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 r4194 = 3.0;
double r4195 = x;
double r4196 = r4195 * r4194;
double r4197 = r4196 * r4195;
double r4198 = 4.0;
double r4199 = r4195 * r4198;
double r4200 = r4197 - r4199;
double r4201 = 1.0;
double r4202 = r4200 + r4201;
double r4203 = r4194 * r4202;
return r4203;
}
double f(double x) {
double r4204 = x;
double r4205 = 9.0;
double r4206 = r4205 * r4204;
double r4207 = 12.0;
double r4208 = r4206 - r4207;
double r4209 = r4204 * r4208;
double r4210 = 3.0;
double r4211 = r4209 + r4210;
return r4211;
}




Bits error versus x
Results
| Original | 0.2 |
|---|---|
| Target | 0.1 |
| Herbie | 0.1 |
Initial program 0.2
Simplified0.1
Taylor expanded around 0 0.1
Taylor expanded around 0 0.1
Simplified0.1
Final simplification0.1
herbie shell --seed 2020025
(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)))