Convert 32 bit HEX to signed floating point

127 visualizaciones (últimos 30 días)
antlhem
antlhem el 1 de Nov. de 2017
Comentada: Walter Roberson el 30 de Nov. de 2022
So far I use the function hexsingle2num to convert a double type number (i.e. 41c1999a = 24.200000762939453) but when I want to use the same to convert ffffffff it gives me NaN, then I have to manually use nhex2dec('ffffffff',32) = -1 (correct answer),same with another example C0728F5C = -3.79. What I am looking for is a way to automatise this process since I have thousands of values. Is there a function in matlab that includes the conversion of HEX to SIGNED floating point?

Respuesta aceptada

Maitreyee Mordekar
Maitreyee Mordekar el 13 de Nov. de 2017
Editada: KSSV el 10 de Dic. de 2019
Hi,
By hexsingle2num function I assume that you are referring to the following File Exchange submission: https://www.mathworks.com/matlabcentral/fileexchange/6927-hexsingle2num
This is one of the several submissions in MATLAB File Exchange on MATLAB Central which is a forum for our product users to interact, exchange information and knowledge, without MathWorks' involvement. You may contact the author of this submission directly for specific questions about the implementation.
However, you can obtain the same results using the following function:
typecast(uint32(hex2dec('C0728F5C')),'single')
Also, if you still need a way to convert hexstring to double precision number then you can consider using hex2num: https://www.mathworks.com/help/matlab/ref/hex2num.html
Hope that helps!
  5 comentarios
Badr Sahib
Badr Sahib el 30 de Nov. de 2022
Hi,
can you please rearrange your command so that i give -3.79 and i can get 'C0728F5C'.
Walter Roberson
Walter Roberson el 30 de Nov. de 2022
num2hex(single(-3.79))

Iniciar sesión para comentar.

Más respuestas (0)

Categorías

Más información sobre GPU Computing en Help Center y File Exchange.

Etiquetas

Community Treasure Hunt

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

Start Hunting!

Translated by