Grouping an Array with respect to certain elements
4 vues (au cours des 30 derniers jours)
Afficher commentaires plus anciens
Hello,
I have an (Nx5) matrix. Each row corresponds to a struct of data. Data identifiers reside in the first and the second columns of matrix, columns 1 and 2.
A sample matrix:
% srcPort | destPort | send | receive | time
% -------------------------------------------
% 23 | 9212 | 41 | 55 | 202912.0
% 551 | 10563 | 0 | 0 | 55125.0
% 23 | 9212 | 921 | 1020 | 802912.0
% 98 | 5612 | 39 | 24 | 902912.0
I want to be able to group these data w.r.t columns 1 and 2; later want to plot 'time vs send' of each groupped data. Plotting is OK, but I am stuck on determining way to group those data?
4 commentaires
Sriram Tadavarty
le 15 Mar 2020
Hi Erdem,
As i get you, you have an Nx5 matrix, then you wanted to group the first two columns into a separate matrix. So, if the matrix is A (N x 5), then if you define B = A(:,[1 2]); then you will get all the indentifiers in B (N x 2). Is this the same you intended?
Réponse acceptée
Ameer Hamza
le 15 Mar 2020
Modifié(e) : Ameer Hamza
le 15 Mar 2020
Try this
data = [23 9212 41 55 202912.0;
551 10563 0 0 55125.0;
23 9212 921 1020 802912.0;
98 5612 39 24 902912.0];
[~,~,ic] = unique(data(:,[1 2]), 'rows');
seperated_data = arrayfun(@(x) data(ic==x,:), unique(ic), 'UniformOutput', 0);
Each element of cell array have same value in column 1 and 2
seperated_data{1}
seperated_data{2}
seperated_data{3}
Plus de réponses (0)
Voir également
Catégories
En savoir plus sur Logical dans Help Center et File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!