\cos \left(x + \varepsilon\right) - \cos x
\mathsf{log1p}\left(\mathsf{expm1}\left(\mathsf{fma}\left(\cos \left(\frac{1}{2} \cdot \varepsilon\right), \sin x, \sin \left(\frac{1}{2} \cdot \varepsilon\right) \cdot \cos x\right)\right)\right) \cdot \left(-2 \cdot \sin \left(\frac{1}{2} \cdot \varepsilon\right)\right)double f(double x, double eps) {
double r33938 = x;
double r33939 = eps;
double r33940 = r33938 + r33939;
double r33941 = cos(r33940);
double r33942 = cos(r33938);
double r33943 = r33941 - r33942;
return r33943;
}
double f(double x, double eps) {
double r33944 = 0.5;
double r33945 = eps;
double r33946 = r33944 * r33945;
double r33947 = cos(r33946);
double r33948 = x;
double r33949 = sin(r33948);
double r33950 = sin(r33946);
double r33951 = cos(r33948);
double r33952 = r33950 * r33951;
double r33953 = fma(r33947, r33949, r33952);
double r33954 = expm1(r33953);
double r33955 = log1p(r33954);
double r33956 = -2.0;
double r33957 = r33956 * r33950;
double r33958 = r33955 * r33957;
return r33958;
}



Bits error versus x



Bits error versus eps
Initial program 39.3
rmApplied diff-cos33.8
Simplified15.0
Taylor expanded around inf 15.0
Simplified14.9
rmApplied fma-udef14.9
Applied sin-sum0.3
rmApplied log1p-expm1-u0.4
Simplified0.4
Final simplification0.4
herbie shell --seed 2019303 +o rules:numerics
(FPCore (x eps)
:name "2cos (problem 3.3.5)"
:precision binary64
(- (cos (+ x eps)) (cos x)))