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

stm32 float 函数 modf 和fmod不能正确计算

[复制链接]
stbking 提问时间:2019-1-24 15:51 /
见下面的code:

  float param=0.0, fractpart=0.0, intpart=0.0;
  param = 3.141;
  fractpart = modf (param , &intpart);
  printf ("Result: %f = %f + %f \r\n", param, intpart, fractpart);

  fractpart = fmod (param , &intpart);
  printf ("Result: %f = %f + %f \r\n", param, intpart, fractpart);

--------------------------

Result: 3.141000 = 0.000000 + 537170816.000000
Result: 3.141000 = 0.000000 + 0.000000


我是在F756上跑的。
看起来这两个函数 modf和 fmod都不能正确给出计算结果。请问是什么原因?有其他替代函数吗?谢谢!
收藏 评论1 发布时间:2019-1-24 15:51

举报

1个回答
stbking 回答时间:2019-1-24 15:58:53
知道答案了,下面是正确的使用方法。

        float fractpart=0.0;
        double        intpart=0.0;
  double param=0.0;

  param = 3.141;
  fractpart = modf (param , &intpart);
  printf ("Result: %f = %f + %f \r\n", param, intpart, fractpart);

  fractpart = fmod (param , intpart);
  printf ("Result: %f = %f + %f \r\n", param, intpart, fractpart);

所属标签

相似问题

关于意法半导体
我们是谁
投资者关系
意法半导体可持续发展举措
创新和工艺
招聘信息
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
关注我们
st-img 微信公众号
st-img 手机版