- 1、本文档共8页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
需右移规格化的尾数形式:01.PPT
* 计算机组成原理第三章 知识点四:浮点数运算 主讲教师:秦磊华 问题引入 浮点数运算是计算机中重要的运算类型之一,如何实现浮点数的四则运算? 学习建议 ?系统观:与数据表示的知识关联,选择合适的数据表示方法,便于浮点法运算方法与运算器设计的简化; 通过浮点运算过程理解浮点运算速度慢的原因。培养科学选择数据类型,优化程序设计的习惯。 ?构造观:掌握浮点运算在计算机中的实现方法,并理解浮点运算部件的工作原理。 topolgy topolgy 1.浮点数的规格化 ?为使浮点数的表示具有唯一性并提高数据表示的精确度而提出的概念; ?规格化浮点数的形式(补码为例): 11.0×…×或00.1×…× ; ?需右移规格化的尾数形式:01.×…× 或10.××…×,右移规格化只需一次即可,右移时阶码加1; ?需左移规格化的尾数形式:11.1×…×或00.0×…×, 每算术左移一次,阶码减1,直到变成规格化数为止。 2.浮点数的加/减运算 设有两个浮点数: x=2m×Mx 和y=2n×My x ? y=2m×(Mx ? 2n-m×My) (m ? n 时) 或 x ? y=2n×(2m-n Mx ? My) (m ? n 时) (1)求阶差并对阶: 求阶差,按小阶向大阶看齐的方式对阶; (2)尾数运算: 按定点数加/减运算法则进行尾数加/减; (3)结果规格化:执行规格化操作(若为非规格化数); (4)舍入:舍入尾数右移过程中(右规和对阶) 移出的1; (5)溢出判断:通过阶码双符号位是否相同。(右规过程中) 例1 设 x= 010?0 y=2100?( ? 0 求 x+y 解:先用补码形式表示x 和 y [X]补 = 00 010 , 00 [Y]补 = 00 100 ,11 (1) 对阶 [ ?E]补 =[Ex]补 + [ - Ey]补 = 00010 + 11100 = 11 110 将 x 的尾数右移2位,阶码加 2 ,对阶后的 x 为: [X]补 = 00 100 , 00.0011011011 0011 2)尾数的运算: + 11 11.1000101011 3)尾数规格化 形如11.10???,左规操作一位 , 阶码减 1。 [X+ Y]补= 00 011 ,11 . 000101011 4)舍入:采用 0 舍 1入, 在结果尾数的最低位加1。 X+Y = – 0 ? 2 011 未溢出! 3.浮点数的乘/除运算 ?浮点数的乘/除运算可转化成两数阶码的加/减运算和尾数的乘/除运算; ?尾数的乘/除运算可以转换成加法运算实现; ?可在浮点运算器中设置两个加法器,一个用于阶码运算,另一个同时进行尾数运算,提高浮点运算速度; ?最后还需要对结果进行规格化判断与处理; ?运算过程中阶码加/减、右规和舍入都有可能产生溢出。 知识点四 回顾 ?浮点数规格化的意义与规格化方法; ?浮点加/减运算的步骤; ?浮点运算过程中的溢出; ?理解浮点数据运算相对较慢的原因,并应用于程序设计的优化。 *
文档评论(0)