【计算机组成原理】定点数的运算

2023-12-23 22:10

本文主要是介绍【计算机组成原理】定点数的运算,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

数值运算的核心是指加、减、乘、除四则算术。由于计算机中的数有定点和浮点两种表示形式,因此相应有定点数的运算和浮点数的运算。本文将介绍计算机中定点数的加减法运算过程。

注意,理解本文的前提是要清楚知道顶点数的源码、反码和补码的含义,以及定点数在计算机中的表示形式。

1.补码加法

由于计算机中定点数均以补码的方式表示和存储(个人观点,有待证明),采用补码表示法进行加减运算比源码方便多了,因为不论是正还是负,机器总是做加法,减法运算可变成加法运算。

这里再次说明定点定点数(定点整数和定点小数)的源码、反码和补码的表示规则:
正数的符号位为0,反码和补码等同于源码。
负数符号位都固定为1,源码,反码和补码的表示都不相同,由原码表示法变成反码和补码有如下规则:
(1)源码符号位为1不变,整数的每一位二进制数位求反得反码;
(2)反码符号位为1不变,反码数值位最低位加1得补码。

1.1补码加法公式

补码加法公式是:

[x]补+[y]补=[x+y]补(mod2n)

这里说一下上面公式的意思。

mod2n

表示的是模运算,

2n

为模,这个模表示被丢掉的值。上面的式子在数学上成为为同余式,即等式两边的值取

2n

的余数是相等的。

以钟表为例,说明模运算。一个钟表有12个小时刻度,时间确实0-24小时。假设现在的标准时间是4点整,而有一个表已经7点了,为了校准时间,可以采用两种方法:一是将时针退7-4=3格;二是将时针向前拨12-3=9格。这两种方法都能对准到4点。由此可见,7-3和7+9是等价的。等价的条件就是以模为12的模运算的情况下等价,即除以12取余。以数学公式表示如下:

7−3=7+9(mod12)

1.2补码加法公式证明

可分五种情况来证明。假设采用定点整数表示。不包括溢出情况,该情况会另行讨论。

(1)x>0, y>0, 则x+y>0
由补码定义,[x]补=x,[y]补=y, 所以[x]补+[y]补=x+y=[x+y]补

(2)x<0, y<0, 则(x+y)<0

[x]补+[y]补=2n+x+2n+y=2n+(2n+x+y)=[x+y]补

(3)x>0, y<0, 则(x+y)<0或(x+y)>0
相加的两数一个为正,一个为负,因此相加结果有正、负两种可能。根据补码定义:[x]补=x,[y]补=2n+y,那么

[x]补+[y]补=x+2n+y=2n+(x+y)=[x+y]补

(4)x<0, y>0, 则(x+y)<0或(x+y)>0
这种情况和第三种情况一样,将x和y对调即可,不再赘述。

(5)当x=0或者y=0,或者x=y=0时
满足[x]补+[y]补=[x+y]补(mod2n)。

因此在模2n的意义下,任意两数的补码之和等于该两数之和的补码。这是补码加法的理论基础。

2.补码减法

负数的加法要利用补码化为加法来做,减法运算当然也要设法化为加法来做。其所以使用这种方法而不适用直接减法,是因为它可以和常规的加法运算使用同一加法器电路,从而简化了计算机的设计。

定点数用补码表示时,减法运算的公式为:

[x]补−[y]补=[x]补+[−y]补

为了证明这个公式,只要证明[−y]补=−[y]补,上式即得证。

证明如下:
因为[x]补+[y]补=[x+y]补,所以
①[y]补=[x+y]补–[x]补

又[x–y]补=[x+(–y)]补=[x]补+[–y]补,所以
②[–y]补=[x–y]补–[x]补

①+②得[–y]补+[y]补=[x–y]补–[x]补+[x+y]补–[x]补=[x–y]补+[x+y]补–[x]补–[x]补=[x–y+x+y]补–[x]补–[x]补=[2x]补–2[x]补=0

从而有 [–y]补=–[y]补(mod2n)

因此,只要求得[–y]补,就可以变减法为加法,已知[y]补,求[–y]补的法则是:

对[y]补各位(包括符号位)取反,然后在末位加上1,就可以得到[–y]补。

示例:
[X]补=00110110,[Y]补=11001101,求[X]补+[Y]补,[X]补−[Y]补 ,其中x=54,y=-51。
这里写图片描述

3.溢出概念与检测方法

3.1溢出的概念

在定点整数机器中,数的表示范围|x|<(2n−1)。在运算过程中如出现大于字长绝对值的现象,称为“溢出”。在定点机器中,正常情况下溢出是不允许的。

例:设定点整数字长8位,补码表示(最高位为符号位),表示范围为-128~127,运算结果超出此范围就发生溢出。

两个负数相加的结果小于机器所能表示的最小负数,结果变为负数,成为负溢

