\sqrt{\frac{e^{2 \cdot x} - 1}{e^{x} - 1}}\begin{array}{l}
\mathbf{if}\;x \le -1.40653091231849928 \cdot 10^{-5}:\\
\;\;\;\;\sqrt{\frac{\mathsf{fma}\left(\sqrt{e^{2 \cdot x}}, \sqrt{e^{2 \cdot x}}, -1\right)}{e^{x} - 1}}\\
\mathbf{else}:\\
\;\;\;\;\sqrt{\mathsf{fma}\left(0.5, {x}^{2}, \mathsf{fma}\left(1, x, 2\right)\right)}\\
\end{array}double code(double x) {
return ((double) sqrt(((double) (((double) (((double) exp(((double) (2.0 * x)))) - 1.0)) / ((double) (((double) exp(x)) - 1.0))))));
}
double code(double x) {
double VAR;
if ((x <= -1.4065309123184993e-05)) {
VAR = ((double) sqrt(((double) (((double) fma(((double) sqrt(((double) exp(((double) (2.0 * x)))))), ((double) sqrt(((double) exp(((double) (2.0 * x)))))), ((double) -(1.0)))) / ((double) (((double) exp(x)) - 1.0))))));
} else {
VAR = ((double) sqrt(((double) fma(0.5, ((double) pow(x, 2.0)), ((double) fma(1.0, x, 2.0))))));
}
return VAR;
}



Bits error versus x
Results
if x < -1.4065309123184993e-05Initial program 0.1
rmApplied add-sqr-sqrt0.1
Applied fma-neg0.0
if -1.4065309123184993e-05 < x Initial program 32.8
Taylor expanded around 0 6.4
Simplified6.4
Final simplification0.8
herbie shell --seed 2020120 +o rules:numerics
(FPCore (x)
:name "sqrtexp (problem 3.4.4)"
:precision binary64
(sqrt (/ (- (exp (* 2 x)) 1) (- (exp x) 1))))