IEEE浮点数标准

阅读笔记:Computer System : A Programmmer's Perspective

基本概念

IEEE浮点数标准采用

\[V=(-1)^s\times M\times2^E
\]

的形式表示一个数:

  • 符号: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位

三个字段的编码:

  1. 单独的s直接编码符号s

  2. k位的阶码字段:

    \[exp=e_{k-1}e_{k-2}\cdots e_{1}e_{0}
    \]

编码E

  1. n位的小数字段:
    \[frac=f_{n-1}f_{n-1}\cdots f_{1}f_{0}
    \]

编码M

编码的三种情况

规范化值

当exp的位即不全为0也不全为1时(即单精度范围:1~254 双精度范围:1~2046),即为规范化的值。这种情况下,阶码字段可以被解释为以偏置量(bias)形式表示的有符号整数

\[E=exp-bias
\]

其中:exp即为阶码字段表示的值,并有

\[bias=2^{k-1}-1
\]

故对于单精度bias=127,双精度bias=1023,由此可得:

\[E=exp-127
\]

或者是:

\[E=exp-1023
\]

因此指数的范围:

\[E\in [-126,127]
\]

或者是:

\[E\in [-1022,1023]
\]

小数字段被解释为描述小数值f,0≤f<1,即:

\[f=\sum_{i=0}^{n-1}f_i*2^{i-n}
\]

尾数定义为:

\[M=1+f
\]

非规范化值

当阶码域全为0时,表示的数是非规范化的,此时的阶码为

\[E=1-bias
\]

故E=-126(单精度)或者E=-1022(双精度)而尾数:

\[M=f
\]

同理0≤f<1,即:

\[f=\sum_{i=0}^{n-1}f_i*2^{i-n}
\]

用途:

  • 表示数值0
  • 表示非常接近0的数

特殊值

  1. 无穷大

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

  1. NaN

阶码全为1且小数字段不全为0,这不是一个数(Not a Number)

总结

值的表示:

\[V=(-1)^s\times M\times2^E
\]

单精度:

  1. 规范值:

    E=exp-bias

    bias=127

    M=1+f

  2. 非规范:

    E=1-bias=-126

    bias=127

    M=f

双精度:

  1. 规范值:

    E=exp-bias

    bias=1023

    M=1+f

  2. 非规范值

    E=1-bias=-1022

    bias=1023

    M=f

示例

Q1.将-3.33333333转换为单精度表示

首先,将这个小数转化为二进制的小数形式(利用×2法)

\[-3.33333333_{10}=-11.010101010101..._{2}
\]

规范化:

\[-3.33333333_{10}=-1.1010101010101..._{2}\times2^1
\]

因此:

\[s=1
\]
\[exp=E+bias=1+127=128_{10}=1000 0000_{2}
\]
\[M=1.1010101010..._2\Rightarrow f=1010101010..._2
\]

从而可以写出单精度表示

\[11000000010101010101010101010101_2=C0555555_{16}
\]

Q2.给出如图8位二进制数在IEEE标准的浮点格式

首先对于规范化值:

\[E=exp-bias=exp-7
\]

对于非规范值:

\[E=1-bias=-6
\]

可以写出如下表格:

