Discover MakerZone

MATLAB and Simulink resources for Arduino, LEGO, and Raspberry Pi

Learn more

Discover what MATLAB® can do for your career.

Opportunities for recent engineering grads.

Apply Today

New to MATLAB?

how to round the decimal point?

Asked by bsd

bsd (view profile)

on 27 Sep 2011

Hai,

I need to round the decimal number to 2 decimal places. What is the function in matlab, to the above rounding off. Looking for your reply.

BSD

0 Comments

bsd

bsd (view profile)

Tags

Products

No products are associated with this question.

3 Answers

Answer by Jan Simon

Jan Simon (view profile)

on 27 Sep 2011
x = rand * 1000;
y = floor(x * 100) / 100;

See: floor, ceil, round, fix.

A general method to find help is searching in the documentation:

docsearch round

4 Comments

Jan Simon

Jan Simon (view profile)

on 27 Sep 2011

In you original question you ask for "rounding off". If you want to round to the nearest: round(0.1698 * 100) / 100 replies 0.17

Walter Roberson

Walter Roberson (view profile)

on 27 Sep 2011

>> sprintf('%.99g\n',round(0.1698 * 100) / 100)
ans =
0.1700000000000000122124532708767219446599483489990234375

>> num2hex(round(0.1698 * 100) / 100 )
ans =
3fc5c28f5c28f5c3
>> num2hex(round(0.1698 * 100) / 100 - 8*eps(.01))
ans =
3fc5c28f5c28f5c2

If you compare the hex of the two floating point values, you will note that this second value is the first representable value smaller than the original value

>> sprintf('%.99g\n',round(0.1698 * 100) / 100 - 8*eps(0.01))
ans =
0.169999999999999984456877655247808434069156646728515625

and you can see from the extended printout that it is below 0.17 whereas the other value was above 0.17. We have thus experimentally demonstrated that there is no exact representation in binary floating point arithmetic for 0.17 exactly.

Jan Simon

Jan Simon (view profile)

on 28 Sep 2011

@BSD: Does Walter's correct argument concern your work? Or is 0.1700000000000000xyz... accurate enough for your demands?

Jan Simon

Jan Simon (view profile)

Answer by Walter Roberson

Walter Roberson (view profile)

on 27 Sep 2011

This is not possible in binary floating point arithmetic, unless the rounded fraction happens to end up being 0.0, 0.25, 0.5, or 0.75

Binary floating point arithmetic cannot exactly represent the fraction 1/100 in any finite amount of storage, for the same reason that decimal arithmetic cannot exactly represent the fraction 1/7 in any finite amount of storage.

0 Comments

Walter Roberson

Walter Roberson (view profile)

Answer by Jigar Gada

Jigar Gada (view profile)

on 28 Aug 2012

Thanks a lot.. It was so simple.

0 Comments

Jigar Gada

Jigar Gada (view profile)

Contact us