\left(3 \cdot \left(2 - x \cdot 3\right)\right) \cdot x
\mathsf{fma}\left(x, 6, -\left(x \cdot x\right) \cdot 9\right)double f(double x) {
double r30793762 = 3.0;
double r30793763 = 2.0;
double r30793764 = x;
double r30793765 = r30793764 * r30793762;
double r30793766 = r30793763 - r30793765;
double r30793767 = r30793762 * r30793766;
double r30793768 = r30793767 * r30793764;
return r30793768;
}
double f(double x) {
double r30793769 = x;
double r30793770 = 6.0;
double r30793771 = r30793769 * r30793769;
double r30793772 = 9.0;
double r30793773 = r30793771 * r30793772;
double r30793774 = -r30793773;
double r30793775 = fma(r30793769, r30793770, r30793774);
return r30793775;
}




Bits error versus x
| Original | 0.3 |
|---|---|
| Target | 0.2 |
| Herbie | 0.1 |
Initial program 0.3
Taylor expanded around 0 0.2
Simplified0.2
rmApplied fma-neg0.1
Final simplification0.1
herbie shell --seed 2019192 +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))