Binary String to double?

8 views (last 30 days)
Cory Zuber
Cory Zuber on 12 Apr 2018
Edited: Walter Roberson on 12 Apr 2018
Here is a piece of code where I take a double and convert it to a binary string.
S=[1.123,2,3];
q = quantizer('double');
B = num2bin(q,S(1));
Which returns
B = '0011111111110001111101111100111011011001000101101000011100101011'
In my code, I randomly change one bit, but I need a way to convert it back to a double.

Answers (1)

Walter Roberson
Walter Roberson on 12 Apr 2018
Edited: Walter Roberson on 12 Apr 2018
bin2num(q, B)
Note:
If you randomly change the first bit then you will get the negative of the original value. If you randomly change one of the 11 bits after that, then you will affect the entire scale of the number, equivalent to multiplying or dividing by a power of 2.
If the number happened to quantize to 0, then if you change one of the last 52 bits then you would have a "denormalized number", which would be a value between 4.94065645841247e-324 and 2.2250738585072e-308

Categories

Find more on Numeric Types in Help Center and File Exchange

Community Treasure Hunt

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

Start Hunting!