
(FPCore (x.re x.im y.re y.im) :precision binary64 (/ (+ (* x.re y.re) (* x.im y.im)) (+ (* y.re y.re) (* y.im y.im))))
double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
return ((x_46_re * y_46_re) + (x_46_im * y_46_im)) / ((y_46_re * y_46_re) + (y_46_im * y_46_im));
}
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_46re * y_46re) + (x_46im * y_46im)) / ((y_46re * y_46re) + (y_46im * y_46im))
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_re * y_46_re) + (x_46_im * 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): return ((x_46_re * y_46_re) + (x_46_im * y_46_im)) / ((y_46_re * y_46_re) + (y_46_im * y_46_im))
function code(x_46_re, x_46_im, y_46_re, y_46_im) return Float64(Float64(Float64(x_46_re * y_46_re) + Float64(x_46_im * y_46_im)) / Float64(Float64(y_46_re * y_46_re) + Float64(y_46_im * y_46_im))) end
function tmp = code(x_46_re, x_46_im, y_46_re, y_46_im) tmp = ((x_46_re * y_46_re) + (x_46_im * y_46_im)) / ((y_46_re * y_46_re) + (y_46_im * y_46_im)); end
code[x$46$re_, x$46$im_, y$46$re_, y$46$im_] := N[(N[(N[(x$46$re * y$46$re), $MachinePrecision] + N[(x$46$im * y$46$im), $MachinePrecision]), $MachinePrecision] / N[(N[(y$46$re * y$46$re), $MachinePrecision] + N[(y$46$im * y$46$im), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\frac{x.re \cdot y.re + x.im \cdot y.im}{y.re \cdot y.re + y.im \cdot y.im}
\end{array}
Sampling outcomes in binary64 precision:
Herbie found 9 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (x.re x.im y.re y.im) :precision binary64 (/ (+ (* x.re y.re) (* x.im y.im)) (+ (* y.re y.re) (* y.im y.im))))
double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
return ((x_46_re * y_46_re) + (x_46_im * y_46_im)) / ((y_46_re * y_46_re) + (y_46_im * y_46_im));
}
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_46re * y_46re) + (x_46im * y_46im)) / ((y_46re * y_46re) + (y_46im * y_46im))
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_re * y_46_re) + (x_46_im * 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): return ((x_46_re * y_46_re) + (x_46_im * y_46_im)) / ((y_46_re * y_46_re) + (y_46_im * y_46_im))
function code(x_46_re, x_46_im, y_46_re, y_46_im) return Float64(Float64(Float64(x_46_re * y_46_re) + Float64(x_46_im * y_46_im)) / Float64(Float64(y_46_re * y_46_re) + Float64(y_46_im * y_46_im))) end
function tmp = code(x_46_re, x_46_im, y_46_re, y_46_im) tmp = ((x_46_re * y_46_re) + (x_46_im * y_46_im)) / ((y_46_re * y_46_re) + (y_46_im * y_46_im)); end
code[x$46$re_, x$46$im_, y$46$re_, y$46$im_] := N[(N[(N[(x$46$re * y$46$re), $MachinePrecision] + N[(x$46$im * y$46$im), $MachinePrecision]), $MachinePrecision] / N[(N[(y$46$re * y$46$re), $MachinePrecision] + N[(y$46$im * y$46$im), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\frac{x.re \cdot y.re + x.im \cdot y.im}{y.re \cdot y.re + y.im \cdot y.im}
\end{array}
(FPCore (x.re x.im y.re y.im)
:precision binary64
(let* ((t_0 (+ (* x.re y.re) (* x.im y.im))))
(if (<= (/ t_0 (+ (* y.re y.re) (* y.im y.im))) 5e+305)
(* (/ 1.0 (hypot y.re y.im)) (/ t_0 (hypot y.re y.im)))
(/ (+ x.re (* x.im (/ y.im y.re))) y.re))))
double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
double t_0 = (x_46_re * y_46_re) + (x_46_im * y_46_im);
double tmp;
if ((t_0 / ((y_46_re * y_46_re) + (y_46_im * y_46_im))) <= 5e+305) {
tmp = (1.0 / hypot(y_46_re, y_46_im)) * (t_0 / hypot(y_46_re, y_46_im));
} else {
tmp = (x_46_re + (x_46_im * (y_46_im / y_46_re))) / y_46_re;
}
return tmp;
}
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_re * y_46_re) + (x_46_im * y_46_im);
double tmp;
if ((t_0 / ((y_46_re * y_46_re) + (y_46_im * y_46_im))) <= 5e+305) {
tmp = (1.0 / Math.hypot(y_46_re, y_46_im)) * (t_0 / Math.hypot(y_46_re, y_46_im));
} else {
tmp = (x_46_re + (x_46_im * (y_46_im / y_46_re))) / y_46_re;
}
return tmp;
}
def code(x_46_re, x_46_im, y_46_re, y_46_im): t_0 = (x_46_re * y_46_re) + (x_46_im * y_46_im) tmp = 0 if (t_0 / ((y_46_re * y_46_re) + (y_46_im * y_46_im))) <= 5e+305: tmp = (1.0 / math.hypot(y_46_re, y_46_im)) * (t_0 / math.hypot(y_46_re, y_46_im)) else: tmp = (x_46_re + (x_46_im * (y_46_im / y_46_re))) / y_46_re return tmp
function code(x_46_re, x_46_im, y_46_re, y_46_im) t_0 = Float64(Float64(x_46_re * y_46_re) + Float64(x_46_im * y_46_im)) tmp = 0.0 if (Float64(t_0 / Float64(Float64(y_46_re * y_46_re) + Float64(y_46_im * y_46_im))) <= 5e+305) tmp = Float64(Float64(1.0 / hypot(y_46_re, y_46_im)) * Float64(t_0 / hypot(y_46_re, y_46_im))); else tmp = Float64(Float64(x_46_re + Float64(x_46_im * Float64(y_46_im / y_46_re))) / y_46_re); end return tmp end
function tmp_2 = code(x_46_re, x_46_im, y_46_re, y_46_im) t_0 = (x_46_re * y_46_re) + (x_46_im * y_46_im); tmp = 0.0; if ((t_0 / ((y_46_re * y_46_re) + (y_46_im * y_46_im))) <= 5e+305) tmp = (1.0 / hypot(y_46_re, y_46_im)) * (t_0 / hypot(y_46_re, y_46_im)); else tmp = (x_46_re + (x_46_im * (y_46_im / y_46_re))) / y_46_re; end tmp_2 = tmp; end
code[x$46$re_, x$46$im_, y$46$re_, y$46$im_] := Block[{t$95$0 = N[(N[(x$46$re * y$46$re), $MachinePrecision] + N[(x$46$im * y$46$im), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[N[(t$95$0 / N[(N[(y$46$re * y$46$re), $MachinePrecision] + N[(y$46$im * y$46$im), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], 5e+305], N[(N[(1.0 / N[Sqrt[y$46$re ^ 2 + y$46$im ^ 2], $MachinePrecision]), $MachinePrecision] * N[(t$95$0 / N[Sqrt[y$46$re ^ 2 + y$46$im ^ 2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(x$46$re + N[(x$46$im * N[(y$46$im / y$46$re), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / y$46$re), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := x.re \cdot y.re + x.im \cdot y.im\\
\mathbf{if}\;\frac{t\_0}{y.re \cdot y.re + y.im \cdot y.im} \leq 5 \cdot 10^{+305}:\\
\;\;\;\;\frac{1}{\mathsf{hypot}\left(y.re, y.im\right)} \cdot \frac{t\_0}{\mathsf{hypot}\left(y.re, y.im\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{x.re + x.im \cdot \frac{y.im}{y.re}}{y.re}\\
\end{array}
\end{array}
if (/.f64 (+.f64 (*.f64 x.re y.re) (*.f64 x.im y.im)) (+.f64 (*.f64 y.re y.re) (*.f64 y.im y.im))) < 5.00000000000000009e305Initial program 77.6%
*-un-lft-identity77.6%
add-sqr-sqrt77.6%
times-frac77.6%
hypot-define77.6%
hypot-define96.7%
Applied egg-rr96.7%
if 5.00000000000000009e305 < (/.f64 (+.f64 (*.f64 x.re y.re) (*.f64 x.im y.im)) (+.f64 (*.f64 y.re y.re) (*.f64 y.im y.im))) Initial program 10.9%
Taylor expanded in y.re around inf 56.7%
associate-/l*61.8%
Simplified61.8%
(FPCore (x.re x.im y.re y.im)
:precision binary64
(let* ((t_0
(/ (+ (* x.re y.re) (* x.im y.im)) (+ (* y.re y.re) (* y.im y.im))))
(t_1 (/ (+ x.re (* y.im (/ x.im y.re))) y.re)))
(if (<= y.re -7.2e+73)
t_1
(if (<= y.re -3.1e-79)
t_0
(if (<= y.re 5.2e-99)
(/ (+ x.im (/ (* x.re y.re) y.im)) y.im)
(if (<= y.re 5.5e+56) t_0 t_1))))))
double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
double t_0 = ((x_46_re * y_46_re) + (x_46_im * y_46_im)) / ((y_46_re * y_46_re) + (y_46_im * y_46_im));
double t_1 = (x_46_re + (y_46_im * (x_46_im / y_46_re))) / y_46_re;
double tmp;
if (y_46_re <= -7.2e+73) {
tmp = t_1;
} else if (y_46_re <= -3.1e-79) {
tmp = t_0;
} else if (y_46_re <= 5.2e-99) {
tmp = (x_46_im + ((x_46_re * y_46_re) / y_46_im)) / y_46_im;
} else if (y_46_re <= 5.5e+56) {
tmp = t_0;
} 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
real(8) :: t_0
real(8) :: t_1
real(8) :: tmp
t_0 = ((x_46re * y_46re) + (x_46im * y_46im)) / ((y_46re * y_46re) + (y_46im * y_46im))
t_1 = (x_46re + (y_46im * (x_46im / y_46re))) / y_46re
if (y_46re <= (-7.2d+73)) then
tmp = t_1
else if (y_46re <= (-3.1d-79)) then
tmp = t_0
else if (y_46re <= 5.2d-99) then
tmp = (x_46im + ((x_46re * y_46re) / y_46im)) / y_46im
else if (y_46re <= 5.5d+56) then
tmp = t_0
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) {
double t_0 = ((x_46_re * y_46_re) + (x_46_im * y_46_im)) / ((y_46_re * y_46_re) + (y_46_im * y_46_im));
double t_1 = (x_46_re + (y_46_im * (x_46_im / y_46_re))) / y_46_re;
double tmp;
if (y_46_re <= -7.2e+73) {
tmp = t_1;
} else if (y_46_re <= -3.1e-79) {
tmp = t_0;
} else if (y_46_re <= 5.2e-99) {
tmp = (x_46_im + ((x_46_re * y_46_re) / y_46_im)) / y_46_im;
} else if (y_46_re <= 5.5e+56) {
tmp = t_0;
} else {
tmp = t_1;
}
return tmp;
}
def code(x_46_re, x_46_im, y_46_re, y_46_im): t_0 = ((x_46_re * y_46_re) + (x_46_im * y_46_im)) / ((y_46_re * y_46_re) + (y_46_im * y_46_im)) t_1 = (x_46_re + (y_46_im * (x_46_im / y_46_re))) / y_46_re tmp = 0 if y_46_re <= -7.2e+73: tmp = t_1 elif y_46_re <= -3.1e-79: tmp = t_0 elif y_46_re <= 5.2e-99: tmp = (x_46_im + ((x_46_re * y_46_re) / y_46_im)) / y_46_im elif y_46_re <= 5.5e+56: tmp = t_0 else: tmp = t_1 return tmp
function code(x_46_re, x_46_im, y_46_re, y_46_im) t_0 = Float64(Float64(Float64(x_46_re * y_46_re) + Float64(x_46_im * y_46_im)) / Float64(Float64(y_46_re * y_46_re) + Float64(y_46_im * y_46_im))) t_1 = Float64(Float64(x_46_re + Float64(y_46_im * Float64(x_46_im / y_46_re))) / y_46_re) tmp = 0.0 if (y_46_re <= -7.2e+73) tmp = t_1; elseif (y_46_re <= -3.1e-79) tmp = t_0; elseif (y_46_re <= 5.2e-99) tmp = Float64(Float64(x_46_im + Float64(Float64(x_46_re * y_46_re) / y_46_im)) / y_46_im); elseif (y_46_re <= 5.5e+56) tmp = t_0; else tmp = t_1; end return tmp end
function tmp_2 = code(x_46_re, x_46_im, y_46_re, y_46_im) t_0 = ((x_46_re * y_46_re) + (x_46_im * y_46_im)) / ((y_46_re * y_46_re) + (y_46_im * y_46_im)); t_1 = (x_46_re + (y_46_im * (x_46_im / y_46_re))) / y_46_re; tmp = 0.0; if (y_46_re <= -7.2e+73) tmp = t_1; elseif (y_46_re <= -3.1e-79) tmp = t_0; elseif (y_46_re <= 5.2e-99) tmp = (x_46_im + ((x_46_re * y_46_re) / y_46_im)) / y_46_im; elseif (y_46_re <= 5.5e+56) tmp = t_0; else tmp = t_1; end tmp_2 = tmp; end
code[x$46$re_, x$46$im_, y$46$re_, y$46$im_] := Block[{t$95$0 = N[(N[(N[(x$46$re * y$46$re), $MachinePrecision] + N[(x$46$im * y$46$im), $MachinePrecision]), $MachinePrecision] / N[(N[(y$46$re * y$46$re), $MachinePrecision] + N[(y$46$im * y$46$im), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[(N[(x$46$re + N[(y$46$im * N[(x$46$im / y$46$re), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / y$46$re), $MachinePrecision]}, If[LessEqual[y$46$re, -7.2e+73], t$95$1, If[LessEqual[y$46$re, -3.1e-79], t$95$0, If[LessEqual[y$46$re, 5.2e-99], N[(N[(x$46$im + N[(N[(x$46$re * y$46$re), $MachinePrecision] / y$46$im), $MachinePrecision]), $MachinePrecision] / y$46$im), $MachinePrecision], If[LessEqual[y$46$re, 5.5e+56], t$95$0, t$95$1]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \frac{x.re \cdot y.re + x.im \cdot y.im}{y.re \cdot y.re + y.im \cdot y.im}\\
t_1 := \frac{x.re + y.im \cdot \frac{x.im}{y.re}}{y.re}\\
\mathbf{if}\;y.re \leq -7.2 \cdot 10^{+73}:\\
\;\;\;\;t\_1\\
\mathbf{elif}\;y.re \leq -3.1 \cdot 10^{-79}:\\
\;\;\;\;t\_0\\
\mathbf{elif}\;y.re \leq 5.2 \cdot 10^{-99}:\\
\;\;\;\;\frac{x.im + \frac{x.re \cdot y.re}{y.im}}{y.im}\\
\mathbf{elif}\;y.re \leq 5.5 \cdot 10^{+56}:\\
\;\;\;\;t\_0\\
\mathbf{else}:\\
\;\;\;\;t\_1\\
\end{array}
\end{array}
if y.re < -7.1999999999999998e73 or 5.5000000000000002e56 < y.re Initial program 48.1%
Taylor expanded in y.re around inf 88.2%
*-commutative88.2%
associate-/l*91.9%
Applied egg-rr91.9%
if -7.1999999999999998e73 < y.re < -3.0999999999999999e-79 or 5.2000000000000001e-99 < y.re < 5.5000000000000002e56Initial program 78.2%
if -3.0999999999999999e-79 < y.re < 5.2000000000000001e-99Initial program 67.5%
Taylor expanded in y.im around inf 92.7%
(FPCore (x.re x.im y.re y.im) :precision binary64 (if (or (<= y.re -2.8e+78) (not (<= y.re 6.4e+30))) (/ x.re y.re) (/ (+ x.im (/ (* x.re y.re) y.im)) y.im)))
double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
double tmp;
if ((y_46_re <= -2.8e+78) || !(y_46_re <= 6.4e+30)) {
tmp = x_46_re / y_46_re;
} else {
tmp = (x_46_im + ((x_46_re * y_46_re) / y_46_im)) / y_46_im;
}
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
real(8) :: tmp
if ((y_46re <= (-2.8d+78)) .or. (.not. (y_46re <= 6.4d+30))) then
tmp = x_46re / y_46re
else
tmp = (x_46im + ((x_46re * y_46re) / y_46im)) / y_46im
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) {
double tmp;
if ((y_46_re <= -2.8e+78) || !(y_46_re <= 6.4e+30)) {
tmp = x_46_re / y_46_re;
} else {
tmp = (x_46_im + ((x_46_re * y_46_re) / y_46_im)) / y_46_im;
}
return tmp;
}
def code(x_46_re, x_46_im, y_46_re, y_46_im): tmp = 0 if (y_46_re <= -2.8e+78) or not (y_46_re <= 6.4e+30): tmp = x_46_re / y_46_re else: tmp = (x_46_im + ((x_46_re * y_46_re) / y_46_im)) / y_46_im return tmp
function code(x_46_re, x_46_im, y_46_re, y_46_im) tmp = 0.0 if ((y_46_re <= -2.8e+78) || !(y_46_re <= 6.4e+30)) tmp = Float64(x_46_re / y_46_re); else tmp = Float64(Float64(x_46_im + Float64(Float64(x_46_re * y_46_re) / y_46_im)) / y_46_im); end return tmp end
function tmp_2 = code(x_46_re, x_46_im, y_46_re, y_46_im) tmp = 0.0; if ((y_46_re <= -2.8e+78) || ~((y_46_re <= 6.4e+30))) tmp = x_46_re / y_46_re; else tmp = (x_46_im + ((x_46_re * y_46_re) / y_46_im)) / y_46_im; end tmp_2 = tmp; end
code[x$46$re_, x$46$im_, y$46$re_, y$46$im_] := If[Or[LessEqual[y$46$re, -2.8e+78], N[Not[LessEqual[y$46$re, 6.4e+30]], $MachinePrecision]], N[(x$46$re / y$46$re), $MachinePrecision], N[(N[(x$46$im + N[(N[(x$46$re * y$46$re), $MachinePrecision] / y$46$im), $MachinePrecision]), $MachinePrecision] / y$46$im), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;y.re \leq -2.8 \cdot 10^{+78} \lor \neg \left(y.re \leq 6.4 \cdot 10^{+30}\right):\\
\;\;\;\;\frac{x.re}{y.re}\\
\mathbf{else}:\\
\;\;\;\;\frac{x.im + \frac{x.re \cdot y.re}{y.im}}{y.im}\\
\end{array}
\end{array}
if y.re < -2.8000000000000001e78 or 6.39999999999999945e30 < y.re Initial program 48.7%
Taylor expanded in y.re around inf 75.5%
if -2.8000000000000001e78 < y.re < 6.39999999999999945e30Initial program 73.0%
Taylor expanded in y.im around inf 77.1%
Final simplification76.4%
(FPCore (x.re x.im y.re y.im) :precision binary64 (if (or (<= y.re -4.2e+81) (not (<= y.re 1.16e+73))) (/ x.re y.re) (/ (+ x.im (* x.re (/ y.re y.im))) y.im)))
double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
double tmp;
if ((y_46_re <= -4.2e+81) || !(y_46_re <= 1.16e+73)) {
tmp = x_46_re / y_46_re;
} else {
tmp = (x_46_im + (x_46_re * (y_46_re / y_46_im))) / y_46_im;
}
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
real(8) :: tmp
if ((y_46re <= (-4.2d+81)) .or. (.not. (y_46re <= 1.16d+73))) then
tmp = x_46re / y_46re
else
tmp = (x_46im + (x_46re * (y_46re / y_46im))) / y_46im
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) {
double tmp;
if ((y_46_re <= -4.2e+81) || !(y_46_re <= 1.16e+73)) {
tmp = x_46_re / y_46_re;
} else {
tmp = (x_46_im + (x_46_re * (y_46_re / y_46_im))) / y_46_im;
}
return tmp;
}
def code(x_46_re, x_46_im, y_46_re, y_46_im): tmp = 0 if (y_46_re <= -4.2e+81) or not (y_46_re <= 1.16e+73): tmp = x_46_re / y_46_re else: tmp = (x_46_im + (x_46_re * (y_46_re / y_46_im))) / y_46_im return tmp
function code(x_46_re, x_46_im, y_46_re, y_46_im) tmp = 0.0 if ((y_46_re <= -4.2e+81) || !(y_46_re <= 1.16e+73)) tmp = Float64(x_46_re / y_46_re); else tmp = Float64(Float64(x_46_im + Float64(x_46_re * Float64(y_46_re / y_46_im))) / y_46_im); end return tmp end
function tmp_2 = code(x_46_re, x_46_im, y_46_re, y_46_im) tmp = 0.0; if ((y_46_re <= -4.2e+81) || ~((y_46_re <= 1.16e+73))) tmp = x_46_re / y_46_re; else tmp = (x_46_im + (x_46_re * (y_46_re / y_46_im))) / y_46_im; end tmp_2 = tmp; end
code[x$46$re_, x$46$im_, y$46$re_, y$46$im_] := If[Or[LessEqual[y$46$re, -4.2e+81], N[Not[LessEqual[y$46$re, 1.16e+73]], $MachinePrecision]], N[(x$46$re / y$46$re), $MachinePrecision], N[(N[(x$46$im + N[(x$46$re * N[(y$46$re / y$46$im), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / y$46$im), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;y.re \leq -4.2 \cdot 10^{+81} \lor \neg \left(y.re \leq 1.16 \cdot 10^{+73}\right):\\
\;\;\;\;\frac{x.re}{y.re}\\
\mathbf{else}:\\
\;\;\;\;\frac{x.im + x.re \cdot \frac{y.re}{y.im}}{y.im}\\
\end{array}
\end{array}
if y.re < -4.1999999999999997e81 or 1.16000000000000007e73 < y.re Initial program 47.1%
Taylor expanded in y.re around inf 78.1%
if -4.1999999999999997e81 < y.re < 1.16000000000000007e73Initial program 72.7%
Taylor expanded in y.im around inf 74.7%
associate-/l*74.1%
Simplified74.1%
Final simplification75.7%
(FPCore (x.re x.im y.re y.im)
:precision binary64
(if (<= y.im -4.8e-32)
(/ (+ x.im (/ x.re (/ y.im y.re))) y.im)
(if (<= y.im 9.5e+45)
(/ (+ x.re (/ (* x.im y.im) y.re)) y.re)
(/ (+ x.im (* y.re (/ x.re y.im))) y.im))))
double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
double tmp;
if (y_46_im <= -4.8e-32) {
tmp = (x_46_im + (x_46_re / (y_46_im / y_46_re))) / y_46_im;
} else if (y_46_im <= 9.5e+45) {
tmp = (x_46_re + ((x_46_im * y_46_im) / y_46_re)) / y_46_re;
} else {
tmp = (x_46_im + (y_46_re * (x_46_re / y_46_im))) / y_46_im;
}
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
real(8) :: tmp
if (y_46im <= (-4.8d-32)) then
tmp = (x_46im + (x_46re / (y_46im / y_46re))) / y_46im
else if (y_46im <= 9.5d+45) then
tmp = (x_46re + ((x_46im * y_46im) / y_46re)) / y_46re
else
tmp = (x_46im + (y_46re * (x_46re / y_46im))) / y_46im
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) {
double tmp;
if (y_46_im <= -4.8e-32) {
tmp = (x_46_im + (x_46_re / (y_46_im / y_46_re))) / y_46_im;
} else if (y_46_im <= 9.5e+45) {
tmp = (x_46_re + ((x_46_im * y_46_im) / y_46_re)) / y_46_re;
} else {
tmp = (x_46_im + (y_46_re * (x_46_re / y_46_im))) / y_46_im;
}
return tmp;
}
def code(x_46_re, x_46_im, y_46_re, y_46_im): tmp = 0 if y_46_im <= -4.8e-32: tmp = (x_46_im + (x_46_re / (y_46_im / y_46_re))) / y_46_im elif y_46_im <= 9.5e+45: tmp = (x_46_re + ((x_46_im * y_46_im) / y_46_re)) / y_46_re else: tmp = (x_46_im + (y_46_re * (x_46_re / y_46_im))) / y_46_im return tmp
function code(x_46_re, x_46_im, y_46_re, y_46_im) tmp = 0.0 if (y_46_im <= -4.8e-32) tmp = Float64(Float64(x_46_im + Float64(x_46_re / Float64(y_46_im / y_46_re))) / y_46_im); elseif (y_46_im <= 9.5e+45) tmp = Float64(Float64(x_46_re + Float64(Float64(x_46_im * y_46_im) / y_46_re)) / y_46_re); else tmp = Float64(Float64(x_46_im + Float64(y_46_re * Float64(x_46_re / y_46_im))) / y_46_im); end return tmp end
function tmp_2 = code(x_46_re, x_46_im, y_46_re, y_46_im) tmp = 0.0; if (y_46_im <= -4.8e-32) tmp = (x_46_im + (x_46_re / (y_46_im / y_46_re))) / y_46_im; elseif (y_46_im <= 9.5e+45) tmp = (x_46_re + ((x_46_im * y_46_im) / y_46_re)) / y_46_re; else tmp = (x_46_im + (y_46_re * (x_46_re / y_46_im))) / y_46_im; end tmp_2 = tmp; end
code[x$46$re_, x$46$im_, y$46$re_, y$46$im_] := If[LessEqual[y$46$im, -4.8e-32], N[(N[(x$46$im + N[(x$46$re / N[(y$46$im / y$46$re), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / y$46$im), $MachinePrecision], If[LessEqual[y$46$im, 9.5e+45], N[(N[(x$46$re + N[(N[(x$46$im * y$46$im), $MachinePrecision] / y$46$re), $MachinePrecision]), $MachinePrecision] / y$46$re), $MachinePrecision], N[(N[(x$46$im + N[(y$46$re * N[(x$46$re / y$46$im), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / y$46$im), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;y.im \leq -4.8 \cdot 10^{-32}:\\
\;\;\;\;\frac{x.im + \frac{x.re}{\frac{y.im}{y.re}}}{y.im}\\
\mathbf{elif}\;y.im \leq 9.5 \cdot 10^{+45}:\\
\;\;\;\;\frac{x.re + \frac{x.im \cdot y.im}{y.re}}{y.re}\\
\mathbf{else}:\\
\;\;\;\;\frac{x.im + y.re \cdot \frac{x.re}{y.im}}{y.im}\\
\end{array}
\end{array}
if y.im < -4.8000000000000003e-32Initial program 48.8%
Taylor expanded in y.im around inf 79.7%
associate-/l*81.4%
*-commutative81.4%
Applied egg-rr81.4%
*-commutative81.4%
clear-num81.5%
un-div-inv81.5%
Applied egg-rr81.5%
if -4.8000000000000003e-32 < y.im < 9.4999999999999998e45Initial program 76.0%
Taylor expanded in y.re around inf 85.7%
if 9.4999999999999998e45 < y.im Initial program 44.6%
Taylor expanded in y.im around inf 73.4%
*-commutative73.4%
associate-/l*76.6%
Applied egg-rr76.6%
(FPCore (x.re x.im y.re y.im)
:precision binary64
(if (<= y.im -7.1e-29)
(/ (+ x.im (/ x.re (/ y.im y.re))) y.im)
(if (<= y.im 8.2e+83)
(/ (+ x.re (* y.im (/ x.im y.re))) y.re)
(/ (+ x.im (* y.re (/ x.re y.im))) y.im))))
double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
double tmp;
if (y_46_im <= -7.1e-29) {
tmp = (x_46_im + (x_46_re / (y_46_im / y_46_re))) / y_46_im;
} else if (y_46_im <= 8.2e+83) {
tmp = (x_46_re + (y_46_im * (x_46_im / y_46_re))) / y_46_re;
} else {
tmp = (x_46_im + (y_46_re * (x_46_re / y_46_im))) / y_46_im;
}
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
real(8) :: tmp
if (y_46im <= (-7.1d-29)) then
tmp = (x_46im + (x_46re / (y_46im / y_46re))) / y_46im
else if (y_46im <= 8.2d+83) then
tmp = (x_46re + (y_46im * (x_46im / y_46re))) / y_46re
else
tmp = (x_46im + (y_46re * (x_46re / y_46im))) / y_46im
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) {
double tmp;
if (y_46_im <= -7.1e-29) {
tmp = (x_46_im + (x_46_re / (y_46_im / y_46_re))) / y_46_im;
} else if (y_46_im <= 8.2e+83) {
tmp = (x_46_re + (y_46_im * (x_46_im / y_46_re))) / y_46_re;
} else {
tmp = (x_46_im + (y_46_re * (x_46_re / y_46_im))) / y_46_im;
}
return tmp;
}
def code(x_46_re, x_46_im, y_46_re, y_46_im): tmp = 0 if y_46_im <= -7.1e-29: tmp = (x_46_im + (x_46_re / (y_46_im / y_46_re))) / y_46_im elif y_46_im <= 8.2e+83: tmp = (x_46_re + (y_46_im * (x_46_im / y_46_re))) / y_46_re else: tmp = (x_46_im + (y_46_re * (x_46_re / y_46_im))) / y_46_im return tmp
function code(x_46_re, x_46_im, y_46_re, y_46_im) tmp = 0.0 if (y_46_im <= -7.1e-29) tmp = Float64(Float64(x_46_im + Float64(x_46_re / Float64(y_46_im / y_46_re))) / y_46_im); elseif (y_46_im <= 8.2e+83) tmp = Float64(Float64(x_46_re + Float64(y_46_im * Float64(x_46_im / y_46_re))) / y_46_re); else tmp = Float64(Float64(x_46_im + Float64(y_46_re * Float64(x_46_re / y_46_im))) / y_46_im); end return tmp end
function tmp_2 = code(x_46_re, x_46_im, y_46_re, y_46_im) tmp = 0.0; if (y_46_im <= -7.1e-29) tmp = (x_46_im + (x_46_re / (y_46_im / y_46_re))) / y_46_im; elseif (y_46_im <= 8.2e+83) tmp = (x_46_re + (y_46_im * (x_46_im / y_46_re))) / y_46_re; else tmp = (x_46_im + (y_46_re * (x_46_re / y_46_im))) / y_46_im; end tmp_2 = tmp; end
code[x$46$re_, x$46$im_, y$46$re_, y$46$im_] := If[LessEqual[y$46$im, -7.1e-29], N[(N[(x$46$im + N[(x$46$re / N[(y$46$im / y$46$re), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / y$46$im), $MachinePrecision], If[LessEqual[y$46$im, 8.2e+83], N[(N[(x$46$re + N[(y$46$im * N[(x$46$im / y$46$re), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / y$46$re), $MachinePrecision], N[(N[(x$46$im + N[(y$46$re * N[(x$46$re / y$46$im), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / y$46$im), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;y.im \leq -7.1 \cdot 10^{-29}:\\
\;\;\;\;\frac{x.im + \frac{x.re}{\frac{y.im}{y.re}}}{y.im}\\
\mathbf{elif}\;y.im \leq 8.2 \cdot 10^{+83}:\\
\;\;\;\;\frac{x.re + y.im \cdot \frac{x.im}{y.re}}{y.re}\\
\mathbf{else}:\\
\;\;\;\;\frac{x.im + y.re \cdot \frac{x.re}{y.im}}{y.im}\\
\end{array}
\end{array}
if y.im < -7.10000000000000003e-29Initial program 48.8%
Taylor expanded in y.im around inf 79.7%
associate-/l*81.4%
*-commutative81.4%
Applied egg-rr81.4%
*-commutative81.4%
clear-num81.5%
un-div-inv81.5%
Applied egg-rr81.5%
if -7.10000000000000003e-29 < y.im < 8.2000000000000002e83Initial program 76.0%
Taylor expanded in y.re around inf 82.4%
*-commutative82.4%
associate-/l*81.9%
Applied egg-rr81.9%
if 8.2000000000000002e83 < y.im Initial program 37.1%
Taylor expanded in y.im around inf 78.6%
*-commutative78.6%
associate-/l*82.7%
Applied egg-rr82.7%
(FPCore (x.re x.im y.re y.im)
:precision binary64
(if (<= y.im -7.1e-29)
(/ (+ x.im (/ x.re (/ y.im y.re))) y.im)
(if (<= y.im 2.1e+81)
(/ (+ x.re (* x.im (/ y.im y.re))) y.re)
(/ (+ x.im (* y.re (/ x.re y.im))) y.im))))
double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
double tmp;
if (y_46_im <= -7.1e-29) {
tmp = (x_46_im + (x_46_re / (y_46_im / y_46_re))) / y_46_im;
} else if (y_46_im <= 2.1e+81) {
tmp = (x_46_re + (x_46_im * (y_46_im / y_46_re))) / y_46_re;
} else {
tmp = (x_46_im + (y_46_re * (x_46_re / y_46_im))) / y_46_im;
}
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
real(8) :: tmp
if (y_46im <= (-7.1d-29)) then
tmp = (x_46im + (x_46re / (y_46im / y_46re))) / y_46im
else if (y_46im <= 2.1d+81) then
tmp = (x_46re + (x_46im * (y_46im / y_46re))) / y_46re
else
tmp = (x_46im + (y_46re * (x_46re / y_46im))) / y_46im
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) {
double tmp;
if (y_46_im <= -7.1e-29) {
tmp = (x_46_im + (x_46_re / (y_46_im / y_46_re))) / y_46_im;
} else if (y_46_im <= 2.1e+81) {
tmp = (x_46_re + (x_46_im * (y_46_im / y_46_re))) / y_46_re;
} else {
tmp = (x_46_im + (y_46_re * (x_46_re / y_46_im))) / y_46_im;
}
return tmp;
}
def code(x_46_re, x_46_im, y_46_re, y_46_im): tmp = 0 if y_46_im <= -7.1e-29: tmp = (x_46_im + (x_46_re / (y_46_im / y_46_re))) / y_46_im elif y_46_im <= 2.1e+81: tmp = (x_46_re + (x_46_im * (y_46_im / y_46_re))) / y_46_re else: tmp = (x_46_im + (y_46_re * (x_46_re / y_46_im))) / y_46_im return tmp
function code(x_46_re, x_46_im, y_46_re, y_46_im) tmp = 0.0 if (y_46_im <= -7.1e-29) tmp = Float64(Float64(x_46_im + Float64(x_46_re / Float64(y_46_im / y_46_re))) / y_46_im); elseif (y_46_im <= 2.1e+81) tmp = Float64(Float64(x_46_re + Float64(x_46_im * Float64(y_46_im / y_46_re))) / y_46_re); else tmp = Float64(Float64(x_46_im + Float64(y_46_re * Float64(x_46_re / y_46_im))) / y_46_im); end return tmp end
function tmp_2 = code(x_46_re, x_46_im, y_46_re, y_46_im) tmp = 0.0; if (y_46_im <= -7.1e-29) tmp = (x_46_im + (x_46_re / (y_46_im / y_46_re))) / y_46_im; elseif (y_46_im <= 2.1e+81) tmp = (x_46_re + (x_46_im * (y_46_im / y_46_re))) / y_46_re; else tmp = (x_46_im + (y_46_re * (x_46_re / y_46_im))) / y_46_im; end tmp_2 = tmp; end
code[x$46$re_, x$46$im_, y$46$re_, y$46$im_] := If[LessEqual[y$46$im, -7.1e-29], N[(N[(x$46$im + N[(x$46$re / N[(y$46$im / y$46$re), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / y$46$im), $MachinePrecision], If[LessEqual[y$46$im, 2.1e+81], N[(N[(x$46$re + N[(x$46$im * N[(y$46$im / y$46$re), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / y$46$re), $MachinePrecision], N[(N[(x$46$im + N[(y$46$re * N[(x$46$re / y$46$im), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / y$46$im), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;y.im \leq -7.1 \cdot 10^{-29}:\\
\;\;\;\;\frac{x.im + \frac{x.re}{\frac{y.im}{y.re}}}{y.im}\\
\mathbf{elif}\;y.im \leq 2.1 \cdot 10^{+81}:\\
\;\;\;\;\frac{x.re + x.im \cdot \frac{y.im}{y.re}}{y.re}\\
\mathbf{else}:\\
\;\;\;\;\frac{x.im + y.re \cdot \frac{x.re}{y.im}}{y.im}\\
\end{array}
\end{array}
if y.im < -7.10000000000000003e-29Initial program 48.8%
Taylor expanded in y.im around inf 79.7%
associate-/l*81.4%
*-commutative81.4%
Applied egg-rr81.4%
*-commutative81.4%
clear-num81.5%
un-div-inv81.5%
Applied egg-rr81.5%
if -7.10000000000000003e-29 < y.im < 2.0999999999999999e81Initial program 76.0%
Taylor expanded in y.re around inf 82.4%
associate-/l*81.8%
Simplified81.8%
if 2.0999999999999999e81 < y.im Initial program 37.1%
Taylor expanded in y.im around inf 78.6%
*-commutative78.6%
associate-/l*82.7%
Applied egg-rr82.7%
(FPCore (x.re x.im y.re y.im) :precision binary64 (if (or (<= y.re -2.5e+62) (not (<= y.re 9.5e+31))) (/ x.re y.re) (/ x.im y.im)))
double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
double tmp;
if ((y_46_re <= -2.5e+62) || !(y_46_re <= 9.5e+31)) {
tmp = x_46_re / y_46_re;
} else {
tmp = x_46_im / y_46_im;
}
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
real(8) :: tmp
if ((y_46re <= (-2.5d+62)) .or. (.not. (y_46re <= 9.5d+31))) then
tmp = x_46re / y_46re
else
tmp = x_46im / y_46im
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) {
double tmp;
if ((y_46_re <= -2.5e+62) || !(y_46_re <= 9.5e+31)) {
tmp = x_46_re / y_46_re;
} else {
tmp = x_46_im / y_46_im;
}
return tmp;
}
def code(x_46_re, x_46_im, y_46_re, y_46_im): tmp = 0 if (y_46_re <= -2.5e+62) or not (y_46_re <= 9.5e+31): tmp = x_46_re / y_46_re else: tmp = x_46_im / y_46_im return tmp
function code(x_46_re, x_46_im, y_46_re, y_46_im) tmp = 0.0 if ((y_46_re <= -2.5e+62) || !(y_46_re <= 9.5e+31)) tmp = Float64(x_46_re / y_46_re); else tmp = Float64(x_46_im / y_46_im); end return tmp end
function tmp_2 = code(x_46_re, x_46_im, y_46_re, y_46_im) tmp = 0.0; if ((y_46_re <= -2.5e+62) || ~((y_46_re <= 9.5e+31))) tmp = x_46_re / y_46_re; else tmp = x_46_im / y_46_im; end tmp_2 = tmp; end
code[x$46$re_, x$46$im_, y$46$re_, y$46$im_] := If[Or[LessEqual[y$46$re, -2.5e+62], N[Not[LessEqual[y$46$re, 9.5e+31]], $MachinePrecision]], N[(x$46$re / y$46$re), $MachinePrecision], N[(x$46$im / y$46$im), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;y.re \leq -2.5 \cdot 10^{+62} \lor \neg \left(y.re \leq 9.5 \cdot 10^{+31}\right):\\
\;\;\;\;\frac{x.re}{y.re}\\
\mathbf{else}:\\
\;\;\;\;\frac{x.im}{y.im}\\
\end{array}
\end{array}
if y.re < -2.50000000000000014e62 or 9.5000000000000008e31 < y.re Initial program 50.5%
Taylor expanded in y.re around inf 73.9%
if -2.50000000000000014e62 < y.re < 9.5000000000000008e31Initial program 72.3%
Taylor expanded in y.re around 0 61.5%
Final simplification67.1%
(FPCore (x.re x.im y.re y.im) :precision binary64 (/ x.im y.im))
double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
return x_46_im / y_46_im;
}
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_46im
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_im;
}
def code(x_46_re, x_46_im, y_46_re, y_46_im): return x_46_im / y_46_im
function code(x_46_re, x_46_im, y_46_re, y_46_im) return Float64(x_46_im / y_46_im) end
function tmp = code(x_46_re, x_46_im, y_46_re, y_46_im) tmp = x_46_im / y_46_im; end
code[x$46$re_, x$46$im_, y$46$re_, y$46$im_] := N[(x$46$im / y$46$im), $MachinePrecision]
\begin{array}{l}
\\
\frac{x.im}{y.im}
\end{array}
Initial program 62.5%
Taylor expanded in y.re around 0 39.0%
herbie shell --seed 2024107
(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))))