Clear Filters
Clear Filters

How can I display a complex decimal result with actual precision value?

6 views (last 30 days)
I am trying to do arithmetic calculation with a number e=0.015923-0.03179523i iteratively to generate an encryption key which is to be expected a high precision complex decimal number. After calculation, I got the result only upto 4 decimal digits. I tried digits() but problem is that the result displayed according to the number given in digits(). I want the result with actual precision value. Please help.

Accepted Answer

Steven Lord
Steven Lord on 3 Nov 2016
The default display format, format short, displays numbers "Short, fixed-decimal format with 4 digits after the decimal point." But note that this has no impact on how the numbers are stored and computed, which is to double precision. Change your display format if you want to see more decimal places.
If you want to compute your complex number using higher precision than double precision, use Symbolic Math Toolbox.
Walter Roberson
Walter Roberson on 4 Nov 2016
to define your number. None of the straightforward input representations will convert to exact number of decimal places. Using rational numbers allows you to make a precise conversion, under the assumption that those really are exact values rather than the rounded versions of the values.
To maintain decimals properly you need to restrict your operations to addition, subtraction, multiplication, and decision, along with exponentials to an integer (which can be calculated by repeated multiplication.)
You might be interested in John D'Errico's file exchange contributions for variable precision arithmetic.

Sign in to comment.

More Answers (1)

Brendan Hamm
Brendan Hamm on 3 Nov 2016
format long
will display the full numeric precision of all values at the command line.

Community Treasure Hunt

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

Start Hunting!