
(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 20 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 ky) (hypot (sin ky) (sin kx))) (sin th)))
double code(double kx, double ky, double th) {
return (sin(ky) / hypot(sin(ky), sin(kx))) * sin(th);
}
public static double code(double kx, double ky, double th) {
return (Math.sin(ky) / Math.hypot(Math.sin(ky), Math.sin(kx))) * Math.sin(th);
}
def code(kx, ky, th): return (math.sin(ky) / math.hypot(math.sin(ky), math.sin(kx))) * math.sin(th)
function code(kx, ky, th) return Float64(Float64(sin(ky) / hypot(sin(ky), sin(kx))) * sin(th)) end
function tmp = code(kx, ky, th) tmp = (sin(ky) / hypot(sin(ky), sin(kx))) * sin(th); end
code[kx_, ky_, th_] := N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[Sin[ky], $MachinePrecision] ^ 2 + N[Sin[kx], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\frac{\sin ky}{\mathsf{hypot}\left(\sin ky, \sin kx\right)} \cdot \sin th
\end{array}
Initial program 95.0%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-pow.f64N/A
unpow2N/A
lower-hypot.f6499.7
Applied rewrites99.7%
(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)
(/
(*
(fma 0.16666666666666666 (* th th) 1.0)
(hypot (sin kx) (sin ky)))
th))))
(if (<= t_3 -0.98)
(* (/ (sin ky) (sqrt (+ (* kx kx) t_1))) (sin th))
(if (<= t_3 -0.002)
t_4
(if (<= t_3 5e-16)
(* (/ (sin ky) (sqrt (+ t_2 (* ky ky)))) (sin th))
(if (<= t_3 0.98) 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) / ((fma(0.16666666666666666, (th * th), 1.0) * hypot(sin(kx), sin(ky))) / th);
double tmp;
if (t_3 <= -0.98) {
tmp = (sin(ky) / sqrt(((kx * kx) + t_1))) * sin(th);
} else if (t_3 <= -0.002) {
tmp = t_4;
} else if (t_3 <= 5e-16) {
tmp = (sin(ky) / sqrt((t_2 + (ky * ky)))) * sin(th);
} else if (t_3 <= 0.98) {
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(sin(ky) / Float64(Float64(fma(0.16666666666666666, Float64(th * th), 1.0) * hypot(sin(kx), sin(ky))) / th)) tmp = 0.0 if (t_3 <= -0.98) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(kx * kx) + t_1))) * sin(th)); elseif (t_3 <= -0.002) tmp = t_4; elseif (t_3 <= 5e-16) tmp = Float64(Float64(sin(ky) / sqrt(Float64(t_2 + Float64(ky * ky)))) * sin(th)); elseif (t_3 <= 0.98) 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[(N[Sin[ky], $MachinePrecision] / N[(N[(N[(0.16666666666666666 * N[(th * th), $MachinePrecision] + 1.0), $MachinePrecision] * N[Sqrt[N[Sin[kx], $MachinePrecision] ^ 2 + N[Sin[ky], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision] / th), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$3, -0.98], 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.002], t$95$4, If[LessEqual[t$95$3, 5e-16], 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.98], 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}{\frac{\mathsf{fma}\left(0.16666666666666666, th \cdot th, 1\right) \cdot \mathsf{hypot}\left(\sin kx, \sin ky\right)}{th}}\\
\mathbf{if}\;t\_3 \leq -0.98:\\
\;\;\;\;\frac{\sin ky}{\sqrt{kx \cdot kx + t\_1}} \cdot \sin th\\
\mathbf{elif}\;t\_3 \leq -0.002:\\
\;\;\;\;t\_4\\
\mathbf{elif}\;t\_3 \leq 5 \cdot 10^{-16}:\\
\;\;\;\;\frac{\sin ky}{\sqrt{t\_2 + ky \cdot ky}} \cdot \sin th\\
\mathbf{elif}\;t\_3 \leq 0.98:\\
\;\;\;\;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.97999999999999998Initial program 86.5%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f6482.8
Applied rewrites82.8%
if -0.97999999999999998 < (/.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))))) < -2e-3 or 5.0000000000000004e-16 < (/.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.97999999999999998Initial program 99.4%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f645.5
Applied rewrites5.5%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
*-commutativeN/A
lift-*.f64N/A
clear-numN/A
lower-/.f64N/A
lower-/.f645.5
Applied rewrites5.5%
lift-/.f64N/A
lift-/.f64N/A
lift-*.f64N/A
associate-/r*N/A
clear-numN/A
lower-/.f64N/A
lower-/.f645.5
Applied rewrites5.5%
Taylor expanded in th around 0
*-commutativeN/A
associate-*r*N/A
lower-/.f64N/A
Applied rewrites59.0%
if -2e-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))))) < 5.0000000000000004e-16Initial program 98.7%
Taylor expanded in ky around 0
unpow2N/A
lower-*.f6498.7
Applied rewrites98.7%
if 0.97999999999999998 < (/.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 92.9%
Taylor expanded in kx around 0
lower-sin.f6497.7
Applied rewrites97.7%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (pow (sin kx) 2.0))
(t_2 (hypot (sin kx) (sin ky)))
(t_3 (pow (sin ky) 2.0))
(t_4 (/ (sin ky) (sqrt (+ t_1 t_3)))))
(if (<= t_4 -0.98)
(* (/ (sin ky) (sqrt (+ (* kx kx) t_3))) (sin th))
(if (<= t_4 -0.002)
(pow (/ t_2 (* (sin ky) th)) -1.0)
(if (<= t_4 5e-16)
(* (/ (sin ky) (sqrt (+ t_1 (* ky ky)))) (sin th))
(if (<= t_4 0.98) (* (/ (sin ky) t_2) th) (sin th)))))))
double code(double kx, double ky, double th) {
double t_1 = pow(sin(kx), 2.0);
double t_2 = hypot(sin(kx), sin(ky));
double t_3 = pow(sin(ky), 2.0);
double t_4 = sin(ky) / sqrt((t_1 + t_3));
double tmp;
if (t_4 <= -0.98) {
tmp = (sin(ky) / sqrt(((kx * kx) + t_3))) * sin(th);
} else if (t_4 <= -0.002) {
tmp = pow((t_2 / (sin(ky) * th)), -1.0);
} else if (t_4 <= 5e-16) {
tmp = (sin(ky) / sqrt((t_1 + (ky * ky)))) * sin(th);
} else if (t_4 <= 0.98) {
tmp = (sin(ky) / t_2) * th;
} else {
tmp = sin(th);
}
return tmp;
}
public static double code(double kx, double ky, double th) {
double t_1 = Math.pow(Math.sin(kx), 2.0);
double t_2 = Math.hypot(Math.sin(kx), Math.sin(ky));
double t_3 = Math.pow(Math.sin(ky), 2.0);
double t_4 = Math.sin(ky) / Math.sqrt((t_1 + t_3));
double tmp;
if (t_4 <= -0.98) {
tmp = (Math.sin(ky) / Math.sqrt(((kx * kx) + t_3))) * Math.sin(th);
} else if (t_4 <= -0.002) {
tmp = Math.pow((t_2 / (Math.sin(ky) * th)), -1.0);
} else if (t_4 <= 5e-16) {
tmp = (Math.sin(ky) / Math.sqrt((t_1 + (ky * ky)))) * Math.sin(th);
} else if (t_4 <= 0.98) {
tmp = (Math.sin(ky) / t_2) * th;
} else {
tmp = Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): t_1 = math.pow(math.sin(kx), 2.0) t_2 = math.hypot(math.sin(kx), math.sin(ky)) t_3 = math.pow(math.sin(ky), 2.0) t_4 = math.sin(ky) / math.sqrt((t_1 + t_3)) tmp = 0 if t_4 <= -0.98: tmp = (math.sin(ky) / math.sqrt(((kx * kx) + t_3))) * math.sin(th) elif t_4 <= -0.002: tmp = math.pow((t_2 / (math.sin(ky) * th)), -1.0) elif t_4 <= 5e-16: tmp = (math.sin(ky) / math.sqrt((t_1 + (ky * ky)))) * math.sin(th) elif t_4 <= 0.98: tmp = (math.sin(ky) / t_2) * th else: tmp = math.sin(th) return tmp
function code(kx, ky, th) t_1 = sin(kx) ^ 2.0 t_2 = hypot(sin(kx), sin(ky)) t_3 = sin(ky) ^ 2.0 t_4 = Float64(sin(ky) / sqrt(Float64(t_1 + t_3))) tmp = 0.0 if (t_4 <= -0.98) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(kx * kx) + t_3))) * sin(th)); elseif (t_4 <= -0.002) tmp = Float64(t_2 / Float64(sin(ky) * th)) ^ -1.0; elseif (t_4 <= 5e-16) tmp = Float64(Float64(sin(ky) / sqrt(Float64(t_1 + Float64(ky * ky)))) * sin(th)); elseif (t_4 <= 0.98) tmp = Float64(Float64(sin(ky) / t_2) * th); else tmp = sin(th); end return tmp end
function tmp_2 = code(kx, ky, th) t_1 = sin(kx) ^ 2.0; t_2 = hypot(sin(kx), sin(ky)); t_3 = sin(ky) ^ 2.0; t_4 = sin(ky) / sqrt((t_1 + t_3)); tmp = 0.0; if (t_4 <= -0.98) tmp = (sin(ky) / sqrt(((kx * kx) + t_3))) * sin(th); elseif (t_4 <= -0.002) tmp = (t_2 / (sin(ky) * th)) ^ -1.0; elseif (t_4 <= 5e-16) tmp = (sin(ky) / sqrt((t_1 + (ky * ky)))) * sin(th); elseif (t_4 <= 0.98) tmp = (sin(ky) / t_2) * th; else tmp = sin(th); end tmp_2 = tmp; end
code[kx_, ky_, th_] := Block[{t$95$1 = N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision]}, Block[{t$95$2 = N[Sqrt[N[Sin[kx], $MachinePrecision] ^ 2 + N[Sin[ky], $MachinePrecision] ^ 2], $MachinePrecision]}, Block[{t$95$3 = N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]}, Block[{t$95$4 = N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(t$95$1 + t$95$3), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$4, -0.98], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[(kx * kx), $MachinePrecision] + t$95$3), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$4, -0.002], N[Power[N[(t$95$2 / N[(N[Sin[ky], $MachinePrecision] * th), $MachinePrecision]), $MachinePrecision], -1.0], $MachinePrecision], If[LessEqual[t$95$4, 5e-16], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(t$95$1 + N[(ky * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$4, 0.98], N[(N[(N[Sin[ky], $MachinePrecision] / t$95$2), $MachinePrecision] * th), $MachinePrecision], N[Sin[th], $MachinePrecision]]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := {\sin kx}^{2}\\
t_2 := \mathsf{hypot}\left(\sin kx, \sin ky\right)\\
t_3 := {\sin ky}^{2}\\
t_4 := \frac{\sin ky}{\sqrt{t\_1 + t\_3}}\\
\mathbf{if}\;t\_4 \leq -0.98:\\
\;\;\;\;\frac{\sin ky}{\sqrt{kx \cdot kx + t\_3}} \cdot \sin th\\
\mathbf{elif}\;t\_4 \leq -0.002:\\
\;\;\;\;{\left(\frac{t\_2}{\sin ky \cdot th}\right)}^{-1}\\
\mathbf{elif}\;t\_4 \leq 5 \cdot 10^{-16}:\\
\;\;\;\;\frac{\sin ky}{\sqrt{t\_1 + ky \cdot ky}} \cdot \sin th\\
\mathbf{elif}\;t\_4 \leq 0.98:\\
\;\;\;\;\frac{\sin ky}{t\_2} \cdot 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.97999999999999998Initial program 86.5%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f6482.8
Applied rewrites82.8%
if -0.97999999999999998 < (/.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))))) < -2e-3Initial program 99.5%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f645.3
Applied rewrites5.3%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
*-commutativeN/A
lift-*.f64N/A
clear-numN/A
lower-/.f64N/A
lower-/.f645.3
Applied rewrites5.3%
Taylor expanded in th around 0
associate-*l/N/A
*-lft-identityN/A
lower-/.f64N/A
unpow2N/A
unpow2N/A
lower-hypot.f64N/A
lower-sin.f64N/A
lower-sin.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f6454.5
Applied rewrites54.5%
if -2e-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))))) < 5.0000000000000004e-16Initial program 98.7%
Taylor expanded in ky around 0
unpow2N/A
lower-*.f6498.7
Applied rewrites98.7%
if 5.0000000000000004e-16 < (/.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.97999999999999998Initial program 99.2%
Taylor expanded in th around 0
lower-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f64N/A
lower-sqrt.f64N/A
lower-/.f64N/A
unpow2N/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-sin.f64N/A
lower-pow.f64N/A
lower-sin.f6462.6
Applied rewrites62.6%
Applied rewrites62.3%
if 0.97999999999999998 < (/.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 92.9%
Taylor expanded in kx around 0
lower-sin.f6497.7
Applied rewrites97.7%
Final simplification86.3%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (pow (sin kx) 2.0))
(t_2 (hypot (sin kx) (sin ky)))
(t_3 (pow (sin ky) 2.0))
(t_4 (/ (sin ky) (sqrt (+ t_1 t_3)))))
(if (<= t_4 -0.98)
(* (/ (sin ky) (sqrt (+ (* kx kx) t_3))) (sin th))
(if (<= t_4 -0.002)
(pow (/ t_2 (* (sin ky) th)) -1.0)
(if (<= t_4 5e-9)
(/ (sin th) (/ (pow t_1 0.5) ky))
(if (<= t_4 0.98) (* (/ (sin ky) t_2) th) (sin th)))))))
double code(double kx, double ky, double th) {
double t_1 = pow(sin(kx), 2.0);
double t_2 = hypot(sin(kx), sin(ky));
double t_3 = pow(sin(ky), 2.0);
double t_4 = sin(ky) / sqrt((t_1 + t_3));
double tmp;
if (t_4 <= -0.98) {
tmp = (sin(ky) / sqrt(((kx * kx) + t_3))) * sin(th);
} else if (t_4 <= -0.002) {
tmp = pow((t_2 / (sin(ky) * th)), -1.0);
} else if (t_4 <= 5e-9) {
tmp = sin(th) / (pow(t_1, 0.5) / ky);
} else if (t_4 <= 0.98) {
tmp = (sin(ky) / t_2) * th;
} else {
tmp = sin(th);
}
return tmp;
}
public static double code(double kx, double ky, double th) {
double t_1 = Math.pow(Math.sin(kx), 2.0);
double t_2 = Math.hypot(Math.sin(kx), Math.sin(ky));
double t_3 = Math.pow(Math.sin(ky), 2.0);
double t_4 = Math.sin(ky) / Math.sqrt((t_1 + t_3));
double tmp;
if (t_4 <= -0.98) {
tmp = (Math.sin(ky) / Math.sqrt(((kx * kx) + t_3))) * Math.sin(th);
} else if (t_4 <= -0.002) {
tmp = Math.pow((t_2 / (Math.sin(ky) * th)), -1.0);
} else if (t_4 <= 5e-9) {
tmp = Math.sin(th) / (Math.pow(t_1, 0.5) / ky);
} else if (t_4 <= 0.98) {
tmp = (Math.sin(ky) / t_2) * th;
} else {
tmp = Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): t_1 = math.pow(math.sin(kx), 2.0) t_2 = math.hypot(math.sin(kx), math.sin(ky)) t_3 = math.pow(math.sin(ky), 2.0) t_4 = math.sin(ky) / math.sqrt((t_1 + t_3)) tmp = 0 if t_4 <= -0.98: tmp = (math.sin(ky) / math.sqrt(((kx * kx) + t_3))) * math.sin(th) elif t_4 <= -0.002: tmp = math.pow((t_2 / (math.sin(ky) * th)), -1.0) elif t_4 <= 5e-9: tmp = math.sin(th) / (math.pow(t_1, 0.5) / ky) elif t_4 <= 0.98: tmp = (math.sin(ky) / t_2) * th else: tmp = math.sin(th) return tmp
function code(kx, ky, th) t_1 = sin(kx) ^ 2.0 t_2 = hypot(sin(kx), sin(ky)) t_3 = sin(ky) ^ 2.0 t_4 = Float64(sin(ky) / sqrt(Float64(t_1 + t_3))) tmp = 0.0 if (t_4 <= -0.98) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(kx * kx) + t_3))) * sin(th)); elseif (t_4 <= -0.002) tmp = Float64(t_2 / Float64(sin(ky) * th)) ^ -1.0; elseif (t_4 <= 5e-9) tmp = Float64(sin(th) / Float64((t_1 ^ 0.5) / ky)); elseif (t_4 <= 0.98) tmp = Float64(Float64(sin(ky) / t_2) * th); else tmp = sin(th); end return tmp end
function tmp_2 = code(kx, ky, th) t_1 = sin(kx) ^ 2.0; t_2 = hypot(sin(kx), sin(ky)); t_3 = sin(ky) ^ 2.0; t_4 = sin(ky) / sqrt((t_1 + t_3)); tmp = 0.0; if (t_4 <= -0.98) tmp = (sin(ky) / sqrt(((kx * kx) + t_3))) * sin(th); elseif (t_4 <= -0.002) tmp = (t_2 / (sin(ky) * th)) ^ -1.0; elseif (t_4 <= 5e-9) tmp = sin(th) / ((t_1 ^ 0.5) / ky); elseif (t_4 <= 0.98) tmp = (sin(ky) / t_2) * th; else tmp = sin(th); end tmp_2 = tmp; end
code[kx_, ky_, th_] := Block[{t$95$1 = N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision]}, Block[{t$95$2 = N[Sqrt[N[Sin[kx], $MachinePrecision] ^ 2 + N[Sin[ky], $MachinePrecision] ^ 2], $MachinePrecision]}, Block[{t$95$3 = N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]}, Block[{t$95$4 = N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(t$95$1 + t$95$3), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$4, -0.98], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[(kx * kx), $MachinePrecision] + t$95$3), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$4, -0.002], N[Power[N[(t$95$2 / N[(N[Sin[ky], $MachinePrecision] * th), $MachinePrecision]), $MachinePrecision], -1.0], $MachinePrecision], If[LessEqual[t$95$4, 5e-9], N[(N[Sin[th], $MachinePrecision] / N[(N[Power[t$95$1, 0.5], $MachinePrecision] / ky), $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$4, 0.98], N[(N[(N[Sin[ky], $MachinePrecision] / t$95$2), $MachinePrecision] * th), $MachinePrecision], N[Sin[th], $MachinePrecision]]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := {\sin kx}^{2}\\
t_2 := \mathsf{hypot}\left(\sin kx, \sin ky\right)\\
t_3 := {\sin ky}^{2}\\
t_4 := \frac{\sin ky}{\sqrt{t\_1 + t\_3}}\\
\mathbf{if}\;t\_4 \leq -0.98:\\
\;\;\;\;\frac{\sin ky}{\sqrt{kx \cdot kx + t\_3}} \cdot \sin th\\
\mathbf{elif}\;t\_4 \leq -0.002:\\
\;\;\;\;{\left(\frac{t\_2}{\sin ky \cdot th}\right)}^{-1}\\
\mathbf{elif}\;t\_4 \leq 5 \cdot 10^{-9}:\\
\;\;\;\;\frac{\sin th}{\frac{{t\_1}^{0.5}}{ky}}\\
\mathbf{elif}\;t\_4 \leq 0.98:\\
\;\;\;\;\frac{\sin ky}{t\_2} \cdot 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.97999999999999998Initial program 86.5%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f6482.8
Applied rewrites82.8%
if -0.97999999999999998 < (/.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))))) < -2e-3Initial program 99.5%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f645.3
Applied rewrites5.3%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
*-commutativeN/A
lift-*.f64N/A
clear-numN/A
lower-/.f64N/A
lower-/.f645.3
Applied rewrites5.3%
Taylor expanded in th around 0
associate-*l/N/A
*-lft-identityN/A
lower-/.f64N/A
unpow2N/A
unpow2N/A
lower-hypot.f64N/A
lower-sin.f64N/A
lower-sin.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f6454.5
Applied rewrites54.5%
if -2e-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))))) < 5.0000000000000001e-9Initial program 98.7%
lift-*.f64N/A
*-commutativeN/A
lift-/.f64N/A
clear-numN/A
un-div-invN/A
lower-/.f64N/A
lower-/.f6498.7
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
lower-sin.f6453.2
Applied rewrites53.2%
Applied rewrites98.7%
if 5.0000000000000001e-9 < (/.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.97999999999999998Initial program 99.2%
Taylor expanded in th around 0
lower-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f64N/A
lower-sqrt.f64N/A
lower-/.f64N/A
unpow2N/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-sin.f64N/A
lower-pow.f64N/A
lower-sin.f6462.6
Applied rewrites62.6%
Applied rewrites62.3%
if 0.97999999999999998 < (/.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 92.9%
Taylor expanded in kx around 0
lower-sin.f6497.7
Applied rewrites97.7%
Final simplification86.3%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (hypot (sin kx) (sin ky)))
(t_2 (pow (sin kx) 2.0))
(t_3 (/ (sin ky) (sqrt (+ t_2 (pow (sin ky) 2.0))))))
(if (<= t_3 -0.98)
(*
(/
(sin ky)
(sqrt (+ (* kx kx) (pow (/ 2.0 (- 1.0 (cos (* 2.0 ky)))) -1.0))))
(sin th))
(if (<= t_3 -0.002)
(pow (/ t_1 (* (sin ky) th)) -1.0)
(if (<= t_3 5e-9)
(/ (sin th) (/ (pow t_2 0.5) ky))
(if (<= t_3 0.98) (* (/ (sin ky) t_1) th) (sin th)))))))
double code(double kx, double ky, double th) {
double t_1 = hypot(sin(kx), sin(ky));
double t_2 = pow(sin(kx), 2.0);
double t_3 = sin(ky) / sqrt((t_2 + pow(sin(ky), 2.0)));
double tmp;
if (t_3 <= -0.98) {
tmp = (sin(ky) / sqrt(((kx * kx) + pow((2.0 / (1.0 - cos((2.0 * ky)))), -1.0)))) * sin(th);
} else if (t_3 <= -0.002) {
tmp = pow((t_1 / (sin(ky) * th)), -1.0);
} else if (t_3 <= 5e-9) {
tmp = sin(th) / (pow(t_2, 0.5) / ky);
} else if (t_3 <= 0.98) {
tmp = (sin(ky) / t_1) * th;
} else {
tmp = sin(th);
}
return tmp;
}
public static double code(double kx, double ky, double th) {
double t_1 = Math.hypot(Math.sin(kx), Math.sin(ky));
double t_2 = Math.pow(Math.sin(kx), 2.0);
double t_3 = Math.sin(ky) / Math.sqrt((t_2 + Math.pow(Math.sin(ky), 2.0)));
double tmp;
if (t_3 <= -0.98) {
tmp = (Math.sin(ky) / Math.sqrt(((kx * kx) + Math.pow((2.0 / (1.0 - Math.cos((2.0 * ky)))), -1.0)))) * Math.sin(th);
} else if (t_3 <= -0.002) {
tmp = Math.pow((t_1 / (Math.sin(ky) * th)), -1.0);
} else if (t_3 <= 5e-9) {
tmp = Math.sin(th) / (Math.pow(t_2, 0.5) / ky);
} else if (t_3 <= 0.98) {
tmp = (Math.sin(ky) / t_1) * th;
} else {
tmp = Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): t_1 = math.hypot(math.sin(kx), math.sin(ky)) t_2 = math.pow(math.sin(kx), 2.0) t_3 = math.sin(ky) / math.sqrt((t_2 + math.pow(math.sin(ky), 2.0))) tmp = 0 if t_3 <= -0.98: tmp = (math.sin(ky) / math.sqrt(((kx * kx) + math.pow((2.0 / (1.0 - math.cos((2.0 * ky)))), -1.0)))) * math.sin(th) elif t_3 <= -0.002: tmp = math.pow((t_1 / (math.sin(ky) * th)), -1.0) elif t_3 <= 5e-9: tmp = math.sin(th) / (math.pow(t_2, 0.5) / ky) elif t_3 <= 0.98: tmp = (math.sin(ky) / t_1) * th else: tmp = math.sin(th) return tmp
function code(kx, ky, th) t_1 = hypot(sin(kx), sin(ky)) t_2 = sin(kx) ^ 2.0 t_3 = Float64(sin(ky) / sqrt(Float64(t_2 + (sin(ky) ^ 2.0)))) tmp = 0.0 if (t_3 <= -0.98) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(kx * kx) + (Float64(2.0 / Float64(1.0 - cos(Float64(2.0 * ky)))) ^ -1.0)))) * sin(th)); elseif (t_3 <= -0.002) tmp = Float64(t_1 / Float64(sin(ky) * th)) ^ -1.0; elseif (t_3 <= 5e-9) tmp = Float64(sin(th) / Float64((t_2 ^ 0.5) / ky)); elseif (t_3 <= 0.98) tmp = Float64(Float64(sin(ky) / t_1) * th); else tmp = sin(th); end return tmp end
function tmp_2 = code(kx, ky, th) t_1 = hypot(sin(kx), sin(ky)); t_2 = sin(kx) ^ 2.0; t_3 = sin(ky) / sqrt((t_2 + (sin(ky) ^ 2.0))); tmp = 0.0; if (t_3 <= -0.98) tmp = (sin(ky) / sqrt(((kx * kx) + ((2.0 / (1.0 - cos((2.0 * ky)))) ^ -1.0)))) * sin(th); elseif (t_3 <= -0.002) tmp = (t_1 / (sin(ky) * th)) ^ -1.0; elseif (t_3 <= 5e-9) tmp = sin(th) / ((t_2 ^ 0.5) / ky); elseif (t_3 <= 0.98) tmp = (sin(ky) / t_1) * th; else tmp = sin(th); end tmp_2 = tmp; end
code[kx_, ky_, th_] := Block[{t$95$1 = N[Sqrt[N[Sin[kx], $MachinePrecision] ^ 2 + N[Sin[ky], $MachinePrecision] ^ 2], $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 + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$3, -0.98], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[(kx * kx), $MachinePrecision] + N[Power[N[(2.0 / N[(1.0 - N[Cos[N[(2.0 * ky), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], -1.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$3, -0.002], N[Power[N[(t$95$1 / N[(N[Sin[ky], $MachinePrecision] * th), $MachinePrecision]), $MachinePrecision], -1.0], $MachinePrecision], If[LessEqual[t$95$3, 5e-9], N[(N[Sin[th], $MachinePrecision] / N[(N[Power[t$95$2, 0.5], $MachinePrecision] / ky), $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$3, 0.98], N[(N[(N[Sin[ky], $MachinePrecision] / t$95$1), $MachinePrecision] * th), $MachinePrecision], N[Sin[th], $MachinePrecision]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \mathsf{hypot}\left(\sin kx, \sin ky\right)\\
t_2 := {\sin kx}^{2}\\
t_3 := \frac{\sin ky}{\sqrt{t\_2 + {\sin ky}^{2}}}\\
\mathbf{if}\;t\_3 \leq -0.98:\\
\;\;\;\;\frac{\sin ky}{\sqrt{kx \cdot kx + {\left(\frac{2}{1 - \cos \left(2 \cdot ky\right)}\right)}^{-1}}} \cdot \sin th\\
\mathbf{elif}\;t\_3 \leq -0.002:\\
\;\;\;\;{\left(\frac{t\_1}{\sin ky \cdot th}\right)}^{-1}\\
\mathbf{elif}\;t\_3 \leq 5 \cdot 10^{-9}:\\
\;\;\;\;\frac{\sin th}{\frac{{t\_2}^{0.5}}{ky}}\\
\mathbf{elif}\;t\_3 \leq 0.98:\\
\;\;\;\;\frac{\sin ky}{t\_1} \cdot 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.97999999999999998Initial program 86.5%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f6482.8
Applied rewrites82.8%
lift-pow.f64N/A
pow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
clear-numN/A
lower-/.f64N/A
lower-/.f64N/A
cos-diffN/A
cos-sin-sumN/A
lower--.f64N/A
lower-cos.f64N/A
count-2N/A
lower-*.f6454.3
Applied rewrites54.3%
if -0.97999999999999998 < (/.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))))) < -2e-3Initial program 99.5%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f645.3
Applied rewrites5.3%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
*-commutativeN/A
lift-*.f64N/A
clear-numN/A
lower-/.f64N/A
lower-/.f645.3
Applied rewrites5.3%
Taylor expanded in th around 0
associate-*l/N/A
*-lft-identityN/A
lower-/.f64N/A
unpow2N/A
unpow2N/A
lower-hypot.f64N/A
lower-sin.f64N/A
lower-sin.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f6454.5
Applied rewrites54.5%
if -2e-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))))) < 5.0000000000000001e-9Initial program 98.7%
lift-*.f64N/A
*-commutativeN/A
lift-/.f64N/A
clear-numN/A
un-div-invN/A
lower-/.f64N/A
lower-/.f6498.7
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
lower-sin.f6453.2
Applied rewrites53.2%
Applied rewrites98.7%
if 5.0000000000000001e-9 < (/.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.97999999999999998Initial program 99.2%
Taylor expanded in th around 0
lower-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f64N/A
lower-sqrt.f64N/A
lower-/.f64N/A
unpow2N/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-sin.f64N/A
lower-pow.f64N/A
lower-sin.f6462.6
Applied rewrites62.6%
Applied rewrites62.3%
if 0.97999999999999998 < (/.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 92.9%
Taylor expanded in kx around 0
lower-sin.f6497.7
Applied rewrites97.7%
Final simplification80.6%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (* (/ (sin ky) (hypot (sin kx) (sin ky))) th))
(t_2 (pow (sin kx) 2.0))
(t_3 (/ (sin ky) (sqrt (+ t_2 (pow (sin ky) 2.0))))))
(if (<= t_3 -0.98)
(*
(/
(sin ky)
(sqrt (+ (* kx kx) (pow (/ 2.0 (- 1.0 (cos (* 2.0 ky)))) -1.0))))
(sin th))
(if (<= t_3 -0.002)
t_1
(if (<= t_3 5e-9)
(/ (sin th) (/ (pow t_2 0.5) ky))
(if (<= t_3 0.98) t_1 (sin th)))))))
double code(double kx, double ky, double th) {
double t_1 = (sin(ky) / hypot(sin(kx), sin(ky))) * th;
double t_2 = pow(sin(kx), 2.0);
double t_3 = sin(ky) / sqrt((t_2 + pow(sin(ky), 2.0)));
double tmp;
if (t_3 <= -0.98) {
tmp = (sin(ky) / sqrt(((kx * kx) + pow((2.0 / (1.0 - cos((2.0 * ky)))), -1.0)))) * sin(th);
} else if (t_3 <= -0.002) {
tmp = t_1;
} else if (t_3 <= 5e-9) {
tmp = sin(th) / (pow(t_2, 0.5) / ky);
} else if (t_3 <= 0.98) {
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) / Math.hypot(Math.sin(kx), Math.sin(ky))) * th;
double t_2 = Math.pow(Math.sin(kx), 2.0);
double t_3 = Math.sin(ky) / Math.sqrt((t_2 + Math.pow(Math.sin(ky), 2.0)));
double tmp;
if (t_3 <= -0.98) {
tmp = (Math.sin(ky) / Math.sqrt(((kx * kx) + Math.pow((2.0 / (1.0 - Math.cos((2.0 * ky)))), -1.0)))) * Math.sin(th);
} else if (t_3 <= -0.002) {
tmp = t_1;
} else if (t_3 <= 5e-9) {
tmp = Math.sin(th) / (Math.pow(t_2, 0.5) / ky);
} else if (t_3 <= 0.98) {
tmp = t_1;
} else {
tmp = Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): t_1 = (math.sin(ky) / math.hypot(math.sin(kx), math.sin(ky))) * th t_2 = math.pow(math.sin(kx), 2.0) t_3 = math.sin(ky) / math.sqrt((t_2 + math.pow(math.sin(ky), 2.0))) tmp = 0 if t_3 <= -0.98: tmp = (math.sin(ky) / math.sqrt(((kx * kx) + math.pow((2.0 / (1.0 - math.cos((2.0 * ky)))), -1.0)))) * math.sin(th) elif t_3 <= -0.002: tmp = t_1 elif t_3 <= 5e-9: tmp = math.sin(th) / (math.pow(t_2, 0.5) / ky) elif t_3 <= 0.98: tmp = t_1 else: tmp = math.sin(th) return tmp
function code(kx, ky, th) t_1 = Float64(Float64(sin(ky) / hypot(sin(kx), sin(ky))) * th) t_2 = sin(kx) ^ 2.0 t_3 = Float64(sin(ky) / sqrt(Float64(t_2 + (sin(ky) ^ 2.0)))) tmp = 0.0 if (t_3 <= -0.98) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(kx * kx) + (Float64(2.0 / Float64(1.0 - cos(Float64(2.0 * ky)))) ^ -1.0)))) * sin(th)); elseif (t_3 <= -0.002) tmp = t_1; elseif (t_3 <= 5e-9) tmp = Float64(sin(th) / Float64((t_2 ^ 0.5) / ky)); elseif (t_3 <= 0.98) tmp = t_1; else tmp = sin(th); end return tmp end
function tmp_2 = code(kx, ky, th) t_1 = (sin(ky) / hypot(sin(kx), sin(ky))) * th; t_2 = sin(kx) ^ 2.0; t_3 = sin(ky) / sqrt((t_2 + (sin(ky) ^ 2.0))); tmp = 0.0; if (t_3 <= -0.98) tmp = (sin(ky) / sqrt(((kx * kx) + ((2.0 / (1.0 - cos((2.0 * ky)))) ^ -1.0)))) * sin(th); elseif (t_3 <= -0.002) tmp = t_1; elseif (t_3 <= 5e-9) tmp = sin(th) / ((t_2 ^ 0.5) / ky); elseif (t_3 <= 0.98) 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] / N[Sqrt[N[Sin[kx], $MachinePrecision] ^ 2 + N[Sin[ky], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision] * th), $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 + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$3, -0.98], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[(kx * kx), $MachinePrecision] + N[Power[N[(2.0 / N[(1.0 - N[Cos[N[(2.0 * ky), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], -1.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$3, -0.002], t$95$1, If[LessEqual[t$95$3, 5e-9], N[(N[Sin[th], $MachinePrecision] / N[(N[Power[t$95$2, 0.5], $MachinePrecision] / ky), $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$3, 0.98], t$95$1, N[Sin[th], $MachinePrecision]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \frac{\sin ky}{\mathsf{hypot}\left(\sin kx, \sin ky\right)} \cdot th\\
t_2 := {\sin kx}^{2}\\
t_3 := \frac{\sin ky}{\sqrt{t\_2 + {\sin ky}^{2}}}\\
\mathbf{if}\;t\_3 \leq -0.98:\\
\;\;\;\;\frac{\sin ky}{\sqrt{kx \cdot kx + {\left(\frac{2}{1 - \cos \left(2 \cdot ky\right)}\right)}^{-1}}} \cdot \sin th\\
\mathbf{elif}\;t\_3 \leq -0.002:\\
\;\;\;\;t\_1\\
\mathbf{elif}\;t\_3 \leq 5 \cdot 10^{-9}:\\
\;\;\;\;\frac{\sin th}{\frac{{t\_2}^{0.5}}{ky}}\\
\mathbf{elif}\;t\_3 \leq 0.98:\\
\;\;\;\;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.97999999999999998Initial program 86.5%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f6482.8
Applied rewrites82.8%
lift-pow.f64N/A
pow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
clear-numN/A
lower-/.f64N/A
lower-/.f64N/A
cos-diffN/A
cos-sin-sumN/A
lower--.f64N/A
lower-cos.f64N/A
count-2N/A
lower-*.f6454.3
Applied rewrites54.3%
if -0.97999999999999998 < (/.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))))) < -2e-3 or 5.0000000000000001e-9 < (/.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.97999999999999998Initial program 99.4%
Taylor expanded in th around 0
lower-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f64N/A
lower-sqrt.f64N/A
lower-/.f64N/A
unpow2N/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-sin.f64N/A
lower-pow.f64N/A
lower-sin.f6457.6
Applied rewrites57.6%
Applied rewrites57.6%
if -2e-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))))) < 5.0000000000000001e-9Initial program 98.7%
lift-*.f64N/A
*-commutativeN/A
lift-/.f64N/A
clear-numN/A
un-div-invN/A
lower-/.f64N/A
lower-/.f6498.7
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
lower-sin.f6453.2
Applied rewrites53.2%
Applied rewrites98.7%
if 0.97999999999999998 < (/.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 92.9%
Taylor expanded in kx around 0
lower-sin.f6497.7
Applied rewrites97.7%
Final simplification80.6%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (* (/ (sin ky) (hypot (sin kx) (sin ky))) th))
(t_2 (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0))))))
(if (<= t_2 -0.98)
(*
(/
(sin ky)
(sqrt (+ (* kx kx) (pow (/ 2.0 (- 1.0 (cos (* 2.0 ky)))) -1.0))))
(sin th))
(if (<= t_2 -0.002)
t_1
(if (<= t_2 5e-9)
(/ (* (sin th) ky) (hypot (sin ky) (sin kx)))
(if (<= t_2 0.98) t_1 (sin th)))))))
double code(double kx, double ky, double th) {
double t_1 = (sin(ky) / hypot(sin(kx), sin(ky))) * th;
double t_2 = sin(ky) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)));
double tmp;
if (t_2 <= -0.98) {
tmp = (sin(ky) / sqrt(((kx * kx) + pow((2.0 / (1.0 - cos((2.0 * ky)))), -1.0)))) * sin(th);
} else if (t_2 <= -0.002) {
tmp = t_1;
} else if (t_2 <= 5e-9) {
tmp = (sin(th) * ky) / hypot(sin(ky), sin(kx));
} else if (t_2 <= 0.98) {
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) / Math.hypot(Math.sin(kx), Math.sin(ky))) * th;
double t_2 = Math.sin(ky) / Math.sqrt((Math.pow(Math.sin(kx), 2.0) + Math.pow(Math.sin(ky), 2.0)));
double tmp;
if (t_2 <= -0.98) {
tmp = (Math.sin(ky) / Math.sqrt(((kx * kx) + Math.pow((2.0 / (1.0 - Math.cos((2.0 * ky)))), -1.0)))) * Math.sin(th);
} else if (t_2 <= -0.002) {
tmp = t_1;
} else if (t_2 <= 5e-9) {
tmp = (Math.sin(th) * ky) / Math.hypot(Math.sin(ky), Math.sin(kx));
} else if (t_2 <= 0.98) {
tmp = t_1;
} else {
tmp = Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): t_1 = (math.sin(ky) / math.hypot(math.sin(kx), math.sin(ky))) * th t_2 = math.sin(ky) / math.sqrt((math.pow(math.sin(kx), 2.0) + math.pow(math.sin(ky), 2.0))) tmp = 0 if t_2 <= -0.98: tmp = (math.sin(ky) / math.sqrt(((kx * kx) + math.pow((2.0 / (1.0 - math.cos((2.0 * ky)))), -1.0)))) * math.sin(th) elif t_2 <= -0.002: tmp = t_1 elif t_2 <= 5e-9: tmp = (math.sin(th) * ky) / math.hypot(math.sin(ky), math.sin(kx)) elif t_2 <= 0.98: tmp = t_1 else: tmp = math.sin(th) return tmp
function code(kx, ky, th) t_1 = Float64(Float64(sin(ky) / hypot(sin(kx), sin(ky))) * th) t_2 = Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) tmp = 0.0 if (t_2 <= -0.98) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(kx * kx) + (Float64(2.0 / Float64(1.0 - cos(Float64(2.0 * ky)))) ^ -1.0)))) * sin(th)); elseif (t_2 <= -0.002) tmp = t_1; elseif (t_2 <= 5e-9) tmp = Float64(Float64(sin(th) * ky) / hypot(sin(ky), sin(kx))); elseif (t_2 <= 0.98) tmp = t_1; else tmp = sin(th); end return tmp end
function tmp_2 = code(kx, ky, th) t_1 = (sin(ky) / hypot(sin(kx), sin(ky))) * th; t_2 = sin(ky) / sqrt(((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0))); tmp = 0.0; if (t_2 <= -0.98) tmp = (sin(ky) / sqrt(((kx * kx) + ((2.0 / (1.0 - cos((2.0 * ky)))) ^ -1.0)))) * sin(th); elseif (t_2 <= -0.002) tmp = t_1; elseif (t_2 <= 5e-9) tmp = (sin(th) * ky) / hypot(sin(ky), sin(kx)); elseif (t_2 <= 0.98) 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] / N[Sqrt[N[Sin[kx], $MachinePrecision] ^ 2 + N[Sin[ky], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision] * th), $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]}, If[LessEqual[t$95$2, -0.98], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[(kx * kx), $MachinePrecision] + N[Power[N[(2.0 / N[(1.0 - N[Cos[N[(2.0 * ky), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], -1.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, -0.002], t$95$1, If[LessEqual[t$95$2, 5e-9], N[(N[(N[Sin[th], $MachinePrecision] * ky), $MachinePrecision] / N[Sqrt[N[Sin[ky], $MachinePrecision] ^ 2 + N[Sin[kx], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, 0.98], t$95$1, N[Sin[th], $MachinePrecision]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \frac{\sin ky}{\mathsf{hypot}\left(\sin kx, \sin ky\right)} \cdot th\\
t_2 := \frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}}\\
\mathbf{if}\;t\_2 \leq -0.98:\\
\;\;\;\;\frac{\sin ky}{\sqrt{kx \cdot kx + {\left(\frac{2}{1 - \cos \left(2 \cdot ky\right)}\right)}^{-1}}} \cdot \sin th\\
\mathbf{elif}\;t\_2 \leq -0.002:\\
\;\;\;\;t\_1\\
\mathbf{elif}\;t\_2 \leq 5 \cdot 10^{-9}:\\
\;\;\;\;\frac{\sin th \cdot ky}{\mathsf{hypot}\left(\sin ky, \sin kx\right)}\\
\mathbf{elif}\;t\_2 \leq 0.98:\\
\;\;\;\;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.97999999999999998Initial program 86.5%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f6482.8
Applied rewrites82.8%
lift-pow.f64N/A
pow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
clear-numN/A
lower-/.f64N/A
lower-/.f64N/A
cos-diffN/A
cos-sin-sumN/A
lower--.f64N/A
lower-cos.f64N/A
count-2N/A
lower-*.f6454.3
Applied rewrites54.3%
if -0.97999999999999998 < (/.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))))) < -2e-3 or 5.0000000000000001e-9 < (/.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.97999999999999998Initial program 99.4%
Taylor expanded in th around 0
lower-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f64N/A
lower-sqrt.f64N/A
lower-/.f64N/A
unpow2N/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-sin.f64N/A
lower-pow.f64N/A
lower-sin.f6457.6
Applied rewrites57.6%
Applied rewrites57.6%
if -2e-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))))) < 5.0000000000000001e-9Initial program 98.7%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
lower-/.f64N/A
*-commutativeN/A
lower-*.f6494.6
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-pow.f64N/A
unpow2N/A
lower-hypot.f6494.8
Applied rewrites94.8%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
lower-sin.f6494.8
Applied rewrites94.8%
if 0.97999999999999998 < (/.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 92.9%
Taylor expanded in kx around 0
lower-sin.f6497.7
Applied rewrites97.7%
Final simplification79.3%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (* (/ (sin ky) (hypot (sin kx) (sin ky))) th))
(t_2 (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0))))))
(if (<= t_2 -0.98)
(*
(/
(sin ky)
(sqrt (+ (* kx kx) (pow (/ 2.0 (- 1.0 (cos (* 2.0 ky)))) -1.0))))
(sin th))
(if (<= t_2 -0.002)
t_1
(if (<= t_2 5e-9)
(* (sin ky) (/ (sin th) (sin kx)))
(if (<= t_2 0.98) t_1 (sin th)))))))
double code(double kx, double ky, double th) {
double t_1 = (sin(ky) / hypot(sin(kx), sin(ky))) * th;
double t_2 = sin(ky) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)));
double tmp;
if (t_2 <= -0.98) {
tmp = (sin(ky) / sqrt(((kx * kx) + pow((2.0 / (1.0 - cos((2.0 * ky)))), -1.0)))) * sin(th);
} else if (t_2 <= -0.002) {
tmp = t_1;
} else if (t_2 <= 5e-9) {
tmp = sin(ky) * (sin(th) / sin(kx));
} else if (t_2 <= 0.98) {
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) / Math.hypot(Math.sin(kx), Math.sin(ky))) * th;
double t_2 = Math.sin(ky) / Math.sqrt((Math.pow(Math.sin(kx), 2.0) + Math.pow(Math.sin(ky), 2.0)));
double tmp;
if (t_2 <= -0.98) {
tmp = (Math.sin(ky) / Math.sqrt(((kx * kx) + Math.pow((2.0 / (1.0 - Math.cos((2.0 * ky)))), -1.0)))) * Math.sin(th);
} else if (t_2 <= -0.002) {
tmp = t_1;
} else if (t_2 <= 5e-9) {
tmp = Math.sin(ky) * (Math.sin(th) / Math.sin(kx));
} else if (t_2 <= 0.98) {
tmp = t_1;
} else {
tmp = Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): t_1 = (math.sin(ky) / math.hypot(math.sin(kx), math.sin(ky))) * th t_2 = math.sin(ky) / math.sqrt((math.pow(math.sin(kx), 2.0) + math.pow(math.sin(ky), 2.0))) tmp = 0 if t_2 <= -0.98: tmp = (math.sin(ky) / math.sqrt(((kx * kx) + math.pow((2.0 / (1.0 - math.cos((2.0 * ky)))), -1.0)))) * math.sin(th) elif t_2 <= -0.002: tmp = t_1 elif t_2 <= 5e-9: tmp = math.sin(ky) * (math.sin(th) / math.sin(kx)) elif t_2 <= 0.98: tmp = t_1 else: tmp = math.sin(th) return tmp
function code(kx, ky, th) t_1 = Float64(Float64(sin(ky) / hypot(sin(kx), sin(ky))) * th) t_2 = Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) tmp = 0.0 if (t_2 <= -0.98) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(kx * kx) + (Float64(2.0 / Float64(1.0 - cos(Float64(2.0 * ky)))) ^ -1.0)))) * sin(th)); elseif (t_2 <= -0.002) tmp = t_1; elseif (t_2 <= 5e-9) tmp = Float64(sin(ky) * Float64(sin(th) / sin(kx))); elseif (t_2 <= 0.98) tmp = t_1; else tmp = sin(th); end return tmp end
function tmp_2 = code(kx, ky, th) t_1 = (sin(ky) / hypot(sin(kx), sin(ky))) * th; t_2 = sin(ky) / sqrt(((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0))); tmp = 0.0; if (t_2 <= -0.98) tmp = (sin(ky) / sqrt(((kx * kx) + ((2.0 / (1.0 - cos((2.0 * ky)))) ^ -1.0)))) * sin(th); elseif (t_2 <= -0.002) tmp = t_1; elseif (t_2 <= 5e-9) tmp = sin(ky) * (sin(th) / sin(kx)); elseif (t_2 <= 0.98) 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] / N[Sqrt[N[Sin[kx], $MachinePrecision] ^ 2 + N[Sin[ky], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision] * th), $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]}, If[LessEqual[t$95$2, -0.98], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[(kx * kx), $MachinePrecision] + N[Power[N[(2.0 / N[(1.0 - N[Cos[N[(2.0 * ky), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], -1.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, -0.002], t$95$1, If[LessEqual[t$95$2, 5e-9], N[(N[Sin[ky], $MachinePrecision] * N[(N[Sin[th], $MachinePrecision] / N[Sin[kx], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, 0.98], t$95$1, N[Sin[th], $MachinePrecision]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \frac{\sin ky}{\mathsf{hypot}\left(\sin kx, \sin ky\right)} \cdot th\\
t_2 := \frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}}\\
\mathbf{if}\;t\_2 \leq -0.98:\\
\;\;\;\;\frac{\sin ky}{\sqrt{kx \cdot kx + {\left(\frac{2}{1 - \cos \left(2 \cdot ky\right)}\right)}^{-1}}} \cdot \sin th\\
\mathbf{elif}\;t\_2 \leq -0.002:\\
\;\;\;\;t\_1\\
\mathbf{elif}\;t\_2 \leq 5 \cdot 10^{-9}:\\
\;\;\;\;\sin ky \cdot \frac{\sin th}{\sin kx}\\
\mathbf{elif}\;t\_2 \leq 0.98:\\
\;\;\;\;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.97999999999999998Initial program 86.5%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f6482.8
Applied rewrites82.8%
lift-pow.f64N/A
pow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
clear-numN/A
lower-/.f64N/A
lower-/.f64N/A
cos-diffN/A
cos-sin-sumN/A
lower--.f64N/A
lower-cos.f64N/A
count-2N/A
lower-*.f6454.3
Applied rewrites54.3%
if -0.97999999999999998 < (/.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))))) < -2e-3 or 5.0000000000000001e-9 < (/.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.97999999999999998Initial program 99.4%
Taylor expanded in th around 0
lower-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f64N/A
lower-sqrt.f64N/A
lower-/.f64N/A
unpow2N/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-sin.f64N/A
lower-pow.f64N/A
lower-sin.f6457.6
Applied rewrites57.6%
Applied rewrites57.6%
if -2e-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))))) < 5.0000000000000001e-9Initial program 98.7%
Taylor expanded in ky around 0
lower-sin.f6453.2
Applied rewrites53.2%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
associate-/l*N/A
lower-*.f64N/A
lower-/.f6453.3
Applied rewrites53.3%
if 0.97999999999999998 < (/.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 92.9%
Taylor expanded in kx around 0
lower-sin.f6497.7
Applied rewrites97.7%
Final simplification65.2%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (* (/ th (hypot (sin kx) (sin ky))) (sin ky)))
(t_2 (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0))))))
(if (<= t_2 -0.98)
(*
(/
(sin ky)
(sqrt (+ (* kx kx) (pow (/ 2.0 (- 1.0 (cos (* 2.0 ky)))) -1.0))))
(sin th))
(if (<= t_2 -0.002)
t_1
(if (<= t_2 5e-16)
(* (sin ky) (/ (sin th) (sin kx)))
(if (<= t_2 0.98) t_1 (sin th)))))))
double code(double kx, double ky, double th) {
double t_1 = (th / hypot(sin(kx), sin(ky))) * sin(ky);
double t_2 = sin(ky) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)));
double tmp;
if (t_2 <= -0.98) {
tmp = (sin(ky) / sqrt(((kx * kx) + pow((2.0 / (1.0 - cos((2.0 * ky)))), -1.0)))) * sin(th);
} else if (t_2 <= -0.002) {
tmp = t_1;
} else if (t_2 <= 5e-16) {
tmp = sin(ky) * (sin(th) / sin(kx));
} else if (t_2 <= 0.98) {
tmp = t_1;
} else {
tmp = sin(th);
}
return tmp;
}
public static double code(double kx, double ky, double th) {
double t_1 = (th / Math.hypot(Math.sin(kx), Math.sin(ky))) * Math.sin(ky);
double t_2 = Math.sin(ky) / Math.sqrt((Math.pow(Math.sin(kx), 2.0) + Math.pow(Math.sin(ky), 2.0)));
double tmp;
if (t_2 <= -0.98) {
tmp = (Math.sin(ky) / Math.sqrt(((kx * kx) + Math.pow((2.0 / (1.0 - Math.cos((2.0 * ky)))), -1.0)))) * Math.sin(th);
} else if (t_2 <= -0.002) {
tmp = t_1;
} else if (t_2 <= 5e-16) {
tmp = Math.sin(ky) * (Math.sin(th) / Math.sin(kx));
} else if (t_2 <= 0.98) {
tmp = t_1;
} else {
tmp = Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): t_1 = (th / math.hypot(math.sin(kx), math.sin(ky))) * math.sin(ky) t_2 = math.sin(ky) / math.sqrt((math.pow(math.sin(kx), 2.0) + math.pow(math.sin(ky), 2.0))) tmp = 0 if t_2 <= -0.98: tmp = (math.sin(ky) / math.sqrt(((kx * kx) + math.pow((2.0 / (1.0 - math.cos((2.0 * ky)))), -1.0)))) * math.sin(th) elif t_2 <= -0.002: tmp = t_1 elif t_2 <= 5e-16: tmp = math.sin(ky) * (math.sin(th) / math.sin(kx)) elif t_2 <= 0.98: tmp = t_1 else: tmp = math.sin(th) return tmp
function code(kx, ky, th) t_1 = Float64(Float64(th / hypot(sin(kx), sin(ky))) * sin(ky)) t_2 = Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) tmp = 0.0 if (t_2 <= -0.98) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(kx * kx) + (Float64(2.0 / Float64(1.0 - cos(Float64(2.0 * ky)))) ^ -1.0)))) * sin(th)); elseif (t_2 <= -0.002) tmp = t_1; elseif (t_2 <= 5e-16) tmp = Float64(sin(ky) * Float64(sin(th) / sin(kx))); elseif (t_2 <= 0.98) tmp = t_1; else tmp = sin(th); end return tmp end
function tmp_2 = code(kx, ky, th) t_1 = (th / hypot(sin(kx), sin(ky))) * sin(ky); t_2 = sin(ky) / sqrt(((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0))); tmp = 0.0; if (t_2 <= -0.98) tmp = (sin(ky) / sqrt(((kx * kx) + ((2.0 / (1.0 - cos((2.0 * ky)))) ^ -1.0)))) * sin(th); elseif (t_2 <= -0.002) tmp = t_1; elseif (t_2 <= 5e-16) tmp = sin(ky) * (sin(th) / sin(kx)); elseif (t_2 <= 0.98) tmp = t_1; else tmp = sin(th); end tmp_2 = tmp; end
code[kx_, ky_, th_] := Block[{t$95$1 = N[(N[(th / N[Sqrt[N[Sin[kx], $MachinePrecision] ^ 2 + N[Sin[ky], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision] * N[Sin[ky], $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]}, If[LessEqual[t$95$2, -0.98], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[(kx * kx), $MachinePrecision] + N[Power[N[(2.0 / N[(1.0 - N[Cos[N[(2.0 * ky), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], -1.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, -0.002], t$95$1, If[LessEqual[t$95$2, 5e-16], N[(N[Sin[ky], $MachinePrecision] * N[(N[Sin[th], $MachinePrecision] / N[Sin[kx], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, 0.98], t$95$1, N[Sin[th], $MachinePrecision]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \frac{th}{\mathsf{hypot}\left(\sin kx, \sin ky\right)} \cdot \sin ky\\
t_2 := \frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}}\\
\mathbf{if}\;t\_2 \leq -0.98:\\
\;\;\;\;\frac{\sin ky}{\sqrt{kx \cdot kx + {\left(\frac{2}{1 - \cos \left(2 \cdot ky\right)}\right)}^{-1}}} \cdot \sin th\\
\mathbf{elif}\;t\_2 \leq -0.002:\\
\;\;\;\;t\_1\\
\mathbf{elif}\;t\_2 \leq 5 \cdot 10^{-16}:\\
\;\;\;\;\sin ky \cdot \frac{\sin th}{\sin kx}\\
\mathbf{elif}\;t\_2 \leq 0.98:\\
\;\;\;\;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.97999999999999998Initial program 86.5%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f6482.8
Applied rewrites82.8%
lift-pow.f64N/A
pow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
clear-numN/A
lower-/.f64N/A
lower-/.f64N/A
cos-diffN/A
cos-sin-sumN/A
lower--.f64N/A
lower-cos.f64N/A
count-2N/A
lower-*.f6454.3
Applied rewrites54.3%
if -0.97999999999999998 < (/.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))))) < -2e-3 or 5.0000000000000004e-16 < (/.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.97999999999999998Initial program 99.4%
Taylor expanded in th around 0
lower-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f64N/A
lower-sqrt.f64N/A
lower-/.f64N/A
unpow2N/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-sin.f64N/A
lower-pow.f64N/A
lower-sin.f6457.6
Applied rewrites57.6%
Applied rewrites57.5%
if -2e-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))))) < 5.0000000000000004e-16Initial program 98.7%
Taylor expanded in ky around 0
lower-sin.f6453.2
Applied rewrites53.2%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
associate-/l*N/A
lower-*.f64N/A
lower-/.f6453.3
Applied rewrites53.3%
if 0.97999999999999998 < (/.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 92.9%
Taylor expanded in kx around 0
lower-sin.f6497.7
Applied rewrites97.7%
Final simplification65.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.99)
(*
(/
(sin ky)
(sqrt (+ (* kx kx) (pow (/ 2.0 (- 1.0 (cos (* 2.0 ky)))) -1.0))))
(sin th))
(if (<= t_1 5e-9) (* (sin ky) (/ (sin th) (sin kx))) (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.99) {
tmp = (sin(ky) / sqrt(((kx * kx) + pow((2.0 / (1.0 - cos((2.0 * ky)))), -1.0)))) * sin(th);
} else if (t_1 <= 5e-9) {
tmp = sin(ky) * (sin(th) / 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) :: t_1
real(8) :: tmp
t_1 = sin(ky) / sqrt(((sin(kx) ** 2.0d0) + (sin(ky) ** 2.0d0)))
if (t_1 <= (-0.99d0)) then
tmp = (sin(ky) / sqrt(((kx * kx) + ((2.0d0 / (1.0d0 - cos((2.0d0 * ky)))) ** (-1.0d0))))) * sin(th)
else if (t_1 <= 5d-9) then
tmp = sin(ky) * (sin(th) / sin(kx))
else
tmp = sin(th)
end if
code = tmp
end function
public static double code(double kx, double ky, double th) {
double t_1 = Math.sin(ky) / Math.sqrt((Math.pow(Math.sin(kx), 2.0) + Math.pow(Math.sin(ky), 2.0)));
double tmp;
if (t_1 <= -0.99) {
tmp = (Math.sin(ky) / Math.sqrt(((kx * kx) + Math.pow((2.0 / (1.0 - Math.cos((2.0 * ky)))), -1.0)))) * Math.sin(th);
} else if (t_1 <= 5e-9) {
tmp = Math.sin(ky) * (Math.sin(th) / Math.sin(kx));
} else {
tmp = Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): t_1 = math.sin(ky) / math.sqrt((math.pow(math.sin(kx), 2.0) + math.pow(math.sin(ky), 2.0))) tmp = 0 if t_1 <= -0.99: tmp = (math.sin(ky) / math.sqrt(((kx * kx) + math.pow((2.0 / (1.0 - math.cos((2.0 * ky)))), -1.0)))) * math.sin(th) elif t_1 <= 5e-9: tmp = math.sin(ky) * (math.sin(th) / math.sin(kx)) else: tmp = math.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.99) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(kx * kx) + (Float64(2.0 / Float64(1.0 - cos(Float64(2.0 * ky)))) ^ -1.0)))) * sin(th)); elseif (t_1 <= 5e-9) tmp = Float64(sin(ky) * Float64(sin(th) / sin(kx))); else tmp = sin(th); end return tmp end
function tmp_2 = code(kx, ky, th) t_1 = sin(ky) / sqrt(((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0))); tmp = 0.0; if (t_1 <= -0.99) tmp = (sin(ky) / sqrt(((kx * kx) + ((2.0 / (1.0 - cos((2.0 * ky)))) ^ -1.0)))) * sin(th); elseif (t_1 <= 5e-9) tmp = sin(ky) * (sin(th) / sin(kx)); else tmp = sin(th); end tmp_2 = 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.99], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[(kx * kx), $MachinePrecision] + N[Power[N[(2.0 / N[(1.0 - N[Cos[N[(2.0 * ky), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], -1.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$1, 5e-9], N[(N[Sin[ky], $MachinePrecision] * N[(N[Sin[th], $MachinePrecision] / N[Sin[kx], $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}}}\\
\mathbf{if}\;t\_1 \leq -0.99:\\
\;\;\;\;\frac{\sin ky}{\sqrt{kx \cdot kx + {\left(\frac{2}{1 - \cos \left(2 \cdot ky\right)}\right)}^{-1}}} \cdot \sin th\\
\mathbf{elif}\;t\_1 \leq 5 \cdot 10^{-9}:\\
\;\;\;\;\sin ky \cdot \frac{\sin th}{\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.98999999999999999Initial program 86.0%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f6486.0
Applied rewrites86.0%
lift-pow.f64N/A
pow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
clear-numN/A
lower-/.f64N/A
lower-/.f64N/A
cos-diffN/A
cos-sin-sumN/A
lower--.f64N/A
lower-cos.f64N/A
count-2N/A
lower-*.f6456.3
Applied rewrites56.3%
if -0.98999999999999999 < (/.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))))) < 5.0000000000000001e-9Initial program 98.9%
Taylor expanded in ky around 0
lower-sin.f6441.3
Applied rewrites41.3%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
associate-/l*N/A
lower-*.f64N/A
lower-/.f6441.3
Applied rewrites41.3%
if 5.0000000000000001e-9 < (/.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.6%
Taylor expanded in kx around 0
lower-sin.f6477.0
Applied rewrites77.0%
Final simplification55.9%
(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.99)
(*
(/ (sin ky) (sqrt (+ (* kx kx) (- 0.5 (* (cos (* 2.0 ky)) 0.5)))))
(sin th))
(if (<= t_1 5e-9) (* (sin ky) (/ (sin th) (sin kx))) (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.99) {
tmp = (sin(ky) / sqrt(((kx * kx) + (0.5 - (cos((2.0 * ky)) * 0.5))))) * sin(th);
} else if (t_1 <= 5e-9) {
tmp = sin(ky) * (sin(th) / 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) :: t_1
real(8) :: tmp
t_1 = sin(ky) / sqrt(((sin(kx) ** 2.0d0) + (sin(ky) ** 2.0d0)))
if (t_1 <= (-0.99d0)) then
tmp = (sin(ky) / sqrt(((kx * kx) + (0.5d0 - (cos((2.0d0 * ky)) * 0.5d0))))) * sin(th)
else if (t_1 <= 5d-9) then
tmp = sin(ky) * (sin(th) / sin(kx))
else
tmp = sin(th)
end if
code = tmp
end function
public static double code(double kx, double ky, double th) {
double t_1 = Math.sin(ky) / Math.sqrt((Math.pow(Math.sin(kx), 2.0) + Math.pow(Math.sin(ky), 2.0)));
double tmp;
if (t_1 <= -0.99) {
tmp = (Math.sin(ky) / Math.sqrt(((kx * kx) + (0.5 - (Math.cos((2.0 * ky)) * 0.5))))) * Math.sin(th);
} else if (t_1 <= 5e-9) {
tmp = Math.sin(ky) * (Math.sin(th) / Math.sin(kx));
} else {
tmp = Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): t_1 = math.sin(ky) / math.sqrt((math.pow(math.sin(kx), 2.0) + math.pow(math.sin(ky), 2.0))) tmp = 0 if t_1 <= -0.99: tmp = (math.sin(ky) / math.sqrt(((kx * kx) + (0.5 - (math.cos((2.0 * ky)) * 0.5))))) * math.sin(th) elif t_1 <= 5e-9: tmp = math.sin(ky) * (math.sin(th) / math.sin(kx)) else: tmp = math.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.99) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(kx * kx) + Float64(0.5 - Float64(cos(Float64(2.0 * ky)) * 0.5))))) * sin(th)); elseif (t_1 <= 5e-9) tmp = Float64(sin(ky) * Float64(sin(th) / sin(kx))); else tmp = sin(th); end return tmp end
function tmp_2 = code(kx, ky, th) t_1 = sin(ky) / sqrt(((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0))); tmp = 0.0; if (t_1 <= -0.99) tmp = (sin(ky) / sqrt(((kx * kx) + (0.5 - (cos((2.0 * ky)) * 0.5))))) * sin(th); elseif (t_1 <= 5e-9) tmp = sin(ky) * (sin(th) / sin(kx)); else tmp = sin(th); end tmp_2 = 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.99], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[(kx * kx), $MachinePrecision] + N[(0.5 - N[(N[Cos[N[(2.0 * ky), $MachinePrecision]], $MachinePrecision] * 0.5), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$1, 5e-9], N[(N[Sin[ky], $MachinePrecision] * N[(N[Sin[th], $MachinePrecision] / N[Sin[kx], $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}}}\\
\mathbf{if}\;t\_1 \leq -0.99:\\
\;\;\;\;\frac{\sin ky}{\sqrt{kx \cdot kx + \left(0.5 - \cos \left(2 \cdot ky\right) \cdot 0.5\right)}} \cdot \sin th\\
\mathbf{elif}\;t\_1 \leq 5 \cdot 10^{-9}:\\
\;\;\;\;\sin ky \cdot \frac{\sin th}{\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.98999999999999999Initial program 86.0%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f6486.0
Applied rewrites86.0%
lift-pow.f64N/A
pow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
count-2N/A
*-commutativeN/A
lower-*.f64N/A
lower-cos.f64N/A
count-2N/A
lower-*.f6456.2
Applied rewrites56.2%
if -0.98999999999999999 < (/.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))))) < 5.0000000000000001e-9Initial program 98.9%
Taylor expanded in ky around 0
lower-sin.f6441.3
Applied rewrites41.3%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
associate-/l*N/A
lower-*.f64N/A
lower-/.f6441.3
Applied rewrites41.3%
if 5.0000000000000001e-9 < (/.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.6%
Taylor expanded in kx around 0
lower-sin.f6477.0
Applied rewrites77.0%
(FPCore (kx ky th) :precision binary64 (if (<= (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))) 5e-9) (* (sin ky) (/ (sin th) (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)))) <= 5e-9) {
tmp = sin(ky) * (sin(th) / 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)))) <= 5d-9) then
tmp = sin(ky) * (sin(th) / 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)))) <= 5e-9) {
tmp = Math.sin(ky) * (Math.sin(th) / 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)))) <= 5e-9: tmp = math.sin(ky) * (math.sin(th) / 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)))) <= 5e-9) tmp = Float64(sin(ky) * Float64(sin(th) / 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)))) <= 5e-9) tmp = sin(ky) * (sin(th) / 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], 5e-9], N[(N[Sin[ky], $MachinePrecision] * N[(N[Sin[th], $MachinePrecision] / N[Sin[kx], $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 5 \cdot 10^{-9}:\\
\;\;\;\;\sin ky \cdot \frac{\sin th}{\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))))) < 5.0000000000000001e-9Initial program 95.2%
Taylor expanded in ky around 0
lower-sin.f6431.7
Applied rewrites31.7%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
associate-/l*N/A
lower-*.f64N/A
lower-/.f6431.7
Applied rewrites31.7%
if 5.0000000000000001e-9 < (/.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.6%
Taylor expanded in kx around 0
lower-sin.f6477.0
Applied rewrites77.0%
(FPCore (kx ky th) :precision binary64 (if (<= (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))) 5e-9) (/ (sin th) (/ (sin kx) ky)) (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)))) <= 5e-9) {
tmp = sin(th) / (sin(kx) / ky);
} 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)))) <= 5d-9) then
tmp = sin(th) / (sin(kx) / ky)
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)))) <= 5e-9) {
tmp = Math.sin(th) / (Math.sin(kx) / ky);
} 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)))) <= 5e-9: tmp = math.sin(th) / (math.sin(kx) / ky) 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)))) <= 5e-9) tmp = Float64(sin(th) / Float64(sin(kx) / ky)); 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)))) <= 5e-9) tmp = sin(th) / (sin(kx) / ky); 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], 5e-9], N[(N[Sin[th], $MachinePrecision] / N[(N[Sin[kx], $MachinePrecision] / ky), $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 5 \cdot 10^{-9}:\\
\;\;\;\;\frac{\sin th}{\frac{\sin kx}{ky}}\\
\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))))) < 5.0000000000000001e-9Initial program 95.2%
lift-*.f64N/A
*-commutativeN/A
lift-/.f64N/A
clear-numN/A
un-div-invN/A
lower-/.f64N/A
lower-/.f6495.2
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%
Taylor expanded in ky around 0
lower-/.f64N/A
lower-sin.f6429.5
Applied rewrites29.5%
if 5.0000000000000001e-9 < (/.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.6%
Taylor expanded in kx around 0
lower-sin.f6477.0
Applied rewrites77.0%
(FPCore (kx ky th) :precision binary64 (if (<= (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))) 5e-9) (* (/ 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)))) <= 5e-9) {
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)))) <= 5d-9) 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)))) <= 5e-9) {
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)))) <= 5e-9: 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)))) <= 5e-9) 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)))) <= 5e-9) 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], 5e-9], 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 5 \cdot 10^{-9}:\\
\;\;\;\;\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))))) < 5.0000000000000001e-9Initial program 95.2%
Taylor expanded in ky around 0
lower-/.f64N/A
lower-sin.f6429.5
Applied rewrites29.5%
if 5.0000000000000001e-9 < (/.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.6%
Taylor expanded in kx around 0
lower-sin.f6477.0
Applied rewrites77.0%
(FPCore (kx ky th) :precision binary64 (if (<= (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))) 1e-23) (/ (sin th) (/ kx ky)) (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-23) {
tmp = sin(th) / (kx / ky);
} 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-23) then
tmp = sin(th) / (kx / ky)
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-23) {
tmp = Math.sin(th) / (kx / ky);
} 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-23: tmp = math.sin(th) / (kx / ky) 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-23) tmp = Float64(sin(th) / Float64(kx / ky)); 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-23) tmp = sin(th) / (kx / ky); 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-23], N[(N[Sin[th], $MachinePrecision] / N[(kx / ky), $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^{-23}:\\
\;\;\;\;\frac{\sin th}{\frac{kx}{ky}}\\
\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))))) < 9.9999999999999996e-24Initial program 95.2%
lift-*.f64N/A
*-commutativeN/A
lift-/.f64N/A
clear-numN/A
un-div-invN/A
lower-/.f64N/A
lower-/.f6495.1
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%
Taylor expanded in ky around 0
lower-/.f64N/A
lower-sin.f6429.3
Applied rewrites29.3%
Taylor expanded in kx around 0
Applied rewrites19.5%
if 9.9999999999999996e-24 < (/.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.7%
Taylor expanded in kx around 0
lower-sin.f6475.5
Applied rewrites75.5%
(FPCore (kx ky th) :precision binary64 (if (<= (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))) 5e-9) (* (/ th (sin kx)) ky) (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)))) <= 5e-9) {
tmp = (th / sin(kx)) * ky;
} 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)))) <= 5d-9) then
tmp = (th / sin(kx)) * ky
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)))) <= 5e-9) {
tmp = (th / Math.sin(kx)) * ky;
} 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)))) <= 5e-9: tmp = (th / math.sin(kx)) * ky 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)))) <= 5e-9) tmp = Float64(Float64(th / sin(kx)) * ky); 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)))) <= 5e-9) tmp = (th / sin(kx)) * ky; 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], 5e-9], N[(N[(th / N[Sin[kx], $MachinePrecision]), $MachinePrecision] * ky), $MachinePrecision], N[Sin[th], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}} \leq 5 \cdot 10^{-9}:\\
\;\;\;\;\frac{th}{\sin kx} \cdot ky\\
\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))))) < 5.0000000000000001e-9Initial program 95.2%
Taylor expanded in th around 0
lower-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f64N/A
lower-sqrt.f64N/A
lower-/.f64N/A
unpow2N/A
lower-fma.f64N/A
lower-sin.f64N/A
lower-sin.f64N/A
lower-pow.f64N/A
lower-sin.f6442.1
Applied rewrites42.1%
Taylor expanded in ky around 0
Applied rewrites16.5%
if 5.0000000000000001e-9 < (/.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.6%
Taylor expanded in kx around 0
lower-sin.f6477.0
Applied rewrites77.0%
(FPCore (kx ky th) :precision binary64 (if (<= (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))) 3.6e-50) (* (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-50) {
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-50) 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-50) {
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-50: 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-50) 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-50) 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-50], 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^{-50}:\\
\;\;\;\;{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.59999999999999979e-50Initial program 95.2%
Taylor expanded in kx around 0
lower-sin.f643.1
Applied rewrites3.1%
Taylor expanded in th around 0
Applied rewrites3.1%
Taylor expanded in th around inf
Applied rewrites12.0%
if 3.59999999999999979e-50 < (/.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.7%
Taylor expanded in kx around 0
lower-sin.f6471.1
Applied rewrites71.1%
(FPCore (kx ky th)
:precision binary64
(if (<= ky 1.32e-5)
(/ (* (sin th) ky) (hypot (sin ky) (sin kx)))
(*
(/
(sin ky)
(/
(sqrt
(fma (- 1.0 (cos (* ky 2.0))) 2.0 (* 2.0 (- 1.0 (cos (* 2.0 kx))))))
2.0))
(sin th))))
double code(double kx, double ky, double th) {
double tmp;
if (ky <= 1.32e-5) {
tmp = (sin(th) * ky) / hypot(sin(ky), sin(kx));
} else {
tmp = (sin(ky) / (sqrt(fma((1.0 - cos((ky * 2.0))), 2.0, (2.0 * (1.0 - cos((2.0 * kx)))))) / 2.0)) * sin(th);
}
return tmp;
}
function code(kx, ky, th) tmp = 0.0 if (ky <= 1.32e-5) tmp = Float64(Float64(sin(th) * ky) / hypot(sin(ky), sin(kx))); else tmp = Float64(Float64(sin(ky) / Float64(sqrt(fma(Float64(1.0 - cos(Float64(ky * 2.0))), 2.0, Float64(2.0 * Float64(1.0 - cos(Float64(2.0 * kx)))))) / 2.0)) * sin(th)); end return tmp end
code[kx_, ky_, th_] := If[LessEqual[ky, 1.32e-5], N[(N[(N[Sin[th], $MachinePrecision] * ky), $MachinePrecision] / N[Sqrt[N[Sin[ky], $MachinePrecision] ^ 2 + N[Sin[kx], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision], 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[(2.0 * N[(1.0 - N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;ky \leq 1.32 \cdot 10^{-5}:\\
\;\;\;\;\frac{\sin th \cdot ky}{\mathsf{hypot}\left(\sin ky, \sin kx\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{\sin ky}{\frac{\sqrt{\mathsf{fma}\left(1 - \cos \left(ky \cdot 2\right), 2, 2 \cdot \left(1 - \cos \left(2 \cdot kx\right)\right)\right)}}{2}} \cdot \sin th\\
\end{array}
\end{array}
if ky < 1.32000000000000007e-5Initial program 93.1%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
lower-/.f64N/A
*-commutativeN/A
lower-*.f6489.8
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-pow.f64N/A
unpow2N/A
lower-hypot.f6494.8
Applied rewrites94.8%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
lower-sin.f6468.4
Applied rewrites68.4%
if 1.32000000000000007e-5 < ky Initial program 99.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 rewrites99.0%
(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 95.0%
Taylor expanded in kx around 0
lower-sin.f6427.6
Applied rewrites27.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 95.0%
Taylor expanded in kx around 0
lower-sin.f6427.6
Applied rewrites27.6%
Taylor expanded in th around 0
Applied rewrites16.0%
Applied rewrites16.0%
Applied rewrites16.0%
herbie shell --seed 2024323
(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)))