It's a bug?

1 Ansicht (letzte 30 Tage)
Emiliano Rosso
Emiliano Rosso am 29 Nov. 2018
Bearbeitet: madhan ravi am 29 Nov. 2018
I discovered a potential bug and I want to report it:
Matlab R2018a windows 10
alfa=-0.0052+(61-1)*0.0001;
reasoning this is 0.0060-0.0052=0.0008=8e-04
so:
alfa2=8e-04;
isequal(alfa,alfa2)
ans
0
if you open alfa variable you can see:
8.000000000000004e-04
in fact if you round alfa:
alfa3=round(alfa,10);
isequal(alfa2,alfa3)
ans
1
That's all Thanks
  1 Kommentar
Bruno Luong
Bruno Luong am 29 Nov. 2018
Welcome to the club, you are one more person who confuses about finite precision floating point calculation.

Melden Sie sich an, um zu kommentieren.

Akzeptierte Antwort

madhan ravi
madhan ravi am 29 Nov. 2018
Bearbeitet: madhan ravi am 29 Nov. 2018
It‘s called floating point comparison just search with the tag floating-point in this forum you will find lot of reasons
abs(alfa-alfa2)<1e-04

Weitere Antworten (0)

Produkte

Community Treasure Hunt

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

Start Hunting!

Translated by