计算机系统基础笔记(10)——浮点数

前言

结合第四篇观看 效果更好^^
数值型分为两类

  • 定点数
    • 整数
    • 小数
  • 浮点数
    注意:小数点不用占用二进制位

第一部分 编码

1.小数的二进制表示

  • 位置计数法:小数点左边的权重是正指数,右边的数是负指数,如图
    在这里插入图片描述
    由此可知,数字形如 0.11111…… (二进制数) 是一个十分接近但小于1的数字
  • 由于这种缘故 可表示的数字精度有限,只能精确的表示 x/2^k 这种形式的数字

2.编码有理数

  • 采用 v = x × 2^𝑦 的方式
    • 这种方式在v的绝对值远大于0或远小于1时有用

3.浮点数的表示(重点)

  • 数字的形式表示
    • s 符号位:符号位 决定正负
    • M 尾数:决定数字的精度,一个小数,通常在[1.0,2.0) 或 [0.0, 1.0)
    • E 阶码:决定数字的范围
      在这里插入图片描述
  • 编码方式
    • 符号位-阶码-尾数
      在这里插入图片描述
  • 几种精度的浮点数(常考32位)
    • 单精度:32位
      在这里插入图片描述

    • 双精度:64位
      在这里插入图片描述

    • 扩展精度:80位(仅Intel支持)
      在这里插入图片描述

4.IEEE 754 标准(浮点数编码)

规格化数

