conversion between numpy float16 and hex string

Convert a numpy float16 data to hex string

import numpy as np

a = np.float16('1.125')
a_hex = hex(a.view(np.int16))  

Remember to view any float format as int befort you hex them. This way you could get the same hex value as np.to_file(a).

Convert a hex string to numpy float16 data

import numpy as np

a = np.float16('1.125')
a_hex_str = hex(a.view(np.int16))  

a_hex_byte = bytes.fromhex(a_hex_str)
a_int16 = struct.unpack('h', h_hex_byte)  # sometimes you need h_hex_byte[::-1] because of big/little endian
a_np_int16 = np.int16(a_int16)
a_np_float16 = a_np_int16.view(np.float16)

assert a_np_float16 == a

A graph to help understand this

np.float16 ←→  np.int16 ← struct.unpack()
                   ↓             ↑  
                  hex() → bytes.fromhex()
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

友情链接更多精彩内容