\left(3 \cdot \left(2 - x \cdot 3\right)\right) \cdot x
\left(6 - 9 \cdot x\right) \cdot x
double f(double x) {
double r713326 = 3.0;
double r713327 = 2.0;
double r713328 = x;
double r713329 = r713328 * r713326;
double r713330 = r713327 - r713329;
double r713331 = r713326 * r713330;
double r713332 = r713331 * r713328;
return r713332;
}
double f(double x) {
double r713333 = 6.0;
double r713334 = 9.0;
double r713335 = x;
double r713336 = r713334 * r713335;
double r713337 = r713333 - r713336;
double r713338 = r713337 * r713335;
return r713338;
}




Bits error versus x
Results
| Original | 0.3 |
|---|---|
| Target | 0.2 |
| Herbie | 0.2 |
Initial program 0.3
Taylor expanded around 0 0.2
Final simplification0.2
herbie shell --seed 2020046 +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))