\frac{x.re \cdot y.re + x.im \cdot y.im}{y.re \cdot y.re + y.im \cdot y.im}\begin{array}{l}
\mathbf{if}\;\frac{x.re \cdot y.re + x.im \cdot y.im}{y.re \cdot y.re + y.im \cdot y.im} \le 3.7042360551829521 \cdot 10^{296}:\\
\;\;\;\;\frac{\frac{x.re \cdot y.re + x.im \cdot y.im}{\sqrt{y.re \cdot y.re + y.im \cdot y.im}}}{\sqrt{y.re \cdot y.re + y.im \cdot y.im}}\\
\mathbf{else}:\\
\;\;\;\;\frac{-1 \cdot x.re}{\sqrt{y.re \cdot y.re + y.im \cdot y.im}}\\
\end{array}double f(double x_re, double x_im, double y_re, double y_im) {
double r65122 = x_re;
double r65123 = y_re;
double r65124 = r65122 * r65123;
double r65125 = x_im;
double r65126 = y_im;
double r65127 = r65125 * r65126;
double r65128 = r65124 + r65127;
double r65129 = r65123 * r65123;
double r65130 = r65126 * r65126;
double r65131 = r65129 + r65130;
double r65132 = r65128 / r65131;
return r65132;
}
double f(double x_re, double x_im, double y_re, double y_im) {
double r65133 = x_re;
double r65134 = y_re;
double r65135 = r65133 * r65134;
double r65136 = x_im;
double r65137 = y_im;
double r65138 = r65136 * r65137;
double r65139 = r65135 + r65138;
double r65140 = r65134 * r65134;
double r65141 = r65137 * r65137;
double r65142 = r65140 + r65141;
double r65143 = r65139 / r65142;
double r65144 = 3.704236055182952e+296;
bool r65145 = r65143 <= r65144;
double r65146 = sqrt(r65142);
double r65147 = r65139 / r65146;
double r65148 = r65147 / r65146;
double r65149 = -1.0;
double r65150 = r65149 * r65133;
double r65151 = r65150 / r65146;
double r65152 = r65145 ? r65148 : r65151;
return r65152;
}



Bits error versus x.re



Bits error versus x.im



Bits error versus y.re



Bits error versus y.im
Results
if (/ (+ (* x.re y.re) (* x.im y.im)) (+ (* y.re y.re) (* y.im y.im))) < 3.704236055182952e+296Initial program 13.8
rmApplied add-sqr-sqrt13.8
Applied associate-/r*13.7
if 3.704236055182952e+296 < (/ (+ (* x.re y.re) (* x.im y.im)) (+ (* y.re y.re) (* y.im y.im))) Initial program 63.4
rmApplied add-sqr-sqrt63.4
Applied associate-/r*63.4
Taylor expanded around -inf 59.9
Final simplification24.9
herbie shell --seed 2020035
(FPCore (x.re x.im y.re y.im)
:name "_divideComplex, real part"
:precision binary64
(/ (+ (* x.re y.re) (* x.im y.im)) (+ (* y.re y.re) (* y.im y.im))))