remove double indexvalues in loop
古いコメントを表示
Hi,
I have a script where I take the maximum values out of a matrix for each column. I am using the index of the max value to get that one.
Sometimes indexmax is more then 1 value. That is the moment that i only need the highes value of A(:,e)
Now I want to avoid that i am using 2 times the same index. I want to use that index just once for the highes match.
for e = 1:length(RawDatafile)
...
for f = 1:length(CLfile)
...
for g = 1:IndRD
...
percentage = (100/length2)*length3;
A(f,e) = percentage;
end
indexmax = find(A(:,e)==max(A(:,e)));
% this is the place where i need to add a while loop or something to avoid a double used index later in the script.
%something like
%if indexmax(e) == used earlier
% use maximum highes value of (A(indexmax(e)))
%end
I tried the indexmax(1) but on that way its using just the first index and not the one he didn't use before.
5 件のコメント
Bob Thompson
2021 年 2 月 25 日
colmaxes = max(A,[],1);
Dion Theunissen
2021 年 2 月 25 日
Bob Thompson
2021 年 2 月 25 日
Just to make sure I understand, you're indicating that the max values from each column may not be unique to a specific column, and you want to know the first column that contains the max?
[unimaxes, ia, ic] = unique(colmaxes);
'ia' will be the indices for the first appearance of each unique max value, i.e. the first column for each max value.
Dion Theunissen
2021 年 2 月 26 日
Bob Thompson
2021 年 2 月 26 日
Ah, ok, I think I better understand now. I recommend a check to see if the value is already within indexmax.
idm = find(A(:,e)==max(A(:,e))); % Find index of max values
idm = idm(~ismember(idm,indexmax)); % Remove indices already recorded
indexmax(e) = idm(1); % Record next index
回答 (0 件)
カテゴリ
ヘルプ センター および File Exchange で Startup and Shutdown についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!