一、原码、反码、补码的定义
1、原码的定义
小数原码的定义 
 
[X] =
 
X
  0≤X 1
 
1 X
 1 X ≤ 0
 例如: X=+0.1011 , [X]= 01011
        X=0.1011  [X]= 11011

整数原码的定义
 
[X] =
 
X
  0≤X 2n
 
2nX
  2n X ≤ 0
2、补码的定义
小数补码的定义
 
[X] =
 
X
  0≤X 1
 
2 X
  1 ≤ X 0
例如:  X=+0.1011,  [X]= 01011
        X=0.1011,  [X]= 10101
整数补码的定义 
 
[X] =
 
X
    0≤X 2n
 
2n+1X
  2n ≤ X 0
3、反码的定义
小数反码的定义 
 
[X] =
 
X
    0≤X 1
 
22n-1X
  1 X ≤ 0
 
例如:  X=+0.1011      [X]= 01011
        X=0.1011    [X]= 10100
整数反码的定义
 
[X] =
 
X
    0≤X 2n
 
2n+11
  2n X ≤ 0
4.移码:移码只用于表示浮点数的阶码,所以只用于整数。
移码的定义:设由1位符号位和n位数值位组成的阶码,则 [X]=2n + X    -2n≤X ≤ 2n
例如: X=1011    [X]=11011    符号位“1”表示正号
              X=1011    [X]=00101    符号位“0”表示负号
移码与补码的关系: [X]移与[X]补的关系是符号位互为反码,
例如: X=1011    [X]=11011    [X]=01011 
              X=1011    [X]=00101    [X]=10101 
移码运算应注意的问题:
对移码运算的结果需要加以修正,修正量为2n ,即对结果的符号位取反后才是移码形式的正确结果。
移码表示中,0有唯一的编码——1000…00,当出现000…00时(表示-2n),属于浮点数下溢。

二、补码加、减运算规则
1、运算规则
[XY]= [X] [Y]
[XY]= [X] [Y]
若已知[Y],求[Y]的方法是:将[Y]的各位(包括符号位)逐位取反再在最低位加1即可。
例如:[Y]= 101101 [Y]= 010011 
2、溢出判断,一般用双符号位进行判断:
符号位00 表示正数 11 表示负数
结果的符号位为01时,称为上溢;为10时,称为下溢
例题:设x=0.1101y=0.0111,符号位为双符号位
用补码求x+yx
[x]+[y]=00 1101+11 1001=00 0110 
[xy]=[x]+[y]=00 1101+00 0111=01 0100
结果错误,正溢出
三、原码一位乘的实现:
X=0.1101Y=0. 1011,求X*Y
解:符号位单独处理, x y
数值部分用原码进行一位乘,如下图所示:
   
小数的原码
 
高位部分积
 低位部分积/乘数
说明
 
    0 0 0 0 0 0 
 1 0 1 1
 
 
起始情况
+) 0 0 1 1 0 1
 
 
乘数最低位为1+X
 
 
 
 
 
    0 0 1 1 0 1
 
 
 
 
    0 0 0 1 1 0 
 1 1 0 1
1()
右移部分积和乘数
 
+) 0 0 1 1 0 1
 
 
乘数最低位为1+X
 
 
 
 
 
    0 1 0 0 1 1 
 
 
 
 
    0 0 1 0 0 1 
 1 1 1 0 
1()
右移部分积和乘数
 
+) 0 0 0 0 0 0
 
 
乘数最低位为0+0
 
 
 
 
 
    0 0 1 0 0 1 
 
 
 
 
    0 0 0 1 0 0 
 1 1 1 1
0()
右移部分积和乘数
 
+) 0 0 1 1 0 1
 
 
乘数最低位为1+X
 
 
 
 
 
    0 1 0 0 0 1 
 
 
 
 
    0 0 1 0 0 0
 1 1 1 1
1()
右移部分积和乘数
 
 
 
 
 

四、原码一位除的实现:一般用不恢复余数法(加减交替法)
 
部分积
低位部分积 附加位
操作说明
 
    0 0 0 0 0 0 
  1 0 1 1
 
 
起始情况
+) 0 0 0 0 0 0
 
 
乘数最低位为1+X
 
 
 
 
 
    0 0 0 0 0 0
 
 
 
 
    0 0 0 0 0 0 
 1 1 0 1
1()
右移部分积和乘数
 
+) 1 1 0 0 1 1
 
 
乘数最低位为1+X
 
 
 
 
 
    0 1 0 0 1 1 
 
 
 
 
    0 0 1 0 0 1 
 1 1 1 0 
1()
右移部分积和乘数
 
+) 0 0 0 0 0 0
 
 
乘数最低位为0+0
 
 
 
 
 
    0 0 1 0 0 1 
 
 
 
 
    0 0 0 1 0 0 
 1 1 1 1
0()
右移部分积和乘数
 
+) 0 0 1 1 0 1
 
 
乘数最低位为1+X
 
 
 
 
 
    0 1 0 0 0 1 
 
 
 
 
    0 0 1 0 0 0
 1 1 1 1
1()
右移部分积和乘数
§2.5 浮点运算与浮点运算器
一、浮点数的运算规则
1、浮点加减法的运算步骤
设两个浮点数 X=Mx2Ex Y=My2Ey
实现X±Y要用如下5步完成:
对阶操作:小阶向大阶看齐
进行尾数加减运算
规格化处理:尾数进行运算的结果必须变成规格化的浮点数,对于双符号位的补码尾数来说,就必须是
001×××…×× 110×××…××的形式
若不符合上述形式要进行左规或右规处理。
舍入操作:在执行对阶或右规操作时常用“0”“1”入法将右移出去的尾数数值进行舍入,以确保精度。
判结果的正确性:即检查阶码是否溢出
若阶码下溢(移码表示是00…0),要置结果为机器0
若阶码上溢(超过了阶码表示的最大值)置溢出标志。
例题:假定X=0 .0110011*211Y=0.1101101*2-10(此处的数均为二进制) ?? 计算X+Y
解:[X] 010 *******
    [Y] 0 0 110 1101101
            符号位 阶码 尾数

第一步:求阶差: │ΔE│=|1010-0110|=0100
第二步:对阶:Y的阶码小, Y的尾数右移4
        [Y]变为 010 *******暂时保存 
第三步:尾数相加,采用双符号位的补码运算 
    00 1100110 
  +00 0000110 
    00 1101100
第四步规格化:满足规格化要求 
第五步:舍入处理,采用01入法处理
故最终运算结果的浮点数格式为: 010 *******
X+Y=+0. 1101101*210