\left(x \cdot x\right) \cdot \left(3.0 - x \cdot 2.0\right)
\frac{x \cdot \left(3.0 \cdot 3.0 - \left(2.0 \cdot x\right) \cdot \left(2.0 \cdot x\right)\right)}{3.0 + 2.0 \cdot x} \cdot xdouble f(double x) {
double r35559354 = x;
double r35559355 = r35559354 * r35559354;
double r35559356 = 3.0;
double r35559357 = 2.0;
double r35559358 = r35559354 * r35559357;
double r35559359 = r35559356 - r35559358;
double r35559360 = r35559355 * r35559359;
return r35559360;
}
double f(double x) {
double r35559361 = x;
double r35559362 = 3.0;
double r35559363 = r35559362 * r35559362;
double r35559364 = 2.0;
double r35559365 = r35559364 * r35559361;
double r35559366 = r35559365 * r35559365;
double r35559367 = r35559363 - r35559366;
double r35559368 = r35559361 * r35559367;
double r35559369 = r35559362 + r35559365;
double r35559370 = r35559368 / r35559369;
double r35559371 = r35559370 * r35559361;
return r35559371;
}




Bits error versus x
Results
| Original | 0.2 |
|---|---|
| Target | 0.2 |
| Herbie | 0.2 |
Initial program 0.2
Taylor expanded around 0 0.1
Simplified0.2
rmApplied flip--0.2
Applied associate-*r/0.2
Final simplification0.2
herbie shell --seed 2019164 +o rules:numerics
(FPCore (x)
:name "Data.Spline.Key:interpolateKeys from smoothie-0.4.0.2"
:herbie-target
(* x (* x (- 3.0 (* x 2.0))))
(* (* x x) (- 3.0 (* x 2.0))))