
(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 19 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) (/ (sin ky) (hypot (sin ky) (sin kx)))))
double code(double kx, double ky, double th) {
return sin(th) * (sin(ky) / hypot(sin(ky), sin(kx)));
}
public static double code(double kx, double ky, double th) {
return Math.sin(th) * (Math.sin(ky) / Math.hypot(Math.sin(ky), Math.sin(kx)));
}
def code(kx, ky, th): return math.sin(th) * (math.sin(ky) / math.hypot(math.sin(ky), math.sin(kx)))
function code(kx, ky, th) return Float64(sin(th) * Float64(sin(ky) / hypot(sin(ky), sin(kx)))) end
function tmp = code(kx, ky, th) tmp = sin(th) * (sin(ky) / hypot(sin(ky), sin(kx))); end
code[kx_, ky_, th_] := N[(N[Sin[th], $MachinePrecision] * N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[Sin[ky], $MachinePrecision] ^ 2 + N[Sin[kx], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\sin th \cdot \frac{\sin ky}{\mathsf{hypot}\left(\sin ky, \sin kx\right)}
\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%
Final simplification99.7%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (/ (sin ky) (sqrt (+ (pow (sin ky) 2.0) (pow (sin kx) 2.0)))))
(t_2 (/ (* th (sin ky)) (hypot (sin ky) (sin kx)))))
(if (<= t_1 -0.999)
(*
(/ (sin ky) (sqrt (+ (- 0.5 (* (cos (* 2.0 ky)) 0.5)) (* kx kx))))
(sin th))
(if (<= t_1 -0.3)
t_2
(if (<= t_1 3e-56)
(*
(/ (sin ky) (sqrt (+ (- 0.5 (* 0.5 (cos (* 2.0 kx)))) (* ky ky))))
(sin th))
(if (<= t_1 5e-8)
(* (/ (sin th) (sin kx)) (sin ky))
(if (<= t_1 0.905) t_2 (sin th))))))))
double code(double kx, double ky, double th) {
double t_1 = sin(ky) / sqrt((pow(sin(ky), 2.0) + pow(sin(kx), 2.0)));
double t_2 = (th * sin(ky)) / hypot(sin(ky), sin(kx));
double tmp;
if (t_1 <= -0.999) {
tmp = (sin(ky) / sqrt(((0.5 - (cos((2.0 * ky)) * 0.5)) + (kx * kx)))) * sin(th);
} else if (t_1 <= -0.3) {
tmp = t_2;
} else if (t_1 <= 3e-56) {
tmp = (sin(ky) / sqrt(((0.5 - (0.5 * cos((2.0 * kx)))) + (ky * ky)))) * sin(th);
} else if (t_1 <= 5e-8) {
tmp = (sin(th) / sin(kx)) * sin(ky);
} else if (t_1 <= 0.905) {
tmp = t_2;
} else {
tmp = sin(th);
}
return tmp;
}
public static double code(double kx, double ky, double th) {
double t_1 = Math.sin(ky) / Math.sqrt((Math.pow(Math.sin(ky), 2.0) + Math.pow(Math.sin(kx), 2.0)));
double t_2 = (th * Math.sin(ky)) / Math.hypot(Math.sin(ky), Math.sin(kx));
double tmp;
if (t_1 <= -0.999) {
tmp = (Math.sin(ky) / Math.sqrt(((0.5 - (Math.cos((2.0 * ky)) * 0.5)) + (kx * kx)))) * Math.sin(th);
} else if (t_1 <= -0.3) {
tmp = t_2;
} else if (t_1 <= 3e-56) {
tmp = (Math.sin(ky) / Math.sqrt(((0.5 - (0.5 * Math.cos((2.0 * kx)))) + (ky * ky)))) * Math.sin(th);
} else if (t_1 <= 5e-8) {
tmp = (Math.sin(th) / Math.sin(kx)) * Math.sin(ky);
} else if (t_1 <= 0.905) {
tmp = t_2;
} else {
tmp = Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): t_1 = math.sin(ky) / math.sqrt((math.pow(math.sin(ky), 2.0) + math.pow(math.sin(kx), 2.0))) t_2 = (th * math.sin(ky)) / math.hypot(math.sin(ky), math.sin(kx)) tmp = 0 if t_1 <= -0.999: tmp = (math.sin(ky) / math.sqrt(((0.5 - (math.cos((2.0 * ky)) * 0.5)) + (kx * kx)))) * math.sin(th) elif t_1 <= -0.3: tmp = t_2 elif t_1 <= 3e-56: tmp = (math.sin(ky) / math.sqrt(((0.5 - (0.5 * math.cos((2.0 * kx)))) + (ky * ky)))) * math.sin(th) elif t_1 <= 5e-8: tmp = (math.sin(th) / math.sin(kx)) * math.sin(ky) elif t_1 <= 0.905: tmp = t_2 else: tmp = math.sin(th) return tmp
function code(kx, ky, th) t_1 = Float64(sin(ky) / sqrt(Float64((sin(ky) ^ 2.0) + (sin(kx) ^ 2.0)))) t_2 = Float64(Float64(th * sin(ky)) / hypot(sin(ky), sin(kx))) tmp = 0.0 if (t_1 <= -0.999) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(0.5 - Float64(cos(Float64(2.0 * ky)) * 0.5)) + Float64(kx * kx)))) * sin(th)); elseif (t_1 <= -0.3) tmp = t_2; elseif (t_1 <= 3e-56) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(0.5 - Float64(0.5 * cos(Float64(2.0 * kx)))) + Float64(ky * ky)))) * sin(th)); elseif (t_1 <= 5e-8) tmp = Float64(Float64(sin(th) / sin(kx)) * sin(ky)); elseif (t_1 <= 0.905) tmp = t_2; else tmp = sin(th); end return tmp end
function tmp_2 = code(kx, ky, th) t_1 = sin(ky) / sqrt(((sin(ky) ^ 2.0) + (sin(kx) ^ 2.0))); t_2 = (th * sin(ky)) / hypot(sin(ky), sin(kx)); tmp = 0.0; if (t_1 <= -0.999) tmp = (sin(ky) / sqrt(((0.5 - (cos((2.0 * ky)) * 0.5)) + (kx * kx)))) * sin(th); elseif (t_1 <= -0.3) tmp = t_2; elseif (t_1 <= 3e-56) tmp = (sin(ky) / sqrt(((0.5 - (0.5 * cos((2.0 * kx)))) + (ky * ky)))) * sin(th); elseif (t_1 <= 5e-8) tmp = (sin(th) / sin(kx)) * sin(ky); elseif (t_1 <= 0.905) tmp = t_2; 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[ky], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[(N[(th * N[Sin[ky], $MachinePrecision]), $MachinePrecision] / N[Sqrt[N[Sin[ky], $MachinePrecision] ^ 2 + N[Sin[kx], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$1, -0.999], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[(0.5 - N[(N[Cos[N[(2.0 * ky), $MachinePrecision]], $MachinePrecision] * 0.5), $MachinePrecision]), $MachinePrecision] + N[(kx * kx), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$1, -0.3], t$95$2, If[LessEqual[t$95$1, 3e-56], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[(0.5 - N[(0.5 * N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] + N[(ky * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$1, 5e-8], N[(N[(N[Sin[th], $MachinePrecision] / N[Sin[kx], $MachinePrecision]), $MachinePrecision] * N[Sin[ky], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$1, 0.905], t$95$2, N[Sin[th], $MachinePrecision]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \frac{\sin ky}{\sqrt{{\sin ky}^{2} + {\sin kx}^{2}}}\\
t_2 := \frac{th \cdot \sin ky}{\mathsf{hypot}\left(\sin ky, \sin kx\right)}\\
\mathbf{if}\;t\_1 \leq -0.999:\\
\;\;\;\;\frac{\sin ky}{\sqrt{\left(0.5 - \cos \left(2 \cdot ky\right) \cdot 0.5\right) + kx \cdot kx}} \cdot \sin th\\
\mathbf{elif}\;t\_1 \leq -0.3:\\
\;\;\;\;t\_2\\
\mathbf{elif}\;t\_1 \leq 3 \cdot 10^{-56}:\\
\;\;\;\;\frac{\sin ky}{\sqrt{\left(0.5 - 0.5 \cdot \cos \left(2 \cdot kx\right)\right) + ky \cdot ky}} \cdot \sin th\\
\mathbf{elif}\;t\_1 \leq 5 \cdot 10^{-8}:\\
\;\;\;\;\frac{\sin th}{\sin kx} \cdot \sin ky\\
\mathbf{elif}\;t\_1 \leq 0.905:\\
\;\;\;\;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.998999999999999999Initial program 88.7%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f6488.7
Applied rewrites88.7%
lift-pow.f64N/A
pow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2N/A
lower-cos.f64N/A
count-2N/A
lower-*.f6468.4
Applied rewrites68.4%
if -0.998999999999999999 < (/.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.299999999999999989 or 4.9999999999999998e-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))))) < 0.90500000000000003Initial program 99.4%
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.f6457.3
Applied rewrites57.3%
if -0.299999999999999989 < (/.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))))) < 2.99999999999999989e-56Initial program 99.2%
Taylor expanded in ky around 0
unpow2N/A
lower-*.f6498.1
Applied rewrites98.1%
lift-pow.f64N/A
pow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2N/A
lower-cos.f64N/A
count-2N/A
lower-*.f6478.6
Applied rewrites78.6%
if 2.99999999999999989e-56 < (/.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))))) < 4.9999999999999998e-8Initial program 99.7%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
associate-/l*N/A
*-commutativeN/A
lower-*.f64N/A
lower-/.f6499.8
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-pow.f64N/A
unpow2N/A
lower-hypot.f6499.8
Applied rewrites99.8%
Taylor expanded in ky around 0
lower-sin.f6477.9
Applied rewrites77.9%
if 0.90500000000000003 < (/.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 89.2%
Taylor expanded in kx around 0
lower-sin.f6489.7
Applied rewrites89.7%
Final simplification73.8%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (hypot (sin kx) (sin ky)))
(t_2 (pow (sin ky) 2.0))
(t_3 (/ (sin ky) (sqrt (+ t_2 (pow (sin kx) 2.0))))))
(if (<= t_3 -0.999)
(/
1.0
(/
(sqrt (fma (* (fma -0.3333333333333333 (* kx kx) 1.0) kx) kx t_2))
(* (sin th) (sin ky))))
(if (<= t_3 -0.2)
(/
1.0
(/ (* (/ t_1 (sin ky)) (fma (* th th) 0.16666666666666666 1.0)) th))
(if (<= t_3 5e-8)
(* (/ (sin th) (sqrt (fma (sin kx) (sin kx) (* ky ky)))) (sin ky))
(if (<= t_3 0.995)
(/ 1.0 (/ t_1 (* th (sin ky))))
(*
(/ (sin ky) (fma (* (/ 0.5 (sin ky)) kx) kx (sin ky)))
(sin th))))))))
double code(double kx, double ky, double th) {
double t_1 = hypot(sin(kx), sin(ky));
double t_2 = pow(sin(ky), 2.0);
double t_3 = sin(ky) / sqrt((t_2 + pow(sin(kx), 2.0)));
double tmp;
if (t_3 <= -0.999) {
tmp = 1.0 / (sqrt(fma((fma(-0.3333333333333333, (kx * kx), 1.0) * kx), kx, t_2)) / (sin(th) * sin(ky)));
} else if (t_3 <= -0.2) {
tmp = 1.0 / (((t_1 / sin(ky)) * fma((th * th), 0.16666666666666666, 1.0)) / th);
} else if (t_3 <= 5e-8) {
tmp = (sin(th) / sqrt(fma(sin(kx), sin(kx), (ky * ky)))) * sin(ky);
} else if (t_3 <= 0.995) {
tmp = 1.0 / (t_1 / (th * sin(ky)));
} else {
tmp = (sin(ky) / fma(((0.5 / sin(ky)) * kx), kx, sin(ky))) * sin(th);
}
return tmp;
}
function code(kx, ky, th) t_1 = hypot(sin(kx), sin(ky)) t_2 = sin(ky) ^ 2.0 t_3 = Float64(sin(ky) / sqrt(Float64(t_2 + (sin(kx) ^ 2.0)))) tmp = 0.0 if (t_3 <= -0.999) tmp = Float64(1.0 / Float64(sqrt(fma(Float64(fma(-0.3333333333333333, Float64(kx * kx), 1.0) * kx), kx, t_2)) / Float64(sin(th) * sin(ky)))); elseif (t_3 <= -0.2) tmp = Float64(1.0 / Float64(Float64(Float64(t_1 / sin(ky)) * fma(Float64(th * th), 0.16666666666666666, 1.0)) / th)); elseif (t_3 <= 5e-8) tmp = Float64(Float64(sin(th) / sqrt(fma(sin(kx), sin(kx), Float64(ky * ky)))) * sin(ky)); elseif (t_3 <= 0.995) tmp = Float64(1.0 / Float64(t_1 / Float64(th * sin(ky)))); else tmp = Float64(Float64(sin(ky) / fma(Float64(Float64(0.5 / sin(ky)) * kx), kx, sin(ky))) * sin(th)); end return 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[ky], $MachinePrecision], 2.0], $MachinePrecision]}, Block[{t$95$3 = N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(t$95$2 + N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$3, -0.999], N[(1.0 / N[(N[Sqrt[N[(N[(N[(-0.3333333333333333 * N[(kx * kx), $MachinePrecision] + 1.0), $MachinePrecision] * kx), $MachinePrecision] * kx + t$95$2), $MachinePrecision]], $MachinePrecision] / N[(N[Sin[th], $MachinePrecision] * N[Sin[ky], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$3, -0.2], N[(1.0 / N[(N[(N[(t$95$1 / N[Sin[ky], $MachinePrecision]), $MachinePrecision] * N[(N[(th * th), $MachinePrecision] * 0.16666666666666666 + 1.0), $MachinePrecision]), $MachinePrecision] / th), $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$3, 5e-8], N[(N[(N[Sin[th], $MachinePrecision] / N[Sqrt[N[(N[Sin[kx], $MachinePrecision] * N[Sin[kx], $MachinePrecision] + N[(ky * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[ky], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$3, 0.995], N[(1.0 / N[(t$95$1 / N[(th * N[Sin[ky], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(N[Sin[ky], $MachinePrecision] / N[(N[(N[(0.5 / N[Sin[ky], $MachinePrecision]), $MachinePrecision] * kx), $MachinePrecision] * kx + N[Sin[ky], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \mathsf{hypot}\left(\sin kx, \sin ky\right)\\
t_2 := {\sin ky}^{2}\\
t_3 := \frac{\sin ky}{\sqrt{t\_2 + {\sin kx}^{2}}}\\
\mathbf{if}\;t\_3 \leq -0.999:\\
\;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{fma}\left(\mathsf{fma}\left(-0.3333333333333333, kx \cdot kx, 1\right) \cdot kx, kx, t\_2\right)}}{\sin th \cdot \sin ky}}\\
\mathbf{elif}\;t\_3 \leq -0.2:\\
\;\;\;\;\frac{1}{\frac{\frac{t\_1}{\sin ky} \cdot \mathsf{fma}\left(th \cdot th, 0.16666666666666666, 1\right)}{th}}\\
\mathbf{elif}\;t\_3 \leq 5 \cdot 10^{-8}:\\
\;\;\;\;\frac{\sin th}{\sqrt{\mathsf{fma}\left(\sin kx, \sin kx, ky \cdot ky\right)}} \cdot \sin ky\\
\mathbf{elif}\;t\_3 \leq 0.995:\\
\;\;\;\;\frac{1}{\frac{t\_1}{th \cdot \sin ky}}\\
\mathbf{else}:\\
\;\;\;\;\frac{\sin ky}{\mathsf{fma}\left(\frac{0.5}{\sin ky} \cdot kx, kx, \sin ky\right)} \cdot \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.998999999999999999Initial program 88.7%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f6488.7
Applied rewrites88.7%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
clear-numN/A
lower-/.f64N/A
lower-/.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
pow2N/A
lower-fma.f64N/A
*-commutativeN/A
lower-*.f6486.4
Applied rewrites86.4%
Taylor expanded in kx around 0
*-commutativeN/A
unpow2N/A
associate-*r*N/A
lower-fma.f64N/A
lower-*.f64N/A
+-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f64N/A
lower-pow.f64N/A
lower-sin.f6486.5
Applied rewrites86.5%
if -0.998999999999999999 < (/.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.4%
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.0%
Taylor expanded in th around 0
Applied rewrites51.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))))) < 4.9999999999999998e-8Initial program 99.3%
Taylor expanded in ky around 0
unpow2N/A
lower-*.f6498.2
Applied rewrites98.2%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
associate-/l*N/A
lower-*.f64N/A
lower-/.f6498.3
lift-+.f64N/A
lift-pow.f64N/A
pow2N/A
lower-fma.f6498.3
Applied rewrites98.3%
if 4.9999999999999998e-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))))) < 0.994999999999999996Initial program 99.4%
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.0%
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.f6462.9
Applied rewrites62.9%
if 0.994999999999999996 < (/.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 88.8%
Taylor expanded in kx around 0
+-commutativeN/A
*-lft-identityN/A
associate-*l/N/A
associate-*l*N/A
unpow2N/A
associate-*r*N/A
lower-fma.f64N/A
lower-*.f64N/A
associate-*r/N/A
metadata-evalN/A
lower-/.f64N/A
lower-sin.f64N/A
lower-sin.f6493.5
Applied rewrites93.5%
Final simplification84.8%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (pow (sin ky) 2.0))
(t_2 (/ (sin ky) (sqrt (+ t_1 (pow (sin kx) 2.0)))))
(t_3 (hypot (sin kx) (sin ky))))
(if (<= t_2 -0.999)
(* (/ (sin ky) (sqrt (+ (* kx kx) t_1))) (sin th))
(if (<= t_2 -0.2)
(/
1.0
(/ (* (/ t_3 (sin ky)) (fma (* th th) 0.16666666666666666 1.0)) th))
(if (<= t_2 5e-8)
(* (/ (sin th) (sqrt (fma (sin kx) (sin kx) (* ky ky)))) (sin ky))
(if (<= t_2 0.995)
(/ 1.0 (/ t_3 (* th (sin ky))))
(*
(/ (sin ky) (fma (* (/ 0.5 (sin ky)) kx) kx (sin ky)))
(sin th))))))))
double code(double kx, double ky, double th) {
double t_1 = pow(sin(ky), 2.0);
double t_2 = sin(ky) / sqrt((t_1 + pow(sin(kx), 2.0)));
double t_3 = hypot(sin(kx), sin(ky));
double tmp;
if (t_2 <= -0.999) {
tmp = (sin(ky) / sqrt(((kx * kx) + t_1))) * sin(th);
} else if (t_2 <= -0.2) {
tmp = 1.0 / (((t_3 / sin(ky)) * fma((th * th), 0.16666666666666666, 1.0)) / th);
} else if (t_2 <= 5e-8) {
tmp = (sin(th) / sqrt(fma(sin(kx), sin(kx), (ky * ky)))) * sin(ky);
} else if (t_2 <= 0.995) {
tmp = 1.0 / (t_3 / (th * sin(ky)));
} else {
tmp = (sin(ky) / fma(((0.5 / sin(ky)) * kx), kx, sin(ky))) * sin(th);
}
return tmp;
}
function code(kx, ky, th) t_1 = sin(ky) ^ 2.0 t_2 = Float64(sin(ky) / sqrt(Float64(t_1 + (sin(kx) ^ 2.0)))) t_3 = hypot(sin(kx), sin(ky)) tmp = 0.0 if (t_2 <= -0.999) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(kx * kx) + t_1))) * sin(th)); elseif (t_2 <= -0.2) tmp = Float64(1.0 / Float64(Float64(Float64(t_3 / sin(ky)) * fma(Float64(th * th), 0.16666666666666666, 1.0)) / th)); elseif (t_2 <= 5e-8) tmp = Float64(Float64(sin(th) / sqrt(fma(sin(kx), sin(kx), Float64(ky * ky)))) * sin(ky)); elseif (t_2 <= 0.995) tmp = Float64(1.0 / Float64(t_3 / Float64(th * sin(ky)))); else tmp = Float64(Float64(sin(ky) / fma(Float64(Float64(0.5 / sin(ky)) * kx), kx, sin(ky))) * 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[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(t$95$1 + N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$3 = N[Sqrt[N[Sin[kx], $MachinePrecision] ^ 2 + N[Sin[ky], $MachinePrecision] ^ 2], $MachinePrecision]}, If[LessEqual[t$95$2, -0.999], 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$2, -0.2], N[(1.0 / N[(N[(N[(t$95$3 / N[Sin[ky], $MachinePrecision]), $MachinePrecision] * N[(N[(th * th), $MachinePrecision] * 0.16666666666666666 + 1.0), $MachinePrecision]), $MachinePrecision] / th), $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, 5e-8], N[(N[(N[Sin[th], $MachinePrecision] / N[Sqrt[N[(N[Sin[kx], $MachinePrecision] * N[Sin[kx], $MachinePrecision] + N[(ky * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[ky], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, 0.995], N[(1.0 / N[(t$95$3 / N[(th * N[Sin[ky], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(N[Sin[ky], $MachinePrecision] / N[(N[(N[(0.5 / N[Sin[ky], $MachinePrecision]), $MachinePrecision] * kx), $MachinePrecision] * kx + N[Sin[ky], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := {\sin ky}^{2}\\
t_2 := \frac{\sin ky}{\sqrt{t\_1 + {\sin kx}^{2}}}\\
t_3 := \mathsf{hypot}\left(\sin kx, \sin ky\right)\\
\mathbf{if}\;t\_2 \leq -0.999:\\
\;\;\;\;\frac{\sin ky}{\sqrt{kx \cdot kx + t\_1}} \cdot \sin th\\
\mathbf{elif}\;t\_2 \leq -0.2:\\
\;\;\;\;\frac{1}{\frac{\frac{t\_3}{\sin ky} \cdot \mathsf{fma}\left(th \cdot th, 0.16666666666666666, 1\right)}{th}}\\
\mathbf{elif}\;t\_2 \leq 5 \cdot 10^{-8}:\\
\;\;\;\;\frac{\sin th}{\sqrt{\mathsf{fma}\left(\sin kx, \sin kx, ky \cdot ky\right)}} \cdot \sin ky\\
\mathbf{elif}\;t\_2 \leq 0.995:\\
\;\;\;\;\frac{1}{\frac{t\_3}{th \cdot \sin ky}}\\
\mathbf{else}:\\
\;\;\;\;\frac{\sin ky}{\mathsf{fma}\left(\frac{0.5}{\sin ky} \cdot kx, kx, \sin ky\right)} \cdot \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.998999999999999999Initial program 88.7%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f6488.7
Applied rewrites88.7%
if -0.998999999999999999 < (/.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.4%
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.0%
Taylor expanded in th around 0
Applied rewrites51.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))))) < 4.9999999999999998e-8Initial program 99.3%
Taylor expanded in ky around 0
unpow2N/A
lower-*.f6498.2
Applied rewrites98.2%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
associate-/l*N/A
lower-*.f64N/A
lower-/.f6498.3
lift-+.f64N/A
lift-pow.f64N/A
pow2N/A
lower-fma.f6498.3
Applied rewrites98.3%
if 4.9999999999999998e-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))))) < 0.994999999999999996Initial program 99.4%
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.0%
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.f6462.9
Applied rewrites62.9%
if 0.994999999999999996 < (/.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 88.8%
Taylor expanded in kx around 0
+-commutativeN/A
*-lft-identityN/A
associate-*l/N/A
associate-*l*N/A
unpow2N/A
associate-*r*N/A
lower-fma.f64N/A
lower-*.f64N/A
associate-*r/N/A
metadata-evalN/A
lower-/.f64N/A
lower-sin.f64N/A
lower-sin.f6493.5
Applied rewrites93.5%
Final simplification85.3%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (pow (sin ky) 2.0))
(t_2 (/ (sin ky) (sqrt (+ t_1 (pow (sin kx) 2.0)))))
(t_3 (* th (sin ky))))
(if (<= t_2 -0.999)
(* (/ (sin ky) (sqrt (+ (* kx kx) t_1))) (sin th))
(if (<= t_2 -0.3)
(/ t_3 (hypot (sin ky) (sin kx)))
(if (<= t_2 5e-8)
(* (/ (sin th) (sqrt (fma (sin kx) (sin kx) (* ky ky)))) (sin ky))
(if (<= t_2 0.995)
(/ 1.0 (/ (hypot (sin kx) (sin ky)) t_3))
(*
(/ (sin ky) (fma (* (/ 0.5 (sin ky)) kx) kx (sin ky)))
(sin th))))))))
double code(double kx, double ky, double th) {
double t_1 = pow(sin(ky), 2.0);
double t_2 = sin(ky) / sqrt((t_1 + pow(sin(kx), 2.0)));
double t_3 = th * sin(ky);
double tmp;
if (t_2 <= -0.999) {
tmp = (sin(ky) / sqrt(((kx * kx) + t_1))) * sin(th);
} else if (t_2 <= -0.3) {
tmp = t_3 / hypot(sin(ky), sin(kx));
} else if (t_2 <= 5e-8) {
tmp = (sin(th) / sqrt(fma(sin(kx), sin(kx), (ky * ky)))) * sin(ky);
} else if (t_2 <= 0.995) {
tmp = 1.0 / (hypot(sin(kx), sin(ky)) / t_3);
} else {
tmp = (sin(ky) / fma(((0.5 / sin(ky)) * kx), kx, sin(ky))) * sin(th);
}
return tmp;
}
function code(kx, ky, th) t_1 = sin(ky) ^ 2.0 t_2 = Float64(sin(ky) / sqrt(Float64(t_1 + (sin(kx) ^ 2.0)))) t_3 = Float64(th * sin(ky)) tmp = 0.0 if (t_2 <= -0.999) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(kx * kx) + t_1))) * sin(th)); elseif (t_2 <= -0.3) tmp = Float64(t_3 / hypot(sin(ky), sin(kx))); elseif (t_2 <= 5e-8) tmp = Float64(Float64(sin(th) / sqrt(fma(sin(kx), sin(kx), Float64(ky * ky)))) * sin(ky)); elseif (t_2 <= 0.995) tmp = Float64(1.0 / Float64(hypot(sin(kx), sin(ky)) / t_3)); else tmp = Float64(Float64(sin(ky) / fma(Float64(Float64(0.5 / sin(ky)) * kx), kx, sin(ky))) * 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[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(t$95$1 + N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$3 = N[(th * N[Sin[ky], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$2, -0.999], 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$2, -0.3], N[(t$95$3 / N[Sqrt[N[Sin[ky], $MachinePrecision] ^ 2 + N[Sin[kx], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, 5e-8], N[(N[(N[Sin[th], $MachinePrecision] / N[Sqrt[N[(N[Sin[kx], $MachinePrecision] * N[Sin[kx], $MachinePrecision] + N[(ky * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[ky], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, 0.995], N[(1.0 / N[(N[Sqrt[N[Sin[kx], $MachinePrecision] ^ 2 + N[Sin[ky], $MachinePrecision] ^ 2], $MachinePrecision] / t$95$3), $MachinePrecision]), $MachinePrecision], N[(N[(N[Sin[ky], $MachinePrecision] / N[(N[(N[(0.5 / N[Sin[ky], $MachinePrecision]), $MachinePrecision] * kx), $MachinePrecision] * kx + N[Sin[ky], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := {\sin ky}^{2}\\
t_2 := \frac{\sin ky}{\sqrt{t\_1 + {\sin kx}^{2}}}\\
t_3 := th \cdot \sin ky\\
\mathbf{if}\;t\_2 \leq -0.999:\\
\;\;\;\;\frac{\sin ky}{\sqrt{kx \cdot kx + t\_1}} \cdot \sin th\\
\mathbf{elif}\;t\_2 \leq -0.3:\\
\;\;\;\;\frac{t\_3}{\mathsf{hypot}\left(\sin ky, \sin kx\right)}\\
\mathbf{elif}\;t\_2 \leq 5 \cdot 10^{-8}:\\
\;\;\;\;\frac{\sin th}{\sqrt{\mathsf{fma}\left(\sin kx, \sin kx, ky \cdot ky\right)}} \cdot \sin ky\\
\mathbf{elif}\;t\_2 \leq 0.995:\\
\;\;\;\;\frac{1}{\frac{\mathsf{hypot}\left(\sin kx, \sin ky\right)}{t\_3}}\\
\mathbf{else}:\\
\;\;\;\;\frac{\sin ky}{\mathsf{fma}\left(\frac{0.5}{\sin ky} \cdot kx, kx, \sin ky\right)} \cdot \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.998999999999999999Initial program 88.7%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f6488.7
Applied rewrites88.7%
if -0.998999999999999999 < (/.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.299999999999999989Initial program 99.4%
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.f6451.5
Applied rewrites51.5%
if -0.299999999999999989 < (/.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))))) < 4.9999999999999998e-8Initial program 99.3%
Taylor expanded in ky around 0
unpow2N/A
lower-*.f6498.2
Applied rewrites98.2%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
associate-/l*N/A
lower-*.f64N/A
lower-/.f6498.3
lift-+.f64N/A
lift-pow.f64N/A
pow2N/A
lower-fma.f6498.3
Applied rewrites98.3%
if 4.9999999999999998e-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))))) < 0.994999999999999996Initial program 99.4%
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.0%
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.f6462.9
Applied rewrites62.9%
if 0.994999999999999996 < (/.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 88.8%
Taylor expanded in kx around 0
+-commutativeN/A
*-lft-identityN/A
associate-*l/N/A
associate-*l*N/A
unpow2N/A
associate-*r*N/A
lower-fma.f64N/A
lower-*.f64N/A
associate-*r/N/A
metadata-evalN/A
lower-/.f64N/A
lower-sin.f64N/A
lower-sin.f6493.5
Applied rewrites93.5%
Final simplification85.3%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (pow (sin ky) 2.0))
(t_2 (/ (sin ky) (sqrt (+ t_1 (pow (sin kx) 2.0)))))
(t_3 (* th (sin ky))))
(if (<= t_2 -0.999)
(* (/ (sin ky) (sqrt (+ (* kx kx) t_1))) (sin th))
(if (<= t_2 -0.3)
(/ t_3 (hypot (sin ky) (sin kx)))
(if (<= t_2 5e-8)
(* (/ (sin th) (sqrt (fma (sin kx) (sin kx) (* ky ky)))) (sin ky))
(if (<= t_2 0.905)
(/ 1.0 (/ (hypot (sin kx) (sin ky)) t_3))
(sin th)))))))
double code(double kx, double ky, double th) {
double t_1 = pow(sin(ky), 2.0);
double t_2 = sin(ky) / sqrt((t_1 + pow(sin(kx), 2.0)));
double t_3 = th * sin(ky);
double tmp;
if (t_2 <= -0.999) {
tmp = (sin(ky) / sqrt(((kx * kx) + t_1))) * sin(th);
} else if (t_2 <= -0.3) {
tmp = t_3 / hypot(sin(ky), sin(kx));
} else if (t_2 <= 5e-8) {
tmp = (sin(th) / sqrt(fma(sin(kx), sin(kx), (ky * ky)))) * sin(ky);
} else if (t_2 <= 0.905) {
tmp = 1.0 / (hypot(sin(kx), sin(ky)) / t_3);
} else {
tmp = sin(th);
}
return tmp;
}
function code(kx, ky, th) t_1 = sin(ky) ^ 2.0 t_2 = Float64(sin(ky) / sqrt(Float64(t_1 + (sin(kx) ^ 2.0)))) t_3 = Float64(th * sin(ky)) tmp = 0.0 if (t_2 <= -0.999) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(kx * kx) + t_1))) * sin(th)); elseif (t_2 <= -0.3) tmp = Float64(t_3 / hypot(sin(ky), sin(kx))); elseif (t_2 <= 5e-8) tmp = Float64(Float64(sin(th) / sqrt(fma(sin(kx), sin(kx), Float64(ky * ky)))) * sin(ky)); elseif (t_2 <= 0.905) tmp = Float64(1.0 / Float64(hypot(sin(kx), sin(ky)) / t_3)); 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[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(t$95$1 + N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$3 = N[(th * N[Sin[ky], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$2, -0.999], 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$2, -0.3], N[(t$95$3 / N[Sqrt[N[Sin[ky], $MachinePrecision] ^ 2 + N[Sin[kx], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, 5e-8], N[(N[(N[Sin[th], $MachinePrecision] / N[Sqrt[N[(N[Sin[kx], $MachinePrecision] * N[Sin[kx], $MachinePrecision] + N[(ky * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[ky], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, 0.905], N[(1.0 / N[(N[Sqrt[N[Sin[kx], $MachinePrecision] ^ 2 + N[Sin[ky], $MachinePrecision] ^ 2], $MachinePrecision] / t$95$3), $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := {\sin ky}^{2}\\
t_2 := \frac{\sin ky}{\sqrt{t\_1 + {\sin kx}^{2}}}\\
t_3 := th \cdot \sin ky\\
\mathbf{if}\;t\_2 \leq -0.999:\\
\;\;\;\;\frac{\sin ky}{\sqrt{kx \cdot kx + t\_1}} \cdot \sin th\\
\mathbf{elif}\;t\_2 \leq -0.3:\\
\;\;\;\;\frac{t\_3}{\mathsf{hypot}\left(\sin ky, \sin kx\right)}\\
\mathbf{elif}\;t\_2 \leq 5 \cdot 10^{-8}:\\
\;\;\;\;\frac{\sin th}{\sqrt{\mathsf{fma}\left(\sin kx, \sin kx, ky \cdot ky\right)}} \cdot \sin ky\\
\mathbf{elif}\;t\_2 \leq 0.905:\\
\;\;\;\;\frac{1}{\frac{\mathsf{hypot}\left(\sin kx, \sin ky\right)}{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.998999999999999999Initial program 88.7%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f6488.7
Applied rewrites88.7%
if -0.998999999999999999 < (/.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.299999999999999989Initial program 99.4%
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.f6451.5
Applied rewrites51.5%
if -0.299999999999999989 < (/.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))))) < 4.9999999999999998e-8Initial program 99.3%
Taylor expanded in ky around 0
unpow2N/A
lower-*.f6498.2
Applied rewrites98.2%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
associate-/l*N/A
lower-*.f64N/A
lower-/.f6498.3
lift-+.f64N/A
lift-pow.f64N/A
pow2N/A
lower-fma.f6498.3
Applied rewrites98.3%
if 4.9999999999999998e-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))))) < 0.90500000000000003Initial program 99.4%
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.1%
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.f6463.6
Applied rewrites63.6%
if 0.90500000000000003 < (/.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 89.2%
Taylor expanded in kx around 0
lower-sin.f6489.7
Applied rewrites89.7%
Final simplification84.8%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (pow (sin ky) 2.0))
(t_2 (* th (sin ky)))
(t_3 (pow (sin kx) 2.0))
(t_4 (/ (sin ky) (sqrt (+ t_1 t_3)))))
(if (<= t_4 -0.999)
(* (/ (sin ky) (sqrt (+ (* kx kx) t_1))) (sin th))
(if (<= t_4 -0.3)
(/ t_2 (hypot (sin ky) (sin kx)))
(if (<= t_4 5e-8)
(* (/ (sin ky) (sqrt (+ (* ky ky) t_3))) (sin th))
(if (<= t_4 0.905)
(/ 1.0 (/ (hypot (sin kx) (sin ky)) t_2))
(sin th)))))))
double code(double kx, double ky, double th) {
double t_1 = pow(sin(ky), 2.0);
double t_2 = th * sin(ky);
double t_3 = pow(sin(kx), 2.0);
double t_4 = sin(ky) / sqrt((t_1 + t_3));
double tmp;
if (t_4 <= -0.999) {
tmp = (sin(ky) / sqrt(((kx * kx) + t_1))) * sin(th);
} else if (t_4 <= -0.3) {
tmp = t_2 / hypot(sin(ky), sin(kx));
} else if (t_4 <= 5e-8) {
tmp = (sin(ky) / sqrt(((ky * ky) + t_3))) * sin(th);
} else if (t_4 <= 0.905) {
tmp = 1.0 / (hypot(sin(kx), sin(ky)) / t_2);
} 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 = th * Math.sin(ky);
double t_3 = Math.pow(Math.sin(kx), 2.0);
double t_4 = Math.sin(ky) / Math.sqrt((t_1 + t_3));
double tmp;
if (t_4 <= -0.999) {
tmp = (Math.sin(ky) / Math.sqrt(((kx * kx) + t_1))) * Math.sin(th);
} else if (t_4 <= -0.3) {
tmp = t_2 / Math.hypot(Math.sin(ky), Math.sin(kx));
} else if (t_4 <= 5e-8) {
tmp = (Math.sin(ky) / Math.sqrt(((ky * ky) + t_3))) * Math.sin(th);
} else if (t_4 <= 0.905) {
tmp = 1.0 / (Math.hypot(Math.sin(kx), Math.sin(ky)) / t_2);
} else {
tmp = Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): t_1 = math.pow(math.sin(ky), 2.0) t_2 = th * math.sin(ky) t_3 = math.pow(math.sin(kx), 2.0) t_4 = math.sin(ky) / math.sqrt((t_1 + t_3)) tmp = 0 if t_4 <= -0.999: tmp = (math.sin(ky) / math.sqrt(((kx * kx) + t_1))) * math.sin(th) elif t_4 <= -0.3: tmp = t_2 / math.hypot(math.sin(ky), math.sin(kx)) elif t_4 <= 5e-8: tmp = (math.sin(ky) / math.sqrt(((ky * ky) + t_3))) * math.sin(th) elif t_4 <= 0.905: tmp = 1.0 / (math.hypot(math.sin(kx), math.sin(ky)) / t_2) else: tmp = math.sin(th) return tmp
function code(kx, ky, th) t_1 = sin(ky) ^ 2.0 t_2 = Float64(th * sin(ky)) t_3 = sin(kx) ^ 2.0 t_4 = Float64(sin(ky) / sqrt(Float64(t_1 + t_3))) tmp = 0.0 if (t_4 <= -0.999) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(kx * kx) + t_1))) * sin(th)); elseif (t_4 <= -0.3) tmp = Float64(t_2 / hypot(sin(ky), sin(kx))); elseif (t_4 <= 5e-8) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(ky * ky) + t_3))) * sin(th)); elseif (t_4 <= 0.905) tmp = Float64(1.0 / Float64(hypot(sin(kx), sin(ky)) / t_2)); else tmp = sin(th); end return tmp end
function tmp_2 = code(kx, ky, th) t_1 = sin(ky) ^ 2.0; t_2 = th * sin(ky); t_3 = sin(kx) ^ 2.0; t_4 = sin(ky) / sqrt((t_1 + t_3)); tmp = 0.0; if (t_4 <= -0.999) tmp = (sin(ky) / sqrt(((kx * kx) + t_1))) * sin(th); elseif (t_4 <= -0.3) tmp = t_2 / hypot(sin(ky), sin(kx)); elseif (t_4 <= 5e-8) tmp = (sin(ky) / sqrt(((ky * ky) + t_3))) * sin(th); elseif (t_4 <= 0.905) tmp = 1.0 / (hypot(sin(kx), sin(ky)) / t_2); 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[(th * N[Sin[ky], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$3 = N[Power[N[Sin[kx], $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.999], 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$4, -0.3], N[(t$95$2 / N[Sqrt[N[Sin[ky], $MachinePrecision] ^ 2 + N[Sin[kx], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$4, 5e-8], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[(ky * ky), $MachinePrecision] + t$95$3), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$4, 0.905], N[(1.0 / N[(N[Sqrt[N[Sin[kx], $MachinePrecision] ^ 2 + N[Sin[ky], $MachinePrecision] ^ 2], $MachinePrecision] / t$95$2), $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := {\sin ky}^{2}\\
t_2 := th \cdot \sin ky\\
t_3 := {\sin kx}^{2}\\
t_4 := \frac{\sin ky}{\sqrt{t\_1 + t\_3}}\\
\mathbf{if}\;t\_4 \leq -0.999:\\
\;\;\;\;\frac{\sin ky}{\sqrt{kx \cdot kx + t\_1}} \cdot \sin th\\
\mathbf{elif}\;t\_4 \leq -0.3:\\
\;\;\;\;\frac{t\_2}{\mathsf{hypot}\left(\sin ky, \sin kx\right)}\\
\mathbf{elif}\;t\_4 \leq 5 \cdot 10^{-8}:\\
\;\;\;\;\frac{\sin ky}{\sqrt{ky \cdot ky + t\_3}} \cdot \sin th\\
\mathbf{elif}\;t\_4 \leq 0.905:\\
\;\;\;\;\frac{1}{\frac{\mathsf{hypot}\left(\sin kx, \sin ky\right)}{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.998999999999999999Initial program 88.7%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f6488.7
Applied rewrites88.7%
if -0.998999999999999999 < (/.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.299999999999999989Initial program 99.4%
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.f6451.5
Applied rewrites51.5%
if -0.299999999999999989 < (/.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))))) < 4.9999999999999998e-8Initial program 99.3%
Taylor expanded in ky around 0
unpow2N/A
lower-*.f6498.2
Applied rewrites98.2%
if 4.9999999999999998e-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))))) < 0.90500000000000003Initial program 99.4%
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.1%
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.f6463.6
Applied rewrites63.6%
if 0.90500000000000003 < (/.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 89.2%
Taylor expanded in kx around 0
lower-sin.f6489.7
Applied rewrites89.7%
Final simplification84.7%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (pow (sin ky) 2.0))
(t_2 (/ (sin ky) (sqrt (+ t_1 (pow (sin kx) 2.0)))))
(t_3 (* th (sin ky)))
(t_4 (hypot (sin ky) (sin kx))))
(if (<= t_2 -0.999)
(* (/ (sin ky) (sqrt (+ (* kx kx) t_1))) (sin th))
(if (<= t_2 -0.1)
(/ t_3 t_4)
(if (<= t_2 5e-8)
(/ (* (sin th) ky) t_4)
(if (<= t_2 0.905)
(/ 1.0 (/ (hypot (sin kx) (sin ky)) t_3))
(sin th)))))))
double code(double kx, double ky, double th) {
double t_1 = pow(sin(ky), 2.0);
double t_2 = sin(ky) / sqrt((t_1 + pow(sin(kx), 2.0)));
double t_3 = th * sin(ky);
double t_4 = hypot(sin(ky), sin(kx));
double tmp;
if (t_2 <= -0.999) {
tmp = (sin(ky) / sqrt(((kx * kx) + t_1))) * sin(th);
} else if (t_2 <= -0.1) {
tmp = t_3 / t_4;
} else if (t_2 <= 5e-8) {
tmp = (sin(th) * ky) / t_4;
} else if (t_2 <= 0.905) {
tmp = 1.0 / (hypot(sin(kx), sin(ky)) / t_3);
} 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.sin(ky) / Math.sqrt((t_1 + Math.pow(Math.sin(kx), 2.0)));
double t_3 = th * Math.sin(ky);
double t_4 = Math.hypot(Math.sin(ky), Math.sin(kx));
double tmp;
if (t_2 <= -0.999) {
tmp = (Math.sin(ky) / Math.sqrt(((kx * kx) + t_1))) * Math.sin(th);
} else if (t_2 <= -0.1) {
tmp = t_3 / t_4;
} else if (t_2 <= 5e-8) {
tmp = (Math.sin(th) * ky) / t_4;
} else if (t_2 <= 0.905) {
tmp = 1.0 / (Math.hypot(Math.sin(kx), Math.sin(ky)) / t_3);
} else {
tmp = Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): t_1 = math.pow(math.sin(ky), 2.0) t_2 = math.sin(ky) / math.sqrt((t_1 + math.pow(math.sin(kx), 2.0))) t_3 = th * math.sin(ky) t_4 = math.hypot(math.sin(ky), math.sin(kx)) tmp = 0 if t_2 <= -0.999: tmp = (math.sin(ky) / math.sqrt(((kx * kx) + t_1))) * math.sin(th) elif t_2 <= -0.1: tmp = t_3 / t_4 elif t_2 <= 5e-8: tmp = (math.sin(th) * ky) / t_4 elif t_2 <= 0.905: tmp = 1.0 / (math.hypot(math.sin(kx), math.sin(ky)) / t_3) else: tmp = math.sin(th) return tmp
function code(kx, ky, th) t_1 = sin(ky) ^ 2.0 t_2 = Float64(sin(ky) / sqrt(Float64(t_1 + (sin(kx) ^ 2.0)))) t_3 = Float64(th * sin(ky)) t_4 = hypot(sin(ky), sin(kx)) tmp = 0.0 if (t_2 <= -0.999) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(kx * kx) + t_1))) * sin(th)); elseif (t_2 <= -0.1) tmp = Float64(t_3 / t_4); elseif (t_2 <= 5e-8) tmp = Float64(Float64(sin(th) * ky) / t_4); elseif (t_2 <= 0.905) tmp = Float64(1.0 / Float64(hypot(sin(kx), sin(ky)) / t_3)); else tmp = sin(th); end return tmp end
function tmp_2 = code(kx, ky, th) t_1 = sin(ky) ^ 2.0; t_2 = sin(ky) / sqrt((t_1 + (sin(kx) ^ 2.0))); t_3 = th * sin(ky); t_4 = hypot(sin(ky), sin(kx)); tmp = 0.0; if (t_2 <= -0.999) tmp = (sin(ky) / sqrt(((kx * kx) + t_1))) * sin(th); elseif (t_2 <= -0.1) tmp = t_3 / t_4; elseif (t_2 <= 5e-8) tmp = (sin(th) * ky) / t_4; elseif (t_2 <= 0.905) tmp = 1.0 / (hypot(sin(kx), sin(ky)) / t_3); 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[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(t$95$1 + N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$3 = N[(th * N[Sin[ky], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$4 = N[Sqrt[N[Sin[ky], $MachinePrecision] ^ 2 + N[Sin[kx], $MachinePrecision] ^ 2], $MachinePrecision]}, If[LessEqual[t$95$2, -0.999], 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$2, -0.1], N[(t$95$3 / t$95$4), $MachinePrecision], If[LessEqual[t$95$2, 5e-8], N[(N[(N[Sin[th], $MachinePrecision] * ky), $MachinePrecision] / t$95$4), $MachinePrecision], If[LessEqual[t$95$2, 0.905], N[(1.0 / N[(N[Sqrt[N[Sin[kx], $MachinePrecision] ^ 2 + N[Sin[ky], $MachinePrecision] ^ 2], $MachinePrecision] / t$95$3), $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := {\sin ky}^{2}\\
t_2 := \frac{\sin ky}{\sqrt{t\_1 + {\sin kx}^{2}}}\\
t_3 := th \cdot \sin ky\\
t_4 := \mathsf{hypot}\left(\sin ky, \sin kx\right)\\
\mathbf{if}\;t\_2 \leq -0.999:\\
\;\;\;\;\frac{\sin ky}{\sqrt{kx \cdot kx + t\_1}} \cdot \sin th\\
\mathbf{elif}\;t\_2 \leq -0.1:\\
\;\;\;\;\frac{t\_3}{t\_4}\\
\mathbf{elif}\;t\_2 \leq 5 \cdot 10^{-8}:\\
\;\;\;\;\frac{\sin th \cdot ky}{t\_4}\\
\mathbf{elif}\;t\_2 \leq 0.905:\\
\;\;\;\;\frac{1}{\frac{\mathsf{hypot}\left(\sin kx, \sin ky\right)}{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.998999999999999999Initial program 88.7%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f6488.7
Applied rewrites88.7%
if -0.998999999999999999 < (/.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.10000000000000001Initial 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.f6450.2
Applied rewrites50.2%
if -0.10000000000000001 < (/.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))))) < 4.9999999999999998e-8Initial program 99.3%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
lower-/.f64N/A
*-commutativeN/A
lower-*.f6497.9
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-pow.f64N/A
unpow2N/A
lower-hypot.f6497.9
Applied rewrites97.9%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
lower-sin.f6497.9
Applied rewrites97.9%
if 4.9999999999999998e-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))))) < 0.90500000000000003Initial program 99.4%
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.1%
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.f6463.6
Applied rewrites63.6%
if 0.90500000000000003 < (/.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 89.2%
Taylor expanded in kx around 0
lower-sin.f6489.7
Applied rewrites89.7%
Final simplification84.3%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (* th (sin ky)))
(t_2 (hypot (sin ky) (sin kx)))
(t_3 (/ (sin ky) (sqrt (+ (pow (sin ky) 2.0) (pow (sin kx) 2.0))))))
(if (<= t_3 -0.999)
(*
(/ (sin ky) (sqrt (+ (- 0.5 (* (cos (* 2.0 ky)) 0.5)) (* kx kx))))
(sin th))
(if (<= t_3 -0.1)
(/ t_1 t_2)
(if (<= t_3 5e-8)
(/ (* (sin th) ky) t_2)
(if (<= t_3 0.905)
(/ 1.0 (/ (hypot (sin kx) (sin ky)) t_1))
(sin th)))))))
double code(double kx, double ky, double th) {
double t_1 = th * sin(ky);
double t_2 = hypot(sin(ky), sin(kx));
double t_3 = sin(ky) / sqrt((pow(sin(ky), 2.0) + pow(sin(kx), 2.0)));
double tmp;
if (t_3 <= -0.999) {
tmp = (sin(ky) / sqrt(((0.5 - (cos((2.0 * ky)) * 0.5)) + (kx * kx)))) * sin(th);
} else if (t_3 <= -0.1) {
tmp = t_1 / t_2;
} else if (t_3 <= 5e-8) {
tmp = (sin(th) * ky) / t_2;
} else if (t_3 <= 0.905) {
tmp = 1.0 / (hypot(sin(kx), sin(ky)) / t_1);
} else {
tmp = sin(th);
}
return tmp;
}
public static double code(double kx, double ky, double th) {
double t_1 = th * Math.sin(ky);
double t_2 = Math.hypot(Math.sin(ky), Math.sin(kx));
double t_3 = Math.sin(ky) / Math.sqrt((Math.pow(Math.sin(ky), 2.0) + Math.pow(Math.sin(kx), 2.0)));
double tmp;
if (t_3 <= -0.999) {
tmp = (Math.sin(ky) / Math.sqrt(((0.5 - (Math.cos((2.0 * ky)) * 0.5)) + (kx * kx)))) * Math.sin(th);
} else if (t_3 <= -0.1) {
tmp = t_1 / t_2;
} else if (t_3 <= 5e-8) {
tmp = (Math.sin(th) * ky) / t_2;
} else if (t_3 <= 0.905) {
tmp = 1.0 / (Math.hypot(Math.sin(kx), Math.sin(ky)) / t_1);
} else {
tmp = Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): t_1 = th * math.sin(ky) t_2 = math.hypot(math.sin(ky), math.sin(kx)) t_3 = math.sin(ky) / math.sqrt((math.pow(math.sin(ky), 2.0) + math.pow(math.sin(kx), 2.0))) tmp = 0 if t_3 <= -0.999: tmp = (math.sin(ky) / math.sqrt(((0.5 - (math.cos((2.0 * ky)) * 0.5)) + (kx * kx)))) * math.sin(th) elif t_3 <= -0.1: tmp = t_1 / t_2 elif t_3 <= 5e-8: tmp = (math.sin(th) * ky) / t_2 elif t_3 <= 0.905: tmp = 1.0 / (math.hypot(math.sin(kx), math.sin(ky)) / t_1) else: tmp = math.sin(th) return tmp
function code(kx, ky, th) t_1 = Float64(th * sin(ky)) t_2 = hypot(sin(ky), sin(kx)) t_3 = Float64(sin(ky) / sqrt(Float64((sin(ky) ^ 2.0) + (sin(kx) ^ 2.0)))) tmp = 0.0 if (t_3 <= -0.999) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(0.5 - Float64(cos(Float64(2.0 * ky)) * 0.5)) + Float64(kx * kx)))) * sin(th)); elseif (t_3 <= -0.1) tmp = Float64(t_1 / t_2); elseif (t_3 <= 5e-8) tmp = Float64(Float64(sin(th) * ky) / t_2); elseif (t_3 <= 0.905) tmp = Float64(1.0 / Float64(hypot(sin(kx), sin(ky)) / t_1)); else tmp = sin(th); end return tmp end
function tmp_2 = code(kx, ky, th) t_1 = th * sin(ky); t_2 = hypot(sin(ky), sin(kx)); t_3 = sin(ky) / sqrt(((sin(ky) ^ 2.0) + (sin(kx) ^ 2.0))); tmp = 0.0; if (t_3 <= -0.999) tmp = (sin(ky) / sqrt(((0.5 - (cos((2.0 * ky)) * 0.5)) + (kx * kx)))) * sin(th); elseif (t_3 <= -0.1) tmp = t_1 / t_2; elseif (t_3 <= 5e-8) tmp = (sin(th) * ky) / t_2; elseif (t_3 <= 0.905) tmp = 1.0 / (hypot(sin(kx), sin(ky)) / t_1); else tmp = sin(th); end tmp_2 = tmp; end
code[kx_, ky_, th_] := Block[{t$95$1 = N[(th * N[Sin[ky], $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[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$3, -0.999], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[(0.5 - N[(N[Cos[N[(2.0 * ky), $MachinePrecision]], $MachinePrecision] * 0.5), $MachinePrecision]), $MachinePrecision] + N[(kx * kx), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$3, -0.1], N[(t$95$1 / t$95$2), $MachinePrecision], If[LessEqual[t$95$3, 5e-8], N[(N[(N[Sin[th], $MachinePrecision] * ky), $MachinePrecision] / t$95$2), $MachinePrecision], If[LessEqual[t$95$3, 0.905], N[(1.0 / N[(N[Sqrt[N[Sin[kx], $MachinePrecision] ^ 2 + N[Sin[ky], $MachinePrecision] ^ 2], $MachinePrecision] / t$95$1), $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := th \cdot \sin ky\\
t_2 := \mathsf{hypot}\left(\sin ky, \sin kx\right)\\
t_3 := \frac{\sin ky}{\sqrt{{\sin ky}^{2} + {\sin kx}^{2}}}\\
\mathbf{if}\;t\_3 \leq -0.999:\\
\;\;\;\;\frac{\sin ky}{\sqrt{\left(0.5 - \cos \left(2 \cdot ky\right) \cdot 0.5\right) + kx \cdot kx}} \cdot \sin th\\
\mathbf{elif}\;t\_3 \leq -0.1:\\
\;\;\;\;\frac{t\_1}{t\_2}\\
\mathbf{elif}\;t\_3 \leq 5 \cdot 10^{-8}:\\
\;\;\;\;\frac{\sin th \cdot ky}{t\_2}\\
\mathbf{elif}\;t\_3 \leq 0.905:\\
\;\;\;\;\frac{1}{\frac{\mathsf{hypot}\left(\sin kx, \sin ky\right)}{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.998999999999999999Initial program 88.7%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f6488.7
Applied rewrites88.7%
lift-pow.f64N/A
pow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2N/A
lower-cos.f64N/A
count-2N/A
lower-*.f6468.4
Applied rewrites68.4%
if -0.998999999999999999 < (/.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.10000000000000001Initial 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.f6450.2
Applied rewrites50.2%
if -0.10000000000000001 < (/.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))))) < 4.9999999999999998e-8Initial program 99.3%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
lower-/.f64N/A
*-commutativeN/A
lower-*.f6497.9
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-pow.f64N/A
unpow2N/A
lower-hypot.f6497.9
Applied rewrites97.9%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
lower-sin.f6497.9
Applied rewrites97.9%
if 4.9999999999999998e-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))))) < 0.90500000000000003Initial program 99.4%
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.1%
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.f6463.6
Applied rewrites63.6%
if 0.90500000000000003 < (/.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 89.2%
Taylor expanded in kx around 0
lower-sin.f6489.7
Applied rewrites89.7%
Final simplification80.1%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (hypot (sin ky) (sin kx)))
(t_2 (/ (sin ky) (sqrt (+ (pow (sin ky) 2.0) (pow (sin kx) 2.0)))))
(t_3 (/ (* th (sin ky)) t_1)))
(if (<= t_2 -0.999)
(*
(/ (sin ky) (sqrt (+ (- 0.5 (* (cos (* 2.0 ky)) 0.5)) (* kx kx))))
(sin th))
(if (<= t_2 -0.1)
t_3
(if (<= t_2 5e-8)
(/ (* (sin th) ky) t_1)
(if (<= t_2 0.905) t_3 (sin th)))))))
double code(double kx, double ky, double th) {
double t_1 = hypot(sin(ky), sin(kx));
double t_2 = sin(ky) / sqrt((pow(sin(ky), 2.0) + pow(sin(kx), 2.0)));
double t_3 = (th * sin(ky)) / t_1;
double tmp;
if (t_2 <= -0.999) {
tmp = (sin(ky) / sqrt(((0.5 - (cos((2.0 * ky)) * 0.5)) + (kx * kx)))) * sin(th);
} else if (t_2 <= -0.1) {
tmp = t_3;
} else if (t_2 <= 5e-8) {
tmp = (sin(th) * ky) / t_1;
} else if (t_2 <= 0.905) {
tmp = t_3;
} else {
tmp = sin(th);
}
return tmp;
}
public static double code(double kx, double ky, double th) {
double t_1 = Math.hypot(Math.sin(ky), Math.sin(kx));
double t_2 = Math.sin(ky) / Math.sqrt((Math.pow(Math.sin(ky), 2.0) + Math.pow(Math.sin(kx), 2.0)));
double t_3 = (th * Math.sin(ky)) / t_1;
double tmp;
if (t_2 <= -0.999) {
tmp = (Math.sin(ky) / Math.sqrt(((0.5 - (Math.cos((2.0 * ky)) * 0.5)) + (kx * kx)))) * Math.sin(th);
} else if (t_2 <= -0.1) {
tmp = t_3;
} else if (t_2 <= 5e-8) {
tmp = (Math.sin(th) * ky) / t_1;
} else if (t_2 <= 0.905) {
tmp = t_3;
} else {
tmp = Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): t_1 = math.hypot(math.sin(ky), math.sin(kx)) t_2 = math.sin(ky) / math.sqrt((math.pow(math.sin(ky), 2.0) + math.pow(math.sin(kx), 2.0))) t_3 = (th * math.sin(ky)) / t_1 tmp = 0 if t_2 <= -0.999: tmp = (math.sin(ky) / math.sqrt(((0.5 - (math.cos((2.0 * ky)) * 0.5)) + (kx * kx)))) * math.sin(th) elif t_2 <= -0.1: tmp = t_3 elif t_2 <= 5e-8: tmp = (math.sin(th) * ky) / t_1 elif t_2 <= 0.905: tmp = t_3 else: tmp = math.sin(th) return tmp
function code(kx, ky, th) t_1 = hypot(sin(ky), sin(kx)) t_2 = Float64(sin(ky) / sqrt(Float64((sin(ky) ^ 2.0) + (sin(kx) ^ 2.0)))) t_3 = Float64(Float64(th * sin(ky)) / t_1) tmp = 0.0 if (t_2 <= -0.999) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(0.5 - Float64(cos(Float64(2.0 * ky)) * 0.5)) + Float64(kx * kx)))) * sin(th)); elseif (t_2 <= -0.1) tmp = t_3; elseif (t_2 <= 5e-8) tmp = Float64(Float64(sin(th) * ky) / t_1); elseif (t_2 <= 0.905) tmp = t_3; else tmp = sin(th); end return tmp end
function tmp_2 = code(kx, ky, th) t_1 = hypot(sin(ky), sin(kx)); t_2 = sin(ky) / sqrt(((sin(ky) ^ 2.0) + (sin(kx) ^ 2.0))); t_3 = (th * sin(ky)) / t_1; tmp = 0.0; if (t_2 <= -0.999) tmp = (sin(ky) / sqrt(((0.5 - (cos((2.0 * ky)) * 0.5)) + (kx * kx)))) * sin(th); elseif (t_2 <= -0.1) tmp = t_3; elseif (t_2 <= 5e-8) tmp = (sin(th) * ky) / t_1; elseif (t_2 <= 0.905) tmp = t_3; else tmp = sin(th); end tmp_2 = tmp; end
code[kx_, ky_, th_] := Block[{t$95$1 = N[Sqrt[N[Sin[ky], $MachinePrecision] ^ 2 + N[Sin[kx], $MachinePrecision] ^ 2], $MachinePrecision]}, Block[{t$95$2 = N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$3 = N[(N[(th * N[Sin[ky], $MachinePrecision]), $MachinePrecision] / t$95$1), $MachinePrecision]}, If[LessEqual[t$95$2, -0.999], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[(0.5 - N[(N[Cos[N[(2.0 * ky), $MachinePrecision]], $MachinePrecision] * 0.5), $MachinePrecision]), $MachinePrecision] + N[(kx * kx), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, -0.1], t$95$3, If[LessEqual[t$95$2, 5e-8], N[(N[(N[Sin[th], $MachinePrecision] * ky), $MachinePrecision] / t$95$1), $MachinePrecision], If[LessEqual[t$95$2, 0.905], t$95$3, N[Sin[th], $MachinePrecision]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \mathsf{hypot}\left(\sin ky, \sin kx\right)\\
t_2 := \frac{\sin ky}{\sqrt{{\sin ky}^{2} + {\sin kx}^{2}}}\\
t_3 := \frac{th \cdot \sin ky}{t\_1}\\
\mathbf{if}\;t\_2 \leq -0.999:\\
\;\;\;\;\frac{\sin ky}{\sqrt{\left(0.5 - \cos \left(2 \cdot ky\right) \cdot 0.5\right) + kx \cdot kx}} \cdot \sin th\\
\mathbf{elif}\;t\_2 \leq -0.1:\\
\;\;\;\;t\_3\\
\mathbf{elif}\;t\_2 \leq 5 \cdot 10^{-8}:\\
\;\;\;\;\frac{\sin th \cdot ky}{t\_1}\\
\mathbf{elif}\;t\_2 \leq 0.905:\\
\;\;\;\;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.998999999999999999Initial program 88.7%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f6488.7
Applied rewrites88.7%
lift-pow.f64N/A
pow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2N/A
lower-cos.f64N/A
count-2N/A
lower-*.f6468.4
Applied rewrites68.4%
if -0.998999999999999999 < (/.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.10000000000000001 or 4.9999999999999998e-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))))) < 0.90500000000000003Initial program 99.4%
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.f6456.5
Applied rewrites56.5%
if -0.10000000000000001 < (/.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))))) < 4.9999999999999998e-8Initial program 99.3%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
lower-/.f64N/A
*-commutativeN/A
lower-*.f6497.9
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-pow.f64N/A
unpow2N/A
lower-hypot.f6497.9
Applied rewrites97.9%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
lower-sin.f6497.9
Applied rewrites97.9%
if 0.90500000000000003 < (/.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 89.2%
Taylor expanded in kx around 0
lower-sin.f6489.7
Applied rewrites89.7%
Final simplification80.1%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (/ (sin ky) (sqrt (+ (pow (sin ky) 2.0) (pow (sin kx) 2.0))))))
(if (<= t_1 -0.999)
(*
(/ (sin ky) (sqrt (+ (- 0.5 (* (cos (* 2.0 ky)) 0.5)) (* kx kx))))
(sin th))
(if (<= t_1 0.43) (* (/ (sin th) (sin kx)) (sin ky)) (sin th)))))
double code(double kx, double ky, double th) {
double t_1 = sin(ky) / sqrt((pow(sin(ky), 2.0) + pow(sin(kx), 2.0)));
double tmp;
if (t_1 <= -0.999) {
tmp = (sin(ky) / sqrt(((0.5 - (cos((2.0 * ky)) * 0.5)) + (kx * kx)))) * sin(th);
} else if (t_1 <= 0.43) {
tmp = (sin(th) / sin(kx)) * sin(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) :: t_1
real(8) :: tmp
t_1 = sin(ky) / sqrt(((sin(ky) ** 2.0d0) + (sin(kx) ** 2.0d0)))
if (t_1 <= (-0.999d0)) then
tmp = (sin(ky) / sqrt(((0.5d0 - (cos((2.0d0 * ky)) * 0.5d0)) + (kx * kx)))) * sin(th)
else if (t_1 <= 0.43d0) then
tmp = (sin(th) / sin(kx)) * sin(ky)
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(ky), 2.0) + Math.pow(Math.sin(kx), 2.0)));
double tmp;
if (t_1 <= -0.999) {
tmp = (Math.sin(ky) / Math.sqrt(((0.5 - (Math.cos((2.0 * ky)) * 0.5)) + (kx * kx)))) * Math.sin(th);
} else if (t_1 <= 0.43) {
tmp = (Math.sin(th) / Math.sin(kx)) * Math.sin(ky);
} else {
tmp = Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): t_1 = math.sin(ky) / math.sqrt((math.pow(math.sin(ky), 2.0) + math.pow(math.sin(kx), 2.0))) tmp = 0 if t_1 <= -0.999: tmp = (math.sin(ky) / math.sqrt(((0.5 - (math.cos((2.0 * ky)) * 0.5)) + (kx * kx)))) * math.sin(th) elif t_1 <= 0.43: tmp = (math.sin(th) / math.sin(kx)) * math.sin(ky) else: tmp = math.sin(th) return tmp
function code(kx, ky, th) t_1 = Float64(sin(ky) / sqrt(Float64((sin(ky) ^ 2.0) + (sin(kx) ^ 2.0)))) tmp = 0.0 if (t_1 <= -0.999) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(0.5 - Float64(cos(Float64(2.0 * ky)) * 0.5)) + Float64(kx * kx)))) * sin(th)); elseif (t_1 <= 0.43) tmp = Float64(Float64(sin(th) / sin(kx)) * sin(ky)); else tmp = sin(th); end return tmp end
function tmp_2 = code(kx, ky, th) t_1 = sin(ky) / sqrt(((sin(ky) ^ 2.0) + (sin(kx) ^ 2.0))); tmp = 0.0; if (t_1 <= -0.999) tmp = (sin(ky) / sqrt(((0.5 - (cos((2.0 * ky)) * 0.5)) + (kx * kx)))) * sin(th); elseif (t_1 <= 0.43) tmp = (sin(th) / sin(kx)) * sin(ky); 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[ky], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$1, -0.999], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[(0.5 - N[(N[Cos[N[(2.0 * ky), $MachinePrecision]], $MachinePrecision] * 0.5), $MachinePrecision]), $MachinePrecision] + N[(kx * kx), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$1, 0.43], N[(N[(N[Sin[th], $MachinePrecision] / N[Sin[kx], $MachinePrecision]), $MachinePrecision] * N[Sin[ky], $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \frac{\sin ky}{\sqrt{{\sin ky}^{2} + {\sin kx}^{2}}}\\
\mathbf{if}\;t\_1 \leq -0.999:\\
\;\;\;\;\frac{\sin ky}{\sqrt{\left(0.5 - \cos \left(2 \cdot ky\right) \cdot 0.5\right) + kx \cdot kx}} \cdot \sin th\\
\mathbf{elif}\;t\_1 \leq 0.43:\\
\;\;\;\;\frac{\sin th}{\sin kx} \cdot \sin 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))))) < -0.998999999999999999Initial program 88.7%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f6488.7
Applied rewrites88.7%
lift-pow.f64N/A
pow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2N/A
lower-cos.f64N/A
count-2N/A
lower-*.f6468.4
Applied rewrites68.4%
if -0.998999999999999999 < (/.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.429999999999999993Initial program 99.3%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
associate-/l*N/A
*-commutativeN/A
lower-*.f64N/A
lower-/.f6499.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%
Taylor expanded in ky around 0
lower-sin.f6439.9
Applied rewrites39.9%
if 0.429999999999999993 < (/.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.3%
Taylor expanded in kx around 0
lower-sin.f6468.4
Applied rewrites68.4%
Final simplification54.4%
(FPCore (kx ky th) :precision binary64 (if (<= (/ (sin ky) (sqrt (+ (pow (sin ky) 2.0) (pow (sin kx) 2.0)))) 0.43) (* (/ (sin th) (sin kx)) (sin ky)) (sin th)))
double code(double kx, double ky, double th) {
double tmp;
if ((sin(ky) / sqrt((pow(sin(ky), 2.0) + pow(sin(kx), 2.0)))) <= 0.43) {
tmp = (sin(th) / sin(kx)) * sin(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(ky) ** 2.0d0) + (sin(kx) ** 2.0d0)))) <= 0.43d0) then
tmp = (sin(th) / sin(kx)) * sin(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(ky), 2.0) + Math.pow(Math.sin(kx), 2.0)))) <= 0.43) {
tmp = (Math.sin(th) / Math.sin(kx)) * Math.sin(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(ky), 2.0) + math.pow(math.sin(kx), 2.0)))) <= 0.43: tmp = (math.sin(th) / math.sin(kx)) * math.sin(ky) else: tmp = math.sin(th) return tmp
function code(kx, ky, th) tmp = 0.0 if (Float64(sin(ky) / sqrt(Float64((sin(ky) ^ 2.0) + (sin(kx) ^ 2.0)))) <= 0.43) tmp = Float64(Float64(sin(th) / sin(kx)) * sin(ky)); else tmp = sin(th); end return tmp end
function tmp_2 = code(kx, ky, th) tmp = 0.0; if ((sin(ky) / sqrt(((sin(ky) ^ 2.0) + (sin(kx) ^ 2.0)))) <= 0.43) tmp = (sin(th) / sin(kx)) * sin(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[ky], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], 0.43], N[(N[(N[Sin[th], $MachinePrecision] / N[Sin[kx], $MachinePrecision]), $MachinePrecision] * N[Sin[ky], $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\frac{\sin ky}{\sqrt{{\sin ky}^{2} + {\sin kx}^{2}}} \leq 0.43:\\
\;\;\;\;\frac{\sin th}{\sin kx} \cdot \sin 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))))) < 0.429999999999999993Initial program 96.2%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
associate-/l*N/A
*-commutativeN/A
lower-*.f64N/A
lower-/.f6496.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.7
Applied rewrites99.7%
Taylor expanded in ky around 0
lower-sin.f6430.9
Applied rewrites30.9%
if 0.429999999999999993 < (/.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.3%
Taylor expanded in kx around 0
lower-sin.f6468.4
Applied rewrites68.4%
Final simplification42.3%
(FPCore (kx ky th) :precision binary64 (if (<= (/ (sin ky) (sqrt (+ (pow (sin ky) 2.0) (pow (sin kx) 2.0)))) 0.43) (* (/ (sin ky) (sin kx)) (sin th)) (sin th)))
double code(double kx, double ky, double th) {
double tmp;
if ((sin(ky) / sqrt((pow(sin(ky), 2.0) + pow(sin(kx), 2.0)))) <= 0.43) {
tmp = (sin(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(ky) ** 2.0d0) + (sin(kx) ** 2.0d0)))) <= 0.43d0) then
tmp = (sin(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(ky), 2.0) + Math.pow(Math.sin(kx), 2.0)))) <= 0.43) {
tmp = (Math.sin(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(ky), 2.0) + math.pow(math.sin(kx), 2.0)))) <= 0.43: tmp = (math.sin(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(ky) ^ 2.0) + (sin(kx) ^ 2.0)))) <= 0.43) tmp = Float64(Float64(sin(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(ky) ^ 2.0) + (sin(kx) ^ 2.0)))) <= 0.43) tmp = (sin(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[ky], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], 0.43], N[(N[(N[Sin[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 ky}^{2} + {\sin kx}^{2}}} \leq 0.43:\\
\;\;\;\;\frac{\sin 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.429999999999999993Initial program 96.2%
Taylor expanded in ky around 0
lower-sin.f6430.8
Applied rewrites30.8%
if 0.429999999999999993 < (/.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.3%
Taylor expanded in kx around 0
lower-sin.f6468.4
Applied rewrites68.4%
Final simplification42.3%
(FPCore (kx ky th) :precision binary64 (if (<= (/ (sin ky) (sqrt (+ (pow (sin ky) 2.0) (pow (sin kx) 2.0)))) 5e-8) (* (/ ky (sin kx)) (sin th)) (sin th)))
double code(double kx, double ky, double th) {
double tmp;
if ((sin(ky) / sqrt((pow(sin(ky), 2.0) + pow(sin(kx), 2.0)))) <= 5e-8) {
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(ky) ** 2.0d0) + (sin(kx) ** 2.0d0)))) <= 5d-8) 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(ky), 2.0) + Math.pow(Math.sin(kx), 2.0)))) <= 5e-8) {
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(ky), 2.0) + math.pow(math.sin(kx), 2.0)))) <= 5e-8: 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(ky) ^ 2.0) + (sin(kx) ^ 2.0)))) <= 5e-8) 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(ky) ^ 2.0) + (sin(kx) ^ 2.0)))) <= 5e-8) 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[ky], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], 5e-8], 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 ky}^{2} + {\sin kx}^{2}}} \leq 5 \cdot 10^{-8}:\\
\;\;\;\;\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))))) < 4.9999999999999998e-8Initial program 96.1%
Taylor expanded in ky around 0
lower-/.f64N/A
lower-sin.f6429.7
Applied rewrites29.7%
if 4.9999999999999998e-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 92.7%
Taylor expanded in kx around 0
lower-sin.f6465.4
Applied rewrites65.4%
Final simplification41.2%
(FPCore (kx ky th) :precision binary64 (if (<= (/ (sin ky) (sqrt (+ (pow (sin ky) 2.0) (pow (sin kx) 2.0)))) 2e-39) (* (pow th 3.0) -0.16666666666666666) (sin th)))
double code(double kx, double ky, double th) {
double tmp;
if ((sin(ky) / sqrt((pow(sin(ky), 2.0) + pow(sin(kx), 2.0)))) <= 2e-39) {
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(ky) ** 2.0d0) + (sin(kx) ** 2.0d0)))) <= 2d-39) 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(ky), 2.0) + Math.pow(Math.sin(kx), 2.0)))) <= 2e-39) {
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(ky), 2.0) + math.pow(math.sin(kx), 2.0)))) <= 2e-39: 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(ky) ^ 2.0) + (sin(kx) ^ 2.0)))) <= 2e-39) 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(ky) ^ 2.0) + (sin(kx) ^ 2.0)))) <= 2e-39) 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[ky], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], 2e-39], 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 ky}^{2} + {\sin kx}^{2}}} \leq 2 \cdot 10^{-39}:\\
\;\;\;\;{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))))) < 1.99999999999999986e-39Initial program 96.1%
Taylor expanded in kx around 0
lower-sin.f643.8
Applied rewrites3.8%
Taylor expanded in th around 0
Applied rewrites3.5%
Taylor expanded in th around inf
Applied rewrites16.8%
if 1.99999999999999986e-39 < (/.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.8%
Taylor expanded in kx around 0
lower-sin.f6464.7
Applied rewrites64.7%
Final simplification32.5%
(FPCore (kx ky th)
:precision binary64
(if (<= ky 3.7e-9)
(/ (* (sin th) ky) (hypot (sin ky) (sin kx)))
(*
(/
(sin ky)
(/
(sqrt
(fma (- 1.0 (cos (* 2.0 ky))) 2.0 (* (- 1.0 (cos (* 2.0 kx))) 2.0)))
2.0))
(sin th))))
double code(double kx, double ky, double th) {
double tmp;
if (ky <= 3.7e-9) {
tmp = (sin(th) * ky) / hypot(sin(ky), sin(kx));
} else {
tmp = (sin(ky) / (sqrt(fma((1.0 - cos((2.0 * ky))), 2.0, ((1.0 - cos((2.0 * kx))) * 2.0))) / 2.0)) * sin(th);
}
return tmp;
}
function code(kx, ky, th) tmp = 0.0 if (ky <= 3.7e-9) 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(2.0 * ky))), 2.0, Float64(Float64(1.0 - cos(Float64(2.0 * kx))) * 2.0))) / 2.0)) * sin(th)); end return tmp end
code[kx_, ky_, th_] := If[LessEqual[ky, 3.7e-9], 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[(2.0 * ky), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * 2.0 + N[(N[(1.0 - N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * 2.0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / 2.0), $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;ky \leq 3.7 \cdot 10^{-9}:\\
\;\;\;\;\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(2 \cdot ky\right), 2, \left(1 - \cos \left(2 \cdot kx\right)\right) \cdot 2\right)}}{2}} \cdot \sin th\\
\end{array}
\end{array}
if ky < 3.7e-9Initial program 93.7%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
lower-/.f64N/A
*-commutativeN/A
lower-*.f6492.0
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-pow.f64N/A
unpow2N/A
lower-hypot.f6496.5
Applied rewrites96.5%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
lower-sin.f6459.1
Applied rewrites59.1%
if 3.7e-9 < ky Initial program 99.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 rewrites98.8%
Final simplification68.1%
(FPCore (kx ky th)
:precision binary64
(if (<= ky 2.5e-145)
(* (/ (sin th) (sin kx)) (sin ky))
(if (<= ky 0.003)
(*
(/ (sin ky) (sqrt (+ (- 0.5 (* 0.5 (cos (* 2.0 kx)))) (* ky ky))))
(sin th))
(*
(/ (sin ky) (sqrt (+ (- 0.5 (* (cos (* 2.0 ky)) 0.5)) (* kx kx))))
(sin th)))))
double code(double kx, double ky, double th) {
double tmp;
if (ky <= 2.5e-145) {
tmp = (sin(th) / sin(kx)) * sin(ky);
} else if (ky <= 0.003) {
tmp = (sin(ky) / sqrt(((0.5 - (0.5 * cos((2.0 * kx)))) + (ky * ky)))) * sin(th);
} else {
tmp = (sin(ky) / sqrt(((0.5 - (cos((2.0 * ky)) * 0.5)) + (kx * kx)))) * 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 (ky <= 2.5d-145) then
tmp = (sin(th) / sin(kx)) * sin(ky)
else if (ky <= 0.003d0) then
tmp = (sin(ky) / sqrt(((0.5d0 - (0.5d0 * cos((2.0d0 * kx)))) + (ky * ky)))) * sin(th)
else
tmp = (sin(ky) / sqrt(((0.5d0 - (cos((2.0d0 * ky)) * 0.5d0)) + (kx * kx)))) * sin(th)
end if
code = tmp
end function
public static double code(double kx, double ky, double th) {
double tmp;
if (ky <= 2.5e-145) {
tmp = (Math.sin(th) / Math.sin(kx)) * Math.sin(ky);
} else if (ky <= 0.003) {
tmp = (Math.sin(ky) / Math.sqrt(((0.5 - (0.5 * Math.cos((2.0 * kx)))) + (ky * ky)))) * Math.sin(th);
} else {
tmp = (Math.sin(ky) / Math.sqrt(((0.5 - (Math.cos((2.0 * ky)) * 0.5)) + (kx * kx)))) * Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): tmp = 0 if ky <= 2.5e-145: tmp = (math.sin(th) / math.sin(kx)) * math.sin(ky) elif ky <= 0.003: tmp = (math.sin(ky) / math.sqrt(((0.5 - (0.5 * math.cos((2.0 * kx)))) + (ky * ky)))) * math.sin(th) else: tmp = (math.sin(ky) / math.sqrt(((0.5 - (math.cos((2.0 * ky)) * 0.5)) + (kx * kx)))) * math.sin(th) return tmp
function code(kx, ky, th) tmp = 0.0 if (ky <= 2.5e-145) tmp = Float64(Float64(sin(th) / sin(kx)) * sin(ky)); elseif (ky <= 0.003) tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(0.5 - Float64(0.5 * cos(Float64(2.0 * kx)))) + Float64(ky * ky)))) * sin(th)); else tmp = Float64(Float64(sin(ky) / sqrt(Float64(Float64(0.5 - Float64(cos(Float64(2.0 * ky)) * 0.5)) + Float64(kx * kx)))) * sin(th)); end return tmp end
function tmp_2 = code(kx, ky, th) tmp = 0.0; if (ky <= 2.5e-145) tmp = (sin(th) / sin(kx)) * sin(ky); elseif (ky <= 0.003) tmp = (sin(ky) / sqrt(((0.5 - (0.5 * cos((2.0 * kx)))) + (ky * ky)))) * sin(th); else tmp = (sin(ky) / sqrt(((0.5 - (cos((2.0 * ky)) * 0.5)) + (kx * kx)))) * sin(th); end tmp_2 = tmp; end
code[kx_, ky_, th_] := If[LessEqual[ky, 2.5e-145], N[(N[(N[Sin[th], $MachinePrecision] / N[Sin[kx], $MachinePrecision]), $MachinePrecision] * N[Sin[ky], $MachinePrecision]), $MachinePrecision], If[LessEqual[ky, 0.003], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[(0.5 - N[(0.5 * N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] + N[(ky * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[(0.5 - N[(N[Cos[N[(2.0 * ky), $MachinePrecision]], $MachinePrecision] * 0.5), $MachinePrecision]), $MachinePrecision] + N[(kx * kx), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;ky \leq 2.5 \cdot 10^{-145}:\\
\;\;\;\;\frac{\sin th}{\sin kx} \cdot \sin ky\\
\mathbf{elif}\;ky \leq 0.003:\\
\;\;\;\;\frac{\sin ky}{\sqrt{\left(0.5 - 0.5 \cdot \cos \left(2 \cdot kx\right)\right) + ky \cdot ky}} \cdot \sin th\\
\mathbf{else}:\\
\;\;\;\;\frac{\sin ky}{\sqrt{\left(0.5 - \cos \left(2 \cdot ky\right) \cdot 0.5\right) + kx \cdot kx}} \cdot \sin th\\
\end{array}
\end{array}
if ky < 2.4999999999999999e-145Initial program 92.6%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
associate-/l*N/A
*-commutativeN/A
lower-*.f64N/A
lower-/.f6492.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.6
Applied rewrites99.6%
Taylor expanded in ky around 0
lower-sin.f6428.6
Applied rewrites28.6%
if 2.4999999999999999e-145 < ky < 0.0030000000000000001Initial program 99.6%
Taylor expanded in ky around 0
unpow2N/A
lower-*.f6499.6
Applied rewrites99.6%
lift-pow.f64N/A
pow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2N/A
lower-cos.f64N/A
count-2N/A
lower-*.f6490.3
Applied rewrites90.3%
if 0.0030000000000000001 < ky Initial program 99.6%
Taylor expanded in kx around 0
unpow2N/A
lower-*.f6452.1
Applied rewrites52.1%
lift-pow.f64N/A
pow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2N/A
lower-cos.f64N/A
count-2N/A
lower-*.f6451.1
Applied rewrites51.1%
Final simplification41.2%
(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.f6423.8
Applied rewrites23.8%
(FPCore (kx ky th) :precision binary64 (fma (* -0.16666666666666666 (* th th)) th th))
double code(double kx, double ky, double th) {
return fma((-0.16666666666666666 * (th * th)), th, th);
}
function code(kx, ky, th) return fma(Float64(-0.16666666666666666 * Float64(th * th)), th, th) end
code[kx_, ky_, th_] := N[(N[(-0.16666666666666666 * N[(th * th), $MachinePrecision]), $MachinePrecision] * th + th), $MachinePrecision]
\begin{array}{l}
\\
\mathsf{fma}\left(-0.16666666666666666 \cdot \left(th \cdot th\right), th, th\right)
\end{array}
Initial program 95.0%
Taylor expanded in kx around 0
lower-sin.f6423.8
Applied rewrites23.8%
Taylor expanded in th around 0
Applied rewrites12.4%
Applied rewrites12.4%
herbie shell --seed 2024277
(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)))