IEEE 754 浮点数加减运算
小数的十进制和二进制转换
移码
定义:[X]移 = X + 2n ( -2n ≤ X < 2n )
X为真值,n为整数的位数
数值位和X的补码相同,符号位与补码相反
舍入方法
0舍1入
保留4位尾数:
0 00100 -> 0 0010
/*
**0直接舍去
*/
1 00101 -> 1 0011
/*
**1进位
*/
1 11011 -> 1 1110
末位恒置1
保留4位尾数:
0 00100 -> 0 0011
1 00101 -> 1 0011
1 11011 -> 1 1101
IEEE 754
32位单精度
| Sign | 8位阶码 [偏移量为28-1-1 = 127的非标准移码] | 23位尾数 |
|---|
| 真值表达式 | E的取值范围 |
|---|---|
| N = (-1)s × 2E-127 × 1.M | 1到254 |
64位双精度
| Sign | 11位阶码 [偏移量为211-1-1 =1023的非标准移码] | 252位尾数 |
|---|
| 真值表达式 | E的取值范围 |
|---|---|
| N = (-1)s × 2E-1023 × 1.M | 1到2046 |
为了确保浮点数表示的唯一性,约定 0 ≤ M < 1
各字段的含义( 以单精度为例 )
规范浮点数
1 ≤ E ≤ 254
真值表达式:N = (-1)s × 2E-127 × 1.M,尾数部分隐含开头的1
- 最小的正规格化数
| 0 | 0000 0001 | 0000 0000 0000 0000 0000 000 |
|---|
- 最大的正规格化数
| 0 | 1111 1110 | 1111 1111 1111 1111 1111 111 |
|---|
非规范浮点数
E = 0,M ≠ 0
| s | 0000 0000 | ≠ 0 |
|---|
真值表达式:N = (-1)s × 2-126 × 0.M,尾数部分不隐含开头的1
最小的正非规格化数
| s | 0000 0000 | 0000 0000 0000 0000 0000 001 |
|---|
最大的正非规格化数
| s | 0000 0000 | 1111 1111 1111 1111 1111 111 |
|---|
浮点数0
E = 0,M = 0
| s | 0000 0000 | 0000 0000 0000 0000 0000 000 |
|---|
有+0.0和-0.0两种零
无穷大
E全为1(255),M = 0
正无穷大
| 0 | 1111 1111 | 0000 0000 0000 0000 0000 000 |
|---|
负无穷大
| 1 | 1111 1111 | 0000 0000 0000 0000 0000 000 |
|---|
NaN Not a Number
计算sqrt(-1)或∞-∞时会返回NaN
E全为1(255),M ≠ 0
| s | 1111 1111 | ≠ 0 |
|---|
为什么要使用127作为偏移量而不是128

https://stackoverflow.com/questions/8909841/why-does-the-ieee-754-standard-use-a-127-bias
溢出
上溢:阶码大于机器的最大阶码,不能继续运算,一般要进行中断处理
下溢:阶码小于最小阶码,当做零处理,机器可以继续运算
规格化浮点数
当尾数结果为00.0x…x 或 11.1x…x
尾数左移,阶码减1,直到尾数形式为00.1x…x 或 11.0x…x当尾数结果为01.x…x 或 10.x…x
尾数右移,阶码加1,尾数形式变为00.1x…x 或 11.0x…x
阶码加减
设:
AE、BE为阶码,CE为结果阶码
[ AE + BE ]移
= ( AE + BE ) + 127
= ( AE + 127 ) + ( BE + 127 ) - 127
= [ AE ]移 + [ BE ]移 -127
= [ AE ]移 + [ BE ]移 + [ -127 ]补
= [AE]移 + [BE]移 + 129
= ( [AE]移 + [BE]移 + 129 ) mod 28
[ AE - BE ]移
= ( AE - BE ) + 127
= ( AE + 127 ) - ( BE + 127 ) + 127
= [ AE ]移 - [ BE ]移 + 127
= ( [AE]移 - [BE]移 + 127 ) mod 28
浮点数加减
设:
A = 2AE × AM,B = 2BE × BM
AE、BE为阶码,AM、BM为尾数

舍入
右移时:
- 0舍1入
- 末位恒置1
例题
x = 0.5, y = 0.4375, 32位单精度表示,求x + y和x - y
转换为二进制
- 0.5 x 2 = 1.0 取1
0.1 → 1.0 x 2 -1
[x]浮 =
| 0 | 0111 1110 | 0000 0000 0000 0000 0000 000 |
|---|---|---|
| -1 + 127 = 126 |
- 0.4375 x 2 = 0.875 取0
- 0.8750 x 2 = 1.750 取1
- 0.7500 x 2 = 1.500 取1
- 0.5000 x 2 = 1.000 取1
-0.0111 → 1.11 x 2-2
[y]浮 =
| 1 | 0111 1101 | 1100 0000 0000 0000 0000 000 |
|---|---|---|
| -2 + 127 = 125 |
求阶差
(0111 1110 - 0111 1101 + 127)mod 28 = 1
y向x对齐
y = 0.111 x 2-1
[y]浮 =
| 1 | 0111 1110 | 1110 0000 0000 0000 0000 000 |
|---|
尾数加减
| + |
|---|
| 00.0000 0000 0000 0000 0000 000 |
| 00.0010 0000 0000 0000 0000 000 |
| 00.0010 0000 0000 0000 0000 000 |
结果为00.0x…x,左规
得到1.0… x 2-4
结果 = 0.0625
| 0 | 0111 1011 | 0000 0000 0000 0000 0000 000 |
|---|---|---|
| -4 + 127 = 123 |
| - |
|---|
| 00.0000 0000 0000 0000 0000 000 |
| 00.1110 0000 0000 0000 0000 000 |
| 00.1110 0000 0000 0000 0000 000 |
结果 = 0.9345
| 0 | 0111 1110 | 1110 0000 0000 0000 0000 000 |
|---|
IEEE 754 浮点数加减运算的更多相关文章
- IEEE 754 浮点数在计算机中的表示方法
IEEE二进制浮点数算术标准(IEEE 754)是20世纪80年代以来最广泛使用的浮点数运算标准,为许多CPU与浮点运算器所采用.这个标准定义了表示浮点数的格式(包括负零-0)与反常值(denorma ...
- velocity加减运算注意格式 ,加减号的左右都要有空格
velocity加减运算注意格式 ,加减号的左右都要有空格 #set( $left= $!biz.value - $vMUtils.getReturnMoney($!biz.billBuy) )
- [Swift]LeetCode592. 分数加减运算 | Fraction Addition and Subtraction
Given a string representing an expression of fraction addition and subtraction, you need to return t ...
- C语言中指针变量的加减运算
1.指针变量中存放的是地址值,也就是一个数字地址,例如某指针变量中的值是0x20000000,表示表示此指针变量存放的是内存中位于0x20000000地方的内存地址.指针变量可以加减,但是只能与整型数 ...
- 大整数加减运算的C语言实现
目录 大整数加减运算的C语言实现 一. 问题提出 二. 代码实现 三. 效果验证 大整数加减运算的C语言实现 标签: 大整数加减 C 一. 问题提出 培训老师给出一个题目:用C语言实现一个大整数计算器 ...
- Linux中日期的加减运算
Linux中日期的加减运算 目录 在显示方面 在设定时间方面 时间的加减 正文 date命令本身提供了日期的加减运算. date 可以用来显示或设定系统的日期与时间. 回到顶部 在显示方面 使用者可以 ...
- void *指针的加减运算
1.手工写了一个程序验证void *指针加减运算移动几个字节: //本程序验证空类型指针减1移动几个字节 #include <stdio.h> int main(int argc, cha ...
- Leetcode 592.分数加减运算
分数加减运算 给定一个表示分数加减运算表达式的字符串,你需要返回一个字符串形式的计算结果. 这个结果应该是不可约分的分数,即最简分数. 如果最终结果是一个整数,例如 2,你需要将它转换成分数形式,其分 ...
- C语言中指针的加减运算
参考文章,值得一看 char arr[3]; printf("arr:\n%d\n%d\n%d\n", arr, arr + 1, arr + 2); char *parr[3]; ...
随机推荐
- 如何攻击Java Web应用
越来越多的企业采用Java语言构建企业Web应用程序,基于Java主流的框架和技术及可能存在的风险,成为被关注的重点. 本文从黑盒渗透的角度,总结下Java Web应用所知道的一些可能被利用的入侵点. ...
- Python3-sqlalchemy-orm 创建关联表带外键并插入数据
#-*-coding:utf-8-*- #__author__ = "logan.xu" import sqlalchemy from sqlalchemy import crea ...
- nRF52832蓝牙iBeacon广播
开发环境 SDK版本:nRF5_SDK_15.0.0 芯片:nRF52832-QFAA 蓝牙iBeacon实现 iBeacon的核心就是广播,不需要进行连接,通过在广播包中插入信息然后广播出去. 广播 ...
- 哦?原来这就是 JVM 垃圾!
大家都知道,JVM 有垃圾回收的机制,垃圾回收的前提是要知道:什么是垃圾!然后再是如何识别垃圾! 什么是垃圾 垃圾,本质上就是没有引用的对象(们),下面来介绍两种垃圾 1. 没有引用指向的对象 下图是 ...
- Input 只能输入数字,数字和字母等的正则表达式
JS只能输入数字,数字和字母等的正则表达式 1.文本框只能输入数字代码(小数点也不能输入) <input onkeyup="this.value=this.value.replace( ...
- 大数据最后一公里——2021年五大开源数据可视化BI方案对比
个人非常喜欢这种说法,最后一公里不是说目标全部达成,而是把整个路程从头到尾走了一遍. 大数据在经过前几年的野蛮生长以后,开始与数据中台的概念一同向着更实际的方向落地.有人问,数据可视化是不是等同于数据 ...
- v-for列表渲染之数组变动检测
1.简单举一个v-for列表渲染例子 <template> <div> <ul> <li v-for="item in items"> ...
- 集合遍历数组三种常用方式(Collecton和Map)
Collection集合遍历数组的三种方式: 迭代器 foreach(增强for循环) JDK1.8之后的新技术Lambda 迭代器: 方法:public Iterator inerator():获取 ...
- C++打字小游戏
从@小蔡编程 那里获得的灵感,原文地址:https://www.cnblogs.com/xiaocaibiancheng/p/15158997.html 那篇文章是说python写打字游戏的,本文就用 ...
- HCNP Routing&Switching之路由控制、路由策略和IP-Prefix List
前文我们了解了IS-IS路由聚合和认证相关话题,回顾请参考https://www.cnblogs.com/qiuhom-1874/p/15306645.html:今天我们来聊一聊路由控制技术中的路由策 ...