\frac{1 - \cos x}{x \cdot x}\begin{array}{l}
\mathbf{if}\;x \le -0.0332328864535681931:\\
\;\;\;\;\frac{\left(1 - \cos x\right) \cdot \frac{1}{x}}{x}\\
\mathbf{elif}\;x \le 0.03010910821075468:\\
\;\;\;\;\mathsf{fma}\left({x}^{4}, \frac{1}{720}, \frac{1}{2} - \frac{1}{24} \cdot {x}^{2}\right)\\
\mathbf{else}:\\
\;\;\;\;\frac{\frac{1}{x}}{\frac{x}{1 - \cos x}}\\
\end{array}double code(double x) {
return ((1.0 - cos(x)) / (x * x));
}
double code(double x) {
double VAR;
if ((x <= -0.03323288645356819)) {
VAR = (((1.0 - cos(x)) * (1.0 / x)) / x);
} else {
double VAR_1;
if ((x <= 0.03010910821075468)) {
VAR_1 = fma(pow(x, 4.0), 0.001388888888888889, (0.5 - (0.041666666666666664 * pow(x, 2.0))));
} else {
VAR_1 = ((1.0 / x) / (x / (1.0 - cos(x))));
}
VAR = VAR_1;
}
return VAR;
}



Bits error versus x
Results
if x < -0.03323288645356819Initial program 1.1
rmApplied associate-/r*0.4
rmApplied div-inv0.5
if -0.03323288645356819 < x < 0.03010910821075468Initial program 62.2
Taylor expanded around 0 0.0
Simplified0.0
if 0.03010910821075468 < x Initial program 1.1
rmApplied associate-/r*0.5
rmApplied div-inv0.5
rmApplied *-commutative0.5
Applied associate-/l*0.5
Final simplification0.3
herbie shell --seed 2020078 +o rules:numerics
(FPCore (x)
:name "cos2 (problem 3.4.1)"
:precision binary64
(/ (- 1 (cos x)) (* x x)))