1 - \sqrt{0.5 \cdot \left(1 + \frac{1}{\mathsf{hypot}\left(1, x\right)}\right)}
\begin{array}{l}
t_0 := 0.5 + \frac{-0.5}{\mathsf{hypot}\left(1, x\right)}\\
t_1 := 1 + \sqrt{0.5 + \frac{0.5}{\mathsf{hypot}\left(1, x\right)}}\\
\mathbf{if}\;x \leq -0.027965099262194516:\\
\;\;\;\;\frac{t_0}{t_1}\\
\mathbf{elif}\;x \leq 0.028761853505194473:\\
\;\;\;\;\left(0.0673828125 \cdot {x}^{6} + 0.125 \cdot {x}^{2}\right) - \left(0.0859375 \cdot {x}^{4} + 0.056243896484375 \cdot {x}^{8}\right)\\
\mathbf{else}:\\
\;\;\;\;\frac{\mathsf{log1p}\left(\mathsf{expm1}\left(t_0\right)\right)}{t_1}\\
\end{array}
(FPCore (x) :precision binary64 (- 1.0 (sqrt (* 0.5 (+ 1.0 (/ 1.0 (hypot 1.0 x)))))))
(FPCore (x)
:precision binary64
(let* ((t_0 (+ 0.5 (/ -0.5 (hypot 1.0 x))))
(t_1 (+ 1.0 (sqrt (+ 0.5 (/ 0.5 (hypot 1.0 x)))))))
(if (<= x -0.027965099262194516)
(/ t_0 t_1)
(if (<= x 0.028761853505194473)
(-
(+ (* 0.0673828125 (pow x 6.0)) (* 0.125 (pow x 2.0)))
(+ (* 0.0859375 (pow x 4.0)) (* 0.056243896484375 (pow x 8.0))))
(/ (log1p (expm1 t_0)) t_1)))))double code(double x) {
return 1.0 - sqrt(0.5 * (1.0 + (1.0 / hypot(1.0, x))));
}
double code(double x) {
double t_0 = 0.5 + (-0.5 / hypot(1.0, x));
double t_1 = 1.0 + sqrt(0.5 + (0.5 / hypot(1.0, x)));
double tmp;
if (x <= -0.027965099262194516) {
tmp = t_0 / t_1;
} else if (x <= 0.028761853505194473) {
tmp = ((0.0673828125 * pow(x, 6.0)) + (0.125 * pow(x, 2.0))) - ((0.0859375 * pow(x, 4.0)) + (0.056243896484375 * pow(x, 8.0)));
} else {
tmp = log1p(expm1(t_0)) / t_1;
}
return tmp;
}



Bits error versus x
Results
if x < -0.027965099262194516Initial program 1.0
Simplified1.0
Applied flip--_binary641.0
Simplified0.1
Applied sub-neg_binary640.1
Simplified0.1
if -0.027965099262194516 < x < 0.028761853505194473Initial program 29.8
Simplified29.8
Taylor expanded in x around 0 0.0
if 0.028761853505194473 < x Initial program 1.0
Simplified1.0
Applied flip--_binary641.0
Simplified0.0
Applied log1p-expm1-u_binary640.1
Final simplification0.0
herbie shell --seed 2022068
(FPCore (x)
:name "Given's Rotation SVD example, simplified"
:precision binary64
(- 1.0 (sqrt (* 0.5 (+ 1.0 (/ 1.0 (hypot 1.0 x)))))))