1 - \sqrt{0.5 \cdot \left(1 + \frac{1}{\mathsf{hypot}\left(1, x\right)}\right)}
\begin{array}{l}
t_0 := \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{\mathsf{fma}\left(1, 0.5, t_0\right)}{t_1}\\
\mathbf{elif}\;x \leq 0.028761853505194473:\\
\;\;\;\;\mathsf{fma}\left(x \cdot x, 0.125, {x}^{6} \cdot 0.0673828125\right) - \mathsf{fma}\left({x}^{4}, 0.0859375, {x}^{8} \cdot 0.056243896484375\right)\\
\mathbf{else}:\\
\;\;\;\;\frac{\mathsf{log1p}\left(\mathsf{expm1}\left(0.5 + 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 (hypot 1.0 x)))
(t_1 (+ 1.0 (sqrt (+ 0.5 (/ 0.5 (hypot 1.0 x)))))))
(if (<= x -0.027965099262194516)
(/ (fma 1.0 0.5 t_0) t_1)
(if (<= x 0.028761853505194473)
(-
(fma (* x x) 0.125 (* (pow x 6.0) 0.0673828125))
(fma (pow x 4.0) 0.0859375 (* (pow x 8.0) 0.056243896484375)))
(/ (log1p (expm1 (+ 0.5 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 / 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 = fma(1.0, 0.5, t_0) / t_1;
} else if (x <= 0.028761853505194473) {
tmp = fma((x * x), 0.125, (pow(x, 6.0) * 0.0673828125)) - fma(pow(x, 4.0), 0.0859375, (pow(x, 8.0) * 0.056243896484375));
} else {
tmp = log1p(expm1(0.5 + t_0)) / t_1;
}
return tmp;
}



Bits error versus x
if x < -0.027965099262194516Initial program 1.0
Simplified1.0
Applied flip--_binary641.0
Simplified0.1
Applied *-un-lft-identity_binary640.1
Applied fma-neg_binary640.1
Simplified0.1
if -0.027965099262194516 < x < 0.028761853505194473Initial program 29.8
Simplified29.8
Applied flip--_binary6429.8
Simplified29.8
Taylor expanded in x around 0 0.0
Simplified0.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)))))))