group sum with matrix
조회 수: 1 (최근 30일)
이전 댓글 표시
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
Guillaume
2018년 5월 1일
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.
답변 (1개)
Ameer Hamza
2018년 5월 1일
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
참고 항목
카테고리
Help Center 및 File Exchange에서 Structures에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!