faster winner takes all
2 Ansichten (letzte 30 Tage)
Ältere Kommentare anzeigen
I 've made an mplementation of the winner takes all rule (WTA) using a for loop (code bellow). But now I want to "harden" ~8 million values and the loop is very slow (several hours). Any idea for a faster WTA implementation? In detail, if we have a matrix with values in [0,1] we need to replace them with 1 for > 0.75 or with 0 for < 0.75.
function H = wta(S)
% Winner Takes All (WTA) rule
% returns the hard values for S
%
[row,col] = size(S);
for r = 1:row
if S(r,1) > 0.75
H(r,1) = 1;
else
H(r,1) = 0;
end
end
3 Kommentare
Walter Roberson
am 6 Nov. 2011
For 0.75 exactly, as you do not define any replacement conditions, the implication would be that those locations should not be replaced, leaving them 0.75 .
Akzeptierte Antwort
Andrei Bobrov
am 6 Nov. 2011
H = S > .75;
2 Kommentare
Walter Roberson
am 6 Nov. 2011
H = S(:,1) > 0.75;
would be a closer match to the code. The difference would be important if S is two-dimensional or S is a row vector.
Weitere Antworten (0)
Siehe auch
Kategorien
Mehr zu Propagation and Channel Models finden Sie in Help Center und File Exchange
Produkte
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!