\sin \left(x + \varepsilon\right) - \sin x
\left(\mathsf{fma}\left(\cos \left(\frac{1}{2} \cdot \varepsilon\right), \cos x, -\sin x \cdot \sin \left(\frac{\varepsilon}{2}\right)\right) \cdot \sin \left(\frac{\varepsilon}{2}\right)\right) \cdot 2double f(double x, double eps) {
double r2393941 = x;
double r2393942 = eps;
double r2393943 = r2393941 + r2393942;
double r2393944 = sin(r2393943);
double r2393945 = sin(r2393941);
double r2393946 = r2393944 - r2393945;
return r2393946;
}
double f(double x, double eps) {
double r2393947 = 0.5;
double r2393948 = eps;
double r2393949 = r2393947 * r2393948;
double r2393950 = cos(r2393949);
double r2393951 = x;
double r2393952 = cos(r2393951);
double r2393953 = sin(r2393951);
double r2393954 = 2.0;
double r2393955 = r2393948 / r2393954;
double r2393956 = sin(r2393955);
double r2393957 = r2393953 * r2393956;
double r2393958 = -r2393957;
double r2393959 = fma(r2393950, r2393952, r2393958);
double r2393960 = r2393959 * r2393956;
double r2393961 = r2393960 * r2393954;
return r2393961;
}




Bits error versus x




Bits error versus eps
| Original | 37.3 |
|---|---|
| Target | 15.1 |
| Herbie | 0.3 |
Initial program 37.3
rmApplied diff-sin37.6
Simplified15.2
Taylor expanded around inf 15.2
Simplified15.1
rmApplied fma-udef15.1
Applied cos-sum0.3
Simplified0.3
rmApplied fma-neg0.3
Final simplification0.3
herbie shell --seed 2019151 +o rules:numerics
(FPCore (x eps)
:name "2sin (example 3.3)"
:herbie-target
(* 2 (* (cos (+ x (/ eps 2))) (sin (/ eps 2))))
(- (sin (+ x eps)) (sin x)))