cell2array with different dimension cells.....

26 visualizaciones (últimos 30 días)
Shivang Patel
Shivang Patel el 22 de Feb. de 2015
Editada: Stephen23 el 22 de Feb. de 2015
my cellarray is 1x4....
I want to convert it into array... but dimensions are different for last cell...
For that, i was tried this code...
maxSize = max(cellfun(@numel,imgData)); %# Get the maximum vector size
fcn = @(x) [x, nan(1,maxSize-numel(x))]; %# Create an anonymous function
rmat = cellfun(fcn,imgData,'UniformOutput',false); %# Pad each cell with NaNs
rmat = vertcat(rmat{:}) %# Vertically concatenate cells
and it show me error !!
so, any solution for this problem... Thank you in advance...

Respuesta aceptada

Stephen23
Stephen23 el 22 de Feb. de 2015
Editada: Stephen23 el 22 de Feb. de 2015
There are a couple of issues here
  1. You need to use size , not numel to get the size of the array in one dimension. Use size's second dimension option to specify which dimension you want to measure.
  2. You concatenate the NaN-padding using square brackets to join them horizontally [x,nan(..)]. Square brackets can concatenate only along the first or second dimension (i.e. [x;y] and [x,y] respectively), but you require the third dimension (because this is where your arrays have different sizes). For this you can use padarray.
As an alternative, you could use cat to concatenate them in the dimension that they are different (e.g. the third in your example). This does not require adding the NaN's, so you need to decide what is best for your situation.
cat(3,imgData{:})
  1 comentario
Shivang Patel
Shivang Patel el 22 de Feb. de 2015
@Stephen Cobeldick you generous...
thanks for suggestion... to use " cat " or " NAN "...
I prefer cat ... Because i just want to make 3 dimensional array to combining 4 different cell array...
A lot's of thanks...

Iniciar sesión para comentar.

Más respuestas (0)

Categorías

Más información sobre Creating and Concatenating Matrices 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!

Translated by