need help to reduce time for each loop

i have 2 tables taxidata.pickup and TaxiRegionsandZones.pickup, i want to compare those two col and if they match it should creat a new col in taxidata.pickupzones (as TaxiRegionsandZones is categorical ), the new taxidata.pickupzones should have the name to that category.
for k = 1 : length(taxidata.PickupZone)
% for Lower Manhattan
for i = 1: length(TaxiRegionsandZones.LowerManhattan)
if taxidata.PickupZone(k) == TaxiRegionsandZones.LowerManhattan(i)
taxidata.PickupRegion(k) = "LowerManhattan";
end
end
i have tried this but it is taking a vary long time, is there any method to reduce the time

답변 (1개)

KSSV
KSSV 2021년 3월 26일

0 개 추천

You need not to run loop for this. Read about function ismemeber, ismembertol, knnsearch.
[lia,lob] = ismember(taxidata.PickupZone,TaxiRegionsandZones.LowerManhattan) ;

댓글 수: 4

the king
the king 2021년 3월 26일
so how should i add that to my table
Rik
Rik 2021년 3월 26일
Did you experiment with what ismember does? Did you read the documentation?
the king
the king 2021년 3월 26일
yea, i am getting lob as index but just not getting how to add that to table.
i am new to matlab.
Rik
Rik 2021년 3월 26일
Can you see how lia and lob are related to the values of k and i for which you did the assignment?
If you have trouble with Matlab basics you may consider doing the Onramp tutorial (which is provided for free by Mathworks).

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

카테고리

도움말 센터File Exchange에서 Loops and Conditional Statements에 대해 자세히 알아보기

태그

질문:

2021년 3월 26일

댓글:

Rik
2021년 3월 26일

Community Treasure Hunt

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

Start Hunting!

Translated by