Effacer les filtres
Effacer les filtres

faster winner takes all

2 vues (au cours des 30 derniers jours)
Dimitris
Dimitris le 6 Nov 2011
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 commentaires
Dimitris
Dimitris le 6 Nov 2011
Correct, it is just that 0.75 is so arbitrary that it does not matter which way is goes. You are correct mathematically though.
Walter Roberson
Walter Roberson le 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 .

Connectez-vous pour commenter.

Réponse acceptée

Andrei Bobrov
Andrei Bobrov le 6 Nov 2011
  2 commentaires
Walter Roberson
Walter Roberson le 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.
Dimitris
Dimitris le 6 Nov 2011
Many thanks.

Connectez-vous pour commenter.

Plus de réponses (0)

Catégories

En savoir plus sur Propagation and Channel Models dans Help Center et File Exchange

Produits

Community Treasure Hunt

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

Start Hunting!

Translated by