\cos \left(x + \varepsilon\right) - \cos x
\sin \left(\frac{1}{2} \cdot \varepsilon\right) \cdot \left(-2 \cdot \left(\cos \left(\frac{1}{2} \cdot \varepsilon\right) \cdot \sin x + \left(\sin \left(\frac{1}{2} \cdot \varepsilon\right) \cdot \left(\sqrt[3]{\cos x} \cdot \sqrt[3]{\cos x}\right)\right) \cdot \sqrt[3]{\cos x}\right)\right)double f(double x, double eps) {
double r1392662 = x;
double r1392663 = eps;
double r1392664 = r1392662 + r1392663;
double r1392665 = cos(r1392664);
double r1392666 = cos(r1392662);
double r1392667 = r1392665 - r1392666;
return r1392667;
}
double f(double x, double eps) {
double r1392668 = 0.5;
double r1392669 = eps;
double r1392670 = r1392668 * r1392669;
double r1392671 = sin(r1392670);
double r1392672 = -2.0;
double r1392673 = cos(r1392670);
double r1392674 = x;
double r1392675 = sin(r1392674);
double r1392676 = r1392673 * r1392675;
double r1392677 = cos(r1392674);
double r1392678 = cbrt(r1392677);
double r1392679 = r1392678 * r1392678;
double r1392680 = r1392671 * r1392679;
double r1392681 = r1392680 * r1392678;
double r1392682 = r1392676 + r1392681;
double r1392683 = r1392672 * r1392682;
double r1392684 = r1392671 * r1392683;
return r1392684;
}



Bits error versus x



Bits error versus eps
Results
Initial program 39.6
rmApplied diff-cos34.2
Simplified15.3
Taylor expanded around -inf 15.3
Simplified15.3
rmApplied fma-udef15.3
Applied sin-sum0.4
rmApplied add-cube-cbrt0.5
Applied associate-*r*0.5
Final simplification0.5
herbie shell --seed 2019141 +o rules:numerics
(FPCore (x eps)
:name "2cos (problem 3.3.5)"
(- (cos (+ x eps)) (cos x)))