计算机组成原理:3.5 浮点运算器.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
计算机组成原理 Slide * ;第 3.5 节;3.5、浮点运算方法;早期的浮点运算 软件实现 协处理器-浮点部件 现在的处理器 具有浮点运算功能 指令系统也包含有浮点运算指令 ;浮点数据表示——回顾;浮点数据表示——回顾;浮点数 规格化(本书讨论) 非规格化 规格化浮点数据运算 具有数的表示唯一、编程方便、有效精度高等优点 阶码和尾数分别进行 阶码是定点整数,尾数是定点小数 运算的结果必须规格化;规格化浮点数尾数形式 00.1???? (正数:原码、补码、反码形式) 11.0???? (负数:补码、反码形式) 不将-1/2列入规格化数 规格化数据通常采用补码表示 11.1???? (负数:原码形式);3.5.1、浮点加(减)运算;判零 目的 简化操作 浮点零 尾数为零 浮点阶码下溢,浮点数作为机器零处理;对阶 对阶使两数的阶码相等,即对齐小数点 原则:小阶向大阶看齐 具体过程 求阶差 保留大阶作为和(差)的阶 阶小的数的尾数右移阶差位(精度有损失), 阶码加阶差得新的阶;例: 设A=0.1101×1001,B=-(0.1010)×1011,求两浮点数之和,要求采用补码数据表示 判零 对阶 [A]补=00 01 , 00.1101 [B]补=00 11 , 11.0110 [?E] =[EA]补-[EB]补=00 01+11 01=11 10, 则?E =-2,需要对阶 [A]补=00 11, 00.0011,有精度损失问题;求和 就是对尾数进行定点加(减)运算 上例,经过对阶后: [A]补=00 11, 00.0011, [B]补=00 11 , 11.0110 故:[MA]补+[MB]补=00.0011+11.0110=11.1001 则:[A+B] 补=00 11,11.1001;规格化 尾数加减后,若结果不是规格化浮点数,还须将尾数移位,使之规格化: 1/2?M1,M=00.1XX…X,M为正数 -1/2M?-1,M=11.0XX…X,M为负数 [-1/2]补=11.10...0,不便于规格化判断 [-1]补=11.00…0,记入规格化数 原码的规格化:尾数最高位为1;规格化 左规 若结果尾数两符号位相等且与尾数第一位相等,则需左规:将尾数左移,每左移一位,阶码减1,直至尾数第一位与尾符不等时为止 右规 若结果两位符号位不等( 01.XX…X 或10.XX…X ),则需右规:将尾数右移1位,阶码加1。显然,右规最多右移1位;4)规格化 上例:[A+B] 补=00 11,11.1001 需要左规,左移1位,阶码减1 则:[A+B]补=00 10,11.0010;舍入 目的 减??误差 注意问题 使误差不超过一定的范围。例如尾数为n位,要使误差不超过2-n 大量运算过程中,力求误差保持平衡,避免产生较大的积累误差; 舍入 0舍1入法 右移时,若丢掉的位数的最高位为0,则舍去;若丢掉的位数的最高位为1,则将尾数的末位加1(相当于舍入) 通过设置专门的寄存器或指定寄存器来记住丢掉数据的最高位,由它来控制所得尾数最末位是否加1; 舍入 恒置1法 只要产生丢失数的情况,将尾数的末位置1,不管末位原来是1还是0 如果原来末位是1(0),舍入置1后,实际上数舍去(入),出现负(正)误差 在浮点加(减)过程中,凡遇到需对阶或右规时,和(差)的尾数末位均应恒置1;例1: 设A= 0.1010×10-01,B= -(0. 0001)×1001,求两浮点数之和,要求采用补码数据表示 判零 对阶 [A]补=11 11 , 00. 1010 [B]补=00 01 , 11. 1111 [?E] =[EA]补-[EB]补=11 11+11 11=11 10,则 [A]补=00 01, 00.0010,需要考虑舍入问题;求和 [MA]补+[MB]补=00.0010+11. 1111 =00.0001 则:[A+B] 补=00 01,00.0001 规格化 需要左规,左移3位,阶码减3 ,则 [A+B]补=11 10,00.1000 舍入 采用“恒置1法” ,则 [A+B]补=11 10,00.1001;银河—1浮点加法器实现;银河—1浮点加法器实现;T2数据格式;T2中流水线结构;浮点加法步骤 对阶(操作数阶码相减,调整尾数向大阶对齐) 尾数相加(加法操作并舍入) 尾数规格化(计算前导零等) 调整阶码(调整大阶) 舍入处理;舍入方式 最近舍入 舍入到能够表示的最近浮点数 向正无穷舍入 向负无穷舍入 向零舍入;浮点异常 异常设置状态标志或产生自陷(Trap) 无效操作 除零 上溢 下溢 不精确;小结:浮点数的加减运算与实现;3.5.2、浮点乘法运算;判零 如操作数中有一个为零,乘积必为零

您可能关注的文档

文档评论(0)

学习让人进步 + 关注
实名认证
文档贡献者

活到老,学到老!知识无价!

1亿VIP精品文档

相关文档