필터 지우기
필터 지우기

find matching values from two unequal size arrays

조회 수: 62 (최근 30일)
akk
akk 2018년 11월 10일
댓글: akk 2018년 11월 11일
I have two arrays of unequal length. [lat1 lon1 pCO2] say 200000 values in each column [lat2 lon2] say 100000 values in each column
I want to find where both lat2=lat1 and lon2=lon1, then take the pCO2 value from the first array and plug it into the second array as a new column.

채택된 답변

Stephen23
Stephen23 2018년 11월 10일
편집: Stephen23 2018년 11월 10일
>> A1 = [1,2,3;4,5,6;7,8,9]
A1 =
1 2 3
4 5 6
7 8 9
>> A2 = [1,2;0,0;0,0;4,5]
A2 =
1 2
0 0
0 0
4 5
>> [ida,idb] = ismember(A2,A1(:,1:2),'rows');
>> A2(:,3) = NaN;
>> A2(ida,3) = A1(idb(ida),3)
A2 =
1 2 3
0 0 NaN
0 0 NaN
4 5 6

추가 답변 (2개)

madhan ravi
madhan ravi 2018년 11월 10일
[ia,c,ib]=ismember(lat1,lat2)
  댓글 수: 2
akk
akk 2018년 11월 10일
Thanks, but lon1 must also equal lon2
madhan ravi
madhan ravi 2018년 11월 10일
[ia1,c1,ib1]=ismember(lon1,lon2)

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


Andrei Bobrov
Andrei Bobrov 2018년 11월 10일
Let:
a = [lat1 lon1 pCO2];
b = [lat2 lon2];
b(:,3) = a(ismember(a(:,1:2),b,'rows'),3);
  댓글 수: 1
akk
akk 2018년 11월 10일
Thanks! This works! Only, because there are some rows in b without a match in a, b (:,3) is smaller than the number of rows in b. Is there a way to fill in those missing rows with a nan instead?

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

카테고리

Help CenterFile Exchange에서 Interpolation of 2-D Selections in 3-D Grids에 대해 자세히 알아보기

태그

Community Treasure Hunt

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

Start Hunting!

Translated by