\[\frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}} \cdot \sin th
\]
↓
\[\frac{\sin ky}{\mathsf{hypot}\left(\sin ky, \sin kx\right)} \cdot \sin th
\]
(FPCore (kx ky th)
:precision binary64
(* (/ (sin ky) (sqrt (+ (pow (sin kx) 2.0) (pow (sin ky) 2.0)))) (sin th)))
↓
(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) / sqrt((pow(sin(kx), 2.0) + pow(sin(ky), 2.0)))) * 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.sqrt((Math.pow(Math.sin(kx), 2.0) + Math.pow(Math.sin(ky), 2.0)))) * Math.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.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.hypot(math.sin(ky), math.sin(kx))) * 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 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) / sqrt(((sin(kx) ^ 2.0) + (sin(ky) ^ 2.0)))) * 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[(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]
↓
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]
\frac{\sin ky}{\sqrt{{\sin kx}^{2} + {\sin ky}^{2}}} \cdot \sin th
↓
\frac{\sin ky}{\mathsf{hypot}\left(\sin ky, \sin kx\right)} \cdot \sin th
Alternatives
| Alternative 1 |
|---|
| Accuracy | 76.0% |
|---|
| Cost | 45964 |
|---|
\[\begin{array}{l}
t_1 := \mathsf{hypot}\left(\sin ky, \sin kx\right)\\
t_2 := \frac{\frac{\sin ky}{t_1}}{\frac{1}{th} + th \cdot 0.16666666666666666}\\
\mathbf{if}\;\sin ky \leq -0.005:\\
\;\;\;\;t_2\\
\mathbf{elif}\;\sin ky \leq 5 \cdot 10^{-16}:\\
\;\;\;\;\sin th \cdot \frac{ky}{t_1}\\
\mathbf{elif}\;\sin ky \leq 0.925:\\
\;\;\;\;\sin th\\
\mathbf{else}:\\
\;\;\;\;t_2\\
\end{array}
\]
| Alternative 2 |
|---|
| Accuracy | 75.8% |
|---|
| Cost | 45580 |
|---|
\[\begin{array}{l}
t_1 := \mathsf{hypot}\left(\sin ky, \sin kx\right)\\
t_2 := \sin ky \cdot \frac{th}{t_1}\\
\mathbf{if}\;\sin ky \leq -0.01:\\
\;\;\;\;t_2\\
\mathbf{elif}\;\sin ky \leq 5 \cdot 10^{-16}:\\
\;\;\;\;\sin th \cdot \frac{ky}{t_1}\\
\mathbf{elif}\;\sin ky \leq 0.925:\\
\;\;\;\;\sin th\\
\mathbf{else}:\\
\;\;\;\;t_2\\
\end{array}
\]
| Alternative 3 |
|---|
| Accuracy | 75.8% |
|---|
| Cost | 45580 |
|---|
\[\begin{array}{l}
t_1 := \mathsf{hypot}\left(\sin ky, \sin kx\right)\\
\mathbf{if}\;\sin ky \leq -0.01:\\
\;\;\;\;\frac{\sin ky}{t_1} \cdot th\\
\mathbf{elif}\;\sin ky \leq 5 \cdot 10^{-16}:\\
\;\;\;\;\sin th \cdot \frac{ky}{t_1}\\
\mathbf{elif}\;\sin ky \leq 0.925:\\
\;\;\;\;\sin th\\
\mathbf{else}:\\
\;\;\;\;\sin ky \cdot \frac{th}{t_1}\\
\end{array}
\]
| Alternative 4 |
|---|
| Accuracy | 43.4% |
|---|
| Cost | 32584 |
|---|
\[\begin{array}{l}
\mathbf{if}\;\sin kx \leq -1 \cdot 10^{-50}:\\
\;\;\;\;\frac{ky \cdot th}{\mathsf{hypot}\left(\sin ky, \sin kx\right)}\\
\mathbf{elif}\;\sin kx \leq 5 \cdot 10^{-15}:\\
\;\;\;\;\frac{\sin th}{1 + 0.5 \cdot \left(\frac{kx}{ky} \cdot \frac{kx}{ky}\right)}\\
\mathbf{else}:\\
\;\;\;\;\sin ky \cdot \frac{\sin th}{\sin kx}\\
\end{array}
\]
| Alternative 5 |
|---|
| Accuracy | 99.6% |
|---|
| Cost | 32384 |
|---|
\[\sin ky \cdot \frac{\sin th}{\mathsf{hypot}\left(\sin ky, \sin kx\right)}
\]
| Alternative 6 |
|---|
| Accuracy | 60.8% |
|---|
| Cost | 26248 |
|---|
\[\begin{array}{l}
\mathbf{if}\;th \leq -0.01:\\
\;\;\;\;\sin th\\
\mathbf{elif}\;th \leq 5500000000000:\\
\;\;\;\;\sin ky \cdot \frac{th}{\mathsf{hypot}\left(\sin ky, \sin kx\right)}\\
\mathbf{else}:\\
\;\;\;\;\sin ky \cdot \left(\sin th \cdot \frac{1}{\sin kx}\right)\\
\end{array}
\]
| Alternative 7 |
|---|
| Accuracy | 41.8% |
|---|
| Cost | 26052 |
|---|
\[\begin{array}{l}
\mathbf{if}\;\sin kx \leq 5 \cdot 10^{-15}:\\
\;\;\;\;\frac{\sin th}{1 + 0.5 \cdot \left(\frac{kx}{ky} \cdot \frac{kx}{ky}\right)}\\
\mathbf{else}:\\
\;\;\;\;\sin ky \cdot \frac{\sin th}{\sin kx}\\
\end{array}
\]
| Alternative 8 |
|---|
| Accuracy | 34.1% |
|---|
| Cost | 19652 |
|---|
\[\begin{array}{l}
\mathbf{if}\;\sin kx \leq 0.18:\\
\;\;\;\;\frac{\sin th}{1 + 0.5 \cdot \left(\frac{kx}{ky} \cdot \frac{kx}{ky}\right)}\\
\mathbf{else}:\\
\;\;\;\;\sin ky \cdot \frac{th}{\sin kx}\\
\end{array}
\]
| Alternative 9 |
|---|
| Accuracy | 33.0% |
|---|
| Cost | 13764 |
|---|
\[\begin{array}{l}
\mathbf{if}\;\sin kx \leq 0.18:\\
\;\;\;\;\frac{\sin th}{1 + 0.5 \cdot \left(\frac{kx}{ky} \cdot \frac{kx}{ky}\right)}\\
\mathbf{else}:\\
\;\;\;\;ky \cdot \frac{th}{\sin kx}\\
\end{array}
\]
| Alternative 10 |
|---|
| Accuracy | 40.1% |
|---|
| Cost | 13384 |
|---|
\[\begin{array}{l}
\mathbf{if}\;ky \leq -19000:\\
\;\;\;\;\sin th\\
\mathbf{elif}\;ky \leq 1.6 \cdot 10^{-103}:\\
\;\;\;\;\sin th \cdot \frac{ky}{\sin kx}\\
\mathbf{else}:\\
\;\;\;\;\frac{\sin th}{1 + 0.5 \cdot \left(\frac{kx}{ky} \cdot \frac{kx}{ky}\right)}\\
\end{array}
\]
| Alternative 11 |
|---|
| Accuracy | 40.1% |
|---|
| Cost | 13384 |
|---|
\[\begin{array}{l}
\mathbf{if}\;ky \leq -19000:\\
\;\;\;\;\sin th\\
\mathbf{elif}\;ky \leq 5.5 \cdot 10^{-108}:\\
\;\;\;\;ky \cdot \frac{\sin th}{\sin kx}\\
\mathbf{else}:\\
\;\;\;\;\frac{\sin th}{1 + 0.5 \cdot \left(\frac{kx}{ky} \cdot \frac{kx}{ky}\right)}\\
\end{array}
\]
| Alternative 12 |
|---|
| Accuracy | 32.6% |
|---|
| Cost | 6984 |
|---|
\[\begin{array}{l}
\mathbf{if}\;ky \leq -3.6 \cdot 10^{-11}:\\
\;\;\;\;\sin th\\
\mathbf{elif}\;ky \leq 1.1 \cdot 10^{-109}:\\
\;\;\;\;th \cdot \frac{ky}{\sin kx}\\
\mathbf{else}:\\
\;\;\;\;\sin th\\
\end{array}
\]
| Alternative 13 |
|---|
| Accuracy | 23.7% |
|---|
| Cost | 6464 |
|---|
\[\sin th
\]
| Alternative 14 |
|---|
| Accuracy | 13.5% |
|---|
| Cost | 64 |
|---|
\[th
\]