3 \cdot \left(\left(\left(x \cdot 3\right) \cdot x - x \cdot 4\right) + 1\right)
x \cdot \left(9 \cdot x - 12\right) + 3
double f(double x) {
double r710157 = 3.0;
double r710158 = x;
double r710159 = r710158 * r710157;
double r710160 = r710159 * r710158;
double r710161 = 4.0;
double r710162 = r710158 * r710161;
double r710163 = r710160 - r710162;
double r710164 = 1.0;
double r710165 = r710163 + r710164;
double r710166 = r710157 * r710165;
return r710166;
}
double f(double x) {
double r710167 = x;
double r710168 = 9.0;
double r710169 = r710168 * r710167;
double r710170 = 12.0;
double r710171 = r710169 - r710170;
double r710172 = r710167 * r710171;
double r710173 = 3.0;
double r710174 = r710172 + r710173;
return r710174;
}




Bits error versus x
Results
| Original | 0.2 |
|---|---|
| Target | 0.1 |
| Herbie | 0.1 |
Initial program 0.2
Taylor expanded around 0 0.1
Simplified0.1
Taylor expanded around 0 0.1
Simplified0.1
rmApplied fma-udef0.1
Final simplification0.1
herbie shell --seed 2020033 +o rules:numerics
(FPCore (x)
:name "Diagrams.Tangent:$catParam from diagrams-lib-1.3.0.3, D"
:precision binary64
:herbie-target
(+ 3 (- (* (* 9 x) x) (* 12 x)))
(* 3 (+ (- (* (* x 3) x) (* x 4)) 1)))