\[\left(\left(\left(0 \leq normAngle \land normAngle \leq \frac{\pi}{2}\right) \land \left(-1 \leq n0_i \land n0_i \leq 1\right)\right) \land \left(-1 \leq n1_i \land n1_i \leq 1\right)\right) \land \left(2.328306437 \cdot 10^{-10} \leq u \land u \leq 1\right)\]
\[\left(\sin \left(\left(1 - u\right) \cdot normAngle\right) \cdot \frac{1}{\sin normAngle}\right) \cdot n0_i + \left(\sin \left(u \cdot normAngle\right) \cdot \frac{1}{\sin normAngle}\right) \cdot n1_i
\]
↓
\[n0_i + \left(\left(n1_i + \left(n1_i \cdot 0.16666666666666666\right) \cdot \left(normAngle \cdot normAngle\right)\right) - n0_i\right) \cdot u
\]
(FPCore (normAngle u n0_i n1_i)
:precision binary32
(+
(* (* (sin (* (- 1.0 u) normAngle)) (/ 1.0 (sin normAngle))) n0_i)
(* (* (sin (* u normAngle)) (/ 1.0 (sin normAngle))) n1_i)))
↓
(FPCore (normAngle u n0_i n1_i)
:precision binary32
(+
n0_i
(*
(- (+ n1_i (* (* n1_i 0.16666666666666666) (* normAngle normAngle))) n0_i)
u)))
float code(float normAngle, float u, float n0_i, float n1_i) {
return ((sinf(((1.0f - u) * normAngle)) * (1.0f / sinf(normAngle))) * n0_i) + ((sinf((u * normAngle)) * (1.0f / sinf(normAngle))) * n1_i);
}
↓
float code(float normAngle, float u, float n0_i, float n1_i) {
return n0_i + (((n1_i + ((n1_i * 0.16666666666666666f) * (normAngle * normAngle))) - n0_i) * u);
}
real(4) function code(normangle, u, n0_i, n1_i)
real(4), intent (in) :: normangle
real(4), intent (in) :: u
real(4), intent (in) :: n0_i
real(4), intent (in) :: n1_i
code = ((sin(((1.0e0 - u) * normangle)) * (1.0e0 / sin(normangle))) * n0_i) + ((sin((u * normangle)) * (1.0e0 / sin(normangle))) * n1_i)
end function
↓
real(4) function code(normangle, u, n0_i, n1_i)
real(4), intent (in) :: normangle
real(4), intent (in) :: u
real(4), intent (in) :: n0_i
real(4), intent (in) :: n1_i
code = n0_i + (((n1_i + ((n1_i * 0.16666666666666666e0) * (normangle * normangle))) - n0_i) * u)
end function
function code(normAngle, u, n0_i, n1_i)
return Float32(Float32(Float32(sin(Float32(Float32(Float32(1.0) - u) * normAngle)) * Float32(Float32(1.0) / sin(normAngle))) * n0_i) + Float32(Float32(sin(Float32(u * normAngle)) * Float32(Float32(1.0) / sin(normAngle))) * n1_i))
end
↓
function code(normAngle, u, n0_i, n1_i)
return Float32(n0_i + Float32(Float32(Float32(n1_i + Float32(Float32(n1_i * Float32(0.16666666666666666)) * Float32(normAngle * normAngle))) - n0_i) * u))
end
function tmp = code(normAngle, u, n0_i, n1_i)
tmp = ((sin(((single(1.0) - u) * normAngle)) * (single(1.0) / sin(normAngle))) * n0_i) + ((sin((u * normAngle)) * (single(1.0) / sin(normAngle))) * n1_i);
end
↓
function tmp = code(normAngle, u, n0_i, n1_i)
tmp = n0_i + (((n1_i + ((n1_i * single(0.16666666666666666)) * (normAngle * normAngle))) - n0_i) * u);
end
\left(\sin \left(\left(1 - u\right) \cdot normAngle\right) \cdot \frac{1}{\sin normAngle}\right) \cdot n0_i + \left(\sin \left(u \cdot normAngle\right) \cdot \frac{1}{\sin normAngle}\right) \cdot n1_i
↓
n0_i + \left(\left(n1_i + \left(n1_i \cdot 0.16666666666666666\right) \cdot \left(normAngle \cdot normAngle\right)\right) - n0_i\right) \cdot u
Alternatives
| Alternative 1 |
|---|
| Accuracy | 86.5% |
|---|
| Cost | 297 |
|---|
\[\begin{array}{l}
\mathbf{if}\;n1_i \leq -2.0000000063421537 \cdot 10^{-30} \lor \neg \left(n1_i \leq 4.0000000781659255 \cdot 10^{-25}\right):\\
\;\;\;\;n0_i + n1_i \cdot u\\
\mathbf{else}:\\
\;\;\;\;n0_i \cdot \left(1 - u\right)\\
\end{array}
\]
| Alternative 2 |
|---|
| Accuracy | 86.6% |
|---|
| Cost | 297 |
|---|
\[\begin{array}{l}
\mathbf{if}\;n1_i \leq -2.0000000063421537 \cdot 10^{-30} \lor \neg \left(n1_i \leq 4.0000000781659255 \cdot 10^{-25}\right):\\
\;\;\;\;n0_i + n1_i \cdot u\\
\mathbf{else}:\\
\;\;\;\;n0_i - n0_i \cdot u\\
\end{array}
\]
| Alternative 3 |
|---|
| Accuracy | 70.4% |
|---|
| Cost | 296 |
|---|
\[\begin{array}{l}
\mathbf{if}\;n1_i \leq -1.99999996490334 \cdot 10^{-14}:\\
\;\;\;\;n1_i \cdot u\\
\mathbf{elif}\;n1_i \leq 5.00000006675716 \cdot 10^{-11}:\\
\;\;\;\;n0_i \cdot \left(1 - u\right)\\
\mathbf{else}:\\
\;\;\;\;n1_i \cdot u\\
\end{array}
\]
| Alternative 4 |
|---|
| Accuracy | 59.3% |
|---|
| Cost | 232 |
|---|
\[\begin{array}{l}
\mathbf{if}\;n1_i \leq -1.999999936531045 \cdot 10^{-21}:\\
\;\;\;\;n1_i \cdot u\\
\mathbf{elif}\;n1_i \leq 5.00000006675716 \cdot 10^{-11}:\\
\;\;\;\;n0_i\\
\mathbf{else}:\\
\;\;\;\;n1_i \cdot u\\
\end{array}
\]
| Alternative 5 |
|---|
| Accuracy | 97.9% |
|---|
| Cost | 224 |
|---|
\[n0_i + u \cdot \left(n1_i - n0_i\right)
\]
| Alternative 6 |
|---|
| Accuracy | 46.4% |
|---|
| Cost | 32 |
|---|
\[n0_i
\]