\left(3.0 \cdot \left(2.0 - x \cdot 3.0\right)\right) \cdot x
\mathsf{fma}\left(x, 6.0, -\left(x \cdot x\right) \cdot 9.0\right)double f(double x) {
double r12534360 = 3.0;
double r12534361 = 2.0;
double r12534362 = x;
double r12534363 = r12534362 * r12534360;
double r12534364 = r12534361 - r12534363;
double r12534365 = r12534360 * r12534364;
double r12534366 = r12534365 * r12534362;
return r12534366;
}
double f(double x) {
double r12534367 = x;
double r12534368 = 6.0;
double r12534369 = r12534367 * r12534367;
double r12534370 = 9.0;
double r12534371 = r12534369 * r12534370;
double r12534372 = -r12534371;
double r12534373 = fma(r12534367, r12534368, r12534372);
return r12534373;
}




Bits error versus x
| Original | 0.2 |
|---|---|
| Target | 0.2 |
| Herbie | 0.1 |
Initial program 0.2
Taylor expanded around 0 0.2
Simplified0.2
rmApplied fma-neg0.1
Final simplification0.1
herbie shell --seed 2019156 +o rules:numerics
(FPCore (x)
:name "Diagrams.Tangent:$catParam from diagrams-lib-1.3.0.3, E"
:herbie-target
(- (* 6.0 x) (* 9.0 (* x x)))
(* (* 3.0 (- 2.0 (* x 3.0))) x))