x \cdot \left(x \cdot x\right) + x \cdot x
\mathsf{expm1}\left(\mathsf{log1p}\left(\mathsf{fma}\left(x, x, {x}^{3}\right)\right)\right)double code(double x) {
return ((x * (x * x)) + (x * x));
}
double code(double x) {
return expm1(log1p(fma(x, x, pow(x, 3.0))));
}




Bits error versus x
Results
| Original | 0.0 |
|---|---|
| Target | 0.0 |
| Herbie | 0.0 |
Initial program 0.0
Simplified0.0
rmApplied expm1-log1p-u0.0
Final simplification0.0
herbie shell --seed 2020066 +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)))