\[\alpha > -1 \land \beta > -1\]
\[\frac{\frac{\beta - \alpha}{\left(\alpha + \beta\right) + 2} + 1}{2}
\]
↓
\[\begin{array}{l}
\mathbf{if}\;\frac{\beta - \alpha}{\left(\beta + \alpha\right) + 2} \leq -0.99996:\\
\;\;\;\;\frac{\beta + 1}{\alpha}\\
\mathbf{else}:\\
\;\;\;\;\frac{\mathsf{fma}\left(\beta - \alpha, \frac{1}{\beta + \left(\alpha + 2\right)}, 1\right)}{2}\\
\end{array}
\]
(FPCore (alpha beta)
:precision binary64
(/ (+ (/ (- beta alpha) (+ (+ alpha beta) 2.0)) 1.0) 2.0))
↓
(FPCore (alpha beta)
:precision binary64
(if (<= (/ (- beta alpha) (+ (+ beta alpha) 2.0)) -0.99996)
(/ (+ beta 1.0) alpha)
(/ (fma (- beta alpha) (/ 1.0 (+ beta (+ alpha 2.0))) 1.0) 2.0)))
double code(double alpha, double beta) {
return (((beta - alpha) / ((alpha + beta) + 2.0)) + 1.0) / 2.0;
}
↓
double code(double alpha, double beta) {
double tmp;
if (((beta - alpha) / ((beta + alpha) + 2.0)) <= -0.99996) {
tmp = (beta + 1.0) / alpha;
} else {
tmp = fma((beta - alpha), (1.0 / (beta + (alpha + 2.0))), 1.0) / 2.0;
}
return tmp;
}
function code(alpha, beta)
return Float64(Float64(Float64(Float64(beta - alpha) / Float64(Float64(alpha + beta) + 2.0)) + 1.0) / 2.0)
end
↓
function code(alpha, beta)
tmp = 0.0
if (Float64(Float64(beta - alpha) / Float64(Float64(beta + alpha) + 2.0)) <= -0.99996)
tmp = Float64(Float64(beta + 1.0) / alpha);
else
tmp = Float64(fma(Float64(beta - alpha), Float64(1.0 / Float64(beta + Float64(alpha + 2.0))), 1.0) / 2.0);
end
return tmp
end
code[alpha_, beta_] := N[(N[(N[(N[(beta - alpha), $MachinePrecision] / N[(N[(alpha + beta), $MachinePrecision] + 2.0), $MachinePrecision]), $MachinePrecision] + 1.0), $MachinePrecision] / 2.0), $MachinePrecision]
↓
code[alpha_, beta_] := If[LessEqual[N[(N[(beta - alpha), $MachinePrecision] / N[(N[(beta + alpha), $MachinePrecision] + 2.0), $MachinePrecision]), $MachinePrecision], -0.99996], N[(N[(beta + 1.0), $MachinePrecision] / alpha), $MachinePrecision], N[(N[(N[(beta - alpha), $MachinePrecision] * N[(1.0 / N[(beta + N[(alpha + 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] + 1.0), $MachinePrecision] / 2.0), $MachinePrecision]]
\frac{\frac{\beta - \alpha}{\left(\alpha + \beta\right) + 2} + 1}{2}
↓
\begin{array}{l}
\mathbf{if}\;\frac{\beta - \alpha}{\left(\beta + \alpha\right) + 2} \leq -0.99996:\\
\;\;\;\;\frac{\beta + 1}{\alpha}\\
\mathbf{else}:\\
\;\;\;\;\frac{\mathsf{fma}\left(\beta - \alpha, \frac{1}{\beta + \left(\alpha + 2\right)}, 1\right)}{2}\\
\end{array}
Alternatives
| Alternative 1 |
|---|
| Error | 0.44% |
|---|
| Cost | 1604 |
|---|
\[\begin{array}{l}
\mathbf{if}\;\frac{\beta - \alpha}{\left(\beta + \alpha\right) + 2} \leq -0.99996:\\
\;\;\;\;\frac{\beta + 1}{\alpha}\\
\mathbf{else}:\\
\;\;\;\;\frac{1 + \left(\beta - \alpha\right) \cdot \frac{1}{\beta + \left(\alpha + 2\right)}}{2}\\
\end{array}
\]
| Alternative 2 |
|---|
| Error | 0.44% |
|---|
| Cost | 1476 |
|---|
\[\begin{array}{l}
t_0 := \frac{\beta - \alpha}{\left(\beta + \alpha\right) + 2}\\
\mathbf{if}\;t_0 \leq -0.99996:\\
\;\;\;\;\frac{\beta + 1}{\alpha}\\
\mathbf{else}:\\
\;\;\;\;\frac{t_0 + 1}{2}\\
\end{array}
\]
| Alternative 3 |
|---|
| Error | 34.52% |
|---|
| Cost | 1116 |
|---|
\[\begin{array}{l}
\mathbf{if}\;\beta \leq -2.5 \cdot 10^{-201}:\\
\;\;\;\;0.5\\
\mathbf{elif}\;\beta \leq -1.22 \cdot 10^{-222}:\\
\;\;\;\;\frac{1}{\alpha}\\
\mathbf{elif}\;\beta \leq 32:\\
\;\;\;\;0.5\\
\mathbf{elif}\;\beta \leq 6.2 \cdot 10^{+43}:\\
\;\;\;\;1\\
\mathbf{elif}\;\beta \leq 4.1 \cdot 10^{+113}:\\
\;\;\;\;\frac{\beta}{\alpha}\\
\mathbf{elif}\;\beta \leq 3.8 \cdot 10^{+191}:\\
\;\;\;\;1\\
\mathbf{elif}\;\beta \leq 1.3 \cdot 10^{+203}:\\
\;\;\;\;\frac{\beta}{\alpha}\\
\mathbf{else}:\\
\;\;\;\;1\\
\end{array}
\]
| Alternative 4 |
|---|
| Error | 25.52% |
|---|
| Cost | 844 |
|---|
\[\begin{array}{l}
t_0 := \frac{1 - \alpha \cdot 0.5}{2}\\
\mathbf{if}\;\alpha \leq -1.5 \cdot 10^{-130}:\\
\;\;\;\;t_0\\
\mathbf{elif}\;\alpha \leq -1.1 \cdot 10^{-162}:\\
\;\;\;\;1\\
\mathbf{elif}\;\alpha \leq 1.8:\\
\;\;\;\;t_0\\
\mathbf{else}:\\
\;\;\;\;\frac{\beta + 1}{\alpha}\\
\end{array}
\]
| Alternative 5 |
|---|
| Error | 25.92% |
|---|
| Cost | 716 |
|---|
\[\begin{array}{l}
\mathbf{if}\;\alpha \leq -1.5 \cdot 10^{-130}:\\
\;\;\;\;0.5\\
\mathbf{elif}\;\alpha \leq -2.1 \cdot 10^{-162}:\\
\;\;\;\;1\\
\mathbf{elif}\;\alpha \leq 54:\\
\;\;\;\;0.5\\
\mathbf{else}:\\
\;\;\;\;\frac{\beta + 1}{\alpha}\\
\end{array}
\]
| Alternative 6 |
|---|
| Error | 6.5% |
|---|
| Cost | 708 |
|---|
\[\begin{array}{l}
\mathbf{if}\;\alpha \leq 8200:\\
\;\;\;\;\frac{1 + \frac{\beta}{\beta + 2}}{2}\\
\mathbf{else}:\\
\;\;\;\;\frac{\beta + 1}{\alpha}\\
\end{array}
\]
| Alternative 7 |
|---|
| Error | 31.57% |
|---|
| Cost | 588 |
|---|
\[\begin{array}{l}
\mathbf{if}\;\alpha \leq -1.5 \cdot 10^{-130}:\\
\;\;\;\;0.5\\
\mathbf{elif}\;\alpha \leq -1.1 \cdot 10^{-162}:\\
\;\;\;\;1\\
\mathbf{elif}\;\alpha \leq 53:\\
\;\;\;\;0.5\\
\mathbf{else}:\\
\;\;\;\;\frac{1}{\alpha}\\
\end{array}
\]
| Alternative 8 |
|---|
| Error | 31.03% |
|---|
| Cost | 324 |
|---|
\[\begin{array}{l}
\mathbf{if}\;\alpha \leq 53:\\
\;\;\;\;0.5\\
\mathbf{else}:\\
\;\;\;\;\frac{1}{\alpha}\\
\end{array}
\]
| Alternative 9 |
|---|
| Error | 51.05% |
|---|
| Cost | 64 |
|---|
\[0.5
\]