0.5 \cdot \sqrt{2.0 \cdot \left(\sqrt{re \cdot re + im \cdot im} + re\right)}\begin{array}{l}
\mathbf{if}\;re \le -1.1214463413730795 \cdot 10^{+123}:\\
\;\;\;\;\left(\sqrt{2.0} \cdot \frac{\left|im\right|}{\sqrt{re \cdot -2}}\right) \cdot 0.5\\
\mathbf{elif}\;re \le -3.263660527236801 \cdot 10^{-218}:\\
\;\;\;\;0.5 \cdot \left(\left(\sqrt{\sqrt{2.0}} \cdot \frac{\left|im\right|}{\sqrt{\sqrt{re \cdot re + im \cdot im} - re}}\right) \cdot \sqrt{\sqrt{2.0}}\right)\\
\mathbf{elif}\;re \le 2.4935750622148784 \cdot 10^{-246}:\\
\;\;\;\;0.5 \cdot \sqrt{\left(re + im\right) \cdot 2.0}\\
\mathbf{elif}\;re \le 9.701163352497263 \cdot 10^{+98}:\\
\;\;\;\;0.5 \cdot \sqrt{\left(\sqrt{re \cdot re + im \cdot im} + re\right) \cdot 2.0}\\
\mathbf{else}:\\
\;\;\;\;\sqrt{2.0 \cdot \left(re + re\right)} \cdot 0.5\\
\end{array}double f(double re, double im) {
double r3013309 = 0.5;
double r3013310 = 2.0;
double r3013311 = re;
double r3013312 = r3013311 * r3013311;
double r3013313 = im;
double r3013314 = r3013313 * r3013313;
double r3013315 = r3013312 + r3013314;
double r3013316 = sqrt(r3013315);
double r3013317 = r3013316 + r3013311;
double r3013318 = r3013310 * r3013317;
double r3013319 = sqrt(r3013318);
double r3013320 = r3013309 * r3013319;
return r3013320;
}
double f(double re, double im) {
double r3013321 = re;
double r3013322 = -1.1214463413730795e+123;
bool r3013323 = r3013321 <= r3013322;
double r3013324 = 2.0;
double r3013325 = sqrt(r3013324);
double r3013326 = im;
double r3013327 = fabs(r3013326);
double r3013328 = -2.0;
double r3013329 = r3013321 * r3013328;
double r3013330 = sqrt(r3013329);
double r3013331 = r3013327 / r3013330;
double r3013332 = r3013325 * r3013331;
double r3013333 = 0.5;
double r3013334 = r3013332 * r3013333;
double r3013335 = -3.263660527236801e-218;
bool r3013336 = r3013321 <= r3013335;
double r3013337 = sqrt(r3013325);
double r3013338 = r3013321 * r3013321;
double r3013339 = r3013326 * r3013326;
double r3013340 = r3013338 + r3013339;
double r3013341 = sqrt(r3013340);
double r3013342 = r3013341 - r3013321;
double r3013343 = sqrt(r3013342);
double r3013344 = r3013327 / r3013343;
double r3013345 = r3013337 * r3013344;
double r3013346 = r3013345 * r3013337;
double r3013347 = r3013333 * r3013346;
double r3013348 = 2.4935750622148784e-246;
bool r3013349 = r3013321 <= r3013348;
double r3013350 = r3013321 + r3013326;
double r3013351 = r3013350 * r3013324;
double r3013352 = sqrt(r3013351);
double r3013353 = r3013333 * r3013352;
double r3013354 = 9.701163352497263e+98;
bool r3013355 = r3013321 <= r3013354;
double r3013356 = r3013341 + r3013321;
double r3013357 = r3013356 * r3013324;
double r3013358 = sqrt(r3013357);
double r3013359 = r3013333 * r3013358;
double r3013360 = r3013321 + r3013321;
double r3013361 = r3013324 * r3013360;
double r3013362 = sqrt(r3013361);
double r3013363 = r3013362 * r3013333;
double r3013364 = r3013355 ? r3013359 : r3013363;
double r3013365 = r3013349 ? r3013353 : r3013364;
double r3013366 = r3013336 ? r3013347 : r3013365;
double r3013367 = r3013323 ? r3013334 : r3013366;
return r3013367;
}




Bits error versus re




Bits error versus im
Results
| Original | 37.8 |
|---|---|
| Target | 32.9 |
| Herbie | 17.5 |
if re < -1.1214463413730795e+123Initial program 60.9
rmApplied flip-+60.9
Applied associate-*r/60.9
Applied sqrt-div60.9
Simplified45.3
rmApplied sqrt-prod45.3
Simplified44.3
rmApplied *-un-lft-identity44.3
Applied sqrt-prod44.3
Applied times-frac44.3
Simplified44.3
Taylor expanded around -inf 9.3
if -1.1214463413730795e+123 < re < -3.263660527236801e-218Initial program 40.6
rmApplied flip-+40.5
Applied associate-*r/40.5
Applied sqrt-div40.6
Simplified29.6
rmApplied sqrt-prod29.7
Simplified18.1
rmApplied *-un-lft-identity18.1
Applied sqrt-prod18.1
Applied times-frac18.1
Simplified18.1
rmApplied add-sqr-sqrt18.1
Applied sqrt-prod18.2
Applied associate-*l*18.2
if -3.263660527236801e-218 < re < 2.4935750622148784e-246Initial program 29.9
Taylor expanded around 0 32.8
if 2.4935750622148784e-246 < re < 9.701163352497263e+98Initial program 18.8
if 9.701163352497263e+98 < re Initial program 49.8
Taylor expanded around inf 10.4
Final simplification17.5
herbie shell --seed 2019156
(FPCore (re im)
:name "math.sqrt on complex, real part"
:herbie-target
(if (< re 0) (* 0.5 (* (sqrt 2) (sqrt (/ (* im im) (- (sqrt (+ (* re re) (* im im))) re))))) (* 0.5 (sqrt (* 2.0 (+ (sqrt (+ (* re re) (* im im))) re)))))
(* 0.5 (sqrt (* 2.0 (+ (sqrt (+ (* re re) (* im im))) re)))))