group sum with matrix
1 view (last 30 days)
Show older comments
With below matrix, I would like to have a sum of the third column and a sum of the fourth column by groups that are the combination of the first and second column.
1 1 1 0.5
1 1 2 0.5
1 1 3 0.5
1 1 4 0.5
1 1 5 0.5
1 2 6 0.5
1 2 7 0.5
1 2 8 0.5
1 2 8 0.5
1 2 9 0.5
2 1 0.1 2
2 1 0.2 2
2 1 0.3 2
2 1 0.4 2
2 1 0.5 2
2 2 0.6 2
2 2 0.7 2
2 2 0.8 2
2 2 0.8 2
2 2 0.9 2
So, here is what I am desiring for
1 1 15 2.5
1 2 38 2.5
2 1 1.5 10
2 2 3.8 10
1 Comment
Guillaume
on 1 May 2018
This is very similar to the question you asked yesterday. The same method can be used for both, so please read and learn from the answers you're given as otherwise people will start ignoring your questions.
Answers (1)
Ameer Hamza
on 1 May 2018
The following code will summarise the table as described in question
groups = findgroups(A(:, 1), A(:, 2));
[~, uniqueGroupsIndex] = unique(groups);
uniqueGroups = A(uniqueGroupsIndex, 1:2);
s1 = splitapply(@(x) sum(x), A(:, 3:end), findgroups(A(:, 1), A(:, 2)) );
final = [uniqueGroups s1];
4 Comments
See Also
Categories
Find more on Structures in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!