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

32 views (last 30 days)
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!

Answers (1)

Jan
Jan on 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 Comments
EB
EB on 6 Apr 2017
Edited: EB on 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 on 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!

Sign in to comment.

Categories

Find more on Data Type Conversion in Help Center and File Exchange

Community Treasure Hunt

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

Start Hunting!