2
  1. 计算机体系结构中的 w-bit 字是什么?
  2. 对于两个 7 位字
1011001 = A 
1101011 = B , how does multiplication returns

10010100110011 ?

这些不涉及简单的二进制乘法吗?请举个例子。

4

5 回答 5

3

w-bit 只是 n-bit 的典型命名法,因为 w 通常是 word size 的缩写

于 2011-07-13T03:03:44.253 回答
2

是的,这是简单的二进制乘法:

>>> 0b1011001
89
>>> chr(_)
'Y'
>>> 0b1101011
107
>>> chr(_)
'k'
>>> ord('Y') * ord('k')
9523
>>> bin(_)
'0b10010100110011'
于 2011-07-13T03:05:53.727 回答
2

加法和乘法都与十进制(以 10 为底)相同。你只需要记住这个真值表:

Multiplying
-----------
0 x 0 = 0
0 x 1 = 0
1 x 0 = 0
1 x 1 = 1

Adding
-----------
0 + 0 = 0
0 + 1 = 1
1 + 0 = 1
1 + 1 = 0 (w/ carry)

首先添加。要添加,您可以像在普通算术中一样添加,除了遵循上面的真值表:

  00000101 = 5
+ 00000011 = 3
--------------
  00001000 = 8

这是如何工作的,你从右边开始,向左工作。1 + 1 = 0,但您将 a1转移到下一列。所以下一列是0 + 1,这将是1,但是由于您1从上一列中进行了另一列,所以它实际上1 + 10。您1在下一列上进行了 a ,即1 + 0,但实际上1 + 1是因为进行了进位。所以0一次又一次地移动1到下一列,即0 + 0,但由于我们的进位,变为1 + 0,即1。所以我们的答案是1000,它是8十进制的。5 + 3 = 8,所以我们知道我们是对的。

接下来,乘法:

  00000101 = 5
x 00000011 = 3
----------
       101 = 5
+     1010 = 10
----------
      1111 = 15

它的工作原理是将顶部的数字乘以00000101第二行中最右边的数字。我们00000011的第二行也是如此,并且1是最右边的数字,所以00000101times 1= 101。接下来,您0在其下方最右侧的列中放置一个占位符,就像在正常乘法中一样。然后你将我们最初的最高数字乘以我们00000101原始问题中左边的下一个数字00000011。它再次产生101。接下来你只需添加101 + 1010 = 1111......这就是答案

于 2011-07-13T03:09:17.643 回答
1

如果要相乘,只需像十进制数一样进行乘法运算,但必须添加二进制进位:

         1011001
        x1101011
         -------
         1011001
        1011001.
       0000000..
      1011001...
     0000000....
    1011001.....
   1011001......
  --------------
  10010100110011
于 2011-07-13T03:14:56.890 回答
1

w-bit 字本身不是任何东西。假设w之前已经在使用“w-bit word”的上下文中定义了 的值,那么它仅表示由w位组成的词。例如:

A version of RC6 is more accurately specified as RC6-w/r/b where the word size
is "w" bits,  encryption consists of a nonnegative number of rounds "r," and
"b" denotes the length of the encryption key in bytes. Since the AES
submission is targetted at w=32, and r=20, we shall use RC6 as shorthand to
refers to such versions.

因此,在该文档的上下文中,“w 位字”只是一个 32 位值。

至于你的乘法,我不确定你在问什么。Google 确认结果正确:

1011001 * 1101011 = 10010100110011

于 2011-07-13T03:15:33.300 回答