stbking 发表于 2019-1-24 15:51:45

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

见下面的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都不能正确给出计算结果。请问是什么原因?有其他替代函数吗?谢谢!

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);
页: [1]
查看完整版本: stm32 float 函数 modf 和fmod不能正确计算