ieee754数据转换程序

1.问题的提出笔者在系统开发中采用RS485实现单片机与外围设备的通信,通信采用通用串行接口协议(USS),按照串行总线的主从通讯原理来确定访问的方法。USS规定了一套严格的通信规则,关于浮点数参数值,USS规定采用IEEE-754格式进行传送。例如,浮点数50.0,在通信中传送的是它的IEEE-754格式,即4字节的十六进制424800H.因此,单片机的C程序,在发送或接收外围设各的参数值时,需要解决如何实现浮点数与IEEE格式转换的问题。2.IEEE浮点数的格式在计算机中,浮点数的存储均采用4字节的IEEE-754格式。例如,浮点数50.0的IEEE表示形式如下:二进制:其中,最高位表示符号,"1"表示负,"0"表示正;第23~30位表示阶码。注意:阶码是以2为底的指数再加上偏移量127.第0~22位是尾数部分。尾数的整数部分永远为1,因此不予保存,但它是隐含存在的。一个浮点数计算式为:例如,前面绘出的浮点数的表示形式中,s=0,n=132,m=(1/2+0/4+0/8+1/16+0/32+……),则计算结果为50.0.3.浮点数与IEEE格式转换在最初的C语言编程中,笔者根据上面介绍的IEEE表示形式,采用移位计算的方法实现浮点数和IEEE格式转换。当接收到外围设备传来的4字节IEEE格式参数值时,依次将符号、阶码、尾数通过移位取出,然后按照IEEE计算规则计算出对应的浮点数。当需要发送给外围设备的浮点数时,按相反的方法将其转化为IEEE格式后再发送出去。笔者一直感觉上述方法太麻烦,而且效率太低。后来笔者想到,既然在C语言中浮点数本身就是采用IEEE格式来存储的,能否利用C语言本身的机制来实现浮点数和IEEE格式的转换?经过尝试,发现利用unlon数据类型可以很好地完成这工作,即只需定义下面这个union类型:注意:类型定义的后面别忘了还有个符号";",union类型虽然有两个内部变量,但两个内部变量占用同-地址空间,它只占用4个字节。内部float变量a(占用4个字节)和char数组b(同样占用4个字节)从同一个地址开始存放,并共享同一块内存空间。C语言中,对于单精度浮点数a,采用四个字节(IEEE格式)来存储,依次存储在四个连续的存储单元内,低字节存储在低地址存储单元,高字节存在高地址存储单元;字符数组b也采用和a同样的存储方式。利用unlon数据类型,可以直接访问浮点数以IEEE格式存放在存储单元中的十六进制字节,通过直接读取或修改这些十六进制字节,便可以巧妙地实现浮点数与IEEE格式的转换。(1)IEEE格式转换浮点数当单片机接收来自USS总线的数据时,只需将4个字节的数据放到内部变量b中,再访问内部变量a,即可实现转换。下面给出示意程序,供参考。(2)浮点数转换IEEE格式当单片机处理好数据后,需要把浮点型的数据转换成IEEE格式,输出给USS总线。只需把数据赋予内部变量a,再从内部变量b中取出对应的4个字节即可。2.1定义union数据typedefunion{floatul_Temp;uint8uc_Buf[4];}un_DtformConver;2.2应用un_DtformConverDtformConver;uint8i;int32il_Temp32;floatf_Temp;//十进制float型数据转换成IEEE754标准DtformConver.ul_Temp=220.1;il_Temp32=0;for(i=0;i<4;i++){il_Temp32|=(int32)(DtformConver.uc_Buf[i]<<(i*8));}//IEEE754标准转换成十进制floatil_Temp32=0x435C0000;//实际十进制值是220memset((uint8*)&DtformConver.uc_Buf[0],0,4);for(i=0;i<4;i++){DtformConver.uc_Buf[i]=(uint8)(il_Temp32>>(i*8));}f_Temp=DtformConver.ul_Temp;

1、当您付费下载文档后,您只拥有了使用权限,并不意味着购买了版权,文档只能用于自身使用,不得用于其他商业用途(如 [转卖]进行直接盈利或[编辑后售卖]进行间接盈利)。
2、本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供参考,付费前请自行鉴别。
3、如文档内容存在侵犯商业秘密、侵犯著作权等,请点击“举报”。

常见问题具体如下:

1、问:已经付过费的文档可以多次下载吗?

      答:可以。登陆您已经付过费的账号,付过费的文档可以免费进行多次下载。

2、问:已经付过费的文档不知下载到什么地方去了?

     答:电脑端-浏览器下载列表里可以找到;手机端-文件管理或下载里可以找到。

            如以上两种方式都没有找到,请提供您的交易单号或截图及接收文档的邮箱等有效信息,发送到客服邮箱,客服经核实后,会将您已经付过费的文档即时发到您邮箱。

注:微信交易号是以“420000”开头的28位数字;

       支付宝交易号是以“2024XXXX”交易日期开头的28位数字。

客服邮箱:

biganzikefu@outlook.com

所有的文档都被视为“模板”,用于写作参考,下载前须认真查看,确认无误后再购买;

文档大部份都是可以预览的,笔杆子文库无法对文档的真实性、完整性、准确性以及专业性等问题提供审核和保证,请慎重购买;

文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为依据;

如果您还有什么不清楚的或需要我们协助,可以联系客服邮箱:

biganzikefu@outlook.com

常见问题具体如下:

1、问:已经付过费的文档可以多次下载吗?

      答:可以。登陆您已经付过费的账号,付过费的文档可以免费进行多次下载。

2、问:已经付过费的文档不知下载到什么地方去了?

     答:电脑端-浏览器下载列表里可以找到;手机端-文件管理或下载里可以找到。

            如以上两种方式都没有找到,请提供您的交易单号或截图及接收文档的邮箱等有效信息,发送到客服邮箱,客服经核实后,会将您已经付过费的文档即时发到您邮箱。

注:微信交易号是以“420000”开头的28位数字;

       支付宝交易号是以“2024XXXX”交易日期开头的28位数字。

文秘专家
机构认证
内容提供者

1

确认删除?