\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) + \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))) (* (cos x) (sin (* eps 0.5)))))))
double code(double x, double eps) {
return cos(x + eps) - cos(x);
}
double code(double x, double eps) {
return -2.0 * (sin(eps / 2.0) * ((sin(x) * cos(eps * 0.5)) + (cos(x) * sin(eps * 0.5))));
}



Bits error versus x



Bits error versus eps
Results
Initial program 39.4
rmApplied diff-cos_binary6433.8
Simplified15.1
Taylor expanded around inf 15.1
Simplified15.1
rmApplied sin-sum_binary640.4
Final simplification0.4
herbie shell --seed 2020273
(FPCore (x eps)
:name "2cos (problem 3.3.5)"
:precision binary64
(- (cos (+ x eps)) (cos x)))