\cos \left(x + \varepsilon\right) - \cos x
\left(\cos x \cdot \sin \left(\frac{1}{2} \cdot \varepsilon\right)\right) \cdot \left(\sin \left(\frac{1}{2} \cdot \varepsilon\right) \cdot -2\right) + \left(\sin x \cdot \cos \left(\frac{1}{2} \cdot \varepsilon\right)\right) \cdot \left(\sin \left(\frac{1}{2} \cdot \varepsilon\right) \cdot -2\right)double f(double x, double eps) {
double r4184467 = x;
double r4184468 = eps;
double r4184469 = r4184467 + r4184468;
double r4184470 = cos(r4184469);
double r4184471 = cos(r4184467);
double r4184472 = r4184470 - r4184471;
return r4184472;
}
double f(double x, double eps) {
double r4184473 = x;
double r4184474 = cos(r4184473);
double r4184475 = 0.5;
double r4184476 = eps;
double r4184477 = r4184475 * r4184476;
double r4184478 = sin(r4184477);
double r4184479 = r4184474 * r4184478;
double r4184480 = -2.0;
double r4184481 = r4184478 * r4184480;
double r4184482 = r4184479 * r4184481;
double r4184483 = sin(r4184473);
double r4184484 = cos(r4184477);
double r4184485 = r4184483 * r4184484;
double r4184486 = r4184485 * r4184481;
double r4184487 = r4184482 + r4184486;
return r4184487;
}



Bits error versus x



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