详解定点数相关运算(定点数补码的加法,减法,原码一位乘法,补码一位乘法,原码一位除法,补码一位除法 )

1.定点数补码的加法

1.定义:

两个补码表示的数相加,符号位参加运算,且两数和的补码等于两数补码之和。两个数不管正负,均用补码表示,符号位应当做数值参加运算,符号位相加所产生的进位要丢掉,结果为补码。

2.举例:
X=0.1011 Y=-0.0101,求 X+Y=?
解:
[X]补=0.1011,[Y]补=1.1011
[X]补+[Y]补 = 0.1011+1.1011 = 0.0110 = [X+Y]补
所以 X+Y = 0.0110

2.定点数的补码减法

1.定义:

对于减法,(-Y)的补码称为[Y]补的机器负数,由[Y]补求[-Y]补的过程称为将[Y]补“变补”或对[Y]补求补,由[Y]补求[-Y]补的方法是,不管Y的真值为正或为负,都是将[Y]补的各位连同符号位在内全变反后,最低位加1。

2.说明:

将“某数的补码表示”与“变补”这两个概念区分开来。一个负数由原码表示转换成补码表示时,符号位是不变的,仅对数值位各位变反,末位加“1”。而变补则不论这个数的真值是正是负,一律连同符号位一起变反(所有的二进制位一起变反),末位加“1”。

3.举例

X=-0.1011,Y=-0.0110, 求X-Y=?

解:
[X]补=1.0101,[Y]补=1.1010,[-Y]补=0.0110
[X]补+[-Y]补 = 1.1011 = [X-Y]补
所以 X-Y = 1.0101 = -0.0101

3.原码一位乘法

1.定义

原码一位乘法是从手算演变而来的。即用两个操作数的绝对值相乘,乘积的符号为两操作数符号的异或值(同号为正,异号为负)。

定点原码一位乘法(Unsigned Binary Multiplication)

设被乘数[X]原=XfX1X2……Xn-1Xn

乘 数[Y]原=YfY1Y2…Yn-1Yn

乘 积[Z]原=ZfZ1Z2……Z2n-1Z2n

2.运算规则:

由于机器字长通常仅有n位,两个n位数相乘结果为2n位;且仅仅有两个操作 数相加的加法器,难以胜任将n个位积一次相加起来。因此,在计算机中不能直 接照搬手工计算乘法的方法,必须进行修改使其便于计算机实现。

  1. 被乘数和乘数均取绝对值参加运算,符号位单独考虑
  2. 被乘数取双符号位部分积的长度同被乘数初值为0
  3. 从乘数的最低位Yn开始判断: 若Yn=1,则部分积加上被乘数|X|,然后右移一位; 若Yn=0,则部分积加上0,然后右移一位
  4. 重复第3步操作n次
3.例题

已知X=0.1101,Y=-0.1011,用原码一位乘计算X * Y=?

解:
[X]原=0.1101,[Y]原=1.1011
|X|=00.1101(用双符号位表示),|Y|=0.1011(用单符号位) ,部分积初值:00.0000

 - 乘数最低位为 1 ,所以00.0000(部分积)+00.1101(被乘数) = 00.1101;再向右移一位:00.01101
 - 乘数往前数一位为 1 ,00.01101 + 00.1101 = 01.00111;再向右移一位:00.100111
 - 乘数往前数一位为 0;不需要加上被乘数了,只需右移一位:00.0100111
 -  乘数往前数一位为 1,00.0100111 + 00.1101 = 01.0001111,右移一位:00.10001111
 - 符号可按异或运算得到(同号相乘为正,异号相乘为负),这里是异号,所以符号位是 1
 - 因此[X*Y]原 = 1.10001111;X*Y = -0.10001111

4.补码一位乘法

1.运算规则:
  • 符号位参加运算,运算的数均以补码表示;
  • 被乘数一般取双符号位参加运算;
  • 乘数可取单符号位;
  • 乘数末位增设附加位Yn+1,且初值为0。
  • 从低位到高位,依次判断相邻的两位乘数的状态,根据比 较结果按下表操作。
  • 最后一步不移位,仅根据Y0与Y1的比较结果作相应的运算
Yn (高位)Yn+1 (低位)操作
00部分积右移一位
01部分积加[X]补, 右移一位
10部分积加[-X]补, 右移一位
11部分积右移一位
2.例题:

