Find the indexes of all the zeros or nonzeros in a cell array that contains empty cells
    12 visualizaciones (últimos 30 días)
  
       Mostrar comentarios más antiguos
    
    Dennis Huver
 el 15 de Sept. de 2017
  
    
    
    
    
    Comentada: Dennis Huver
 el 15 de Sept. de 2017
            Is there a way to find the indexes of all nonzero elements in a cell that contains empty cells too? I know of the way to first replace all of empty cells with 0 and they use the find and cellfun function. But is there a simpler way? Lets say A={2 5 0 10 0 [] 22 0 13} index=find(~cellfun(@isempty,A)) % index for non-empty cells Is there a way to find indexes for those who contain positive numbers only? Thanks btw using MatLab 2015a
1 comentario
  Stephen23
      
      
 el 15 de Sept. de 2017
				
      Editada: Stephen23
      
      
 el 15 de Sept. de 2017
  
			Why are you storing numeric data in a cell array? Numeric arrays are the best kind of array for storing numeric data. Note that find is not required if you just want to replace empty arrays with zero:
A(cellfun('isempty',A)) = {0}
Respuesta aceptada
  Stephen23
      
      
 el 15 de Sept. de 2017
        
      Editada: Stephen23
      
      
 el 15 de Sept. de 2017
  
      >> A = {2,5,0,10,0,[],22,0,13};
>> cellfun(@(a)~isempty(a)&&a>0,A)
ans =
  1  1  0  1  0  0  1  0  1
But note that doing numeric operations on the contents of a cell array is quite inefficient. You could be much better off putting numeric data into a numeric array, and then all numeric operations will be much simpler and much more efficient:
>> A = {2,5,0,10,0,[],22,0,13};
>> A(cellfun('isempty',A)) = {NaN};
>> V = [A{:}]
V =
     2     5     0    10     0   NaN    22     0    13
>> V>0
ans =
  1  1  0  1  0  0  1  0  1
Más respuestas (0)
Ver también
Categorías
				Más información sobre Matrix Indexing en Help Center y File Exchange.
			
	Productos
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!

