Truncating fractions
3 visualizaciones (últimos 30 días)
Mostrar comentarios más antiguos
If A I have like this
>> A=[0.0001 -0.0012 1.0005 0.0040 1.4125]
A =
0.0001 -0.0012 1.0005 0.0040 1.4125
I want to have A values like this
0.00 0.00 1.00 0.00 1.41
How to do in MATLAB ?
0 comentarios
Respuesta aceptada
Matt Fig
el 7 de Abr. de 2011
Ar = round(A*100)/100
.
.
.
EDIT
Raviteja, the above command does store your values as you want. The problem is not with the values, but with how the values are displayed in MATLAB. You cannot make MATLAB display the values in just any way you want. The closest you can get is:
format bank
Ar = round(A*100)/100
Ab = abs(A) %This looks like what you want, but the full value is there.
2 comentarios
Matt Fig
el 7 de Abr. de 2011
It looks like it is working to me. Did you mean that you want to print out the array? That is a different question.
sprintf('%3.2f ',abs(A.'))
Más respuestas (2)
Oleg Komarov
el 7 de Abr. de 2011
Matt's solution is working. Your question isn't specific enough. You want to display, and not to truncate.
A=[0.0001 -0.0012 1.0005 0.0040 1.4125]
sprintf('%4.2f ',A)
Oleg
2 comentarios
Walter Roberson
el 7 de Abr. de 2011
Raviteja, it is impossible for binary value representation in *any* programming language to store 1.41 _exactly_.
Walter Roberson
el 7 de Abr. de 2011
What you would like to do cannot be done in any finite binary number representation system. 1/10 is an infinitely repeating number in binary, just the same way that 1/7 is an infinitely repeating number in decimal.
You can represent A to two decimal places as character strings for display purposes, but you will not be able to truncate to two decimal places numerically in binary.
>> sprintf('%.53g', 1.41)
ans =
1.4099999999999999200639422269887290894985198974609375
0 comentarios
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!