IEEE浮点数标准的更多相关文章

  1. 浮点数在计算机中的表示(IEEE浮点数标准)

    转载自:https://wdxtub.com/2016/04/16/thin-csapp-1/

  2. 基于 IEEE 754 标准的 单精度浮点数计算方式 (未完成)

    def dec2bin(dec): if dec < 0: s = ' dec = dec * (-1) else: s = ' e = 127 dec = float(dec) r = int ...

  3. 打印一个浮点数组,会输出字符串"Hello, world“ & 浮点数的二进制表示(IEEE 754标准)

    #include <stdio.h> #include<stdlib.h> int main() { float a[3] = { 1143139122437582505939 ...

  4. 【算法】解析IEEE 754 标准

    目录结构: contents structure [-] 浮点数的存储过程 次正规数(Denormalized Number) 零(zero) 非数值(NaN) 无穷大(infinity) 除数为0. ...

  5. python 警惕 IEEE 754标准

    双精度浮点数格式,即IEEE 754标准 >>> 0.1+0.2 0.30000000000000004 >>> (0.1+0.2)==0.3 False > ...

  6. IEEE 754标准--维基百科

    IEEE二进制浮点数算术标准(IEEE 754) 是20世纪80年代以来最广泛使用的浮点数运算标准,为许多CPU与浮点运算器所采用.这个标准定义了表示浮点数的格式(包括负零-0)与反常值(denorm ...

  7. 计算机中如何表示数字-07IEEE754浮点数标准

    由于不同机器所选用的基数.尾数位长度和阶码位长度不同,因此对浮点数的表示有较大差别,这不利于软件在不同计算机之间的移植.为此,美国IEEE(电器及电子工程师协会)提出了一个从系统角度支持浮点数的表示方 ...

  8. IEEE浮点数float、double的存储结构

    众所周知,C的float.VB的Single都是32位浮点数变量类型(也叫单精度浮点数),C的double和VB的Double则都是64位的浮点数变量类型(也叫双精度浮点数).有些编译器还支持更屌的l ...

  9. IEEE 754标准

    IEEE 754-1985 was an industry standard for representing floating-point numbers in computers, officia ...

随机推荐

  1. Luogu P4105 [HEOI2014]南园满地堆轻絮

    题解 传送门 其实只要找差距最大的逆序对就好了 答案就是此逆序对的差 /2 代码 (代码很短) #include<bits/stdc++.h> using namespace std; # ...

  2. Redis发布订阅使用方法

    Redis发布订阅 发布订阅模式中发布消息的为publisher即发布者,接收消息的为subscriber即订阅者.在Redis中,所有的消息通过channel即频道进行发布,一个发布者可以向多个ch ...

  3. PHP 获取当前页面的URL信息

    //获取当前的域名: echo $_SERVER['SERVER_NAME']; //获取来源网址,即点击来到本页的上页网址 echo $_SERVER["HTTP_REFERER" ...

  4. 编排yml文件剖析

    # yaml格式的pod定义文件完整内容: apiVersion: v1       #必选,版本号,例如v1 kind: Pod       #必选,Pod metadata:       #必选, ...

  5. python数据类型之Number(数字)

    一.Number(数字) 关注公众号"轻松学编程"了解更多. 数据类型 ​ 为什么会有不同的数据类型? ​ 计算机是用来做数学计算的机器,因此它可以处理各种数值,但是计算机能够处理 ...

  6. 【SpringBoot】11.Springboot整合SpringMVC+Mybatis(上)

    Springboot整合SpringMVC+Mybatis 需求分析:通过使用Springboot+SpringMVC+Mybatis 整合实现一个对数据库表users表的CRUD操作. 1.创建项目 ...

  7. iframe框架下的某一页面跳转到另外一个页面

    //iframe只在当前页跳转 window.location = "/Admin/Blog/Index"; 只在当前页跳转 而不是整个页面都跳转

  8. 主动关闭 time wait结构体

    /* * This is a TIME_WAIT sock. It works around the memory consumption * problems of sockets in such ...

  9. Java 合并多个文件内容到一个文件(递归遍历某个文件夹下所有文件)

    这段代码通过Java I/O流API实现将多个文件合并到一个文件中,输出为文本文件,提供一个支持语法高亮的网站,http://www.codeinword.com/ 适合粘贴代码到word文档,小巧实 ...

  10. SpringBoot加载配置文件的几种方式

    首先回忆一下在没有使用SpringBoot之前也就是传统的spring项目中是如何读取配置文件,通过I/O流读取指定路径的配置文件,然后再去获取指定的配置信息. 传统项目读取配置方式 读取xml配置文 ...