About floor function problem.
Afficher commentaires plus anciens
floor(1.999999999999)=1 floor(1.99999999999999999999999999)=2, why is that?
Floor should return the lower integer right? Thanks.
Réponse acceptée
Plus de réponses (1)
Azzi Abdelmalek
le 23 Oct 2012
Just try without floor
a=1.99999999999999999999999999
8 commentaires
C Zeng
le 23 Oct 2012
Azzi Abdelmalek
le 23 Oct 2012
Modifié(e) : Azzi Abdelmalek
le 23 Oct 2012
I mean you don't need to floor it, you will find 2
C Zeng
le 23 Oct 2012
Azzi Abdelmalek
le 23 Oct 2012
Modifié(e) : Azzi Abdelmalek
le 23 Oct 2012
Zeng. from where did you get 1.999999999999999? knowing that matlab don't allow it
C Zeng
le 23 Oct 2012
Azzi Abdelmalek
le 23 Oct 2012
I am not sur what you mean by converting to 2 digits, I think, with 2 digits, you will have four possible digital numbers, And you need a min and max value to be able to do this conversion. Can you explain, or post another question?
Walter Roberson
le 23 Oct 2012
If you are starting with an integer, then dividing by a power of 2 can never result in this kind of round-off. Powers of 2 are represented exactly in binary floating point numbers, and dividing by a power of two effectively only changes the internal binary exponent without changing the mantissa. If you are running into this kind of round-off then either you are not starting with an integer or you are not dividing by a power of 2.
C Zeng
le 26 Oct 2012
Catégories
En savoir plus sur Logical dans Centre d'aide et File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!