你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

STM32F302R8 浮点计算出错

[复制链接]
jplzl10000 提问时间:2017-3-21 20:16 /
QQ图片20170321173815.png
如图所示,这条除法会计算很多次,但会在第几千次的某一次中计算错误,结果如图中寄存器所示的。
有时候,也能计算正常。但错的时候多。
这会是什么原因造成的呢?
收藏 1 评论4 发布时间:2017-3-21 20:16

举报

4个回答
回答时间:2017-3-22 09:38:27
是数据溢出了,楼主你换成double型的吧。我用C#测试的。
jplzl10000 回答时间:2017-3-22 10:21:47
安 发表于 2017-3-22 09:38
是数据溢出了,楼主你换成double型的吧。我用C#测试的。

但是我有试过,把那个plus_off乘以1000,再来计算的话,ti还是会有错哦
回答时间:2017-3-22 10:23:24
本帖最后由 安 于 2017-3-22 10:38 编辑

VI也溢出了。直接定义看看会不会提示错误。 t9.png
jplzl10000 回答时间:2017-3-25 23:02:22
安 发表于 2017-3-22 10:23
VI也溢出了。直接定义看看会不会提示错误。

我是宏定义的0.0065f
然后,后面那一串,是c99编译器整出来的吧
溢出的话,不会只是某一次吧,况且,vi还有上到1000多的时候,也不会出错
我想,有可能是用了一些不太确定的操作吧,
比如两个浮点比较时用了>=/<=这样的比较
或是用了>=0.0f这样的操作
关于 意法半导体
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
13245底部标题123相同标题
12底部标题123相同标题
33333底部标题123相同序号
3435底部标题-无链接
关注我们
st-img 微信公众号
st-img 手机版