About floor function problem.
7 visualizaciones (últimos 30 días)
Mostrar comentarios más antiguos
floor(1.999999999999)=1 floor(1.99999999999999999999999999)=2, why is that?
Floor should return the lower integer right? Thanks.
0 comentarios
Respuesta aceptada
Matt J
el 23 de Oct. de 2012
Editada: Matt J
el 23 de Oct. de 2012
If that confuses you, this probably will too:
>> isequal(1.99999999999999999999999999, 2)
ans =
1
Anyway, it has nothing to do with the FLOOR command. It's because your big long decimal can't be distinguished from 2 in floating point.
6 comentarios
Matt J
el 23 de Oct. de 2012
This one contains an overloaded floor function, if that's what you mean
Más respuestas (1)
Azzi Abdelmalek
el 23 de Oct. de 2012
Just try without floor
a=1.99999999999999999999999999
8 comentarios
Walter Roberson
el 23 de Oct. de 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.
Ver también
Categorías
Más información sobre Data Type Conversion en Help Center y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!