\[\frac{x.im \cdot y.re - x.re \cdot y.im}{y.re \cdot y.re + y.im \cdot y.im}
\]
↓
\[\begin{array}{l}
t_0 := x.im \cdot y.re - x.re \cdot y.im\\
t_1 := \frac{\frac{x.im}{y.im} \cdot y.re - x.re}{y.im}\\
t_2 := y.re \cdot y.re + y.im \cdot y.im\\
\mathbf{if}\;y.im \leq -1.4 \cdot 10^{+121}:\\
\;\;\;\;t_1\\
\mathbf{elif}\;y.im \leq -4.7 \cdot 10^{-152}:\\
\;\;\;\;\frac{\begin{array}{l}
\mathbf{if}\;t_0 \ne 0:\\
\;\;\;\;\frac{1}{\frac{1}{t_0}}\\
\mathbf{else}:\\
\;\;\;\;t_0\\
\end{array}}{t_2}\\
\mathbf{elif}\;y.im \leq 1.4 \cdot 10^{-164}:\\
\;\;\;\;\frac{x.im - \frac{y.im \cdot x.re}{y.re}}{y.re}\\
\mathbf{elif}\;y.im \leq 7 \cdot 10^{+92}:\\
\;\;\;\;\frac{t_0}{t_2}\\
\mathbf{else}:\\
\;\;\;\;t_1\\
\end{array}
\]
(FPCore (x.re x.im y.re y.im)
:precision binary64
(/ (- (* x.im y.re) (* x.re y.im)) (+ (* y.re y.re) (* y.im y.im))))
↓
(FPCore (x.re x.im y.re y.im)
:precision binary64
(let* ((t_0 (- (* x.im y.re) (* x.re y.im)))
(t_1 (/ (- (* (/ x.im y.im) y.re) x.re) y.im))
(t_2 (+ (* y.re y.re) (* y.im y.im))))
(if (<= y.im -1.4e+121)
t_1
(if (<= y.im -4.7e-152)
(/ (if (!= t_0 0.0) (/ 1.0 (/ 1.0 t_0)) t_0) t_2)
(if (<= y.im 1.4e-164)
(/ (- x.im (/ (* y.im x.re) y.re)) y.re)
(if (<= y.im 7e+92) (/ t_0 t_2) t_1))))))double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
return ((x_46_im * y_46_re) - (x_46_re * y_46_im)) / ((y_46_re * y_46_re) + (y_46_im * y_46_im));
}
↓
double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
double t_0 = (x_46_im * y_46_re) - (x_46_re * y_46_im);
double t_1 = (((x_46_im / y_46_im) * y_46_re) - x_46_re) / y_46_im;
double t_2 = (y_46_re * y_46_re) + (y_46_im * y_46_im);
double tmp;
if (y_46_im <= -1.4e+121) {
tmp = t_1;
} else if (y_46_im <= -4.7e-152) {
double tmp_1;
if (t_0 != 0.0) {
tmp_1 = 1.0 / (1.0 / t_0);
} else {
tmp_1 = t_0;
}
tmp = tmp_1 / t_2;
} else if (y_46_im <= 1.4e-164) {
tmp = (x_46_im - ((y_46_im * x_46_re) / y_46_re)) / y_46_re;
} else if (y_46_im <= 7e+92) {
tmp = t_0 / t_2;
} else {
tmp = t_1;
}
return tmp;
}
real(8) function code(x_46re, x_46im, y_46re, y_46im)
real(8), intent (in) :: x_46re
real(8), intent (in) :: x_46im
real(8), intent (in) :: y_46re
real(8), intent (in) :: y_46im
code = ((x_46im * y_46re) - (x_46re * y_46im)) / ((y_46re * y_46re) + (y_46im * y_46im))
end function
↓
real(8) function code(x_46re, x_46im, y_46re, y_46im)
real(8), intent (in) :: x_46re
real(8), intent (in) :: x_46im
real(8), intent (in) :: y_46re
real(8), intent (in) :: y_46im
real(8) :: t_0
real(8) :: t_1
real(8) :: t_2
real(8) :: tmp
real(8) :: tmp_1
t_0 = (x_46im * y_46re) - (x_46re * y_46im)
t_1 = (((x_46im / y_46im) * y_46re) - x_46re) / y_46im
t_2 = (y_46re * y_46re) + (y_46im * y_46im)
if (y_46im <= (-1.4d+121)) then
tmp = t_1
else if (y_46im <= (-4.7d-152)) then
if (t_0 /= 0.0d0) then
tmp_1 = 1.0d0 / (1.0d0 / t_0)
else
tmp_1 = t_0
end if
tmp = tmp_1 / t_2
else if (y_46im <= 1.4d-164) then
tmp = (x_46im - ((y_46im * x_46re) / y_46re)) / y_46re
else if (y_46im <= 7d+92) then
tmp = t_0 / t_2
else
tmp = t_1
end if
code = tmp
end function
public static double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
return ((x_46_im * y_46_re) - (x_46_re * y_46_im)) / ((y_46_re * y_46_re) + (y_46_im * y_46_im));
}
↓
public static double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
double t_0 = (x_46_im * y_46_re) - (x_46_re * y_46_im);
double t_1 = (((x_46_im / y_46_im) * y_46_re) - x_46_re) / y_46_im;
double t_2 = (y_46_re * y_46_re) + (y_46_im * y_46_im);
double tmp;
if (y_46_im <= -1.4e+121) {
tmp = t_1;
} else if (y_46_im <= -4.7e-152) {
double tmp_1;
if (t_0 != 0.0) {
tmp_1 = 1.0 / (1.0 / t_0);
} else {
tmp_1 = t_0;
}
tmp = tmp_1 / t_2;
} else if (y_46_im <= 1.4e-164) {
tmp = (x_46_im - ((y_46_im * x_46_re) / y_46_re)) / y_46_re;
} else if (y_46_im <= 7e+92) {
tmp = t_0 / t_2;
} else {
tmp = t_1;
}
return tmp;
}
def code(x_46_re, x_46_im, y_46_re, y_46_im):
return ((x_46_im * y_46_re) - (x_46_re * y_46_im)) / ((y_46_re * y_46_re) + (y_46_im * y_46_im))
↓
def code(x_46_re, x_46_im, y_46_re, y_46_im):
t_0 = (x_46_im * y_46_re) - (x_46_re * y_46_im)
t_1 = (((x_46_im / y_46_im) * y_46_re) - x_46_re) / y_46_im
t_2 = (y_46_re * y_46_re) + (y_46_im * y_46_im)
tmp = 0
if y_46_im <= -1.4e+121:
tmp = t_1
elif y_46_im <= -4.7e-152:
tmp_1 = 0
if t_0 != 0.0:
tmp_1 = 1.0 / (1.0 / t_0)
else:
tmp_1 = t_0
tmp = tmp_1 / t_2
elif y_46_im <= 1.4e-164:
tmp = (x_46_im - ((y_46_im * x_46_re) / y_46_re)) / y_46_re
elif y_46_im <= 7e+92:
tmp = t_0 / t_2
else:
tmp = t_1
return tmp
function code(x_46_re, x_46_im, y_46_re, y_46_im)
return Float64(Float64(Float64(x_46_im * y_46_re) - Float64(x_46_re * y_46_im)) / Float64(Float64(y_46_re * y_46_re) + Float64(y_46_im * y_46_im)))
end
↓
function code(x_46_re, x_46_im, y_46_re, y_46_im)
t_0 = Float64(Float64(x_46_im * y_46_re) - Float64(x_46_re * y_46_im))
t_1 = Float64(Float64(Float64(Float64(x_46_im / y_46_im) * y_46_re) - x_46_re) / y_46_im)
t_2 = Float64(Float64(y_46_re * y_46_re) + Float64(y_46_im * y_46_im))
tmp = 0.0
if (y_46_im <= -1.4e+121)
tmp = t_1;
elseif (y_46_im <= -4.7e-152)
tmp_1 = 0.0
if (t_0 != 0.0)
tmp_1 = Float64(1.0 / Float64(1.0 / t_0));
else
tmp_1 = t_0;
end
tmp = Float64(tmp_1 / t_2);
elseif (y_46_im <= 1.4e-164)
tmp = Float64(Float64(x_46_im - Float64(Float64(y_46_im * x_46_re) / y_46_re)) / y_46_re);
elseif (y_46_im <= 7e+92)
tmp = Float64(t_0 / t_2);
else
tmp = t_1;
end
return tmp
end
function tmp = code(x_46_re, x_46_im, y_46_re, y_46_im)
tmp = ((x_46_im * y_46_re) - (x_46_re * y_46_im)) / ((y_46_re * y_46_re) + (y_46_im * y_46_im));
end
↓
function tmp_3 = code(x_46_re, x_46_im, y_46_re, y_46_im)
t_0 = (x_46_im * y_46_re) - (x_46_re * y_46_im);
t_1 = (((x_46_im / y_46_im) * y_46_re) - x_46_re) / y_46_im;
t_2 = (y_46_re * y_46_re) + (y_46_im * y_46_im);
tmp = 0.0;
if (y_46_im <= -1.4e+121)
tmp = t_1;
elseif (y_46_im <= -4.7e-152)
tmp_2 = 0.0;
if (t_0 ~= 0.0)
tmp_2 = 1.0 / (1.0 / t_0);
else
tmp_2 = t_0;
end
tmp = tmp_2 / t_2;
elseif (y_46_im <= 1.4e-164)
tmp = (x_46_im - ((y_46_im * x_46_re) / y_46_re)) / y_46_re;
elseif (y_46_im <= 7e+92)
tmp = t_0 / t_2;
else
tmp = t_1;
end
tmp_3 = tmp;
end
code[x$46$re_, x$46$im_, y$46$re_, y$46$im_] := N[(N[(N[(x$46$im * y$46$re), $MachinePrecision] - N[(x$46$re * y$46$im), $MachinePrecision]), $MachinePrecision] / N[(N[(y$46$re * y$46$re), $MachinePrecision] + N[(y$46$im * y$46$im), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
↓
code[x$46$re_, x$46$im_, y$46$re_, y$46$im_] := Block[{t$95$0 = N[(N[(x$46$im * y$46$re), $MachinePrecision] - N[(x$46$re * y$46$im), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[(N[(N[(N[(x$46$im / y$46$im), $MachinePrecision] * y$46$re), $MachinePrecision] - x$46$re), $MachinePrecision] / y$46$im), $MachinePrecision]}, Block[{t$95$2 = N[(N[(y$46$re * y$46$re), $MachinePrecision] + N[(y$46$im * y$46$im), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[y$46$im, -1.4e+121], t$95$1, If[LessEqual[y$46$im, -4.7e-152], N[(If[Unequal[t$95$0, 0.0], N[(1.0 / N[(1.0 / t$95$0), $MachinePrecision]), $MachinePrecision], t$95$0] / t$95$2), $MachinePrecision], If[LessEqual[y$46$im, 1.4e-164], N[(N[(x$46$im - N[(N[(y$46$im * x$46$re), $MachinePrecision] / y$46$re), $MachinePrecision]), $MachinePrecision] / y$46$re), $MachinePrecision], If[LessEqual[y$46$im, 7e+92], N[(t$95$0 / t$95$2), $MachinePrecision], t$95$1]]]]]]]
\frac{x.im \cdot y.re - x.re \cdot y.im}{y.re \cdot y.re + y.im \cdot y.im}
↓
\begin{array}{l}
t_0 := x.im \cdot y.re - x.re \cdot y.im\\
t_1 := \frac{\frac{x.im}{y.im} \cdot y.re - x.re}{y.im}\\
t_2 := y.re \cdot y.re + y.im \cdot y.im\\
\mathbf{if}\;y.im \leq -1.4 \cdot 10^{+121}:\\
\;\;\;\;t_1\\
\mathbf{elif}\;y.im \leq -4.7 \cdot 10^{-152}:\\
\;\;\;\;\frac{\begin{array}{l}
\mathbf{if}\;t_0 \ne 0:\\
\;\;\;\;\frac{1}{\frac{1}{t_0}}\\
\mathbf{else}:\\
\;\;\;\;t_0\\
\end{array}}{t_2}\\
\mathbf{elif}\;y.im \leq 1.4 \cdot 10^{-164}:\\
\;\;\;\;\frac{x.im - \frac{y.im \cdot x.re}{y.re}}{y.re}\\
\mathbf{elif}\;y.im \leq 7 \cdot 10^{+92}:\\
\;\;\;\;\frac{t_0}{t_2}\\
\mathbf{else}:\\
\;\;\;\;t_1\\
\end{array}