IEEE754标准
以下计算按规格化规定:
S:符号位
M:分数值
E:指数偏移值
单精度浮点数(32bit):
NUM_single = (-1)^S * 1.M * 2^(E-127)
双精度浮点数(64bit):
NUM_double = (-1)^S * 1.M * 2^(E-1023)
十六进制单精度浮点数 与 十进制浮点数 互转:
MATLAB:
a = '45438971'                              % IEEE754 格式十六进制浮点数
b = typecast(uint32(hex2dec(a)),'single')   % 十进制单精度浮点数
sprintf('```%tx',single(b))                 % IEEE754 格式十六进制浮点数
十六进制单精度浮点数转十进制浮点数:
- 方式一
 
a = textread('4.txt','%s');      % 读取字符
n = length(a(:));                % 计算数组长度
b = hex2single(a)
t = linspace(0,1000,n);
plot(t,b, "*");
function number_transform = hex2single(hexString)
binString = dec2bin(hex2dec(hexString));
binString = [char(zeros(size(binString, 1),32-length(binString)) + 48) binString];
if binString(1) == '0'
    number_transform = (1 + single(bin2dec(binString(:, 10:end)))/2^23).*2.^(bin2dec(binString(:, 2:9)) - 127);
else
    number_transform = -(1 + single(bin2dec(binString(:, 10:end)))/2^23).*2.^(bin2dec(binString(:, 2:9)) - 127);
end
end
- 方式二
 
a = '409BFFFF';                                    %# A sample hexadecimal value
b = hex2dec(a);                                    %# Convert to an integer
sign = bitget(b,32);                               %# Compute the sign
exponent = bitget(b,24:31)*2.^(0:7).';             %# Compute the exponent
fraction = bitget(b,1:23)*2.^(-23:-1).';           %# Compute the fraction
value = (-1)^sign*(1+fraction)*2^(exponent-127);   %# Compute the value
fprintf('%1.7f\n',value)                           %# Display the value
取值范围:
博客园 - IEEE754 32位浮点数表示范围
参考链接:
CSDN - IEEE754标准 单精度(32位)/双精度(64位)浮点数解码
博客园 - 二进制小数及 IEEE 浮点表示
MATLAB论坛 - 浮点数在内存中表示方式的理解
MATLAB论坛 - MATLAB怎么实现浮点数到16进制的转换(float)?
IT屋 - 32位十六进制到32位浮点(IEEE 754)在matlab中的转换
IEEE754标准的更多相关文章
- C#中浮点数依IEEE-754标准转二进制串 (MODBUS 浮点数转换)
		