已知X=-0.1101,Y=0.1011,用补码一位乘计算X * Y=?

 [X]补=11.0011,[-X]补=00.1101(用双符号表示),
 [Y]补=0.10110(用单符号位), 部分积:00.0000
 
 1. 0.10110(乘数)上 Y4Y5 位上的是1 0,所以部分积加[-X]补,再右移一位:00.01101
 2. 0.10110(乘数)上 Y3Y4 位上的是1 1,所以部分积右移一位:00.001101
 3.  0.10110(乘数)上 Y2Y3 位上的是0 1,所以部分积加[X]补,再右移一位:11.1011001
 4.  0.10110(乘数)上 Y1Y2 位上的是1 0,所以部分积加[-X]补,再右移一位:00.01000001
 5. 0.10110(乘数)上 Y0Y1 位上的是0 1,所以部分积加[X]补,最后一步不移位:11.01110001
 6. 所以[X*Y]补 = 1.01110001,X*Y = -0.10001111

5.原码一位除法

计算原码一位除法推荐使用不恢复余数法(加减交替法)

1.运算规则:

首先作X-Y余数为正,表明产生溢出,应终止除法运算;余数为负上商为0(作为商的符号位),然后重复下述操作n次,可得商的n位数值。

  1. 余数左移一位。
  2. 余数为正时,减除数;余数为负时,加除数。
  3. 所得的新余数为正时,上商为1;为负时,上商为0。
  4. 由于运算中余数共左移了n次,相当于乘2^n, 故最后得余数应乘上2^(-n)才是真正的正确余数。
2.例题:

已知X=0.1001,Y=0.1011,计算X / Y = ?

解:
[|X|]原 = 00.1001,[|Y|]原 = 00.1011,[-|Y|]补 = 11.0101
设每次的余数位Rn,商数位Q。

1.作X-Y:[|X|]原 + [-|Y|]补 = 11.1110,余数R0为负数,所以上商为0,R0左移一位,最终R0 = 11.1100,Q = 0。
2.因为R0为负数,所以余数R0要加上除数Y: R0 + [|Y|]原 = 00,0111,余数为正,上商为1,余数左移一位,最终R1 = 00.1110,Q = 0.1
3.因为R1为正数,所以余数R1要减去除数Y: R1 + [-|Y|]原 = 00.0011,余数为正,上商为1,余数左移一位,最终R2 = 00.0110,Q = 0.11
4.因为R2为正数,所以余数R2要减去除数Y: R2 + [-|Y|]原 = 11.1011,余数为负,上商为0,余数左移一位,最终R3 = 11.0110,Q = 0.110
5.因为R3为负数,所以余数R3要加上除数Y: R3 + [|Y|]原 = 00.0001,余数为正,上商为1,最后一步余数不变,最终R4 = 00.0001,Q = 0.1101
6.所以最后商为 Q = 0.1101,余数 R = 00.0001*2^(-4)

6.补码一位除法

1.运算规则:
  1. 参加运算的数用补码表示。
  2. 符号位参加运算,结果为补码。
  3. 被除数与除数同号,做被除数除数的运算,被除数与除数异号, 做被除数除数的运算。
  4. 如果余数与除数同号商1,左移一位, 除数,如果余数与除数异号商0, 左移一位, 除数。
  5. 重复上步n次,末位恒置1。
2.例题:

已知X=0.1000,Y=-0.1010,用补码一位除计算X ÷Y=?

解:
[X]补 = 00.1000,[Y]补 = 11.0110,[-Y]补 = 00.1010

1.[X]补 [Y]补异号,所以被除数加除数:[X]补 + [Y]补 = 11.1110。
2.余数和除数同号,所以商1,余数再左移一位 = 11.1100,再减除数 = 00.0110
3.新的余数和除数异号,所以商现在是1.0,余数再左移一位 = 00.1100,再加除数 = 00.0010
4..新的余数和除数异号,所以商现在是1.00,余数再左移一位 = 00.0100,再加除数 = 11.1010
5.新的余数和除数同号,所以商现在是1.001,余数再左移一位 = 11.0100,再减除数 = 11.1110
6.某位恒置1,此时商为:1.0011
7.最终:[商]补 = 1.0011,所以商 = -0.1101
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值