x \cdot \left(x \cdot x\right) + x \cdot x
\mathsf{fma}\left(x, x, {x}^{3}\right)double f(double x) {
double r51051 = x;
double r51052 = r51051 * r51051;
double r51053 = r51051 * r51052;
double r51054 = r51053 + r51052;
return r51054;
}
double f(double x) {
double r51055 = x;
double r51056 = 3.0;
double r51057 = pow(r51055, r51056);
double r51058 = fma(r51055, r51055, r51057);
return r51058;
}




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 2019303 +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)))