int2str returns the wrong result
2 visualizaciones (últimos 30 días)
Mostrar comentarios más antiguos
Kevin
el 8 de Jul. de 2015
Comentada: Kevin
el 8 de Jul. de 2015
>> int2str(73167176531330624919225119674426574742355349194934)
ans =
73167176531330625585928818171611107149744948903936
Anyone know what's going on here? I'm guessing the number is too because when I evaluate the difference between the input and output, the answer is 0.
What causes Matlab to fill in nonsense numbers though?
1 comentario
Respuesta aceptada
James Tursa
el 8 de Jul. de 2015
Editada: James Tursa
el 8 de Jul. de 2015
Your original number has too many digits to store in a double precision number. E.g.,
num2strexact(73167176531330624919225119674426574742355349194934)
ans =
7.3167176531330625585928818171611107149744948903936e49
So what you are seeing as output is exactly what is being stored (i.e., the exact decimal conversion of the binary bit pattern being stored), and there aren't enough mantissa bits in double precision to store more precision.
In fact, the nearest numbers in the double precision set to your original number are:
>> x = 73167176531330624919225119674426574742355349194934
>> num2strexact(x)
ans =
7.3167176531330625585928818171611107149744948903936e49
>> num2strexact(x+eps(x))
ans =
7.3167176531330635970522535241266364210737607344128e49
>> num2strexact(x-eps(x))
ans =
7.3167176531330615201335101101955850088752290463744e49
5 comentarios
James Tursa
el 8 de Jul. de 2015
Well, you can't do a simple copy-paste since MATLAB will assume a double as you found out. So that means a bit more caution on your part. E.g., read as a string directly from the source, or copy-paste with manually adding the apostrophes, or copy-paste into a file and then read the file, etc.
Más respuestas (0)
Ver también
Categorías
Más información sobre Function Creation 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!