\cos \left(x + \varepsilon\right) - \cos x
\mathsf{log1p}\left(\mathsf{expm1}\left(\sin \left(\frac{1}{2} \cdot \varepsilon\right) \cdot \cos x + \cos \left(\frac{1}{2} \cdot \varepsilon\right) \cdot \sin x\right)\right) \cdot \left(\sin \left(\frac{1}{2} \cdot \varepsilon\right) \cdot -2\right)double f(double x, double eps) {
double r1674351 = x;
double r1674352 = eps;
double r1674353 = r1674351 + r1674352;
double r1674354 = cos(r1674353);
double r1674355 = cos(r1674351);
double r1674356 = r1674354 - r1674355;
return r1674356;
}
double f(double x, double eps) {
double r1674357 = 0.5;
double r1674358 = eps;
double r1674359 = r1674357 * r1674358;
double r1674360 = sin(r1674359);
double r1674361 = x;
double r1674362 = cos(r1674361);
double r1674363 = r1674360 * r1674362;
double r1674364 = cos(r1674359);
double r1674365 = sin(r1674361);
double r1674366 = r1674364 * r1674365;
double r1674367 = r1674363 + r1674366;
double r1674368 = expm1(r1674367);
double r1674369 = log1p(r1674368);
double r1674370 = -2.0;
double r1674371 = r1674360 * r1674370;
double r1674372 = r1674369 * r1674371;
return r1674372;
}



Bits error versus x



Bits error versus eps
Results
Initial program 40.0
rmApplied diff-cos34.3
Simplified15.1
rmApplied associate-*r*15.1
rmApplied log1p-expm1-u15.1
Simplified15.1
rmApplied fma-udef15.1
Applied sin-sum0.4
Final simplification0.4
herbie shell --seed 2019200 +o rules:numerics
(FPCore (x eps)
:name "2cos (problem 3.3.5)"
(- (cos (+ x eps)) (cos x)))