\left(0.5\right) \cdot \left(\sqrt{\left(\left(2.0\right) \cdot \left(\frac{\left(\sqrt{\left(\frac{\left(re \cdot re\right)}{\left(im \cdot im\right)}\right)}\right)}{re}\right)\right)}\right)0.5 \cdot \sqrt{2.0 \cdot \left(\sqrt{re \cdot re + im \cdot im} + re\right)}double f(double re, double im) {
double r16094 = 0.5;
double r16095 = /* ERROR: no posit support in C */;
double r16096 = 2.0;
double r16097 = /* ERROR: no posit support in C */;
double r16098 = re;
double r16099 = r16098 * r16098;
double r16100 = im;
double r16101 = r16100 * r16100;
double r16102 = r16099 + r16101;
double r16103 = sqrt(r16102);
double r16104 = r16103 + r16098;
double r16105 = r16097 * r16104;
double r16106 = sqrt(r16105);
double r16107 = r16095 * r16106;
return r16107;
}
double f(double re, double im) {
double r16108 = 0.5;
double r16109 = 2.0;
double r16110 = re;
double r16111 = r16110 * r16110;
double r16112 = im;
double r16113 = r16112 * r16112;
double r16114 = r16111 + r16113;
double r16115 = sqrt(r16114);
double r16116 = r16115 + r16110;
double r16117 = r16109 * r16116;
double r16118 = sqrt(r16117);
double r16119 = r16108 * r16118;
return r16119;
}



Bits error versus re



Bits error versus im
Initial program 2.1
Final simplification2.1
herbie shell --seed 2019125
(FPCore (re im)
:name "math.sqrt on complex, real part"
(*.p16 (real->posit16 0.5) (sqrt.p16 (*.p16 (real->posit16 2.0) (+.p16 (sqrt.p16 (+.p16 (*.p16 re re) (*.p16 im im))) re)))))