Limiting Precision on MATLAB

10 Ansichten (letzte 30 Tage)
Robert Dominski
Robert Dominski am 26 Feb. 2018
Beantwortet: Robert Dominski am 26 Feb. 2018
I have a condition for a switch statement. For example:
% Program variables and input prompts
runProgram = 1;
i = 1;
prompt_massRatio = 'Enter m/M Ratio: ';
prompt_Us = 'Enter Static friction: ';
prompt_Uk = 'Enter kinetic friction: ';
prompt_theta = 'Enter block angle: ';
% Graph variables F vs. m/M
Fplot = [];
massFraction = [];
% Program start
while runProgram == 1
% Calculation Variables
m_M = input(prompt_massRatio);
angle = input(prompt_theta);
theta = angle*(pi/180);
Us = input(prompt_Us);
Uk = input(prompt_Uk);
g = 9.81;
T = m_M*g;
W = g*sin(theta);
Fs = cos(theta)*g*Us;
Fk = cos(theta)*g*Uk;
% Conditions
forceSum = T - W;
switch (true)
case (forceSum < 0)
In this case, when forceSum is calculated for the conditions of m_M = 0.5, angle = 30, we get a value that is essentially zero but MATLAB does not read it as zero for the case statement. I.E. forceSum returns 8.8818e-016.
Any idea of making MATLAB read this value as 0?
Thanks for any help.

Akzeptierte Antwort

David Fletcher
David Fletcher am 26 Feb. 2018
Could try forceSum=int32(T-W)

Weitere Antworten (3)

James Tursa
James Tursa am 26 Feb. 2018
Bearbeitet: James Tursa am 26 Feb. 2018
With floating point calculations you often need to use tolerances, so this
if( forceSum < 0 )
would be coded something like this instead
if( abs(forceSum) < tol ) % for some appropriate tolerance
So all of your conditional tests should probably be modified into some type of tolerance test.

Walter Roberson
Walter Roberson am 26 Feb. 2018

Robert Dominski
Robert Dominski am 26 Feb. 2018
Thanks for the help and links. It worked.
Cheers! You guys are great.

Kategorien

Mehr zu Get Started with MuPAD 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