两个正数相加,结果大于机器字长所能表示的最大正数,结果成为变为负数,称为正溢

下面以具体的例子来演示正常的运算和溢出时的运算。
这里写图片描述

这里写图片描述

这里写图片描述

这里写图片描述

3.2溢出的检测方法

为了判断溢出是否发生可采用以下两种检测方法。

(1)单符号法
当两个操作数同号时,而其和的符号与操作数的符号不一致则就发出溢出,公式表示如下:

溢出=A⎯⎯⎯nB⎯⎯⎯nSn+AnBnS⎯⎯n

注意:
a、若是同号相减或异号相加,则运算结果不可能溢出;
b、若是同号相加或异号相减,则运算结果可能溢出。

(2)采用最高有效位的进位判断

溢出=C⎯⎯⎯nCn−1+CnC⎯⎯⎯n−1=C⎯⎯⎯n⨁C⎯⎯⎯n−1

符号位产生的进位与最高有效位产生的进位情况不同,则溢出。

(3)采用变形补码判断(双符号位)
用Sn+1、Sn分别表示结果最高符号位和第2个符号位。

溢出=Sn+1⨁Sn

01:结果正溢;

10:结果负溢;

定点整数的加减运算完成之后,会由硬件逻辑电路进行溢出检测,如果发现存在溢出,则产生硬件中断 。

4.定点小数的加减运算法则

定点小数是定点数的一种,其运算法则和步骤与定点整数一致,不再赘述。下面举个仅以双符号位补码来表示定点小数的补码加减运算示例。

这里写图片描述

这里写图片描述

这里写图片描述

这里写图片描述


参考文献

[1]计算机组成原理第四版[M].白中英.科学出版社
[2]http://wenku.baidu.com/link?url=BL5mztNkNIvtPKAF96-iHRPIUQLimljQ9bci9Vy5yGyjhfMe8F_wjxTYHgGG3MbgdMsEU-18oG27u5Tw4Q_ffmRqSg9imaPzif-0Vs3f8g3

原文链接:http://blog.csdn.net/k346k346/article/details/50530004

这篇关于【计算机组成原理】定点数的运算的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/529647

相关文章

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

hdu4407(容斥原理)

题意:给一串数字1,2,......n,两个操作:1、修改第k个数字,2、查询区间[l,r]中与n互质的数之和。 解题思路:咱一看,像线段树,但是如果用线段树做,那么每个区间一定要记录所有的素因子,这样会超内存。然后我就做不来了。后来看了题解,原来是用容斥原理来做的。还记得这道题目吗?求区间[1,r]中与p互质的数的个数,如果不会的话就先去做那题吧。现在这题是求区间[l,r]中与n互质的数的和

uva 575 Skew Binary(位运算)

求第一个以(2^(k+1)-1)为进制的数。 数据不大,可以直接搞。 代码: #include <stdio.h>#include <string.h>const int maxn = 100 + 5;int main(){char num[maxn];while (scanf("%s", num) == 1){if (num[0] == '0')break;int len =

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

hdu4407容斥原理

题意: 有一个元素为 1~n 的数列{An},有2种操作(1000次): 1、求某段区间 [a,b] 中与 p 互质的数的和。 2、将数列中某个位置元素的值改变。 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.Inpu

hdu4059容斥原理

求1-n中与n互质的数的4次方之和 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import java.io.InputStreamReader;import java.io.PrintWrit

寻迹模块TCRT5000的应用原理和功能实现(基于STM32)

目录 概述 1 认识TCRT5000 1.1 模块介绍 1.2 电气特性 2 系统应用 2.1 系统架构 2.2 STM32Cube创建工程 3 功能实现 3.1 代码实现 3.2 源代码文件 4 功能测试 4.1 检测黑线状态 4.2 未检测黑线状态 概述 本文主要介绍TCRT5000模块的使用原理,包括该模块的硬件实现方式,电路实现原理,还使用STM32类

计算机视觉工程师所需的基本技能

一、编程技能 熟练掌握编程语言 Python:在计算机视觉领域广泛应用,有丰富的库如 OpenCV、TensorFlow、PyTorch 等,方便进行算法实现和模型开发。 C++:运行效率高,适用于对性能要求严格的计算机视觉应用。 数据结构与算法 掌握常见的数据结构(如数组、链表、栈、队列、树、图等)和算法(如排序、搜索、动态规划等),能够优化代码性能,提高算法效率。 二、数学基础

TL-Tomcat中长连接的底层源码原理实现

长连接:浏览器告诉tomcat不要将请求关掉。  如果不是长连接,tomcat响应后会告诉浏览器把这个连接关掉。    tomcat中有一个缓冲区  如果发送大批量数据后 又不处理  那么会堆积缓冲区 后面的请求会越来越慢。