数据的表示与运算

news2024/11/25 14:47:43

目录

一、进位计数制

二、信息编码

三、定点数数据表示

四、校验码

五、定点数补码加减运算

六、标志位的生成

七、定点数的移位运算

八、定点数的乘除运算

九、浮点数的表示

十、浮点数的运算


一、进位计数制

整数部分:

  • 二进制、八进制、十六进制   --->   十进制:加权求和
  • 二进制   --->   八进制:每三位分为一组,转为八进制数
  • 二进制   --->   十六进制:每四位分为一组,转为十六进制数
  • 十进制   --->   二进制:除2取余,先得到低位
  • 十进制   --->   八进制、十六进制:先转为二进制,再转为八进制数或十六进制数

小数部分:

  • 十进制转换为任意进制:乘积取整法,结果不能得到准确值,则取精度值
  • 二进制   --->   八进制、十六进制:与整数部分类似
  • 二进制   --->   十进制:加权求和
  • 八进制、十六进制   --->   十进制:先转为二进制,再转为十进制

真值:符合人类习惯的数字

机器数:数字实际存在机器里的形式

二、信息编码

BCD码:Binary Coded Decimal,二-十进制码,即用二进制数表示十进制数。

BCD码分为有权码和无权码。常见的有权码有8421码、2421码、84-2-1码,常见的无权码有格雷码、余三码。

有权码的共性:都是自补码,即任意两个和为9的编码,互为补码。

格雷码:任何相邻的两个编码之间只有一位二进制位不同。

余三码:每个编码都是其8421码加上0011所得。

三、定点数数据表示

原码

反码

补码

移码

四、校验码

奇偶校验码:奇校验位的取值应该使整个奇校验码中“1”的个数为奇数,偶校验码的取值应该使整个偶校验码中“1”的个数为偶数

奇偶校验码的码距为2,具有检查一位错误或奇数位错误的能力。

五、定点数补码加减运算

六、标志位的生成

OF:Overflow Flag bit,溢出标志位(只对有符号数加减有意义)

SF:Sign Flag bit,符号标志位(只对有符号数加减有意义)

ZF:Zero Flag bit,判零标志位

CF:Carry Flag bit,进位/借位标志位(只对无符号数加减法有意义)

PF:Parity Flag bit,奇偶标志位

OF可以由最高位产生的进位S1和次高位产生的进位S2异或所得,即OF = S1 ⊕ S2

CF可以由最高位产生的进位S1和sub加减控制信号异或所得,即CF = S1 ⊕ sub

七、定点数的移位运算

算术移位:通过改变各个数码位与小数点的相对位置,从而改变各数码位的位权。可用移位运算实现乘法、除法。

原码的算术移位:符号位不变,仅对数值位进行移位。

右移——高位补0,低位舍弃,若舍弃不为0,丢失精度;

左移——低位补0,高位舍弃,若舍弃不为0,出现严重误差。

反码的算术移位:正数与原码一样,负数与原码不同

负数右移——高位补1,低位舍弃;

负数左移——低位补1,高位舍弃。

补码的算术移位:正数与原码、反码一样

补码是原码的反码低位加一所得,所以补码的前半部分同反码,后半部分同原码

负数右移——高位补1,低位舍弃;

负数左移——低位补0,高位舍弃。

逻辑移位:右移则高位补0低位舍弃,左移则低位补0高位舍弃,视作对无符号数处理。

循环移位:用移出去的位,补上空缺的位。带CF标志位一起的循环,称为大循环,不带则是小循环。

八、定点数的乘除运算

原码的乘法运算

补码的乘法运算

原码的除法运算

补码的除法运算

九、浮点数的表示

浮点数的格式

浮点数规格化

浮点数的溢出

  • 出现上溢:系统中断
  • 出现下溢:当作机器0处理
  • 当浮点数尾数为0:当作机器0处理,无视阶码

 真值与浮点数格式的转换

十进制数与单精度浮点数的转换

十、浮点数的运算

浮点数加减运算步骤

  1. 对阶:小阶向大阶对齐
  2. 尾数加减:阶数不变
  3. 规格化:保证尾数的第一个数值位是一个有效位
  4. 舍入:①截断法;②0舍1入法;③末尾恒置1法
  5. 判溢出:根据双符号是否一样panduan


 

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

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

相关文章

机器人模型预测控制MPC(model predictive control)

当前控制动作是在每一个采样瞬间通过求解一个有限时域开环最优控制问题而获得。过程的当前状态作为最优控制问题的初始状态,解得的最优控制序列只实施第一个控制作用。这是它与那些使用预先计算控制律的算法的最大不同。本质上模型预测控制求解一个开环最优控制问题…

使用APIPOST 进行压力测试

使用APIPOST 进行压力测试 目录概述需求: 设计思路实现思路分析1.apipost 压力测试 参考资料和推荐阅读 Survive by day and develop by night. talk for import biz , show your perfect code,full busy,skip hardness,make a better result,wait for c…

​【指针和数组区别与理解】超万字

指针和数组的关系 指针指的是指针变量,不是数组,指针变量的大小是4/8个字节,是专门来存放地址的。数组也不是指针,数组是一块连续的空间,存放一组相同类型的数据的。 没有关系,但是它们之间有比较相似的地方…

代理模式的学习与使用

1、代理模式的学习 代理模式是一种结构型设计模式,它允许你提供一个代理对象,该对象可以控制对其他对象的访问。代理模式通过在代理对象和实际对象之间添加一个中间层,使得代理对象可以代表实际对象执行某些操作,从而实现对实际对…

ARM-系统移植(开发环境搭建)

