Borrar filtros
Borrar filtros

issue about ismember wrong output

3 visualizaciones (últimos 30 días)
jason lee
jason lee el 24 de Mzo. de 2020
Editada: Stephen23 el 24 de Mzo. de 2020
a=0.02:0.02:2;
b=0:0.01:5;
ismember(a(6),b)
ans =
logical
0
But it is clear that all elements in a belong to b, so where is the problem?

Respuesta aceptada

Walter Roberson
Walter Roberson el 24 de Mzo. de 2020
You forgot that in binary floating point representation there is no exact equivalent to 0.1 or 0.01 or 0.02, only approximations of those. When you add up those approximations of 0.01 you are not necessarily going to get exactly an approximation of 0.02 especially since you start the 0.02 accumulation at a different start point.
Consider the analogy in decimal of 1/3 to two decimal places. 1/3 decimal is 0.33333333 with the 3 infinitely repeated. To two decimals, 0.33. Now add another of the same to that and you get 0.66. Is that the same as the 2 decimal approximation of 2/3? No, the 2 decimal approximation of 2/3 is 0.67. This illustrates that when you add up truncated approximations that you do not necessarily get the same as the direct value.
The moral of the story is to avoid exact comparisons in floating point. See ismembertol
  3 comentarios
Stephen23
Stephen23 el 24 de Mzo. de 2020
Editada: Stephen23 el 24 de Mzo. de 2020
"but unfortunately, 0.9999999 is a LITTLE smaller than 1."
According to standard mathematics, 0.999... is equal to 1 (different representations of exactly the same number is very common in mathematics).
Walter Roberson
Walter Roberson el 24 de Mzo. de 2020
The .9 repeated == 1 is however only true for infinite precision. If you were to stop at 10^43 decimal places, then you would indeed have a value mathematically less than one.
Physically, if you were to stop at 1e-43 metres, it is unclear what the result would be. There have been serious proposals that space as we know it does not exist below about that small, that everything is a quantum foam.

Iniciar sesión para comentar.

Más respuestas (0)

Categorías

Más información sobre C Matrix API en Help Center y File Exchange.

Productos


Versión

R2019b

Community Treasure Hunt

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

Start Hunting!

Translated by