\left(3 \cdot \left(2 - x \cdot 3\right)\right) \cdot x
x \cdot \left(6 - x \cdot 9\right)
double f(double x) {
double r2840 = 3.0;
double r2841 = 2.0;
double r2842 = x;
double r2843 = r2842 * r2840;
double r2844 = r2841 - r2843;
double r2845 = r2840 * r2844;
double r2846 = r2845 * r2842;
return r2846;
}
double f(double x) {
double r2847 = x;
double r2848 = 6.0;
double r2849 = 9.0;
double r2850 = r2847 * r2849;
double r2851 = r2848 - r2850;
double r2852 = r2847 * r2851;
return r2852;
}




Bits error versus x
Results
| Original | 0.3 |
|---|---|
| Target | 0.2 |
| Herbie | 0.2 |
Initial program 0.3
rmApplied associate-*l*0.3
rmApplied add-cube-cbrt0.3
Applied associate-*l*0.5
Taylor expanded around 0 0.2
Simplified0.2
Final simplification0.2
herbie shell --seed 2020025 +o rules:numerics
(FPCore (x)
:name "Diagrams.Tangent:$catParam from diagrams-lib-1.3.0.3, E"
:precision binary64
:herbie-target
(- (* 6 x) (* 9 (* x x)))
(* (* 3 (- 2 (* x 3))) x))