
(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 25 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 93.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.7
Applied rewrites99.7%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (* (sin ky) th))
(t_2 (* (fma (* ky ky) -0.16666666666666666 1.0) ky))
(t_3 (pow (sin ky) 2.0))
(t_4 (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) t_3)))))
(if (<= t_4 -0.9)
(* (/ (sin ky) (sqrt t_3)) (sin th))
(if (<= t_4 -0.2)
(*
t_1
(sqrt
(pow
(/ (+ (- 1.0 (cos (* 2.0 ky))) (- 1.0 (cos (* -2.0 kx)))) 2.0)
-1.0)))
(if (<= t_4 2e-6)
(* (/ (sin ky) (hypot t_2 (sin kx))) (sin th))
(if (<= t_4 0.999998)
(* t_1 (pow (hypot (sin kx) (sin ky)) -1.0))
(if (<= t_4 2.0)
(* (fma (* kx (/ kx t_3)) -0.5 1.0) (sin th))
(* (/ (sin th) (hypot (sin ky) (sin kx))) t_2))))))))
double code(double kx, double ky, double th) {
double t_1 = sin(ky) * th;
double t_2 = fma((ky * ky), -0.16666666666666666, 1.0) * ky;
double t_3 = pow(sin(ky), 2.0);
double t_4 = sin(ky) / sqrt((pow(sin(kx), 2.0) + t_3));
double tmp;
if (t_4 <= -0.9) {
tmp = (sin(ky) / sqrt(t_3)) * sin(th);
} else if (t_4 <= -0.2) {
tmp = t_1 * sqrt(pow((((1.0 - cos((2.0 * ky))) + (1.0 - cos((-2.0 * kx)))) / 2.0), -1.0));
} else if (t_4 <= 2e-6) {
tmp = (sin(ky) / hypot(t_2, sin(kx))) * sin(th);
} else if (t_4 <= 0.999998) {
tmp = t_1 * pow(hypot(sin(kx), sin(ky)), -1.0);
} else if (t_4 <= 2.0) {
tmp = fma((kx * (kx / t_3)), -0.5, 1.0) * sin(th);
} else {
tmp = (sin(th) / hypot(sin(ky), sin(kx))) * t_2;
}
return tmp;
}
function code(kx, ky, th) t_1 = Float64(sin(ky) * th) t_2 = Float64(fma(Float64(ky * ky), -0.16666666666666666, 1.0) * ky) t_3 = sin(ky) ^ 2.0 t_4 = Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + t_3))) tmp = 0.0 if (t_4 <= -0.9) tmp = Float64(Float64(sin(ky) / sqrt(t_3)) * sin(th)); elseif (t_4 <= -0.2) tmp = Float64(t_1 * sqrt((Float64(Float64(Float64(1.0 - cos(Float64(2.0 * ky))) + Float64(1.0 - cos(Float64(-2.0 * kx)))) / 2.0) ^ -1.0))); elseif (t_4 <= 2e-6) tmp = Float64(Float64(sin(ky) / hypot(t_2, sin(kx))) * sin(th)); elseif (t_4 <= 0.999998) tmp = Float64(t_1 * (hypot(sin(kx), sin(ky)) ^ -1.0)); elseif (t_4 <= 2.0) tmp = Float64(fma(Float64(kx * Float64(kx / t_3)), -0.5, 1.0) * sin(th)); else tmp = Float64(Float64(sin(th) / hypot(sin(ky), sin(kx))) * t_2); end return tmp end
code[kx_, ky_, th_] := Block[{t$95$1 = N[(N[Sin[ky], $MachinePrecision] * th), $MachinePrecision]}, Block[{t$95$2 = N[(N[(N[(ky * ky), $MachinePrecision] * -0.16666666666666666 + 1.0), $MachinePrecision] * ky), $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[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + t$95$3), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$4, -0.9], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[t$95$3], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$4, -0.2], N[(t$95$1 * N[Sqrt[N[Power[N[(N[(N[(1.0 - N[Cos[N[(2.0 * ky), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] + N[(1.0 - N[Cos[N[(-2.0 * kx), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / 2.0), $MachinePrecision], -1.0], $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$4, 2e-6], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[t$95$2 ^ 2 + N[Sin[kx], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$4, 0.999998], N[(t$95$1 * N[Power[N[Sqrt[N[Sin[kx], $MachinePrecision] ^ 2 + N[Sin[ky], $MachinePrecision] ^ 2], $MachinePrecision], -1.0], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$4, 2.0], N[(N[(N[(kx * N[(kx / t$95$3), $MachinePrecision]), $MachinePrecision] * -0.5 + 1.0), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], N[(N[(N[Sin[th], $MachinePrecision] / N[Sqrt[N[Sin[ky], $MachinePrecision] ^ 2 + N[Sin[kx], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision] * t$95$2), $MachinePrecision]]]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \sin ky \cdot th\\
t_2 := \mathsf{fma}\left(ky \cdot ky, -0.16666666666666666, 1\right) \cdot ky\\
t_3 := {\sin ky}^{2}\\
t_4 := \frac{\sin ky}{\sqrt{{\sin kx}^{2} + t\_3}}\\
\mathbf{if}\;t\_4 \leq -0.9:\\
\;\;\;\;\frac{\sin ky}{\sqrt{t\_3}} \cdot \sin th\\
\mathbf{elif}\;t\_4 \leq -0.2:\\
\;\;\;\;t\_1 \cdot \sqrt{{\left(\frac{\left(1 - \cos \left(2 \cdot ky\right)\right) + \left(1 - \cos \left(-2 \cdot kx\right)\right)}{2}\right)}^{-1}}\\
\mathbf{elif}\;t\_4 \leq 2 \cdot 10^{-6}:\\
\;\;\;\;\frac{\sin ky}{\mathsf{hypot}\left(t\_2, \sin kx\right)} \cdot \sin th\\
\mathbf{elif}\;t\_4 \leq 0.999998:\\
\;\;\;\;t\_1 \cdot {\left(\mathsf{hypot}\left(\sin kx, \sin ky\right)\right)}^{-1}\\
\mathbf{elif}\;t\_4 \leq 2:\\
\;\;\;\;\mathsf{fma}\left(kx \cdot \frac{kx}{t\_3}, -0.5, 1\right) \cdot \sin th\\
\mathbf{else}:\\
\;\;\;\;\frac{\sin th}{\mathsf{hypot}\left(\sin ky, \sin kx\right)} \cdot t\_2\\
\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.900000000000000022Initial program 89.1%
lift-pow.f64N/A
unpow2N/A
sqr-neg-revN/A
lift-sin.f64N/A
cos-+PI/2-revN/A
lift-sin.f64N/A
cos-+PI/2-revN/A
1-sub-sin-revN/A
metadata-evalN/A
sin-+PI/2-revN/A
sin-+PI/2-revN/A
lower--.f64N/A
metadata-evalN/A
lower-*.f64N/A
lower-cos.f64N/A
lower-cos.f6469.9
Applied rewrites69.9%
Taylor expanded in kx around 0
unpow2N/A
1-sub-cosN/A
unpow2N/A
lower-sqrt.f64N/A
lower-pow.f64N/A
lower-sin.f6482.8
Applied rewrites82.8%
if -0.900000000000000022 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.20000000000000001Initial program 99.3%
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2-revN/A
lower-cos.f64N/A
count-2-revN/A
lower-*.f6499.2
Applied rewrites99.2%
Taylor expanded in ky around 0
lower-sqrt.f64N/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
cos-neg-revN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
lower-*.f64N/A
metadata-eval21.5
Applied rewrites21.5%
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
fp-cancel-sub-sign-invN/A
+-commutativeN/A
metadata-evalN/A
lower-fma.f64N/A
metadata-evalN/A
distribute-lft-neg-inN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
metadata-evalN/A
lower-*.f64N/A
+-commutativeN/A
unpow2N/A
lower-fma.f64N/A
Applied rewrites50.8%
Applied rewrites50.8%
if -0.20000000000000001 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 1.99999999999999991e-6Initial program 99.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.7
Applied rewrites99.7%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f6497.7
Applied rewrites97.7%
if 1.99999999999999991e-6 < (/.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.999998000000000054Initial program 99.1%
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2-revN/A
lower-cos.f64N/A
count-2-revN/A
lower-*.f6499.0
Applied rewrites99.0%
Taylor expanded in ky around 0
lower-sqrt.f64N/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
cos-neg-revN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
lower-*.f64N/A
metadata-eval22.2
Applied rewrites22.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
fp-cancel-sub-sign-invN/A
+-commutativeN/A
metadata-evalN/A
lower-fma.f64N/A
metadata-evalN/A
distribute-lft-neg-inN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
metadata-evalN/A
lower-*.f64N/A
+-commutativeN/A
unpow2N/A
lower-fma.f64N/A
Applied rewrites55.1%
Applied rewrites55.4%
if 0.999998000000000054 < (/.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))))) < 2Initial program 100.0%
Taylor expanded in kx around 0
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
unpow2N/A
associate-/l*N/A
lower-*.f64N/A
lower-/.f64N/A
lower-pow.f64N/A
lower-sin.f64100.0
Applied rewrites100.0%
if 2 < (/.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 2.3%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
associate-/l*N/A
*-commutativeN/A
lower-*.f64N/A
lower-/.f642.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.8
Applied rewrites99.8%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f6499.8
Applied rewrites99.8%
Final simplification87.1%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (* (sin ky) th))
(t_2
(*
(/
(sin ky)
(hypot (* (fma (* ky ky) -0.16666666666666666 1.0) ky) (sin kx)))
(sin th)))
(t_3 (pow (sin ky) 2.0))
(t_4 (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) t_3)))))
(if (<= t_4 -0.9)
(* (/ (sin ky) (sqrt t_3)) (sin th))
(if (<= t_4 -0.2)
(*
t_1
(sqrt
(pow
(/ (+ (- 1.0 (cos (* 2.0 ky))) (- 1.0 (cos (* -2.0 kx)))) 2.0)
-1.0)))
(if (<= t_4 2e-6)
t_2
(if (<= t_4 0.999998)
(* t_1 (pow (hypot (sin kx) (sin ky)) -1.0))
(if (<= t_4 2.0)
(* (fma (* kx (/ kx t_3)) -0.5 1.0) (sin th))
t_2)))))))
double code(double kx, double ky, double th) {
double t_1 = sin(ky) * th;
double t_2 = (sin(ky) / hypot((fma((ky * ky), -0.16666666666666666, 1.0) * ky), sin(kx))) * sin(th);
double t_3 = pow(sin(ky), 2.0);
double t_4 = sin(ky) / sqrt((pow(sin(kx), 2.0) + t_3));
double tmp;
if (t_4 <= -0.9) {
tmp = (sin(ky) / sqrt(t_3)) * sin(th);
} else if (t_4 <= -0.2) {
tmp = t_1 * sqrt(pow((((1.0 - cos((2.0 * ky))) + (1.0 - cos((-2.0 * kx)))) / 2.0), -1.0));
} else if (t_4 <= 2e-6) {
tmp = t_2;
} else if (t_4 <= 0.999998) {
tmp = t_1 * pow(hypot(sin(kx), sin(ky)), -1.0);
} else if (t_4 <= 2.0) {
tmp = fma((kx * (kx / t_3)), -0.5, 1.0) * sin(th);
} else {
tmp = t_2;
}
return tmp;
}
function code(kx, ky, th) t_1 = Float64(sin(ky) * th) t_2 = Float64(Float64(sin(ky) / hypot(Float64(fma(Float64(ky * ky), -0.16666666666666666, 1.0) * ky), sin(kx))) * sin(th)) t_3 = sin(ky) ^ 2.0 t_4 = Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + t_3))) tmp = 0.0 if (t_4 <= -0.9) tmp = Float64(Float64(sin(ky) / sqrt(t_3)) * sin(th)); elseif (t_4 <= -0.2) tmp = Float64(t_1 * sqrt((Float64(Float64(Float64(1.0 - cos(Float64(2.0 * ky))) + Float64(1.0 - cos(Float64(-2.0 * kx)))) / 2.0) ^ -1.0))); elseif (t_4 <= 2e-6) tmp = t_2; elseif (t_4 <= 0.999998) tmp = Float64(t_1 * (hypot(sin(kx), sin(ky)) ^ -1.0)); elseif (t_4 <= 2.0) tmp = Float64(fma(Float64(kx * Float64(kx / t_3)), -0.5, 1.0) * sin(th)); else tmp = t_2; end return tmp end
code[kx_, ky_, th_] := Block[{t$95$1 = N[(N[Sin[ky], $MachinePrecision] * th), $MachinePrecision]}, Block[{t$95$2 = N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[(N[(ky * ky), $MachinePrecision] * -0.16666666666666666 + 1.0), $MachinePrecision] * ky), $MachinePrecision] ^ 2 + N[Sin[kx], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $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[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + t$95$3), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$4, -0.9], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[t$95$3], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$4, -0.2], N[(t$95$1 * N[Sqrt[N[Power[N[(N[(N[(1.0 - N[Cos[N[(2.0 * ky), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] + N[(1.0 - N[Cos[N[(-2.0 * kx), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / 2.0), $MachinePrecision], -1.0], $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$4, 2e-6], t$95$2, If[LessEqual[t$95$4, 0.999998], N[(t$95$1 * N[Power[N[Sqrt[N[Sin[kx], $MachinePrecision] ^ 2 + N[Sin[ky], $MachinePrecision] ^ 2], $MachinePrecision], -1.0], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$4, 2.0], N[(N[(N[(kx * N[(kx / t$95$3), $MachinePrecision]), $MachinePrecision] * -0.5 + 1.0), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], t$95$2]]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \sin ky \cdot th\\
t_2 := \frac{\sin ky}{\mathsf{hypot}\left(\mathsf{fma}\left(ky \cdot ky, -0.16666666666666666, 1\right) \cdot ky, \sin kx\right)} \cdot \sin th\\
t_3 := {\sin ky}^{2}\\
t_4 := \frac{\sin ky}{\sqrt{{\sin kx}^{2} + t\_3}}\\
\mathbf{if}\;t\_4 \leq -0.9:\\
\;\;\;\;\frac{\sin ky}{\sqrt{t\_3}} \cdot \sin th\\
\mathbf{elif}\;t\_4 \leq -0.2:\\
\;\;\;\;t\_1 \cdot \sqrt{{\left(\frac{\left(1 - \cos \left(2 \cdot ky\right)\right) + \left(1 - \cos \left(-2 \cdot kx\right)\right)}{2}\right)}^{-1}}\\
\mathbf{elif}\;t\_4 \leq 2 \cdot 10^{-6}:\\
\;\;\;\;t\_2\\
\mathbf{elif}\;t\_4 \leq 0.999998:\\
\;\;\;\;t\_1 \cdot {\left(\mathsf{hypot}\left(\sin kx, \sin ky\right)\right)}^{-1}\\
\mathbf{elif}\;t\_4 \leq 2:\\
\;\;\;\;\mathsf{fma}\left(kx \cdot \frac{kx}{t\_3}, -0.5, 1\right) \cdot \sin th\\
\mathbf{else}:\\
\;\;\;\;t\_2\\
\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.900000000000000022Initial program 89.1%
lift-pow.f64N/A
unpow2N/A
sqr-neg-revN/A
lift-sin.f64N/A
cos-+PI/2-revN/A
lift-sin.f64N/A
cos-+PI/2-revN/A
1-sub-sin-revN/A
metadata-evalN/A
sin-+PI/2-revN/A
sin-+PI/2-revN/A
lower--.f64N/A
metadata-evalN/A
lower-*.f64N/A
lower-cos.f64N/A
lower-cos.f6469.9
Applied rewrites69.9%
Taylor expanded in kx around 0
unpow2N/A
1-sub-cosN/A
unpow2N/A
lower-sqrt.f64N/A
lower-pow.f64N/A
lower-sin.f6482.8
Applied rewrites82.8%
if -0.900000000000000022 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.20000000000000001Initial program 99.3%
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2-revN/A
lower-cos.f64N/A
count-2-revN/A
lower-*.f6499.2
Applied rewrites99.2%
Taylor expanded in ky around 0
lower-sqrt.f64N/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
cos-neg-revN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
lower-*.f64N/A
metadata-eval21.5
Applied rewrites21.5%
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
fp-cancel-sub-sign-invN/A
+-commutativeN/A
metadata-evalN/A
lower-fma.f64N/A
metadata-evalN/A
distribute-lft-neg-inN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
metadata-evalN/A
lower-*.f64N/A
+-commutativeN/A
unpow2N/A
lower-fma.f64N/A
Applied rewrites50.8%
Applied rewrites50.8%
if -0.20000000000000001 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 1.99999999999999991e-6 or 2 < (/.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 91.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
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f6497.9
Applied rewrites97.9%
if 1.99999999999999991e-6 < (/.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.999998000000000054Initial program 99.1%
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2-revN/A
lower-cos.f64N/A
count-2-revN/A
lower-*.f6499.0
Applied rewrites99.0%
Taylor expanded in ky around 0
lower-sqrt.f64N/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
cos-neg-revN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
lower-*.f64N/A
metadata-eval22.2
Applied rewrites22.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
fp-cancel-sub-sign-invN/A
+-commutativeN/A
metadata-evalN/A
lower-fma.f64N/A
metadata-evalN/A
distribute-lft-neg-inN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
metadata-evalN/A
lower-*.f64N/A
+-commutativeN/A
unpow2N/A
lower-fma.f64N/A
Applied rewrites55.1%
Applied rewrites55.4%
if 0.999998000000000054 < (/.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))))) < 2Initial program 100.0%
Taylor expanded in kx around 0
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
unpow2N/A
associate-/l*N/A
lower-*.f64N/A
lower-/.f64N/A
lower-pow.f64N/A
lower-sin.f64100.0
Applied rewrites100.0%
Final simplification87.1%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (* (sin ky) th))
(t_2 (pow (sin kx) 2.0))
(t_3 (pow (sin ky) 2.0))
(t_4 (/ (sin ky) (sqrt (+ t_2 t_3)))))
(if (<= t_4 -0.9)
(* (/ (sin ky) (sqrt t_3)) (sin th))
(if (<= t_4 -0.05)
(*
t_1
(sqrt
(pow
(/ (+ (- 1.0 (cos (* 2.0 ky))) (- 1.0 (cos (* -2.0 kx)))) 2.0)
-1.0)))
(if (<= t_4 1.5e-6)
(*
(/
(* (fma (* ky ky) -0.16666666666666666 1.0) ky)
(sqrt (+ t_2 (* ky ky))))
(sin th))
(if (<= t_4 0.9999999999998741)
(* t_1 (pow (hypot (sin kx) (sin ky)) -1.0))
(sin th)))))))
double code(double kx, double ky, double th) {
double t_1 = sin(ky) * th;
double t_2 = pow(sin(kx), 2.0);
double t_3 = pow(sin(ky), 2.0);
double t_4 = sin(ky) / sqrt((t_2 + t_3));
double tmp;
if (t_4 <= -0.9) {
tmp = (sin(ky) / sqrt(t_3)) * sin(th);
} else if (t_4 <= -0.05) {
tmp = t_1 * sqrt(pow((((1.0 - cos((2.0 * ky))) + (1.0 - cos((-2.0 * kx)))) / 2.0), -1.0));
} else if (t_4 <= 1.5e-6) {
tmp = ((fma((ky * ky), -0.16666666666666666, 1.0) * ky) / sqrt((t_2 + (ky * ky)))) * sin(th);
} else if (t_4 <= 0.9999999999998741) {
tmp = t_1 * pow(hypot(sin(kx), sin(ky)), -1.0);
} else {
tmp = sin(th);
}
return tmp;
}
function code(kx, ky, th) t_1 = Float64(sin(ky) * th) t_2 = sin(kx) ^ 2.0 t_3 = sin(ky) ^ 2.0 t_4 = Float64(sin(ky) / sqrt(Float64(t_2 + t_3))) tmp = 0.0 if (t_4 <= -0.9) tmp = Float64(Float64(sin(ky) / sqrt(t_3)) * sin(th)); elseif (t_4 <= -0.05) tmp = Float64(t_1 * sqrt((Float64(Float64(Float64(1.0 - cos(Float64(2.0 * ky))) + Float64(1.0 - cos(Float64(-2.0 * kx)))) / 2.0) ^ -1.0))); elseif (t_4 <= 1.5e-6) tmp = Float64(Float64(Float64(fma(Float64(ky * ky), -0.16666666666666666, 1.0) * ky) / sqrt(Float64(t_2 + Float64(ky * ky)))) * sin(th)); elseif (t_4 <= 0.9999999999998741) tmp = Float64(t_1 * (hypot(sin(kx), sin(ky)) ^ -1.0)); else tmp = sin(th); end return tmp end
code[kx_, ky_, th_] := Block[{t$95$1 = N[(N[Sin[ky], $MachinePrecision] * th), $MachinePrecision]}, Block[{t$95$2 = N[Power[N[Sin[kx], $MachinePrecision], 2.0], $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$2 + t$95$3), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$4, -0.9], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[t$95$3], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$4, -0.05], N[(t$95$1 * N[Sqrt[N[Power[N[(N[(N[(1.0 - N[Cos[N[(2.0 * ky), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] + N[(1.0 - N[Cos[N[(-2.0 * kx), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / 2.0), $MachinePrecision], -1.0], $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$4, 1.5e-6], N[(N[(N[(N[(N[(ky * ky), $MachinePrecision] * -0.16666666666666666 + 1.0), $MachinePrecision] * ky), $MachinePrecision] / N[Sqrt[N[(t$95$2 + N[(ky * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$4, 0.9999999999998741], N[(t$95$1 * N[Power[N[Sqrt[N[Sin[kx], $MachinePrecision] ^ 2 + N[Sin[ky], $MachinePrecision] ^ 2], $MachinePrecision], -1.0], $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \sin ky \cdot th\\
t_2 := {\sin kx}^{2}\\
t_3 := {\sin ky}^{2}\\
t_4 := \frac{\sin ky}{\sqrt{t\_2 + t\_3}}\\
\mathbf{if}\;t\_4 \leq -0.9:\\
\;\;\;\;\frac{\sin ky}{\sqrt{t\_3}} \cdot \sin th\\
\mathbf{elif}\;t\_4 \leq -0.05:\\
\;\;\;\;t\_1 \cdot \sqrt{{\left(\frac{\left(1 - \cos \left(2 \cdot ky\right)\right) + \left(1 - \cos \left(-2 \cdot kx\right)\right)}{2}\right)}^{-1}}\\
\mathbf{elif}\;t\_4 \leq 1.5 \cdot 10^{-6}:\\
\;\;\;\;\frac{\mathsf{fma}\left(ky \cdot ky, -0.16666666666666666, 1\right) \cdot ky}{\sqrt{t\_2 + ky \cdot ky}} \cdot \sin th\\
\mathbf{elif}\;t\_4 \leq 0.9999999999998741:\\
\;\;\;\;t\_1 \cdot {\left(\mathsf{hypot}\left(\sin kx, \sin ky\right)\right)}^{-1}\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\end{array}
if (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.900000000000000022Initial program 89.1%
lift-pow.f64N/A
unpow2N/A
sqr-neg-revN/A
lift-sin.f64N/A
cos-+PI/2-revN/A
lift-sin.f64N/A
cos-+PI/2-revN/A
1-sub-sin-revN/A
metadata-evalN/A
sin-+PI/2-revN/A
sin-+PI/2-revN/A
lower--.f64N/A
metadata-evalN/A
lower-*.f64N/A
lower-cos.f64N/A
lower-cos.f6469.9
Applied rewrites69.9%
Taylor expanded in kx around 0
unpow2N/A
1-sub-cosN/A
unpow2N/A
lower-sqrt.f64N/A
lower-pow.f64N/A
lower-sin.f6482.8
Applied rewrites82.8%
if -0.900000000000000022 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < -0.050000000000000003Initial program 99.2%
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2-revN/A
lower-cos.f64N/A
count-2-revN/A
lower-*.f6499.2
Applied rewrites99.2%
Taylor expanded in ky around 0
lower-sqrt.f64N/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
cos-neg-revN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
lower-*.f64N/A
metadata-eval21.9
Applied rewrites21.9%
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
fp-cancel-sub-sign-invN/A
+-commutativeN/A
metadata-evalN/A
lower-fma.f64N/A
metadata-evalN/A
distribute-lft-neg-inN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
metadata-evalN/A
lower-*.f64N/A
+-commutativeN/A
unpow2N/A
lower-fma.f64N/A
Applied rewrites48.6%
Applied rewrites48.7%
if -0.050000000000000003 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 1.5e-6Initial program 99.3%
Taylor expanded in ky around 0
unpow2N/A
lower-*.f6498.1
Applied rewrites98.1%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f6498.0
Applied rewrites98.0%
if 1.5e-6 < (/.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.9999999999998741Initial program 99.1%
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2-revN/A
lower-cos.f64N/A
count-2-revN/A
lower-*.f6499.0
Applied rewrites99.0%
Taylor expanded in ky around 0
lower-sqrt.f64N/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
cos-neg-revN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
lower-*.f64N/A
metadata-eval21.8
Applied rewrites21.8%
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
fp-cancel-sub-sign-invN/A
+-commutativeN/A
metadata-evalN/A
lower-fma.f64N/A
metadata-evalN/A
distribute-lft-neg-inN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
metadata-evalN/A
lower-*.f64N/A
+-commutativeN/A
unpow2N/A
lower-fma.f64N/A
Applied rewrites56.8%
Applied rewrites57.1%
if 0.9999999999998741 < (/.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 84.3%
Taylor expanded in kx around 0
lower-sin.f6492.0
Applied rewrites92.0%
Final simplification85.1%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (* (sin ky) th))
(t_2 (hypot (sin kx) (sin ky)))
(t_3 (pow (sin kx) 2.0))
(t_4 (/ (sin ky) (sqrt (+ t_3 (pow (sin ky) 2.0))))))
(if (<= t_4 -0.05)
(/ t_1 t_2)
(if (<= t_4 1.5e-6)
(*
(/
(* (fma (* ky ky) -0.16666666666666666 1.0) ky)
(sqrt (+ t_3 (* ky ky))))
(sin th))
(if (<= t_4 0.9999999999998741) (* t_1 (pow t_2 -1.0)) (sin th))))))
double code(double kx, double ky, double th) {
double t_1 = sin(ky) * th;
double t_2 = hypot(sin(kx), sin(ky));
double t_3 = pow(sin(kx), 2.0);
double t_4 = sin(ky) / sqrt((t_3 + pow(sin(ky), 2.0)));
double tmp;
if (t_4 <= -0.05) {
tmp = t_1 / t_2;
} else if (t_4 <= 1.5e-6) {
tmp = ((fma((ky * ky), -0.16666666666666666, 1.0) * ky) / sqrt((t_3 + (ky * ky)))) * sin(th);
} else if (t_4 <= 0.9999999999998741) {
tmp = t_1 * pow(t_2, -1.0);
} else {
tmp = sin(th);
}
return tmp;
}
function code(kx, ky, th) t_1 = Float64(sin(ky) * th) t_2 = hypot(sin(kx), sin(ky)) t_3 = sin(kx) ^ 2.0 t_4 = Float64(sin(ky) / sqrt(Float64(t_3 + (sin(ky) ^ 2.0)))) tmp = 0.0 if (t_4 <= -0.05) tmp = Float64(t_1 / t_2); elseif (t_4 <= 1.5e-6) tmp = Float64(Float64(Float64(fma(Float64(ky * ky), -0.16666666666666666, 1.0) * ky) / sqrt(Float64(t_3 + Float64(ky * ky)))) * sin(th)); elseif (t_4 <= 0.9999999999998741) tmp = Float64(t_1 * (t_2 ^ -1.0)); else tmp = sin(th); end return tmp end
code[kx_, ky_, th_] := Block[{t$95$1 = N[(N[Sin[ky], $MachinePrecision] * th), $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[kx], $MachinePrecision], 2.0], $MachinePrecision]}, Block[{t$95$4 = N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(t$95$3 + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$4, -0.05], N[(t$95$1 / t$95$2), $MachinePrecision], If[LessEqual[t$95$4, 1.5e-6], N[(N[(N[(N[(N[(ky * ky), $MachinePrecision] * -0.16666666666666666 + 1.0), $MachinePrecision] * ky), $MachinePrecision] / N[Sqrt[N[(t$95$3 + N[(ky * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$4, 0.9999999999998741], N[(t$95$1 * N[Power[t$95$2, -1.0], $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \sin ky \cdot th\\
t_2 := \mathsf{hypot}\left(\sin kx, \sin ky\right)\\
t_3 := {\sin kx}^{2}\\
t_4 := \frac{\sin ky}{\sqrt{t\_3 + {\sin ky}^{2}}}\\
\mathbf{if}\;t\_4 \leq -0.05:\\
\;\;\;\;\frac{t\_1}{t\_2}\\
\mathbf{elif}\;t\_4 \leq 1.5 \cdot 10^{-6}:\\
\;\;\;\;\frac{\mathsf{fma}\left(ky \cdot ky, -0.16666666666666666, 1\right) \cdot ky}{\sqrt{t\_3 + ky \cdot ky}} \cdot \sin th\\
\mathbf{elif}\;t\_4 \leq 0.9999999999998741:\\
\;\;\;\;t\_1 \cdot {t\_2}^{-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.050000000000000003Initial program 92.1%
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2-revN/A
lower-cos.f64N/A
count-2-revN/A
lower-*.f6492.1
Applied rewrites92.1%
Taylor expanded in ky around 0
lower-sqrt.f64N/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
cos-neg-revN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
lower-*.f64N/A
metadata-eval9.3
Applied rewrites9.3%
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
fp-cancel-sub-sign-invN/A
+-commutativeN/A
metadata-evalN/A
lower-fma.f64N/A
metadata-evalN/A
distribute-lft-neg-inN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
metadata-evalN/A
lower-*.f64N/A
+-commutativeN/A
unpow2N/A
lower-fma.f64N/A
Applied rewrites43.9%
Applied rewrites49.7%
if -0.050000000000000003 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 1.5e-6Initial program 99.3%
Taylor expanded in ky around 0
unpow2N/A
lower-*.f6498.1
Applied rewrites98.1%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f6498.0
Applied rewrites98.0%
if 1.5e-6 < (/.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.9999999999998741Initial program 99.1%
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2-revN/A
lower-cos.f64N/A
count-2-revN/A
lower-*.f6499.0
Applied rewrites99.0%
Taylor expanded in ky around 0
lower-sqrt.f64N/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
cos-neg-revN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
lower-*.f64N/A
metadata-eval21.8
Applied rewrites21.8%
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
fp-cancel-sub-sign-invN/A
+-commutativeN/A
metadata-evalN/A
lower-fma.f64N/A
metadata-evalN/A
distribute-lft-neg-inN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
metadata-evalN/A
lower-*.f64N/A
+-commutativeN/A
unpow2N/A
lower-fma.f64N/A
Applied rewrites56.8%
Applied rewrites57.1%
if 0.9999999999998741 < (/.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 84.3%
Taylor expanded in kx around 0
lower-sin.f6492.0
Applied rewrites92.0%
Final simplification78.2%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (* (* (sin ky) th) (pow (hypot (sin kx) (sin ky)) -1.0)))
(t_2 (pow (sin kx) 2.0))
(t_3 (/ (sin ky) (sqrt (+ t_2 (pow (sin ky) 2.0))))))
(if (<= t_3 -0.05)
t_1
(if (<= t_3 1.5e-6)
(*
(/
(* (fma (* ky ky) -0.16666666666666666 1.0) ky)
(sqrt (+ t_2 (* ky ky))))
(sin th))
(if (<= t_3 0.9999999999998741) t_1 (sin th))))))
double code(double kx, double ky, double th) {
double t_1 = (sin(ky) * th) * pow(hypot(sin(kx), sin(ky)), -1.0);
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.05) {
tmp = t_1;
} else if (t_3 <= 1.5e-6) {
tmp = ((fma((ky * ky), -0.16666666666666666, 1.0) * ky) / sqrt((t_2 + (ky * ky)))) * sin(th);
} else if (t_3 <= 0.9999999999998741) {
tmp = t_1;
} else {
tmp = sin(th);
}
return tmp;
}
function code(kx, ky, th) t_1 = Float64(Float64(sin(ky) * th) * (hypot(sin(kx), sin(ky)) ^ -1.0)) 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.05) tmp = t_1; elseif (t_3 <= 1.5e-6) tmp = Float64(Float64(Float64(fma(Float64(ky * ky), -0.16666666666666666, 1.0) * ky) / sqrt(Float64(t_2 + Float64(ky * ky)))) * sin(th)); elseif (t_3 <= 0.9999999999998741) tmp = t_1; else tmp = sin(th); end return tmp end
code[kx_, ky_, th_] := Block[{t$95$1 = N[(N[(N[Sin[ky], $MachinePrecision] * th), $MachinePrecision] * N[Power[N[Sqrt[N[Sin[kx], $MachinePrecision] ^ 2 + N[Sin[ky], $MachinePrecision] ^ 2], $MachinePrecision], -1.0], $MachinePrecision]), $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.05], t$95$1, If[LessEqual[t$95$3, 1.5e-6], N[(N[(N[(N[(N[(ky * ky), $MachinePrecision] * -0.16666666666666666 + 1.0), $MachinePrecision] * 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.9999999999998741], t$95$1, N[Sin[th], $MachinePrecision]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \left(\sin ky \cdot th\right) \cdot {\left(\mathsf{hypot}\left(\sin kx, \sin ky\right)\right)}^{-1}\\
t_2 := {\sin kx}^{2}\\
t_3 := \frac{\sin ky}{\sqrt{t\_2 + {\sin ky}^{2}}}\\
\mathbf{if}\;t\_3 \leq -0.05:\\
\;\;\;\;t\_1\\
\mathbf{elif}\;t\_3 \leq 1.5 \cdot 10^{-6}:\\
\;\;\;\;\frac{\mathsf{fma}\left(ky \cdot ky, -0.16666666666666666, 1\right) \cdot ky}{\sqrt{t\_2 + ky \cdot ky}} \cdot \sin th\\
\mathbf{elif}\;t\_3 \leq 0.9999999999998741:\\
\;\;\;\;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.050000000000000003 or 1.5e-6 < (/.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.9999999999998741Initial program 93.8%
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2-revN/A
lower-cos.f64N/A
count-2-revN/A
lower-*.f6493.8
Applied rewrites93.8%
Taylor expanded in ky around 0
lower-sqrt.f64N/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
cos-neg-revN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
lower-*.f64N/A
metadata-eval12.4
Applied rewrites12.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
fp-cancel-sub-sign-invN/A
+-commutativeN/A
metadata-evalN/A
lower-fma.f64N/A
metadata-evalN/A
distribute-lft-neg-inN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
metadata-evalN/A
lower-*.f64N/A
+-commutativeN/A
unpow2N/A
lower-fma.f64N/A
Applied rewrites47.1%
Applied rewrites51.5%
if -0.050000000000000003 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 1.5e-6Initial program 99.3%
Taylor expanded in ky around 0
unpow2N/A
lower-*.f6498.1
Applied rewrites98.1%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f6498.0
Applied rewrites98.0%
if 0.9999999999998741 < (/.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 84.3%
Taylor expanded in kx around 0
lower-sin.f6492.0
Applied rewrites92.0%
Final simplification78.2%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1
(*
(* (sin ky) th)
(sqrt
(pow
(/ (+ (- 1.0 (cos (* 2.0 ky))) (- 1.0 (cos (* -2.0 kx)))) 2.0)
-1.0))))
(t_2 (pow (sin kx) 2.0))
(t_3 (/ (sin ky) (sqrt (+ t_2 (pow (sin ky) 2.0))))))
(if (<= t_3 -0.05)
t_1
(if (<= t_3 1.5e-6)
(*
(/
(* (fma (* ky ky) -0.16666666666666666 1.0) ky)
(sqrt (+ t_2 (* ky ky))))
(sin th))
(if (<= t_3 0.9999999999998741) t_1 (sin th))))))
double code(double kx, double ky, double th) {
double t_1 = (sin(ky) * th) * sqrt(pow((((1.0 - cos((2.0 * ky))) + (1.0 - cos((-2.0 * kx)))) / 2.0), -1.0));
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.05) {
tmp = t_1;
} else if (t_3 <= 1.5e-6) {
tmp = ((fma((ky * ky), -0.16666666666666666, 1.0) * ky) / sqrt((t_2 + (ky * ky)))) * sin(th);
} else if (t_3 <= 0.9999999999998741) {
tmp = t_1;
} else {
tmp = sin(th);
}
return tmp;
}
function code(kx, ky, th) t_1 = Float64(Float64(sin(ky) * th) * sqrt((Float64(Float64(Float64(1.0 - cos(Float64(2.0 * ky))) + Float64(1.0 - cos(Float64(-2.0 * kx)))) / 2.0) ^ -1.0))) 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.05) tmp = t_1; elseif (t_3 <= 1.5e-6) tmp = Float64(Float64(Float64(fma(Float64(ky * ky), -0.16666666666666666, 1.0) * ky) / sqrt(Float64(t_2 + Float64(ky * ky)))) * sin(th)); elseif (t_3 <= 0.9999999999998741) tmp = t_1; else tmp = sin(th); end return tmp end
code[kx_, ky_, th_] := Block[{t$95$1 = N[(N[(N[Sin[ky], $MachinePrecision] * th), $MachinePrecision] * N[Sqrt[N[Power[N[(N[(N[(1.0 - N[Cos[N[(2.0 * ky), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] + N[(1.0 - N[Cos[N[(-2.0 * kx), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / 2.0), $MachinePrecision], -1.0], $MachinePrecision]], $MachinePrecision]), $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.05], t$95$1, If[LessEqual[t$95$3, 1.5e-6], N[(N[(N[(N[(N[(ky * ky), $MachinePrecision] * -0.16666666666666666 + 1.0), $MachinePrecision] * 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.9999999999998741], t$95$1, N[Sin[th], $MachinePrecision]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \left(\sin ky \cdot th\right) \cdot \sqrt{{\left(\frac{\left(1 - \cos \left(2 \cdot ky\right)\right) + \left(1 - \cos \left(-2 \cdot kx\right)\right)}{2}\right)}^{-1}}\\
t_2 := {\sin kx}^{2}\\
t_3 := \frac{\sin ky}{\sqrt{t\_2 + {\sin ky}^{2}}}\\
\mathbf{if}\;t\_3 \leq -0.05:\\
\;\;\;\;t\_1\\
\mathbf{elif}\;t\_3 \leq 1.5 \cdot 10^{-6}:\\
\;\;\;\;\frac{\mathsf{fma}\left(ky \cdot ky, -0.16666666666666666, 1\right) \cdot ky}{\sqrt{t\_2 + ky \cdot ky}} \cdot \sin th\\
\mathbf{elif}\;t\_3 \leq 0.9999999999998741:\\
\;\;\;\;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.050000000000000003 or 1.5e-6 < (/.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.9999999999998741Initial program 93.8%
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2-revN/A
lower-cos.f64N/A
count-2-revN/A
lower-*.f6493.8
Applied rewrites93.8%
Taylor expanded in ky around 0
lower-sqrt.f64N/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
cos-neg-revN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
lower-*.f64N/A
metadata-eval12.4
Applied rewrites12.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
fp-cancel-sub-sign-invN/A
+-commutativeN/A
metadata-evalN/A
lower-fma.f64N/A
metadata-evalN/A
distribute-lft-neg-inN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
metadata-evalN/A
lower-*.f64N/A
+-commutativeN/A
unpow2N/A
lower-fma.f64N/A
Applied rewrites47.1%
Applied rewrites47.1%
if -0.050000000000000003 < (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 1.5e-6Initial program 99.3%
Taylor expanded in ky around 0
unpow2N/A
lower-*.f6498.1
Applied rewrites98.1%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f6498.0
Applied rewrites98.0%
if 0.9999999999998741 < (/.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 84.3%
Taylor expanded in kx around 0
lower-sin.f6492.0
Applied rewrites92.0%
Final simplification76.4%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0))))))
(if (<= t_1 -1.0)
(*
(/
(sin ky)
(hypot (sin ky) (* (fma -0.16666666666666666 (* kx kx) 1.0) kx)))
(* (fma (* th th) -0.16666666666666666 1.0) th))
(if (<= t_1 5e-221)
(* (/ (sin ky) (sqrt (fma -0.5 (cos (* 2.0 kx)) 0.5))) (sin th))
(if (<= t_1 0.285) (* (/ (sin ky) (sin kx)) (sin th)) (sin th))))))
double code(double kx, double ky, double th) {
double t_1 = sin(ky) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)));
double tmp;
if (t_1 <= -1.0) {
tmp = (sin(ky) / hypot(sin(ky), (fma(-0.16666666666666666, (kx * kx), 1.0) * kx))) * (fma((th * th), -0.16666666666666666, 1.0) * th);
} else if (t_1 <= 5e-221) {
tmp = (sin(ky) / sqrt(fma(-0.5, cos((2.0 * kx)), 0.5))) * sin(th);
} else if (t_1 <= 0.285) {
tmp = (sin(ky) / sin(kx)) * sin(th);
} else {
tmp = sin(th);
}
return tmp;
}
function code(kx, ky, th) t_1 = Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) tmp = 0.0 if (t_1 <= -1.0) tmp = Float64(Float64(sin(ky) / hypot(sin(ky), Float64(fma(-0.16666666666666666, Float64(kx * kx), 1.0) * kx))) * Float64(fma(Float64(th * th), -0.16666666666666666, 1.0) * th)); elseif (t_1 <= 5e-221) tmp = Float64(Float64(sin(ky) / sqrt(fma(-0.5, cos(Float64(2.0 * kx)), 0.5))) * sin(th)); elseif (t_1 <= 0.285) tmp = Float64(Float64(sin(ky) / sin(kx)) * sin(th)); else tmp = sin(th); end return tmp end
code[kx_, ky_, th_] := Block[{t$95$1 = N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$1, -1.0], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[Sin[ky], $MachinePrecision] ^ 2 + N[(N[(-0.16666666666666666 * N[(kx * kx), $MachinePrecision] + 1.0), $MachinePrecision] * kx), $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision] * N[(N[(N[(th * th), $MachinePrecision] * -0.16666666666666666 + 1.0), $MachinePrecision] * th), $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$1, 5e-221], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(-0.5 * N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision] + 0.5), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$1, 0.285], 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}
t_1 := \frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}}\\
\mathbf{if}\;t\_1 \leq -1:\\
\;\;\;\;\frac{\sin ky}{\mathsf{hypot}\left(\sin ky, \mathsf{fma}\left(-0.16666666666666666, kx \cdot kx, 1\right) \cdot kx\right)} \cdot \left(\mathsf{fma}\left(th \cdot th, -0.16666666666666666, 1\right) \cdot th\right)\\
\mathbf{elif}\;t\_1 \leq 5 \cdot 10^{-221}:\\
\;\;\;\;\frac{\sin ky}{\sqrt{\mathsf{fma}\left(-0.5, \cos \left(2 \cdot kx\right), 0.5\right)}} \cdot \sin th\\
\mathbf{elif}\;t\_1 \leq 0.285:\\
\;\;\;\;\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))))) < -1Initial program 88.1%
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-pow.f64N/A
unpow2N/A
lower-hypot.f64100.0
Applied rewrites100.0%
Taylor expanded in th around 0
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f6453.0
Applied rewrites53.0%
Taylor expanded in kx around 0
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f6453.0
Applied rewrites53.0%
if -1 < (/.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.99999999999999996e-221Initial program 99.2%
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2-revN/A
lower-cos.f64N/A
count-2-revN/A
lower-*.f6485.6
Applied rewrites85.6%
Taylor expanded in ky around 0
lower-sqrt.f64N/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
cos-neg-revN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
lower-*.f64N/A
metadata-eval60.1
Applied rewrites60.1%
Taylor expanded in ky around 0
lower-sqrt.f64N/A
fp-cancel-sub-sign-invN/A
+-commutativeN/A
metadata-evalN/A
lower-fma.f64N/A
metadata-evalN/A
distribute-lft-neg-inN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
metadata-evalN/A
lower-*.f6460.1
Applied rewrites60.1%
if 4.99999999999999996e-221 < (/.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.284999999999999976Initial program 99.5%
Taylor expanded in ky around 0
lower-sin.f6450.2
Applied rewrites50.2%
if 0.284999999999999976 < (/.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.3%
Taylor expanded in kx around 0
lower-sin.f6473.3
Applied rewrites73.3%
Final simplification61.3%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (pow (sin kx) 2.0))
(t_2 (/ (sin ky) (sqrt (+ t_1 (pow (sin ky) 2.0))))))
(if (<= t_2 -0.4)
(*
(/
(sin ky)
(hypot (sin ky) (* (fma -0.16666666666666666 (* kx kx) 1.0) kx)))
(* (fma (* th th) -0.16666666666666666 1.0) th))
(if (<= t_2 0.004)
(*
(/
(* (fma (* ky ky) -0.16666666666666666 1.0) ky)
(sqrt (+ t_1 (* ky ky))))
(sin th))
(sin th)))))
double code(double kx, double ky, double th) {
double t_1 = pow(sin(kx), 2.0);
double t_2 = sin(ky) / sqrt((t_1 + pow(sin(ky), 2.0)));
double tmp;
if (t_2 <= -0.4) {
tmp = (sin(ky) / hypot(sin(ky), (fma(-0.16666666666666666, (kx * kx), 1.0) * kx))) * (fma((th * th), -0.16666666666666666, 1.0) * th);
} else if (t_2 <= 0.004) {
tmp = ((fma((ky * ky), -0.16666666666666666, 1.0) * ky) / sqrt((t_1 + (ky * ky)))) * sin(th);
} else {
tmp = sin(th);
}
return tmp;
}
function code(kx, ky, th) t_1 = sin(kx) ^ 2.0 t_2 = Float64(sin(ky) / sqrt(Float64(t_1 + (sin(ky) ^ 2.0)))) tmp = 0.0 if (t_2 <= -0.4) tmp = Float64(Float64(sin(ky) / hypot(sin(ky), Float64(fma(-0.16666666666666666, Float64(kx * kx), 1.0) * kx))) * Float64(fma(Float64(th * th), -0.16666666666666666, 1.0) * th)); elseif (t_2 <= 0.004) tmp = Float64(Float64(Float64(fma(Float64(ky * ky), -0.16666666666666666, 1.0) * ky) / sqrt(Float64(t_1 + Float64(ky * ky)))) * sin(th)); else tmp = sin(th); end return tmp end
code[kx_, ky_, th_] := Block[{t$95$1 = N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision]}, Block[{t$95$2 = N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(t$95$1 + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$2, -0.4], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[Sin[ky], $MachinePrecision] ^ 2 + N[(N[(-0.16666666666666666 * N[(kx * kx), $MachinePrecision] + 1.0), $MachinePrecision] * kx), $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision] * N[(N[(N[(th * th), $MachinePrecision] * -0.16666666666666666 + 1.0), $MachinePrecision] * th), $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, 0.004], N[(N[(N[(N[(N[(ky * ky), $MachinePrecision] * -0.16666666666666666 + 1.0), $MachinePrecision] * ky), $MachinePrecision] / N[Sqrt[N[(t$95$1 + N[(ky * ky), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := {\sin kx}^{2}\\
t_2 := \frac{\sin ky}{\sqrt{t\_1 + {\sin ky}^{2}}}\\
\mathbf{if}\;t\_2 \leq -0.4:\\
\;\;\;\;\frac{\sin ky}{\mathsf{hypot}\left(\sin ky, \mathsf{fma}\left(-0.16666666666666666, kx \cdot kx, 1\right) \cdot kx\right)} \cdot \left(\mathsf{fma}\left(th \cdot th, -0.16666666666666666, 1\right) \cdot th\right)\\
\mathbf{elif}\;t\_2 \leq 0.004:\\
\;\;\;\;\frac{\mathsf{fma}\left(ky \cdot ky, -0.16666666666666666, 1\right) \cdot ky}{\sqrt{t\_1 + ky \cdot ky}} \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.40000000000000002Initial program 91.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.9
Applied rewrites99.9%
Taylor expanded in th around 0
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f6454.5
Applied rewrites54.5%
Taylor expanded in kx around 0
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f6439.6
Applied rewrites39.6%
if -0.40000000000000002 < (/.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.0040000000000000001Initial program 99.2%
Taylor expanded in ky around 0
unpow2N/A
lower-*.f6491.9
Applied rewrites91.9%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f6491.6
Applied rewrites91.6%
if 0.0040000000000000001 < (/.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.7%
Taylor expanded in kx around 0
lower-sin.f6471.2
Applied rewrites71.2%
Final simplification71.0%
(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 5e-221)
(* (* (sqrt (pow (fma -0.5 (cos (* 2.0 kx)) 0.5) -1.0)) ky) (sin th))
(if (<= t_1 0.004) (* (/ ky (sin kx)) (sin th)) (sin th)))))
double code(double kx, double ky, double th) {
double t_1 = sin(ky) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)));
double tmp;
if (t_1 <= 5e-221) {
tmp = (sqrt(pow(fma(-0.5, cos((2.0 * kx)), 0.5), -1.0)) * ky) * sin(th);
} else if (t_1 <= 0.004) {
tmp = (ky / sin(kx)) * sin(th);
} else {
tmp = sin(th);
}
return tmp;
}
function code(kx, ky, th) t_1 = Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) tmp = 0.0 if (t_1 <= 5e-221) tmp = Float64(Float64(sqrt((fma(-0.5, cos(Float64(2.0 * kx)), 0.5) ^ -1.0)) * ky) * sin(th)); elseif (t_1 <= 0.004) tmp = Float64(Float64(ky / sin(kx)) * sin(th)); else tmp = sin(th); end return tmp end
code[kx_, ky_, th_] := Block[{t$95$1 = N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$1, 5e-221], N[(N[(N[Sqrt[N[Power[N[(-0.5 * N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision] + 0.5), $MachinePrecision], -1.0], $MachinePrecision]], $MachinePrecision] * ky), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$1, 0.004], N[(N[(ky / N[Sin[kx], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}}\\
\mathbf{if}\;t\_1 \leq 5 \cdot 10^{-221}:\\
\;\;\;\;\left(\sqrt{{\left(\mathsf{fma}\left(-0.5, \cos \left(2 \cdot kx\right), 0.5\right)\right)}^{-1}} \cdot ky\right) \cdot \sin th\\
\mathbf{elif}\;t\_1 \leq 0.004:\\
\;\;\;\;\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.99999999999999996e-221Initial program 95.3%
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2-revN/A
lower-cos.f64N/A
count-2-revN/A
lower-*.f6486.5
Applied rewrites86.5%
Taylor expanded in ky around 0
lower-sqrt.f64N/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
cos-neg-revN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
lower-*.f64N/A
metadata-eval40.1
Applied rewrites40.1%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
lower-sqrt.f64N/A
lower-/.f64N/A
fp-cancel-sub-sign-invN/A
+-commutativeN/A
metadata-evalN/A
lower-fma.f64N/A
metadata-evalN/A
distribute-lft-neg-inN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
metadata-evalN/A
lower-*.f6436.2
Applied rewrites36.2%
if 4.99999999999999996e-221 < (/.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.0040000000000000001Initial program 99.5%
Taylor expanded in ky around 0
lower-/.f64N/A
lower-sin.f6453.7
Applied rewrites53.7%
if 0.0040000000000000001 < (/.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.7%
Taylor expanded in kx around 0
lower-sin.f6471.2
Applied rewrites71.2%
Final simplification49.6%
(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 5e-221)
(* (sqrt (pow (fma -0.5 (cos (* 2.0 kx)) 0.5) -1.0)) (* (sin th) ky))
(if (<= t_1 0.004) (* (/ ky (sin kx)) (sin th)) (sin th)))))
double code(double kx, double ky, double th) {
double t_1 = sin(ky) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)));
double tmp;
if (t_1 <= 5e-221) {
tmp = sqrt(pow(fma(-0.5, cos((2.0 * kx)), 0.5), -1.0)) * (sin(th) * ky);
} else if (t_1 <= 0.004) {
tmp = (ky / sin(kx)) * sin(th);
} else {
tmp = sin(th);
}
return tmp;
}
function code(kx, ky, th) t_1 = Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) tmp = 0.0 if (t_1 <= 5e-221) tmp = Float64(sqrt((fma(-0.5, cos(Float64(2.0 * kx)), 0.5) ^ -1.0)) * Float64(sin(th) * ky)); elseif (t_1 <= 0.004) tmp = Float64(Float64(ky / sin(kx)) * sin(th)); else tmp = sin(th); end return tmp end
code[kx_, ky_, th_] := Block[{t$95$1 = N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$1, 5e-221], N[(N[Sqrt[N[Power[N[(-0.5 * N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision] + 0.5), $MachinePrecision], -1.0], $MachinePrecision]], $MachinePrecision] * N[(N[Sin[th], $MachinePrecision] * ky), $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$1, 0.004], N[(N[(ky / N[Sin[kx], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}}\\
\mathbf{if}\;t\_1 \leq 5 \cdot 10^{-221}:\\
\;\;\;\;\sqrt{{\left(\mathsf{fma}\left(-0.5, \cos \left(2 \cdot kx\right), 0.5\right)\right)}^{-1}} \cdot \left(\sin th \cdot ky\right)\\
\mathbf{elif}\;t\_1 \leq 0.004:\\
\;\;\;\;\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.99999999999999996e-221Initial program 95.3%
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2-revN/A
lower-cos.f64N/A
count-2-revN/A
lower-*.f6486.5
Applied rewrites86.5%
Taylor expanded in ky around 0
lower-sqrt.f64N/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
cos-neg-revN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
lower-*.f64N/A
metadata-eval40.1
Applied rewrites40.1%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
lower-sqrt.f64N/A
lower-/.f64N/A
fp-cancel-sub-sign-invN/A
+-commutativeN/A
metadata-evalN/A
lower-fma.f64N/A
metadata-evalN/A
distribute-lft-neg-inN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
metadata-evalN/A
lower-*.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f6436.2
Applied rewrites36.2%
if 4.99999999999999996e-221 < (/.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.0040000000000000001Initial program 99.5%
Taylor expanded in ky around 0
lower-/.f64N/A
lower-sin.f6453.7
Applied rewrites53.7%
if 0.0040000000000000001 < (/.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.7%
Taylor expanded in kx around 0
lower-sin.f6471.2
Applied rewrites71.2%
Final simplification49.5%
(FPCore (kx ky th)
:precision binary64
(let* ((t_1 (pow (sin kx) 2.0)))
(if (<= t_1 1e-169)
(sin th)
(if (<= t_1 1e-24)
(* (/ (sin ky) (sqrt (* kx kx))) (sin th))
(*
(sqrt (pow (fma -0.5 (cos (* 2.0 kx)) (fma ky ky 0.5)) -1.0))
(* (sin th) ky))))))
double code(double kx, double ky, double th) {
double t_1 = pow(sin(kx), 2.0);
double tmp;
if (t_1 <= 1e-169) {
tmp = sin(th);
} else if (t_1 <= 1e-24) {
tmp = (sin(ky) / sqrt((kx * kx))) * sin(th);
} else {
tmp = sqrt(pow(fma(-0.5, cos((2.0 * kx)), fma(ky, ky, 0.5)), -1.0)) * (sin(th) * ky);
}
return tmp;
}
function code(kx, ky, th) t_1 = sin(kx) ^ 2.0 tmp = 0.0 if (t_1 <= 1e-169) tmp = sin(th); elseif (t_1 <= 1e-24) tmp = Float64(Float64(sin(ky) / sqrt(Float64(kx * kx))) * sin(th)); else tmp = Float64(sqrt((fma(-0.5, cos(Float64(2.0 * kx)), fma(ky, ky, 0.5)) ^ -1.0)) * Float64(sin(th) * ky)); end return tmp end
code[kx_, ky_, th_] := Block[{t$95$1 = N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision]}, If[LessEqual[t$95$1, 1e-169], N[Sin[th], $MachinePrecision], If[LessEqual[t$95$1, 1e-24], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(kx * kx), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], N[(N[Sqrt[N[Power[N[(-0.5 * N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision] + N[(ky * ky + 0.5), $MachinePrecision]), $MachinePrecision], -1.0], $MachinePrecision]], $MachinePrecision] * N[(N[Sin[th], $MachinePrecision] * ky), $MachinePrecision]), $MachinePrecision]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := {\sin kx}^{2}\\
\mathbf{if}\;t\_1 \leq 10^{-169}:\\
\;\;\;\;\sin th\\
\mathbf{elif}\;t\_1 \leq 10^{-24}:\\
\;\;\;\;\frac{\sin ky}{\sqrt{kx \cdot kx}} \cdot \sin th\\
\mathbf{else}:\\
\;\;\;\;\sqrt{{\left(\mathsf{fma}\left(-0.5, \cos \left(2 \cdot kx\right), \mathsf{fma}\left(ky, ky, 0.5\right)\right)\right)}^{-1}} \cdot \left(\sin th \cdot ky\right)\\
\end{array}
\end{array}
if (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) < 1.00000000000000002e-169Initial program 85.1%
Taylor expanded in kx around 0
lower-sin.f6446.7
Applied rewrites46.7%
if 1.00000000000000002e-169 < (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) < 9.99999999999999924e-25Initial program 99.8%
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2-revN/A
lower-cos.f64N/A
count-2-revN/A
lower-*.f6444.0
Applied rewrites44.0%
Taylor expanded in ky around 0
lower-sqrt.f64N/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
cos-neg-revN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
lower-*.f64N/A
metadata-eval2.3
Applied rewrites2.3%
Taylor expanded in kx around 0
Applied rewrites60.6%
if 9.99999999999999924e-25 < (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) Initial program 99.5%
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2-revN/A
lower-cos.f64N/A
count-2-revN/A
lower-*.f6498.8
Applied rewrites98.8%
Taylor expanded in kx around inf
*-commutativeN/A
lower-*.f64N/A
Applied rewrites98.7%
Taylor expanded in ky around 0
Applied rewrites59.4%
Taylor expanded in ky around 0
Applied rewrites61.6%
Final simplification55.6%
(FPCore (kx ky th) :precision binary64 (if (<= (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))) 0.004) (* (/ ky (sin kx)) (sin th)) (sin th)))
double code(double kx, double ky, double th) {
double tmp;
if ((sin(ky) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)))) <= 0.004) {
tmp = (ky / sin(kx)) * sin(th);
} else {
tmp = sin(th);
}
return tmp;
}
real(8) function code(kx, ky, th)
real(8), intent (in) :: kx
real(8), intent (in) :: ky
real(8), intent (in) :: th
real(8) :: tmp
if ((sin(ky) / sqrt(((sin(kx) ** 2.0d0) + (sin(ky) ** 2.0d0)))) <= 0.004d0) then
tmp = (ky / sin(kx)) * sin(th)
else
tmp = sin(th)
end if
code = tmp
end function
public static double code(double kx, double ky, double th) {
double tmp;
if ((Math.sin(ky) / Math.sqrt((Math.pow(Math.sin(kx), 2.0) + Math.pow(Math.sin(ky), 2.0)))) <= 0.004) {
tmp = (ky / Math.sin(kx)) * Math.sin(th);
} else {
tmp = Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): tmp = 0 if (math.sin(ky) / math.sqrt((math.pow(math.sin(kx), 2.0) + math.pow(math.sin(ky), 2.0)))) <= 0.004: tmp = (ky / math.sin(kx)) * math.sin(th) else: tmp = math.sin(th) return tmp
function code(kx, ky, th) tmp = 0.0 if (Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) <= 0.004) tmp = Float64(Float64(ky / sin(kx)) * sin(th)); else tmp = sin(th); end return tmp end
function tmp_2 = code(kx, ky, th) tmp = 0.0; if ((sin(ky) / sqrt(((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) <= 0.004) tmp = (ky / sin(kx)) * sin(th); else tmp = sin(th); end tmp_2 = tmp; end
code[kx_, ky_, th_] := If[LessEqual[N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], 0.004], N[(N[(ky / N[Sin[kx], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}} \leq 0.004:\\
\;\;\;\;\frac{ky}{\sin kx} \cdot \sin th\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\end{array}
if (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.0040000000000000001Initial program 96.2%
Taylor expanded in ky around 0
lower-/.f64N/A
lower-sin.f6431.7
Applied rewrites31.7%
if 0.0040000000000000001 < (/.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.7%
Taylor expanded in kx around 0
lower-sin.f6471.2
Applied rewrites71.2%
Final simplification44.1%
(FPCore (kx ky th) :precision binary64 (if (<= (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))) 0.004) (/ (* (sin th) ky) (sin kx)) (sin th)))
double code(double kx, double ky, double th) {
double tmp;
if ((sin(ky) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)))) <= 0.004) {
tmp = (sin(th) * ky) / sin(kx);
} else {
tmp = sin(th);
}
return tmp;
}
real(8) function code(kx, ky, th)
real(8), intent (in) :: kx
real(8), intent (in) :: ky
real(8), intent (in) :: th
real(8) :: tmp
if ((sin(ky) / sqrt(((sin(kx) ** 2.0d0) + (sin(ky) ** 2.0d0)))) <= 0.004d0) then
tmp = (sin(th) * ky) / sin(kx)
else
tmp = sin(th)
end if
code = tmp
end function
public static double code(double kx, double ky, double th) {
double tmp;
if ((Math.sin(ky) / Math.sqrt((Math.pow(Math.sin(kx), 2.0) + Math.pow(Math.sin(ky), 2.0)))) <= 0.004) {
tmp = (Math.sin(th) * ky) / Math.sin(kx);
} else {
tmp = Math.sin(th);
}
return tmp;
}
def code(kx, ky, th): tmp = 0 if (math.sin(ky) / math.sqrt((math.pow(math.sin(kx), 2.0) + math.pow(math.sin(ky), 2.0)))) <= 0.004: tmp = (math.sin(th) * ky) / math.sin(kx) else: tmp = math.sin(th) return tmp
function code(kx, ky, th) tmp = 0.0 if (Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) <= 0.004) tmp = Float64(Float64(sin(th) * ky) / sin(kx)); else tmp = sin(th); end return tmp end
function tmp_2 = code(kx, ky, th) tmp = 0.0; if ((sin(ky) / sqrt(((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) <= 0.004) tmp = (sin(th) * ky) / sin(kx); else tmp = sin(th); end tmp_2 = tmp; end
code[kx_, ky_, th_] := If[LessEqual[N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], 0.004], N[(N[(N[Sin[th], $MachinePrecision] * ky), $MachinePrecision] / N[Sin[kx], $MachinePrecision]), $MachinePrecision], N[Sin[th], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}} \leq 0.004:\\
\;\;\;\;\frac{\sin th \cdot ky}{\sin kx}\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\end{array}
if (/.f64 (sin.f64 ky) (sqrt.f64 (+.f64 (pow.f64 (sin.f64 kx) #s(literal 2 binary64)) (pow.f64 (sin.f64 ky) #s(literal 2 binary64))))) < 0.0040000000000000001Initial program 96.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-/.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower-sin.f64N/A
lower-sin.f6430.4
Applied rewrites30.4%
if 0.0040000000000000001 < (/.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.7%
Taylor expanded in kx around 0
lower-sin.f6471.2
Applied rewrites71.2%
Final simplification43.2%
(FPCore (kx ky th)
:precision binary64
(if (<=
(*
(/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0))))
(sin th))
5e-309)
(* (* (* -0.16666666666666666 th) th) th)
(*
(fma
(- (* (* th th) 0.008333333333333333) 0.16666666666666666)
(* th th)
1.0)
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)))) * sin(th)) <= 5e-309) {
tmp = ((-0.16666666666666666 * th) * th) * th;
} else {
tmp = fma((((th * th) * 0.008333333333333333) - 0.16666666666666666), (th * th), 1.0) * th;
}
return tmp;
}
function code(kx, ky, th) tmp = 0.0 if (Float64(Float64(sin(ky) / sqrt(Float64((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) * sin(th)) <= 5e-309) tmp = Float64(Float64(Float64(-0.16666666666666666 * th) * th) * th); else tmp = Float64(fma(Float64(Float64(Float64(th * th) * 0.008333333333333333) - 0.16666666666666666), Float64(th * th), 1.0) * th); end return tmp end
code[kx_, ky_, th_] := If[LessEqual[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], 5e-309], N[(N[(N[(-0.16666666666666666 * th), $MachinePrecision] * th), $MachinePrecision] * th), $MachinePrecision], N[(N[(N[(N[(N[(th * th), $MachinePrecision] * 0.008333333333333333), $MachinePrecision] - 0.16666666666666666), $MachinePrecision] * N[(th * th), $MachinePrecision] + 1.0), $MachinePrecision] * th), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}} \cdot \sin th \leq 5 \cdot 10^{-309}:\\
\;\;\;\;\left(\left(-0.16666666666666666 \cdot th\right) \cdot th\right) \cdot th\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(\left(th \cdot th\right) \cdot 0.008333333333333333 - 0.16666666666666666, th \cdot th, 1\right) \cdot th\\
\end{array}
\end{array}
if (*.f64 (/.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))))) (sin.f64 th)) < 4.9999999999999995e-309Initial program 95.9%
Taylor expanded in kx around 0
lower-sin.f6418.8
Applied rewrites18.8%
Taylor expanded in th around 0
Applied rewrites11.5%
Taylor expanded in th around inf
Applied rewrites14.0%
Applied rewrites14.0%
if 4.9999999999999995e-309 < (*.f64 (/.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))))) (sin.f64 th)) Initial program 92.2%
Taylor expanded in kx around 0
lower-sin.f6429.7
Applied rewrites29.7%
Taylor expanded in th around 0
Applied rewrites15.8%
Final simplification15.0%
(FPCore (kx ky th) :precision binary64 (if (<= (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))) 2e-13) (* (/ ky 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)))) <= 2e-13) {
tmp = (ky / 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)))) <= 2d-13) then
tmp = (ky / 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)))) <= 2e-13) {
tmp = (ky / 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)))) <= 2e-13: tmp = (ky / 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)))) <= 2e-13) tmp = Float64(Float64(ky / 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)))) <= 2e-13) tmp = (ky / 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], 2e-13], N[(N[(ky / kx), $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 2 \cdot 10^{-13}:\\
\;\;\;\;\frac{ky}{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))))) < 2.0000000000000001e-13Initial program 96.1%
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2-revN/A
lower-cos.f64N/A
count-2-revN/A
lower-*.f6483.1
Applied rewrites83.1%
Taylor expanded in ky around 0
lower-sqrt.f64N/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
cos-neg-revN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
lower-*.f64N/A
metadata-eval45.6
Applied rewrites45.6%
Taylor expanded in ky around 0
*-commutativeN/A
lower-*.f64N/A
lower-sqrt.f64N/A
lower-/.f64N/A
fp-cancel-sub-sign-invN/A
+-commutativeN/A
metadata-evalN/A
lower-fma.f64N/A
metadata-evalN/A
distribute-lft-neg-inN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
metadata-evalN/A
lower-*.f6442.4
Applied rewrites42.4%
Taylor expanded in kx around 0
Applied rewrites18.8%
if 2.0000000000000001e-13 < (/.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.0%
Taylor expanded in kx around 0
lower-sin.f6469.8
Applied rewrites69.8%
Final simplification35.1%
(FPCore (kx ky th)
:precision binary64
(if (<=
(/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0))))
1.32e-51)
(* (* (* -0.16666666666666666 th) th) 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)))) <= 1.32e-51) {
tmp = ((-0.16666666666666666 * th) * th) * 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)))) <= 1.32d-51) then
tmp = (((-0.16666666666666666d0) * th) * th) * 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)))) <= 1.32e-51) {
tmp = ((-0.16666666666666666 * th) * th) * 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)))) <= 1.32e-51: tmp = ((-0.16666666666666666 * th) * th) * 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)))) <= 1.32e-51) tmp = Float64(Float64(Float64(-0.16666666666666666 * th) * th) * 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)))) <= 1.32e-51) tmp = ((-0.16666666666666666 * th) * th) * 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], 1.32e-51], N[(N[(N[(-0.16666666666666666 * th), $MachinePrecision] * th), $MachinePrecision] * th), $MachinePrecision], N[Sin[th], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}} \leq 1.32 \cdot 10^{-51}:\\
\;\;\;\;\left(\left(-0.16666666666666666 \cdot th\right) \cdot th\right) \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))))) < 1.31999999999999998e-51Initial program 96.0%
Taylor expanded in kx around 0
lower-sin.f643.5
Applied rewrites3.5%
Taylor expanded in th around 0
Applied rewrites3.1%
Taylor expanded in th around inf
Applied rewrites11.0%
Applied rewrites11.0%
if 1.31999999999999998e-51 < (/.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.7%
Taylor expanded in kx around 0
lower-sin.f6465.6
Applied rewrites65.6%
Final simplification29.8%
(FPCore (kx ky th)
:precision binary64
(if (<= ky 0.003)
(*
(/
(sin ky)
(hypot (* (fma (* ky ky) -0.16666666666666666 1.0) ky) (sin kx)))
(sin th))
(*
(sqrt
(pow (/ (+ (- 1.0 (cos (* 2.0 ky))) (- 1.0 (cos (* 2.0 kx)))) 2.0) -1.0))
(* (sin th) (sin ky)))))
double code(double kx, double ky, double th) {
double tmp;
if (ky <= 0.003) {
tmp = (sin(ky) / hypot((fma((ky * ky), -0.16666666666666666, 1.0) * ky), sin(kx))) * sin(th);
} else {
tmp = sqrt(pow((((1.0 - cos((2.0 * ky))) + (1.0 - cos((2.0 * kx)))) / 2.0), -1.0)) * (sin(th) * sin(ky));
}
return tmp;
}
function code(kx, ky, th) tmp = 0.0 if (ky <= 0.003) tmp = Float64(Float64(sin(ky) / hypot(Float64(fma(Float64(ky * ky), -0.16666666666666666, 1.0) * ky), sin(kx))) * sin(th)); else tmp = Float64(sqrt((Float64(Float64(Float64(1.0 - cos(Float64(2.0 * ky))) + Float64(1.0 - cos(Float64(2.0 * kx)))) / 2.0) ^ -1.0)) * Float64(sin(th) * sin(ky))); end return tmp end
code[kx_, ky_, th_] := If[LessEqual[ky, 0.003], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[(N[(ky * ky), $MachinePrecision] * -0.16666666666666666 + 1.0), $MachinePrecision] * ky), $MachinePrecision] ^ 2 + N[Sin[kx], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], N[(N[Sqrt[N[Power[N[(N[(N[(1.0 - N[Cos[N[(2.0 * ky), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] + N[(1.0 - N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / 2.0), $MachinePrecision], -1.0], $MachinePrecision]], $MachinePrecision] * N[(N[Sin[th], $MachinePrecision] * N[Sin[ky], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;ky \leq 0.003:\\
\;\;\;\;\frac{\sin ky}{\mathsf{hypot}\left(\mathsf{fma}\left(ky \cdot ky, -0.16666666666666666, 1\right) \cdot ky, \sin kx\right)} \cdot \sin th\\
\mathbf{else}:\\
\;\;\;\;\sqrt{{\left(\frac{\left(1 - \cos \left(2 \cdot ky\right)\right) + \left(1 - \cos \left(2 \cdot kx\right)\right)}{2}\right)}^{-1}} \cdot \left(\sin th \cdot \sin ky\right)\\
\end{array}
\end{array}
if ky < 0.0030000000000000001Initial program 92.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
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f6469.6
Applied rewrites69.6%
if 0.0030000000000000001 < ky Initial program 99.7%
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2-revN/A
lower-cos.f64N/A
count-2-revN/A
lower-*.f6499.7
Applied rewrites99.7%
Taylor expanded in kx around inf
*-commutativeN/A
lower-*.f64N/A
Applied rewrites98.5%
Applied rewrites98.8%
Final simplification75.8%
(FPCore (kx ky th)
:precision binary64
(if (<=
(/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0))))
1.25e-36)
(* (* (* -0.16666666666666666 th) th) th)
(* (fma (* -0.16666666666666666 th) th 1.0) 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)))) <= 1.25e-36) {
tmp = ((-0.16666666666666666 * th) * th) * th;
} else {
tmp = fma((-0.16666666666666666 * th), th, 1.0) * 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)))) <= 1.25e-36) tmp = Float64(Float64(Float64(-0.16666666666666666 * th) * th) * th); else tmp = Float64(fma(Float64(-0.16666666666666666 * th), th, 1.0) * th); end return tmp end
code[kx_, ky_, th_] := If[LessEqual[N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[Power[N[Sin[kx], $MachinePrecision], 2.0], $MachinePrecision] + N[Power[N[Sin[ky], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], 1.25e-36], N[(N[(N[(-0.16666666666666666 * th), $MachinePrecision] * th), $MachinePrecision] * th), $MachinePrecision], N[(N[(N[(-0.16666666666666666 * th), $MachinePrecision] * th + 1.0), $MachinePrecision] * th), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}} \leq 1.25 \cdot 10^{-36}:\\
\;\;\;\;\left(\left(-0.16666666666666666 \cdot th\right) \cdot th\right) \cdot th\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(-0.16666666666666666 \cdot th, th, 1\right) \cdot 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.25000000000000001e-36Initial program 96.1%
Taylor expanded in kx around 0
lower-sin.f643.5
Applied rewrites3.5%
Taylor expanded in th around 0
Applied rewrites3.2%
Taylor expanded in th around inf
Applied rewrites10.9%
Applied rewrites10.9%
if 1.25000000000000001e-36 < (/.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.4%
Taylor expanded in kx around 0
lower-sin.f6467.0
Applied rewrites67.0%
Taylor expanded in th around 0
Applied rewrites34.8%
Applied rewrites34.8%
Final simplification19.0%
(FPCore (kx ky th) :precision binary64 (if (<= (sin kx) -0.005) (* (/ (sin ky) (sqrt (fma -0.5 (cos (* 2.0 kx)) 0.5))) (sin th)) (if (<= (sin kx) 5e-85) (sin th) (* (/ (sin ky) (sin kx)) (sin th)))))
double code(double kx, double ky, double th) {
double tmp;
if (sin(kx) <= -0.005) {
tmp = (sin(ky) / sqrt(fma(-0.5, cos((2.0 * kx)), 0.5))) * sin(th);
} else if (sin(kx) <= 5e-85) {
tmp = sin(th);
} else {
tmp = (sin(ky) / sin(kx)) * sin(th);
}
return tmp;
}
function code(kx, ky, th) tmp = 0.0 if (sin(kx) <= -0.005) tmp = Float64(Float64(sin(ky) / sqrt(fma(-0.5, cos(Float64(2.0 * kx)), 0.5))) * sin(th)); elseif (sin(kx) <= 5e-85) tmp = sin(th); else tmp = Float64(Float64(sin(ky) / sin(kx)) * sin(th)); end return tmp end
code[kx_, ky_, th_] := If[LessEqual[N[Sin[kx], $MachinePrecision], -0.005], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(-0.5 * N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision] + 0.5), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], If[LessEqual[N[Sin[kx], $MachinePrecision], 5e-85], N[Sin[th], $MachinePrecision], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sin[kx], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\sin kx \leq -0.005:\\
\;\;\;\;\frac{\sin ky}{\sqrt{\mathsf{fma}\left(-0.5, \cos \left(2 \cdot kx\right), 0.5\right)}} \cdot \sin th\\
\mathbf{elif}\;\sin kx \leq 5 \cdot 10^{-85}:\\
\;\;\;\;\sin th\\
\mathbf{else}:\\
\;\;\;\;\frac{\sin ky}{\sin kx} \cdot \sin th\\
\end{array}
\end{array}
if (sin.f64 kx) < -0.0050000000000000001Initial program 99.5%
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2-revN/A
lower-cos.f64N/A
count-2-revN/A
lower-*.f6499.0
Applied rewrites99.0%
Taylor expanded in ky around 0
lower-sqrt.f64N/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
cos-neg-revN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
lower-*.f64N/A
metadata-eval68.8
Applied rewrites68.8%
Taylor expanded in ky around 0
lower-sqrt.f64N/A
fp-cancel-sub-sign-invN/A
+-commutativeN/A
metadata-evalN/A
lower-fma.f64N/A
metadata-evalN/A
distribute-lft-neg-inN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
metadata-evalN/A
lower-*.f6468.8
Applied rewrites68.8%
if -0.0050000000000000001 < (sin.f64 kx) < 5.0000000000000002e-85Initial program 87.2%
Taylor expanded in kx around 0
lower-sin.f6443.7
Applied rewrites43.7%
if 5.0000000000000002e-85 < (sin.f64 kx) Initial program 99.5%
Taylor expanded in ky around 0
lower-sin.f6462.6
Applied rewrites62.6%
Final simplification55.5%
(FPCore (kx ky th)
:precision binary64
(if (<= (sin kx) -0.005)
(*
(sqrt (pow (fma -0.5 (cos (* 2.0 kx)) (fma ky ky 0.5)) -1.0))
(* (sin th) ky))
(if (<= (sin kx) 5e-85) (sin th) (* (/ (sin ky) (sin kx)) (sin th)))))
double code(double kx, double ky, double th) {
double tmp;
if (sin(kx) <= -0.005) {
tmp = sqrt(pow(fma(-0.5, cos((2.0 * kx)), fma(ky, ky, 0.5)), -1.0)) * (sin(th) * ky);
} else if (sin(kx) <= 5e-85) {
tmp = sin(th);
} else {
tmp = (sin(ky) / sin(kx)) * sin(th);
}
return tmp;
}
function code(kx, ky, th) tmp = 0.0 if (sin(kx) <= -0.005) tmp = Float64(sqrt((fma(-0.5, cos(Float64(2.0 * kx)), fma(ky, ky, 0.5)) ^ -1.0)) * Float64(sin(th) * ky)); elseif (sin(kx) <= 5e-85) tmp = sin(th); else tmp = Float64(Float64(sin(ky) / sin(kx)) * sin(th)); end return tmp end
code[kx_, ky_, th_] := If[LessEqual[N[Sin[kx], $MachinePrecision], -0.005], N[(N[Sqrt[N[Power[N[(-0.5 * N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision] + N[(ky * ky + 0.5), $MachinePrecision]), $MachinePrecision], -1.0], $MachinePrecision]], $MachinePrecision] * N[(N[Sin[th], $MachinePrecision] * ky), $MachinePrecision]), $MachinePrecision], If[LessEqual[N[Sin[kx], $MachinePrecision], 5e-85], N[Sin[th], $MachinePrecision], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sin[kx], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\sin kx \leq -0.005:\\
\;\;\;\;\sqrt{{\left(\mathsf{fma}\left(-0.5, \cos \left(2 \cdot kx\right), \mathsf{fma}\left(ky, ky, 0.5\right)\right)\right)}^{-1}} \cdot \left(\sin th \cdot ky\right)\\
\mathbf{elif}\;\sin kx \leq 5 \cdot 10^{-85}:\\
\;\;\;\;\sin th\\
\mathbf{else}:\\
\;\;\;\;\frac{\sin ky}{\sin kx} \cdot \sin th\\
\end{array}
\end{array}
if (sin.f64 kx) < -0.0050000000000000001Initial program 99.5%
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2-revN/A
lower-cos.f64N/A
count-2-revN/A
lower-*.f6499.0
Applied rewrites99.0%
Taylor expanded in kx around inf
*-commutativeN/A
lower-*.f64N/A
Applied rewrites99.0%
Taylor expanded in ky around 0
Applied rewrites62.9%
Taylor expanded in ky around 0
Applied rewrites64.3%
if -0.0050000000000000001 < (sin.f64 kx) < 5.0000000000000002e-85Initial program 87.2%
Taylor expanded in kx around 0
lower-sin.f6443.7
Applied rewrites43.7%
if 5.0000000000000002e-85 < (sin.f64 kx) Initial program 99.5%
Taylor expanded in ky around 0
lower-sin.f6462.6
Applied rewrites62.6%
Final simplification54.4%
(FPCore (kx ky th)
:precision binary64
(if (<= (sin kx) -0.005)
(*
(sqrt (pow (fma -0.5 (cos (* 2.0 kx)) (fma ky ky 0.5)) -1.0))
(* (sin th) ky))
(if (<= (sin kx) 5e-85) (sin th) (* (sin ky) (/ (sin th) (sin kx))))))
double code(double kx, double ky, double th) {
double tmp;
if (sin(kx) <= -0.005) {
tmp = sqrt(pow(fma(-0.5, cos((2.0 * kx)), fma(ky, ky, 0.5)), -1.0)) * (sin(th) * ky);
} else if (sin(kx) <= 5e-85) {
tmp = sin(th);
} else {
tmp = sin(ky) * (sin(th) / sin(kx));
}
return tmp;
}
function code(kx, ky, th) tmp = 0.0 if (sin(kx) <= -0.005) tmp = Float64(sqrt((fma(-0.5, cos(Float64(2.0 * kx)), fma(ky, ky, 0.5)) ^ -1.0)) * Float64(sin(th) * ky)); elseif (sin(kx) <= 5e-85) tmp = sin(th); else tmp = Float64(sin(ky) * Float64(sin(th) / sin(kx))); end return tmp end
code[kx_, ky_, th_] := If[LessEqual[N[Sin[kx], $MachinePrecision], -0.005], N[(N[Sqrt[N[Power[N[(-0.5 * N[Cos[N[(2.0 * kx), $MachinePrecision]], $MachinePrecision] + N[(ky * ky + 0.5), $MachinePrecision]), $MachinePrecision], -1.0], $MachinePrecision]], $MachinePrecision] * N[(N[Sin[th], $MachinePrecision] * ky), $MachinePrecision]), $MachinePrecision], If[LessEqual[N[Sin[kx], $MachinePrecision], 5e-85], N[Sin[th], $MachinePrecision], N[(N[Sin[ky], $MachinePrecision] * N[(N[Sin[th], $MachinePrecision] / N[Sin[kx], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\sin kx \leq -0.005:\\
\;\;\;\;\sqrt{{\left(\mathsf{fma}\left(-0.5, \cos \left(2 \cdot kx\right), \mathsf{fma}\left(ky, ky, 0.5\right)\right)\right)}^{-1}} \cdot \left(\sin th \cdot ky\right)\\
\mathbf{elif}\;\sin kx \leq 5 \cdot 10^{-85}:\\
\;\;\;\;\sin th\\
\mathbf{else}:\\
\;\;\;\;\sin ky \cdot \frac{\sin th}{\sin kx}\\
\end{array}
\end{array}
if (sin.f64 kx) < -0.0050000000000000001Initial program 99.5%
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2-revN/A
lower-cos.f64N/A
count-2-revN/A
lower-*.f6499.0
Applied rewrites99.0%
Taylor expanded in kx around inf
*-commutativeN/A
lower-*.f64N/A
Applied rewrites99.0%
Taylor expanded in ky around 0
Applied rewrites62.9%
Taylor expanded in ky around 0
Applied rewrites64.3%
if -0.0050000000000000001 < (sin.f64 kx) < 5.0000000000000002e-85Initial program 87.2%
Taylor expanded in kx around 0
lower-sin.f6443.7
Applied rewrites43.7%
if 5.0000000000000002e-85 < (sin.f64 kx) Initial program 99.5%
lift-pow.f64N/A
unpow2N/A
lift-sin.f64N/A
lift-sin.f64N/A
sqr-sin-aN/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
count-2-revN/A
lower-cos.f64N/A
count-2-revN/A
lower-*.f6489.7
Applied rewrites89.7%
Taylor expanded in ky around 0
lower-sqrt.f64N/A
lower--.f64N/A
*-commutativeN/A
lower-*.f64N/A
cos-neg-revN/A
lower-cos.f64N/A
distribute-lft-neg-inN/A
lower-*.f64N/A
metadata-eval52.6
Applied rewrites52.6%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
associate-/l*N/A
lower-*.f64N/A
lower-/.f6452.6
Applied rewrites62.6%
Final simplification54.4%
(FPCore (kx ky th)
:precision binary64
(if (<= ky 0.003)
(*
(/
(sin ky)
(hypot (* (fma (* ky ky) -0.16666666666666666 1.0) ky) (sin kx)))
(sin th))
(/
(* (sin th) (sin ky))
(/
(sqrt
(fma (- 1.0 (cos (* 2.0 ky))) 2.0 (* 2.0 (- 1.0 (cos (* -2.0 kx))))))
2.0))))
double code(double kx, double ky, double th) {
double tmp;
if (ky <= 0.003) {
tmp = (sin(ky) / hypot((fma((ky * ky), -0.16666666666666666, 1.0) * ky), sin(kx))) * sin(th);
} else {
tmp = (sin(th) * sin(ky)) / (sqrt(fma((1.0 - cos((2.0 * ky))), 2.0, (2.0 * (1.0 - cos((-2.0 * kx)))))) / 2.0);
}
return tmp;
}
function code(kx, ky, th) tmp = 0.0 if (ky <= 0.003) tmp = Float64(Float64(sin(ky) / hypot(Float64(fma(Float64(ky * ky), -0.16666666666666666, 1.0) * ky), sin(kx))) * sin(th)); else tmp = Float64(Float64(sin(th) * sin(ky)) / Float64(sqrt(fma(Float64(1.0 - cos(Float64(2.0 * ky))), 2.0, Float64(2.0 * Float64(1.0 - cos(Float64(-2.0 * kx)))))) / 2.0)); end return tmp end
code[kx_, ky_, th_] := If[LessEqual[ky, 0.003], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[(N[(ky * ky), $MachinePrecision] * -0.16666666666666666 + 1.0), $MachinePrecision] * ky), $MachinePrecision] ^ 2 + N[Sin[kx], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], N[(N[(N[Sin[th], $MachinePrecision] * N[Sin[ky], $MachinePrecision]), $MachinePrecision] / N[(N[Sqrt[N[(N[(1.0 - N[Cos[N[(2.0 * ky), $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]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;ky \leq 0.003:\\
\;\;\;\;\frac{\sin ky}{\mathsf{hypot}\left(\mathsf{fma}\left(ky \cdot ky, -0.16666666666666666, 1\right) \cdot ky, \sin kx\right)} \cdot \sin th\\
\mathbf{else}:\\
\;\;\;\;\frac{\sin th \cdot \sin ky}{\frac{\sqrt{\mathsf{fma}\left(1 - \cos \left(2 \cdot ky\right), 2, 2 \cdot \left(1 - \cos \left(-2 \cdot kx\right)\right)\right)}}{2}}\\
\end{array}
\end{array}
if ky < 0.0030000000000000001Initial program 92.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
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f6469.6
Applied rewrites69.6%
if 0.0030000000000000001 < ky Initial program 99.7%
lift-*.f64N/A
lift-/.f64N/A
associate-*l/N/A
lower-/.f64N/A
*-commutativeN/A
lower-*.f6499.6
lift-sqrt.f64N/A
lift-+.f64N/A
+-commutativeN/A
lift-pow.f64N/A
unpow2N/A
lift-pow.f64N/A
unpow2N/A
lower-hypot.f6499.6
Applied rewrites99.6%
Applied rewrites98.9%
(FPCore (kx ky th)
:precision binary64
(if (<= ky 0.003)
(*
(/
(sin ky)
(hypot (* (fma (* ky ky) -0.16666666666666666 1.0) ky) (sin kx)))
(sin th))
(*
(/
(sin ky)
(/
(sqrt
(fma (- 1.0 (cos (* 2.0 ky))) 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 <= 0.003) {
tmp = (sin(ky) / hypot((fma((ky * ky), -0.16666666666666666, 1.0) * ky), sin(kx))) * sin(th);
} else {
tmp = (sin(ky) / (sqrt(fma((1.0 - cos((2.0 * ky))), 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 <= 0.003) tmp = Float64(Float64(sin(ky) / hypot(Float64(fma(Float64(ky * ky), -0.16666666666666666, 1.0) * ky), sin(kx))) * sin(th)); else tmp = Float64(Float64(sin(ky) / Float64(sqrt(fma(Float64(1.0 - cos(Float64(2.0 * ky))), 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, 0.003], N[(N[(N[Sin[ky], $MachinePrecision] / N[Sqrt[N[(N[(N[(ky * ky), $MachinePrecision] * -0.16666666666666666 + 1.0), $MachinePrecision] * ky), $MachinePrecision] ^ 2 + N[Sin[kx], $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision] * N[Sin[th], $MachinePrecision]), $MachinePrecision], N[(N[(N[Sin[ky], $MachinePrecision] / N[(N[Sqrt[N[(N[(1.0 - N[Cos[N[(2.0 * ky), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * 2.0 + 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 0.003:\\
\;\;\;\;\frac{\sin ky}{\mathsf{hypot}\left(\mathsf{fma}\left(ky \cdot ky, -0.16666666666666666, 1\right) \cdot ky, \sin kx\right)} \cdot \sin th\\
\mathbf{else}:\\
\;\;\;\;\frac{\sin ky}{\frac{\sqrt{\mathsf{fma}\left(1 - \cos \left(2 \cdot ky\right), 2, 2 \cdot \left(1 - \cos \left(-2 \cdot kx\right)\right)\right)}}{2}} \cdot \sin th\\
\end{array}
\end{array}
if ky < 0.0030000000000000001Initial program 92.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
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
lower-fma.f64N/A
unpow2N/A
lower-*.f6469.6
Applied rewrites69.6%
if 0.0030000000000000001 < ky Initial program 99.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.7
Applied rewrites99.7%
lift-hypot.f64N/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
lift-sin.f64N/A
lift-sin.f64N/A
sin-multN/A
frac-addN/A
metadata-evalN/A
metadata-evalN/A
sqrt-divN/A
metadata-evalN/A
metadata-evalN/A
lower-/.f64N/A
Applied rewrites98.9%
(FPCore (kx ky th) :precision binary64 (* (* (* -0.16666666666666666 th) th) th))
double code(double kx, double ky, double th) {
return ((-0.16666666666666666 * th) * th) * th;
}
real(8) function code(kx, ky, th)
real(8), intent (in) :: kx
real(8), intent (in) :: ky
real(8), intent (in) :: th
code = (((-0.16666666666666666d0) * th) * th) * th
end function
public static double code(double kx, double ky, double th) {
return ((-0.16666666666666666 * th) * th) * th;
}
def code(kx, ky, th): return ((-0.16666666666666666 * th) * th) * th
function code(kx, ky, th) return Float64(Float64(Float64(-0.16666666666666666 * th) * th) * th) end
function tmp = code(kx, ky, th) tmp = ((-0.16666666666666666 * th) * th) * th; end
code[kx_, ky_, th_] := N[(N[(N[(-0.16666666666666666 * th), $MachinePrecision] * th), $MachinePrecision] * th), $MachinePrecision]
\begin{array}{l}
\\
\left(\left(-0.16666666666666666 \cdot th\right) \cdot th\right) \cdot th
\end{array}
Initial program 93.8%
Taylor expanded in kx around 0
lower-sin.f6424.8
Applied rewrites24.8%
Taylor expanded in th around 0
Applied rewrites13.8%
Taylor expanded in th around inf
Applied rewrites8.8%
Applied rewrites8.8%
Final simplification8.8%
herbie shell --seed 2024329
(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)))