[教学]直接补码并行乘法

直接补码阵列乘法器的设计原理
* 李澄举
(嘉应学院计算机系,广东梅州514015)
[摘要]直接补码阵列乘法器的工作原理是《计算机组成原理》课程的难点。本文从组成阵列乘法器的四类全加器的工作原理分析开始,结合补码和真值的转换关系,通过和手工计算方法的对比,深入浅出地揭示了直接补码阵列乘法器的工作原理。
磷酸氧钛钾[关键词] 直接补码阵列乘法器,负权值,一般化全加器
一、引言
直接补码阵列乘法器可以直接求出两个补码的相乘积,由于符号位也参加运算,运算速度比起原码阵列乘法器快得多。5位乘5位的直接补码并行阵列乘法器的逻辑结构如图1所示。
与原码阵列乘法器不同的是,直接补码阵列乘法器除了采用0类全加器之外,还采用了1类和2类全加器,以对应于输入补码符号位的负的位权值;图1左下角的虚框是行波进位加法器,为了缩短加法时间,可以用先行进位加法器代替。
设被乘数和乘数(均为补码)分别为A=(a4)a3a2a1a0,B=(b4)b3b2b1b0,其中a4和b4是符号位,用括号括起来是表示这一位具有负的位权值。根据补码和真值的转换可以知道,
补码A的真值a=a4×(-24)+a3×23+a2×22+a1×21+a0×20;
补码B的真值b=b4×(-24)+b3×23+b2×22+b1×21+b0×20;
即在将补码直接转换成真值时,符号位取负权值,其余位取正权值。
如设A=01101(+13),B=11011(-5),计算符号位参加运算A×B的竖式乘法如下:
在这个竖式中,带括位的位具有负的位权值,即(1)=-1,(0)=0。原乘积最高两位0(1)是带有负位权值的二进制数,相当于0×21+1×(-20) =-1,因(1)1相当于1×(-21)+1×20 =-1,故0(1)可以写成(1)1,这扩充符号位(1)便是乘积的符号位。由此可见,在竖式乘法中,若乘积中间位有带负位权值的(1),可照此办法将(1)左移或消去,如果(1)能移到乘积最左边,则说明乘积为负,这(1)便是补码符号位;否则乘积为正,应在乘积最左边的1之左边加一个0作为补码符号位。
二、各类全加器的加法逻辑
要了解直接补码阵列乘法器的工作原理,首先要了解各类全加器的工作原理。
营养米
常规的一位全加器可假定它的3个输入和2个输出都是正权。这种加法器通过把正权
或负权加到输入/输出端,可以归纳出四类加法单元。如图2所示各类全加器的逻辑符
号,图中凡带有小圆圈的输入端都是负位权值的输
入端、带有小圆圈的输出端都是负位权值的输出端。由图可见,0类全加器没有负权输入和负权输出;1类全加器有1个负权输入和1个负权输出;2类全加器有2个负权输入和1个负权输出;3类全加器有3个负权输入和3个负权输出;各类全加器就是按负权值输入的个数命名的。
1、0类全加器
由于0类全加器3个输入X 、Y 、Z 和2个输出S (本位)和C (进位)都是正权,它的输出函数
表达式为我们所熟知:
ZX
YZ XY C XYZ Z Y X Z Y X Z Y X S 00++=+++=。
2、1类全加器
1类全加器只有1个负权输入和1个负权的本位输出。对于负权输入,如竖式乘法可见,加法的结果是正权的值的和与负权的值相减。但一位的减法不同于做n 位定点整数的补码减法,1类全加器须有如表1所示的真值表(表中带负权值的输入、输出变量前加符号“-”以标识),这种真值表表明了带权输入和带权输出之间的逻辑关系和数值关系:输入端X 、Y 带正权值,Z 带负权值,按手工加法,结果为X
+Y +(-Z )的值。只是当结果为1时,应将1变换为进位C =1、本位S =(1),等效于1×21+1×(-20)=1,使本位保持负的位权值,即:
X +Y +(-Z )=C (-S ) =C ×21+S ×(-20)
X 、Y 、Z 的所有取值组合对应的输出结果如下: 0+0+(-0)=0(0)=0×21+0×(-20) =0;
0+0+(-1)=0(1)=0×21
+1×(-20
) =-1;
0+1+(-0)=1(1)=1×21+1×(-20) =1; 0+1+(-1)=0(0)=0×21+0×(-20) =0;
1+0+(-0)=1(1)=1×21+1×(-20) =1;
1+0+(-1)=0(0)=0×21+0×(-20) =0;
1+1+(-0)=1(0)=1×21+0×(-20) =2;
1+1+(-1)=1(1)=1×21+1×(-20
) =1;
故其输出函数表达式为:
X Z Y Z XY C XYZ Z Y X Z Y X Z Y X S 11++=+++=
与0类全加器的输出函数比较,它们的本位函数相同但进位函数不同。若将带负权值的Z 取反后代入输出函数表达式,进位函数和0类全加器的一致,而本位函数1S 就是0类全加器本位输出的反,即01S S =。由此可见,要实现1类全加器的功能,带负权输入的Z 端须经一反相器输入到0类全加器与带正权输入的X 、Y 做一位的加法,然后本位端取反输出。本位1S 是取反后输出,表明本位输出带负的位权值。因此,1类全加器符号中的大圆
圈可以看成是0类全加器。
3、2类全加器
2类全加器有2个负权输入和1个负权的进位
输出,输入和输出之间的逻辑、数值关系为:
(-X )+ (-Y ) +Z =(-C )S =C ×(-21)+S ×20。
当数值运算的结果为-1时,应将它变换为(1)1,等效于1×(-21) +1×20 =-2+1=-1,使进位C 保持负的位权值。
X 、Y 、Z 的所有取值组合对应的输出结果如下:
(-0)+(-0)+0=(0)0=0×(-21)+0×20 =0;
(-0)+(-0)+1=(0)1=0×(-21)+1×20 =1; (-0)+(-1)+0=(1)1=1×(-21
)+1×20
=-1; (-0)+(-1)+1=(0)0=0×(-21)+0×20
=0; (-1)+(-0)+0=(1)1=1×(-21)+1×20
=-1; (-1)+(-0)+1=(0)0=0×(-21)+0×20
=0;
(-1)+(-1)+0=(1)0=1×(-21)+0×20 =-2;  (-1)+(-1)+1=(1)1=1×(-21
)+1×20
=-1;
故其输出函数表达式为:
X
Z Y Z XY C XYZ Z Y X Z Y X Z Y X S 22++=+++=
与0类全加器的输出函数比较,它们的本位函数相同但进位函数不同。若将带负权值的X 和Y 取反后代入输出函数表达式,本位函数和0类全加器的一致,而进位函数2C 就是0类全加器进位输出的反,即02C C =。由此可见,要实现2类全加器的功能,带负权输入的X 、Y 端须经反相器输入到0类全加器内与带正权输入的Z 做一位的加法,然后进位端取反输出。进位2C 是取反后输出,表明进位输出带负的位权值。2类全加器符号中的大圆圈也可以看成是0类全加器。
4、3类全加器
3类全加器有3个负权输入和2个负权的本位和进位输出,输入和输出之间的逻辑、数值关系为:(-X )+ (-Y ) +(-Z )=(-C ) (-S ) =C ×(-21)+S ×(-20)。
X 、Y 、Z 的所有取值组合对应的输出结果如下:
(-0)+(-0)+(-0)=(0) (0)=0×(-21)+0×(-20) =0;
(-0)+(-0)+(-1)=(0) (1)=0×(-21)+1×(-20
) =-1; (-0)+(-1)+(-0)=(0) (1)=0×(-21)+1×(-20) =-1;; (-0)+(-1)+(-1)=(1) (0)=1×(-21
)+0×(-20
) =-2;
(-1)+(-0)+(-0)=(0) (1)=0×(-21)+1×(-20) =-1; (-1)+(-0)+(-1)=(1) (0)=1×(-21)+0×(-20) =-2; (-1)+(-1)+(-0)=(1) (0)=1×(-21)+0×(-20) =-2;
(-1)+(-1)+(-1)=(1) (1)=1×(-21)+1×(-20) =-3;;
污水处理流程
数值运算的结果≤0,进位C 和本位S 始终保持负的位权值,其输出函数表达式为:
ZX
YZ XY C XYZ Z Y X Z Y X Z Y X S 33++=+++=。
这与0类全加器的输出函数表达式相同。若将带负权值的X 、Y 和Z 取反后代入输出函数表达式,有03S S =和03C C =。由此可见,要实现3类全加器的功能,所有带负权输入的输入端都须经反相器输入到0类全加器内做一位的加法,然后本位端和进位端都取反输
出。进位3C 和本位3S 都是取反后输出,表明本位和进位输出都带负的位权值。3类全加器符号中的大圆圈同样可以看成是0类全加器。
由此可见,这一般化的全加器可以实现二进制数的一位加法或减法的功能。
表2列出了以上四类一般化全加器的名称和逻辑符号及所对应的操作。
图1所示5位乘5位的直接补码阵列乘法器中用了0类、1类和2类的全加器,应该指
出,只是为了画图的方便,图中1类和2类的全加器的带负权值的输出端都省略了标示取反的小圆圈,这是需要特别注意的。在下面举例说明这5位乘5位的直接补码阵列乘法器的工作原理。活性氟化钾
纳米防脱
三、直接补码阵列乘法器的工作原理
扩张网机这里分别以被乘数和乘数的正负来说明直接补码阵列乘法器的工作原理。行波进位加法器的功能还可将乘积中间的带负权值的位进行处理,使它移到最高位(p9)作为符号位。图3右上角用六个0类全加器,它的工作原理容易理解,左边用六个1类全加器的连接的原理
是:由a 4带负权值,故a 4 b 0带负权值,需用1类全加器,也因本位是负权输出,故接下来也用1类全加器,这一列用了三个1类全加器。这列第4行因a 0 b 4也带负权值,故用2类
全加器。其它各列如此类推。
1、被乘数和乘数都为负的情况:如10001×10011,即(-15) ×(-13)。
图3中标出了阵列乘法器在作10001×10011乘法时各类加法器的输入端和输出端的值。左上角第一个1类全加器三个输入端的值分别为(1)、0、0,根据上述1类全加器的工作原理,传到这个1类全加器内的0类全加器输入端为0、0、0,运算结果为00,那么这个1类全加器的进位输出为0,本位则取反输出为(1)。如此类推。
可得阵列乘法器的输出为0011000011。

本文发布于:2024-09-21 06:03:45,感谢您对本站的认可!

本文链接:https://www.17tex.com/tex/1/309281.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:输出   全加器   输入   补码   乘法器   符号   负权   进位
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2024 Comsenz Inc.Powered by © 易纺专利技术学习网 豫ICP备2022007602号 豫公网安备41160202000603 站长QQ:729038198 关于我们 投诉建议