
(FPCore (c_p c_n t s)
:precision binary64
(let* ((t_1 (/ 1.0 (+ 1.0 (exp (- t))))) (t_2 (/ 1.0 (+ 1.0 (exp (- s))))))
(/
(* (pow t_2 c_p) (pow (- 1.0 t_2) c_n))
(* (pow t_1 c_p) (pow (- 1.0 t_1) c_n)))))
double code(double c_p, double c_n, double t, double s) {
double t_1 = 1.0 / (1.0 + exp(-t));
double t_2 = 1.0 / (1.0 + exp(-s));
return (pow(t_2, c_p) * pow((1.0 - t_2), c_n)) / (pow(t_1, c_p) * pow((1.0 - t_1), c_n));
}
real(8) function code(c_p, c_n, t, s)
real(8), intent (in) :: c_p
real(8), intent (in) :: c_n
real(8), intent (in) :: t
real(8), intent (in) :: s
real(8) :: t_1
real(8) :: t_2
t_1 = 1.0d0 / (1.0d0 + exp(-t))
t_2 = 1.0d0 / (1.0d0 + exp(-s))
code = ((t_2 ** c_p) * ((1.0d0 - t_2) ** c_n)) / ((t_1 ** c_p) * ((1.0d0 - t_1) ** c_n))
end function
public static double code(double c_p, double c_n, double t, double s) {
double t_1 = 1.0 / (1.0 + Math.exp(-t));
double t_2 = 1.0 / (1.0 + Math.exp(-s));
return (Math.pow(t_2, c_p) * Math.pow((1.0 - t_2), c_n)) / (Math.pow(t_1, c_p) * Math.pow((1.0 - t_1), c_n));
}
def code(c_p, c_n, t, s): t_1 = 1.0 / (1.0 + math.exp(-t)) t_2 = 1.0 / (1.0 + math.exp(-s)) return (math.pow(t_2, c_p) * math.pow((1.0 - t_2), c_n)) / (math.pow(t_1, c_p) * math.pow((1.0 - t_1), c_n))
function code(c_p, c_n, t, s) t_1 = Float64(1.0 / Float64(1.0 + exp(Float64(-t)))) t_2 = Float64(1.0 / Float64(1.0 + exp(Float64(-s)))) return Float64(Float64((t_2 ^ c_p) * (Float64(1.0 - t_2) ^ c_n)) / Float64((t_1 ^ c_p) * (Float64(1.0 - t_1) ^ c_n))) end
function tmp = code(c_p, c_n, t, s) t_1 = 1.0 / (1.0 + exp(-t)); t_2 = 1.0 / (1.0 + exp(-s)); tmp = ((t_2 ^ c_p) * ((1.0 - t_2) ^ c_n)) / ((t_1 ^ c_p) * ((1.0 - t_1) ^ c_n)); end
code[c$95$p_, c$95$n_, t_, s_] := Block[{t$95$1 = N[(1.0 / N[(1.0 + N[Exp[(-t)], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[(1.0 / N[(1.0 + N[Exp[(-s)], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, N[(N[(N[Power[t$95$2, c$95$p], $MachinePrecision] * N[Power[N[(1.0 - t$95$2), $MachinePrecision], c$95$n], $MachinePrecision]), $MachinePrecision] / N[(N[Power[t$95$1, c$95$p], $MachinePrecision] * N[Power[N[(1.0 - t$95$1), $MachinePrecision], c$95$n], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \frac{1}{1 + e^{-t}}\\
t_2 := \frac{1}{1 + e^{-s}}\\
\frac{{t\_2}^{c\_p} \cdot {\left(1 - t\_2\right)}^{c\_n}}{{t\_1}^{c\_p} \cdot {\left(1 - t\_1\right)}^{c\_n}}
\end{array}
\end{array}
Sampling outcomes in binary64 precision:
Herbie found 7 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (c_p c_n t s)
:precision binary64
(let* ((t_1 (/ 1.0 (+ 1.0 (exp (- t))))) (t_2 (/ 1.0 (+ 1.0 (exp (- s))))))
(/
(* (pow t_2 c_p) (pow (- 1.0 t_2) c_n))
(* (pow t_1 c_p) (pow (- 1.0 t_1) c_n)))))
double code(double c_p, double c_n, double t, double s) {
double t_1 = 1.0 / (1.0 + exp(-t));
double t_2 = 1.0 / (1.0 + exp(-s));
return (pow(t_2, c_p) * pow((1.0 - t_2), c_n)) / (pow(t_1, c_p) * pow((1.0 - t_1), c_n));
}
real(8) function code(c_p, c_n, t, s)
real(8), intent (in) :: c_p
real(8), intent (in) :: c_n
real(8), intent (in) :: t
real(8), intent (in) :: s
real(8) :: t_1
real(8) :: t_2
t_1 = 1.0d0 / (1.0d0 + exp(-t))
t_2 = 1.0d0 / (1.0d0 + exp(-s))
code = ((t_2 ** c_p) * ((1.0d0 - t_2) ** c_n)) / ((t_1 ** c_p) * ((1.0d0 - t_1) ** c_n))
end function
public static double code(double c_p, double c_n, double t, double s) {
double t_1 = 1.0 / (1.0 + Math.exp(-t));
double t_2 = 1.0 / (1.0 + Math.exp(-s));
return (Math.pow(t_2, c_p) * Math.pow((1.0 - t_2), c_n)) / (Math.pow(t_1, c_p) * Math.pow((1.0 - t_1), c_n));
}
def code(c_p, c_n, t, s): t_1 = 1.0 / (1.0 + math.exp(-t)) t_2 = 1.0 / (1.0 + math.exp(-s)) return (math.pow(t_2, c_p) * math.pow((1.0 - t_2), c_n)) / (math.pow(t_1, c_p) * math.pow((1.0 - t_1), c_n))
function code(c_p, c_n, t, s) t_1 = Float64(1.0 / Float64(1.0 + exp(Float64(-t)))) t_2 = Float64(1.0 / Float64(1.0 + exp(Float64(-s)))) return Float64(Float64((t_2 ^ c_p) * (Float64(1.0 - t_2) ^ c_n)) / Float64((t_1 ^ c_p) * (Float64(1.0 - t_1) ^ c_n))) end
function tmp = code(c_p, c_n, t, s) t_1 = 1.0 / (1.0 + exp(-t)); t_2 = 1.0 / (1.0 + exp(-s)); tmp = ((t_2 ^ c_p) * ((1.0 - t_2) ^ c_n)) / ((t_1 ^ c_p) * ((1.0 - t_1) ^ c_n)); end
code[c$95$p_, c$95$n_, t_, s_] := Block[{t$95$1 = N[(1.0 / N[(1.0 + N[Exp[(-t)], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[(1.0 / N[(1.0 + N[Exp[(-s)], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, N[(N[(N[Power[t$95$2, c$95$p], $MachinePrecision] * N[Power[N[(1.0 - t$95$2), $MachinePrecision], c$95$n], $MachinePrecision]), $MachinePrecision] / N[(N[Power[t$95$1, c$95$p], $MachinePrecision] * N[Power[N[(1.0 - t$95$1), $MachinePrecision], c$95$n], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \frac{1}{1 + e^{-t}}\\
t_2 := \frac{1}{1 + e^{-s}}\\
\frac{{t\_2}^{c\_p} \cdot {\left(1 - t\_2\right)}^{c\_n}}{{t\_1}^{c\_p} \cdot {\left(1 - t\_1\right)}^{c\_n}}
\end{array}
\end{array}
(FPCore (c_p c_n t s)
:precision binary64
(let* ((t_1 (exp (- t))) (t_2 (* c_p (log1p t_1))) (t_3 (exp (- s))))
(if (<= (- t) -5.2e-44)
(/ (pow 0.5 c_p) (- 1.0 t_2))
(if (<= (- t) 100.0)
(exp
(+
t_2
(-
(- (* c_n (log1p (/ 1.0 (- -1.0 t_3)))) (* c_p (log1p t_3)))
(* c_n (log1p (/ 1.0 (- -1.0 t_1)))))))
(pow 0.5 c_n)))))
double code(double c_p, double c_n, double t, double s) {
double t_1 = exp(-t);
double t_2 = c_p * log1p(t_1);
double t_3 = exp(-s);
double tmp;
if (-t <= -5.2e-44) {
tmp = pow(0.5, c_p) / (1.0 - t_2);
} else if (-t <= 100.0) {
tmp = exp((t_2 + (((c_n * log1p((1.0 / (-1.0 - t_3)))) - (c_p * log1p(t_3))) - (c_n * log1p((1.0 / (-1.0 - t_1)))))));
} else {
tmp = pow(0.5, c_n);
}
return tmp;
}
public static double code(double c_p, double c_n, double t, double s) {
double t_1 = Math.exp(-t);
double t_2 = c_p * Math.log1p(t_1);
double t_3 = Math.exp(-s);
double tmp;
if (-t <= -5.2e-44) {
tmp = Math.pow(0.5, c_p) / (1.0 - t_2);
} else if (-t <= 100.0) {
tmp = Math.exp((t_2 + (((c_n * Math.log1p((1.0 / (-1.0 - t_3)))) - (c_p * Math.log1p(t_3))) - (c_n * Math.log1p((1.0 / (-1.0 - t_1)))))));
} else {
tmp = Math.pow(0.5, c_n);
}
return tmp;
}
def code(c_p, c_n, t, s): t_1 = math.exp(-t) t_2 = c_p * math.log1p(t_1) t_3 = math.exp(-s) tmp = 0 if -t <= -5.2e-44: tmp = math.pow(0.5, c_p) / (1.0 - t_2) elif -t <= 100.0: tmp = math.exp((t_2 + (((c_n * math.log1p((1.0 / (-1.0 - t_3)))) - (c_p * math.log1p(t_3))) - (c_n * math.log1p((1.0 / (-1.0 - t_1))))))) else: tmp = math.pow(0.5, c_n) return tmp
function code(c_p, c_n, t, s) t_1 = exp(Float64(-t)) t_2 = Float64(c_p * log1p(t_1)) t_3 = exp(Float64(-s)) tmp = 0.0 if (Float64(-t) <= -5.2e-44) tmp = Float64((0.5 ^ c_p) / Float64(1.0 - t_2)); elseif (Float64(-t) <= 100.0) tmp = exp(Float64(t_2 + Float64(Float64(Float64(c_n * log1p(Float64(1.0 / Float64(-1.0 - t_3)))) - Float64(c_p * log1p(t_3))) - Float64(c_n * log1p(Float64(1.0 / Float64(-1.0 - t_1))))))); else tmp = 0.5 ^ c_n; end return tmp end
code[c$95$p_, c$95$n_, t_, s_] := Block[{t$95$1 = N[Exp[(-t)], $MachinePrecision]}, Block[{t$95$2 = N[(c$95$p * N[Log[1 + t$95$1], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$3 = N[Exp[(-s)], $MachinePrecision]}, If[LessEqual[(-t), -5.2e-44], N[(N[Power[0.5, c$95$p], $MachinePrecision] / N[(1.0 - t$95$2), $MachinePrecision]), $MachinePrecision], If[LessEqual[(-t), 100.0], N[Exp[N[(t$95$2 + N[(N[(N[(c$95$n * N[Log[1 + N[(1.0 / N[(-1.0 - t$95$3), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] - N[(c$95$p * N[Log[1 + t$95$3], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] - N[(c$95$n * N[Log[1 + N[(1.0 / N[(-1.0 - t$95$1), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], N[Power[0.5, c$95$n], $MachinePrecision]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := e^{-t}\\
t_2 := c\_p \cdot \mathsf{log1p}\left(t\_1\right)\\
t_3 := e^{-s}\\
\mathbf{if}\;-t \leq -5.2 \cdot 10^{-44}:\\
\;\;\;\;\frac{{0.5}^{c\_p}}{1 - t\_2}\\
\mathbf{elif}\;-t \leq 100:\\
\;\;\;\;e^{t\_2 + \left(\left(c\_n \cdot \mathsf{log1p}\left(\frac{1}{-1 - t\_3}\right) - c\_p \cdot \mathsf{log1p}\left(t\_3\right)\right) - c\_n \cdot \mathsf{log1p}\left(\frac{1}{-1 - t\_1}\right)\right)}\\
\mathbf{else}:\\
\;\;\;\;{0.5}^{c\_n}\\
\end{array}
\end{array}
if (neg.f64 t) < -5.1999999999999996e-44Initial program 77.7%
associate-/l*77.7%
Simplified77.7%
Taylor expanded in c_n around 0 95.6%
Taylor expanded in c_p around 0 95.6%
log-rec95.6%
log1p-undefine95.6%
distribute-rgt-neg-out95.6%
unsub-neg95.6%
Simplified95.6%
Taylor expanded in s around 0 100.0%
if -5.1999999999999996e-44 < (neg.f64 t) < 100Initial program 91.9%
associate-/l/91.9%
Simplified91.9%
add-exp-log91.9%
log-div91.9%
Applied egg-rr99.4%
if 100 < (neg.f64 t) Initial program 1.3%
associate-/l*1.3%
Simplified1.3%
Taylor expanded in c_p around 0 100.0%
Taylor expanded in s around 0 100.0%
Taylor expanded in t around 0 50.0%
Taylor expanded in t around inf 100.0%
Final simplification99.5%
(FPCore (c_p c_n t s) :precision binary64 (if (<= t -0.84) (/ (pow 0.5 c_n) (pow (+ 1.0 (/ 1.0 (- -1.0 (exp (- t))))) c_n)) (pow (/ (/ 1.0 (+ 1.0 (exp (- s)))) 0.5) c_p)))
double code(double c_p, double c_n, double t, double s) {
double tmp;
if (t <= -0.84) {
tmp = pow(0.5, c_n) / pow((1.0 + (1.0 / (-1.0 - exp(-t)))), c_n);
} else {
tmp = pow(((1.0 / (1.0 + exp(-s))) / 0.5), c_p);
}
return tmp;
}
real(8) function code(c_p, c_n, t, s)
real(8), intent (in) :: c_p
real(8), intent (in) :: c_n
real(8), intent (in) :: t
real(8), intent (in) :: s
real(8) :: tmp
if (t <= (-0.84d0)) then
tmp = (0.5d0 ** c_n) / ((1.0d0 + (1.0d0 / ((-1.0d0) - exp(-t)))) ** c_n)
else
tmp = ((1.0d0 / (1.0d0 + exp(-s))) / 0.5d0) ** c_p
end if
code = tmp
end function
public static double code(double c_p, double c_n, double t, double s) {
double tmp;
if (t <= -0.84) {
tmp = Math.pow(0.5, c_n) / Math.pow((1.0 + (1.0 / (-1.0 - Math.exp(-t)))), c_n);
} else {
tmp = Math.pow(((1.0 / (1.0 + Math.exp(-s))) / 0.5), c_p);
}
return tmp;
}
def code(c_p, c_n, t, s): tmp = 0 if t <= -0.84: tmp = math.pow(0.5, c_n) / math.pow((1.0 + (1.0 / (-1.0 - math.exp(-t)))), c_n) else: tmp = math.pow(((1.0 / (1.0 + math.exp(-s))) / 0.5), c_p) return tmp
function code(c_p, c_n, t, s) tmp = 0.0 if (t <= -0.84) tmp = Float64((0.5 ^ c_n) / (Float64(1.0 + Float64(1.0 / Float64(-1.0 - exp(Float64(-t))))) ^ c_n)); else tmp = Float64(Float64(1.0 / Float64(1.0 + exp(Float64(-s)))) / 0.5) ^ c_p; end return tmp end
function tmp_2 = code(c_p, c_n, t, s) tmp = 0.0; if (t <= -0.84) tmp = (0.5 ^ c_n) / ((1.0 + (1.0 / (-1.0 - exp(-t)))) ^ c_n); else tmp = ((1.0 / (1.0 + exp(-s))) / 0.5) ^ c_p; end tmp_2 = tmp; end
code[c$95$p_, c$95$n_, t_, s_] := If[LessEqual[t, -0.84], N[(N[Power[0.5, c$95$n], $MachinePrecision] / N[Power[N[(1.0 + N[(1.0 / N[(-1.0 - N[Exp[(-t)], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], c$95$n], $MachinePrecision]), $MachinePrecision], N[Power[N[(N[(1.0 / N[(1.0 + N[Exp[(-s)], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / 0.5), $MachinePrecision], c$95$p], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;t \leq -0.84:\\
\;\;\;\;\frac{{0.5}^{c\_n}}{{\left(1 + \frac{1}{-1 - e^{-t}}\right)}^{c\_n}}\\
\mathbf{else}:\\
\;\;\;\;{\left(\frac{\frac{1}{1 + e^{-s}}}{0.5}\right)}^{c\_p}\\
\end{array}
\end{array}
if t < -0.839999999999999969Initial program 37.7%
associate-/l*37.7%
Simplified37.7%
Taylor expanded in c_p around 0 92.8%
Taylor expanded in s around 0 92.8%
if -0.839999999999999969 < t Initial program 90.3%
associate-/l*90.3%
Simplified90.3%
Taylor expanded in c_n around 0 94.4%
Taylor expanded in t around 0 93.5%
Taylor expanded in s around -inf 93.5%
neg-mul-193.5%
exp-to-pow93.5%
*-commutative93.5%
log-rec93.5%
log1p-undefine93.5%
exp-to-pow93.5%
*-commutative93.5%
div-exp97.4%
log1p-undefine97.4%
log-rec97.4%
Simplified97.4%
Final simplification97.0%
(FPCore (c_p c_n t s) :precision binary64 (if (<= t -0.5) (/ (pow 0.5 c_n) (pow (+ 0.5 (* t -0.25)) c_n)) (pow (/ (/ 1.0 (+ 1.0 (exp (- s)))) 0.5) c_p)))
double code(double c_p, double c_n, double t, double s) {
double tmp;
if (t <= -0.5) {
tmp = pow(0.5, c_n) / pow((0.5 + (t * -0.25)), c_n);
} else {
tmp = pow(((1.0 / (1.0 + exp(-s))) / 0.5), c_p);
}
return tmp;
}
real(8) function code(c_p, c_n, t, s)
real(8), intent (in) :: c_p
real(8), intent (in) :: c_n
real(8), intent (in) :: t
real(8), intent (in) :: s
real(8) :: tmp
if (t <= (-0.5d0)) then
tmp = (0.5d0 ** c_n) / ((0.5d0 + (t * (-0.25d0))) ** c_n)
else
tmp = ((1.0d0 / (1.0d0 + exp(-s))) / 0.5d0) ** c_p
end if
code = tmp
end function
public static double code(double c_p, double c_n, double t, double s) {
double tmp;
if (t <= -0.5) {
tmp = Math.pow(0.5, c_n) / Math.pow((0.5 + (t * -0.25)), c_n);
} else {
tmp = Math.pow(((1.0 / (1.0 + Math.exp(-s))) / 0.5), c_p);
}
return tmp;
}
def code(c_p, c_n, t, s): tmp = 0 if t <= -0.5: tmp = math.pow(0.5, c_n) / math.pow((0.5 + (t * -0.25)), c_n) else: tmp = math.pow(((1.0 / (1.0 + math.exp(-s))) / 0.5), c_p) return tmp
function code(c_p, c_n, t, s) tmp = 0.0 if (t <= -0.5) tmp = Float64((0.5 ^ c_n) / (Float64(0.5 + Float64(t * -0.25)) ^ c_n)); else tmp = Float64(Float64(1.0 / Float64(1.0 + exp(Float64(-s)))) / 0.5) ^ c_p; end return tmp end
function tmp_2 = code(c_p, c_n, t, s) tmp = 0.0; if (t <= -0.5) tmp = (0.5 ^ c_n) / ((0.5 + (t * -0.25)) ^ c_n); else tmp = ((1.0 / (1.0 + exp(-s))) / 0.5) ^ c_p; end tmp_2 = tmp; end
code[c$95$p_, c$95$n_, t_, s_] := If[LessEqual[t, -0.5], N[(N[Power[0.5, c$95$n], $MachinePrecision] / N[Power[N[(0.5 + N[(t * -0.25), $MachinePrecision]), $MachinePrecision], c$95$n], $MachinePrecision]), $MachinePrecision], N[Power[N[(N[(1.0 / N[(1.0 + N[Exp[(-s)], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / 0.5), $MachinePrecision], c$95$p], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;t \leq -0.5:\\
\;\;\;\;\frac{{0.5}^{c\_n}}{{\left(0.5 + t \cdot -0.25\right)}^{c\_n}}\\
\mathbf{else}:\\
\;\;\;\;{\left(\frac{\frac{1}{1 + e^{-s}}}{0.5}\right)}^{c\_p}\\
\end{array}
\end{array}
if t < -0.5Initial program 37.7%
associate-/l*37.7%
Simplified37.7%
Taylor expanded in c_p around 0 92.8%
Taylor expanded in s around 0 92.8%
Taylor expanded in t around 0 90.6%
*-commutative90.6%
Simplified90.6%
if -0.5 < t Initial program 90.3%
associate-/l*90.3%
Simplified90.3%
Taylor expanded in c_n around 0 94.4%
Taylor expanded in t around 0 93.5%
Taylor expanded in s around -inf 93.5%
neg-mul-193.5%
exp-to-pow93.5%
*-commutative93.5%
log-rec93.5%
log1p-undefine93.5%
exp-to-pow93.5%
*-commutative93.5%
div-exp97.4%
log1p-undefine97.4%
log-rec97.4%
Simplified97.4%
(FPCore (c_p c_n t s)
:precision binary64
(if (<= t -2e-82)
(pow 0.5 c_n)
(+
1.0
(* s (+ (* 0.5 c_p) (* s (+ (* c_p -0.125) (* 0.125 (pow c_p 2.0)))))))))
double code(double c_p, double c_n, double t, double s) {
double tmp;
if (t <= -2e-82) {
tmp = pow(0.5, c_n);
} else {
tmp = 1.0 + (s * ((0.5 * c_p) + (s * ((c_p * -0.125) + (0.125 * pow(c_p, 2.0))))));
}
return tmp;
}
real(8) function code(c_p, c_n, t, s)
real(8), intent (in) :: c_p
real(8), intent (in) :: c_n
real(8), intent (in) :: t
real(8), intent (in) :: s
real(8) :: tmp
if (t <= (-2d-82)) then
tmp = 0.5d0 ** c_n
else
tmp = 1.0d0 + (s * ((0.5d0 * c_p) + (s * ((c_p * (-0.125d0)) + (0.125d0 * (c_p ** 2.0d0))))))
end if
code = tmp
end function
public static double code(double c_p, double c_n, double t, double s) {
double tmp;
if (t <= -2e-82) {
tmp = Math.pow(0.5, c_n);
} else {
tmp = 1.0 + (s * ((0.5 * c_p) + (s * ((c_p * -0.125) + (0.125 * Math.pow(c_p, 2.0))))));
}
return tmp;
}
def code(c_p, c_n, t, s): tmp = 0 if t <= -2e-82: tmp = math.pow(0.5, c_n) else: tmp = 1.0 + (s * ((0.5 * c_p) + (s * ((c_p * -0.125) + (0.125 * math.pow(c_p, 2.0)))))) return tmp
function code(c_p, c_n, t, s) tmp = 0.0 if (t <= -2e-82) tmp = 0.5 ^ c_n; else tmp = Float64(1.0 + Float64(s * Float64(Float64(0.5 * c_p) + Float64(s * Float64(Float64(c_p * -0.125) + Float64(0.125 * (c_p ^ 2.0))))))); end return tmp end
function tmp_2 = code(c_p, c_n, t, s) tmp = 0.0; if (t <= -2e-82) tmp = 0.5 ^ c_n; else tmp = 1.0 + (s * ((0.5 * c_p) + (s * ((c_p * -0.125) + (0.125 * (c_p ^ 2.0)))))); end tmp_2 = tmp; end
code[c$95$p_, c$95$n_, t_, s_] := If[LessEqual[t, -2e-82], N[Power[0.5, c$95$n], $MachinePrecision], N[(1.0 + N[(s * N[(N[(0.5 * c$95$p), $MachinePrecision] + N[(s * N[(N[(c$95$p * -0.125), $MachinePrecision] + N[(0.125 * N[Power[c$95$p, 2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;t \leq -2 \cdot 10^{-82}:\\
\;\;\;\;{0.5}^{c\_n}\\
\mathbf{else}:\\
\;\;\;\;1 + s \cdot \left(0.5 \cdot c\_p + s \cdot \left(c\_p \cdot -0.125 + 0.125 \cdot {c\_p}^{2}\right)\right)\\
\end{array}
\end{array}
if t < -2e-82Initial program 70.5%
associate-/l*70.5%
Simplified70.5%
Taylor expanded in c_p around 0 86.7%
Taylor expanded in s around 0 86.7%
Taylor expanded in t around 0 73.2%
Taylor expanded in t around inf 86.7%
if -2e-82 < t Initial program 90.0%
associate-/l*90.0%
Simplified90.0%
Taylor expanded in c_n around 0 94.6%
Taylor expanded in t around 0 93.6%
Taylor expanded in s around 0 95.0%
Final simplification93.5%
(FPCore (c_p c_n t s) :precision binary64 (if (<= t -2.8e-82) (pow 0.5 c_n) (+ 1.0 (* s (* 0.5 c_p)))))
double code(double c_p, double c_n, double t, double s) {
double tmp;
if (t <= -2.8e-82) {
tmp = pow(0.5, c_n);
} else {
tmp = 1.0 + (s * (0.5 * c_p));
}
return tmp;
}
real(8) function code(c_p, c_n, t, s)
real(8), intent (in) :: c_p
real(8), intent (in) :: c_n
real(8), intent (in) :: t
real(8), intent (in) :: s
real(8) :: tmp
if (t <= (-2.8d-82)) then
tmp = 0.5d0 ** c_n
else
tmp = 1.0d0 + (s * (0.5d0 * c_p))
end if
code = tmp
end function
public static double code(double c_p, double c_n, double t, double s) {
double tmp;
if (t <= -2.8e-82) {
tmp = Math.pow(0.5, c_n);
} else {
tmp = 1.0 + (s * (0.5 * c_p));
}
return tmp;
}
def code(c_p, c_n, t, s): tmp = 0 if t <= -2.8e-82: tmp = math.pow(0.5, c_n) else: tmp = 1.0 + (s * (0.5 * c_p)) return tmp
function code(c_p, c_n, t, s) tmp = 0.0 if (t <= -2.8e-82) tmp = 0.5 ^ c_n; else tmp = Float64(1.0 + Float64(s * Float64(0.5 * c_p))); end return tmp end
function tmp_2 = code(c_p, c_n, t, s) tmp = 0.0; if (t <= -2.8e-82) tmp = 0.5 ^ c_n; else tmp = 1.0 + (s * (0.5 * c_p)); end tmp_2 = tmp; end
code[c$95$p_, c$95$n_, t_, s_] := If[LessEqual[t, -2.8e-82], N[Power[0.5, c$95$n], $MachinePrecision], N[(1.0 + N[(s * N[(0.5 * c$95$p), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;t \leq -2.8 \cdot 10^{-82}:\\
\;\;\;\;{0.5}^{c\_n}\\
\mathbf{else}:\\
\;\;\;\;1 + s \cdot \left(0.5 \cdot c\_p\right)\\
\end{array}
\end{array}
if t < -2.80000000000000024e-82Initial program 70.5%
associate-/l*70.5%
Simplified70.5%
Taylor expanded in c_p around 0 86.7%
Taylor expanded in s around 0 86.7%
Taylor expanded in t around 0 73.2%
Taylor expanded in t around inf 86.7%
if -2.80000000000000024e-82 < t Initial program 90.0%
associate-/l*90.0%
Simplified90.0%
Taylor expanded in c_n around 0 94.6%
Taylor expanded in t around 0 93.6%
Taylor expanded in s around 0 94.9%
associate-*r*94.9%
Simplified94.9%
Final simplification93.4%
(FPCore (c_p c_n t s) :precision binary64 (+ 1.0 (* s (* 0.5 c_p))))
double code(double c_p, double c_n, double t, double s) {
return 1.0 + (s * (0.5 * c_p));
}
real(8) function code(c_p, c_n, t, s)
real(8), intent (in) :: c_p
real(8), intent (in) :: c_n
real(8), intent (in) :: t
real(8), intent (in) :: s
code = 1.0d0 + (s * (0.5d0 * c_p))
end function
public static double code(double c_p, double c_n, double t, double s) {
return 1.0 + (s * (0.5 * c_p));
}
def code(c_p, c_n, t, s): return 1.0 + (s * (0.5 * c_p))
function code(c_p, c_n, t, s) return Float64(1.0 + Float64(s * Float64(0.5 * c_p))) end
function tmp = code(c_p, c_n, t, s) tmp = 1.0 + (s * (0.5 * c_p)); end
code[c$95$p_, c$95$n_, t_, s_] := N[(1.0 + N[(s * N[(0.5 * c$95$p), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
1 + s \cdot \left(0.5 \cdot c\_p\right)
\end{array}
Initial program 86.4%
associate-/l*86.4%
Simplified86.4%
Taylor expanded in c_n around 0 89.8%
Taylor expanded in t around 0 90.6%
Taylor expanded in s around 0 90.6%
associate-*r*90.6%
Simplified90.6%
Final simplification90.6%
(FPCore (c_p c_n t s) :precision binary64 1.0)
double code(double c_p, double c_n, double t, double s) {
return 1.0;
}
real(8) function code(c_p, c_n, t, s)
real(8), intent (in) :: c_p
real(8), intent (in) :: c_n
real(8), intent (in) :: t
real(8), intent (in) :: s
code = 1.0d0
end function
public static double code(double c_p, double c_n, double t, double s) {
return 1.0;
}
def code(c_p, c_n, t, s): return 1.0
function code(c_p, c_n, t, s) return 1.0 end
function tmp = code(c_p, c_n, t, s) tmp = 1.0; end
code[c$95$p_, c$95$n_, t_, s_] := 1.0
\begin{array}{l}
\\
1
\end{array}
Initial program 86.4%
associate-/l*86.4%
Simplified86.4%
Taylor expanded in c_p around 0 90.0%
Taylor expanded in s around 0 90.4%
Taylor expanded in c_n around 0 90.5%
(FPCore (c_p c_n t s) :precision binary64 (* (pow (/ (+ 1.0 (exp (- t))) (+ 1.0 (exp (- s)))) c_p) (pow (/ (+ 1.0 (exp t)) (+ 1.0 (exp s))) c_n)))
double code(double c_p, double c_n, double t, double s) {
return pow(((1.0 + exp(-t)) / (1.0 + exp(-s))), c_p) * pow(((1.0 + exp(t)) / (1.0 + exp(s))), c_n);
}
real(8) function code(c_p, c_n, t, s)
real(8), intent (in) :: c_p
real(8), intent (in) :: c_n
real(8), intent (in) :: t
real(8), intent (in) :: s
code = (((1.0d0 + exp(-t)) / (1.0d0 + exp(-s))) ** c_p) * (((1.0d0 + exp(t)) / (1.0d0 + exp(s))) ** c_n)
end function
public static double code(double c_p, double c_n, double t, double s) {
return Math.pow(((1.0 + Math.exp(-t)) / (1.0 + Math.exp(-s))), c_p) * Math.pow(((1.0 + Math.exp(t)) / (1.0 + Math.exp(s))), c_n);
}
def code(c_p, c_n, t, s): return math.pow(((1.0 + math.exp(-t)) / (1.0 + math.exp(-s))), c_p) * math.pow(((1.0 + math.exp(t)) / (1.0 + math.exp(s))), c_n)
function code(c_p, c_n, t, s) return Float64((Float64(Float64(1.0 + exp(Float64(-t))) / Float64(1.0 + exp(Float64(-s)))) ^ c_p) * (Float64(Float64(1.0 + exp(t)) / Float64(1.0 + exp(s))) ^ c_n)) end
function tmp = code(c_p, c_n, t, s) tmp = (((1.0 + exp(-t)) / (1.0 + exp(-s))) ^ c_p) * (((1.0 + exp(t)) / (1.0 + exp(s))) ^ c_n); end
code[c$95$p_, c$95$n_, t_, s_] := N[(N[Power[N[(N[(1.0 + N[Exp[(-t)], $MachinePrecision]), $MachinePrecision] / N[(1.0 + N[Exp[(-s)], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], c$95$p], $MachinePrecision] * N[Power[N[(N[(1.0 + N[Exp[t], $MachinePrecision]), $MachinePrecision] / N[(1.0 + N[Exp[s], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], c$95$n], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
{\left(\frac{1 + e^{-t}}{1 + e^{-s}}\right)}^{c\_p} \cdot {\left(\frac{1 + e^{t}}{1 + e^{s}}\right)}^{c\_n}
\end{array}
herbie shell --seed 2024151
(FPCore (c_p c_n t s)
:name "Harley's example"
:precision binary64
:pre (and (< 0.0 c_p) (< 0.0 c_n))
:alt
(! :herbie-platform default (* (pow (/ (+ 1 (exp (- t))) (+ 1 (exp (- s)))) c_p) (pow (/ (+ 1 (exp t)) (+ 1 (exp s))) c_n)))
(/ (* (pow (/ 1.0 (+ 1.0 (exp (- s)))) c_p) (pow (- 1.0 (/ 1.0 (+ 1.0 (exp (- s))))) c_n)) (* (pow (/ 1.0 (+ 1.0 (exp (- t)))) c_p) (pow (- 1.0 (/ 1.0 (+ 1.0 (exp (- t))))) c_n))))