因工作需要,把再串口通信中浮点数与字节流的数据转换函数放在这,转发的,谢谢原作者. 今天花了一天的时间搜罗资料,为了解决一个串口编程的进制转化问题.因为串口传送的浮点数据格式与IEEE-754标准(3 ...
 - 将四个BYTE数值转换成IEEE754标准的浮点数(两种方法:用Addr函数取字节数字的首地址,或者用Absolute关键字)
		
在工作中,经常使用到IEEE754格式的数据.IEEE754格式的数据占四个字节,好像Motorola格式和Intel格式的还不一样. 由于工作中很少和他打交道(使用的软件内部已经处理),就没太在意. ...
 - 第二章 运算方法与运算器(浮点数的加减法,IEEE754标准32/64浮点规格化数)
		
这一章,主要介绍了好多种计算方法.下面,写一点自己对于有些计算(手写计算过程)的见解. 1.原码.反码.补码 原码:相信大家都会写,符号位在前二进制数值在后,凑够位数即可. 反码:原码符号位不变,其他 ...
 - 十进制浮点数转换成IEEE754标准的32浮点数的二进制格式
		
参考: http://jimmygod.blog.163.com/blog/static/43511339200792605627411/ http://blog.csdn.net/archersab ...
 - IEEE754标准浮点格式
		
两种基本浮点格式:单精度和双精度.IEEE单精度格式具有24位有效数字,并总共占用32 位.IEEE双精度格式具有53位有效数字精度,并总共占用64位 两种扩展浮点格式:单精度扩展和双精度扩展.此标准 ...
 - IEEE754标准浮点数表示与舍入
		
原文地址:https://blog.fanscore.cn/p/26/ 友情提示:本文排版不太好,但内容简单,请耐心观看,总会搞懂的. 1. 定点数 对于一个无符号二进制小数,例如101.111,如果 ...
 - 【转载】JS Number类型数字位数及IEEE754标准
		
JS的基础类型Number,遵循 IEEE 754 规范,采用双精度存储(double precision),占用 64 bit.如图 意义 1位用来表示符号位 11位用来表示指数 52位表示尾数 浮 ...
 - JS Number类型数字位数及IEEE754标准
		
JS的基础类型Number,遵循 IEEE 754 规范,采用双精度存储(double precision),占用 64 bit.如图 意义 1位用来表示符号位 11位用来表示指数 52位表示尾数 浮 ...
 - IEEE754标准的浮点数存储格式
		
操作系统 : CentOS7.3.1611_x64 gcc版本 :4.8.5 基本存储格式(从高到低) : Sign + Exponent + Fraction Sign : 符号位 Exponent ...
 
随机推荐
- [Fundamental of Power Electronics]-PART II-9. 控制器设计-9.3 关键项1/(1+T)和T/(1+T)以及闭环传递函数的构建
			
9.3 关键项\(1/(1+T)\)和\(T/(1+T)\)以及闭环传递函数的构建 从式(9.4)到(9.9)的传递函数可以很容易的由图形代数方法进行构建.假设我们已经分析了反馈系统模块,并且已经画出 ...
 - 通过Dapr实现一个简单的基于.net的微服务电商系统(三)——一步一步教你如何撸Dapr
			
目录:一.通过Dapr实现一个简单的基于.net的微服务电商系统 二.通过Dapr实现一个简单的基于.net的微服务电商系统(二)--通讯框架讲解 三.通过Dapr实现一个简单的基于.net的微服务电 ...
 - Latex的使用(Ctex+TeXstudio)
			
1.下载 CTEX Latex 本来是只支持英文的,但是实在太好用了,遂结合中国的团队以及有识之士,开发了这个 CTEX , CTEX 有 TexLive( TexLive 为 Latex 安装包的名 ...
 - 磁盘挖矿时代开启——GitHub 热点速览 v.21.16
			
作者:HelloGitHub-小鱼干 本周的 GitHub 热点非常经常,因为一贫如洗的小鱼干突然发现了发家致富之道:磁盘挖矿.chia-blockchain 是一个将磁盘作为计算资源的项目,简而言之 ...
 - NumPy之:NumPy简介教程
			
目录 简介 安装NumPy Array和List 创建Array Array操作 sort concatenate 统计信息 reshape 增加维度 index和切片 从现有数据中创建Array 算 ...
 - java7与java9中的try-finally关闭资源
			
1.java7中的try 在java7之前,对于一些需要使用finally关闭资源的操作,会显得很臃肿. try { // } catch(Exception e) { // } finally { ...
 - 通过Fiddler 远程 对 安卓手机 iPhone 苹果手机 访问请求抓包  Android  IOS14.4  fiddler代理 无法联网
			
Fiddler 中的设置 1 查看 Fiddler所在 电脑的内网 ip地址. (cmd > ipconfig 查看本机ipv4地址) 2 Fiddler 设置 允许远程设备连接: Fiddl ...
 - C语言头文件到底是什么?
			
C语言头文件到底是什么? 在C语言学习的时候总是会引入这样的语句#include <stdio.h>,书上解释说把stdio.h这个文件的全部内容直接插入到这个位置,然后再经过C语言的编译 ...
 - Django模板引擎
			
Django作为Web框架,需要一种很便利的方法动态地生成 HTML 网页,因此有了模板这个概念.模板包含所需 HTML 的部分代码以及一些特殊语法,特殊语法用于描述如何将视图传递的数据动态插入HTM ...
 - 🍎
			
江湖中有一本练了就能天下无敌的葵花宝典,大家都想得到它.如果有一天葵花宝典被公开了,人人都有机会练,到底是好事还是坏事呢? 这会成为一个灾难. 因为一个人拥有时,练不练是一个人的事.大家都拥有,练不练 ...