搜索
bottom↓
回复: 5

關於pow的用法

[复制链接]

出0入0汤圆

发表于 2012-12-13 11:58:11 | 显示全部楼层 |阅读模式
請問 i 的數值是多少?

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

阿莫论坛20周年了!感谢大家的支持与爱护!!

知道什么是神吗?其实神本来也是人,只不过神做了人做不到的事情 所以才成了神。 (头文字D, 杜汶泽)

出0入0汤圆

发表于 2013-2-19 13:03:09 | 显示全部楼层
本帖最后由 清雨影 于 2013-2-19 13:06 编辑

姐姐,你原来是香港的啊……怪不得繁体字加粤字。
关于POW,本身是针对单精度(Keil里面)浮点数运算的函数,会有第7位的舍入误差。
比如,1.999999其实就是2,第七位有效数字是不确定的,也就是说.
只有第六位是固定的。没办法,精度就是这样,只能允许6位有效数字。
第七位只有在数据满足一定条件的情况下是有效的,这个就不要去想了。
------------------------------
话说回来,为什么你的误差会出现在第四位,是你C语言没学好。
pow在keil里的原形:extern float pow   (float x, float y);
i=(pow(10,4));等于i=(u32)pow(10,4);
pow(10,4)=9999.998(那个8是第七位,做不得准)
(u32)9999.998=9999(转换为int类型时丢掉小数)
所以误差就放大了。所以要四舍五入。

出0入0汤圆

发表于 2013-2-19 13:25:20 | 显示全部楼层
学习了!

出0入0汤圆

 楼主| 发表于 2013-2-20 09:40:44 | 显示全部楼层
清雨影 发表于 2013-2-19 13:03
姐姐,你原来是香港的啊……怪不得繁体字加粤字。
关于POW,本身是针对单精度(Keil里面)浮点数运算的函数 ...

請問如何可以克服呢?

出0入0汤圆

发表于 2013-2-20 13:33:22 | 显示全部楼层
mbass51 发表于 2013-2-20 09:40
請問如何可以克服呢?

那就是四舍五入了。在数字绝对值小于等于999999的时候这一招非常有效。
但是C语言里没有round函数。
提供代码如下:
#define TR_INT unsigned long int
TR_INT round(float x){
    return((TR_INT)(x+0.5));
}
修改TR_INT后面的类型以得到不同类型的返回值。
i=(pow(10,4));修改为
i=round(pow(10,4));
即可。

出0入0汤圆

 楼主| 发表于 2013-2-20 15:11:17 | 显示全部楼层
清雨影 发表于 2013-2-20 13:33
那就是四舍五入了。在数字绝对值小于等于999999的时候这一招非常有效。
但是C语言里没有round函数。
提供 ...

THANK YOU,謝謝
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-7-23 18:18

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表