-当 exp ≠ 000…0 且 exp ≠ 111…1 时

  • 阶码ExpE = Exp – Bias
    • E :真值 即真实值乘以的2的指数
    • Bias: bias = 2^k‐1 – 1, k是exp的位宽(因此可知这是固定的,32位是127,64位是1023
  • 尾数MM = 1.xxx….x (二进制数)
    • 包含一个隐式前置的1,即小数点前面的1(这个1存在但不会记录到编码上,相当于节省了一位^^)
    • xxx…x: 为frac域的各位的编码
    • 最小值:frac = 000…0 (M = 1.0 )
    • 最大值:frac = 111…1 (M = 2.0 - ε)(上面已经说过了,这个会无限的接近于1,加上小数点前的1就是2-ε)

举个例子吧~
我们现在有一个浮点数
数值为float f = 15213.0

  • 转化成二进制就是
    15213 = 11101101101101
    = 1.1101101101101 × 2 ^13

从这里就可以得到尾数和阶码的信息了

  • 尾数是1.1101101101101
    补上单精度的位数并去掉前置1就是尾数
    11011011011010000000000

  • 阶码部分
    真实值E是13(2的指数)
    Bias是127(32位)
    因此Exp是127+13 = 140
    转换成二进制就是 10001100

而符号位为0(正数)
因此我们有以下编码
在这里插入图片描述

非规格化数
  • 当 exp = 000…0 时
  • 阶码
    • E = - Bias + 1
  • 尾数M = 0.xxx…x(二进制)
    • 包含一个隐式前置的0
    • xxx…x: 为frac域的各位的编码
  • 当 exp = 000…0, 且 frac = 000…0 时
    • 注意区别:+0 和 -0区别
    • 表示 0
  • 当 exp = 000…0, 且 frac ≠ 000…0 时
    • 非常接近于0.0的数字
    • 等间距的
特殊值
  • 当 exp = 111…1 时
  • 当 exp = 111…1 且 frac = 000…0 时
    • 表示无穷 ∞
    • 意味着运算出现了溢出
    • 正向溢出,或负向溢出
  • 当 exp = 111…1 且 frac ≠ 000…0 时
    • 不是一个数字
    • 表示数值无法确定
    • NaN
      如图,
      在这里插入图片描述
      在这里插入图片描述

第二部分 运算

在这里插入图片描述

1.几种舍入模式

这是重点

  • 向下舍入
    ◼ 舍入结果接近但不会大于实际结果
  • 向上舍入
    ◼ 舍入结果接近但不会小于实际结果
  • 向 0 舍入
    ◼ 舍入结果向 0 的方向靠近
    ◼ 如果为正数,舍入结果不大于实际结果
    ◼ 如果为负数,舍入结果不小于实际结果
向偶数舍入(重点)
  • 浮点数运算默认的舍入模式
    ◼其他的舍入模式都会统计偏差
    ◼ 一组正数的总和将始终被高估或低估
  • 适用于舍入至小数点后任何位置
    ◼ 当数字正好处在四舍五入的中间时
    ◼ 向最低位为偶数的方向舍入

下面是例子
就是四舍五入的偶数版(一般是按照四舍五入,如果在中间的话就向偶数方向舍入
在这里插入图片描述

不同舍入之间的比较

我们可以看一下不同舍入之间的差异
第一行是向偶数舍入
第二行是向零舍入
第三四行向下和向上舍入
在这里插入图片描述

2.基本思想

  • 首先计算出精确的值
  • 将结果调整至目标的精度
    ◼ 如果阶码值过大,可能会导致溢出
    ◼ 可能会进行舍入以满足尾数的位宽

3.浮点数乘法

(-1)s1 M1 2E1 × (-1)s2 M2 2E2

  • 精确的结果是(-1)s M 2E
    • 符号位 (Sign) s:s1^s2
      尾数 (Significand) M:M1 ×M2
      阶码 (Exponent) E:E1 + E2
  • 修正
    • 符号位 (Sign) s:s1^s2
      尾数 (Significand) M: M1 ×M2
      阶码 (Exponent) E:E1 + E2
      在这里插入图片描述

4.浮点数加法

(-1)s1 M1 2E1 × (-1)s2 M2 2E2(假设E1 > E2)

  • 精确的结果 (Exact Result):(-1)s1 M 2E
    ◼ 符号位 s 和尾数 M:有符号数对齐后相加的结果
    ◼ 阶码 (Exponent) E:E2
  • 修正
    • 如果M ≥ 2,右移M,并增大E的值
      如果M < 1,左移M k位,然后E减去k
      如果E超出范围,溢出
      对M进行舍入以满足frac的位宽精度要求

5.C语言中的浮点数

  • C语言中支持两种精度的浮点数(float单精度 double 双精度)
  • 类型转换
    • double/float → int
      • 截断尾数
      • 向0舍入
      • 越界和NaN的情况通常设置为Tmin Tmax
    • int → double
      • 精准转换 因为int的位宽小于53(double)
    • int → float
      • 浮点数舍入模式(上面介绍的)

下面是例子
在这里插入图片描述
各类型的强制转换结果如下 解释在右^^
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/851280.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

贪心算法例子

贪心算法概述 贪心算法是一种在每一步选择中都做出局部最优选择的算法,以期望通过一系列局部最优选择达到全局最优。贪心算法在许多优化问题中表现良好,特别是在某些特定类型的问题中能够保证找到最优解。 活动选择问题(Activity Selection Problem)背包问题(贪心解法)霍…

MySQL数据库(二)和java复习

一.MySQL数据库学习(二) (一).DQL查询数据 DQL&#xff08;Data Query Language&#xff09;是用于从数据库中检索数据的语言。常见的 DQL 语句包括 SELECT、FROM、WHERE、GROUP BY、HAVING 和 ORDER BY 等关键字&#xff0c;用于指定要检索的数据、数据源、过滤条件、分组方…

格式化后硬盘数据能恢复吗?硬盘数据恢复这样做!

硬盘是电脑中必备的数据存储设备&#xff0c;另外还有移动硬盘。移动硬盘存储空间非常大、性价比高、便于携带&#xff0c;给我们带来和很多便利。但是和其他存储设备一样&#xff0c;各种硬盘也会出现各种问题&#xff0c;比如常见的格式化硬盘导致数据丢失的问题。 怎么样恢复…

【软考的系统分析师的考题考点解析2025】

2024-2025系统分析师考试&#xff08;简称软考&#xff09;是计算机技术与软件专业技术资格&#xff08;水平&#xff09;考试中的高级资格考试&#xff0c;主要考察考生在系统分析、系统设计、项目管理等方面的知识和技能。以下是软考系统分析师的常见考点、考题和重点&#x…

【源码】Spring Data JPA原理解析之事务执行原理

Spring Data JPA系列 1、SpringBoot集成JPA及基本使用 2、Spring Data JPA Criteria查询、部分字段查询 3、Spring Data JPA数据批量插入、批量更新真的用对了吗 4、Spring Data JPA的一对一、LazyInitializationException异常、一对多、多对多操作 5、Spring Data JPA自定…

Python 虚拟环境 + 嵌入式 部署方案

Python 虚拟环境 嵌入式 部署方案 开发阶段1. 在虚拟环境下开发 Python 项目 部署阶段1. 创建项目文件夹2. 准备嵌入器 Python 解释器3. 处理第三方库4. 修改 ._pth 文件添加 Python 运行环境 5. 添加启动 bat 脚本最终目录结构参考资料 开发阶段 1. 在虚拟环境下开发 Python…

PHP 寿光蔬菜大棚宣传平台-计算机毕业设计源码88288

摘 要 随着科学技术的飞速发展&#xff0c;各行各业都在努力与现代先进技术接轨&#xff0c;通过科技手段提高自身的优势&#xff1b;对于寿光蔬菜大棚宣传平台当然也不能排除在外&#xff0c;随着网络技术的不断成熟&#xff0c;带动了寿光蔬菜大棚宣传平台&#xff0c;它彻底…

ISO 19115-2:2019 附录C XML 模式实现

C.1 XML 模式 本文件中定义的 UML 模型的 XML 模式在 ISO/TS 19115-3 中定义的适当 XML 命名空间中提供。新增内容包括: 命名空间前缀模式文件名Metadata for ACquisition (mac)acquisitionInformationImagery.xsdMetadata for Resource Content (mrc)contentInformationImag…

BPF:BCC(BPF Compiler Collection)工具集认知

写在前面 博文内容为 《BPF Performance Tools》 读书笔记整理内容涉及 BCC 工具整体介绍理解不足小伙伴帮忙指正 &#x1f603;,生活加油 不必太纠结于当下&#xff0c;也不必太忧虑未来&#xff0c;当你经历过一些事情的时候&#xff0c;眼前的风景已经和从前不一样了。——村…

内存EDAC在AMD异构场景的应用

在异构系统中&#xff0c;AMD通过将CPU与GPU的数据织物网络通过定制的xGMI链接连接&#xff0c;实现了统一访问&#xff0c;使得GPU节点的数据织物网络如同CPU节点一样可访问。这样的设计使得系统能够高效地整合CPU与GPU资源&#xff0c;提升数据处理速度和效率&#xff0c;特别…

从河流到空气,BL340工控机助力全面环保监测网络构建

在环保监测领域&#xff0c;智能化、高效率的监测手段正逐步成为守护绿水青山的新常态。其中&#xff0c;ARMxy工业计算机BL340凭借其强大的处理能力、高度的灵活性以及广泛的兼容性&#xff0c;在水质监测站、空气质量检测、噪音污染监控等多个环保应用场景中脱颖而出&#xf…

MySQL深分页优化

MySQL中的深分页问题通常是指当我们通过LIMIT语句查询数据&#xff0c;尤其是在翻到较后面的页码时&#xff0c;性能会急剧下降。例如&#xff0c;查询第1000页的数据&#xff0c;每页10条&#xff0c;系统需要跳过前9990条数据&#xff0c;然后才能获取到所需的记录&#xff0…

Vue基础面试题(一)

1.Vue的基本原理 Vue.js的核心原理在于其响应式的数据绑定机制&#xff0c;当创建一个Vue实例时&#xff0c;Vue会遍历每个属性&#xff0c;用Object.defineProperty转化为getter和setter。这样使得Vue可以追踪属性的变化&#xff0c;在属性被修改和访问时通知变化。每个组件也…

PostgreSQL的视图pg_tables

PostgreSQL的视图pg_tables pg_tables 是 PostgreSQL 中的一个系统视图&#xff0c;用于显示当前数据库中所有用户定义的表的信息。这个视图提供了关于表的名称、所属模式&#xff08;schema&#xff09;、所有者以及表类型等详细信息。 pg_tables 视图的主要列 列名类型描述…

如何提高个人和企业的网络安全意识?

提高个人网络安全意识 个人可以通过以下方式提高网络安全意识&#xff1a; 1. 加强教育和培训&#xff1a;参加网络安全培训课程&#xff0c;学习识别网络攻击的常见迹象、安全密码的设置、不点击可疑链接等知识。 2. 建立网络安全政策&#xff1a;制定个人网络安全规则&…

【Linux】进程3——PID/PPID,父进程,子进程

在讲父子进程之前&#xff0c;我们接着上面那篇继续讲 1.查看进程 mycode.c makefile 我们在zs_108直接编译mycode.c&#xff0c;直接运行&#xff0c;然后我们转换另一个账号来查看这个进程 我们可以通过ps指令来查看进程 我们就会好奇了&#xff0c;第二行是什么&#xff…

基于JavaScript 实现近邻算法以及优化方案

前言 近邻算法&#xff08;K-Nearest Neighbors&#xff0c;简称 KNN&#xff09;是一种简单的、广泛使用的分类和回归算法。它的基本思想是&#xff1a;给定一个待分类的样本&#xff0c;找到这个样本在特征空间中距离最近的 k 个样本&#xff0c;这 k 个样本的多数类别作为待…

【C++】<知识点> C++11新特性

文章目录 一、auto关键字 二、decltype关键字 三、nullptr关键字 四、智能指针 五、 无序容器&#xff08;哈希表&#xff09; 六、统一的初始化方法 七、成员变量默认初始值 八、范围for循环 九、右值引用与移动语义 十、lambda表达式 一、auto关键字 1. 作用&#…

Linux shell编程学习笔记58:cat /proc/mem 获取系统内存信息

0 前言 在开展系统安全检查的过程中&#xff0c;除了收集cpu信息&#xff0c;我们还需要收集内存信息。在Linux中&#xff0c;获取内存信息的命令很多&#xff0c;这里我们着重研究 cat /proc/mem命令。 1 cat /proc/mem命令 /proc/meminfo 文件提供了有关系统内存的使用情况…

280 基于matlab的摇号系统GUI界面仿真MATLAB程序

基于matlab的摇号系统GUI界面仿真MATLAB程序&#xff0c;输入总数量及摇号需求&#xff0c;进行随机性摇号&#xff0c;并对摇取的号码进行双重随机性数据检测&#xff0c;确定是否符合要求。程序已调通&#xff0c;可直接运行。 280 GUI人机交互 摇号系统GUI界面仿真 - 小红书…