私はC99 でfetestexcept()を使用していますが、float を乗算すると不正確な結果が得られると不平を言うことがあります ( FE_INEXACT )。float 変数に float リテラルを乗算すると発生するようです。fetestexcept() が文句を言わないように、これをどのように変更できますか?
gcc -std=c99 -lm test.c
#include <stdio.h>
#include <math.h>
#include <fenv.h>
#pragma STDC FENV_ACCESS ON
int main(void)
{
float a = 1.1f;
float b = 1.2f;
float c = a * b * 1.3f;
int exception = fetestexcept(FE_ALL_EXCEPT);
if(exception != 0)
{
printf("Exception: 0x%x\n", exception); // 0x20 FE_INEXACT
}
return 0;
}