Why do I get: "Error using sum Invalid option. Option must be 'double' " even though my variable is a double?

28 views (last 30 days)
Hi,
I have this for loop:
n = numel(first_three);
test_first_three = {};
for dd = 1:n
test_first_three{dd} = sqrt(sum(first_three{dd}(:,1:3),1,1).^2);
end
Whenever I try to run it I get the error,
Error using sum
Invalid option. Option must be 'double', 'native', 'default', 'omitnan', or 'includenan'.
It isn't clear to me why that is happening since my cell of doubles array is a double.
What I am trying to achieve with this loop is to apply this function: dist = sqrt( dx.^2 + dy.^2 + dz.^2 ); to every row and its adjacent row.
Here dx, dy and dz are the differences (subtracted from one another) between one row (ex: row 2) and its adjacent row (ex: row 1). That way row 2 - row 1, row 3 - row 2, row 4 - row 3 ... and so on.
Does anyone know how I can solve this?

Accepted Answer

Walter Roberson
Walter Roberson on 25 Mar 2022
At the moment you have code which is effectively
sum(x,1,1)
where x happens to have 3 columns.
The first 1 there would give the dimension to sum over (so, sum each column), but the second 1 there is in the slot where MATLAB expects only output class 'double', 'native', 'default', or else the flag about how to treat nans. No numeric value is expected in that third parameter.
  4 Comments
lil brain
lil brain on 25 Mar 2022
Is there perhaps also a solution without using diff? Using diff seems to mess with later steps in my data analysis as I am not able to 2nd order derivative twice.
Walter Roberson
Walter Roberson on 25 Mar 2022
temp = first_three{dd}(:,1:3);
sqrt(sum( (temp(2:end,:) - temp(1:end-1,:)).^2, 2))
But you should expect exactly the same problem with secod order derivative later, as subtracting adjacent rows like this is exactly what diff() is going to do (but with a more efficient internal implementation.)

Sign in to comment.

More Answers (0)

Categories

Find more on Loops and Conditional Statements 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!