\cos \left(x + \varepsilon\right) - \cos x
\left(-2 \cdot \left(\sqrt[3]{\left(\cos x \cdot \sin \left(\frac{\varepsilon}{2}\right)\right) \cdot \left(\left(\cos x \cdot \sin \left(\frac{\varepsilon}{2}\right)\right) \cdot \left(\cos x \cdot \sin \left(\frac{\varepsilon}{2}\right)\right)\right)} + \cos \left(\frac{\varepsilon}{2}\right) \cdot \sin x\right)\right) \cdot \sin \left(\frac{\varepsilon}{2}\right)double f(double x, double eps) {
double r3431421 = x;
double r3431422 = eps;
double r3431423 = r3431421 + r3431422;
double r3431424 = cos(r3431423);
double r3431425 = cos(r3431421);
double r3431426 = r3431424 - r3431425;
return r3431426;
}
double f(double x, double eps) {
double r3431427 = -2.0;
double r3431428 = x;
double r3431429 = cos(r3431428);
double r3431430 = eps;
double r3431431 = 2.0;
double r3431432 = r3431430 / r3431431;
double r3431433 = sin(r3431432);
double r3431434 = r3431429 * r3431433;
double r3431435 = r3431434 * r3431434;
double r3431436 = r3431434 * r3431435;
double r3431437 = cbrt(r3431436);
double r3431438 = cos(r3431432);
double r3431439 = sin(r3431428);
double r3431440 = r3431438 * r3431439;
double r3431441 = r3431437 + r3431440;
double r3431442 = r3431427 * r3431441;
double r3431443 = r3431442 * r3431433;
return r3431443;
}



Bits error versus x



Bits error versus eps
Results
Initial program 39.1
rmApplied diff-cos33.8
Simplified15.0
Taylor expanded around inf 15.0
Simplified14.9
rmApplied sin-sum0.4
rmApplied add-cbrt-cube1.7
Applied add-cbrt-cube1.8
Applied cbrt-unprod1.8
Simplified1.8
Final simplification1.8
herbie shell --seed 2019168
(FPCore (x eps)
:name "2cos (problem 3.3.5)"
(- (cos (+ x eps)) (cos x)))