Loop to a specific point in data set

2 views (last 30 days)
I have a function used to loop through a data set and I want it to stop once the data reaches a specific threshold (In this case, the failure displacement value 'fdValue'. However, I keep getting the error for the if statement:
Undefined function 'ge' for input arguments of type 'cell'.
I think 'cellfun' can be used in this case but I'm not sure how to use it. Any Suggestions? Below is the function
totalRect = 0;
for j = 2:length(bridgeDisp)
%Calculations
rectangle1 = (bridgeDisp(j, 1) - bridgeDisp(j-1, 1))*((bridgeLoad(j, 1) + bridgeLoad(j-1, 1))/2);
totalRect = totalRect + rectangle1;
%If statment error
if bridgeDisp(j, 1) >= fdValue
break;
end
end
  4 Comments
Anas Abou Allaban
Anas Abou Allaban on 13 Oct 2015
Edited: Anas Abou Allaban on 13 Oct 2015
Its supposed to be a variable of type double, its an input from a user
Name Size Bytes Class Attributes
fdValue 1x1 118 cell
I just added
fdValue = str2double(fdValue);
in my main function and that let it loop through...I'm guessing thats the solution. Unless you had another suggestion?
Anas Abou Allaban
Anas Abou Allaban on 13 Oct 2015
fdValue = inputdlg('text');
Thats how it was created, I just noticed that inputdlg does not conver to string and that why I added
str2double

Sign in to comment.

Accepted Answer

per isakson
per isakson on 13 Oct 2015
Edited: per isakson on 13 Oct 2015
Why is fdValue a cell array in the first place?
I assume the cell array contains a numerical scalar. If so replace
bridgeDisp(j, 1) >= fdValue
by
bridgeDisp(j, 1) >= fdValue{1}
or maybe by
bridgeDisp(j, 1) >= str2double(fdValue{1})
if the cell arrays contains a string
  2 Comments
Anas Abou Allaban
Anas Abou Allaban on 13 Oct 2015
Since fdValue was made like this:
fdValue = inputdlg('text'):
So I added i converted it to double by adding on the next line
fdValue = str2double(fdValue);
and that fixed it
per isakson
per isakson on 13 Oct 2015
Edited: per isakson on 13 Oct 2015
Note that not all functions take a cell array of a string in place of a string, as does str2double. Excerpt of documentation
X = str2double(C) converts the strings in the cell array of strings C to double precision.
However, str2num does not!
>> str2double({'17'})
ans =
17
>> str2num({'17'})
Error using str2num (line 33)
Requires string or character array input.

Sign in to comment.

More Answers (0)

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!