\cos \left(x + \varepsilon\right) - \cos x
\sin \left(\frac{1}{2} \cdot \varepsilon\right) \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 -2\right)double f(double x, double eps) {
double r1613645 = x;
double r1613646 = eps;
double r1613647 = r1613645 + r1613646;
double r1613648 = cos(r1613647);
double r1613649 = cos(r1613645);
double r1613650 = r1613648 - r1613649;
return r1613650;
}
double f(double x, double eps) {
double r1613651 = 0.5;
double r1613652 = eps;
double r1613653 = r1613651 * r1613652;
double r1613654 = sin(r1613653);
double r1613655 = x;
double r1613656 = cos(r1613655);
double r1613657 = r1613656 * r1613654;
double r1613658 = sin(r1613655);
double r1613659 = cos(r1613653);
double r1613660 = r1613658 * r1613659;
double r1613661 = r1613657 + r1613660;
double r1613662 = -2.0;
double r1613663 = r1613661 * r1613662;
double r1613664 = r1613654 * r1613663;
return r1613664;
}



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 fma-udef15.4
Applied sin-sum0.4
Final simplification0.4
herbie shell --seed 2019129 +o rules:numerics
(FPCore (x eps)
:name "2cos (problem 3.3.5)"
(- (cos (+ x eps)) (cos x)))