Dear all,
I have to round a number to a specified number of decimal points.Anybody can help me??
Thank you

추가 답변 (2개)

Walter Roberson
Walter Roberson 2011년 10월 18일

0 개 추천

That cannot be done exactly in binary floating point arithmetic. Just the same way that you cannot exactly represent 1/3 in a fixed number of decimal digits, 1/100 cannot be exactly represented in binary digits.
It is possible to display something with two decimal places, such as by using
disp(sprintf('%.2f', 343.945584))
but you cannot store 343.95 exactly in a floating point number: try
sprintf('%.99f\n', 343.95)
and notice that it is not exactly 343.95 that is stored.
If you do not mind that you can only numerically get a close approximation, then use:
round(N*100)/100

댓글 수: 1

Image Analyst
Image Analyst 2011년 10월 18일
Walter, as you know this is a frequently asked question, since you've repeated it bazillions of times. Yet it's not in the FAQ (that I could find anyway). I'm thinking it should be added to section 6 on Math/Algorithms. What do you think? You can add it, or I could if you want.

댓글을 달려면 로그인하십시오.

Pritesh Shah
Pritesh Shah 2011년 10월 18일

0 개 추천

Also, Please see Cell, fix and round function for the same. If you want decimal point fix,
Also, You can you format function.
Thank you

댓글 수: 1

Walter Roberson
Walter Roberson 2011년 10월 18일
I think you mean ceil rather than cell.
The "format" function cannot be used to get a precise number of decimal places, except for "format bank"

댓글을 달려면 로그인하십시오.

카테고리

도움말 센터File Exchange에서 Logical에 대해 자세히 알아보기

태그

질문:

2011년 10월 18일

Community Treasure Hunt

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

Start Hunting!

Translated by