count number of indices
    10 visualizaciones (últimos 30 días)
  
       Mostrar comentarios más antiguos
    
    gummiyummi
 el 6 de Ag. de 2020
  
I have an array with 7 columns filled with data. Column 2 has 0s then a 1 then 0s and then a -1 in repeating order. The number of 0s between a 1 and a -1 varies. 
In column 2 I want to count for each cell which has the value 1, the number of cells there are until the next cell with value -1. If the count is bigger than 100, I want to add the index of the cell with value 1, to the first available cell in column 8. 
I have come furthest with the following code:
n=1;
for i = 1:length(arrayA)
    if arrayA(i,2) == 1
        if abs(find(arrayA(i,2)==1) - find(arrayA(:,2)==-1)) > 200
            arrayA(n,8)=i;
            n=n+1;
        end
    end
end
yet column 8 still doesn't have any values when I run the whole thing. 
Pretty sure the problem is line 3 but have no more ideas left on how I could make it work... 
2 comentarios
  Rik
      
      
 el 6 de Ag. de 2020
				Where do you define n? Also, find might return multiple values, in which case you have a logical array for you if statement, which I always have to look up what it does. Are you sure you implemented that line correctly?
Respuesta aceptada
  gummiyummi
 el 7 de Ag. de 2020
        2 comentarios
  Rik
      
      
 el 7 de Ag. de 2020
				If the number of elements in I and J are equal, you can use find to remove the loop.
Más respuestas (1)
  Matt J
      
      
 el 6 de Ag. de 2020
        
      Editada: Matt J
      
      
 el 6 de Ag. de 2020
  
      Using group1s from the File Exchange
col2=arrayA(:,2);
I=find(col2==1);
H=histcounts(nonzeros(group1s(~abs(col2))));
loc=I(H(2:2:end)>100);
arrayA(loc,8)=loc;
Ver también
Categorías
				Más información sobre Matrix Indexing en Help Center y File Exchange.
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!


