浮点数计算方法.ppt
《浮点数计算方法.ppt》由会员分享,可在线阅读,更多相关《浮点数计算方法.ppt(164页珍藏版)》请在三一办公上搜索。
1、第二章 运算方法和运算器,2.1 数据与文字的表示方法2.2 定点加法、减法运算2.3 定点乘法运算2.4 定点除法运算2.5 定点运算器的组成2.6 浮点运算方法和浮点运算器,2.1 数据与文字的表示方法 2.1.1 数据格式,计算机中常用的数据表示格式有两种:1 定点格式 2 浮点格式 一般来说,定点格式容许的数值范围有限,但要求的处理硬件比较简单。而浮点格式容许的数值范围很大,但要求的处理硬件比较复杂。,1.定点数的表示方法,定点表示:约定机器中所有数据的小数点位置是固定不变的。由于约定在固定的位置,小数点就不再使用记号“.”来表示。通常将数据表示成纯小数或纯整数。定点数012n 在定点
2、机中表示如下(0:符号位,0代表正号,1代表负号):,纯小数的表示范围为(012n 各位均为0时最小;各位均为1时最大)0|12n(2.1)纯整数的表示范围为0|2n1(2.2)目前计算机中多采用定点纯整数表示,因此将定点数表示的运算简称为整数运算。,电子的质量(91028克)和太阳的质量(21033克)相差甚远,在定点计算机中无法直接来表示这个数值范围.要使它们送入定点计算机进行某种运算,必须对它们分别取不同的比例因子,使其数值部分绝对值小于1,即:9 10280.9 1027 2 10330.2 1034 这里的比例因子1027 和 1034要分别存放在机器的某个存储单元中,以便以后对计算
3、结果按这个比例增大。显然这要占用一定的存储空间和运算时间。因此得到浮点表示法如下:,2.浮点数的表示方法,浮点表示法:把一个数的有效数字和数的范围在计算机的一个存储单元中分别予以表示,这种把数的范围和精度分别表示的方法,相当于数的小数点位置随比例因子的不同而在一定范围内自由浮动,称为浮点表示法。任意一个十进制数 可以写成 10E.(2.3)同样在计算机中一个任意进制数 可以写成 e.(2.4):尾数,是一个纯小数。e:比例因子的指数,称为浮点数的指数,是一个整数。R:比例因子的基数,对于二进计数值的机器是一个常数,一般规定 为2,8或16。,一个机器浮点数由阶码和尾数及其符号位组成(尾数:用定
4、点小数表示,给出有效数字的位数决定了浮点数的表示精度;阶码:用整数形式表示,指明小数点在数据中的位置,决定了浮点数的表示范围。):,32位浮点数的IEEE754标准格式为:,64位浮点数的IEEE754标准格式为:,在IEEE754标准格式表示的32位浮点数中,:浮点数的符号位,1 位,0表示正数,1表示负数。:尾数,23位,用小数表示,小数点放在尾数域的最前面。:阶码,8 位阶符采用隐含方式,即采用移码方式来表示正负指数。移码方法对两个指数大小的比较和对阶操作都比较方便,因为阶码域值大者其指数值也大。采用这种方式时,将浮点数的指数真值e 变成阶码 时,应将指数 e 加上一个固定的偏移值127
5、(01111111),即 e127.,IEEE754 标准中,一个规格化的32位浮点数的真值可表示为(1)s(1.)2127 e127 一个规格化的64位浮点数的真值为(1)s(1.)21023 e1023 为提高数据的表示精度,当尾数的值不为 0 时,尾数域的最高有效位应为1,否则以修改阶码同时左右移小数点的办法,使其变成这一表示形式,这称为浮点数的规格化表示。当浮点数的尾数为 0,不论其阶码为何值,或者当阶码的值遇到比它能表示的最小值还小时,不管其尾数为何值,计算机都把该浮点数看成零值,称为机器零。,当阶码E 为全0且尾数M 也为全0时,表示的真值x 为零,结合符号位S 为0或1,有正零和
6、负零之分。当阶码E 为全1且尾数M 为全0时,表示的真值x 为无穷大,结合符号位S 为0或1,也有+和-之分。这样在32位浮点数表示中,要除去E 用全0和全1(255)10表示零和无穷大的特殊情况,指数的偏移值不选128(10000000),而选127(01111111)。对于规格化浮点数,E 的范围变为1到254,真正的指数值e 则为-126到+127。因此32位浮点数表示的绝对值的范围是10-381038(以10的幂表示)。,浮点数所表示的范围远比定点数大。一台计算机中究竟采用定点表示还是浮点表示,要根据计算机的使用条件来确定。一般在高档微机以上的计算机中同时采用定点、浮点表示,由使用者进
7、行选择,而单片机中多采用定点表示。例1 若浮点数的754标准存储格式为(41360000)16,求其浮点数的十进制数值。例2 将(20.59375)10转换成754标准的32位浮点 数的二进制存储格式。,例1 若浮点数的754标准存储格式为(41360000)16,求其浮点数的十进制数值。解:将十六进制数展开后,可得二进制数格式为 指数e阶码127100000100111111100000011=(3)10包括隐藏位1的尾数 1.M1.011 0110 0000 0000 0000 00001.011011 于是有(1)s1.M2e(1.011011)231011.011(11.375)10,
8、例2 将(20.59375)10转换成754标准的32位浮点 数的二进制存储格式。解:首先分别将整数和分数部分转换成二进制数:20.5937510100.10011 然后移动小数点,使其在第1,2位之间 10100.100111.01001001124e4于是得到:S0,E4127131,M010010011最后得到32位浮点数的二进制存储格式为:0100 0001 1010 0100 1100 0000 0000 0000(41A4C000)16,3.十进制数串的表示方法,目前,大多数通用性较强的计算机都能直接处理十进制形式表示的数据。十进制数串在计算机内主要有两种表示形式:(1)字符串形式
9、:一个字节存放一个十进制的数位或符号位。为了指明这样一个数,需要给出该数在主存中的起始地址和位数(串的长度)。(2)压缩的十进制数串形式:一个字节存放两个十进制的数位。它比前一种形式节省存储空间,又便于直接完成十进制数的算术运算,是广泛采用的较为理想的方法。,4.自定义数据表示,在传统的计算机体系结构中,用指令本身来说明操作数据的类型。如定点加法表示操作数是纯小数或纯整数;浮点加法表示操作数是浮点数;十进制加法表示操作数是BCD数。由于操作数据类型不同,要设三种不同的指令(操作码)来加以区分。自定义数据表示则用数据本身来说明数据类型。表示形式有两种,即标志符数据表示和描述符数据表示。,描述符数
10、据表示主要用来描述多维结构的数据类型,如向量、矩阵、记录等。描述符标志位部分指明这是一个数据描述符;特征标记部分指明数据的各种特征;长度部分指明数组中元素个数;起始地址部分指明数据块的首地址。其格式为:,标志符数据表示要求对每一个数据都附加标志符。其指明后面的数据所具有的类型,如整数、浮点数、BCD数、字符串等,其格式如下:,2.1.2 数的机器码表示,在计算机中对数据进行运算操作时,为了妥善的处理好符号位问题,就产生了把符号位和数字位一起编码来表示相应的数的各种表示方法,如原码、补码、反码、移码等。为了区别一般书写表示的数和机器中这些编码表示的数,通常将前者称为真值,后者称为机器数或机器码。
11、常用的机器码表示法:1.原码表示法 2.补码表示法 3.反码表示法 4.移码表示法,1.原码表示法,若定点小数的原码形式为0.12n,则原码表示的定义是:10 原 11|01 式中原是机器数,是真值 若定点整数的原码形式为0 12n,则原码表示的定义是 2n0 原 2n2n|02n,对于0,原码机器中往往有“+0”、“-0”之分,故有两种形式:+0原=0.000.0-0原=1.000.0 采用原码表示法简单易懂,但它的最大缺点是加法运算复杂。这是因为,当两数相加时,如果是同号则数值相加;如果是异号,则要进行减法。而在进行减法时还要比较绝对值的大小,然后大数减去小数,最后还要给结果选择符号。为了
12、解决这些矛盾,人们找到了补码表示法。,2.补码表示法,我们先以钟表对时为例说明补码的概念。假设现在的标准时间为4点正;而有一只表已经7点了,为了校准时间,可以采用两种方法:一是将时针退 7-4=3 格;一是将时针向前拨12-3=9格。这两种方法都能对准到4点,由此可以看出,减3和加9是等价的,就是说9是(-3)对12的补码,可以用数学公式表示:-3+9(mod12)mod12的意思就是12模数,这个“模”表示被丢掉的数值。上式在数学上称为同余式。,上例中其所以7-3和7+9(mod12)等价,原因就是表指针超过12时,将12自动丢掉,最后得到16-12=4。从这里可以得到一个启示,就是负数用补
13、码表示时,可以把减法转化为加法。这样,在计算机中实现起来就比较方便。7 3=4 7+9=4 以12取模数(mod12)-3=+9(mod12)采用补码表示法进行减法运算就比原码方便得多了。因为不论数是正还是负,机器总是做加法,减法运算可变为加法运算。关键是我们需要换算出两个操作数的补码表示。,若定点小数补码形式为0.12n,则补码表示的定义是:10 补 22|01(mod 2)若定点整数补码形式为0 12n,则补码表示的定义是:2n0 补 2n+1+2n+1|02n(mod 2n1)根据补码定义,求负数的补码要从2减去|x|。为了用加法代替减法,结果还得在求补码时作一次减法,这显然是不方便的。
14、下面介绍的反码表示法可以解决负数的求补问题。,3.反码表示法,所谓反码,就是二进制的各位数码0变为1,1变为0。也就是说,若Xi=1,则反码为xi=0;若xi=0,则反码xi=1。数值上面的一横表示反码的意思。在计算机中用触发器寄存数码,若触发器Q端输出表示原码,则其Q端输出就是反码。由此可知,反码是容易得到的。,若定点小数反码形式为0.12n,则反码表示的定义是:10 反(22-n)01一般情况下,对正数和负数的值,0.12n,则反0.12n0.12n,则反1.12n 若定点整数反码形式为0 12n,则反码表示的定义是:2n0 反(2n+11)02n,我们比较反码与补码的公式,对于负数有:定
15、点小数 反(22n)补2 可得到 补反2n 定点整数 反(2n+11)补 2n+1+可得到 补反1 这就是通过反码求补码的重要公式。这个公式告诉我们,若要一个负数变补码,其方法是符号位置1,其余各位0变1,1变0,然后在最末位(2-n)上加1。,4.移码表示法,移码通常用于表示浮点数的阶码。由于阶码是个n位的整数,假定定点整数移码形式为 012n时,对定点整数移码的传统定义是:移2n 2n2n 若阶码数值部分为5位,以表示真值,则:移25 25 25,小结:上面的数据四种机器表示法中,移码表示法主要用于表示浮点数的阶码。由于补码表示对加减法运算十分方便,因此目前机器中广泛采用补码表示法。在这类
16、机器中,数用补码表示,补码存储,补码运算。也有些机器,数用原码进行存储和传送,运算时改用补码。还有些机器在做加减法时用补码运算,在做乘除法时用原码运算。,例5设机器字长16位,定点表示,尾数15位,数符1位,问:(1)定点原码整数表示时,最大正数是多少?最小负数是多少?(2)定点原码小数表示时,最大正数是多少?最小负数是多少?;解:(1)定点原码整数表示 最大正数值(2151)10(32767)10 最小负数值(2151)10(32767)10(2)定点原码小数表示 最大正数值(1215)10(0.111.11)2 最小负数值(1215)10(0.111.11)2,例6假设由S,E,M三个域组
17、成的一个32位二进制数所表示的非零规格化浮点数,真值表示为:(1)s(1.M)2E128问:它所表示的规格化的最大正数、最小正数、最大负数、最小负数是多少?解:(1)最大正数 1(12-23)2127(2)最小正数 1.02128(3)最小负数 1(1223)2127(4)最大负数 1.02128,例7 若机器使用8位表示定点数,将数 x100/100,y0.59375/0.59375分别转换为各种机器码形式。解:已知数据位数为8位,最高位为符号位,数据表示范围可用7位,那么定点整数的范围是:0|127(271)定点小数的范围是:0|0.9921875(127)(100)10=(1100100
18、)2(0.59375)10=(0.10011)2+1100100原=01100100-1100100原=11100100+1100100反=01100100-1100100反=10011011+1100100补=01100100-1100100补=10011100+0.10011原=01001100-0.10011原=11001100+0.10011反=01001100-0.10011反=10110011+0.10011补=01001100-0.10011补=10110100,2.1.3 字符与字符串的表示方法,1.字符的表示方法现代计算机不仅处理数值领域的问题,而且处理大量非数值领域的问题。
19、这样一来,必然要引入文字、字母以及某些专用符号,以便表示文字语言、逻辑语言等信息。目前国际上普遍采用的字符系统是七单位的ASCII码(美国国家信息交换标准字符码),它包括10个十进制数码,26个英文字母和一定数量的专用符号,如$,%,等,共128个元素,因此二进制编码需7位,加一位偶校验位,共8位一个字节。参见书中表2.1的ASCII码字符编码表。,2.字符串 字符串是指连续的一串字符,通常方式下,它们占用主存中连续的多个字节,每个字节存一个字符。当主存字由2个或4个字节组成时,在同一个主存字中,既可按从低位字节向高位字节的顺序存放字符串的内容,也可按从高位字节向低位字节的次序顺序存放字符串的
20、内容。例 将下面字符串从高位字节到低位字节依次存在主存中。IFABTHENREAD(C),2.1.4 汉字的表示方法,1.汉字的输入编码 当前采用的方法主要有以下三类:数字编码 常用的是国标区位码,用数字串代表一个汉字输入。区位码是将国家标准局公布的6763个两级汉字分为94个区,每个区分94位,实际上把汉字表示成二维数组,每个汉字在数组中的下标就是区位码。区码和位码各两位十进制数字,因此输入一个汉字需按键四次。数字编码输入的优点是无重码,且输入码与内部编码的转换比较方便,缺点是代码难以记忆。拼音码 拼音码是以汉字拼音为基础的输入方法。使用简单方便,但汉字同音字太多,输入重码率很高,同音字选择
21、影响了输入速度。字形编码 字形编码是用汉字的形状来进行的编码。把汉字的笔划部件用字母或数字进行编码,按笔划的顺序依次输入,就能表示一个汉字。,2.汉字内码汉字内码是用于汉字信息的存储、交换、检索等操作的机内代码,一般采用两个字节表示。英文字符的机内代码是七位的ASCII码,当用一个字节表示时,最高位为“0”。为了与英文字符能相互区别,汉字机内代码中两个字节的最高位均规定为“1”。注意:有些系统中字节的最高位用于奇偶校验位,这种情况下用三个字节表示汉字内码。,3.汉字字模码字模码是用点阵表示的汉字字形代码,它是汉字的输出形式。字模点阵只能用来构成汉字库,用于汉字的显示输出或打印输出。,注意,汉字
22、的输入编码、汉字内码、字模码是计算机中用于输入、内部处理、输出三种不同 用途的编码,不要混为一谈。,图2.1汉字的字模点阵及编码,2.1.5 校验码,元件故障/噪声干扰等各种因素常导致计算机在处理信息过程中出现错误。为了防止错误 可将信号采用专门的逻辑线路进行编码以检测错误,甚至校正错误。通常的方法是在每个字上添加一些校验位,用来确定字中出现错误的位置。最简单且应用广泛的检错码是采用一位校验位的奇校验或偶校验。设(01n-1)是一个n位字,则奇校验位定义为 C01n-1 同理偶校验位定义为 C01n-1,2.2 定点加法、减法运算2.2.1 补码加法,负数用补码表示后,可以和正数一样来处理。这
23、样,运算器里只需要一个加法器就可以了,不必为了负数的加法运算,再配一个减法器。补码加法的公式是 补补补(mod 2)现分四种情况来证明。假设采用定点小数表示,因此证明的先决条件是 1,1,1。,(1)0,0,则0。相加两数都是正数,故其和也一定是正数。正数的补码和原码是一样的,可得:补补补(mod 2)(2)0,0,则0或0时,2()2,进位2必丢失,又因()0,故补补补(mod 2)当0时,2()2,又因()0,故补补2()补(mod 2),(3)0,则0或 0。这种情况等同于第2种情况。(4)0,0,则0。相加两数都是负数,则其和也一定是负数。补2,补2补补222(2)上式右边分为”2”和
24、(2)两部分.既然()是负数,而其绝对值又小于1,那么(2)就一定是小于2而大于1的数,进位”2”必丢失.又因()0,所以补补2()补(mod 2)至此我们证明了,在模2意义下,任意两数的补码之和等于该两数之和的补码.这是补码加法的理论基础,其结论也适用于定点整数。,例8 0.1001,0.0101,用补码求解:补0.1001,补0.0101 补0.1001 补0.0101 补0.1110 所以0.1110,例90.1011,0.0101,用补码求。解:补0.1011,补1.1011 补0.1011 补1.1011 补 10.0110 所以0.0110 由以上两例看到,补码加法的特点,一是符号
25、位要作为数的一部分一起参加运算,二是要在模2的意义下相加,即超过2的进位要丢掉。,2.2.2 补码减法,负数的减法运算也要设法化为加法来做,其所以使用这种方法而不使用直接减法,是因为它可以和常规的加法运算使用同一加法器电路,从而简化了计算机的设计。数用补码表示时,减法运算的公式为 补补补补-补 只要证明补补,上式即得证。,现证明如下:补补补(mod 2)补补补(2.19a)补()补补补补 补补(2.19a)将式(2.19a)与(2.19b)相加,得补补补补补补 补补补 补补补0故 补补(mod 2),从补求补的法则是:对补包括符号位“求反且最末位加1”,即可得到补。写成运算表达式,则为,其中符
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 浮点 计算方法
链接地址:https://www.31ppt.com/p-6476862.html