\cos \left(x + \varepsilon\right) - \cos x
\left(\sin x \cdot \left(\sin \left(\frac{1}{2} \cdot \varepsilon\right) \cdot \cos \left(\frac{1}{2} \cdot \varepsilon\right)\right)\right) \cdot -2 + \left(-2 \cdot \sin \left(\frac{1}{2} \cdot \varepsilon\right)\right) \cdot \left(\cos x \cdot \sin \left(\frac{1}{2} \cdot \varepsilon\right)\right)double f(double x, double eps) {
double r679695 = x;
double r679696 = eps;
double r679697 = r679695 + r679696;
double r679698 = cos(r679697);
double r679699 = cos(r679695);
double r679700 = r679698 - r679699;
return r679700;
}
double f(double x, double eps) {
double r679701 = x;
double r679702 = sin(r679701);
double r679703 = 0.5;
double r679704 = eps;
double r679705 = r679703 * r679704;
double r679706 = sin(r679705);
double r679707 = cos(r679705);
double r679708 = r679706 * r679707;
double r679709 = r679702 * r679708;
double r679710 = -2.0;
double r679711 = r679709 * r679710;
double r679712 = r679710 * r679706;
double r679713 = cos(r679701);
double r679714 = r679713 * r679706;
double r679715 = r679712 * r679714;
double r679716 = r679711 + r679715;
return r679716;
}



Bits error versus x



Bits error versus eps
Results
Initial program 39.8
rmApplied diff-cos34.4
Simplified15.4
Taylor expanded around -inf 15.4
Simplified15.4
rmApplied sin-sum0.4
Applied distribute-lft-in0.4
Taylor expanded around -inf 0.4
Final simplification0.4
herbie shell --seed 2019129
(FPCore (x eps)
:name "2cos (problem 3.3.5)"
(- (cos (+ x eps)) (cos x)))