Arithmetic for Computer¶
约 993 个字 23 张图片 预计阅读时间 5 分钟
Arithmetic¶
加法¶
不管什么表示,直接加就是对的(包括负数的补码表示)。
减法¶
减去一个数等于加上这个数的补码。
Overflow¶
定义次高位向最高位的进位为\(c_i\),最高位的进位为\(c_{i+1}\),则溢出检验可定义为\(c_i \oplus c_{i+1}\),若结果为1则发生溢出。
ALU¶
在数字逻辑中已经设计过
乘法¶
朴素的思路¶
但是这样会很慢,因此有一种优化的思路,可以将ALU的位数降下来。
改进V2¶
这时我们又想到,乘法运算的结果和乘数每次都要右移一位,结果是乘数丢弃一位,product要增加一位。那我们能不能让增加的这一位利用丢弃导致空出来的位置呢?
改进V3¶
Booth¶
然后又有一个神人想出了一个神奇的方法,可以在乘数含大量1的情况下大大加快速度,思想类似于乘法分配律。
除法¶
思路¶
和小学学除法一样,用一个竖式来计算。
V1¶
解析
-
把除数(divisor)放在左半部分,被除数(dividend)放在右半边,置于寄存器中。
-
把被除数减去除数,得到结果:
-
若结果大于0,商(Quotient)左移一位,最低位置为1
-
若结果小于0,把结果加上除数恢复原来的被除数,商左移一位,最低为置为0
-
-
除数右移一位
修改版本¶
上面的ALU是128位的,太过于浪费空间,有没有优化呢? 我们考虑一个reminder,一开始被除数放在最右边,这样就分成了左边64位与右边64位。左边64位与除数作减法运算。每次被除数左移一位,计算减法结果,根据是否大于0在左移空出来的最低位置1或0.
浮点数与运算¶
想象二进制的科学计数法,浮点数形如\(1.xxxxx \times 2^{yyyyy}\)
在表示时,1
可以直接省去,因为肯定是1
精度(precision)¶
有单精度(Single precision)与双精度(Double precision)两种
组成
result=\(-1^{\text{sign}} \times (1+significand) \times 2^{exponent - bias}\)
1位符号位,8位指数位,23位小数位组成。指数bias=127
加法¶
加法的步骤为
-
指数对齐,一般是小的指数往大的指数对齐。
-
做运算
-
归一化
-
检查溢出
-
round
-
选择性归一化
乘法¶
小数相乘,指数相加,需要注意的是指数相加的结果需要减去一个bias,不然bias会加两次。
精确计算¶
IEEE Std 754建议了一些额外的位数,用来增加计算的精度。
-
Guard: The first of two extra bits.
-
Round: method to make the immediate floatingpoint result fit the floating-point format.
-
Units in the last place(ulp):The number of bits in error in the least significant bits of the significant between the actual number and the number that can be represented.
这里我放一篇比较简短而精确的文章:https://blog.csdn.net/qianniuwei321/article/details/113499393