Typecast a hex string to single

33 views (last 30 days)
Michael
Michael on 17 Aug 2022
Commented: Michael on 19 Aug 2022
I have strings of hex values that I need to typecast to single precision values. I don't actually care about the actual single precision value, I am just trying to package the binary into a single datatype for transmission.
I want something like
MyHexString = '7f8e2d38';
out = typecast(MyHexString,'single'); %This doesn't work because typecast needs number
But the typecast.m function requires a numeric value. All I want to do is to produce the single precision number equivalent of the binary data held in my hex string.
FYI: I was using
out = typecast(uint32(hex2dec(MyHexString)),'single');
This worked most of the time but is occasionally produced incorrect results because the hex2dec function produces a double and there is some loss on the subsequent uint32 cast. At least that's what I think is wrong.
How to I package hex into a single datatype?
  2 Comments
James Tursa
James Tursa on 18 Aug 2022
Edited: James Tursa on 18 Aug 2022
"... occasionally produced incorrect results ..."
Can you post some specific examples where this happens? How can there be a loss converting to uint32?

Sign in to comment.

Accepted Answer

Jan
Jan on 18 Aug 2022
Edited: Jan on 18 Aug 2022
str = '7f8e2d38';
vec = uint8(sscanf(str, '%2x'));
num = typecast(vec, 'single')
num = single 4.1379e-05
num = typecast(flip(vec), 'single') % Maybe MSB?
num = single NaN
NaN due to initial 7f
  13 Comments
Walter Roberson
Walter Roberson on 19 Aug 2022
You are transmitting in binary, right? Rather than formatting the single precision data as text?
Because if so then it does not matter that the printable version of a series of bytes might be NaN, as long as the byte sequence is exactly recoverable when transmitted in binary.
format long g
s = '7f8e2d38';
d = uint8(sscanf(s, '%2x').')
d = 1×4
127 142 45 56
df = typecast(fliplr(d), 'single')
df = single
NaN
typecast(df, 'uint8')
ans = 1×4
56 45 142 127
filename = tempname();
fid = fopen(filename, 'w')
fid =
3
fwrite(fid, df, 'single')
ans =
1
fclose(fid)
ans =
0
ls('-l', filename)
-rw-r--r-- 1 mluser worker 4 Aug 19 18:21 /tmp/tp3dab8982_f12e_4817_9513_f7aa0e567ad9
fid = fopen(filename, 'r')
fid =
3
dfr = fread(fid, '*single')
dfr = single
NaN
fclose(fid)
ans =
0
typecast(dfr, 'uint8')
ans = 1×4
56 45 142 127
Michael
Michael on 19 Aug 2022
Yes. That's what I was originally doing i.e. transmitting the raw binary. I believe the main issues I was having is that I was converting the double to a hex and then splitting up that hex. When one part of the resulting split hex string would result in a NaN value, using () +1i() in matlab would then force the other part of the number to be NaN as well. I got around that by using complext(real, imag). The code I posted above that splits the digits rather than the hex seems to do what I need related to transmitting time values. I believe that the transmission of the raw binary would work as well. Thanks for all your help!

Sign in to comment.

More Answers (0)

Products


Release

R2022a

Community Treasure Hunt

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

Start Hunting!