\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 r2481801 = x;
double r2481802 = eps;
double r2481803 = r2481801 + r2481802;
double r2481804 = cos(r2481803);
double r2481805 = cos(r2481801);
double r2481806 = r2481804 - r2481805;
return r2481806;
}
double f(double x, double eps) {
double r2481807 = 0.5;
double r2481808 = eps;
double r2481809 = r2481807 * r2481808;
double r2481810 = sin(r2481809);
double r2481811 = x;
double r2481812 = cos(r2481811);
double r2481813 = r2481810 * r2481812;
double r2481814 = cos(r2481809);
double r2481815 = sin(r2481811);
double r2481816 = r2481814 * r2481815;
double r2481817 = r2481813 + r2481816;
double r2481818 = expm1(r2481817);
double r2481819 = log1p(r2481818);
double r2481820 = -2.0;
double r2481821 = r2481810 * r2481820;
double r2481822 = r2481819 * r2481821;
return r2481822;
}



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)))