Splitting a matrix based on certain values in the rows
조회 수: 18 (최근 30일)
이전 댓글 표시
I have a matrix A like this:
A = [911 911;
0 2;
8 5;
7 3;
911 911;
5 3;
1 6;
6 7;
911 911;
3 5;
8 4];
I want to split the matrix A into three matrices (A1,A2,A3) based on the row values 911 like this:
A1 = [0 2; 8 5; 7 3];
A2 = [5 3; 1 6; 6 7];
A3 = [3 5; 8 4];
I need to do this thing inside a for loop which will give the spitted matrix one after another.
댓글 수: 3
Jan
2019년 2월 19일
@Atta: A,B,C, ... suffers from exactly the same problems as A1, A2, A3, ... With using a cell array and and index, the code is fast and flexibel. You can e.g. simply run it for 12'781'986 rows without getting mad while typing the code with manually hidden names of variables.
채택된 답변
Stephen23
2019년 2월 19일
편집: Stephen23
2019년 2월 19일
No loop required:
>> idx = cumsum(all(A==911,2));
>> row = 1:numel(idx);
>> fun = @(r){A(r(2:end),:)};
>> C = accumarray(idx,row(:),[],fun);
>> C{:}
ans =
0 2
8 5
7 3
ans =
5 3
1 6
6 7
ans =
3 5
8 4
댓글 수: 4
Jos (10584)
2019년 2월 20일
% Pad each cell with rows of 911,
% so that it has the same number of rows as D
% using CELLFUN with an anonymous padding function using REPMAT
C2 = cellfun(@(m) [m ; repmat(911, size(D,1)-size(m,1),size(m,2))], C)
추가 답변 (1개)
Jan
2019년 2월 19일
편집: Jan
2019년 2월 19일
A = [911 911;
0 2;
8 5;
7 3;
911 911;
5 3;
1 6;
6 7;
911 911;
3 5;
8 4];
index = [find(A(:, 1) == 911); size(A, 1) + 1];
n = numel(index) - 1;
Result = cell(1, n);
for k = 1:n
Result{k} = A(index(k):index(k+1)-1, :); % [EDITED]
end
댓글 수: 2
Jan
2019년 2월 19일
@Atta: Yes, I had a typo in my code. It is fixed now. Sometimes I expect the readers to fix bugs, when they are not too hard.
The result is a cell array and you access it as Result{1}. This is much smarter than hiding an index in the name of a variable.
참고 항목
카테고리
Help Center 및 File Exchange에서 Logical에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!