Convert a cell array that contains numbers and NaN values to a matrix

33 visualizzazioni (ultimi 30 giorni)
I have a cell array Acceleration {131341x1} that contains NaN and numbers. I tried to use the cell2mat like
Acc = cell2mat (Acceleration);
but I get following error:
Error using cat
Dimensions of matrices being concatenated are not consistent.
Error in cell2mat (line 83)
m{n} = cat(1,c{:,n});
Any idea how can I solve the problem?
Thanks!

Risposte (1)

Jan
Jan il 5 Apr 2017
The elements of the cell do not have the same size:
W = cellfun('ndims', Acceleration);
isequal(length(unqiue(W)), 1)
S = cellfun('size', Acceleration, 2);
unique(S)
If you have different number of columns, how should the result look like? It does not matter if the values contain NaNs, but only if the sizes match.
Are the cell elements vectors? Then you could pad them with NaNs, see FEX: padcat.
  4 Commenti
EB
EB il 6 Apr 2017
Modificato: EB il 6 Apr 2017
I didn't look careful enough on the data I have. So instead of NaN I have NAN so the dimension is {1x3}. The cell elements that contain numbers are {1x1}.
The first cell element is Acceleration{1,1} = NAN and NAN continue until Acceleration{44811,1} = NAN. Then I have numeric variables from cell element {44812,1} to cell element {131341,1}.
Now I need to convert NAN to NaN and cell2mat function will work. Any idea how to convert NAN to NaN?
Thanks!
EB
EB il 6 Apr 2017
OK, I found a solution. I used this line of code and automatically I got a matrix (131341x1).
Acc = str2num(strvcat(strrep(Acceleration,'NAN','NaN')));
Anyway, thank you for all the help.
Cheers!

Accedi per commentare.

Categorie

Scopri di più su Data Type Conversion in Help Center e File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by