\cos \left(x + \varepsilon\right) - \cos x
\begin{array}{l}
\mathbf{if}\;\varepsilon \le -8.39699580404506896243528445638072145972 \cdot 10^{-12} \lor \neg \left(\varepsilon \le 3.588703897944783975981375382800948881101 \cdot 10^{-9}\right):\\
\;\;\;\;\mathsf{fma}\left(\cos \varepsilon, \cos x, -\mathsf{log1p}\left(\mathsf{expm1}\left(\mathsf{fma}\left(\sin x, \sin \varepsilon, \cos x\right)\right)\right)\right) + \mathsf{fma}\left(-\cos x, 1, \cos x\right)\\
\mathbf{else}:\\
\;\;\;\;\varepsilon \cdot \left({\varepsilon}^{3} \cdot \frac{1}{24} - \mathsf{fma}\left(\frac{1}{2}, \varepsilon, x\right)\right) + \mathsf{fma}\left(-\cos x, 1, \cos x\right)\\
\end{array}double f(double x, double eps) {
double r68120 = x;
double r68121 = eps;
double r68122 = r68120 + r68121;
double r68123 = cos(r68122);
double r68124 = cos(r68120);
double r68125 = r68123 - r68124;
return r68125;
}
double f(double x, double eps) {
double r68126 = eps;
double r68127 = -8.396995804045069e-12;
bool r68128 = r68126 <= r68127;
double r68129 = 3.588703897944784e-09;
bool r68130 = r68126 <= r68129;
double r68131 = !r68130;
bool r68132 = r68128 || r68131;
double r68133 = cos(r68126);
double r68134 = x;
double r68135 = cos(r68134);
double r68136 = sin(r68134);
double r68137 = sin(r68126);
double r68138 = fma(r68136, r68137, r68135);
double r68139 = expm1(r68138);
double r68140 = log1p(r68139);
double r68141 = -r68140;
double r68142 = fma(r68133, r68135, r68141);
double r68143 = -r68135;
double r68144 = 1.0;
double r68145 = fma(r68143, r68144, r68135);
double r68146 = r68142 + r68145;
double r68147 = 3.0;
double r68148 = pow(r68126, r68147);
double r68149 = 0.041666666666666664;
double r68150 = r68148 * r68149;
double r68151 = 0.5;
double r68152 = fma(r68151, r68126, r68134);
double r68153 = r68150 - r68152;
double r68154 = r68126 * r68153;
double r68155 = r68154 + r68145;
double r68156 = r68132 ? r68146 : r68155;
return r68156;
}



Bits error versus x



Bits error versus eps
if eps < -8.396995804045069e-12 or 3.588703897944784e-09 < eps Initial program 30.6
rmApplied cos-sum1.4
rmApplied add-cube-cbrt1.8
Applied add-sqr-sqrt32.6
Applied prod-diff32.6
Simplified1.4
Simplified1.3
rmApplied log1p-expm1-u1.4
if -8.396995804045069e-12 < eps < 3.588703897944784e-09Initial program 49.8
rmApplied cos-sum49.6
rmApplied add-cube-cbrt50.0
Applied add-sqr-sqrt50.8
Applied prod-diff50.9
Simplified50.1
Simplified49.6
Taylor expanded around 0 30.8
Simplified30.8
Final simplification15.6
herbie shell --seed 2020001 +o rules:numerics
(FPCore (x eps)
:name "2cos (problem 3.3.5)"
:precision binary64
(- (cos (+ x eps)) (cos x)))