\cos \left(x + \varepsilon\right) - \cos x
\sin \left(\frac{1}{2} \cdot \varepsilon\right) \cdot \left(-2 \cdot \left(\sqrt[3]{\left(\sin x \cdot \cos \left(\frac{1}{2} \cdot \varepsilon\right)\right) \cdot \left(\left(\sin x \cdot \cos \left(\frac{1}{2} \cdot \varepsilon\right)\right) \cdot \left(\sin x \cdot \cos \left(\frac{1}{2} \cdot \varepsilon\right)\right)\right)} + \cos x \cdot \sin \left(\frac{1}{2} \cdot \varepsilon\right)\right)\right)double f(double x, double eps) {
double r3059977 = x;
double r3059978 = eps;
double r3059979 = r3059977 + r3059978;
double r3059980 = cos(r3059979);
double r3059981 = cos(r3059977);
double r3059982 = r3059980 - r3059981;
return r3059982;
}
double f(double x, double eps) {
double r3059983 = 0.5;
double r3059984 = eps;
double r3059985 = r3059983 * r3059984;
double r3059986 = sin(r3059985);
double r3059987 = -2.0;
double r3059988 = x;
double r3059989 = sin(r3059988);
double r3059990 = cos(r3059985);
double r3059991 = r3059989 * r3059990;
double r3059992 = r3059991 * r3059991;
double r3059993 = r3059991 * r3059992;
double r3059994 = cbrt(r3059993);
double r3059995 = cos(r3059988);
double r3059996 = r3059995 * r3059986;
double r3059997 = r3059994 + r3059996;
double r3059998 = r3059987 * r3059997;
double r3059999 = r3059986 * r3059998;
return r3059999;
}



Bits error versus x



Bits error versus eps
Results
Initial program 39.8
rmApplied diff-cos34.1
Simplified15.1
Taylor expanded around inf 15.1
Simplified15.0
rmApplied sin-sum0.4
rmApplied add-cbrt-cube1.0
Final simplification1.0
herbie shell --seed 2019172
(FPCore (x eps)
:name "2cos (problem 3.3.5)"
(- (cos (+ x eps)) (cos x)))