double f(double t) {
double r7610021 = 1.7e+308;
double r7610022 = t;
double r7610023 = r7610021 * r7610022;
double r7610024 = r7610023 - r7610021;
return r7610024;
}
double f(double t) {
double r7610025 = 1.7e+308;
double r7610026 = t;
double r7610027 = -r7610025;
double r7610028 = fma(r7610025, r7610026, r7610027);
return r7610028;
}
1.7 \cdot 10^{+308} \cdot t - 1.7 \cdot 10^{+308}(\left( 1.7 \cdot 10^{+308} \right) \cdot t + \left(-1.7 \cdot 10^{+308}\right))_*



Bits error versus t
| Original | 49.1 |
|---|---|
| Target | 0 |
| Herbie | 0 |
Initial program 49.1
rmApplied fma-neg0
Final simplification0
herbie shell --seed 2019102 +o rules:numerics
(FPCore (t)
:name "fma_test2"
:pre (<= 1.9 t 2.1)
:herbie-target
(fma 1.7e+308 t (- 1.7e+308))
(- (* 1.7e+308 t) 1.7e+308))