77范文网 - 专业文章范例文档资料分享平台

Q格式数据运算

来源:网络收集 时间:2020-06-03 下载这篇文档 手机版
说明:文章内容仅供预览,部分内容可能不全,需要完整文档或者需要复制内容,请下载word后使用。下载word有问题请添加微信号:或QQ: 处理(尽可能给您提供完整文档),感谢您的支持与谅解。点击这里给我发消息

Q格式数据运算

1、浮点数与定点数的转换关系可表示为

浮点数(x)转换为定点数(xq):

xq=(int)x*2Q

xqx=(float)Q

定点数(xq)转换为浮点数(x):

2

2 加法/减法运算的C语言定点摸拟 设浮点加法运算的表达式为: float x,y,z; z=x+y;

将浮点加法/减法转化为定点加法/减法时最重要的一点就是必须保证两个操作数的定标 temp=x+temp;

z=temp>>(Qx-Qz),若Qx>=Qz z=temp<<(Qz-Qx),若Qx<=Qz 例1.4结果超过16位的定点加法

设x=l5000,y=20000,则浮点运算值为z=x+y=35000,显然z>32767,因此 Qx=1,Qy=0,Qz=0,则定点加法为: x=30000;y=20000; temp=20000<<1=40000;

temp=temp+x=40000+30000=70000; z=70000L>>1=35000;

3 定点乘法

设浮点乘法运算的表达式为: float x,y,z; z = xy;

假设经过统计后x的定标值为Qx(比如Q10),y的定标值为Qy,乘积z的定标值为Qz,则 定点表示的乘法为: int x,y,z; long temp; temp = (long)x;

z = (temp×y) >> (Qx+Qy-Qz);

例1.9 Q15*Q15=Q30 0.5*0.5=0.25

0.100000000000000;Q15 * 0.100000000000000;Q15

-------------------------------------------- 00.010000000000000000000000000000=0.25;Q30

两个Q15的小数相乘后得到一个Q30的小数,即有两个符号位。一般情况下相乘后得到的满精度数不必全部保留,而只需保留16位单精度数。由于相乘后得到的高16位不满15位的小数据度,为了达到15位精度,可将乘积左移一位.

float x,y,z; z=x*y; 假设x用Qx(比如Q10)表示xq,y用Qy(比如Q6)表示yq, 当Qx+Qy=16时; z=x*y=xq*yq;==》则乘积为Q16数据,即32位的乘积的高16位为Q0格式的数据。

百度搜索“77cn”或“免费范文网”即可找到本站免费阅读全部范文。收藏本站方便下次阅读,免费范文网,提供经典小说教育文库Q格式数据运算在线全文阅读。

Q格式数据运算.doc 将本文的Word文档下载到电脑,方便复制、编辑、收藏和打印 下载失败或者文档不完整,请联系客服人员解决!
本文链接:https://www.77cn.com.cn/wenku/jiaoyu/1086401.html(转载请注明文章来源)
Copyright © 2008-2022 免费范文网 版权所有
声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。
客服QQ: 邮箱:tiandhx2@hotmail.com
苏ICP备16052595号-18
× 注册会员免费下载(下载后可以自由复制和排版)
注册会员下载
全站内容免费自由复制
注册会员下载
全站内容免费自由复制
注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: