I want to eliminate the whole row of that matrix, if the column 12 contains a 760 - I want that row removed. That's why I used [ ]
Removing a Range of Elements from an array
41 次查看(过去 30 天)
显示 更早的评论
Hi,
I have a matrix M and I am interested in the 12th column which has elements [1 2 3 4..... 540 589 760 761 770 47 46 47 48]
My goal is to get rid of all the elements after 750, including the values less than it.
My first code was
M(M(:,12)>750,:) =[];
but this didn't get rid of 47 46 48..
Mx= find(M(:,12)>750);
Mxmin=min(Mx); %to find the smallest value above 750 (in this case 760)
M(Mxmin:end,12)= [];
currently I am using this code, which gives me an error that says A null assignment can have only one non-colon index.
What am I doing wrong?
采纳的回答
更多回答(1 个)
Jos (10584)
2019-3-28
ix = find(M(:,12) > 750, 1, 'first') % find the row index of the first element in the 12th column of A being larger than 750
M(ix:end,:) = [] % remove all the rows of M starting with this row
0 个评论
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Logical 的更多信息
产品
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!