基于STM32MP157单片机 一、安装tftp服务器 首先保证ubuntu连接网络成功 1. 安装步骤 作用:完成ubuntu和开发板之间传输文件 1)安装tftp服务器的安装包 sudo apt-get install tftpd-hpa tftp-hpa tftpd-hpa : 服务器端 tftp-hpa : 客户端 2&#x…

Docker Desktop 如何运行容器

第一次使用windows环境下的DockerDesktop记录下使用方法 1、配置镜像源,虽然配置了镜像源,但是在界面你还是搜索不到镜像,应该默认使用的是官方dockerhub的原因,后面可以手动创建避开这个问题。 2、运行系统的windows powershell…

使用yolov5实现图像识别

文章目录 开始之前下载依赖下载数据集标记数据集整理文件新建 yaml 文件开始训练模型选择训练完成使用模型进行识别自定义模型下载数据集下载地址分享问题 开始之前 你应当先克隆这个仓库 git clone https://github.com/ultralytics/yolov5 # clone下载完毕后,进入…

【轻量化网络系列(5)】ShuffleNetV2论文超详细解读(翻译 +学习笔记+代码实现)

前言 今天我们要讲的是ShuffleNetV2,它是由旷视科技团队在 2018 年提出的,原论文发表在ECCV上。在同等复杂度下,ShuffleNetV2比ShuffleNet和MobileNetv2更准确。这篇论文除了提出这个全新的轻量化网络结构以外,还创新性地提出四…

redis第二章-第二课-主从模式和哨兵模式原理

主从模式 1、复制一份redis.conf,命名为redis-6380.conf文件 2、修改该文件,修改端口号,线程文件,日志文件,以及指定文件存放目录 3.在从节点上配置,这是核心配置 从本机6379的redis实例复制数据 replica…

如何准备一场面试

目录 一、心理准备1、内心的答案2、表述的答案 二、简历准备三、知识准备&面试流程1、一面:技术面2、二面:BOSS面3、终面:HR面 四、面试的技巧有哪些1、自信2、真诚3、主动4、复盘 五、补充:其他面试内容1、逻辑思维2、技术开…

圆柱点云展开为平面点云

文章目录 简单计算图示目标:将圆柱点云展开为平面点云用途(目前想到的)思路:本文展开思路关键点 简单计算图示 目标:将圆柱点云展开为平面点云 注意:工业实际场景中只能获取可见区域的圆柱侧面&#xff0c…

CC2530+ESP8266与手机APP通信

一、案例介绍 下面是一个基于CC2530和ESP8266的项目示例,演示了如何使用CC2530与ESP8266通信以及使用AT指令控制其WiFi模块设置和数据传输。 项目概述: 通过CC2530控制ESP8266将其配置成AP+TCP服务器模式,并通过手机APP连接到TCP服务器并完成数据传输。ESP8266将作为一个热…

基于Nginx部署的LNMP及搭建论坛

文章目录 1.部署LNMPLNMP架构拓扑图1.安装Nginx服务😊2.安装MySQL服务🤣3.安装配置PHP解析环境😂 2.部署Discuz社区论坛Web应用3. 部署WordPress社区论坛Web应用4. fpm参数优化 1.部署LNMP LNMP架构拓扑图 1.安装Nginx服务😊 ##…

DPDK相关开源代码汇总

上篇《DPDK相关学习资料汇总》中,我们讲了学习DPDK的相关资料,今天我们来讲一下DPDK相关的开源代码。 1、suricata Suricata引擎能够进行实时入侵检测(IDS)、内联入侵预防(IPS)、网络安全监控(NSM)和离线pcap处理。是一款开源、快速、高度稳定的网络入…

【Python wxPython】零基础也能轻松掌握的学习路线与参考资料

wxPython是一个基于wxWidgets C类库的Python GUI框架,使用它可以轻松创建跨平台的可视化应用程序。此外,wxPython与Python语言天然融合,让Python程序员可以轻松使用Python编写图形界面程序。因此,学习wxPython实际上就是学习如何用…

基本思维方式

经济学定义 人的欲望是无止境的,而资源有限,这是一个矛盾。 经济学是研究个人和社会如何最优利用由自然和前人提供的有限资源的学问。 经济学的范围 Microeconomics 微观经济学 研究各个行业的运作的以及企业和个人的决策行为的经济学分支。Macroeco…

BTC API:如何在比特币网络上创建应用程序?

比特币是一种去中心化的数字货币,可以通过比特币API与比特币网络进行交互。比特币API是一组允许开发人员与比特币网络进行交互的编程接口,可以帮助开发者构建各种比特币应用程序。 比特币API可以用于创建区块浏览器、钱包和比特币支付。其中利用比特币A…

机器视觉_HALCON_编程指南_多线程编程

文章目录 一、前言二、HALCON并行编程2.1 深入可重入性⭐2.2 多线程编程设计问题2.3 多线程算子2.4 示例 三、结语 一、前言 本文是HALCON的 programmers_guide(编程指南) 中的2.2章节,章节名直译是——用HALCON进行并行编程,实际…

C++入门:命名空间、函数重载、缺省参数

目录 一:命名空间 1.命名空间的意义 2.命名空间的定义 3.如何使用命名空间中成员? 小结 二:C的输入输出 三:函数重载 1.概念 2.实例 3.为什么C能支持函数重载而C不行? 【1】先看一段C语言代码 【2】我们把上…

基于单片机的七彩音乐喷泉设计

目录 一、方案流程及技术规格书设计 二、系统硬件电路设计 三、软件编写及调试 四、系统调试测试与分析 前言 随着时代的进步,人们对生活质量的要求也在不断提升,因此,51单片机七彩音乐喷泉系统应运而生,它不仅可以满足人们对…