\cos \left(x + \varepsilon\right) - \cos x
-2 \cdot \left(\frac{\left(\sin \left(\frac{1}{2} \cdot \left(2 \cdot x\right)\right) \cdot \cos \left(\frac{1}{2} \cdot \varepsilon\right)\right) \cdot \left(\sin \left(\frac{1}{2} \cdot \left(2 \cdot x\right)\right) \cdot \cos \left(\frac{1}{2} \cdot \varepsilon\right)\right) - \left(\cos \left(\left(2 \cdot x\right) \cdot \frac{1}{2}\right) \cdot \sin \left(\varepsilon \cdot \frac{1}{2}\right)\right) \cdot \left(\cos \left(\left(2 \cdot x\right) \cdot \frac{1}{2}\right) \cdot \sin \left(\varepsilon \cdot \frac{1}{2}\right)\right)}{\sin \left(\frac{1}{2} \cdot \left(2 \cdot x\right)\right) \cdot \cos \left(\frac{1}{2} \cdot \varepsilon\right) - \cos \left(\left(2 \cdot x\right) \cdot \frac{1}{2}\right) \cdot \sin \left(\varepsilon \cdot \frac{1}{2}\right)} \cdot \sin \left(\frac{1}{2} \cdot \varepsilon\right)\right)double f(double x, double eps) {
double r34390 = x;
double r34391 = eps;
double r34392 = r34390 + r34391;
double r34393 = cos(r34392);
double r34394 = cos(r34390);
double r34395 = r34393 - r34394;
return r34395;
}
double f(double x, double eps) {
double r34396 = -2.0;
double r34397 = 0.5;
double r34398 = 2.0;
double r34399 = x;
double r34400 = r34398 * r34399;
double r34401 = r34397 * r34400;
double r34402 = sin(r34401);
double r34403 = eps;
double r34404 = r34397 * r34403;
double r34405 = cos(r34404);
double r34406 = r34402 * r34405;
double r34407 = r34406 * r34406;
double r34408 = r34400 * r34397;
double r34409 = cos(r34408);
double r34410 = r34403 * r34397;
double r34411 = sin(r34410);
double r34412 = r34409 * r34411;
double r34413 = r34412 * r34412;
double r34414 = r34407 - r34413;
double r34415 = r34406 - r34412;
double r34416 = r34414 / r34415;
double r34417 = sin(r34404);
double r34418 = r34416 * r34417;
double r34419 = r34396 * r34418;
return r34419;
}



Bits error versus x



Bits error versus eps
Results
Initial program 39.1
rmApplied diff-cos33.5
Simplified14.9
Taylor expanded around inf 14.9
rmApplied distribute-lft-in14.9
Applied sin-sum0.4
Simplified0.4
rmApplied flip-+0.5
Final simplification0.5
herbie shell --seed 2019323
(FPCore (x eps)
:name "2cos (problem 3.3.5)"
:precision binary64
(- (cos (+ x eps)) (cos x)))