Floating Number without "e"?

35 views (last 30 days)
giovanacgois
giovanacgois on 19 May 2018
Commented: Walter Roberson on 19 May 2018
Hello everyone!
I'm a begginer in Matlab struggling to plot a graph. I'm having a hard difficult with my decimal numbers, because I have a very small one. My program is returning like "2.917974892076614e-04" and I didn't want this notation. I need the normal number, even if it is rounded - no problem!
Well, can I round the number to the maximum value acceptable by the var type? Or can I stop my program from writing like this and make it return the original number?

Accepted Answer

Walter Roberson
Walter Roberson on 19 May 2018
If you are using R2015b or later, do not bother trying to work with format or vpa() for this purpose. Instead, use
ax = gca;
ax.XRuler.TickLabelFormat = '%.5f';
or the same with YRuler .
R2015a had a similar facility but the name XRuler and YRuler were different in that one release.
For earlier releases, set the axis XTickLabel or YTickLabel properties as appropriate. For example,
xt = get(gca, 'XTick');
xlab = cellstr( num2str(xt(:), '%.5f') );
set(gca, 'XTickLabel', xlab)
When you work with XTickLabel or YTickLabel then if you zoom or pan then the labels are not automatically recreated in appropriate format to match new appropriate new ticks. When you work with the newer TickLabelFormat, then any new tick brought into view by zoom or pan will be automatically formatted properly.
  2 Comments
giovanacgois
giovanacgois on 19 May 2018
I'm really gratefull for your answer! Thanks for your kindneess!!! You helped me so much.
Walter Roberson
Walter Roberson on 19 May 2018
Go to Preferences -> Variables and change "Default array format" to "long g". Now look at the data again.
The representation of the data as being in floating point format in the Variable Browser has absolutely no effect on graphics.

Sign in to comment.

More Answers (1)

Ameer Hamza
Ameer Hamza on 19 May 2018
Edited: Ameer Hamza on 19 May 2018
If you want to calculate or display very small or very large numbers without using e notation then use vpa
digits(20) % set how many digits to use after the decimal point
vpa(0.0000537523327672541)
ans =
0.000053752332767254096626
Also as you can see that there is a little difference between value inside vpa() and the number displayed by the MATLAB. That is because of finite precision of floating point numbers in MATLAB. The detailed discussion and the method to avoid this can be found here.
  2 Comments
giovanacgois
giovanacgois on 19 May 2018
I came close to solving with your help. But if I need to do operations with these numbers, how can I convert them back to double, considering the decimal places?
Example:
I want a number like: 1.1234, right?
So I have: x=5.3752e-05 to convert.
K>> digits (20)
K>> vpa(x)
ans =
0.000053752000000000003065
It's right, but I want just "0.0001". I tried:
K>> digits(4)
K>> vpa(x)
ans =
5.375e-5
It still returns e.
Ameer Hamza
Ameer Hamza on 19 May 2018
Why do you want "0.0001" your actual number is 0.00005..., If you want to round the number then use
vpa(round(x,4))

Sign in to comment.

Products


Release

R2017a

Community Treasure Hunt

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

Start Hunting!