- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
M68HC08 浮点运算子程序
M68HC08 是一种高性能高速8 位单片机。它广泛应用于家用
电器、仪器仪表和工业控制等场合。
绝大多数单片机应用系统都离不开数值计算,并且有时数的范
围可能比较大,计算也比较复杂,这时就需要使用浮点数。为此,
下面将介绍适用于M68HC08 单片机的一套IEEE 单精度浮点运算
子程序,它包括浮点四则运算、数制转换、函数运算等子程序。
一. 浮点数格式
浮点数一般采用M ×2E 的形式来表示,M 为,它一般为小数;
E 为阶码,它为整数。M、E 有各种表示方法。对IEEE 单精度浮点
数,M 为符号-数值表示法,可计为S ×M :S 为符号,正数S=1,
负数S=-1。M 为24 位二进制小数,对规格化浮点数,2M=1,
故最高位总为1。在存放M 时,可省略最高位的1,仅存放23 位。
E 采用移码表示,E=数值+127。例127 ($7F )表示0 ,$80 表
示1,$7E 表示-1。存放时的格式如下:
数
符 阶 码 (8 位) 尾 数 ( 23 位)
S
31 30 24 23 22 16 15 8 7
0
38
该浮点数为4 字节,可表示的最大值为10 ,最小值(绝对值)
为 10-38 。它的有效数字约为七位十进制数。全0 表示零,
第一字节为FF 表示溢出。
1
本套浮点运算子程序中,除了M68HC08 的A、H、X 寄存器
外,不使用其他固定RAM 单元。它使用堆栈来传递参数和运算结
果,中间运算单元也使用堆栈来实现,以方便子程序调用。堆栈中
传递的浮点数,低位地址存放浮点数的高位字节。
二. 浮点四则运算子程序
1. 加法子程序 FADD
①功能:X +Y - Z
入口:X、Y 在堆栈中,Y 在高位地址,X 在低位地址,格
式如下图 (E 表示阶码 (高位字节),H 表示高位尾数,M 表示中
位尾数,L 表示低位尾数)。
SP
SP + XE
1
SP + XH
2
SP + XM
3
SP + XL
4
SP + YE
5
SP + YH
6
SP + YM
7
SP + YL
8
出口:Z 在堆栈中,格式如下图。
2
SP
SP + ZE
1
SP + ZH
2
SP + ZM
3
SP + ZL
4
FADD 需使用12 字节堆栈区 (含8 字节的X、Y,2 字节调用
指令的返回地址)。
执行时间约20 -80 μs。
②算法:
1) 对阶:右移阶小的数的尾数,使它的阶码等于大阶。
2) 执行定点数 (尾数)加(减)法运算。
3) 结果规格化。
③程序:
***************************************************
* FADD: Addition X + Y - Z
文档评论(0)