二进制乘法器(二进制乘法)
无符号乘法。

无符号的乘法与加法类似,它的运算方式是比较简单的,只是也可能产生溢出。
对于两个w位的无符号数来说,它们的乘积范围在0到(2w-1)2之间,因此可能需要2w位二进制才能表示。
因此由于位数的限制,假设两个w位的无符号数的真实乘积为pro,根据截断的规则,则实际得到的乘积为 pro mod 2w。
2、补码乘法。
与加法运算类似,补码乘法也是建立在无符号的基础之上的,因此我们可以很容易的得到,对于两个w位的补码数来说,假设它们的真实乘积为pro,则实际得到的乘积为:U2Tw(pro mod 2w。
上面的式子有一个假设,就是假设对于w位的两个补码数来说,它们的乘积的低w位与无符号数乘积的低w位是一样的。
这意味着计算机可以使用一个指令执行无符号和补码的乘法运算。
3、乘法运算的优化。
根据小学所学的乘法运算,假设两个w位的二进制数相乘,则需要进行w次与运算,然后进行w - 1次加法运算才能得到结果。
从此不难看出,乘法运算的时间周期是很长的。
因此计算机界的高手们想出了一种方式可以优化乘法运算的效率,就是使用移位和加法来替代乘法。
上述优化的前提是对于一个w位的二进制数来说,它与2k的乘积,等同于这个二进制数左移k位,在低位补k个0。
在书中对这一等式进行了证明,过程如下。
这个过程主要应用了无符号编码的公式。
有了上面的基础,就可以使用移位和加法对乘法优化了。
对于任意一个整数y,它总能使用二进制序列表示(假设不超过二进制的表示范围),因此可以将x和y乘积的二进制序列表示为如下形式(此公式在书中没有展现)。
x * y = x * (yw-12w-1 + ... + y020) = (x << w-1) * yw-1 +....+ (x << 0 ) * y0。
举个例子,对于x * 17,可以计算x * 16 + x = (x << 4) + x ,这样算下来的话,只需要一次移位一次加法就可以搞定这个乘法运算。
而对于x * 14,则可以计算 x * 8 + x * 4 + x * 2 = (x << 3) + (x << 2) + (x << 1) ,更快的方式可以这么计算,x * 16 - x * 2 = (x << 4) - (x << 1) 。
这里最后需要提一下的是,加法、减法和移位的速度并不会总快于乘法运算,因此是否要进行上面的优化就取决于二者的速度了。
4、二进制乘法的运算步骤。
二进制数乘法过程可仿照十进制数乘法进行。
但由于二进制数只有0或1两种可能的乘数位,导致二进制乘法更为简单。
二进制数乘法的法则为:0×0=0。
2、0×1=1×0=0。
3、1×1=1。
例如:1001和1010相乘的过程如下:由低位到高位,用乘数的每一位去乘被乘数,若乘数的某一位为1,则该次部分积为被乘数;若乘数的某一位为0,则该次部分积为0。
某次部分积的最低位必须和本位乘数对齐,所有部分积相加的结果则为相乘得到的乘积。
参考资料来源:百度百科——二进制乘法。
免责声明:本文由用户上传,与本网站立场无关。财经信息仅供读者参考,并不构成投资建议。投资者据此操作,风险自担。 如有侵权请联系删除!
-
【如何使木炭快速燃烧】在日常生活中,无论是烧烤、取暖还是工业用途,木炭的燃烧效率都至关重要。想要让木炭...浏览全文>>
-
【ps如何让照片变清晰】在使用Photoshop(PS)进行图片处理时,很多人会遇到照片模糊、不清晰的问题。其实,通...浏览全文>>
-
【化学ohc是什么意思】在化学领域中,缩写词“OHC”有时会被使用,但它的具体含义可能因上下文而异。为了更清...浏览全文>>
-
【爱的天灵灵歌词爱的天灵灵歌词简单介绍】《爱的天灵灵》是一首具有浓厚民间风格和地方特色的歌曲,源自中国...浏览全文>>
-
【卫生间洗脸盆尺寸有哪些】在装修卫生间时,洗脸盆的尺寸选择非常重要,它不仅影响使用体验,还关系到整体空...浏览全文>>
-
【山东农业大学南校区邮编】山东农业大学南校区作为学校的重要组成部分,其地址和邮编信息对于师生、访客以及...浏览全文>>
-
【4789是什么商户】在日常的消费和交易过程中,消费者可能会遇到一些不熟悉的商户编号或代码,例如“4789”。...浏览全文>>
-
【乐视手机怎么修改解锁密码忘记】在使用乐视手机的过程中,如果用户忘记了锁屏密码或图案,可能会导致无法正...浏览全文>>
-
【消防车声音是什么样的】消防车作为城市中重要的应急救援车辆,其声音具有明显的辨识度。无论是紧急出警还是...浏览全文>>
-
【搞怎么组词】“搞”是一个常见的汉字,在日常生活中使用频率较高,尤其在口语中。它既可以作为动词,也可以...浏览全文>>
