\cos \left(x + \varepsilon\right) - \cos x
-2 \cdot \left(\left(\cos x \cdot \sin \left(\frac{1}{2} \cdot \varepsilon\right) + \sin x \cdot \cos \left(\frac{1}{2} \cdot \varepsilon\right)\right) \cdot \sin \left(\frac{1}{2} \cdot \varepsilon\right)\right)double f(double x, double eps) {
double r51754 = x;
double r51755 = eps;
double r51756 = r51754 + r51755;
double r51757 = cos(r51756);
double r51758 = cos(r51754);
double r51759 = r51757 - r51758;
return r51759;
}
double f(double x, double eps) {
double r51760 = -2.0;
double r51761 = x;
double r51762 = cos(r51761);
double r51763 = 0.5;
double r51764 = eps;
double r51765 = r51763 * r51764;
double r51766 = sin(r51765);
double r51767 = r51762 * r51766;
double r51768 = sin(r51761);
double r51769 = cos(r51765);
double r51770 = r51768 * r51769;
double r51771 = r51767 + r51770;
double r51772 = r51771 * r51766;
double r51773 = r51760 * r51772;
return r51773;
}



Bits error versus x



Bits error versus eps
Results
Initial program 39.5
rmApplied diff-cos34.0
Simplified15.1
Taylor expanded around inf 15.1
rmApplied distribute-lft-in15.1
Applied sin-sum0.4
Simplified0.4
Simplified0.4
rmApplied +-commutative0.4
Final simplification0.4
herbie shell --seed 2020045
(FPCore (x eps)
:name "2cos (problem 3.3.5)"
:precision binary64
(- (cos (+ x eps)) (cos x)))