
(FPCore (w l) :precision binary64 (* (exp (- w)) (pow l (exp w))))
double code(double w, double l) {
return exp(-w) * pow(l, exp(w));
}
real(8) function code(w, l)
real(8), intent (in) :: w
real(8), intent (in) :: l
code = exp(-w) * (l ** exp(w))
end function
public static double code(double w, double l) {
return Math.exp(-w) * Math.pow(l, Math.exp(w));
}
def code(w, l): return math.exp(-w) * math.pow(l, math.exp(w))
function code(w, l) return Float64(exp(Float64(-w)) * (l ^ exp(w))) end
function tmp = code(w, l) tmp = exp(-w) * (l ^ exp(w)); end
code[w_, l_] := N[(N[Exp[(-w)], $MachinePrecision] * N[Power[l, N[Exp[w], $MachinePrecision]], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
e^{-w} \cdot {\ell}^{\left(e^{w}\right)}
\end{array}
Sampling outcomes in binary64 precision:
Herbie found 7 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (w l) :precision binary64 (* (exp (- w)) (pow l (exp w))))
double code(double w, double l) {
return exp(-w) * pow(l, exp(w));
}
real(8) function code(w, l)
real(8), intent (in) :: w
real(8), intent (in) :: l
code = exp(-w) * (l ** exp(w))
end function
public static double code(double w, double l) {
return Math.exp(-w) * Math.pow(l, Math.exp(w));
}
def code(w, l): return math.exp(-w) * math.pow(l, math.exp(w))
function code(w, l) return Float64(exp(Float64(-w)) * (l ^ exp(w))) end
function tmp = code(w, l) tmp = exp(-w) * (l ^ exp(w)); end
code[w_, l_] := N[(N[Exp[(-w)], $MachinePrecision] * N[Power[l, N[Exp[w], $MachinePrecision]], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
e^{-w} \cdot {\ell}^{\left(e^{w}\right)}
\end{array}
(FPCore (w l) :precision binary64 (/ (pow (pow l (sqrt (exp w))) (exp (* w 0.5))) (exp w)))
double code(double w, double l) {
return pow(pow(l, sqrt(exp(w))), exp((w * 0.5))) / exp(w);
}
real(8) function code(w, l)
real(8), intent (in) :: w
real(8), intent (in) :: l
code = ((l ** sqrt(exp(w))) ** exp((w * 0.5d0))) / exp(w)
end function
public static double code(double w, double l) {
return Math.pow(Math.pow(l, Math.sqrt(Math.exp(w))), Math.exp((w * 0.5))) / Math.exp(w);
}
def code(w, l): return math.pow(math.pow(l, math.sqrt(math.exp(w))), math.exp((w * 0.5))) / math.exp(w)
function code(w, l) return Float64(((l ^ sqrt(exp(w))) ^ exp(Float64(w * 0.5))) / exp(w)) end
function tmp = code(w, l) tmp = ((l ^ sqrt(exp(w))) ^ exp((w * 0.5))) / exp(w); end
code[w_, l_] := N[(N[Power[N[Power[l, N[Sqrt[N[Exp[w], $MachinePrecision]], $MachinePrecision]], $MachinePrecision], N[Exp[N[(w * 0.5), $MachinePrecision]], $MachinePrecision]], $MachinePrecision] / N[Exp[w], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\frac{{\left({\ell}^{\left(\sqrt{e^{w}}\right)}\right)}^{\left(e^{w \cdot 0.5}\right)}}{e^{w}}
\end{array}
Initial program 98.5%
exp-neg98.5%
associate-*l/98.5%
*-lft-identity98.5%
Simplified98.5%
add-exp-log94.6%
log-pow94.6%
Applied egg-rr94.6%
*-commutative94.6%
pow-to-exp98.5%
add-sqr-sqrt98.4%
pow-unpow98.4%
Applied egg-rr98.4%
pow1/298.4%
pow-exp98.5%
Applied egg-rr98.5%
Final simplification98.5%
(FPCore (w l) :precision binary64 (/ (pow l (exp w)) (exp w)))
double code(double w, double l) {
return pow(l, exp(w)) / exp(w);
}
real(8) function code(w, l)
real(8), intent (in) :: w
real(8), intent (in) :: l
code = (l ** exp(w)) / exp(w)
end function
public static double code(double w, double l) {
return Math.pow(l, Math.exp(w)) / Math.exp(w);
}
def code(w, l): return math.pow(l, math.exp(w)) / math.exp(w)
function code(w, l) return Float64((l ^ exp(w)) / exp(w)) end
function tmp = code(w, l) tmp = (l ^ exp(w)) / exp(w); end
code[w_, l_] := N[(N[Power[l, N[Exp[w], $MachinePrecision]], $MachinePrecision] / N[Exp[w], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\frac{{\ell}^{\left(e^{w}\right)}}{e^{w}}
\end{array}
Initial program 98.5%
exp-neg98.5%
associate-*l/98.5%
*-lft-identity98.5%
Simplified98.5%
Final simplification98.5%
(FPCore (w l) :precision binary64 (if (or (<= w -0.7) (not (<= w 440000000.0))) (exp (- w)) (- l (+ (* l w) (* (* w w) (* l -0.5))))))
double code(double w, double l) {
double tmp;
if ((w <= -0.7) || !(w <= 440000000.0)) {
tmp = exp(-w);
} else {
tmp = l - ((l * w) + ((w * w) * (l * -0.5)));
}
return tmp;
}
real(8) function code(w, l)
real(8), intent (in) :: w
real(8), intent (in) :: l
real(8) :: tmp
if ((w <= (-0.7d0)) .or. (.not. (w <= 440000000.0d0))) then
tmp = exp(-w)
else
tmp = l - ((l * w) + ((w * w) * (l * (-0.5d0))))
end if
code = tmp
end function
public static double code(double w, double l) {
double tmp;
if ((w <= -0.7) || !(w <= 440000000.0)) {
tmp = Math.exp(-w);
} else {
tmp = l - ((l * w) + ((w * w) * (l * -0.5)));
}
return tmp;
}
def code(w, l): tmp = 0 if (w <= -0.7) or not (w <= 440000000.0): tmp = math.exp(-w) else: tmp = l - ((l * w) + ((w * w) * (l * -0.5))) return tmp
function code(w, l) tmp = 0.0 if ((w <= -0.7) || !(w <= 440000000.0)) tmp = exp(Float64(-w)); else tmp = Float64(l - Float64(Float64(l * w) + Float64(Float64(w * w) * Float64(l * -0.5)))); end return tmp end
function tmp_2 = code(w, l) tmp = 0.0; if ((w <= -0.7) || ~((w <= 440000000.0))) tmp = exp(-w); else tmp = l - ((l * w) + ((w * w) * (l * -0.5))); end tmp_2 = tmp; end
code[w_, l_] := If[Or[LessEqual[w, -0.7], N[Not[LessEqual[w, 440000000.0]], $MachinePrecision]], N[Exp[(-w)], $MachinePrecision], N[(l - N[(N[(l * w), $MachinePrecision] + N[(N[(w * w), $MachinePrecision] * N[(l * -0.5), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;w \leq -0.7 \lor \neg \left(w \leq 440000000\right):\\
\;\;\;\;e^{-w}\\
\mathbf{else}:\\
\;\;\;\;\ell - \left(\ell \cdot w + \left(w \cdot w\right) \cdot \left(\ell \cdot -0.5\right)\right)\\
\end{array}
\end{array}
if w < -0.69999999999999996 or 4.4e8 < w Initial program 100.0%
exp-neg100.0%
associate-*l/100.0%
*-lft-identity100.0%
Simplified100.0%
add-exp-log100.0%
log-pow100.0%
Applied egg-rr100.0%
*-commutative100.0%
pow-to-exp100.0%
add-sqr-sqrt100.0%
pow-unpow100.0%
Applied egg-rr100.0%
add-exp-log100.0%
log-div100.0%
pow-pow100.0%
add-sqr-sqrt100.0%
log-pow100.0%
add-log-exp100.0%
Applied egg-rr100.0%
Taylor expanded in w around inf 100.0%
neg-mul-1100.0%
Simplified100.0%
if -0.69999999999999996 < w < 4.4e8Initial program 96.9%
exp-neg96.9%
associate-*l/96.9%
*-lft-identity96.9%
Simplified96.9%
add-exp-log89.2%
log-pow89.2%
Applied egg-rr89.2%
*-commutative89.2%
pow-to-exp96.9%
add-sqr-sqrt96.9%
pow-unpow96.9%
Applied egg-rr96.9%
Taylor expanded in w around 0 94.4%
Taylor expanded in w around 0 94.5%
distribute-lft-out94.5%
unpow294.5%
distribute-rgt-out94.5%
metadata-eval94.5%
Simplified94.5%
Final simplification97.3%
(FPCore (w l) :precision binary64 (/ l (exp w)))
double code(double w, double l) {
return l / exp(w);
}
real(8) function code(w, l)
real(8), intent (in) :: w
real(8), intent (in) :: l
code = l / exp(w)
end function
public static double code(double w, double l) {
return l / Math.exp(w);
}
def code(w, l): return l / math.exp(w)
function code(w, l) return Float64(l / exp(w)) end
function tmp = code(w, l) tmp = l / exp(w); end
code[w_, l_] := N[(l / N[Exp[w], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\frac{\ell}{e^{w}}
\end{array}
Initial program 98.5%
exp-neg98.5%
associate-*l/98.5%
*-lft-identity98.5%
Simplified98.5%
add-exp-log94.6%
log-pow94.6%
Applied egg-rr94.6%
*-commutative94.6%
pow-to-exp98.5%
add-sqr-sqrt98.4%
pow-unpow98.4%
Applied egg-rr98.4%
Taylor expanded in w around 0 97.2%
Final simplification97.2%
(FPCore (w l) :precision binary64 (- l (+ (* l w) (* (* w w) (* l -0.5)))))
double code(double w, double l) {
return l - ((l * w) + ((w * w) * (l * -0.5)));
}
real(8) function code(w, l)
real(8), intent (in) :: w
real(8), intent (in) :: l
code = l - ((l * w) + ((w * w) * (l * (-0.5d0))))
end function
public static double code(double w, double l) {
return l - ((l * w) + ((w * w) * (l * -0.5)));
}
def code(w, l): return l - ((l * w) + ((w * w) * (l * -0.5)))
function code(w, l) return Float64(l - Float64(Float64(l * w) + Float64(Float64(w * w) * Float64(l * -0.5)))) end
function tmp = code(w, l) tmp = l - ((l * w) + ((w * w) * (l * -0.5))); end
code[w_, l_] := N[(l - N[(N[(l * w), $MachinePrecision] + N[(N[(w * w), $MachinePrecision] * N[(l * -0.5), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\ell - \left(\ell \cdot w + \left(w \cdot w\right) \cdot \left(\ell \cdot -0.5\right)\right)
\end{array}
Initial program 98.5%
exp-neg98.5%
associate-*l/98.5%
*-lft-identity98.5%
Simplified98.5%
add-exp-log94.6%
log-pow94.6%
Applied egg-rr94.6%
*-commutative94.6%
pow-to-exp98.5%
add-sqr-sqrt98.4%
pow-unpow98.4%
Applied egg-rr98.4%
Taylor expanded in w around 0 97.2%
Taylor expanded in w around 0 68.5%
distribute-lft-out68.5%
unpow268.5%
distribute-rgt-out68.5%
metadata-eval68.5%
Simplified68.5%
Final simplification68.5%
(FPCore (w l) :precision binary64 (- l (* l w)))
double code(double w, double l) {
return l - (l * w);
}
real(8) function code(w, l)
real(8), intent (in) :: w
real(8), intent (in) :: l
code = l - (l * w)
end function
public static double code(double w, double l) {
return l - (l * w);
}
def code(w, l): return l - (l * w)
function code(w, l) return Float64(l - Float64(l * w)) end
function tmp = code(w, l) tmp = l - (l * w); end
code[w_, l_] := N[(l - N[(l * w), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\ell - \ell \cdot w
\end{array}
Initial program 98.5%
exp-neg98.5%
associate-*l/98.5%
*-lft-identity98.5%
Simplified98.5%
add-exp-log94.6%
log-pow94.6%
Applied egg-rr94.6%
*-commutative94.6%
pow-to-exp98.5%
add-sqr-sqrt98.4%
pow-unpow98.4%
Applied egg-rr98.4%
Taylor expanded in w around 0 97.2%
Taylor expanded in w around 0 59.2%
mul-1-neg59.2%
unsub-neg59.2%
Simplified59.2%
Final simplification59.2%
(FPCore (w l) :precision binary64 l)
double code(double w, double l) {
return l;
}
real(8) function code(w, l)
real(8), intent (in) :: w
real(8), intent (in) :: l
code = l
end function
public static double code(double w, double l) {
return l;
}
def code(w, l): return l
function code(w, l) return l end
function tmp = code(w, l) tmp = l; end
code[w_, l_] := l
\begin{array}{l}
\\
\ell
\end{array}
Initial program 98.5%
Taylor expanded in w around 0 49.5%
Final simplification49.5%
herbie shell --seed 2023297
(FPCore (w l)
:name "exp-w (used to crash)"
:precision binary64
(* (exp (- w)) (pow l (exp w))))