\sin \left(x + \varepsilon\right) - \sin x
\mathsf{fma}\left(\sin x, \sqrt[3]{{\left(\cos \varepsilon - 1\right)}^{3}}, \cos x \cdot \sin \varepsilon\right) + \mathsf{fma}\left(-\sin x, 1, \sin x \cdot 1\right)double code(double x, double eps) {
return (sin((x + eps)) - sin(x));
}
double code(double x, double eps) {
return (fma(sin(x), cbrt(pow((cos(eps) - 1.0), 3.0)), (cos(x) * sin(eps))) + fma(-sin(x), 1.0, (sin(x) * 1.0)));
}




Bits error versus x




Bits error versus eps
Results
| Original | 37.3 |
|---|---|
| Target | 15.3 |
| Herbie | 0.4 |
Initial program 37.3
rmApplied sin-sum21.9
Applied associate--l+21.9
rmApplied *-un-lft-identity21.9
Applied prod-diff21.9
Applied associate-+r+21.9
Simplified0.4
rmApplied add-cbrt-cube0.4
Simplified0.4
Final simplification0.4
herbie shell --seed 2020049 +o rules:numerics
(FPCore (x eps)
:name "2sin (example 3.3)"
:precision binary64
:herbie-target
(* 2 (* (cos (+ x (/ eps 2))) (sin (/ eps 2))))
(- (sin (+ x eps)) (sin x)))