0.5 \cdot \sqrt{2 \cdot \left(\sqrt{re \cdot re + im \cdot im} - re\right)}\begin{array}{l}
\mathbf{if}\;im \le -2.047959521004422594885937246194657560109 \cdot 10^{153} \lor \neg \left(im \le -5.915675441341099358122284237091288586253 \cdot 10^{60} \lor \neg \left(im \le -645644762598500.5 \lor \neg \left(im \le -2.780954356842541639179543979500359083621 \cdot 10^{-41}\right)\right)\right):\\
\;\;\;\;0.5 \cdot \sqrt{2 \cdot \left(\left(\mathsf{hypot}\left(re, im\right) - re\right) + 0\right)}\\
\mathbf{else}:\\
\;\;\;\;0.5 \cdot \sqrt{2 \cdot \frac{{im}^{2} + 0}{re + \mathsf{hypot}\left(re, im\right)}}\\
\end{array}double f(double re, double im) {
double r18056 = 0.5;
double r18057 = 2.0;
double r18058 = re;
double r18059 = r18058 * r18058;
double r18060 = im;
double r18061 = r18060 * r18060;
double r18062 = r18059 + r18061;
double r18063 = sqrt(r18062);
double r18064 = r18063 - r18058;
double r18065 = r18057 * r18064;
double r18066 = sqrt(r18065);
double r18067 = r18056 * r18066;
return r18067;
}
double f(double re, double im) {
double r18068 = im;
double r18069 = -2.0479595210044226e+153;
bool r18070 = r18068 <= r18069;
double r18071 = -5.9156754413410994e+60;
bool r18072 = r18068 <= r18071;
double r18073 = -645644762598500.5;
bool r18074 = r18068 <= r18073;
double r18075 = -2.7809543568425416e-41;
bool r18076 = r18068 <= r18075;
double r18077 = !r18076;
bool r18078 = r18074 || r18077;
double r18079 = !r18078;
bool r18080 = r18072 || r18079;
double r18081 = !r18080;
bool r18082 = r18070 || r18081;
double r18083 = 0.5;
double r18084 = 2.0;
double r18085 = re;
double r18086 = hypot(r18085, r18068);
double r18087 = r18086 - r18085;
double r18088 = 0.0;
double r18089 = r18087 + r18088;
double r18090 = r18084 * r18089;
double r18091 = sqrt(r18090);
double r18092 = r18083 * r18091;
double r18093 = 2.0;
double r18094 = pow(r18068, r18093);
double r18095 = r18094 + r18088;
double r18096 = r18085 + r18086;
double r18097 = r18095 / r18096;
double r18098 = r18084 * r18097;
double r18099 = sqrt(r18098);
double r18100 = r18083 * r18099;
double r18101 = r18082 ? r18092 : r18100;
return r18101;
}



Bits error versus re



Bits error versus im
Results
if im < -2.0479595210044226e+153 or -5.9156754413410994e+60 < im < -645644762598500.5 or -2.7809543568425416e-41 < im Initial program 41.5
rmApplied add-cube-cbrt42.1
Applied add-sqr-sqrt42.1
Applied sqrt-prod42.2
Applied prod-diff42.3
Simplified15.8
Simplified13.3
if -2.0479595210044226e+153 < im < -5.9156754413410994e+60 or -645644762598500.5 < im < -2.7809543568425416e-41Initial program 18.9
rmApplied flip--22.7
Simplified18.6
Simplified11.4
Final simplification13.1
herbie shell --seed 2019347 +o rules:numerics
(FPCore (re im)
:name "math.sqrt on complex, imaginary part, im greater than 0 branch"
:precision binary64
(* 0.5 (sqrt (* 2 (- (sqrt (+ (* re re) (* im im))) re)))))