画出实现Booth算法的运算器框图,
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了画出实现Booth算法的运算器框图,相关的知识,希望对你有一定的参考价值。
要求如下:1:寄存器和全加器均用i方框表示,指出寄存器和全加器的位数,2:说明加和移位的次数,3:详细画出最低位全加器的输入电路,4:描述Booth算法重复加和移位的过程。
参考技术A http://wenku.baidu.com/link?url=TuFWEqHNPdbiVZfilSAKmm2FkqJwmKv3R28IpXIqKQpcZGkCPjoGQPQXkvz81e7UOMjFbABbaS5FsceFntPxfLSRPk47KEMkfhwKuI7eE-G###第25页 自己看吧
计算机组成原理——补码乘法运算
补码的一位乘法(Booth算法)
- 进行 n 轮加法、移位,最后再多来一次加法
- 每次加法可能 +0 、+[x]补、+[-x]补
- 每次移位是“补码的算数右移”
- 符号位参与运算
在第二个步骤中,需要根据MQ中的最低位、辅助位 来确定加什么:
- 辅助位 - MQ中最低位 = 1时,(ACC)+[x]补
- 辅助位 - MQ中最低位 = 0时,(ACC)+0
- 辅助位 - MQ中最低位 = -1时,(ACC)+[-x]补
手算模拟
例题
设机器字长为5位(含1位符号位,n=4),x = −0.1101,y = +0.1011,采用Booth算法求x·y
解:手动计算是这样
最后得 [x·y]补 = 11.01110001
即x·y = −0.10001111
做题总结
- n轮加法、算数右移,加法规则如下:
辅助位 - MQ中最低位 = 1时,(ACC)+[x]补
辅助位 - MQ中最低位 = 0时,(ACC)+0
辅助位 - MQ中最低位 = -1时,(ACC)+[-x]补 - 补码的算数右移:
符号位不动,数值位右移,正数右移补0,
负数右移补1(符号位是啥就补啥) - 一般来说,Booth算法的被乘数、部分积采用双符号位补码
原码,补码一位乘法的对比
原码一位乘法: | 补码一位乘法: |
---|---|
进行 n 轮加法、移位 | 进行 n 轮加法、移位,最后再多来一次加法 |
每次加法可能 +0 、+[|x|] 原 | 每次加法可能 +0 、+[x] 补、+[-x] 补 |
每次移位是“逻辑右移” | 每次移位是“补码的算数右移” |
符号位不参与运算 | 符号位参与运算 |
以上是关于画出实现Booth算法的运算器框图,的主要内容,如果未能解决你的问题,请参考以下文章