`

原码、反码、补码、移码

阅读更多
 原码、反码、补码、移码   <script src="http://blog.csdn.net/count.aspx?ID=1545180&amp;Type=Rank"></script>  CSDN Blog推出文章指数概念,文章指数是对Blog文章综合评分后推算出的,综合评分项分别是该文章的点击量,回复次数,被网摘收录数量,文章长度和文章类型;满分100,每月更新一次。

一、原码、反码、补码的定义

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
  2n-X  - 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+1+X    - 2n ≤ X < 0


3、反码的定义

①小数反码的定义 

 

[X] =

  X     0≤X <1
  2-2n-1-X    -1 < X ≤ 0

 

例如:   X=+0.1011      [X]= 01011
         X=-0.1011     [X]= 10100

②整数反码的定义

 

[X] =

  X     0≤X <2n
  2n+1-1-X     - 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、运算规则

[X+Y]= [X]+ [Y]
[X-Y]= [X]+ [-Y]

若已知[Y],求[-Y]的方法是:将[Y]的各位(包括符号位)逐位取反再在最低位加1即可。
例如:[Y]= 101101 [-Y]= 010011 

2、溢出判断,一般用双符号位进行判断:

符号位00 表示正数 11 表示负数
结果的符号位为01时,称为上溢;为10时,称为下溢

例题:设x=0.1101,y=-0.0111,符号位为双符号位
用补码求x+y,x-y 
[x]补+[y]补=00 1101+11 1001=00 0110 
[x-y]补=[x]补+[-y]补=00 1101+00 0111=01 0100
结果错误,正溢出

三、原码一位乘的实现:

设X=0.1101,Y=-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=Mx※2Ex Y=My※2Ey
实现X±Y要用如下5步完成:
①对阶操作:小阶向大阶看齐
②进行尾数加减运算
③规格化处理:尾数进行运算的结果必须变成规格化的浮点数,对于双符号位的补码尾数来说,就必须是
001×××…×× 或110×××…××的形式
若不符合上述形式要进行左规或右规处理。

④舍入操作:在执行对阶或右规操作时常用“0”舍“1”入法将右移出去的尾数数值进行舍入,以确保精度。
⑤判结果的正确性:即检查阶码是否溢出
若阶码下溢(移码表示是00…0),要置结果为机器0;
若阶码上溢(超过了阶码表示的最大值)置溢出标志。

例题:假定X=0 .0110011*211,Y=0.1101101*2-10(此处的数均为二进制) ?? 计算X+Y;
解:[X]: 0 1 010 1100110
    [Y]: 0 0 110 1101101
            符号位 阶码 尾数

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

2、浮点乘除法的运算步骤

①阶码运算:阶码求和(乘法)或阶码求差(除法)
    即  [Ex+Ey]移= [Ex]移+ [Ey]补 
        [Ex-Ey]移= [Ex]移+ [-Ey]补

②浮点数的尾数处理:浮点数中尾数乘除法运算结果要进行舍入处理
例题:X=0 .0110011*211,Y=0.1101101*2-10
求X※Y
解:[X]: 0 1 010 1100110
    [Y]: 0 0 110 1101101
第一步:阶码相加 
[Ex+Ey]移=[Ex]移+[Ey]补=1 010+1 110=1 000 
1 000为移码表示的0
第二步:原码尾数相乘的结果为:
0 10101101101110
第三步:规格化处理:已满足规格化要求,不需左规,尾数不变,阶码不变。
第四步:舍入处理:按舍入规则,加1进行修正
所以 X※Y= 0.1010111※2+000

from:http://blog.yesky.com/blog/andygao/archive/2005/01/05/60472.aspx



Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1545180

分享到:
评论

相关推荐

    原码、反码、补码、移码与浮点.doc

    原码、反码、补码、移码与浮点数 原码、反码、补码、移码是计算机科学中用于表示数字的编码方式,浮点数是一种特殊的数值表示方式。本文将对原码、反码、补码、移码进行详细的介绍,并对浮点数的表示方式进行讨论。...

    定点数机器码转换器(原码、反码、补码、移码)

    定点数机器码转换器。十进制输入示例:12345、0.12345、-12345、-0.12345;二进制输入示例:10101、0.10101、-10101、-0.10101,将定点数转换成机器码

    十进制转换二进制(原码)

    十进制转换二进制计算机是采用二进制存储的,计算机的二进制编码方式也分为原码,反码,补码方法。这是一个把十进制数字转换到它的二进制原码的算法,希望能给大家一些启发吧!这个算法我是用VB6写的,其中用到了...

    记忆和转换原码、反码、补码和移码其实很简单

    原码、反码、补码和移码是四种常见的二进制表示方法,主要用于表示有符号整数。这些编码方式在计算机硬件和软件中有着广泛的应用,特别是在处理器内部进行算术运算时。 首先,我们来看**原码**。原码是最直观的二...

    原码、反码、补码、移码与浮点.pdf

    在计算机系统中,数字的表示和计算主要依赖于原码、反码、补码、移码以及浮点数的表示方法。理解这些概念对掌握计算机算术运算至关重要。 首先,我们来看原码、反码、补码和移码的定义: 1. 原码定义了一种直接的二...

    C语言基础 原码、反码、补码和移码详解

    本文将深入探讨四种不同的数值表示方式:原码、反码、补码和移码。 原码是最直观的数据表示方式,它直接将数值的符号位(最高位)作为正负的标识。对于正数,原码的符号位为0,其余位按照二进制表示数值。例如,...

    原码、反码、补码,计算机中负数的表示.pdf

    原码、反码和补码是计算机系统中表示和存储负数的基本概念。由于计算机采用二进制数表示数据,它必须能够准确表示正数和负数。在计算机系统中,整数通常按照补码形式存储,这能够简化加法和减法的硬件实现,并使得二...

    第一章 计算机组成与体系结构

    ##### 1.2 原码反码补码移码 - **原码**:在计算机中,原码是数字最直接的表示形式。例如,十进制数 `1` 转换成二进制后为 `1`,使用一个字节存储时,则在前面补零,即 `00000001`。正数的原码、反码和补码相同。 -...

    计算机组成原理第六章答案00098.doc

    本文档主要介绍计算机组成原理的相关知识点,包括计算机的运算方法、补码、原码、反码和移码的关系、机器数字长的影响、整数和小数的表示方法等。 1. 计算机的运算方法 计算机的运算方法可以分为整数运算和小数...

    组成原理 第二章复习

    机器数字长为8位(含1位符号位),如81(十六进制)分别表示原码、补码、反码和移码时,对应的十进制数需要通过计算得到。对于浮点规格化表示,如27/64和-27/64,需要先将分数转换为二进制,然后确定阶码和尾数的...

    计算机组成原理第二章-运算方法与运算器

    原码、补码、反码、移码等码制之间的关系以及各码制之间真值数的转换; 补码的加减运算,定点原码一位乘、除运算,定点补码一位乘、除运算及其逻辑结构; 变形补码、运算方法(尤其是补码)的理解,溢出、进位等问题...

    计算机组成原理第六章答案.pdf

    本章节主要讲述计算机组成原理的浮点数表示、定点数表示、补码、反码、移码等相关知识点。 一、浮点数表示 浮点数是计算机中表示实数的一种方式。浮点数由三部分组成:符号位(S)、阶码(E)和尾数(M)。符号位...

    计算机组成原理_第6章作业.pdf

    6.9 当十六进制数9BH和 FFH分别表示为原码、补码、反码、移码和无符号数时,所对应的十进制数各为多少(设机器数采用1位符号位)? 这道题目考察了机器数的表示形式。通过将十六进制数9BH和FFH转换为原码、补码、...

    计算机组成与设计试题\计算机组成原理自测与解答

    本章主要探讨了数据表示、定点数和浮点数的概念、原码、反码、补码和移码的使用,以及数据校验码的应用。 1. 数据表示:在计算机中,数据以二进制形式存在,包括字符编码(如ASCII或Unicode)、汉字编码(如GB2312...

    计算机基础知识点总结..pptx

    计算机基础知识点总结是一份详细的知识点总结,涵盖计算机基础知识的多个方面,包括进制表示和转换、原码、反码、补码、移码、定点数与浮点数、奇偶检验码、海明码、循环冗余校验码、与(AND)、或(OR)等逻辑运算...

    南方电网面试--计算机组成与体系结构--知识点汇总.pdf

    本文将对计算机组成与体系结构的知识点进行汇总,涵盖计算机五大组成部件、数制表示、原码、反码、补码、移码、各种码之间的转换等内容。 一、计算机五大组成部件 计算机的五大组成部件包括输入设备、存储器、运算...

Global site tag (gtag.js) - Google Analytics