Can I sort Find function base on rows?
显示 更早的评论
Hello
I use find function to find location of a vector on my Image, It works, but I have location Order by column.I mean at firs I have location of pixels on column1 then column2,..... Can I change find function to have location of pixels on row1,row2,.....?
I'll appreciate your help.
3 个评论
Roger Stafford
2014-3-4
I don't understand your question, Bkshn. Matlab's 'find' function finds the locations of individual nonzero elements within arrays. It doesn't find "location of a vector on my Image". Could you please explain what you mean by "location of pixels on column1" and "location of pixels on row1,row2,.....?" Please give some very simple examples.
Image Analyst
2014-3-4
编辑:Image Analyst
2014-3-4
I agree - totally confusing. Posting the image would probably help, as well as reading this. And say what you want to do once you have this. Because I suspect you don't even need it. I think you might be able to do what you want to do just with a binary image - no need to get (x,y) coordinates of every single non-zero pixel. I mean, why? Why do you think you need that? There are some situations (e.g. edge linking) but I'd like to know your reason.
bkshn
2014-3-5
编辑:Walter Roberson
2014-3-15
回答(2 个)
Julian
2023-8-3
1 个投票
I couldn't find a nice solution in the documentation, so I assume the best way is instead of:
A = [1 0;
0 1;
1 0];
[row, col] = find(A);
% Results:
% row = [1; 3; 2]
% col = [1; 1; 2]
Transpose the matrix A and exchange the row and column:
[col, row] = find(A.');
% Results:
% row = [1; 2; 3]
% col = [1; 2; 1]
Walter Roberson
2014-3-4
[row, col] = find(.....);
cr = sortrows([col(:), row(:)];
r = cr(:,2);
c = cr(:,1);
now r(K), c(K) is a (row, column) pair and the pairs are ordered so that column varies more slowly. But it normally would anyhow. So perhaps what you want is
[row, col = find(.....);
rc = sortrows([row(:), col(:)]);
r = rc(:,1);
c = rc(:,2);
and that should be ordered with row varying more slowly, "going along rows", the opposite of what would normally happen.
6 个评论
Image Analyst
2014-3-4
Which would be slower than the "normal" way of going down rows in a column before moving over to the next column. So why is this wanted? I'm still waiting to hear.
bkshn
2014-3-5
bkshn
2014-3-14
Walter Roberson
2014-3-15
With regards to your March 5 response, it appears you missed the line
[row, col] = find(.....);
which give values to row and col.
With regards to your more recent question, you have not defined what you want to have happen when there are multiple entries with the same row but with different columns. When you define what you want to have happen in that case, the code can be adjusted.
bkshn
2014-3-16
Walter Roberson
2014-3-16
sort(A,2)
but you are now not working with vectors returned from find(), which are indices with row(K) corresponding to col(K) after the find and row(K), col(K) giving the location of what was found; you are now sorting by array content based upon the full array, which is a different task.
类别
在 帮助中心 和 File Exchange 中查找有关 Matrix Indexing 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!
