faster winner takes all
    3 vues (au cours des 30 derniers jours)
  
       Afficher commentaires plus anciens
    
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
  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 .
Réponse acceptée
  Andrei Bobrov
      
      
 le 6 Nov 2011
        H = S > .75;
2 commentaires
  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.
Plus de réponses (0)
Voir également
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!