
(FPCore (kx ky th) :precision binary64 (* (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))) (sin th)))
double code(double kx, double ky, double th) {
return (sin(ky) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)))) * sin(th);
}
real(8) function code(kx, ky, th)
real(8), intent (in) :: kx
real(8), intent (in) :: ky
real(8), intent (in) :: th
code = (sin(ky) / sqrt(((sin(kx) ** 2.0d0) + (sin(ky) ** 2.0d0)))) * sin(th)
end function
public static double code(double kx, double ky, double th) {
return (Math.sin(ky) / Math.sqrt((Math.pow(Math.sin(kx), 2.0) + Math.pow(Math.sin(ky), 2.0)))) * Math.sin(th);
}
def code(kx, ky, th): return (math.sin(ky) / math.sqrt((math.pow(math.sin(kx), 2.0) + math.pow(math.sin(ky), 2.0)))) * math.sin(th)
function code(kx, ky, th) return Float64(Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) * sin(th)) end
function tmp = code(kx, ky, th) tmp = (sin(ky) / sqrt(((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) * sin(th); end
code[kx_, ky_, th_] := N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}} \cdot \sin th
\end{array}
Sampling outcomes in binary64 precision:
Herbie found 31 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (kx ky th) :precision binary64 (* (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))) (sin th)))
double code(double kx, double ky, double th) {
return (sin(ky) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)))) * sin(th);
}
real(8) function code(kx, ky, th)
real(8), intent (in) :: kx
real(8), intent (in) :: ky
real(8), intent (in) :: th
code = (sin(ky) / sqrt(((sin(kx) ** 2.0d0) + (sin(ky) ** 2.0d0)))) * sin(th)
end function
public static double code(double kx, double ky, double th) {
return (Math.sin(ky) / Math.sqrt((Math.pow(Math.sin(kx), 2.0) + Math.pow(Math.sin(ky), 2.0)))) * Math.sin(th);
}
def code(kx, ky, th): return (math.sin(ky) / math.sqrt((math.pow(math.sin(kx), 2.0) + math.pow(math.sin(ky), 2.0)))) * math.sin(th)
function code(kx, ky, th) return Float64(Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) * sin(th)) end
function tmp = code(kx, ky, th) tmp = (sin(ky) / sqrt(((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) * sin(th); end
code[kx_, ky_, th_] := N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}} \cdot \sin th
\end{array}
(FPCore (kx ky th) :precision binary64 (/ (sin th) (/ (hypot (sin ky) (sin kx)) (sin ky))))
double code(double kx, double ky, double th) {
return sin(th) / (hypot(sin(ky), sin(kx)) / sin(ky));
}
public static double code(double kx, double ky, double th) {
return Math.sin(th) / (Math.hypot(Math.sin(ky), Math.sin(kx)) / Math.sin(ky));
}
def code(kx, ky, th): return math.sin(th) / (math.hypot(math.sin(ky), math.sin(kx)) / math.sin(ky))
function code(kx, ky, th) return Float64(sin(th) / Float64(hypot(sin(ky), sin(kx)) / sin(ky))) end
function tmp = code(kx, ky, th) tmp = sin(th) / (hypot(sin(ky), sin(kx)) / sin(ky)); end
code[kx_, ky_, th_] := N[(N[Sin[th], $MachinePrecision] / N[(N[Sqrt[N[Sin[ky], $MachinePrecision] ^ 2 + N[Sin[kx], $MachinePrecision] ^ 2], $MachinePrecision] / N[Sin[ky], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\frac{\sin th}{\frac{\mathsf{hypot}\left(\sin ky, \sin kx\right)}{\sin ky}}
\end{array}
Initial program 96.6%
lift-*.f64N/A
*-commutativeN/A
lift-/.f64N/A
clear-numN/A
un-div-invN/A
lower-/.f64N/A
lower-/.f6496.6
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-pow.f64N/A
unpow2N/A
lower-hypot.f6499.6
Applied rewrites99.6%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (pow (sin ky) 2.0))
(t_2 (pow (sin kx) 2.0))
(t_3 (/ (sin ky) (sqrt (+ t_2 t_1))))
(t_4
(pow
(/
(*
(fma (* th th) 0.16666666666666666 1.0)
(/ (hypot (sin kx) (sin ky)) (sin ky)))
th)
-1.0)))
(if (<= t_3 -0.998)
(* (/ (sin ky) (sqrt (+ (* kx kx) t_1))) (sin th))
(if (<= t_3 -0.2)
t_4
(if (<= t_3 0.001)
(* (/ (sin ky) (sqrt (+ t_2 (* ky ky)))) (sin th))
(if (<= t_3 0.96) t_4 (sin th)))))))
double code(double kx, double ky, double th) {
double t_1 = pow(sin(ky), 2.0);
double t_2 = pow(sin(kx), 2.0);
double t_3 = sin(ky) / sqrt((t_2 + t_1));
double t_4 = pow(((fma((th * th), 0.16666666666666666, 1.0) * (hypot(sin(kx), sin(ky)) / sin(ky))) / th), -1.0);
double tmp;
if (t_3 <= -0.998) {
tmp = (sin(ky) / sqrt(((kx * kx) + t_1))) * sin(th);
} else if (t_3 <= -0.2) {
tmp = t_4;
} else if (t_3 <= 0.001) {
tmp = (sin(ky) / sqrt((t_2 + (ky * ky)))) * sin(th);
} else if (t_3 <= 0.96) {
tmp = t_4;
} else {
tmp = sin(th);
}
return tmp;
}
function code(kx, ky, th) t_1 = sin(ky) ^ 2.0 t_2 = sin(kx) ^ 2.0 t_3 = Float64(sin(ky) / sqrt(Float64(t_2 + t_1))) t_4 = Float64(Float64(fma(Float64(th * th), 0.16666666666666666, 1.0) * Float64(hypot(sin(kx), sin(ky)) / sin(ky))) / th) ^ -1.0 tmp = 0.0 if (t_3 <= -0.998) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(kx * kx) + t_1))) * sin(th)); elseif (t_3 <= -0.2) tmp = t_4; elseif (t_3 <= 0.001) tmp = Float64(Float64(sin(ky) / sqrt(Float64(t_2 + Float64(ky * ky)))) * sin(th)); elseif (t_3 <= 0.96) tmp = t_4; else tmp = sin(th); end return tmp end
code[kx_, ky_, th_] := Block[{t$95$1 = N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]}, Block[{t$95$2 = N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision]}, Block[{t$95$3 = N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(t$95$2 + t$95$1), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$4 = N[Power[N[(N[(N[(N[(th * th), $MachinePrecision] * 0.16666666666666666 + 1.0), $MachinePrecision] * N[(N[Sqrt[N[Sin[kx], $MachinePrecision] ^ 2 + N[Sin[ky], $MachinePrecision] ^ 2], $MachinePrecision] / N[Sin[ky], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / th), $MachinePrecision], -1.0], $MachinePrecision]}, If[LessEqual[t$95$3, -0.998], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[(kx * kx), $MachinePrecision] + t$95$1), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$3, -0.2], t$95$4, If[LessEqual[t$95$3, 0.001], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(t$95$2 + N[(ky * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$3, 0.96], t$95$4, N[Sin[th], $MachinePrecision]]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := {\sin ky}^{2}\\
t_2 := {\sin kx}^{2}\\
t_3 := \frac{\sin ky}{\sqrt{t\_2 + t\_1}}\\
t_4 := {\left(\frac{\mathsf{fma}\left(th \cdot th, 0.16666666666666666, 1\right) \cdot \frac{\mathsf{hypot}\left(\sin kx, \sin ky\right)}{\sin ky}}{th}\right)}^{-1}\\
\mathbf{if}\;t\_3 \leq -0.998:\\
\;\;\;\;\frac{\sin ky}{\sqrt{kx \cdot kx + t\_1}} \cdot \sin th\\
\mathbf{elif}\;t\_3 \leq -0.2:\\
\;\;\;\;t\_4\\
\mathbf{elif}\;t\_3 \leq 0.001:\\
\;\;\;\;\frac{\sin ky}{\sqrt{t\_2 + ky \cdot ky}} \cdot \sin th\\
\mathbf{elif}\;t\_3 \leq 0.96:\\
\;\;\;\;t\_4\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\end{array}
if (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.998Initial program 88.9%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f6488.9
Applied rewrites88.9%
if -0.998 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.20000000000000001 or 1e-3 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.95999999999999996Initial program 99.3%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
clear-numN/A
lower-/.f64N/A
associate-/r*N/A
lower-/.f64N/A
Applied rewrites99.2%
Taylor expanded in th around 0
Applied rewrites47.0%
if -0.20000000000000001 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 1e-3Initial program 99.5%
Taylor expanded in ky around 0
unpow2N/A
lower-*.f6497.3
Applied rewrites97.3%
if 0.95999999999999996 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) Initial program 94.1%
Taylor expanded in kx around 0
lower-sin.f6492.4
Applied rewrites92.4%
Final simplification79.2%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (pow (sin ky) 2.0))
(t_2 (pow (sin kx) 2.0))
(t_3 (/ (sin ky) (sqrt (+ t_2 t_1))))
(t_4 (/ (* (sin ky) th) (hypot (sin ky) (sin kx)))))
(if (<= t_3 -0.9995)
(* (/ (sin ky) (sqrt (+ (* kx kx) t_1))) (sin th))
(if (<= t_3 -0.2)
t_4
(if (<= t_3 0.06)
(* (/ (sin ky) (sqrt (+ t_2 (* ky ky)))) (sin th))
(if (<= t_3 0.96) t_4 (sin th)))))))
double code(double kx, double ky, double th) {
double t_1 = pow(sin(ky), 2.0);
double t_2 = pow(sin(kx), 2.0);
double t_3 = sin(ky) / sqrt((t_2 + t_1));
double t_4 = (sin(ky) * th) / hypot(sin(ky), sin(kx));
double tmp;
if (t_3 <= -0.9995) {
tmp = (sin(ky) / sqrt(((kx * kx) + t_1))) * sin(th);
} else if (t_3 <= -0.2) {
tmp = t_4;
} else if (t_3 <= 0.06) {
tmp = (sin(ky) / sqrt((t_2 + (ky * ky)))) * sin(th);
} else if (t_3 <= 0.96) {
tmp = t_4;
} else {
tmp = sin(th);
}
return tmp;
}
public static double code(double kx, double ky, double th) {
double t_1 = Math.pow(Math.sin(ky), 2.0);
double t_2 = Math.pow(Math.sin(kx), 2.0);
double t_3 = Math.sin(ky) / Math.sqrt((t_2 + t_1));
double t_4 = (Math.sin(ky) * th) / Math.hypot(Math.sin(ky), Math.sin(kx));
double tmp;
if (t_3 <= -0.9995) {
tmp = (Math.sin(ky) / Math.sqrt(((kx * kx) + t_1))) * Math.sin(th);
} else if (t_3 <= -0.2) {
tmp = t_4;
} else if (t_3 <= 0.06) {
tmp = (Math.sin(ky) / Math.sqrt((t_2 + (ky * ky)))) * Math.sin(th);
} else if (t_3 <= 0.96) {
tmp = t_4;
} else {
tmp = Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): t_1 = math.pow(math.sin(ky), 2.0) t_2 = math.pow(math.sin(kx), 2.0) t_3 = math.sin(ky) / math.sqrt((t_2 + t_1)) t_4 = (math.sin(ky) * th) / math.hypot(math.sin(ky), math.sin(kx)) tmp = 0 if t_3 <= -0.9995: tmp = (math.sin(ky) / math.sqrt(((kx * kx) + t_1))) * math.sin(th) elif t_3 <= -0.2: tmp = t_4 elif t_3 <= 0.06: tmp = (math.sin(ky) / math.sqrt((t_2 + (ky * ky)))) * math.sin(th) elif t_3 <= 0.96: tmp = t_4 else: tmp = math.sin(th) return tmp
function code(kx, ky, th) t_1 = sin(ky) ^ 2.0 t_2 = sin(kx) ^ 2.0 t_3 = Float64(sin(ky) / sqrt(Float64(t_2 + t_1))) t_4 = Float64(Float64(sin(ky) * th) / hypot(sin(ky), sin(kx))) tmp = 0.0 if (t_3 <= -0.9995) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(kx * kx) + t_1))) * sin(th)); elseif (t_3 <= -0.2) tmp = t_4; elseif (t_3 <= 0.06) tmp = Float64(Float64(sin(ky) / sqrt(Float64(t_2 + Float64(ky * ky)))) * sin(th)); elseif (t_3 <= 0.96) tmp = t_4; else tmp = sin(th); end return tmp end
function tmp_2 = code(kx, ky, th) t_1 = sin(ky) ^ 2.0; t_2 = sin(kx) ^ 2.0; t_3 = sin(ky) / sqrt((t_2 + t_1)); t_4 = (sin(ky) * th) / hypot(sin(ky), sin(kx)); tmp = 0.0; if (t_3 <= -0.9995) tmp = (sin(ky) / sqrt(((kx * kx) + t_1))) * sin(th); elseif (t_3 <= -0.2) tmp = t_4; elseif (t_3 <= 0.06) tmp = (sin(ky) / sqrt((t_2 + (ky * ky)))) * sin(th); elseif (t_3 <= 0.96) tmp = t_4; else tmp = sin(th); end tmp_2 = tmp; end
code[kx_, ky_, th_] := Block[{t$95$1 = N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]}, Block[{t$95$2 = N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision]}, Block[{t$95$3 = N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(t$95$2 + t$95$1), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$4 = N[(N[(N[Sin[ky], $MachinePrecision] * th), $MachinePrecision] / N[Sqrt[N[Sin[ky], $MachinePrecision] ^ 2 + N[Sin[kx], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$3, -0.9995], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[(kx * kx), $MachinePrecision] + t$95$1), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$3, -0.2], t$95$4, If[LessEqual[t$95$3, 0.06], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(t$95$2 + N[(ky * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$3, 0.96], t$95$4, N[Sin[th], $MachinePrecision]]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := {\sin ky}^{2}\\
t_2 := {\sin kx}^{2}\\
t_3 := \frac{\sin ky}{\sqrt{t\_2 + t\_1}}\\
t_4 := \frac{\sin ky \cdot th}{\mathsf{hypot}\left(\sin ky, \sin kx\right)}\\
\mathbf{if}\;t\_3 \leq -0.9995:\\
\;\;\;\;\frac{\sin ky}{\sqrt{kx \cdot kx + t\_1}} \cdot \sin th\\
\mathbf{elif}\;t\_3 \leq -0.2:\\
\;\;\;\;t\_4\\
\mathbf{elif}\;t\_3 \leq 0.06:\\
\;\;\;\;\frac{\sin ky}{\sqrt{t\_2 + ky \cdot ky}} \cdot \sin th\\
\mathbf{elif}\;t\_3 \leq 0.96:\\
\;\;\;\;t\_4\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\end{array}
if (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.99950000000000006Initial program 88.9%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f6488.9
Applied rewrites88.9%
if -0.99950000000000006 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.20000000000000001 or 0.059999999999999998 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.95999999999999996Initial program 99.3%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
lower-/.f64N/A
*-commutativeN/A
lower-*.f6499.3
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-pow.f64N/A
unpow2N/A
lower-hypot.f6499.3
Applied rewrites99.3%
Taylor expanded in th around 0
*-commutativeN/A
lower-*.f64N/A
lower-sin.f6446.2
Applied rewrites46.2%
if -0.20000000000000001 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.059999999999999998Initial program 99.5%
Taylor expanded in ky around 0
unpow2N/A
lower-*.f6496.2
Applied rewrites96.2%
if 0.95999999999999996 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) Initial program 94.1%
Taylor expanded in kx around 0
lower-sin.f6492.4
Applied rewrites92.4%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (/ (* (sin ky) th) (hypot (sin ky) (sin kx))))
(t_2 (pow (sin ky) 2.0))
(t_3 (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) t_2)))))
(if (<= t_3 -0.9995)
(* (/ (sin ky) (sqrt (+ (* kx kx) t_2))) (sin th))
(if (<= t_3 -0.05)
t_1
(if (<= t_3 0.06)
(* (/ -1.0 (* (/ -1.0 ky) (hypot (sin kx) (sin ky)))) (sin th))
(if (<= t_3 0.96) t_1 (sin th)))))))
double code(double kx, double ky, double th) {
double t_1 = (sin(ky) * th) / hypot(sin(ky), sin(kx));
double t_2 = pow(sin(ky), 2.0);
double t_3 = sin(ky) / sqrt((pow(sin(kx), 2.0) + t_2));
double tmp;
if (t_3 <= -0.9995) {
tmp = (sin(ky) / sqrt(((kx * kx) + t_2))) * sin(th);
} else if (t_3 <= -0.05) {
tmp = t_1;
} else if (t_3 <= 0.06) {
tmp = (-1.0 / ((-1.0 / ky) * hypot(sin(kx), sin(ky)))) * sin(th);
} else if (t_3 <= 0.96) {
tmp = t_1;
} else {
tmp = sin(th);
}
return tmp;
}
public static double code(double kx, double ky, double th) {
double t_1 = (Math.sin(ky) * th) / Math.hypot(Math.sin(ky), Math.sin(kx));
double t_2 = Math.pow(Math.sin(ky), 2.0);
double t_3 = Math.sin(ky) / Math.sqrt((Math.pow(Math.sin(kx), 2.0) + t_2));
double tmp;
if (t_3 <= -0.9995) {
tmp = (Math.sin(ky) / Math.sqrt(((kx * kx) + t_2))) * Math.sin(th);
} else if (t_3 <= -0.05) {
tmp = t_1;
} else if (t_3 <= 0.06) {
tmp = (-1.0 / ((-1.0 / ky) * Math.hypot(Math.sin(kx), Math.sin(ky)))) * Math.sin(th);
} else if (t_3 <= 0.96) {
tmp = t_1;
} else {
tmp = Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): t_1 = (math.sin(ky) * th) / math.hypot(math.sin(ky), math.sin(kx)) t_2 = math.pow(math.sin(ky), 2.0) t_3 = math.sin(ky) / math.sqrt((math.pow(math.sin(kx), 2.0) + t_2)) tmp = 0 if t_3 <= -0.9995: tmp = (math.sin(ky) / math.sqrt(((kx * kx) + t_2))) * math.sin(th) elif t_3 <= -0.05: tmp = t_1 elif t_3 <= 0.06: tmp = (-1.0 / ((-1.0 / ky) * math.hypot(math.sin(kx), math.sin(ky)))) * math.sin(th) elif t_3 <= 0.96: tmp = t_1 else: tmp = math.sin(th) return tmp
function code(kx, ky, th) t_1 = Float64(Float64(sin(ky) * th) / hypot(sin(ky), sin(kx))) t_2 = sin(ky) ^ 2.0 t_3 = Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + t_2))) tmp = 0.0 if (t_3 <= -0.9995) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(kx * kx) + t_2))) * sin(th)); elseif (t_3 <= -0.05) tmp = t_1; elseif (t_3 <= 0.06) tmp = Float64(Float64(-1.0 / Float64(Float64(-1.0 / ky) * hypot(sin(kx), sin(ky)))) * sin(th)); elseif (t_3 <= 0.96) tmp = t_1; else tmp = sin(th); end return tmp end
function tmp_2 = code(kx, ky, th) t_1 = (sin(ky) * th) / hypot(sin(ky), sin(kx)); t_2 = sin(ky) ^ 2.0; t_3 = sin(ky) / sqrt(((sin(kx) ^ 2.0) + t_2)); tmp = 0.0; if (t_3 <= -0.9995) tmp = (sin(ky) / sqrt(((kx * kx) + t_2))) * sin(th); elseif (t_3 <= -0.05) tmp = t_1; elseif (t_3 <= 0.06) tmp = (-1.0 / ((-1.0 / ky) * hypot(sin(kx), sin(ky)))) * sin(th); elseif (t_3 <= 0.96) tmp = t_1; else tmp = sin(th); end tmp_2 = tmp; end
code[kx_, ky_, th_] := Block[{t$95$1 = N[(N[(N[Sin[ky], $MachinePrecision] * th), $MachinePrecision] / N[Sqrt[N[Sin[ky], $MachinePrecision] ^ 2 + N[Sin[kx], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]}, Block[{t$95$3 = N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + t$95$2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$3, -0.9995], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[(kx * kx), $MachinePrecision] + t$95$2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$3, -0.05], t$95$1, If[LessEqual[t$95$3, 0.06], N[(N[(-1.0 / N[(N[(-1.0 / ky), $MachinePrecision] * N[Sqrt[N[Sin[kx], $MachinePrecision] ^ 2 + N[Sin[ky], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$3, 0.96], t$95$1, N[Sin[th], $MachinePrecision]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \frac{\sin ky \cdot th}{\mathsf{hypot}\left(\sin ky, \sin kx\right)}\\
t_2 := {\sin ky}^{2}\\
t_3 := \frac{\sin ky}{\sqrt{{\sin kx}^{2} + t\_2}}\\
\mathbf{if}\;t\_3 \leq -0.9995:\\
\;\;\;\;\frac{\sin ky}{\sqrt{kx \cdot kx + t\_2}} \cdot \sin th\\
\mathbf{elif}\;t\_3 \leq -0.05:\\
\;\;\;\;t\_1\\
\mathbf{elif}\;t\_3 \leq 0.06:\\
\;\;\;\;\frac{-1}{\frac{-1}{ky} \cdot \mathsf{hypot}\left(\sin kx, \sin ky\right)} \cdot \sin th\\
\mathbf{elif}\;t\_3 \leq 0.96:\\
\;\;\;\;t\_1\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\end{array}
if (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.99950000000000006Initial program 88.9%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f6488.9
Applied rewrites88.9%
if -0.99950000000000006 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.050000000000000003 or 0.059999999999999998 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.95999999999999996Initial program 99.3%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
lower-/.f64N/A
*-commutativeN/A
lower-*.f6499.3
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-pow.f64N/A
unpow2N/A
lower-hypot.f6499.3
Applied rewrites99.3%
Taylor expanded in th around 0
*-commutativeN/A
lower-*.f64N/A
lower-sin.f6446.3
Applied rewrites46.3%
if -0.050000000000000003 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.059999999999999998Initial program 99.5%
lift-/.f64N/A
clear-numN/A
lower-/.f64N/A
lower-/.f6499.5
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-pow.f64N/A
unpow2N/A
lower-hypot.f6499.5
Applied rewrites99.5%
Applied rewrites99.4%
Taylor expanded in ky around 0
lower-/.f6498.2
Applied rewrites98.2%
if 0.95999999999999996 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) Initial program 94.1%
Taylor expanded in kx around 0
lower-sin.f6492.4
Applied rewrites92.4%
Final simplification79.2%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))))
(t_2 (/ (* (sin ky) th) (hypot (sin ky) (sin kx)))))
(if (<= t_1 -0.9995)
(*
(/
(sin ky)
(/
(sqrt
(fma
(- 1.0 (cos (* ky 2.0)))
2.0
(*
(*
(fma
(fma 0.17777777777777778 (* kx kx) -1.3333333333333333)
(* kx kx)
4.0)
kx)
kx)))
2.0))
(sin th))
(if (<= t_1 -0.05)
t_2
(if (<= t_1 0.06)
(* (/ -1.0 (* (/ -1.0 ky) (hypot (sin kx) (sin ky)))) (sin th))
(if (<= t_1 0.96) t_2 (sin th)))))))
double code(double kx, double ky, double th) {
double t_1 = sin(ky) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)));
double t_2 = (sin(ky) * th) / hypot(sin(ky), sin(kx));
double tmp;
if (t_1 <= -0.9995) {
tmp = (sin(ky) / (sqrt(fma((1.0 - cos((ky * 2.0))), 2.0, ((fma(fma(0.17777777777777778, (kx * kx), -1.3333333333333333), (kx * kx), 4.0) * kx) * kx))) / 2.0)) * sin(th);
} else if (t_1 <= -0.05) {
tmp = t_2;
} else if (t_1 <= 0.06) {
tmp = (-1.0 / ((-1.0 / ky) * hypot(sin(kx), sin(ky)))) * sin(th);
} else if (t_1 <= 0.96) {
tmp = t_2;
} else {
tmp = sin(th);
}
return tmp;
}
function code(kx, ky, th) t_1 = Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) t_2 = Float64(Float64(sin(ky) * th) / hypot(sin(ky), sin(kx))) tmp = 0.0 if (t_1 <= -0.9995) tmp = Float64(Float64(sin(ky) / Float64(sqrt(fma(Float64(1.0 - cos(Float64(ky * 2.0))), 2.0, Float64(Float64(fma(fma(0.17777777777777778, Float64(kx * kx), -1.3333333333333333), Float64(kx * kx), 4.0) * kx) * kx))) / 2.0)) * sin(th)); elseif (t_1 <= -0.05) tmp = t_2; elseif (t_1 <= 0.06) tmp = Float64(Float64(-1.0 / Float64(Float64(-1.0 / ky) * hypot(sin(kx), sin(ky)))) * sin(th)); elseif (t_1 <= 0.96) tmp = t_2; else tmp = sin(th); end return tmp end
code[kx_, ky_, th_] := Block[{t$95$1 = N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[(N[(N[Sin[ky], $MachinePrecision] * th), $MachinePrecision] / N[Sqrt[N[Sin[ky], $MachinePrecision] ^ 2 + N[Sin[kx], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$1, -0.9995], N[(N[(N[Sin[ky], $MachinePrecision] / N[(N[Sqrt[N[(N[(1.0 - N[Cos[N[(ky * 2.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * 2.0 + N[(N[(N[(N[(0.17777777777777778 * N[(kx * kx), $MachinePrecision] + -1.3333333333333333), $MachinePrecision] * N[(kx * kx), $MachinePrecision] + 4.0), $MachinePrecision] * kx), $MachinePrecision] * kx), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$1, -0.05], t$95$2, If[LessEqual[t$95$1, 0.06], N[(N[(-1.0 / N[(N[(-1.0 / ky), $MachinePrecision] * N[Sqrt[N[Sin[kx], $MachinePrecision] ^ 2 + N[Sin[ky], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$1, 0.96], t$95$2, N[Sin[th], $MachinePrecision]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}}\\
t_2 := \frac{\sin ky \cdot th}{\mathsf{hypot}\left(\sin ky, \sin kx\right)}\\
\mathbf{if}\;t\_1 \leq -0.9995:\\
\;\;\;\;\frac{\sin ky}{\frac{\sqrt{\mathsf{fma}\left(1 - \cos \left(ky \cdot 2\right), 2, \left(\mathsf{fma}\left(\mathsf{fma}\left(0.17777777777777778, kx \cdot kx, -1.3333333333333333\right), kx \cdot kx, 4\right) \cdot kx\right) \cdot kx\right)}}{2}} \cdot \sin th\\
\mathbf{elif}\;t\_1 \leq -0.05:\\
\;\;\;\;t\_2\\
\mathbf{elif}\;t\_1 \leq 0.06:\\
\;\;\;\;\frac{-1}{\frac{-1}{ky} \cdot \mathsf{hypot}\left(\sin kx, \sin ky\right)} \cdot \sin th\\
\mathbf{elif}\;t\_1 \leq 0.96:\\
\;\;\;\;t\_2\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\end{array}
if (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.99950000000000006Initial program 88.9%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites59.9%
Taylor expanded in kx around 0
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-*.f64N/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
sub-negN/A
metadata-evalN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f64N/A
unpow2N/A
lower-*.f6460.2
Applied rewrites60.2%
if -0.99950000000000006 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.050000000000000003 or 0.059999999999999998 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.95999999999999996Initial program 99.3%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
lower-/.f64N/A
*-commutativeN/A
lower-*.f6499.3
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-pow.f64N/A
unpow2N/A
lower-hypot.f6499.3
Applied rewrites99.3%
Taylor expanded in th around 0
*-commutativeN/A
lower-*.f64N/A
lower-sin.f6446.3
Applied rewrites46.3%
if -0.050000000000000003 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.059999999999999998Initial program 99.5%
lift-/.f64N/A
clear-numN/A
lower-/.f64N/A
lower-/.f6499.5
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-pow.f64N/A
unpow2N/A
lower-hypot.f6499.5
Applied rewrites99.5%
Applied rewrites99.4%
Taylor expanded in ky around 0
lower-/.f6498.2
Applied rewrites98.2%
if 0.95999999999999996 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) Initial program 94.1%
Taylor expanded in kx around 0
lower-sin.f6492.4
Applied rewrites92.4%
Final simplification74.3%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))))
(t_2 (hypot (sin ky) (sin kx)))
(t_3 (/ (* (sin ky) th) t_2)))
(if (<= t_1 -0.9995)
(*
(/
(sin ky)
(/
(sqrt
(fma
(- 1.0 (cos (* ky 2.0)))
2.0
(*
(*
(fma
(fma 0.17777777777777778 (* kx kx) -1.3333333333333333)
(* kx kx)
4.0)
kx)
kx)))
2.0))
(sin th))
(if (<= t_1 -0.05)
t_3
(if (<= t_1 0.06)
(/ (* (sin th) ky) t_2)
(if (<= t_1 0.96) t_3 (sin th)))))))
double code(double kx, double ky, double th) {
double t_1 = sin(ky) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)));
double t_2 = hypot(sin(ky), sin(kx));
double t_3 = (sin(ky) * th) / t_2;
double tmp;
if (t_1 <= -0.9995) {
tmp = (sin(ky) / (sqrt(fma((1.0 - cos((ky * 2.0))), 2.0, ((fma(fma(0.17777777777777778, (kx * kx), -1.3333333333333333), (kx * kx), 4.0) * kx) * kx))) / 2.0)) * sin(th);
} else if (t_1 <= -0.05) {
tmp = t_3;
} else if (t_1 <= 0.06) {
tmp = (sin(th) * ky) / t_2;
} else if (t_1 <= 0.96) {
tmp = t_3;
} else {
tmp = sin(th);
}
return tmp;
}
function code(kx, ky, th) t_1 = Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) t_2 = hypot(sin(ky), sin(kx)) t_3 = Float64(Float64(sin(ky) * th) / t_2) tmp = 0.0 if (t_1 <= -0.9995) tmp = Float64(Float64(sin(ky) / Float64(sqrt(fma(Float64(1.0 - cos(Float64(ky * 2.0))), 2.0, Float64(Float64(fma(fma(0.17777777777777778, Float64(kx * kx), -1.3333333333333333), Float64(kx * kx), 4.0) * kx) * kx))) / 2.0)) * sin(th)); elseif (t_1 <= -0.05) tmp = t_3; elseif (t_1 <= 0.06) tmp = Float64(Float64(sin(th) * ky) / t_2); elseif (t_1 <= 0.96) tmp = t_3; else tmp = sin(th); end return tmp end
code[kx_, ky_, th_] := Block[{t$95$1 = N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[Sqrt[N[Sin[ky], $MachinePrecision] ^ 2 + N[Sin[kx], $MachinePrecision] ^ 2], $MachinePrecision]}, Block[{t$95$3 = N[(N[(N[Sin[ky], $MachinePrecision] * th), $MachinePrecision] / t$95$2), $MachinePrecision]}, If[LessEqual[t$95$1, -0.9995], N[(N[(N[Sin[ky], $MachinePrecision] / N[(N[Sqrt[N[(N[(1.0 - N[Cos[N[(ky * 2.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * 2.0 + N[(N[(N[(N[(0.17777777777777778 * N[(kx * kx), $MachinePrecision] + -1.3333333333333333), $MachinePrecision] * N[(kx * kx), $MachinePrecision] + 4.0), $MachinePrecision] * kx), $MachinePrecision] * kx), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$1, -0.05], t$95$3, If[LessEqual[t$95$1, 0.06], N[(N[(N[Sin[th], $MachinePrecision] * ky), $MachinePrecision] / t$95$2), $MachinePrecision], If[LessEqual[t$95$1, 0.96], t$95$3, N[Sin[th], $MachinePrecision]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}}\\
t_2 := \mathsf{hypot}\left(\sin ky, \sin kx\right)\\
t_3 := \frac{\sin ky \cdot th}{t\_2}\\
\mathbf{if}\;t\_1 \leq -0.9995:\\
\;\;\;\;\frac{\sin ky}{\frac{\sqrt{\mathsf{fma}\left(1 - \cos \left(ky \cdot 2\right), 2, \left(\mathsf{fma}\left(\mathsf{fma}\left(0.17777777777777778, kx \cdot kx, -1.3333333333333333\right), kx \cdot kx, 4\right) \cdot kx\right) \cdot kx\right)}}{2}} \cdot \sin th\\
\mathbf{elif}\;t\_1 \leq -0.05:\\
\;\;\;\;t\_3\\
\mathbf{elif}\;t\_1 \leq 0.06:\\
\;\;\;\;\frac{\sin th \cdot ky}{t\_2}\\
\mathbf{elif}\;t\_1 \leq 0.96:\\
\;\;\;\;t\_3\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\end{array}
if (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.99950000000000006Initial program 88.9%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites59.9%
Taylor expanded in kx around 0
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-*.f64N/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
sub-negN/A
metadata-evalN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f64N/A
unpow2N/A
lower-*.f6460.2
Applied rewrites60.2%
if -0.99950000000000006 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.050000000000000003 or 0.059999999999999998 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.95999999999999996Initial program 99.3%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
lower-/.f64N/A
*-commutativeN/A
lower-*.f6499.3
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-pow.f64N/A
unpow2N/A
lower-hypot.f6499.3
Applied rewrites99.3%
Taylor expanded in th around 0
*-commutativeN/A
lower-*.f64N/A
lower-sin.f6446.3
Applied rewrites46.3%
if -0.050000000000000003 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.059999999999999998Initial program 99.5%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
lower-/.f64N/A
*-commutativeN/A
lower-*.f6498.4
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-pow.f64N/A
unpow2N/A
lower-hypot.f6498.5
Applied rewrites98.5%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
lower-sin.f6497.3
Applied rewrites97.3%
if 0.95999999999999996 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) Initial program 94.1%
Taylor expanded in kx around 0
lower-sin.f6492.4
Applied rewrites92.4%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))))
(t_2 (/ (* (sin ky) th) (hypot (sin ky) (sin kx)))))
(if (<= t_1 -0.9995)
(*
(/
(sin ky)
(/
(sqrt
(fma
(- 1.0 (cos (* ky 2.0)))
2.0
(*
(*
(fma
(fma 0.17777777777777778 (* kx kx) -1.3333333333333333)
(* kx kx)
4.0)
kx)
kx)))
2.0))
(sin th))
(if (<= t_1 -0.2)
t_2
(if (<= t_1 0.001)
(*
(/
(* (fma -0.16666666666666666 (* ky ky) 1.0) ky)
(/
(sqrt
(fma
(- 1.0 (cos (* 2.0 kx)))
2.0
(*
(*
(fma
(fma (* ky ky) 0.17777777777777778 -1.3333333333333333)
(* ky ky)
4.0)
ky)
ky)))
2.0))
(sin th))
(if (<= t_1 0.96) t_2 (sin th)))))))
double code(double kx, double ky, double th) {
double t_1 = sin(ky) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)));
double t_2 = (sin(ky) * th) / hypot(sin(ky), sin(kx));
double tmp;
if (t_1 <= -0.9995) {
tmp = (sin(ky) / (sqrt(fma((1.0 - cos((ky * 2.0))), 2.0, ((fma(fma(0.17777777777777778, (kx * kx), -1.3333333333333333), (kx * kx), 4.0) * kx) * kx))) / 2.0)) * sin(th);
} else if (t_1 <= -0.2) {
tmp = t_2;
} else if (t_1 <= 0.001) {
tmp = ((fma(-0.16666666666666666, (ky * ky), 1.0) * ky) / (sqrt(fma((1.0 - cos((2.0 * kx))), 2.0, ((fma(fma((ky * ky), 0.17777777777777778, -1.3333333333333333), (ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th);
} else if (t_1 <= 0.96) {
tmp = t_2;
} else {
tmp = sin(th);
}
return tmp;
}
function code(kx, ky, th) t_1 = Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) t_2 = Float64(Float64(sin(ky) * th) / hypot(sin(ky), sin(kx))) tmp = 0.0 if (t_1 <= -0.9995) tmp = Float64(Float64(sin(ky) / Float64(sqrt(fma(Float64(1.0 - cos(Float64(ky * 2.0))), 2.0, Float64(Float64(fma(fma(0.17777777777777778, Float64(kx * kx), -1.3333333333333333), Float64(kx * kx), 4.0) * kx) * kx))) / 2.0)) * sin(th)); elseif (t_1 <= -0.2) tmp = t_2; elseif (t_1 <= 0.001) tmp = Float64(Float64(Float64(fma(-0.16666666666666666, Float64(ky * ky), 1.0) * ky) / Float64(sqrt(fma(Float64(1.0 - cos(Float64(2.0 * kx))), 2.0, Float64(Float64(fma(fma(Float64(ky * ky), 0.17777777777777778, -1.3333333333333333), Float64(ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th)); elseif (t_1 <= 0.96) tmp = t_2; else tmp = sin(th); end return tmp end
code[kx_, ky_, th_] := Block[{t$95$1 = N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[(N[(N[Sin[ky], $MachinePrecision] * th), $MachinePrecision] / N[Sqrt[N[Sin[ky], $MachinePrecision] ^ 2 + N[Sin[kx], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$1, -0.9995], N[(N[(N[Sin[ky], $MachinePrecision] / N[(N[Sqrt[N[(N[(1.0 - N[Cos[N[(ky * 2.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * 2.0 + N[(N[(N[(N[(0.17777777777777778 * N[(kx * kx), $MachinePrecision] + -1.3333333333333333), $MachinePrecision] * N[(kx * kx), $MachinePrecision] + 4.0), $MachinePrecision] * kx), $MachinePrecision] * kx), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$1, -0.2], t$95$2, If[LessEqual[t$95$1, 0.001], N[(N[(N[(N[(-0.16666666666666666 * N[(ky * ky), $MachinePrecision] + 1.0), $MachinePrecision] * ky), $MachinePrecision] / N[(N[Sqrt[N[(N[(1.0 - N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * 2.0 + N[(N[(N[(N[(N[(ky * ky), $MachinePrecision] * 0.17777777777777778 + -1.3333333333333333), $MachinePrecision] * N[(ky * ky), $MachinePrecision] + 4.0), $MachinePrecision] * ky), $MachinePrecision] * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$1, 0.96], t$95$2, N[Sin[th], $MachinePrecision]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}}\\
t_2 := \frac{\sin ky \cdot th}{\mathsf{hypot}\left(\sin ky, \sin kx\right)}\\
\mathbf{if}\;t\_1 \leq -0.9995:\\
\;\;\;\;\frac{\sin ky}{\frac{\sqrt{\mathsf{fma}\left(1 - \cos \left(ky \cdot 2\right), 2, \left(\mathsf{fma}\left(\mathsf{fma}\left(0.17777777777777778, kx \cdot kx, -1.3333333333333333\right), kx \cdot kx, 4\right) \cdot kx\right) \cdot kx\right)}}{2}} \cdot \sin th\\
\mathbf{elif}\;t\_1 \leq -0.2:\\
\;\;\;\;t\_2\\
\mathbf{elif}\;t\_1 \leq 0.001:\\
\;\;\;\;\frac{\mathsf{fma}\left(-0.16666666666666666, ky \cdot ky, 1\right) \cdot ky}{\frac{\sqrt{\mathsf{fma}\left(1 - \cos \left(2 \cdot kx\right), 2, \left(\mathsf{fma}\left(\mathsf{fma}\left(ky \cdot ky, 0.17777777777777778, -1.3333333333333333\right), ky \cdot ky, 4\right) \cdot ky\right) \cdot ky\right)}}{2}} \cdot \sin th\\
\mathbf{elif}\;t\_1 \leq 0.96:\\
\;\;\;\;t\_2\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\end{array}
if (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.99950000000000006Initial program 88.9%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites59.9%
Taylor expanded in kx around 0
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-*.f64N/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
sub-negN/A
metadata-evalN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f64N/A
unpow2N/A
lower-*.f6460.2
Applied rewrites60.2%
if -0.99950000000000006 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.20000000000000001 or 1e-3 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.95999999999999996Initial program 99.3%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
lower-/.f64N/A
*-commutativeN/A
lower-*.f6499.3
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-pow.f64N/A
unpow2N/A
lower-hypot.f6499.3
Applied rewrites99.3%
Taylor expanded in th around 0
*-commutativeN/A
lower-*.f64N/A
lower-sin.f6446.3
Applied rewrites46.3%
if -0.20000000000000001 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 1e-3Initial program 99.5%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites76.9%
Taylor expanded in ky around 0
*-commutativeN/A
lower-fma.f64N/A
lower--.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-*.f64N/A
Applied rewrites75.2%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f6475.2
Applied rewrites75.2%
if 0.95999999999999996 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) Initial program 94.1%
Taylor expanded in kx around 0
lower-sin.f6492.4
Applied rewrites92.4%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (cos (* 2.0 kx)))
(t_2 (- 1.0 t_1))
(t_3 (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))))
(t_4 (- 1.0 (cos (* 2.0 ky)))))
(if (<= t_3 -0.9995)
(*
(/
(sin ky)
(/
(sqrt
(fma
(- 1.0 (cos (* ky 2.0)))
2.0
(*
(*
(fma
(fma 0.17777777777777778 (* kx kx) -1.3333333333333333)
(* kx kx)
4.0)
kx)
kx)))
2.0))
(sin th))
(if (<= t_3 -0.2)
(* (* th (* 2.0 (sin ky))) (sqrt (pow (* 2.0 (+ t_4 t_2)) -1.0)))
(if (<= t_3 0.02)
(*
(/
(* (fma -0.16666666666666666 (* ky ky) 1.0) ky)
(/
(sqrt
(fma
t_2
2.0
(*
(*
(fma
(fma (* ky ky) 0.17777777777777778 -1.3333333333333333)
(* ky ky)
4.0)
ky)
ky)))
2.0))
(sin th))
(if (<= t_3 0.96)
(* (* 2.0 (* (sin ky) th)) (sqrt (/ 0.5 (- 1.0 (- t_1 t_4)))))
(sin th)))))))
double code(double kx, double ky, double th) {
double t_1 = cos((2.0 * kx));
double t_2 = 1.0 - t_1;
double t_3 = sin(ky) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)));
double t_4 = 1.0 - cos((2.0 * ky));
double tmp;
if (t_3 <= -0.9995) {
tmp = (sin(ky) / (sqrt(fma((1.0 - cos((ky * 2.0))), 2.0, ((fma(fma(0.17777777777777778, (kx * kx), -1.3333333333333333), (kx * kx), 4.0) * kx) * kx))) / 2.0)) * sin(th);
} else if (t_3 <= -0.2) {
tmp = (th * (2.0 * sin(ky))) * sqrt(pow((2.0 * (t_4 + t_2)), -1.0));
} else if (t_3 <= 0.02) {
tmp = ((fma(-0.16666666666666666, (ky * ky), 1.0) * ky) / (sqrt(fma(t_2, 2.0, ((fma(fma((ky * ky), 0.17777777777777778, -1.3333333333333333), (ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th);
} else if (t_3 <= 0.96) {
tmp = (2.0 * (sin(ky) * th)) * sqrt((0.5 / (1.0 - (t_1 - t_4))));
} else {
tmp = sin(th);
}
return tmp;
}
function code(kx, ky, th) t_1 = cos(Float64(2.0 * kx)) t_2 = Float64(1.0 - t_1) t_3 = Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) t_4 = Float64(1.0 - cos(Float64(2.0 * ky))) tmp = 0.0 if (t_3 <= -0.9995) tmp = Float64(Float64(sin(ky) / Float64(sqrt(fma(Float64(1.0 - cos(Float64(ky * 2.0))), 2.0, Float64(Float64(fma(fma(0.17777777777777778, Float64(kx * kx), -1.3333333333333333), Float64(kx * kx), 4.0) * kx) * kx))) / 2.0)) * sin(th)); elseif (t_3 <= -0.2) tmp = Float64(Float64(th * Float64(2.0 * sin(ky))) * sqrt((Float64(2.0 * Float64(t_4 + t_2)) ^ -1.0))); elseif (t_3 <= 0.02) tmp = Float64(Float64(Float64(fma(-0.16666666666666666, Float64(ky * ky), 1.0) * ky) / Float64(sqrt(fma(t_2, 2.0, Float64(Float64(fma(fma(Float64(ky * ky), 0.17777777777777778, -1.3333333333333333), Float64(ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th)); elseif (t_3 <= 0.96) tmp = Float64(Float64(2.0 * Float64(sin(ky) * th)) * sqrt(Float64(0.5 / Float64(1.0 - Float64(t_1 - t_4))))); else tmp = sin(th); end return tmp end
code[kx_, ky_, th_] := Block[{t$95$1 = N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$2 = N[(1.0 - t$95$1), $MachinePrecision]}, Block[{t$95$3 = N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$4 = N[(1.0 - N[Cos[N[(2.0 * ky), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$3, -0.9995], N[(N[(N[Sin[ky], $MachinePrecision] / N[(N[Sqrt[N[(N[(1.0 - N[Cos[N[(ky * 2.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * 2.0 + N[(N[(N[(N[(0.17777777777777778 * N[(kx * kx), $MachinePrecision] + -1.3333333333333333), $MachinePrecision] * N[(kx * kx), $MachinePrecision] + 4.0), $MachinePrecision] * kx), $MachinePrecision] * kx), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$3, -0.2], N[(N[(th * N[(2.0 * N[Sin[ky], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Sqrt[N[Power[N[(2.0 * N[(t$95$4 + t$95$2), $MachinePrecision]), $MachinePrecision], -1.0], $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$3, 0.02], N[(N[(N[(N[(-0.16666666666666666 * N[(ky * ky), $MachinePrecision] + 1.0), $MachinePrecision] * ky), $MachinePrecision] / N[(N[Sqrt[N[(t$95$2 * 2.0 + N[(N[(N[(N[(N[(ky * ky), $MachinePrecision] * 0.17777777777777778 + -1.3333333333333333), $MachinePrecision] * N[(ky * ky), $MachinePrecision] + 4.0), $MachinePrecision] * ky), $MachinePrecision] * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$3, 0.96], N[(N[(2.0 * N[(N[Sin[ky], $MachinePrecision] * th), $MachinePrecision]), $MachinePrecision] * N[Sqrt[N[(0.5 / N[(1.0 - N[(t$95$1 - t$95$4), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \cos \left(2 \cdot kx\right)\\
t_2 := 1 - t\_1\\
t_3 := \frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}}\\
t_4 := 1 - \cos \left(2 \cdot ky\right)\\
\mathbf{if}\;t\_3 \leq -0.9995:\\
\;\;\;\;\frac{\sin ky}{\frac{\sqrt{\mathsf{fma}\left(1 - \cos \left(ky \cdot 2\right), 2, \left(\mathsf{fma}\left(\mathsf{fma}\left(0.17777777777777778, kx \cdot kx, -1.3333333333333333\right), kx \cdot kx, 4\right) \cdot kx\right) \cdot kx\right)}}{2}} \cdot \sin th\\
\mathbf{elif}\;t\_3 \leq -0.2:\\
\;\;\;\;\left(th \cdot \left(2 \cdot \sin ky\right)\right) \cdot \sqrt{{\left(2 \cdot \left(t\_4 + t\_2\right)\right)}^{-1}}\\
\mathbf{elif}\;t\_3 \leq 0.02:\\
\;\;\;\;\frac{\mathsf{fma}\left(-0.16666666666666666, ky \cdot ky, 1\right) \cdot ky}{\frac{\sqrt{\mathsf{fma}\left(t\_2, 2, \left(\mathsf{fma}\left(\mathsf{fma}\left(ky \cdot ky, 0.17777777777777778, -1.3333333333333333\right), ky \cdot ky, 4\right) \cdot ky\right) \cdot ky\right)}}{2}} \cdot \sin th\\
\mathbf{elif}\;t\_3 \leq 0.96:\\
\;\;\;\;\left(2 \cdot \left(\sin ky \cdot th\right)\right) \cdot \sqrt{\frac{0.5}{1 - \left(t\_1 - t\_4\right)}}\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\end{array}
if (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.99950000000000006Initial program 88.9%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites59.9%
Taylor expanded in kx around 0
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-*.f64N/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
sub-negN/A
metadata-evalN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f64N/A
unpow2N/A
lower-*.f6460.2
Applied rewrites60.2%
if -0.99950000000000006 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.20000000000000001Initial program 99.3%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites99.2%
Taylor expanded in th around 0
*-commutativeN/A
associate-*l*N/A
associate-*r*N/A
*-commutativeN/A
associate-*r*N/A
associate-*r*N/A
lower-*.f64N/A
Applied rewrites51.8%
if -0.20000000000000001 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.0200000000000000004Initial program 99.5%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites76.0%
Taylor expanded in ky around 0
*-commutativeN/A
lower-fma.f64N/A
lower--.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-*.f64N/A
Applied rewrites74.4%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f6474.5
Applied rewrites74.5%
if 0.0200000000000000004 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.95999999999999996Initial program 99.4%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites98.9%
Taylor expanded in ky around 0
*-commutativeN/A
lower-fma.f64N/A
lower--.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-*.f64N/A
Applied rewrites6.3%
Taylor expanded in th around 0
associate-*r*N/A
lower-*.f64N/A
lower-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f64N/A
lower-sqrt.f64N/A
distribute-lft-outN/A
associate-/r*N/A
metadata-evalN/A
lower-/.f64N/A
associate-+l-N/A
lower--.f64N/A
lower--.f64N/A
Applied rewrites38.9%
if 0.95999999999999996 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) Initial program 94.1%
Taylor expanded in kx around 0
lower-sin.f6492.4
Applied rewrites92.4%
Final simplification66.5%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))))
(t_2 (- 1.0 (cos (* 2.0 ky))))
(t_3 (cos (* 2.0 kx)))
(t_4 (- 1.0 t_3)))
(if (<= t_1 -0.9995)
(*
(/
(sin ky)
(/
(sqrt
(fma
(- 1.0 (cos (* ky 2.0)))
2.0
(* (* (fma -1.3333333333333333 (* kx kx) 4.0) kx) kx)))
2.0))
(sin th))
(if (<= t_1 -0.2)
(* (* th (* 2.0 (sin ky))) (sqrt (pow (* 2.0 (+ t_2 t_4)) -1.0)))
(if (<= t_1 0.02)
(*
(/
(* (fma -0.16666666666666666 (* ky ky) 1.0) ky)
(/
(sqrt
(fma
t_4
2.0
(*
(*
(fma
(fma (* ky ky) 0.17777777777777778 -1.3333333333333333)
(* ky ky)
4.0)
ky)
ky)))
2.0))
(sin th))
(if (<= t_1 0.96)
(* (* 2.0 (* (sin ky) th)) (sqrt (/ 0.5 (- 1.0 (- t_3 t_2)))))
(sin th)))))))
double code(double kx, double ky, double th) {
double t_1 = sin(ky) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)));
double t_2 = 1.0 - cos((2.0 * ky));
double t_3 = cos((2.0 * kx));
double t_4 = 1.0 - t_3;
double tmp;
if (t_1 <= -0.9995) {
tmp = (sin(ky) / (sqrt(fma((1.0 - cos((ky * 2.0))), 2.0, ((fma(-1.3333333333333333, (kx * kx), 4.0) * kx) * kx))) / 2.0)) * sin(th);
} else if (t_1 <= -0.2) {
tmp = (th * (2.0 * sin(ky))) * sqrt(pow((2.0 * (t_2 + t_4)), -1.0));
} else if (t_1 <= 0.02) {
tmp = ((fma(-0.16666666666666666, (ky * ky), 1.0) * ky) / (sqrt(fma(t_4, 2.0, ((fma(fma((ky * ky), 0.17777777777777778, -1.3333333333333333), (ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th);
} else if (t_1 <= 0.96) {
tmp = (2.0 * (sin(ky) * th)) * sqrt((0.5 / (1.0 - (t_3 - t_2))));
} else {
tmp = sin(th);
}
return tmp;
}
function code(kx, ky, th) t_1 = Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) t_2 = Float64(1.0 - cos(Float64(2.0 * ky))) t_3 = cos(Float64(2.0 * kx)) t_4 = Float64(1.0 - t_3) tmp = 0.0 if (t_1 <= -0.9995) tmp = Float64(Float64(sin(ky) / Float64(sqrt(fma(Float64(1.0 - cos(Float64(ky * 2.0))), 2.0, Float64(Float64(fma(-1.3333333333333333, Float64(kx * kx), 4.0) * kx) * kx))) / 2.0)) * sin(th)); elseif (t_1 <= -0.2) tmp = Float64(Float64(th * Float64(2.0 * sin(ky))) * sqrt((Float64(2.0 * Float64(t_2 + t_4)) ^ -1.0))); elseif (t_1 <= 0.02) tmp = Float64(Float64(Float64(fma(-0.16666666666666666, Float64(ky * ky), 1.0) * ky) / Float64(sqrt(fma(t_4, 2.0, Float64(Float64(fma(fma(Float64(ky * ky), 0.17777777777777778, -1.3333333333333333), Float64(ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th)); elseif (t_1 <= 0.96) tmp = Float64(Float64(2.0 * Float64(sin(ky) * th)) * sqrt(Float64(0.5 / Float64(1.0 - Float64(t_3 - t_2))))); else tmp = sin(th); end return tmp end
code[kx_, ky_, th_] := Block[{t$95$1 = N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[(1.0 - N[Cos[N[(2.0 * ky), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$3 = N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$4 = N[(1.0 - t$95$3), $MachinePrecision]}, If[LessEqual[t$95$1, -0.9995], N[(N[(N[Sin[ky], $MachinePrecision] / N[(N[Sqrt[N[(N[(1.0 - N[Cos[N[(ky * 2.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * 2.0 + N[(N[(N[(-1.3333333333333333 * N[(kx * kx), $MachinePrecision] + 4.0), $MachinePrecision] * kx), $MachinePrecision] * kx), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$1, -0.2], N[(N[(th * N[(2.0 * N[Sin[ky], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Sqrt[N[Power[N[(2.0 * N[(t$95$2 + t$95$4), $MachinePrecision]), $MachinePrecision], -1.0], $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$1, 0.02], N[(N[(N[(N[(-0.16666666666666666 * N[(ky * ky), $MachinePrecision] + 1.0), $MachinePrecision] * ky), $MachinePrecision] / N[(N[Sqrt[N[(t$95$4 * 2.0 + N[(N[(N[(N[(N[(ky * ky), $MachinePrecision] * 0.17777777777777778 + -1.3333333333333333), $MachinePrecision] * N[(ky * ky), $MachinePrecision] + 4.0), $MachinePrecision] * ky), $MachinePrecision] * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$1, 0.96], N[(N[(2.0 * N[(N[Sin[ky], $MachinePrecision] * th), $MachinePrecision]), $MachinePrecision] * N[Sqrt[N[(0.5 / N[(1.0 - N[(t$95$3 - t$95$2), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}}\\
t_2 := 1 - \cos \left(2 \cdot ky\right)\\
t_3 := \cos \left(2 \cdot kx\right)\\
t_4 := 1 - t\_3\\
\mathbf{if}\;t\_1 \leq -0.9995:\\
\;\;\;\;\frac{\sin ky}{\frac{\sqrt{\mathsf{fma}\left(1 - \cos \left(ky \cdot 2\right), 2, \left(\mathsf{fma}\left(-1.3333333333333333, kx \cdot kx, 4\right) \cdot kx\right) \cdot kx\right)}}{2}} \cdot \sin th\\
\mathbf{elif}\;t\_1 \leq -0.2:\\
\;\;\;\;\left(th \cdot \left(2 \cdot \sin ky\right)\right) \cdot \sqrt{{\left(2 \cdot \left(t\_2 + t\_4\right)\right)}^{-1}}\\
\mathbf{elif}\;t\_1 \leq 0.02:\\
\;\;\;\;\frac{\mathsf{fma}\left(-0.16666666666666666, ky \cdot ky, 1\right) \cdot ky}{\frac{\sqrt{\mathsf{fma}\left(t\_4, 2, \left(\mathsf{fma}\left(\mathsf{fma}\left(ky \cdot ky, 0.17777777777777778, -1.3333333333333333\right), ky \cdot ky, 4\right) \cdot ky\right) \cdot ky\right)}}{2}} \cdot \sin th\\
\mathbf{elif}\;t\_1 \leq 0.96:\\
\;\;\;\;\left(2 \cdot \left(\sin ky \cdot th\right)\right) \cdot \sqrt{\frac{0.5}{1 - \left(t\_3 - t\_2\right)}}\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\end{array}
if (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.99950000000000006Initial program 88.9%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites59.9%
Taylor expanded in kx around 0
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-*.f64N/A
lower-*.f64N/A
+-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f6460.2
Applied rewrites60.2%
if -0.99950000000000006 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.20000000000000001Initial program 99.3%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites99.2%
Taylor expanded in th around 0
*-commutativeN/A
associate-*l*N/A
associate-*r*N/A
*-commutativeN/A
associate-*r*N/A
associate-*r*N/A
lower-*.f64N/A
Applied rewrites51.8%
if -0.20000000000000001 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.0200000000000000004Initial program 99.5%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites76.0%
Taylor expanded in ky around 0
*-commutativeN/A
lower-fma.f64N/A
lower--.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-*.f64N/A
Applied rewrites74.4%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f6474.5
Applied rewrites74.5%
if 0.0200000000000000004 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.95999999999999996Initial program 99.4%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites98.9%
Taylor expanded in ky around 0
*-commutativeN/A
lower-fma.f64N/A
lower--.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-*.f64N/A
Applied rewrites6.3%
Taylor expanded in th around 0
associate-*r*N/A
lower-*.f64N/A
lower-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f64N/A
lower-sqrt.f64N/A
distribute-lft-outN/A
associate-/r*N/A
metadata-evalN/A
lower-/.f64N/A
associate-+l-N/A
lower--.f64N/A
lower--.f64N/A
Applied rewrites38.9%
if 0.95999999999999996 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) Initial program 94.1%
Taylor expanded in kx around 0
lower-sin.f6492.4
Applied rewrites92.4%
Final simplification66.5%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (cos (* 2.0 kx)))
(t_2 (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))))
(t_3 (- 1.0 (cos (* 2.0 ky))))
(t_4 (- 1.0 t_1)))
(if (<= t_2 -0.998)
(* (/ (sin ky) (/ (sqrt (* t_3 2.0)) 2.0)) (sin th))
(if (<= t_2 -0.2)
(* (* th (* 2.0 (sin ky))) (sqrt (pow (* 2.0 (+ t_3 t_4)) -1.0)))
(if (<= t_2 0.02)
(*
(/
(* (fma -0.16666666666666666 (* ky ky) 1.0) ky)
(/
(sqrt
(fma
t_4
2.0
(*
(*
(fma
(fma (* ky ky) 0.17777777777777778 -1.3333333333333333)
(* ky ky)
4.0)
ky)
ky)))
2.0))
(sin th))
(if (<= t_2 0.96)
(* (* 2.0 (* (sin ky) th)) (sqrt (/ 0.5 (- 1.0 (- t_1 t_3)))))
(sin th)))))))
double code(double kx, double ky, double th) {
double t_1 = cos((2.0 * kx));
double t_2 = sin(ky) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)));
double t_3 = 1.0 - cos((2.0 * ky));
double t_4 = 1.0 - t_1;
double tmp;
if (t_2 <= -0.998) {
tmp = (sin(ky) / (sqrt((t_3 * 2.0)) / 2.0)) * sin(th);
} else if (t_2 <= -0.2) {
tmp = (th * (2.0 * sin(ky))) * sqrt(pow((2.0 * (t_3 + t_4)), -1.0));
} else if (t_2 <= 0.02) {
tmp = ((fma(-0.16666666666666666, (ky * ky), 1.0) * ky) / (sqrt(fma(t_4, 2.0, ((fma(fma((ky * ky), 0.17777777777777778, -1.3333333333333333), (ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th);
} else if (t_2 <= 0.96) {
tmp = (2.0 * (sin(ky) * th)) * sqrt((0.5 / (1.0 - (t_1 - t_3))));
} else {
tmp = sin(th);
}
return tmp;
}
function code(kx, ky, th) t_1 = cos(Float64(2.0 * kx)) t_2 = Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) t_3 = Float64(1.0 - cos(Float64(2.0 * ky))) t_4 = Float64(1.0 - t_1) tmp = 0.0 if (t_2 <= -0.998) tmp = Float64(Float64(sin(ky) / Float64(sqrt(Float64(t_3 * 2.0)) / 2.0)) * sin(th)); elseif (t_2 <= -0.2) tmp = Float64(Float64(th * Float64(2.0 * sin(ky))) * sqrt((Float64(2.0 * Float64(t_3 + t_4)) ^ -1.0))); elseif (t_2 <= 0.02) tmp = Float64(Float64(Float64(fma(-0.16666666666666666, Float64(ky * ky), 1.0) * ky) / Float64(sqrt(fma(t_4, 2.0, Float64(Float64(fma(fma(Float64(ky * ky), 0.17777777777777778, -1.3333333333333333), Float64(ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th)); elseif (t_2 <= 0.96) tmp = Float64(Float64(2.0 * Float64(sin(ky) * th)) * sqrt(Float64(0.5 / Float64(1.0 - Float64(t_1 - t_3))))); else tmp = sin(th); end return tmp end
code[kx_, ky_, th_] := Block[{t$95$1 = N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$2 = N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$3 = N[(1.0 - N[Cos[N[(2.0 * ky), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$4 = N[(1.0 - t$95$1), $MachinePrecision]}, If[LessEqual[t$95$2, -0.998], N[(N[(N[Sin[ky], $MachinePrecision] / N[(N[Sqrt[N[(t$95$3 * 2.0), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, -0.2], N[(N[(th * N[(2.0 * N[Sin[ky], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Sqrt[N[Power[N[(2.0 * N[(t$95$3 + t$95$4), $MachinePrecision]), $MachinePrecision], -1.0], $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, 0.02], N[(N[(N[(N[(-0.16666666666666666 * N[(ky * ky), $MachinePrecision] + 1.0), $MachinePrecision] * ky), $MachinePrecision] / N[(N[Sqrt[N[(t$95$4 * 2.0 + N[(N[(N[(N[(N[(ky * ky), $MachinePrecision] * 0.17777777777777778 + -1.3333333333333333), $MachinePrecision] * N[(ky * ky), $MachinePrecision] + 4.0), $MachinePrecision] * ky), $MachinePrecision] * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, 0.96], N[(N[(2.0 * N[(N[Sin[ky], $MachinePrecision] * th), $MachinePrecision]), $MachinePrecision] * N[Sqrt[N[(0.5 / N[(1.0 - N[(t$95$1 - t$95$3), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \cos \left(2 \cdot kx\right)\\
t_2 := \frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}}\\
t_3 := 1 - \cos \left(2 \cdot ky\right)\\
t_4 := 1 - t\_1\\
\mathbf{if}\;t\_2 \leq -0.998:\\
\;\;\;\;\frac{\sin ky}{\frac{\sqrt{t\_3 \cdot 2}}{2}} \cdot \sin th\\
\mathbf{elif}\;t\_2 \leq -0.2:\\
\;\;\;\;\left(th \cdot \left(2 \cdot \sin ky\right)\right) \cdot \sqrt{{\left(2 \cdot \left(t\_3 + t\_4\right)\right)}^{-1}}\\
\mathbf{elif}\;t\_2 \leq 0.02:\\
\;\;\;\;\frac{\mathsf{fma}\left(-0.16666666666666666, ky \cdot ky, 1\right) \cdot ky}{\frac{\sqrt{\mathsf{fma}\left(t\_4, 2, \left(\mathsf{fma}\left(\mathsf{fma}\left(ky \cdot ky, 0.17777777777777778, -1.3333333333333333\right), ky \cdot ky, 4\right) \cdot ky\right) \cdot ky\right)}}{2}} \cdot \sin th\\
\mathbf{elif}\;t\_2 \leq 0.96:\\
\;\;\;\;\left(2 \cdot \left(\sin ky \cdot th\right)\right) \cdot \sqrt{\frac{0.5}{1 - \left(t\_1 - t\_3\right)}}\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\end{array}
if (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.998Initial program 88.9%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites59.9%
Taylor expanded in kx around 0
*-commutativeN/A
lower-*.f64N/A
lower--.f64N/A
lower-cos.f64N/A
lower-*.f6459.9
Applied rewrites59.9%
if -0.998 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.20000000000000001Initial program 99.3%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites99.2%
Taylor expanded in th around 0
*-commutativeN/A
associate-*l*N/A
associate-*r*N/A
*-commutativeN/A
associate-*r*N/A
associate-*r*N/A
lower-*.f64N/A
Applied rewrites51.8%
if -0.20000000000000001 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.0200000000000000004Initial program 99.5%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites76.0%
Taylor expanded in ky around 0
*-commutativeN/A
lower-fma.f64N/A
lower--.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-*.f64N/A
Applied rewrites74.4%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f6474.5
Applied rewrites74.5%
if 0.0200000000000000004 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.95999999999999996Initial program 99.4%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites98.9%
Taylor expanded in ky around 0
*-commutativeN/A
lower-fma.f64N/A
lower--.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-*.f64N/A
Applied rewrites6.3%
Taylor expanded in th around 0
associate-*r*N/A
lower-*.f64N/A
lower-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f64N/A
lower-sqrt.f64N/A
distribute-lft-outN/A
associate-/r*N/A
metadata-evalN/A
lower-/.f64N/A
associate-+l-N/A
lower--.f64N/A
lower--.f64N/A
Applied rewrites38.9%
if 0.95999999999999996 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) Initial program 94.1%
Taylor expanded in kx around 0
lower-sin.f6492.4
Applied rewrites92.4%
Final simplification66.5%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (cos (* 2.0 kx)))
(t_2 (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))))
(t_3 (- 1.0 (cos (* 2.0 ky))))
(t_4 (* (* 2.0 (* (sin ky) th)) (sqrt (/ 0.5 (- 1.0 (- t_1 t_3)))))))
(if (<= t_2 -0.998)
(* (/ (sin ky) (/ (sqrt (* t_3 2.0)) 2.0)) (sin th))
(if (<= t_2 -0.2)
t_4
(if (<= t_2 0.02)
(*
(/
(* (fma -0.16666666666666666 (* ky ky) 1.0) ky)
(/
(sqrt
(fma
(- 1.0 t_1)
2.0
(*
(*
(fma
(fma (* ky ky) 0.17777777777777778 -1.3333333333333333)
(* ky ky)
4.0)
ky)
ky)))
2.0))
(sin th))
(if (<= t_2 0.96) t_4 (sin th)))))))
double code(double kx, double ky, double th) {
double t_1 = cos((2.0 * kx));
double t_2 = sin(ky) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)));
double t_3 = 1.0 - cos((2.0 * ky));
double t_4 = (2.0 * (sin(ky) * th)) * sqrt((0.5 / (1.0 - (t_1 - t_3))));
double tmp;
if (t_2 <= -0.998) {
tmp = (sin(ky) / (sqrt((t_3 * 2.0)) / 2.0)) * sin(th);
} else if (t_2 <= -0.2) {
tmp = t_4;
} else if (t_2 <= 0.02) {
tmp = ((fma(-0.16666666666666666, (ky * ky), 1.0) * ky) / (sqrt(fma((1.0 - t_1), 2.0, ((fma(fma((ky * ky), 0.17777777777777778, -1.3333333333333333), (ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th);
} else if (t_2 <= 0.96) {
tmp = t_4;
} else {
tmp = sin(th);
}
return tmp;
}
function code(kx, ky, th) t_1 = cos(Float64(2.0 * kx)) t_2 = Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) t_3 = Float64(1.0 - cos(Float64(2.0 * ky))) t_4 = Float64(Float64(2.0 * Float64(sin(ky) * th)) * sqrt(Float64(0.5 / Float64(1.0 - Float64(t_1 - t_3))))) tmp = 0.0 if (t_2 <= -0.998) tmp = Float64(Float64(sin(ky) / Float64(sqrt(Float64(t_3 * 2.0)) / 2.0)) * sin(th)); elseif (t_2 <= -0.2) tmp = t_4; elseif (t_2 <= 0.02) tmp = Float64(Float64(Float64(fma(-0.16666666666666666, Float64(ky * ky), 1.0) * ky) / Float64(sqrt(fma(Float64(1.0 - t_1), 2.0, Float64(Float64(fma(fma(Float64(ky * ky), 0.17777777777777778, -1.3333333333333333), Float64(ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th)); elseif (t_2 <= 0.96) tmp = t_4; else tmp = sin(th); end return tmp end
code[kx_, ky_, th_] := Block[{t$95$1 = N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$2 = N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$3 = N[(1.0 - N[Cos[N[(2.0 * ky), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$4 = N[(N[(2.0 * N[(N[Sin[ky], $MachinePrecision] * th), $MachinePrecision]), $MachinePrecision] * N[Sqrt[N[(0.5 / N[(1.0 - N[(t$95$1 - t$95$3), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$2, -0.998], N[(N[(N[Sin[ky], $MachinePrecision] / N[(N[Sqrt[N[(t$95$3 * 2.0), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, -0.2], t$95$4, If[LessEqual[t$95$2, 0.02], N[(N[(N[(N[(-0.16666666666666666 * N[(ky * ky), $MachinePrecision] + 1.0), $MachinePrecision] * ky), $MachinePrecision] / N[(N[Sqrt[N[(N[(1.0 - t$95$1), $MachinePrecision] * 2.0 + N[(N[(N[(N[(N[(ky * ky), $MachinePrecision] * 0.17777777777777778 + -1.3333333333333333), $MachinePrecision] * N[(ky * ky), $MachinePrecision] + 4.0), $MachinePrecision] * ky), $MachinePrecision] * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, 0.96], t$95$4, N[Sin[th], $MachinePrecision]]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \cos \left(2 \cdot kx\right)\\
t_2 := \frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}}\\
t_3 := 1 - \cos \left(2 \cdot ky\right)\\
t_4 := \left(2 \cdot \left(\sin ky \cdot th\right)\right) \cdot \sqrt{\frac{0.5}{1 - \left(t\_1 - t\_3\right)}}\\
\mathbf{if}\;t\_2 \leq -0.998:\\
\;\;\;\;\frac{\sin ky}{\frac{\sqrt{t\_3 \cdot 2}}{2}} \cdot \sin th\\
\mathbf{elif}\;t\_2 \leq -0.2:\\
\;\;\;\;t\_4\\
\mathbf{elif}\;t\_2 \leq 0.02:\\
\;\;\;\;\frac{\mathsf{fma}\left(-0.16666666666666666, ky \cdot ky, 1\right) \cdot ky}{\frac{\sqrt{\mathsf{fma}\left(1 - t\_1, 2, \left(\mathsf{fma}\left(\mathsf{fma}\left(ky \cdot ky, 0.17777777777777778, -1.3333333333333333\right), ky \cdot ky, 4\right) \cdot ky\right) \cdot ky\right)}}{2}} \cdot \sin th\\
\mathbf{elif}\;t\_2 \leq 0.96:\\
\;\;\;\;t\_4\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\end{array}
if (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.998Initial program 88.9%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites59.9%
Taylor expanded in kx around 0
*-commutativeN/A
lower-*.f64N/A
lower--.f64N/A
lower-cos.f64N/A
lower-*.f6459.9
Applied rewrites59.9%
if -0.998 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.20000000000000001 or 0.0200000000000000004 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.95999999999999996Initial program 99.3%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites99.1%
Taylor expanded in ky around 0
*-commutativeN/A
lower-fma.f64N/A
lower--.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-*.f64N/A
Applied rewrites6.0%
Taylor expanded in th around 0
associate-*r*N/A
lower-*.f64N/A
lower-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f64N/A
lower-sqrt.f64N/A
distribute-lft-outN/A
associate-/r*N/A
metadata-evalN/A
lower-/.f64N/A
associate-+l-N/A
lower--.f64N/A
lower--.f64N/A
Applied rewrites45.4%
if -0.20000000000000001 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.0200000000000000004Initial program 99.5%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites76.0%
Taylor expanded in ky around 0
*-commutativeN/A
lower-fma.f64N/A
lower--.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-*.f64N/A
Applied rewrites74.4%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f6474.5
Applied rewrites74.5%
if 0.95999999999999996 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) Initial program 94.1%
Taylor expanded in kx around 0
lower-sin.f6492.4
Applied rewrites92.4%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0))))))
(if (<= t_1 -0.05)
(pow (pow (sin th) 2.0) 0.5)
(if (<= t_1 0.2)
(*
(/
(*
(fma
(fma 0.008333333333333333 (* ky ky) -0.16666666666666666)
(* ky ky)
1.0)
ky)
(/
(sqrt
(fma
(- 1.0 (cos (* 2.0 kx)))
2.0
(*
(*
(fma
(fma (* ky ky) 0.17777777777777778 -1.3333333333333333)
(* ky ky)
4.0)
ky)
ky)))
2.0))
(sin th))
(sin th)))))
double code(double kx, double ky, double th) {
double t_1 = sin(ky) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)));
double tmp;
if (t_1 <= -0.05) {
tmp = pow(pow(sin(th), 2.0), 0.5);
} else if (t_1 <= 0.2) {
tmp = ((fma(fma(0.008333333333333333, (ky * ky), -0.16666666666666666), (ky * ky), 1.0) * ky) / (sqrt(fma((1.0 - cos((2.0 * kx))), 2.0, ((fma(fma((ky * ky), 0.17777777777777778, -1.3333333333333333), (ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th);
} else {
tmp = sin(th);
}
return tmp;
}
function code(kx, ky, th) t_1 = Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) tmp = 0.0 if (t_1 <= -0.05) tmp = (sin(th) ^ 2.0) ^ 0.5; elseif (t_1 <= 0.2) tmp = Float64(Float64(Float64(fma(fma(0.008333333333333333, Float64(ky * ky), -0.16666666666666666), Float64(ky * ky), 1.0) * ky) / Float64(sqrt(fma(Float64(1.0 - cos(Float64(2.0 * kx))), 2.0, Float64(Float64(fma(fma(Float64(ky * ky), 0.17777777777777778, -1.3333333333333333), Float64(ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th)); else tmp = sin(th); end return tmp end
code[kx_, ky_, th_] := Block[{t$95$1 = N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$1, -0.05], N[Power[N[Power[N[Sin[th], $MachinePrecision], 2.0], $MachinePrecision], 0.5], $MachinePrecision], If[LessEqual[t$95$1, 0.2], N[(N[(N[(N[(N[(0.008333333333333333 * N[(ky * ky), $MachinePrecision] + -0.16666666666666666), $MachinePrecision] * N[(ky * ky), $MachinePrecision] + 1.0), $MachinePrecision] * ky), $MachinePrecision] / N[(N[Sqrt[N[(N[(1.0 - N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * 2.0 + N[(N[(N[(N[(N[(ky * ky), $MachinePrecision] * 0.17777777777777778 + -1.3333333333333333), $MachinePrecision] * N[(ky * ky), $MachinePrecision] + 4.0), $MachinePrecision] * ky), $MachinePrecision] * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}}\\
\mathbf{if}\;t\_1 \leq -0.05:\\
\;\;\;\;{\left({\sin th}^{2}\right)}^{0.5}\\
\mathbf{elif}\;t\_1 \leq 0.2:\\
\;\;\;\;\frac{\mathsf{fma}\left(\mathsf{fma}\left(0.008333333333333333, ky \cdot ky, -0.16666666666666666\right), ky \cdot ky, 1\right) \cdot ky}{\frac{\sqrt{\mathsf{fma}\left(1 - \cos \left(2 \cdot kx\right), 2, \left(\mathsf{fma}\left(\mathsf{fma}\left(ky \cdot ky, 0.17777777777777778, -1.3333333333333333\right), ky \cdot ky, 4\right) \cdot ky\right) \cdot ky\right)}}{2}} \cdot \sin th\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\end{array}
if (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.050000000000000003Initial program 93.9%
Taylor expanded in kx around 0
lower-sin.f643.0
Applied rewrites3.0%
Applied rewrites1.6%
Applied rewrites20.4%
if -0.050000000000000003 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.20000000000000001Initial program 99.5%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites76.2%
Taylor expanded in ky around 0
*-commutativeN/A
lower-fma.f64N/A
lower--.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-*.f64N/A
Applied rewrites74.5%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
sub-negN/A
metadata-evalN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f64N/A
unpow2N/A
lower-*.f6474.5
Applied rewrites74.5%
if 0.20000000000000001 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) Initial program 96.3%
Taylor expanded in kx around 0
lower-sin.f6462.1
Applied rewrites62.1%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0))))))
(if (<= t_1 -0.2)
(pow (pow (sin th) 2.0) 0.5)
(if (<= t_1 0.2)
(*
(/
(* (fma -0.16666666666666666 (* ky ky) 1.0) ky)
(/
(sqrt
(fma
(- 1.0 (cos (* 2.0 kx)))
2.0
(*
(*
(fma
(fma (* ky ky) 0.17777777777777778 -1.3333333333333333)
(* ky ky)
4.0)
ky)
ky)))
2.0))
(sin th))
(sin th)))))
double code(double kx, double ky, double th) {
double t_1 = sin(ky) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)));
double tmp;
if (t_1 <= -0.2) {
tmp = pow(pow(sin(th), 2.0), 0.5);
} else if (t_1 <= 0.2) {
tmp = ((fma(-0.16666666666666666, (ky * ky), 1.0) * ky) / (sqrt(fma((1.0 - cos((2.0 * kx))), 2.0, ((fma(fma((ky * ky), 0.17777777777777778, -1.3333333333333333), (ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th);
} else {
tmp = sin(th);
}
return tmp;
}
function code(kx, ky, th) t_1 = Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) tmp = 0.0 if (t_1 <= -0.2) tmp = (sin(th) ^ 2.0) ^ 0.5; elseif (t_1 <= 0.2) tmp = Float64(Float64(Float64(fma(-0.16666666666666666, Float64(ky * ky), 1.0) * ky) / Float64(sqrt(fma(Float64(1.0 - cos(Float64(2.0 * kx))), 2.0, Float64(Float64(fma(fma(Float64(ky * ky), 0.17777777777777778, -1.3333333333333333), Float64(ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th)); else tmp = sin(th); end return tmp end
code[kx_, ky_, th_] := Block[{t$95$1 = N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$1, -0.2], N[Power[N[Power[N[Sin[th], $MachinePrecision], 2.0], $MachinePrecision], 0.5], $MachinePrecision], If[LessEqual[t$95$1, 0.2], N[(N[(N[(N[(-0.16666666666666666 * N[(ky * ky), $MachinePrecision] + 1.0), $MachinePrecision] * ky), $MachinePrecision] / N[(N[Sqrt[N[(N[(1.0 - N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * 2.0 + N[(N[(N[(N[(N[(ky * ky), $MachinePrecision] * 0.17777777777777778 + -1.3333333333333333), $MachinePrecision] * N[(ky * ky), $MachinePrecision] + 4.0), $MachinePrecision] * ky), $MachinePrecision] * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}}\\
\mathbf{if}\;t\_1 \leq -0.2:\\
\;\;\;\;{\left({\sin th}^{2}\right)}^{0.5}\\
\mathbf{elif}\;t\_1 \leq 0.2:\\
\;\;\;\;\frac{\mathsf{fma}\left(-0.16666666666666666, ky \cdot ky, 1\right) \cdot ky}{\frac{\sqrt{\mathsf{fma}\left(1 - \cos \left(2 \cdot kx\right), 2, \left(\mathsf{fma}\left(\mathsf{fma}\left(ky \cdot ky, 0.17777777777777778, -1.3333333333333333\right), ky \cdot ky, 4\right) \cdot ky\right) \cdot ky\right)}}{2}} \cdot \sin th\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\end{array}
if (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.20000000000000001Initial program 93.8%
Taylor expanded in kx around 0
lower-sin.f643.0
Applied rewrites3.0%
Applied rewrites1.6%
Applied rewrites20.8%
if -0.20000000000000001 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.20000000000000001Initial program 99.5%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites76.7%
Taylor expanded in ky around 0
*-commutativeN/A
lower-fma.f64N/A
lower--.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-*.f64N/A
Applied rewrites73.0%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f6472.7
Applied rewrites72.7%
if 0.20000000000000001 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) Initial program 96.3%
Taylor expanded in kx around 0
lower-sin.f6462.1
Applied rewrites62.1%
(FPCore (kx ky th)
:precision binary64
(if (<= (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))) 1e-8)
(*
(* 2.0 (* (* (sin th) ky) (sqrt 0.5)))
(sqrt (pow (- 1.0 (cos (* 2.0 kx))) -1.0)))
(sin th)))
double code(double kx, double ky, double th) {
double tmp;
if ((sin(ky) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)))) <= 1e-8) {
tmp = (2.0 * ((sin(th) * ky) * sqrt(0.5))) * sqrt(pow((1.0 - cos((2.0 * kx))), -1.0));
} else {
tmp = sin(th);
}
return tmp;
}
real(8) function code(kx, ky, th)
real(8), intent (in) :: kx
real(8), intent (in) :: ky
real(8), intent (in) :: th
real(8) :: tmp
if ((sin(ky) / sqrt(((sin(kx) ** 2.0d0) + (sin(ky) ** 2.0d0)))) <= 1d-8) then
tmp = (2.0d0 * ((sin(th) * ky) * sqrt(0.5d0))) * sqrt(((1.0d0 - cos((2.0d0 * kx))) ** (-1.0d0)))
else
tmp = sin(th)
end if
code = tmp
end function
public static double code(double kx, double ky, double th) {
double tmp;
if ((Math.sin(ky) / Math.sqrt((Math.pow(Math.sin(kx), 2.0) + Math.pow(Math.sin(ky), 2.0)))) <= 1e-8) {
tmp = (2.0 * ((Math.sin(th) * ky) * Math.sqrt(0.5))) * Math.sqrt(Math.pow((1.0 - Math.cos((2.0 * kx))), -1.0));
} else {
tmp = Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): tmp = 0 if (math.sin(ky) / math.sqrt((math.pow(math.sin(kx), 2.0) + math.pow(math.sin(ky), 2.0)))) <= 1e-8: tmp = (2.0 * ((math.sin(th) * ky) * math.sqrt(0.5))) * math.sqrt(math.pow((1.0 - math.cos((2.0 * kx))), -1.0)) else: tmp = math.sin(th) return tmp
function code(kx, ky, th) tmp = 0.0 if (Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) <= 1e-8) tmp = Float64(Float64(2.0 * Float64(Float64(sin(th) * ky) * sqrt(0.5))) * sqrt((Float64(1.0 - cos(Float64(2.0 * kx))) ^ -1.0))); else tmp = sin(th); end return tmp end
function tmp_2 = code(kx, ky, th) tmp = 0.0; if ((sin(ky) / sqrt(((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) <= 1e-8) tmp = (2.0 * ((sin(th) * ky) * sqrt(0.5))) * sqrt(((1.0 - cos((2.0 * kx))) ^ -1.0)); else tmp = sin(th); end tmp_2 = tmp; end
code[kx_, ky_, th_] := If[LessEqual[N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], 1e-8], N[(N[(2.0 * N[(N[(N[Sin[th], $MachinePrecision] * ky), $MachinePrecision] * N[Sqrt[0.5], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Sqrt[N[Power[N[(1.0 - N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], -1.0], $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}} \leq 10^{-8}:\\
\;\;\;\;\left(2 \cdot \left(\left(\sin th \cdot ky\right) \cdot \sqrt{0.5}\right)\right) \cdot \sqrt{{\left(1 - \cos \left(2 \cdot kx\right)\right)}^{-1}}\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\end{array}
if (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 1e-8Initial program 96.6%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites78.2%
Taylor expanded in ky around 0
*-commutativeN/A
lower-fma.f64N/A
lower--.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-*.f64N/A
Applied rewrites47.3%
Taylor expanded in ky around 0
associate-*r*N/A
lower-*.f64N/A
lower-*.f64N/A
associate-*r*N/A
lower-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f64N/A
lower-sqrt.f64N/A
lower-sqrt.f64N/A
lower-/.f64N/A
lower--.f64N/A
lower-cos.f64N/A
lower-*.f6438.5
Applied rewrites38.5%
if 1e-8 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) Initial program 96.4%
Taylor expanded in kx around 0
lower-sin.f6459.5
Applied rewrites59.5%
Final simplification45.9%
(FPCore (kx ky th)
:precision binary64
(if (<= (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))) 0.2)
(*
(/
(* (fma -0.16666666666666666 (* ky ky) 1.0) ky)
(/
(sqrt
(fma
(- 1.0 (cos (* 2.0 kx)))
2.0
(*
(*
(fma
(fma (* ky ky) 0.17777777777777778 -1.3333333333333333)
(* ky ky)
4.0)
ky)
ky)))
2.0))
(sin th))
(sin th)))
double code(double kx, double ky, double th) {
double tmp;
if ((sin(ky) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)))) <= 0.2) {
tmp = ((fma(-0.16666666666666666, (ky * ky), 1.0) * ky) / (sqrt(fma((1.0 - cos((2.0 * kx))), 2.0, ((fma(fma((ky * ky), 0.17777777777777778, -1.3333333333333333), (ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th);
} else {
tmp = sin(th);
}
return tmp;
}
function code(kx, ky, th) tmp = 0.0 if (Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) <= 0.2) tmp = Float64(Float64(Float64(fma(-0.16666666666666666, Float64(ky * ky), 1.0) * ky) / Float64(sqrt(fma(Float64(1.0 - cos(Float64(2.0 * kx))), 2.0, Float64(Float64(fma(fma(Float64(ky * ky), 0.17777777777777778, -1.3333333333333333), Float64(ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th)); else tmp = sin(th); end return tmp end
code[kx_, ky_, th_] := If[LessEqual[N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], 0.2], N[(N[(N[(N[(-0.16666666666666666 * N[(ky * ky), $MachinePrecision] + 1.0), $MachinePrecision] * ky), $MachinePrecision] / N[(N[Sqrt[N[(N[(1.0 - N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * 2.0 + N[(N[(N[(N[(N[(ky * ky), $MachinePrecision] * 0.17777777777777778 + -1.3333333333333333), $MachinePrecision] * N[(ky * ky), $MachinePrecision] + 4.0), $MachinePrecision] * ky), $MachinePrecision] * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}} \leq 0.2:\\
\;\;\;\;\frac{\mathsf{fma}\left(-0.16666666666666666, ky \cdot ky, 1\right) \cdot ky}{\frac{\sqrt{\mathsf{fma}\left(1 - \cos \left(2 \cdot kx\right), 2, \left(\mathsf{fma}\left(\mathsf{fma}\left(ky \cdot ky, 0.17777777777777778, -1.3333333333333333\right), ky \cdot ky, 4\right) \cdot ky\right) \cdot ky\right)}}{2}} \cdot \sin th\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\end{array}
if (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.20000000000000001Initial program 96.7%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites77.6%
Taylor expanded in ky around 0
*-commutativeN/A
lower-fma.f64N/A
lower--.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-*.f64N/A
Applied rewrites46.7%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f6445.8
Applied rewrites45.8%
if 0.20000000000000001 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) Initial program 96.3%
Taylor expanded in kx around 0
lower-sin.f6462.1
Applied rewrites62.1%
(FPCore (kx ky th) :precision binary64 (if (<= (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))) 0.02) (* (/ (* (fma (* ky ky) -0.16666666666666666 1.0) ky) (sin kx)) (sin th)) (sin th)))
double code(double kx, double ky, double th) {
double tmp;
if ((sin(ky) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)))) <= 0.02) {
tmp = ((fma((ky * ky), -0.16666666666666666, 1.0) * ky) / sin(kx)) * sin(th);
} else {
tmp = sin(th);
}
return tmp;
}
function code(kx, ky, th) tmp = 0.0 if (Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) <= 0.02) tmp = Float64(Float64(Float64(fma(Float64(ky * ky), -0.16666666666666666, 1.0) * ky) / sin(kx)) * sin(th)); else tmp = sin(th); end return tmp end
code[kx_, ky_, th_] := If[LessEqual[N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], 0.02], N[(N[(N[(N[(N[(ky * ky), $MachinePrecision] * -0.16666666666666666 + 1.0), $MachinePrecision] * ky), $MachinePrecision] / N[Sin[kx], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}} \leq 0.02:\\
\;\;\;\;\frac{\mathsf{fma}\left(ky \cdot ky, -0.16666666666666666, 1\right) \cdot ky}{\sin kx} \cdot \sin th\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\end{array}
if (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.0200000000000000004Initial program 96.7%
Taylor expanded in ky around 0
lower-sin.f6435.4
Applied rewrites35.4%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f6433.1
Applied rewrites33.1%
if 0.0200000000000000004 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) Initial program 96.4%
Taylor expanded in kx around 0
lower-sin.f6460.5
Applied rewrites60.5%
(FPCore (kx ky th) :precision binary64 (if (<= (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))) 0.02) (* (/ ky (sin kx)) (sin th)) (sin th)))
double code(double kx, double ky, double th) {
double tmp;
if ((sin(ky) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)))) <= 0.02) {
tmp = (ky / sin(kx)) * sin(th);
} else {
tmp = sin(th);
}
return tmp;
}
real(8) function code(kx, ky, th)
real(8), intent (in) :: kx
real(8), intent (in) :: ky
real(8), intent (in) :: th
real(8) :: tmp
if ((sin(ky) / sqrt(((sin(kx) ** 2.0d0) + (sin(ky) ** 2.0d0)))) <= 0.02d0) then
tmp = (ky / sin(kx)) * sin(th)
else
tmp = sin(th)
end if
code = tmp
end function
public static double code(double kx, double ky, double th) {
double tmp;
if ((Math.sin(ky) / Math.sqrt((Math.pow(Math.sin(kx), 2.0) + Math.pow(Math.sin(ky), 2.0)))) <= 0.02) {
tmp = (ky / Math.sin(kx)) * Math.sin(th);
} else {
tmp = Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): tmp = 0 if (math.sin(ky) / math.sqrt((math.pow(math.sin(kx), 2.0) + math.pow(math.sin(ky), 2.0)))) <= 0.02: tmp = (ky / math.sin(kx)) * math.sin(th) else: tmp = math.sin(th) return tmp
function code(kx, ky, th) tmp = 0.0 if (Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) <= 0.02) tmp = Float64(Float64(ky / sin(kx)) * sin(th)); else tmp = sin(th); end return tmp end
function tmp_2 = code(kx, ky, th) tmp = 0.0; if ((sin(ky) / sqrt(((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) <= 0.02) tmp = (ky / sin(kx)) * sin(th); else tmp = sin(th); end tmp_2 = tmp; end
code[kx_, ky_, th_] := If[LessEqual[N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], 0.02], N[(N[(ky / N[Sin[kx], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}} \leq 0.02:\\
\;\;\;\;\frac{ky}{\sin kx} \cdot \sin th\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\end{array}
if (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.0200000000000000004Initial program 96.7%
Taylor expanded in ky around 0
lower-/.f64N/A
lower-sin.f6433.2
Applied rewrites33.2%
if 0.0200000000000000004 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) Initial program 96.4%
Taylor expanded in kx around 0
lower-sin.f6460.5
Applied rewrites60.5%
(FPCore (kx ky th) :precision binary64 (if (<= (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))) 0.02) (/ (* (sin th) ky) (sin kx)) (sin th)))
double code(double kx, double ky, double th) {
double tmp;
if ((sin(ky) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)))) <= 0.02) {
tmp = (sin(th) * ky) / sin(kx);
} else {
tmp = sin(th);
}
return tmp;
}
real(8) function code(kx, ky, th)
real(8), intent (in) :: kx
real(8), intent (in) :: ky
real(8), intent (in) :: th
real(8) :: tmp
if ((sin(ky) / sqrt(((sin(kx) ** 2.0d0) + (sin(ky) ** 2.0d0)))) <= 0.02d0) then
tmp = (sin(th) * ky) / sin(kx)
else
tmp = sin(th)
end if
code = tmp
end function
public static double code(double kx, double ky, double th) {
double tmp;
if ((Math.sin(ky) / Math.sqrt((Math.pow(Math.sin(kx), 2.0) + Math.pow(Math.sin(ky), 2.0)))) <= 0.02) {
tmp = (Math.sin(th) * ky) / Math.sin(kx);
} else {
tmp = Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): tmp = 0 if (math.sin(ky) / math.sqrt((math.pow(math.sin(kx), 2.0) + math.pow(math.sin(ky), 2.0)))) <= 0.02: tmp = (math.sin(th) * ky) / math.sin(kx) else: tmp = math.sin(th) return tmp
function code(kx, ky, th) tmp = 0.0 if (Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) <= 0.02) tmp = Float64(Float64(sin(th) * ky) / sin(kx)); else tmp = sin(th); end return tmp end
function tmp_2 = code(kx, ky, th) tmp = 0.0; if ((sin(ky) / sqrt(((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) <= 0.02) tmp = (sin(th) * ky) / sin(kx); else tmp = sin(th); end tmp_2 = tmp; end
code[kx_, ky_, th_] := If[LessEqual[N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], 0.02], N[(N[(N[Sin[th], $MachinePrecision] * ky), $MachinePrecision] / N[Sin[kx], $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}} \leq 0.02:\\
\;\;\;\;\frac{\sin th \cdot ky}{\sin kx}\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\end{array}
if (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.0200000000000000004Initial program 96.7%
lift-/.f64N/A
clear-numN/A
lower-/.f64N/A
lower-/.f6496.6
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-pow.f64N/A
unpow2N/A
lower-hypot.f6499.5
Applied rewrites99.5%
Taylor expanded in ky around 0
lower-/.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f64N/A
lower-sin.f6433.3
Applied rewrites33.3%
if 0.0200000000000000004 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) Initial program 96.4%
Taylor expanded in kx around 0
lower-sin.f6460.5
Applied rewrites60.5%
Final simplification42.8%
(FPCore (kx ky th) :precision binary64 (if (<= (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))) 3.6e-66) (* (pow th 3.0) -0.16666666666666666) (sin th)))
double code(double kx, double ky, double th) {
double tmp;
if ((sin(ky) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)))) <= 3.6e-66) {
tmp = pow(th, 3.0) * -0.16666666666666666;
} else {
tmp = sin(th);
}
return tmp;
}
real(8) function code(kx, ky, th)
real(8), intent (in) :: kx
real(8), intent (in) :: ky
real(8), intent (in) :: th
real(8) :: tmp
if ((sin(ky) / sqrt(((sin(kx) ** 2.0d0) + (sin(ky) ** 2.0d0)))) <= 3.6d-66) then
tmp = (th ** 3.0d0) * (-0.16666666666666666d0)
else
tmp = sin(th)
end if
code = tmp
end function
public static double code(double kx, double ky, double th) {
double tmp;
if ((Math.sin(ky) / Math.sqrt((Math.pow(Math.sin(kx), 2.0) + Math.pow(Math.sin(ky), 2.0)))) <= 3.6e-66) {
tmp = Math.pow(th, 3.0) * -0.16666666666666666;
} else {
tmp = Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): tmp = 0 if (math.sin(ky) / math.sqrt((math.pow(math.sin(kx), 2.0) + math.pow(math.sin(ky), 2.0)))) <= 3.6e-66: tmp = math.pow(th, 3.0) * -0.16666666666666666 else: tmp = math.sin(th) return tmp
function code(kx, ky, th) tmp = 0.0 if (Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) <= 3.6e-66) tmp = Float64((th ^ 3.0) * -0.16666666666666666); else tmp = sin(th); end return tmp end
function tmp_2 = code(kx, ky, th) tmp = 0.0; if ((sin(ky) / sqrt(((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) <= 3.6e-66) tmp = (th ^ 3.0) * -0.16666666666666666; else tmp = sin(th); end tmp_2 = tmp; end
code[kx_, ky_, th_] := If[LessEqual[N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], 3.6e-66], N[(N[Power[th, 3.0], $MachinePrecision] * -0.16666666666666666), $MachinePrecision], N[Sin[th], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}} \leq 3.6 \cdot 10^{-66}:\\
\;\;\;\;{th}^{3} \cdot -0.16666666666666666\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\end{array}
if (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 3.60000000000000012e-66Initial program 96.5%
Taylor expanded in kx around 0
lower-sin.f643.6
Applied rewrites3.6%
Taylor expanded in th around 0
Applied rewrites3.6%
Taylor expanded in th around inf
Applied rewrites13.7%
if 3.60000000000000012e-66 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) Initial program 96.7%
Taylor expanded in kx around 0
lower-sin.f6455.4
Applied rewrites55.4%
(FPCore (kx ky th)
:precision binary64
(if (<= (sin ky) 2e-191)
(pow (/ (/ (sin kx) (sin th)) (sin ky)) -1.0)
(if (<= (sin ky) 0.01)
(*
(/
(*
(fma
(fma 0.008333333333333333 (* ky ky) -0.16666666666666666)
(* ky ky)
1.0)
ky)
(/
(sqrt
(fma
(- 1.0 (cos (* 2.0 kx)))
2.0
(*
(*
(fma
(fma (* ky ky) 0.17777777777777778 -1.3333333333333333)
(* ky ky)
4.0)
ky)
ky)))
2.0))
(sin th))
(sin th))))
double code(double kx, double ky, double th) {
double tmp;
if (sin(ky) <= 2e-191) {
tmp = pow(((sin(kx) / sin(th)) / sin(ky)), -1.0);
} else if (sin(ky) <= 0.01) {
tmp = ((fma(fma(0.008333333333333333, (ky * ky), -0.16666666666666666), (ky * ky), 1.0) * ky) / (sqrt(fma((1.0 - cos((2.0 * kx))), 2.0, ((fma(fma((ky * ky), 0.17777777777777778, -1.3333333333333333), (ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th);
} else {
tmp = sin(th);
}
return tmp;
}
function code(kx, ky, th) tmp = 0.0 if (sin(ky) <= 2e-191) tmp = Float64(Float64(sin(kx) / sin(th)) / sin(ky)) ^ -1.0; elseif (sin(ky) <= 0.01) tmp = Float64(Float64(Float64(fma(fma(0.008333333333333333, Float64(ky * ky), -0.16666666666666666), Float64(ky * ky), 1.0) * ky) / Float64(sqrt(fma(Float64(1.0 - cos(Float64(2.0 * kx))), 2.0, Float64(Float64(fma(fma(Float64(ky * ky), 0.17777777777777778, -1.3333333333333333), Float64(ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th)); else tmp = sin(th); end return tmp end
code[kx_, ky_, th_] := If[LessEqual[N[Sin[ky], $MachinePrecision], 2e-191], N[Power[N[(N[(N[Sin[kx], $MachinePrecision] / N[Sin[th], $MachinePrecision]), $MachinePrecision] / N[Sin[ky], $MachinePrecision]), $MachinePrecision], -1.0], $MachinePrecision], If[LessEqual[N[Sin[ky], $MachinePrecision], 0.01], N[(N[(N[(N[(N[(0.008333333333333333 * N[(ky * ky), $MachinePrecision] + -0.16666666666666666), $MachinePrecision] * N[(ky * ky), $MachinePrecision] + 1.0), $MachinePrecision] * ky), $MachinePrecision] / N[(N[Sqrt[N[(N[(1.0 - N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * 2.0 + N[(N[(N[(N[(N[(ky * ky), $MachinePrecision] * 0.17777777777777778 + -1.3333333333333333), $MachinePrecision] * N[(ky * ky), $MachinePrecision] + 4.0), $MachinePrecision] * ky), $MachinePrecision] * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\sin ky \leq 2 \cdot 10^{-191}:\\
\;\;\;\;{\left(\frac{\frac{\sin kx}{\sin th}}{\sin ky}\right)}^{-1}\\
\mathbf{elif}\;\sin ky \leq 0.01:\\
\;\;\;\;\frac{\mathsf{fma}\left(\mathsf{fma}\left(0.008333333333333333, ky \cdot ky, -0.16666666666666666\right), ky \cdot ky, 1\right) \cdot ky}{\frac{\sqrt{\mathsf{fma}\left(1 - \cos \left(2 \cdot kx\right), 2, \left(\mathsf{fma}\left(\mathsf{fma}\left(ky \cdot ky, 0.17777777777777778, -1.3333333333333333\right), ky \cdot ky, 4\right) \cdot ky\right) \cdot ky\right)}}{2}} \cdot \sin th\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\end{array}
if (sin.f64 ky) < 2e-191Initial program 94.7%
Taylor expanded in ky around 0
lower-sin.f6430.3
Applied rewrites30.3%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
lower-/.f64N/A
*-commutativeN/A
lower-*.f6430.3
Applied rewrites30.3%
lift-/.f64N/A
clear-numN/A
lower-/.f64N/A
lift-*.f64N/A
associate-/r*N/A
lower-/.f64N/A
lower-/.f6429.9
Applied rewrites29.9%
if 2e-191 < (sin.f64 ky) < 0.0100000000000000002Initial program 97.2%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites61.5%
Taylor expanded in ky around 0
*-commutativeN/A
lower-fma.f64N/A
lower--.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-*.f64N/A
Applied rewrites86.0%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
sub-negN/A
metadata-evalN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f64N/A
unpow2N/A
lower-*.f6486.0
Applied rewrites86.0%
if 0.0100000000000000002 < (sin.f64 ky) Initial program 99.6%
Taylor expanded in kx around 0
lower-sin.f6456.7
Applied rewrites56.7%
Final simplification46.7%
(FPCore (kx ky th)
:precision binary64
(if (<= (sin ky) 2e-191)
(pow (/ (sin kx) (* (sin th) (sin ky))) -1.0)
(if (<= (sin ky) 0.01)
(*
(/
(*
(fma
(fma 0.008333333333333333 (* ky ky) -0.16666666666666666)
(* ky ky)
1.0)
ky)
(/
(sqrt
(fma
(- 1.0 (cos (* 2.0 kx)))
2.0
(*
(*
(fma
(fma (* ky ky) 0.17777777777777778 -1.3333333333333333)
(* ky ky)
4.0)
ky)
ky)))
2.0))
(sin th))
(sin th))))
double code(double kx, double ky, double th) {
double tmp;
if (sin(ky) <= 2e-191) {
tmp = pow((sin(kx) / (sin(th) * sin(ky))), -1.0);
} else if (sin(ky) <= 0.01) {
tmp = ((fma(fma(0.008333333333333333, (ky * ky), -0.16666666666666666), (ky * ky), 1.0) * ky) / (sqrt(fma((1.0 - cos((2.0 * kx))), 2.0, ((fma(fma((ky * ky), 0.17777777777777778, -1.3333333333333333), (ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th);
} else {
tmp = sin(th);
}
return tmp;
}
function code(kx, ky, th) tmp = 0.0 if (sin(ky) <= 2e-191) tmp = Float64(sin(kx) / Float64(sin(th) * sin(ky))) ^ -1.0; elseif (sin(ky) <= 0.01) tmp = Float64(Float64(Float64(fma(fma(0.008333333333333333, Float64(ky * ky), -0.16666666666666666), Float64(ky * ky), 1.0) * ky) / Float64(sqrt(fma(Float64(1.0 - cos(Float64(2.0 * kx))), 2.0, Float64(Float64(fma(fma(Float64(ky * ky), 0.17777777777777778, -1.3333333333333333), Float64(ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th)); else tmp = sin(th); end return tmp end
code[kx_, ky_, th_] := If[LessEqual[N[Sin[ky], $MachinePrecision], 2e-191], N[Power[N[(N[Sin[kx], $MachinePrecision] / N[(N[Sin[th], $MachinePrecision] * N[Sin[ky], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], -1.0], $MachinePrecision], If[LessEqual[N[Sin[ky], $MachinePrecision], 0.01], N[(N[(N[(N[(N[(0.008333333333333333 * N[(ky * ky), $MachinePrecision] + -0.16666666666666666), $MachinePrecision] * N[(ky * ky), $MachinePrecision] + 1.0), $MachinePrecision] * ky), $MachinePrecision] / N[(N[Sqrt[N[(N[(1.0 - N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * 2.0 + N[(N[(N[(N[(N[(ky * ky), $MachinePrecision] * 0.17777777777777778 + -1.3333333333333333), $MachinePrecision] * N[(ky * ky), $MachinePrecision] + 4.0), $MachinePrecision] * ky), $MachinePrecision] * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\sin ky \leq 2 \cdot 10^{-191}:\\
\;\;\;\;{\left(\frac{\sin kx}{\sin th \cdot \sin ky}\right)}^{-1}\\
\mathbf{elif}\;\sin ky \leq 0.01:\\
\;\;\;\;\frac{\mathsf{fma}\left(\mathsf{fma}\left(0.008333333333333333, ky \cdot ky, -0.16666666666666666\right), ky \cdot ky, 1\right) \cdot ky}{\frac{\sqrt{\mathsf{fma}\left(1 - \cos \left(2 \cdot kx\right), 2, \left(\mathsf{fma}\left(\mathsf{fma}\left(ky \cdot ky, 0.17777777777777778, -1.3333333333333333\right), ky \cdot ky, 4\right) \cdot ky\right) \cdot ky\right)}}{2}} \cdot \sin th\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\end{array}
if (sin.f64 ky) < 2e-191Initial program 94.7%
Taylor expanded in ky around 0
lower-sin.f6430.3
Applied rewrites30.3%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
clear-numN/A
lower-/.f64N/A
lower-/.f64N/A
*-commutativeN/A
lower-*.f6430.0
Applied rewrites30.0%
if 2e-191 < (sin.f64 ky) < 0.0100000000000000002Initial program 97.2%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites61.5%
Taylor expanded in ky around 0
*-commutativeN/A
lower-fma.f64N/A
lower--.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-*.f64N/A
Applied rewrites86.0%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
sub-negN/A
metadata-evalN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f64N/A
unpow2N/A
lower-*.f6486.0
Applied rewrites86.0%
if 0.0100000000000000002 < (sin.f64 ky) Initial program 99.6%
Taylor expanded in kx around 0
lower-sin.f6456.7
Applied rewrites56.7%
Final simplification46.8%
(FPCore (kx ky th)
:precision binary64
(if (<= (sin ky) 2e-191)
(/ (* (sin th) (sin ky)) (sin kx))
(if (<= (sin ky) 0.01)
(*
(/
(*
(fma
(fma 0.008333333333333333 (* ky ky) -0.16666666666666666)
(* ky ky)
1.0)
ky)
(/
(sqrt
(fma
(- 1.0 (cos (* 2.0 kx)))
2.0
(*
(*
(fma
(fma (* ky ky) 0.17777777777777778 -1.3333333333333333)
(* ky ky)
4.0)
ky)
ky)))
2.0))
(sin th))
(sin th))))
double code(double kx, double ky, double th) {
double tmp;
if (sin(ky) <= 2e-191) {
tmp = (sin(th) * sin(ky)) / sin(kx);
} else if (sin(ky) <= 0.01) {
tmp = ((fma(fma(0.008333333333333333, (ky * ky), -0.16666666666666666), (ky * ky), 1.0) * ky) / (sqrt(fma((1.0 - cos((2.0 * kx))), 2.0, ((fma(fma((ky * ky), 0.17777777777777778, -1.3333333333333333), (ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th);
} else {
tmp = sin(th);
}
return tmp;
}
function code(kx, ky, th) tmp = 0.0 if (sin(ky) <= 2e-191) tmp = Float64(Float64(sin(th) * sin(ky)) / sin(kx)); elseif (sin(ky) <= 0.01) tmp = Float64(Float64(Float64(fma(fma(0.008333333333333333, Float64(ky * ky), -0.16666666666666666), Float64(ky * ky), 1.0) * ky) / Float64(sqrt(fma(Float64(1.0 - cos(Float64(2.0 * kx))), 2.0, Float64(Float64(fma(fma(Float64(ky * ky), 0.17777777777777778, -1.3333333333333333), Float64(ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th)); else tmp = sin(th); end return tmp end
code[kx_, ky_, th_] := If[LessEqual[N[Sin[ky], $MachinePrecision], 2e-191], N[(N[(N[Sin[th], $MachinePrecision] * N[Sin[ky], $MachinePrecision]), $MachinePrecision] / N[Sin[kx], $MachinePrecision]), $MachinePrecision], If[LessEqual[N[Sin[ky], $MachinePrecision], 0.01], N[(N[(N[(N[(N[(0.008333333333333333 * N[(ky * ky), $MachinePrecision] + -0.16666666666666666), $MachinePrecision] * N[(ky * ky), $MachinePrecision] + 1.0), $MachinePrecision] * ky), $MachinePrecision] / N[(N[Sqrt[N[(N[(1.0 - N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * 2.0 + N[(N[(N[(N[(N[(ky * ky), $MachinePrecision] * 0.17777777777777778 + -1.3333333333333333), $MachinePrecision] * N[(ky * ky), $MachinePrecision] + 4.0), $MachinePrecision] * ky), $MachinePrecision] * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\sin ky \leq 2 \cdot 10^{-191}:\\
\;\;\;\;\frac{\sin th \cdot \sin ky}{\sin kx}\\
\mathbf{elif}\;\sin ky \leq 0.01:\\
\;\;\;\;\frac{\mathsf{fma}\left(\mathsf{fma}\left(0.008333333333333333, ky \cdot ky, -0.16666666666666666\right), ky \cdot ky, 1\right) \cdot ky}{\frac{\sqrt{\mathsf{fma}\left(1 - \cos \left(2 \cdot kx\right), 2, \left(\mathsf{fma}\left(\mathsf{fma}\left(ky \cdot ky, 0.17777777777777778, -1.3333333333333333\right), ky \cdot ky, 4\right) \cdot ky\right) \cdot ky\right)}}{2}} \cdot \sin th\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\end{array}
if (sin.f64 ky) < 2e-191Initial program 94.7%
Taylor expanded in ky around 0
lower-sin.f6430.3
Applied rewrites30.3%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
lower-/.f64N/A
*-commutativeN/A
lower-*.f6430.3
Applied rewrites30.3%
if 2e-191 < (sin.f64 ky) < 0.0100000000000000002Initial program 97.2%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites61.5%
Taylor expanded in ky around 0
*-commutativeN/A
lower-fma.f64N/A
lower--.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-*.f64N/A
Applied rewrites86.0%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
sub-negN/A
metadata-evalN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f64N/A
unpow2N/A
lower-*.f6486.0
Applied rewrites86.0%
if 0.0100000000000000002 < (sin.f64 ky) Initial program 99.6%
Taylor expanded in kx around 0
lower-sin.f6456.7
Applied rewrites56.7%
(FPCore (kx ky th)
:precision binary64
(if (<= (sin ky) 2e-191)
(* (/ (sin ky) (sin kx)) (sin th))
(if (<= (sin ky) 0.01)
(*
(/
(*
(fma
(fma 0.008333333333333333 (* ky ky) -0.16666666666666666)
(* ky ky)
1.0)
ky)
(/
(sqrt
(fma
(- 1.0 (cos (* 2.0 kx)))
2.0
(*
(*
(fma
(fma (* ky ky) 0.17777777777777778 -1.3333333333333333)
(* ky ky)
4.0)
ky)
ky)))
2.0))
(sin th))
(sin th))))
double code(double kx, double ky, double th) {
double tmp;
if (sin(ky) <= 2e-191) {
tmp = (sin(ky) / sin(kx)) * sin(th);
} else if (sin(ky) <= 0.01) {
tmp = ((fma(fma(0.008333333333333333, (ky * ky), -0.16666666666666666), (ky * ky), 1.0) * ky) / (sqrt(fma((1.0 - cos((2.0 * kx))), 2.0, ((fma(fma((ky * ky), 0.17777777777777778, -1.3333333333333333), (ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th);
} else {
tmp = sin(th);
}
return tmp;
}
function code(kx, ky, th) tmp = 0.0 if (sin(ky) <= 2e-191) tmp = Float64(Float64(sin(ky) / sin(kx)) * sin(th)); elseif (sin(ky) <= 0.01) tmp = Float64(Float64(Float64(fma(fma(0.008333333333333333, Float64(ky * ky), -0.16666666666666666), Float64(ky * ky), 1.0) * ky) / Float64(sqrt(fma(Float64(1.0 - cos(Float64(2.0 * kx))), 2.0, Float64(Float64(fma(fma(Float64(ky * ky), 0.17777777777777778, -1.3333333333333333), Float64(ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th)); else tmp = sin(th); end return tmp end
code[kx_, ky_, th_] := If[LessEqual[N[Sin[ky], $MachinePrecision], 2e-191], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sin[kx], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[N[Sin[ky], $MachinePrecision], 0.01], N[(N[(N[(N[(N[(0.008333333333333333 * N[(ky * ky), $MachinePrecision] + -0.16666666666666666), $MachinePrecision] * N[(ky * ky), $MachinePrecision] + 1.0), $MachinePrecision] * ky), $MachinePrecision] / N[(N[Sqrt[N[(N[(1.0 - N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * 2.0 + N[(N[(N[(N[(N[(ky * ky), $MachinePrecision] * 0.17777777777777778 + -1.3333333333333333), $MachinePrecision] * N[(ky * ky), $MachinePrecision] + 4.0), $MachinePrecision] * ky), $MachinePrecision] * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\sin ky \leq 2 \cdot 10^{-191}:\\
\;\;\;\;\frac{\sin ky}{\sin kx} \cdot \sin th\\
\mathbf{elif}\;\sin ky \leq 0.01:\\
\;\;\;\;\frac{\mathsf{fma}\left(\mathsf{fma}\left(0.008333333333333333, ky \cdot ky, -0.16666666666666666\right), ky \cdot ky, 1\right) \cdot ky}{\frac{\sqrt{\mathsf{fma}\left(1 - \cos \left(2 \cdot kx\right), 2, \left(\mathsf{fma}\left(\mathsf{fma}\left(ky \cdot ky, 0.17777777777777778, -1.3333333333333333\right), ky \cdot ky, 4\right) \cdot ky\right) \cdot ky\right)}}{2}} \cdot \sin th\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\end{array}
if (sin.f64 ky) < 2e-191Initial program 94.7%
Taylor expanded in ky around 0
lower-sin.f6430.3
Applied rewrites30.3%
if 2e-191 < (sin.f64 ky) < 0.0100000000000000002Initial program 97.2%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites61.5%
Taylor expanded in ky around 0
*-commutativeN/A
lower-fma.f64N/A
lower--.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-*.f64N/A
Applied rewrites86.0%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
sub-negN/A
metadata-evalN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f64N/A
unpow2N/A
lower-*.f6486.0
Applied rewrites86.0%
if 0.0100000000000000002 < (sin.f64 ky) Initial program 99.6%
Taylor expanded in kx around 0
lower-sin.f6456.7
Applied rewrites56.7%
(FPCore (kx ky th) :precision binary64 (* (/ (sin th) (hypot (sin ky) (sin kx))) (sin ky)))
double code(double kx, double ky, double th) {
return (sin(th) / hypot(sin(ky), sin(kx))) * sin(ky);
}
public static double code(double kx, double ky, double th) {
return (Math.sin(th) / Math.hypot(Math.sin(ky), Math.sin(kx))) * Math.sin(ky);
}
def code(kx, ky, th): return (math.sin(th) / math.hypot(math.sin(ky), math.sin(kx))) * math.sin(ky)
function code(kx, ky, th) return Float64(Float64(sin(th) / hypot(sin(ky), sin(kx))) * sin(ky)) end
function tmp = code(kx, ky, th) tmp = (sin(th) / hypot(sin(ky), sin(kx))) * sin(ky); end
code[kx_, ky_, th_] := N[(N[(N[Sin[th], $MachinePrecision] / N[Sqrt[N[Sin[ky], $MachinePrecision] ^ 2 + N[Sin[kx], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision] * N[Sin[ky], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\frac{\sin th}{\mathsf{hypot}\left(\sin ky, \sin kx\right)} \cdot \sin ky
\end{array}
Initial program 96.6%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
associate-/l*N/A
*-commutativeN/A
lower-*.f64N/A
lower-/.f6496.5
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-pow.f64N/A
unpow2N/A
lower-hypot.f6499.5
Applied rewrites99.5%
(FPCore (kx ky th)
:precision binary64
(if (<= ky 2.1e-5)
(* (/ -1.0 (* (/ -1.0 ky) (hypot (sin kx) (sin ky)))) (sin th))
(*
(/
(* (sin ky) 2.0)
(sqrt (* 2.0 (+ (- 1.0 (cos (* 2.0 ky))) (- 1.0 (cos (* 2.0 kx)))))))
(sin th))))
double code(double kx, double ky, double th) {
double tmp;
if (ky <= 2.1e-5) {
tmp = (-1.0 / ((-1.0 / ky) * hypot(sin(kx), sin(ky)))) * sin(th);
} else {
tmp = ((sin(ky) * 2.0) / sqrt((2.0 * ((1.0 - cos((2.0 * ky))) + (1.0 - cos((2.0 * kx))))))) * sin(th);
}
return tmp;
}
public static double code(double kx, double ky, double th) {
double tmp;
if (ky <= 2.1e-5) {
tmp = (-1.0 / ((-1.0 / ky) * Math.hypot(Math.sin(kx), Math.sin(ky)))) * Math.sin(th);
} else {
tmp = ((Math.sin(ky) * 2.0) / Math.sqrt((2.0 * ((1.0 - Math.cos((2.0 * ky))) + (1.0 - Math.cos((2.0 * kx))))))) * Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): tmp = 0 if ky <= 2.1e-5: tmp = (-1.0 / ((-1.0 / ky) * math.hypot(math.sin(kx), math.sin(ky)))) * math.sin(th) else: tmp = ((math.sin(ky) * 2.0) / math.sqrt((2.0 * ((1.0 - math.cos((2.0 * ky))) + (1.0 - math.cos((2.0 * kx))))))) * math.sin(th) return tmp
function code(kx, ky, th) tmp = 0.0 if (ky <= 2.1e-5) tmp = Float64(Float64(-1.0 / Float64(Float64(-1.0 / ky) * hypot(sin(kx), sin(ky)))) * sin(th)); else tmp = Float64(Float64(Float64(sin(ky) * 2.0) / sqrt(Float64(2.0 * Float64(Float64(1.0 - cos(Float64(2.0 * ky))) + Float64(1.0 - cos(Float64(2.0 * kx))))))) * sin(th)); end return tmp end
function tmp_2 = code(kx, ky, th) tmp = 0.0; if (ky <= 2.1e-5) tmp = (-1.0 / ((-1.0 / ky) * hypot(sin(kx), sin(ky)))) * sin(th); else tmp = ((sin(ky) * 2.0) / sqrt((2.0 * ((1.0 - cos((2.0 * ky))) + (1.0 - cos((2.0 * kx))))))) * sin(th); end tmp_2 = tmp; end
code[kx_, ky_, th_] := If[LessEqual[ky, 2.1e-5], N[(N[(-1.0 / N[(N[(-1.0 / ky), $MachinePrecision] * N[Sqrt[N[Sin[kx], $MachinePrecision] ^ 2 + N[Sin[ky], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], N[(N[(N[(N[Sin[ky], $MachinePrecision] * 2.0), $MachinePrecision] / N[Sqrt[N[(2.0 * N[(N[(1.0 - N[Cos[N[(2.0 * ky), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] + N[(1.0 - N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;ky \leq 2.1 \cdot 10^{-5}:\\
\;\;\;\;\frac{-1}{\frac{-1}{ky} \cdot \mathsf{hypot}\left(\sin kx, \sin ky\right)} \cdot \sin th\\
\mathbf{else}:\\
\;\;\;\;\frac{\sin ky \cdot 2}{\sqrt{2 \cdot \left(\left(1 - \cos \left(2 \cdot ky\right)\right) + \left(1 - \cos \left(2 \cdot kx\right)\right)\right)}} \cdot \sin th\\
\end{array}
\end{array}
if ky < 2.09999999999999988e-5Initial program 95.5%
lift-/.f64N/A
clear-numN/A
lower-/.f64N/A
lower-/.f6495.4
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-pow.f64N/A
unpow2N/A
lower-hypot.f6499.6
Applied rewrites99.6%
Applied rewrites99.4%
Taylor expanded in ky around 0
lower-/.f6460.6
Applied rewrites60.6%
if 2.09999999999999988e-5 < ky Initial program 99.5%
lift-/.f64N/A
clear-numN/A
lower-/.f64N/A
lower-/.f6499.6
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-pow.f64N/A
unpow2N/A
lower-hypot.f6499.6
Applied rewrites99.6%
Applied rewrites98.7%
Final simplification70.7%
(FPCore (kx ky th)
:precision binary64
(if (<= ky 2.1e-5)
(* (/ -1.0 (* (/ -1.0 ky) (hypot (sin kx) (sin ky)))) (sin th))
(*
(* 2.0 (* (sin th) (sin ky)))
(sqrt (/ 0.5 (- 1.0 (- (cos (* 2.0 kx)) (- 1.0 (cos (* 2.0 ky))))))))))
double code(double kx, double ky, double th) {
double tmp;
if (ky <= 2.1e-5) {
tmp = (-1.0 / ((-1.0 / ky) * hypot(sin(kx), sin(ky)))) * sin(th);
} else {
tmp = (2.0 * (sin(th) * sin(ky))) * sqrt((0.5 / (1.0 - (cos((2.0 * kx)) - (1.0 - cos((2.0 * ky)))))));
}
return tmp;
}
public static double code(double kx, double ky, double th) {
double tmp;
if (ky <= 2.1e-5) {
tmp = (-1.0 / ((-1.0 / ky) * Math.hypot(Math.sin(kx), Math.sin(ky)))) * Math.sin(th);
} else {
tmp = (2.0 * (Math.sin(th) * Math.sin(ky))) * Math.sqrt((0.5 / (1.0 - (Math.cos((2.0 * kx)) - (1.0 - Math.cos((2.0 * ky)))))));
}
return tmp;
}
def code(kx, ky, th): tmp = 0 if ky <= 2.1e-5: tmp = (-1.0 / ((-1.0 / ky) * math.hypot(math.sin(kx), math.sin(ky)))) * math.sin(th) else: tmp = (2.0 * (math.sin(th) * math.sin(ky))) * math.sqrt((0.5 / (1.0 - (math.cos((2.0 * kx)) - (1.0 - math.cos((2.0 * ky))))))) return tmp
function code(kx, ky, th) tmp = 0.0 if (ky <= 2.1e-5) tmp = Float64(Float64(-1.0 / Float64(Float64(-1.0 / ky) * hypot(sin(kx), sin(ky)))) * sin(th)); else tmp = Float64(Float64(2.0 * Float64(sin(th) * sin(ky))) * sqrt(Float64(0.5 / Float64(1.0 - Float64(cos(Float64(2.0 * kx)) - Float64(1.0 - cos(Float64(2.0 * ky)))))))); end return tmp end
function tmp_2 = code(kx, ky, th) tmp = 0.0; if (ky <= 2.1e-5) tmp = (-1.0 / ((-1.0 / ky) * hypot(sin(kx), sin(ky)))) * sin(th); else tmp = (2.0 * (sin(th) * sin(ky))) * sqrt((0.5 / (1.0 - (cos((2.0 * kx)) - (1.0 - cos((2.0 * ky))))))); end tmp_2 = tmp; end
code[kx_, ky_, th_] := If[LessEqual[ky, 2.1e-5], N[(N[(-1.0 / N[(N[(-1.0 / ky), $MachinePrecision] * N[Sqrt[N[Sin[kx], $MachinePrecision] ^ 2 + N[Sin[ky], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], N[(N[(2.0 * N[(N[Sin[th], $MachinePrecision] * N[Sin[ky], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Sqrt[N[(0.5 / N[(1.0 - N[(N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision] - N[(1.0 - N[Cos[N[(2.0 * ky), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;ky \leq 2.1 \cdot 10^{-5}:\\
\;\;\;\;\frac{-1}{\frac{-1}{ky} \cdot \mathsf{hypot}\left(\sin kx, \sin ky\right)} \cdot \sin th\\
\mathbf{else}:\\
\;\;\;\;\left(2 \cdot \left(\sin th \cdot \sin ky\right)\right) \cdot \sqrt{\frac{0.5}{1 - \left(\cos \left(2 \cdot kx\right) - \left(1 - \cos \left(2 \cdot ky\right)\right)\right)}}\\
\end{array}
\end{array}
if ky < 2.09999999999999988e-5Initial program 95.5%
lift-/.f64N/A
clear-numN/A
lower-/.f64N/A
lower-/.f6495.4
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-pow.f64N/A
unpow2N/A
lower-hypot.f6499.6
Applied rewrites99.6%
Applied rewrites99.4%
Taylor expanded in ky around 0
lower-/.f6460.6
Applied rewrites60.6%
if 2.09999999999999988e-5 < ky Initial program 99.5%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites98.7%
Taylor expanded in ky around 0
*-commutativeN/A
lower-fma.f64N/A
lower--.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-*.f64N/A
Applied rewrites5.6%
Taylor expanded in kx around inf
associate-*r*N/A
lower-*.f64N/A
lower-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f64N/A
lower-sin.f64N/A
lower-sqrt.f64N/A
distribute-lft-outN/A
associate-/r*N/A
metadata-evalN/A
lower-/.f64N/A
associate-+l-N/A
lower--.f64N/A
Applied rewrites98.8%
Final simplification70.7%
(FPCore (kx ky th)
:precision binary64
(if (<= ky 2.4e-191)
(pow (/ (/ (sin kx) (sin th)) (sin ky)) -1.0)
(if (<= ky 0.68)
(*
(/
(*
(fma
(fma 0.008333333333333333 (* ky ky) -0.16666666666666666)
(* ky ky)
1.0)
ky)
(/
(sqrt
(fma
(- 1.0 (cos (* 2.0 kx)))
2.0
(*
(*
(fma
(fma (* ky ky) 0.17777777777777778 -1.3333333333333333)
(* ky ky)
4.0)
ky)
ky)))
2.0))
(sin th))
(*
(/ (sin ky) (/ (sqrt (* (- 1.0 (cos (* 2.0 ky))) 2.0)) 2.0))
(sin th)))))
double code(double kx, double ky, double th) {
double tmp;
if (ky <= 2.4e-191) {
tmp = pow(((sin(kx) / sin(th)) / sin(ky)), -1.0);
} else if (ky <= 0.68) {
tmp = ((fma(fma(0.008333333333333333, (ky * ky), -0.16666666666666666), (ky * ky), 1.0) * ky) / (sqrt(fma((1.0 - cos((2.0 * kx))), 2.0, ((fma(fma((ky * ky), 0.17777777777777778, -1.3333333333333333), (ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th);
} else {
tmp = (sin(ky) / (sqrt(((1.0 - cos((2.0 * ky))) * 2.0)) / 2.0)) * sin(th);
}
return tmp;
}
function code(kx, ky, th) tmp = 0.0 if (ky <= 2.4e-191) tmp = Float64(Float64(sin(kx) / sin(th)) / sin(ky)) ^ -1.0; elseif (ky <= 0.68) tmp = Float64(Float64(Float64(fma(fma(0.008333333333333333, Float64(ky * ky), -0.16666666666666666), Float64(ky * ky), 1.0) * ky) / Float64(sqrt(fma(Float64(1.0 - cos(Float64(2.0 * kx))), 2.0, Float64(Float64(fma(fma(Float64(ky * ky), 0.17777777777777778, -1.3333333333333333), Float64(ky * ky), 4.0) * ky) * ky))) / 2.0)) * sin(th)); else tmp = Float64(Float64(sin(ky) / Float64(sqrt(Float64(Float64(1.0 - cos(Float64(2.0 * ky))) * 2.0)) / 2.0)) * sin(th)); end return tmp end
code[kx_, ky_, th_] := If[LessEqual[ky, 2.4e-191], N[Power[N[(N[(N[Sin[kx], $MachinePrecision] / N[Sin[th], $MachinePrecision]), $MachinePrecision] / N[Sin[ky], $MachinePrecision]), $MachinePrecision], -1.0], $MachinePrecision], If[LessEqual[ky, 0.68], N[(N[(N[(N[(N[(0.008333333333333333 * N[(ky * ky), $MachinePrecision] + -0.16666666666666666), $MachinePrecision] * N[(ky * ky), $MachinePrecision] + 1.0), $MachinePrecision] * ky), $MachinePrecision] / N[(N[Sqrt[N[(N[(1.0 - N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * 2.0 + N[(N[(N[(N[(N[(ky * ky), $MachinePrecision] * 0.17777777777777778 + -1.3333333333333333), $MachinePrecision] * N[(ky * ky), $MachinePrecision] + 4.0), $MachinePrecision] * ky), $MachinePrecision] * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], N[(N[(N[Sin[ky], $MachinePrecision] / N[(N[Sqrt[N[(N[(1.0 - N[Cos[N[(2.0 * ky), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * 2.0), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;ky \leq 2.4 \cdot 10^{-191}:\\
\;\;\;\;{\left(\frac{\frac{\sin kx}{\sin th}}{\sin ky}\right)}^{-1}\\
\mathbf{elif}\;ky \leq 0.68:\\
\;\;\;\;\frac{\mathsf{fma}\left(\mathsf{fma}\left(0.008333333333333333, ky \cdot ky, -0.16666666666666666\right), ky \cdot ky, 1\right) \cdot ky}{\frac{\sqrt{\mathsf{fma}\left(1 - \cos \left(2 \cdot kx\right), 2, \left(\mathsf{fma}\left(\mathsf{fma}\left(ky \cdot ky, 0.17777777777777778, -1.3333333333333333\right), ky \cdot ky, 4\right) \cdot ky\right) \cdot ky\right)}}{2}} \cdot \sin th\\
\mathbf{else}:\\
\;\;\;\;\frac{\sin ky}{\frac{\sqrt{\left(1 - \cos \left(2 \cdot ky\right)\right) \cdot 2}}{2}} \cdot \sin th\\
\end{array}
\end{array}
if ky < 2.3999999999999999e-191Initial program 95.0%
Taylor expanded in ky around 0
lower-sin.f6428.7
Applied rewrites28.7%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
lower-/.f64N/A
*-commutativeN/A
lower-*.f6428.8
Applied rewrites28.8%
lift-/.f64N/A
clear-numN/A
lower-/.f64N/A
lift-*.f64N/A
associate-/r*N/A
lower-/.f64N/A
lower-/.f6428.4
Applied rewrites28.4%
if 2.3999999999999999e-191 < ky < 0.680000000000000049Initial program 97.2%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites61.5%
Taylor expanded in ky around 0
*-commutativeN/A
lower-fma.f64N/A
lower--.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-*.f64N/A
Applied rewrites86.0%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
sub-negN/A
metadata-evalN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f64N/A
unpow2N/A
lower-*.f6486.0
Applied rewrites86.0%
if 0.680000000000000049 < ky Initial program 99.5%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites98.9%
Taylor expanded in kx around 0
*-commutativeN/A
lower-*.f64N/A
lower--.f64N/A
lower-cos.f64N/A
lower-*.f6453.4
Applied rewrites53.4%
Final simplification44.2%
(FPCore (kx ky th)
:precision binary64
(if (<= kx 1.15e-114)
(sin th)
(if (<= kx 2.9e-6)
(* (/ (sin ky) (sqrt (+ (* kx kx) (* ky ky)))) (sin th))
(*
(/ (sin ky) (/ (sqrt (* (- 1.0 (cos (* 2.0 kx))) 2.0)) 2.0))
(sin th)))))
double code(double kx, double ky, double th) {
double tmp;
if (kx <= 1.15e-114) {
tmp = sin(th);
} else if (kx <= 2.9e-6) {
tmp = (sin(ky) / sqrt(((kx * kx) + (ky * ky)))) * sin(th);
} else {
tmp = (sin(ky) / (sqrt(((1.0 - cos((2.0 * kx))) * 2.0)) / 2.0)) * sin(th);
}
return tmp;
}
real(8) function code(kx, ky, th)
real(8), intent (in) :: kx
real(8), intent (in) :: ky
real(8), intent (in) :: th
real(8) :: tmp
if (kx <= 1.15d-114) then
tmp = sin(th)
else if (kx <= 2.9d-6) then
tmp = (sin(ky) / sqrt(((kx * kx) + (ky * ky)))) * sin(th)
else
tmp = (sin(ky) / (sqrt(((1.0d0 - cos((2.0d0 * kx))) * 2.0d0)) / 2.0d0)) * sin(th)
end if
code = tmp
end function
public static double code(double kx, double ky, double th) {
double tmp;
if (kx <= 1.15e-114) {
tmp = Math.sin(th);
} else if (kx <= 2.9e-6) {
tmp = (Math.sin(ky) / Math.sqrt(((kx * kx) + (ky * ky)))) * Math.sin(th);
} else {
tmp = (Math.sin(ky) / (Math.sqrt(((1.0 - Math.cos((2.0 * kx))) * 2.0)) / 2.0)) * Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): tmp = 0 if kx <= 1.15e-114: tmp = math.sin(th) elif kx <= 2.9e-6: tmp = (math.sin(ky) / math.sqrt(((kx * kx) + (ky * ky)))) * math.sin(th) else: tmp = (math.sin(ky) / (math.sqrt(((1.0 - math.cos((2.0 * kx))) * 2.0)) / 2.0)) * math.sin(th) return tmp
function code(kx, ky, th) tmp = 0.0 if (kx <= 1.15e-114) tmp = sin(th); elseif (kx <= 2.9e-6) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(kx * kx) + Float64(ky * ky)))) * sin(th)); else tmp = Float64(Float64(sin(ky) / Float64(sqrt(Float64(Float64(1.0 - cos(Float64(2.0 * kx))) * 2.0)) / 2.0)) * sin(th)); end return tmp end
function tmp_2 = code(kx, ky, th) tmp = 0.0; if (kx <= 1.15e-114) tmp = sin(th); elseif (kx <= 2.9e-6) tmp = (sin(ky) / sqrt(((kx * kx) + (ky * ky)))) * sin(th); else tmp = (sin(ky) / (sqrt(((1.0 - cos((2.0 * kx))) * 2.0)) / 2.0)) * sin(th); end tmp_2 = tmp; end
code[kx_, ky_, th_] := If[LessEqual[kx, 1.15e-114], N[Sin[th], $MachinePrecision], If[LessEqual[kx, 2.9e-6], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[(kx * kx), $MachinePrecision] + N[(ky * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], N[(N[(N[Sin[ky], $MachinePrecision] / N[(N[Sqrt[N[(N[(1.0 - N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * 2.0), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;kx \leq 1.15 \cdot 10^{-114}:\\
\;\;\;\;\sin th\\
\mathbf{elif}\;kx \leq 2.9 \cdot 10^{-6}:\\
\;\;\;\;\frac{\sin ky}{\sqrt{kx \cdot kx + ky \cdot ky}} \cdot \sin th\\
\mathbf{else}:\\
\;\;\;\;\frac{\sin ky}{\frac{\sqrt{\left(1 - \cos \left(2 \cdot kx\right)\right) \cdot 2}}{2}} \cdot \sin th\\
\end{array}
\end{array}
if kx < 1.15e-114Initial program 94.7%
Taylor expanded in kx around 0
lower-sin.f6429.6
Applied rewrites29.6%
if 1.15e-114 < kx < 2.9000000000000002e-6Initial program 99.8%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f6499.8
Applied rewrites99.8%
Taylor expanded in ky around 0
unpow2N/A
lower-*.f6466.9
Applied rewrites66.9%
if 2.9000000000000002e-6 < kx Initial program 99.4%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
Applied rewrites97.9%
Taylor expanded in ky around 0
*-commutativeN/A
lower-fma.f64N/A
lower--.f64N/A
lower-cos.f64N/A
lower-*.f64N/A
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-*.f64N/A
Applied rewrites44.0%
Taylor expanded in ky around 0
Applied rewrites52.5%
(FPCore (kx ky th) :precision binary64 (pow (/ (fma 0.16666666666666666 (* th th) 1.0) th) -1.0))
double code(double kx, double ky, double th) {
return pow((fma(0.16666666666666666, (th * th), 1.0) / th), -1.0);
}
function code(kx, ky, th) return Float64(fma(0.16666666666666666, Float64(th * th), 1.0) / th) ^ -1.0 end
code[kx_, ky_, th_] := N[Power[N[(N[(0.16666666666666666 * N[(th * th), $MachinePrecision] + 1.0), $MachinePrecision] / th), $MachinePrecision], -1.0], $MachinePrecision]
\begin{array}{l}
\\
{\left(\frac{\mathsf{fma}\left(0.16666666666666666, th \cdot th, 1\right)}{th}\right)}^{-1}
\end{array}
Initial program 96.6%
Taylor expanded in kx around 0
lower-sin.f6423.6
Applied rewrites23.6%
Applied rewrites11.7%
Taylor expanded in th around 0
Applied rewrites6.1%
Applied rewrites12.6%
Final simplification12.6%
(FPCore (kx ky th) :precision binary64 (sin th))
double code(double kx, double ky, double th) {
return sin(th);
}
real(8) function code(kx, ky, th)
real(8), intent (in) :: kx
real(8), intent (in) :: ky
real(8), intent (in) :: th
code = sin(th)
end function
public static double code(double kx, double ky, double th) {
return Math.sin(th);
}
def code(kx, ky, th): return math.sin(th)
function code(kx, ky, th) return sin(th) end
function tmp = code(kx, ky, th) tmp = sin(th); end
code[kx_, ky_, th_] := N[Sin[th], $MachinePrecision]
\begin{array}{l}
\\
\sin th
\end{array}
Initial program 96.6%
Taylor expanded in kx around 0
lower-sin.f6423.6
Applied rewrites23.6%
(FPCore (kx ky th) :precision binary64 (* (fma (* th th) -0.16666666666666666 1.0) th))
double code(double kx, double ky, double th) {
return fma((th * th), -0.16666666666666666, 1.0) * th;
}
function code(kx, ky, th) return Float64(fma(Float64(th * th), -0.16666666666666666, 1.0) * th) end
code[kx_, ky_, th_] := N[(N[(N[(th * th), $MachinePrecision] * -0.16666666666666666 + 1.0), $MachinePrecision] * th), $MachinePrecision]
\begin{array}{l}
\\
\mathsf{fma}\left(th \cdot th, -0.16666666666666666, 1\right) \cdot th
\end{array}
Initial program 96.6%
Taylor expanded in kx around 0
lower-sin.f6423.6
Applied rewrites23.6%
Taylor expanded in th around 0
Applied rewrites11.9%
Applied rewrites11.9%
Taylor expanded in th around 0
Applied rewrites11.9%
herbie shell --seed 2024307
(FPCore (kx ky th)
:name "Toniolo and Linder, Equation (3b), real"
:precision binary64
(* (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))) (sin th)))