double code(double x) {
return ((double) (3.0 * ((double) (((double) (((double) (((double) (x * 3.0)) * x)) - ((double) (x * 4.0)))) + 1.0))));
}
double code(double x) {
return ((double) (3.0 + ((double) (x * ((double) (((double) (x * 9.0)) - 12.0))))));
}




Bits error versus x
Results
| Original | 0.1 |
|---|---|
| Target | 0.1 |
| Herbie | 0.1 |
Initial program 0.1
Simplified0.1
Taylor expanded around 0 0.1
Simplified0.1
Final simplification0.1
herbie shell --seed 2020191
(FPCore (x)
:name "Diagrams.Tangent:$catParam from diagrams-lib-1.3.0.3, D"
:precision binary64
:herbie-target
(+ 3.0 (- (* (* 9.0 x) x) (* 12.0 x)))
(* 3.0 (+ (- (* (* x 3.0) x) (* x 4.0)) 1.0)))