필터 지우기
필터 지우기

Mapping locations of similar rows in two matrices

조회 수: 1 (최근 30일)
Patrick Mboma
Patrick Mboma 2014년 11월 1일
댓글: Patrick Mboma 2014년 11월 1일
Dear all,
I have two matrices A and B of respective sizes [na,m] and [nb,m], with na>=nb. Both matrices have the same number of columns. All the rows in B are unique while the rows in A can be duplicated, but are all members of B. I would like to create a mapping between A and B and one very inefficient way to do that is as follows:
out=nan(na,1);
for ii=1:na
% for each row of A, I search its location in B
out(ii)=find(all(bsxfun(@minus,A(ii,:),B),2)==0);
end
This works well but becomes prohibitively expensive for large na and nb. And so my question is whether there is a way of getting rid of the for loop and/or creating this mapping differently.
Thanks,
P.

채택된 답변

Guillaume
Guillaume 2014년 11월 1일
This is exactly what ismember is for. The 2nd output argument will give you the locations:
[~, out] = ismember(A, B, 'rows');
  댓글 수: 4
Guillaume
Guillaume 2014년 11월 1일
For that specialised function to be any faster than ismember you would have to write it as a mex file.
And if ismember(..., 'rows') is implemented efficiently, it's possible the only saving you could get would be to skip the parsing of the 'rows' argument
Patrick Mboma
Patrick Mboma 2014년 11월 1일
A million thanks Guillaume

댓글을 달려면 로그인하십시오.

추가 답변 (1개)

the cyclist
the cyclist 2014년 11월 1일
Use the ismember function, with the 'rows' option.

카테고리

Help CenterFile Exchange에서 Logical에 대해 자세히 알아보기

태그

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by