Filter löschen
Filter löschen

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

26 Ansichten (letzte 30 Tage)
EB
EB am 5 Apr. 2017
Kommentiert: EB am 6 Apr. 2017
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!

Antworten (1)

Jan
Jan am 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 Kommentare
EB
EB am 6 Apr. 2017
Bearbeitet: EB am 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 am 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!

Melden Sie sich an, um zu kommentieren.

Kategorien

Mehr zu Cell Arrays finden Sie in Help Center und File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by