Floating point to 16 bit hexadecimal
24 visualizaciones (últimos 30 días)
Mostrar comentarios más antiguos
Tousif Ahmed
el 23 de Abr. de 2018
Comentada: Tousif Ahmed
el 24 de Abr. de 2018
Hello all, how can i convert floating point decimal to 16 bit hexadecimal value?
Thank you
2 comentarios
Guillaume
el 24 de Abr. de 2018
Specifying the encoding used would be helpful. Is it IEEE 754 half precision you're after?
Respuesta aceptada
Ameer Hamza
el 24 de Abr. de 2018
Editada: Ameer Hamza
el 24 de Abr. de 2018
You can use this file exchange submission. It will convert your number to 16-bit half precision format. But instead of returning as a string, it will return the equivalent uint16 MATLAB object. To get binary string, you can do this,
halfPrecisionNumber = halfprecision(1.2); % halfprecision() is provided in the file exchange package.
halfPrecisionString = dec2bin(halfPrecisionNumber, 16);
In case you face the following error on running the package
"Floating point bit pattern is not IEEE 754"
you can try following
- Open halfprecision.c file.
- Add following to include section
#include <stdint.h>
- Replace 4 #define with the following macros
#define INT16_TYPE int16_t
#define UINT16_TYPE uint16_t
#define INT32_TYPE int32_t
#define UINT32_TYPE uint32_t
- Run mex halfprecision.c.
5 comentarios
Guillaume
el 24 de Abr. de 2018
Editada: Guillaume
el 24 de Abr. de 2018
Use dec2hex instead of dec2bin in Ameer's answer. Do not use num2hex which is not all suited for what you want.
halfPrecisionNumber = halfprecision(1.2); % halfprecision() is provided in the file exchange package. halfPrecisionHex = dec2hex(halfPrecisionNumber, 4);
Más respuestas (0)
Ver también
Categorías
Más información sobre Particle & Nuclear Physics en Help Center y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!