Math FPCore C Fortran Java Python Julia MATLAB Wolfram TeX \[\frac{e^{a}}{e^{a} + e^{b}}
\]
↓
\[\begin{array}{l}
\\
e^{a - \log \left(e^{a} + e^{b}\right)}
\end{array}
\]
(FPCore (a b) :precision binary64 (/ (exp a) (+ (exp a) (exp b)))) ↓
(FPCore (a b) :precision binary64 (exp (- a (log (+ (exp a) (exp b)))))) double code(double a, double b) {
return exp(a) / (exp(a) + exp(b));
}
↓
double code(double a, double b) {
return exp((a - log((exp(a) + exp(b)))));
}
real(8) function code(a, b)
real(8), intent (in) :: a
real(8), intent (in) :: b
code = exp(a) / (exp(a) + exp(b))
end function
↓
real(8) function code(a, b)
real(8), intent (in) :: a
real(8), intent (in) :: b
code = exp((a - log((exp(a) + exp(b)))))
end function
public static double code(double a, double b) {
return Math.exp(a) / (Math.exp(a) + Math.exp(b));
}
↓
public static double code(double a, double b) {
return Math.exp((a - Math.log((Math.exp(a) + Math.exp(b)))));
}
def code(a, b):
return math.exp(a) / (math.exp(a) + math.exp(b))
↓
def code(a, b):
return math.exp((a - math.log((math.exp(a) + math.exp(b)))))
function code(a, b)
return Float64(exp(a) / Float64(exp(a) + exp(b)))
end
↓
function code(a, b)
return exp(Float64(a - log(Float64(exp(a) + exp(b)))))
end
function tmp = code(a, b)
tmp = exp(a) / (exp(a) + exp(b));
end
↓
function tmp = code(a, b)
tmp = exp((a - log((exp(a) + exp(b)))));
end
code[a_, b_] := N[(N[Exp[a], $MachinePrecision] / N[(N[Exp[a], $MachinePrecision] + N[Exp[b], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
↓
code[a_, b_] := N[Exp[N[(a - N[Log[N[(N[Exp[a], $MachinePrecision] + N[Exp[b], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\frac{e^{a}}{e^{a} + e^{b}}
↓
\begin{array}{l}
\\
e^{a - \log \left(e^{a} + e^{b}\right)}
\end{array}
Alternatives Alternative 1 Accuracy 99.2% Cost 25920
\[e^{a - \log \left(e^{a} + e^{b}\right)}
\]
Alternative 2 Accuracy 99.0% Cost 19520
\[\frac{e^{a}}{e^{a} + e^{b}}
\]
Alternative 3 Accuracy 98.5% Cost 13252
\[\begin{array}{l}
\mathbf{if}\;e^{a} \leq 0:\\
\;\;\;\;\frac{e^{a}}{a}\\
\mathbf{else}:\\
\;\;\;\;\frac{1}{e^{b} + 1}\\
\end{array}
\]
Alternative 4 Accuracy 98.3% Cost 13248
\[\frac{e^{a}}{1 + \left(a + e^{b}\right)}
\]
Alternative 5 Accuracy 71.7% Cost 6724
\[\begin{array}{l}
\mathbf{if}\;a \leq -490:\\
\;\;\;\;\frac{e^{a}}{a}\\
\mathbf{elif}\;a \leq -3.7 \cdot 10^{-42}:\\
\;\;\;\;1\\
\mathbf{else}:\\
\;\;\;\;\frac{1}{2 + b \cdot \left(1 + b \cdot 0.5\right)}\\
\end{array}
\]
Alternative 6 Accuracy 72.6% Cost 1356
\[\begin{array}{l}
t_0 := b \cdot \left(-b\right)\\
\mathbf{if}\;b \leq -1.45:\\
\;\;\;\;1\\
\mathbf{elif}\;b \leq 5.5 \cdot 10^{+102}:\\
\;\;\;\;\frac{1}{2 + b \cdot \left(1 + b \cdot 0.5\right)}\\
\mathbf{elif}\;b \leq 1.35 \cdot 10^{+154}:\\
\;\;\;\;\frac{t_0 - b \cdot -2}{b \cdot t_0}\\
\mathbf{else}:\\
\;\;\;\;\frac{-2}{b \cdot b}\\
\end{array}
\]
Alternative 7 Accuracy 68.7% Cost 836
\[\begin{array}{l}
\mathbf{if}\;b \leq -0.94:\\
\;\;\;\;1\\
\mathbf{else}:\\
\;\;\;\;\frac{1}{2 + b \cdot \left(1 + b \cdot 0.5\right)}\\
\end{array}
\]
Alternative 8 Accuracy 68.2% Cost 708
\[\begin{array}{l}
\mathbf{if}\;b \leq -0.065:\\
\;\;\;\;1\\
\mathbf{else}:\\
\;\;\;\;\frac{1}{2 + b \cdot \left(b \cdot 0.5\right)}\\
\end{array}
\]
Alternative 9 Accuracy 68.7% Cost 584
\[\begin{array}{l}
\mathbf{if}\;b \leq -2:\\
\;\;\;\;1\\
\mathbf{elif}\;b \leq 2.9:\\
\;\;\;\;0.5 + b \cdot -0.25\\
\mathbf{else}:\\
\;\;\;\;\frac{-2}{b \cdot b}\\
\end{array}
\]
Alternative 10 Accuracy 55.2% Cost 452
\[\begin{array}{l}
\mathbf{if}\;b \leq -0.98:\\
\;\;\;\;1\\
\mathbf{else}:\\
\;\;\;\;0.5 + a \cdot 0.25\\
\end{array}
\]
Alternative 11 Accuracy 55.1% Cost 452
\[\begin{array}{l}
\mathbf{if}\;b \leq -2:\\
\;\;\;\;1\\
\mathbf{else}:\\
\;\;\;\;0.5 + b \cdot -0.25\\
\end{array}
\]
Alternative 12 Accuracy 54.9% Cost 196
\[\begin{array}{l}
\mathbf{if}\;b \leq -0.48:\\
\;\;\;\;1\\
\mathbf{else}:\\
\;\;\;\;0.5\\
\end{array}
\]
Alternative 13 Accuracy 40.0% Cost 64
\[0.5
\]