IEEE浮点数标准
IEEE浮点数标准
阅读笔记:Computer System : A Programmmer's Perspective
基本概念
IEEE浮点数标准采用
\]
的形式表示一个数:
符号:s决定数的正负
尾数:M是一个二进制小数,范围是1~2-epsilon 或者 0~1-epsilon
阶码:E的作用是对浮点数加权,权重为2的E次幂
下图为单精度(32位)与双精度(64位)的位示意图:
单精度:
- s:1位
- exp:k=8位
- frac:n=23位

双精度:
- s:1位
- exp:k=11位
- frac:n=52位

三个字段的编码:
单独的s直接编码符号s
k位的阶码字段:
\[exp=e_{k-1}e_{k-2}\cdots e_{1}e_{0}
\]
编码E
- n位的小数字段:
\[frac=f_{n-1}f_{n-1}\cdots f_{1}f_{0}
\]
编码M
编码的三种情况
规范化值

当exp的位即不全为0也不全为1时(即单精度范围:1~254 双精度范围:1~2046),即为规范化的值。这种情况下,阶码字段可以被解释为以偏置量(bias)形式表示的有符号整数
\]
其中:exp即为阶码字段表示的值,并有
\]
故对于单精度bias=127,双精度bias=1023,由此可得:
\]
或者是:
\]
因此指数的范围:
\]
或者是:
\]
小数字段被解释为描述小数值f,0≤f<1,即:
\]
尾数定义为:
\]
非规范化值

当阶码域全为0时,表示的数是非规范化的,此时的阶码为
\]
故E=-126(单精度)或者E=-1022(双精度)而尾数:
\]
同理0≤f<1,即:
\]
用途:
- 表示数值0
- 表示非常接近0的数
特殊值
- 无穷大

阶码全为1且小数字段全为0,根据符号位表示±∞
- NaN

阶码全为1且小数字段不全为0,这不是一个数(Not a Number)
总结
值的表示:
\]
单精度:
规范值:
E=exp-bias
bias=127
M=1+f
非规范:
E=1-bias=-126
bias=127
M=f
双精度:
规范值:
E=exp-bias
bias=1023
M=1+f
非规范值
E=1-bias=-1022
bias=1023
M=f
示例
Q1.将-3.33333333转换为单精度表示
首先,将这个小数转化为二进制的小数形式(利用×2法)
\]
规范化:
\]
因此:
\]
\]
\]
从而可以写出单精度表示
\]
Q2.给出如图8位二进制数在IEEE标准的浮点格式

首先对于规范化值:
\]
对于非规范值:
\]
可以写出如下表格:

IEEE浮点数标准的更多相关文章
- 浮点数在计算机中的表示(IEEE浮点数标准)
转载自:https://wdxtub.com/2016/04/16/thin-csapp-1/
- 基于 IEEE 754 标准的 单精度浮点数计算方式 (未完成)
def dec2bin(dec): if dec < 0: s = ' dec = dec * (-1) else: s = ' e = 127 dec = float(dec) r = int ...
- 打印一个浮点数组,会输出字符串"Hello, world“ & 浮点数的二进制表示(IEEE 754标准)
#include <stdio.h> #include<stdlib.h> int main() { float a[3] = { 1143139122437582505939 ...
- 【算法】解析IEEE 754 标准
目录结构: contents structure [-] 浮点数的存储过程 次正规数(Denormalized Number) 零(zero) 非数值(NaN) 无穷大(infinity) 除数为0. ...
- python 警惕 IEEE 754标准
双精度浮点数格式,即IEEE 754标准 >>> 0.1+0.2 0.30000000000000004 >>> (0.1+0.2)==0.3 False > ...
- IEEE 754标准--维基百科
IEEE二进制浮点数算术标准(IEEE 754) 是20世纪80年代以来最广泛使用的浮点数运算标准,为许多CPU与浮点运算器所采用.这个标准定义了表示浮点数的格式(包括负零-0)与反常值(denorm ...
- 计算机中如何表示数字-07IEEE754浮点数标准
由于不同机器所选用的基数.尾数位长度和阶码位长度不同,因此对浮点数的表示有较大差别,这不利于软件在不同计算机之间的移植.为此,美国IEEE(电器及电子工程师协会)提出了一个从系统角度支持浮点数的表示方 ...
- IEEE浮点数float、double的存储结构
众所周知,C的float.VB的Single都是32位浮点数变量类型(也叫单精度浮点数),C的double和VB的Double则都是64位的浮点数变量类型(也叫双精度浮点数).有些编译器还支持更屌的l ...
- IEEE 754标准
IEEE 754-1985 was an industry standard for representing floating-point numbers in computers, officia ...
随机推荐
- model的基础操作
1.创建表 1.1 Meta源信息 from django.db import models class UserInfo(models.Model): username = models.CharF ...
- Python爬虫之线程池
详情点我跳转 关注公众号"轻松学编程"了解更多. 一.为什么要使用线程池? 对于任务数量不断增加的程序,每有一个任务就生成一个线程,最终会导致线程数量的失控,例如,整站爬虫,假设初 ...
- [Luogu P2341] [HAOI2006]受欢迎的牛 (缩点+bitset)
题面 传送门:https://www.luogu.org/problemnew/show/P2341 Solution 前排提示,本蒟蒻做法既奇葩又麻烦 我们先可以把题目转换一下. 可以把一头牛喜欢另 ...
- rclone 云盘同步工具的正确打开方式
Rclone 是一款的命令行工具,支持在不同对象存储.网盘间同步.上传.下载数据. 官网网址:https://rclone.org/ Github 项目:https://github.com/ncw/ ...
- 微信小程序跳转到微信公众号
我这里是uniapp里的操作 微信开发者工具配置 微信小程序官网地址:official-account 公众号关注组件. 当用户扫小程序码打开小程序时,开发者可在小程序内配置公众号关注组件,方便用户快 ...
- 2.1获取Git仓库-2.2记录每次更新到仓库
2.1 获取 Git 仓库 获取 Git 仓库通常有两种方式 将尚未进行版本控制的本地目录转换为 Git 仓库: 从其它服务器 克隆 一个已存在的 Git 仓库. 在已存在目录中初始化仓库 首先进入该 ...
- 一款基于.NET Core的认证授权解决方案-葫芦藤1.0开源啦
背景 18年公司准备在技术上进行转型,而公司技术团队是互相独立的,新技术的推动阻力很大.我们需要找到一个切入点.公司的项目很多,而各个系统之间又不互通,导致每套系统都有一套登录体系,给员工和客户都带来 ...
- Spider_基础总结5--动态网页抓取--元素审查--json--字典
# 静态网页在浏览器中展示的内容都在HTML的源码中,但主流网页使用 Javascript时,很多内容不出现在HTML的源代码中,此时仍然使用 # requests+beautifulsoup是不能够 ...
- SpringBoot中BeanValidation数据校验与优雅处理详解
目录 本篇要点 后端参数校验的必要性 不使用Validator的参数处理逻辑 Validator框架提供的便利 SpringBoot自动配置ValidationAutoConfiguration Va ...
- tcp输入数据 慢速路径处理 && oob数据 接收 && 数据接收 tcp_data_queue
大致的处理过程 TCP的接收流程:在tcp_v4_do_rcv中的相关处理(网卡收到报文触发)中,会首先通过tcp_check_urg设置tcp_sock的urg_data为TCP_URG_NOTYE ...