x \cdot \left(x \cdot x\right) + x \cdot x
\mathsf{fma}\left(x, x, {x}^{3}\right)double f(double x) {
double r77334 = x;
double r77335 = r77334 * r77334;
double r77336 = r77334 * r77335;
double r77337 = r77336 + r77335;
return r77337;
}
double f(double x) {
double r77338 = x;
double r77339 = 3.0;
double r77340 = pow(r77338, r77339);
double r77341 = fma(r77338, r77338, r77340);
return r77341;
}




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