double f(double x) {
double r12993384 = x;
double r12993385 = r12993384 * r12993384;
double r12993386 = r12993384 + r12993385;
return r12993386;
}
double f(double x) {
double r12993387 = x;
double r12993388 = fma(r12993387, r12993387, r12993387);
return r12993388;
}
x + x \cdot x
(x \cdot x + x)_*




Bits error versus x
| Original | 0.0 |
|---|---|
| Target | 0.0 |
| Herbie | 0 |
Initial program 0.0
Simplified0
Final simplification0
herbie shell --seed 2019101 +o rules:numerics
(FPCore (x)
:name "Expression 2, p15"
:pre (<= 0 x 2)
:herbie-target
(* (+ 1.0 x) x)
(+ x (* x x)))