\cos \left(x + \varepsilon\right) - \cos x
-2 \cdot \left(\sin \left(\frac{\varepsilon}{2}\right) \cdot \left(\sin x \cdot \cos \left(\varepsilon \cdot 0.5\right)\right) + \sin \left(\frac{\varepsilon}{2}\right) \cdot \left(\cos x \cdot \sin \left(\varepsilon \cdot 0.5\right)\right)\right)(FPCore (x eps) :precision binary64 (- (cos (+ x eps)) (cos x)))
(FPCore (x eps) :precision binary64 (* -2.0 (+ (* (sin (/ eps 2.0)) (* (sin x) (cos (* eps 0.5)))) (* (sin (/ eps 2.0)) (* (cos x) (sin (* eps 0.5)))))))
double code(double x, double eps) {
return ((double) (((double) cos(((double) (x + eps)))) - ((double) cos(x))));
}
double code(double x, double eps) {
return ((double) (-2.0 * ((double) (((double) (((double) sin((eps / 2.0))) * ((double) (((double) sin(x)) * ((double) cos(((double) (eps * 0.5)))))))) + ((double) (((double) sin((eps / 2.0))) * ((double) (((double) cos(x)) * ((double) sin(((double) (eps * 0.5))))))))))));
}



Bits error versus x



Bits error versus eps
Results
Initial program 39.7
rmApplied diff-cos34.0
Simplified14.6
Taylor expanded around inf 14.6
Simplified14.6
rmApplied sin-sum0.4
rmApplied distribute-lft-in0.4
Final simplification0.4
herbie shell --seed 2020198
(FPCore (x eps)
:name "2cos (problem 3.3.5)"
:precision binary64
(- (cos (+ x eps)) (cos x)))