| Alternative 1 | |
|---|---|
| Accuracy | 99.6% |
| Cost | 6592 |
\[\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);
}
function code(t) return Float64(Float64(1.7e+308 * t) - 1.7e+308) end
function code(t) return fma(1.7e+308, t, -1.7e+308) end
code[t_] := N[(N[(1.7e+308 * t), $MachinePrecision] - 1.7e+308), $MachinePrecision]
code[t_] := N[(1.7e+308 * t + -1.7e+308), $MachinePrecision]
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)
Herbie found 3 alternatives:
| Alternative | Accuracy | Speedup |
|---|
| Original | 34.4% |
|---|---|
| Target | 99.6% |
| Herbie | 99.6% |
Initial program 34.2%
Simplified99.6%
[Start]34.2% | \[ 1.7 \cdot 10^{+308} \cdot t - 1.7 \cdot 10^{+308}
\] |
|---|---|
fma-neg [=>]99.6% | \[ \color{blue}{\mathsf{fma}\left(1.7 \cdot 10^{+308}, t, -1.7 \cdot 10^{+308}\right)}
\] |
metadata-eval [=>]99.6% | \[ \mathsf{fma}\left(1.7 \cdot 10^{+308}, t, \color{blue}{-1.7 \cdot 10^{+308}}\right)
\] |
Final simplification99.6%
| Alternative 1 | |
|---|---|
| Accuracy | 99.6% |
| Cost | 6592 |
| Alternative 2 | |
|---|---|
| Accuracy | 34.4% |
| Cost | 192 |
| Alternative 3 | |
|---|---|
| Accuracy | 0.0% |
| Cost | 64 |
herbie shell --seed 2023178
(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))