\cos \left(x + \varepsilon\right) - \cos x
\begin{array}{l}
\mathbf{if}\;\varepsilon \le -8.8476275124370457 \cdot 10^{-18} \lor \neg \left(\varepsilon \le 4.2827293773201444 \cdot 10^{-9}\right):\\
\;\;\;\;\cos x \cdot \cos \varepsilon - \mathsf{fma}\left(\sin x, \sin \varepsilon, \cos x\right)\\
\mathbf{else}:\\
\;\;\;\;\varepsilon \cdot \left({\varepsilon}^{3} \cdot \frac{1}{24} - \mathsf{fma}\left(\frac{1}{2}, \varepsilon, x\right)\right)\\
\end{array}double code(double x, double eps) {
return (cos((x + eps)) - cos(x));
}
double code(double x, double eps) {
double VAR;
if (((eps <= -8.847627512437046e-18) || !(eps <= 4.282729377320144e-09))) {
VAR = ((cos(x) * cos(eps)) - fma(sin(x), sin(eps), cos(x)));
} else {
VAR = (eps * ((pow(eps, 3.0) * 0.041666666666666664) - fma(0.5, eps, x)));
}
return VAR;
}



Bits error versus x



Bits error versus eps
Results
if eps < -8.847627512437046e-18 or 4.282729377320144e-09 < eps Initial program 31.0
rmApplied cos-sum2.0
Applied associate--l-2.0
Simplified2.0
if -8.847627512437046e-18 < eps < 4.282729377320144e-09Initial program 49.5
rmApplied cos-sum49.3
Taylor expanded around inf 49.3
Simplified49.3
Taylor expanded around 0 31.8
Simplified31.8
Final simplification16.2
herbie shell --seed 2020103 +o rules:numerics
(FPCore (x eps)
:name "2cos (problem 3.3.5)"
:precision binary64
(- (cos (+ x eps)) (cos x)))