
(FPCore (x.re x.im y.re y.im) :precision binary64 (let* ((t_0 (log (sqrt (+ (* x.re x.re) (* x.im x.im)))))) (* (exp (- (* t_0 y.re) (* (atan2 x.im x.re) y.im))) (cos (+ (* t_0 y.im) (* (atan2 x.im x.re) y.re))))))
double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
double t_0 = log(sqrt(((x_46_re * x_46_re) + (x_46_im * x_46_im))));
return exp(((t_0 * y_46_re) - (atan2(x_46_im, x_46_re) * y_46_im))) * cos(((t_0 * y_46_im) + (atan2(x_46_im, x_46_re) * y_46_re)));
}
real(8) function code(x_46re, x_46im, y_46re, y_46im)
use fmin_fmax_functions
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
t_0 = log(sqrt(((x_46re * x_46re) + (x_46im * x_46im))))
code = exp(((t_0 * y_46re) - (atan2(x_46im, x_46re) * y_46im))) * cos(((t_0 * y_46im) + (atan2(x_46im, x_46re) * y_46re)))
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 = Math.log(Math.sqrt(((x_46_re * x_46_re) + (x_46_im * x_46_im))));
return Math.exp(((t_0 * y_46_re) - (Math.atan2(x_46_im, x_46_re) * y_46_im))) * Math.cos(((t_0 * y_46_im) + (Math.atan2(x_46_im, x_46_re) * y_46_re)));
}
def code(x_46_re, x_46_im, y_46_re, y_46_im): t_0 = math.log(math.sqrt(((x_46_re * x_46_re) + (x_46_im * x_46_im)))) return math.exp(((t_0 * y_46_re) - (math.atan2(x_46_im, x_46_re) * y_46_im))) * math.cos(((t_0 * y_46_im) + (math.atan2(x_46_im, x_46_re) * y_46_re)))
function code(x_46_re, x_46_im, y_46_re, y_46_im) t_0 = log(sqrt(Float64(Float64(x_46_re * x_46_re) + Float64(x_46_im * x_46_im)))) return Float64(exp(Float64(Float64(t_0 * y_46_re) - Float64(atan(x_46_im, x_46_re) * y_46_im))) * cos(Float64(Float64(t_0 * y_46_im) + Float64(atan(x_46_im, x_46_re) * y_46_re)))) end
function tmp = code(x_46_re, x_46_im, y_46_re, y_46_im) t_0 = log(sqrt(((x_46_re * x_46_re) + (x_46_im * x_46_im)))); tmp = exp(((t_0 * y_46_re) - (atan2(x_46_im, x_46_re) * y_46_im))) * cos(((t_0 * y_46_im) + (atan2(x_46_im, x_46_re) * y_46_re))); end
code[x$46$re_, x$46$im_, y$46$re_, y$46$im_] := Block[{t$95$0 = N[Log[N[Sqrt[N[(N[(x$46$re * x$46$re), $MachinePrecision] + N[(x$46$im * x$46$im), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]], $MachinePrecision]}, N[(N[Exp[N[(N[(t$95$0 * y$46$re), $MachinePrecision] - N[(N[ArcTan[x$46$im / x$46$re], $MachinePrecision] * y$46$im), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] * N[Cos[N[(N[(t$95$0 * y$46$im), $MachinePrecision] + N[(N[ArcTan[x$46$im / x$46$re], $MachinePrecision] * y$46$re), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
t_0 := \log \left(\sqrt{x.re \cdot x.re + x.im \cdot x.im}\right)\\
e^{t\_0 \cdot y.re - \tan^{-1}_* \frac{x.im}{x.re} \cdot y.im} \cdot \cos \left(t\_0 \cdot y.im + \tan^{-1}_* \frac{x.im}{x.re} \cdot y.re\right)
\end{array}
Herbie found 9 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (x.re x.im y.re y.im) :precision binary64 (let* ((t_0 (log (sqrt (+ (* x.re x.re) (* x.im x.im)))))) (* (exp (- (* t_0 y.re) (* (atan2 x.im x.re) y.im))) (cos (+ (* t_0 y.im) (* (atan2 x.im x.re) y.re))))))
double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
double t_0 = log(sqrt(((x_46_re * x_46_re) + (x_46_im * x_46_im))));
return exp(((t_0 * y_46_re) - (atan2(x_46_im, x_46_re) * y_46_im))) * cos(((t_0 * y_46_im) + (atan2(x_46_im, x_46_re) * y_46_re)));
}
real(8) function code(x_46re, x_46im, y_46re, y_46im)
use fmin_fmax_functions
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
t_0 = log(sqrt(((x_46re * x_46re) + (x_46im * x_46im))))
code = exp(((t_0 * y_46re) - (atan2(x_46im, x_46re) * y_46im))) * cos(((t_0 * y_46im) + (atan2(x_46im, x_46re) * y_46re)))
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 = Math.log(Math.sqrt(((x_46_re * x_46_re) + (x_46_im * x_46_im))));
return Math.exp(((t_0 * y_46_re) - (Math.atan2(x_46_im, x_46_re) * y_46_im))) * Math.cos(((t_0 * y_46_im) + (Math.atan2(x_46_im, x_46_re) * y_46_re)));
}
def code(x_46_re, x_46_im, y_46_re, y_46_im): t_0 = math.log(math.sqrt(((x_46_re * x_46_re) + (x_46_im * x_46_im)))) return math.exp(((t_0 * y_46_re) - (math.atan2(x_46_im, x_46_re) * y_46_im))) * math.cos(((t_0 * y_46_im) + (math.atan2(x_46_im, x_46_re) * y_46_re)))
function code(x_46_re, x_46_im, y_46_re, y_46_im) t_0 = log(sqrt(Float64(Float64(x_46_re * x_46_re) + Float64(x_46_im * x_46_im)))) return Float64(exp(Float64(Float64(t_0 * y_46_re) - Float64(atan(x_46_im, x_46_re) * y_46_im))) * cos(Float64(Float64(t_0 * y_46_im) + Float64(atan(x_46_im, x_46_re) * y_46_re)))) end
function tmp = code(x_46_re, x_46_im, y_46_re, y_46_im) t_0 = log(sqrt(((x_46_re * x_46_re) + (x_46_im * x_46_im)))); tmp = exp(((t_0 * y_46_re) - (atan2(x_46_im, x_46_re) * y_46_im))) * cos(((t_0 * y_46_im) + (atan2(x_46_im, x_46_re) * y_46_re))); end
code[x$46$re_, x$46$im_, y$46$re_, y$46$im_] := Block[{t$95$0 = N[Log[N[Sqrt[N[(N[(x$46$re * x$46$re), $MachinePrecision] + N[(x$46$im * x$46$im), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]], $MachinePrecision]}, N[(N[Exp[N[(N[(t$95$0 * y$46$re), $MachinePrecision] - N[(N[ArcTan[x$46$im / x$46$re], $MachinePrecision] * y$46$im), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] * N[Cos[N[(N[(t$95$0 * y$46$im), $MachinePrecision] + N[(N[ArcTan[x$46$im / x$46$re], $MachinePrecision] * y$46$re), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
t_0 := \log \left(\sqrt{x.re \cdot x.re + x.im \cdot x.im}\right)\\
e^{t\_0 \cdot y.re - \tan^{-1}_* \frac{x.im}{x.re} \cdot y.im} \cdot \cos \left(t\_0 \cdot y.im + \tan^{-1}_* \frac{x.im}{x.re} \cdot y.re\right)
\end{array}
(FPCore (x.re x.im y.re y.im)
:precision binary64
(let* ((t_0 (* (atan2 x.im x.re) y.im)))
(if (<= x.im -1.86e+21)
(*
(exp (- (* (log (* -1.0 x.im)) y.re) t_0))
(sin (fma (log (- x.im)) y.im (* 0.5 PI))))
(if (<= x.im 1e-13)
(*
(/
1.0
(exp
(- (* y.im (atan2 x.im x.re)) (* (log (fabs x.re)) y.re))))
1.0)
(* (exp (- (* (* -1.0 (log (/ 1.0 x.im))) y.re) t_0)) 1.0)))))double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
double t_0 = atan2(x_46_im, x_46_re) * y_46_im;
double tmp;
if (x_46_im <= -1.86e+21) {
tmp = exp(((log((-1.0 * x_46_im)) * y_46_re) - t_0)) * sin(fma(log(-x_46_im), y_46_im, (0.5 * ((double) M_PI))));
} else if (x_46_im <= 1e-13) {
tmp = (1.0 / exp(((y_46_im * atan2(x_46_im, x_46_re)) - (log(fabs(x_46_re)) * y_46_re)))) * 1.0;
} else {
tmp = exp((((-1.0 * log((1.0 / x_46_im))) * y_46_re) - t_0)) * 1.0;
}
return tmp;
}
function code(x_46_re, x_46_im, y_46_re, y_46_im) t_0 = Float64(atan(x_46_im, x_46_re) * y_46_im) tmp = 0.0 if (x_46_im <= -1.86e+21) tmp = Float64(exp(Float64(Float64(log(Float64(-1.0 * x_46_im)) * y_46_re) - t_0)) * sin(fma(log(Float64(-x_46_im)), y_46_im, Float64(0.5 * pi)))); elseif (x_46_im <= 1e-13) tmp = Float64(Float64(1.0 / exp(Float64(Float64(y_46_im * atan(x_46_im, x_46_re)) - Float64(log(abs(x_46_re)) * y_46_re)))) * 1.0); else tmp = Float64(exp(Float64(Float64(Float64(-1.0 * log(Float64(1.0 / x_46_im))) * y_46_re) - t_0)) * 1.0); end return tmp end
code[x$46$re_, x$46$im_, y$46$re_, y$46$im_] := Block[{t$95$0 = N[(N[ArcTan[x$46$im / x$46$re], $MachinePrecision] * y$46$im), $MachinePrecision]}, If[LessEqual[x$46$im, -1.86e+21], N[(N[Exp[N[(N[(N[Log[N[(-1.0 * x$46$im), $MachinePrecision]], $MachinePrecision] * y$46$re), $MachinePrecision] - t$95$0), $MachinePrecision]], $MachinePrecision] * N[Sin[N[(N[Log[(-x$46$im)], $MachinePrecision] * y$46$im + N[(0.5 * Pi), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[LessEqual[x$46$im, 1e-13], N[(N[(1.0 / N[Exp[N[(N[(y$46$im * N[ArcTan[x$46$im / x$46$re], $MachinePrecision]), $MachinePrecision] - N[(N[Log[N[Abs[x$46$re], $MachinePrecision]], $MachinePrecision] * y$46$re), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * 1.0), $MachinePrecision], N[(N[Exp[N[(N[(N[(-1.0 * N[Log[N[(1.0 / x$46$im), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * y$46$re), $MachinePrecision] - t$95$0), $MachinePrecision]], $MachinePrecision] * 1.0), $MachinePrecision]]]]
\begin{array}{l}
t_0 := \tan^{-1}_* \frac{x.im}{x.re} \cdot y.im\\
\mathbf{if}\;x.im \leq -1.86 \cdot 10^{+21}:\\
\;\;\;\;e^{\log \left(-1 \cdot x.im\right) \cdot y.re - t\_0} \cdot \sin \left(\mathsf{fma}\left(\log \left(-x.im\right), y.im, 0.5 \cdot \pi\right)\right)\\
\mathbf{elif}\;x.im \leq 10^{-13}:\\
\;\;\;\;\frac{1}{e^{y.im \cdot \tan^{-1}_* \frac{x.im}{x.re} - \log \left(\left|x.re\right|\right) \cdot y.re}} \cdot 1\\
\mathbf{else}:\\
\;\;\;\;e^{\left(-1 \cdot \log \left(\frac{1}{x.im}\right)\right) \cdot y.re - t\_0} \cdot 1\\
\end{array}
if x.im < -1.86e21Initial program 40.1%
Taylor expanded in x.im around -inf
lower-*.f6417.7%
Applied rewrites17.7%
Taylor expanded in x.im around -inf
lower-*.f6435.6%
Applied rewrites35.6%
lift-cos.f64N/A
sin-+PI/2-revN/A
lower-sin.f64N/A
lift-+.f64N/A
associate-+l+N/A
lift-*.f64N/A
lift-*.f64N/A
*-commutativeN/A
lift-*.f64N/A
lower-fma.f64N/A
Applied rewrites35.7%
Taylor expanded in y.re around 0
lower-*.f64N/A
lower-PI.f6436.5%
Applied rewrites36.5%
if -1.86e21 < x.im < 1e-13Initial program 40.1%
Taylor expanded in y.im around 0
lower-cos.f64N/A
lower-*.f64N/A
lower-atan2.f6462.0%
Applied rewrites62.0%
Taylor expanded in y.re around 0
Applied rewrites64.0%
Taylor expanded in x.im around 0
lower-sqrt.f64N/A
lower-pow.f6455.7%
Applied rewrites55.7%
lift-exp.f64N/A
lift--.f64N/A
sub-negate-revN/A
exp-negN/A
sub-negate-revN/A
lift--.f64N/A
lower-/.f64N/A
Applied rewrites72.8%
if 1e-13 < x.im Initial program 40.1%
Taylor expanded in y.im around 0
lower-cos.f64N/A
lower-*.f64N/A
lower-atan2.f6462.0%
Applied rewrites62.0%
Taylor expanded in y.re around 0
Applied rewrites64.0%
Taylor expanded in x.im around inf
lower-*.f64N/A
lower-log.f64N/A
lower-/.f6435.8%
Applied rewrites35.8%
(FPCore (x.re x.im y.re y.im)
:precision binary64
(let* ((t_0 (* (atan2 x.im x.re) y.im)))
(if (<= x.im -1.05e+22)
(* (exp (- (* (* -1.0 (log (/ -1.0 x.im))) y.re) t_0)) 1.0)
(if (<= x.im 1e-13)
(*
(/
1.0
(exp
(- (* y.im (atan2 x.im x.re)) (* (log (fabs x.re)) y.re))))
1.0)
(* (exp (- (* (* -1.0 (log (/ 1.0 x.im))) y.re) t_0)) 1.0)))))double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
double t_0 = atan2(x_46_im, x_46_re) * y_46_im;
double tmp;
if (x_46_im <= -1.05e+22) {
tmp = exp((((-1.0 * log((-1.0 / x_46_im))) * y_46_re) - t_0)) * 1.0;
} else if (x_46_im <= 1e-13) {
tmp = (1.0 / exp(((y_46_im * atan2(x_46_im, x_46_re)) - (log(fabs(x_46_re)) * y_46_re)))) * 1.0;
} else {
tmp = exp((((-1.0 * log((1.0 / x_46_im))) * y_46_re) - t_0)) * 1.0;
}
return tmp;
}
real(8) function code(x_46re, x_46im, y_46re, y_46im)
use fmin_fmax_functions
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) :: tmp
t_0 = atan2(x_46im, x_46re) * y_46im
if (x_46im <= (-1.05d+22)) then
tmp = exp(((((-1.0d0) * log(((-1.0d0) / x_46im))) * y_46re) - t_0)) * 1.0d0
else if (x_46im <= 1d-13) then
tmp = (1.0d0 / exp(((y_46im * atan2(x_46im, x_46re)) - (log(abs(x_46re)) * y_46re)))) * 1.0d0
else
tmp = exp(((((-1.0d0) * log((1.0d0 / x_46im))) * y_46re) - t_0)) * 1.0d0
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 = Math.atan2(x_46_im, x_46_re) * y_46_im;
double tmp;
if (x_46_im <= -1.05e+22) {
tmp = Math.exp((((-1.0 * Math.log((-1.0 / x_46_im))) * y_46_re) - t_0)) * 1.0;
} else if (x_46_im <= 1e-13) {
tmp = (1.0 / Math.exp(((y_46_im * Math.atan2(x_46_im, x_46_re)) - (Math.log(Math.abs(x_46_re)) * y_46_re)))) * 1.0;
} else {
tmp = Math.exp((((-1.0 * Math.log((1.0 / x_46_im))) * y_46_re) - t_0)) * 1.0;
}
return tmp;
}
def code(x_46_re, x_46_im, y_46_re, y_46_im): t_0 = math.atan2(x_46_im, x_46_re) * y_46_im tmp = 0 if x_46_im <= -1.05e+22: tmp = math.exp((((-1.0 * math.log((-1.0 / x_46_im))) * y_46_re) - t_0)) * 1.0 elif x_46_im <= 1e-13: tmp = (1.0 / math.exp(((y_46_im * math.atan2(x_46_im, x_46_re)) - (math.log(math.fabs(x_46_re)) * y_46_re)))) * 1.0 else: tmp = math.exp((((-1.0 * math.log((1.0 / x_46_im))) * y_46_re) - t_0)) * 1.0 return tmp
function code(x_46_re, x_46_im, y_46_re, y_46_im) t_0 = Float64(atan(x_46_im, x_46_re) * y_46_im) tmp = 0.0 if (x_46_im <= -1.05e+22) tmp = Float64(exp(Float64(Float64(Float64(-1.0 * log(Float64(-1.0 / x_46_im))) * y_46_re) - t_0)) * 1.0); elseif (x_46_im <= 1e-13) tmp = Float64(Float64(1.0 / exp(Float64(Float64(y_46_im * atan(x_46_im, x_46_re)) - Float64(log(abs(x_46_re)) * y_46_re)))) * 1.0); else tmp = Float64(exp(Float64(Float64(Float64(-1.0 * log(Float64(1.0 / x_46_im))) * y_46_re) - t_0)) * 1.0); end return tmp end
function tmp_2 = code(x_46_re, x_46_im, y_46_re, y_46_im) t_0 = atan2(x_46_im, x_46_re) * y_46_im; tmp = 0.0; if (x_46_im <= -1.05e+22) tmp = exp((((-1.0 * log((-1.0 / x_46_im))) * y_46_re) - t_0)) * 1.0; elseif (x_46_im <= 1e-13) tmp = (1.0 / exp(((y_46_im * atan2(x_46_im, x_46_re)) - (log(abs(x_46_re)) * y_46_re)))) * 1.0; else tmp = exp((((-1.0 * log((1.0 / x_46_im))) * y_46_re) - t_0)) * 1.0; end tmp_2 = tmp; end
code[x$46$re_, x$46$im_, y$46$re_, y$46$im_] := Block[{t$95$0 = N[(N[ArcTan[x$46$im / x$46$re], $MachinePrecision] * y$46$im), $MachinePrecision]}, If[LessEqual[x$46$im, -1.05e+22], N[(N[Exp[N[(N[(N[(-1.0 * N[Log[N[(-1.0 / x$46$im), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * y$46$re), $MachinePrecision] - t$95$0), $MachinePrecision]], $MachinePrecision] * 1.0), $MachinePrecision], If[LessEqual[x$46$im, 1e-13], N[(N[(1.0 / N[Exp[N[(N[(y$46$im * N[ArcTan[x$46$im / x$46$re], $MachinePrecision]), $MachinePrecision] - N[(N[Log[N[Abs[x$46$re], $MachinePrecision]], $MachinePrecision] * y$46$re), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * 1.0), $MachinePrecision], N[(N[Exp[N[(N[(N[(-1.0 * N[Log[N[(1.0 / x$46$im), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * y$46$re), $MachinePrecision] - t$95$0), $MachinePrecision]], $MachinePrecision] * 1.0), $MachinePrecision]]]]
\begin{array}{l}
t_0 := \tan^{-1}_* \frac{x.im}{x.re} \cdot y.im\\
\mathbf{if}\;x.im \leq -1.05 \cdot 10^{+22}:\\
\;\;\;\;e^{\left(-1 \cdot \log \left(\frac{-1}{x.im}\right)\right) \cdot y.re - t\_0} \cdot 1\\
\mathbf{elif}\;x.im \leq 10^{-13}:\\
\;\;\;\;\frac{1}{e^{y.im \cdot \tan^{-1}_* \frac{x.im}{x.re} - \log \left(\left|x.re\right|\right) \cdot y.re}} \cdot 1\\
\mathbf{else}:\\
\;\;\;\;e^{\left(-1 \cdot \log \left(\frac{1}{x.im}\right)\right) \cdot y.re - t\_0} \cdot 1\\
\end{array}
if x.im < -1.0499999999999999e22Initial program 40.1%
Taylor expanded in y.im around 0
lower-cos.f64N/A
lower-*.f64N/A
lower-atan2.f6462.0%
Applied rewrites62.0%
Taylor expanded in y.re around 0
Applied rewrites64.0%
Taylor expanded in x.im around -inf
lower-*.f64N/A
lower-log.f64N/A
lower-/.f6436.1%
Applied rewrites36.1%
if -1.0499999999999999e22 < x.im < 1e-13Initial program 40.1%
Taylor expanded in y.im around 0
lower-cos.f64N/A
lower-*.f64N/A
lower-atan2.f6462.0%
Applied rewrites62.0%
Taylor expanded in y.re around 0
Applied rewrites64.0%
Taylor expanded in x.im around 0
lower-sqrt.f64N/A
lower-pow.f6455.7%
Applied rewrites55.7%
lift-exp.f64N/A
lift--.f64N/A
sub-negate-revN/A
exp-negN/A
sub-negate-revN/A
lift--.f64N/A
lower-/.f64N/A
Applied rewrites72.8%
if 1e-13 < x.im Initial program 40.1%
Taylor expanded in y.im around 0
lower-cos.f64N/A
lower-*.f64N/A
lower-atan2.f6462.0%
Applied rewrites62.0%
Taylor expanded in y.re around 0
Applied rewrites64.0%
Taylor expanded in x.im around inf
lower-*.f64N/A
lower-log.f64N/A
lower-/.f6435.8%
Applied rewrites35.8%
(FPCore (x.re x.im y.re y.im)
:precision binary64
(let* ((t_0 (* (atan2 x.im x.re) y.im))
(t_1 (log (hypot x.re x.im)))
(t_2 (* (atan2 x.im x.re) y.re))
(t_3 (log (sqrt (+ (* x.re x.re) (* x.im x.im)))))
(t_4 (exp (- (* t_3 y.re) t_0))))
(if (<= (* t_4 (cos (+ (* t_3 y.im) t_2))) (- INFINITY))
(* t_4 (sin (fma PI 0.5 t_2)))
(* (exp (- (* t_1 y.re) t_0)) (cos (+ (* t_1 y.im) t_2))))))double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
double t_0 = atan2(x_46_im, x_46_re) * y_46_im;
double t_1 = log(hypot(x_46_re, x_46_im));
double t_2 = atan2(x_46_im, x_46_re) * y_46_re;
double t_3 = log(sqrt(((x_46_re * x_46_re) + (x_46_im * x_46_im))));
double t_4 = exp(((t_3 * y_46_re) - t_0));
double tmp;
if ((t_4 * cos(((t_3 * y_46_im) + t_2))) <= -((double) INFINITY)) {
tmp = t_4 * sin(fma(((double) M_PI), 0.5, t_2));
} else {
tmp = exp(((t_1 * y_46_re) - t_0)) * cos(((t_1 * y_46_im) + t_2));
}
return tmp;
}
function code(x_46_re, x_46_im, y_46_re, y_46_im) t_0 = Float64(atan(x_46_im, x_46_re) * y_46_im) t_1 = log(hypot(x_46_re, x_46_im)) t_2 = Float64(atan(x_46_im, x_46_re) * y_46_re) t_3 = log(sqrt(Float64(Float64(x_46_re * x_46_re) + Float64(x_46_im * x_46_im)))) t_4 = exp(Float64(Float64(t_3 * y_46_re) - t_0)) tmp = 0.0 if (Float64(t_4 * cos(Float64(Float64(t_3 * y_46_im) + t_2))) <= Float64(-Inf)) tmp = Float64(t_4 * sin(fma(pi, 0.5, t_2))); else tmp = Float64(exp(Float64(Float64(t_1 * y_46_re) - t_0)) * cos(Float64(Float64(t_1 * y_46_im) + t_2))); end return tmp end
code[x$46$re_, x$46$im_, y$46$re_, y$46$im_] := Block[{t$95$0 = N[(N[ArcTan[x$46$im / x$46$re], $MachinePrecision] * y$46$im), $MachinePrecision]}, Block[{t$95$1 = N[Log[N[Sqrt[x$46$re ^ 2 + x$46$im ^ 2], $MachinePrecision]], $MachinePrecision]}, Block[{t$95$2 = N[(N[ArcTan[x$46$im / x$46$re], $MachinePrecision] * y$46$re), $MachinePrecision]}, Block[{t$95$3 = N[Log[N[Sqrt[N[(N[(x$46$re * x$46$re), $MachinePrecision] + N[(x$46$im * x$46$im), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]], $MachinePrecision]}, Block[{t$95$4 = N[Exp[N[(N[(t$95$3 * y$46$re), $MachinePrecision] - t$95$0), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[N[(t$95$4 * N[Cos[N[(N[(t$95$3 * y$46$im), $MachinePrecision] + t$95$2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], (-Infinity)], N[(t$95$4 * N[Sin[N[(Pi * 0.5 + t$95$2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[(N[Exp[N[(N[(t$95$1 * y$46$re), $MachinePrecision] - t$95$0), $MachinePrecision]], $MachinePrecision] * N[Cos[N[(N[(t$95$1 * y$46$im), $MachinePrecision] + t$95$2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]]]]]]
\begin{array}{l}
t_0 := \tan^{-1}_* \frac{x.im}{x.re} \cdot y.im\\
t_1 := \log \left(\mathsf{hypot}\left(x.re, x.im\right)\right)\\
t_2 := \tan^{-1}_* \frac{x.im}{x.re} \cdot y.re\\
t_3 := \log \left(\sqrt{x.re \cdot x.re + x.im \cdot x.im}\right)\\
t_4 := e^{t\_3 \cdot y.re - t\_0}\\
\mathbf{if}\;t\_4 \cdot \cos \left(t\_3 \cdot y.im + t\_2\right) \leq -\infty:\\
\;\;\;\;t\_4 \cdot \sin \left(\mathsf{fma}\left(\pi, 0.5, t\_2\right)\right)\\
\mathbf{else}:\\
\;\;\;\;e^{t\_1 \cdot y.re - t\_0} \cdot \cos \left(t\_1 \cdot y.im + t\_2\right)\\
\end{array}
if (*.f64 (exp.f64 (-.f64 (*.f64 (log.f64 (sqrt.f64 (+.f64 (*.f64 x.re x.re) (*.f64 x.im x.im)))) y.re) (*.f64 (atan2.f64 x.im x.re) y.im))) (cos.f64 (+.f64 (*.f64 (log.f64 (sqrt.f64 (+.f64 (*.f64 x.re x.re) (*.f64 x.im x.im)))) y.im) (*.f64 (atan2.f64 x.im x.re) y.re)))) < -inf.0Initial program 40.1%
Taylor expanded in y.im around 0
lower-cos.f64N/A
lower-*.f64N/A
lower-atan2.f6462.0%
Applied rewrites62.0%
lift-cos.f64N/A
sin-+PI/2-revN/A
lower-sin.f64N/A
lift-*.f64N/A
*-commutativeN/A
lift-*.f64N/A
+-commutativeN/A
mult-flipN/A
metadata-evalN/A
lower-fma.f64N/A
lower-PI.f6462.0%
Applied rewrites62.0%
if -inf.0 < (*.f64 (exp.f64 (-.f64 (*.f64 (log.f64 (sqrt.f64 (+.f64 (*.f64 x.re x.re) (*.f64 x.im x.im)))) y.re) (*.f64 (atan2.f64 x.im x.re) y.im))) (cos.f64 (+.f64 (*.f64 (log.f64 (sqrt.f64 (+.f64 (*.f64 x.re x.re) (*.f64 x.im x.im)))) y.im) (*.f64 (atan2.f64 x.im x.re) y.re)))) Initial program 40.1%
lift-sqrt.f64N/A
lift-+.f64N/A
lift-*.f64N/A
lift-*.f64N/A
lower-hypot.f6440.1%
Applied rewrites40.1%
lift-sqrt.f64N/A
lift-+.f64N/A
lift-*.f64N/A
lift-*.f64N/A
lower-hypot.f6480.0%
Applied rewrites80.0%
(FPCore (x.re x.im y.re y.im)
:precision binary64
(if (<= x.im -1.05e+22)
(*
(exp
(-
(* (* -1.0 (log (/ -1.0 x.im))) y.re)
(* (atan2 x.im x.re) y.im)))
1.0)
(*
(/
1.0
(exp (- (* y.im (atan2 x.im x.re)) (* (log (fabs x.re)) y.re))))
1.0)))double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
double tmp;
if (x_46_im <= -1.05e+22) {
tmp = exp((((-1.0 * log((-1.0 / x_46_im))) * y_46_re) - (atan2(x_46_im, x_46_re) * y_46_im))) * 1.0;
} else {
tmp = (1.0 / exp(((y_46_im * atan2(x_46_im, x_46_re)) - (log(fabs(x_46_re)) * y_46_re)))) * 1.0;
}
return tmp;
}
real(8) function code(x_46re, x_46im, y_46re, y_46im)
use fmin_fmax_functions
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 (x_46im <= (-1.05d+22)) then
tmp = exp(((((-1.0d0) * log(((-1.0d0) / x_46im))) * y_46re) - (atan2(x_46im, x_46re) * y_46im))) * 1.0d0
else
tmp = (1.0d0 / exp(((y_46im * atan2(x_46im, x_46re)) - (log(abs(x_46re)) * y_46re)))) * 1.0d0
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 (x_46_im <= -1.05e+22) {
tmp = Math.exp((((-1.0 * Math.log((-1.0 / x_46_im))) * y_46_re) - (Math.atan2(x_46_im, x_46_re) * y_46_im))) * 1.0;
} else {
tmp = (1.0 / Math.exp(((y_46_im * Math.atan2(x_46_im, x_46_re)) - (Math.log(Math.abs(x_46_re)) * y_46_re)))) * 1.0;
}
return tmp;
}
def code(x_46_re, x_46_im, y_46_re, y_46_im): tmp = 0 if x_46_im <= -1.05e+22: tmp = math.exp((((-1.0 * math.log((-1.0 / x_46_im))) * y_46_re) - (math.atan2(x_46_im, x_46_re) * y_46_im))) * 1.0 else: tmp = (1.0 / math.exp(((y_46_im * math.atan2(x_46_im, x_46_re)) - (math.log(math.fabs(x_46_re)) * y_46_re)))) * 1.0 return tmp
function code(x_46_re, x_46_im, y_46_re, y_46_im) tmp = 0.0 if (x_46_im <= -1.05e+22) tmp = Float64(exp(Float64(Float64(Float64(-1.0 * log(Float64(-1.0 / x_46_im))) * y_46_re) - Float64(atan(x_46_im, x_46_re) * y_46_im))) * 1.0); else tmp = Float64(Float64(1.0 / exp(Float64(Float64(y_46_im * atan(x_46_im, x_46_re)) - Float64(log(abs(x_46_re)) * y_46_re)))) * 1.0); end return tmp end
function tmp_2 = code(x_46_re, x_46_im, y_46_re, y_46_im) tmp = 0.0; if (x_46_im <= -1.05e+22) tmp = exp((((-1.0 * log((-1.0 / x_46_im))) * y_46_re) - (atan2(x_46_im, x_46_re) * y_46_im))) * 1.0; else tmp = (1.0 / exp(((y_46_im * atan2(x_46_im, x_46_re)) - (log(abs(x_46_re)) * y_46_re)))) * 1.0; end tmp_2 = tmp; end
code[x$46$re_, x$46$im_, y$46$re_, y$46$im_] := If[LessEqual[x$46$im, -1.05e+22], N[(N[Exp[N[(N[(N[(-1.0 * N[Log[N[(-1.0 / x$46$im), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * y$46$re), $MachinePrecision] - N[(N[ArcTan[x$46$im / x$46$re], $MachinePrecision] * y$46$im), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] * 1.0), $MachinePrecision], N[(N[(1.0 / N[Exp[N[(N[(y$46$im * N[ArcTan[x$46$im / x$46$re], $MachinePrecision]), $MachinePrecision] - N[(N[Log[N[Abs[x$46$re], $MachinePrecision]], $MachinePrecision] * y$46$re), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * 1.0), $MachinePrecision]]
\begin{array}{l}
\mathbf{if}\;x.im \leq -1.05 \cdot 10^{+22}:\\
\;\;\;\;e^{\left(-1 \cdot \log \left(\frac{-1}{x.im}\right)\right) \cdot y.re - \tan^{-1}_* \frac{x.im}{x.re} \cdot y.im} \cdot 1\\
\mathbf{else}:\\
\;\;\;\;\frac{1}{e^{y.im \cdot \tan^{-1}_* \frac{x.im}{x.re} - \log \left(\left|x.re\right|\right) \cdot y.re}} \cdot 1\\
\end{array}
if x.im < -1.0499999999999999e22Initial program 40.1%
Taylor expanded in y.im around 0
lower-cos.f64N/A
lower-*.f64N/A
lower-atan2.f6462.0%
Applied rewrites62.0%
Taylor expanded in y.re around 0
Applied rewrites64.0%
Taylor expanded in x.im around -inf
lower-*.f64N/A
lower-log.f64N/A
lower-/.f6436.1%
Applied rewrites36.1%
if -1.0499999999999999e22 < x.im Initial program 40.1%
Taylor expanded in y.im around 0
lower-cos.f64N/A
lower-*.f64N/A
lower-atan2.f6462.0%
Applied rewrites62.0%
Taylor expanded in y.re around 0
Applied rewrites64.0%
Taylor expanded in x.im around 0
lower-sqrt.f64N/A
lower-pow.f6455.7%
Applied rewrites55.7%
lift-exp.f64N/A
lift--.f64N/A
sub-negate-revN/A
exp-negN/A
sub-negate-revN/A
lift--.f64N/A
lower-/.f64N/A
Applied rewrites72.8%
(FPCore (x.re x.im y.re y.im) :precision binary64 (* (/ 1.0 (exp (- (* y.im (atan2 x.im x.re)) (* (log (fabs x.re)) y.re)))) 1.0))
double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
return (1.0 / exp(((y_46_im * atan2(x_46_im, x_46_re)) - (log(fabs(x_46_re)) * y_46_re)))) * 1.0;
}
real(8) function code(x_46re, x_46im, y_46re, y_46im)
use fmin_fmax_functions
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 = (1.0d0 / exp(((y_46im * atan2(x_46im, x_46re)) - (log(abs(x_46re)) * y_46re)))) * 1.0d0
end function
public static double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
return (1.0 / Math.exp(((y_46_im * Math.atan2(x_46_im, x_46_re)) - (Math.log(Math.abs(x_46_re)) * y_46_re)))) * 1.0;
}
def code(x_46_re, x_46_im, y_46_re, y_46_im): return (1.0 / math.exp(((y_46_im * math.atan2(x_46_im, x_46_re)) - (math.log(math.fabs(x_46_re)) * y_46_re)))) * 1.0
function code(x_46_re, x_46_im, y_46_re, y_46_im) return Float64(Float64(1.0 / exp(Float64(Float64(y_46_im * atan(x_46_im, x_46_re)) - Float64(log(abs(x_46_re)) * y_46_re)))) * 1.0) end
function tmp = code(x_46_re, x_46_im, y_46_re, y_46_im) tmp = (1.0 / exp(((y_46_im * atan2(x_46_im, x_46_re)) - (log(abs(x_46_re)) * y_46_re)))) * 1.0; end
code[x$46$re_, x$46$im_, y$46$re_, y$46$im_] := N[(N[(1.0 / N[Exp[N[(N[(y$46$im * N[ArcTan[x$46$im / x$46$re], $MachinePrecision]), $MachinePrecision] - N[(N[Log[N[Abs[x$46$re], $MachinePrecision]], $MachinePrecision] * y$46$re), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * 1.0), $MachinePrecision]
\frac{1}{e^{y.im \cdot \tan^{-1}_* \frac{x.im}{x.re} - \log \left(\left|x.re\right|\right) \cdot y.re}} \cdot 1
Initial program 40.1%
Taylor expanded in y.im around 0
lower-cos.f64N/A
lower-*.f64N/A
lower-atan2.f6462.0%
Applied rewrites62.0%
Taylor expanded in y.re around 0
Applied rewrites64.0%
Taylor expanded in x.im around 0
lower-sqrt.f64N/A
lower-pow.f6455.7%
Applied rewrites55.7%
lift-exp.f64N/A
lift--.f64N/A
sub-negate-revN/A
exp-negN/A
sub-negate-revN/A
lift--.f64N/A
lower-/.f64N/A
Applied rewrites72.8%
(FPCore (x.re x.im y.re y.im) :precision binary64 (* (exp (- (* (log (fabs x.re)) y.re) (* (atan2 x.im x.re) y.im))) 1.0))
double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
return exp(((log(fabs(x_46_re)) * y_46_re) - (atan2(x_46_im, x_46_re) * y_46_im))) * 1.0;
}
real(8) function code(x_46re, x_46im, y_46re, y_46im)
use fmin_fmax_functions
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 = exp(((log(abs(x_46re)) * y_46re) - (atan2(x_46im, x_46re) * y_46im))) * 1.0d0
end function
public static double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
return Math.exp(((Math.log(Math.abs(x_46_re)) * y_46_re) - (Math.atan2(x_46_im, x_46_re) * y_46_im))) * 1.0;
}
def code(x_46_re, x_46_im, y_46_re, y_46_im): return math.exp(((math.log(math.fabs(x_46_re)) * y_46_re) - (math.atan2(x_46_im, x_46_re) * y_46_im))) * 1.0
function code(x_46_re, x_46_im, y_46_re, y_46_im) return Float64(exp(Float64(Float64(log(abs(x_46_re)) * y_46_re) - Float64(atan(x_46_im, x_46_re) * y_46_im))) * 1.0) end
function tmp = code(x_46_re, x_46_im, y_46_re, y_46_im) tmp = exp(((log(abs(x_46_re)) * y_46_re) - (atan2(x_46_im, x_46_re) * y_46_im))) * 1.0; end
code[x$46$re_, x$46$im_, y$46$re_, y$46$im_] := N[(N[Exp[N[(N[(N[Log[N[Abs[x$46$re], $MachinePrecision]], $MachinePrecision] * y$46$re), $MachinePrecision] - N[(N[ArcTan[x$46$im / x$46$re], $MachinePrecision] * y$46$im), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] * 1.0), $MachinePrecision]
e^{\log \left(\left|x.re\right|\right) \cdot y.re - \tan^{-1}_* \frac{x.im}{x.re} \cdot y.im} \cdot 1
Initial program 40.1%
Taylor expanded in y.im around 0
lower-cos.f64N/A
lower-*.f64N/A
lower-atan2.f6462.0%
Applied rewrites62.0%
Taylor expanded in y.re around 0
Applied rewrites64.0%
Taylor expanded in x.im around 0
lower-sqrt.f64N/A
lower-pow.f6455.7%
Applied rewrites55.7%
lift-sqrt.f64N/A
lift-pow.f64N/A
pow2N/A
rem-sqrt-square-revN/A
lower-fabs.f6472.8%
Applied rewrites72.8%
(FPCore (x.re x.im y.re y.im) :precision binary64 (* (exp (- (* y.im (atan2 x.im 0.0)))) 1.0))
double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
return exp(-(y_46_im * atan2(x_46_im, 0.0))) * 1.0;
}
real(8) function code(x_46re, x_46im, y_46re, y_46im)
use fmin_fmax_functions
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 = exp(-(y_46im * atan2(x_46im, 0.0d0))) * 1.0d0
end function
public static double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
return Math.exp(-(y_46_im * Math.atan2(x_46_im, 0.0))) * 1.0;
}
def code(x_46_re, x_46_im, y_46_re, y_46_im): return math.exp(-(y_46_im * math.atan2(x_46_im, 0.0))) * 1.0
function code(x_46_re, x_46_im, y_46_re, y_46_im) return Float64(exp(Float64(-Float64(y_46_im * atan(x_46_im, 0.0)))) * 1.0) end
function tmp = code(x_46_re, x_46_im, y_46_re, y_46_im) tmp = exp(-(y_46_im * atan2(x_46_im, 0.0))) * 1.0; end
code[x$46$re_, x$46$im_, y$46$re_, y$46$im_] := N[(N[Exp[(-N[(y$46$im * N[ArcTan[x$46$im / 0.0], $MachinePrecision]), $MachinePrecision])], $MachinePrecision] * 1.0), $MachinePrecision]
e^{-y.im \cdot \tan^{-1}_* \frac{x.im}{0}} \cdot 1
Initial program 40.1%
Taylor expanded in y.im around 0
lower-cos.f64N/A
lower-*.f64N/A
lower-atan2.f6462.0%
Applied rewrites62.0%
Taylor expanded in y.re around 0
lower-exp.f64N/A
lower-neg.f64N/A
lower-*.f64N/A
lower-atan2.f6453.4%
Applied rewrites53.4%
Taylor expanded in y.re around 0
Applied rewrites53.3%
Taylor expanded in undef-var around zero
Applied rewrites54.5%
(FPCore (x.re x.im y.re y.im) :precision binary64 (* (exp (- (* y.im (atan2 x.im x.re)))) 1.0))
double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
return exp(-(y_46_im * atan2(x_46_im, x_46_re))) * 1.0;
}
real(8) function code(x_46re, x_46im, y_46re, y_46im)
use fmin_fmax_functions
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 = exp(-(y_46im * atan2(x_46im, x_46re))) * 1.0d0
end function
public static double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
return Math.exp(-(y_46_im * Math.atan2(x_46_im, x_46_re))) * 1.0;
}
def code(x_46_re, x_46_im, y_46_re, y_46_im): return math.exp(-(y_46_im * math.atan2(x_46_im, x_46_re))) * 1.0
function code(x_46_re, x_46_im, y_46_re, y_46_im) return Float64(exp(Float64(-Float64(y_46_im * atan(x_46_im, x_46_re)))) * 1.0) end
function tmp = code(x_46_re, x_46_im, y_46_re, y_46_im) tmp = exp(-(y_46_im * atan2(x_46_im, x_46_re))) * 1.0; end
code[x$46$re_, x$46$im_, y$46$re_, y$46$im_] := N[(N[Exp[(-N[(y$46$im * N[ArcTan[x$46$im / x$46$re], $MachinePrecision]), $MachinePrecision])], $MachinePrecision] * 1.0), $MachinePrecision]
e^{-y.im \cdot \tan^{-1}_* \frac{x.im}{x.re}} \cdot 1
Initial program 40.1%
Taylor expanded in y.im around 0
lower-cos.f64N/A
lower-*.f64N/A
lower-atan2.f6462.0%
Applied rewrites62.0%
Taylor expanded in y.re around 0
lower-exp.f64N/A
lower-neg.f64N/A
lower-*.f64N/A
lower-atan2.f6453.4%
Applied rewrites53.4%
Taylor expanded in y.re around 0
Applied rewrites53.3%
(FPCore (x.re x.im y.re y.im) :precision binary64 (* (+ 1.0 (* -1.0 (* y.im (atan2 x.im x.re)))) 1.0))
double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
return (1.0 + (-1.0 * (y_46_im * atan2(x_46_im, x_46_re)))) * 1.0;
}
real(8) function code(x_46re, x_46im, y_46re, y_46im)
use fmin_fmax_functions
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 = (1.0d0 + ((-1.0d0) * (y_46im * atan2(x_46im, x_46re)))) * 1.0d0
end function
public static double code(double x_46_re, double x_46_im, double y_46_re, double y_46_im) {
return (1.0 + (-1.0 * (y_46_im * Math.atan2(x_46_im, x_46_re)))) * 1.0;
}
def code(x_46_re, x_46_im, y_46_re, y_46_im): return (1.0 + (-1.0 * (y_46_im * math.atan2(x_46_im, x_46_re)))) * 1.0
function code(x_46_re, x_46_im, y_46_re, y_46_im) return Float64(Float64(1.0 + Float64(-1.0 * Float64(y_46_im * atan(x_46_im, x_46_re)))) * 1.0) end
function tmp = code(x_46_re, x_46_im, y_46_re, y_46_im) tmp = (1.0 + (-1.0 * (y_46_im * atan2(x_46_im, x_46_re)))) * 1.0; end
code[x$46$re_, x$46$im_, y$46$re_, y$46$im_] := N[(N[(1.0 + N[(-1.0 * N[(y$46$im * N[ArcTan[x$46$im / x$46$re], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * 1.0), $MachinePrecision]
\left(1 + -1 \cdot \left(y.im \cdot \tan^{-1}_* \frac{x.im}{x.re}\right)\right) \cdot 1
Initial program 40.1%
Taylor expanded in y.im around 0
lower-cos.f64N/A
lower-*.f64N/A
lower-atan2.f6462.0%
Applied rewrites62.0%
Taylor expanded in y.re around 0
lower-exp.f64N/A
lower-neg.f64N/A
lower-*.f64N/A
lower-atan2.f6453.4%
Applied rewrites53.4%
Taylor expanded in y.re around 0
Applied rewrites53.3%
Taylor expanded in y.im around 0
lower-+.f64N/A
lower-*.f64N/A
lower-*.f64N/A
lower-atan2.f6426.8%
Applied rewrites26.8%
herbie shell --seed 2025313 -o setup:search
(FPCore (x.re x.im y.re y.im)
:name "powComplex, real part"
:precision binary64
(* (exp (- (* (log (sqrt (+ (* x.re x.re) (* x.im x.im)))) y.re) (* (atan2 x.im x.re) y.im))) (cos (+ (* (log (sqrt (+ (* x.re x.re) (* x.im x.im)))) y.im) (* (atan2 x.im x.re) y.re)))))