1.7 \cdot 10^{+308} \cdot t - 1.7 \cdot 10^{+308}
\mathsf{fma}\left(1.7 \cdot 10^{+308}, t, -1.7 \cdot 10^{+308}\right)
(FPCore (t) :precision binary64 (- (* 1.7e+308 t) 1.7e+308))
(FPCore (t) :precision binary64 (fma 1.7e+308 t -1.7e+308))
double code(double t) {
return (1.7e+308 * t) - 1.7e+308;
}
double code(double t) {
return fma(1.7e+308, t, -1.7e+308);
}




Bits error versus t
| Original | 64.0 |
|---|---|
| Target | 0.3 |
| Herbie | 0.3 |
Initial program 64.0
Simplified0.3
Final simplification0.3
herbie shell --seed 2022125
(FPCore (t)
:name "fma_test2"
:precision binary64
:pre (and (<= 1.9 t) (<= t 2.1))
:herbie-target
(fma 1.7e+308 t (- 1.7e+308))
(- (* 1.7e+308 t) 1.7e+308))