(FPCore (w l) :precision binary64 (* (exp (- w)) (pow l (exp w))))
(FPCore (w l) :precision binary64 (let* ((t_0 (sqrt (exp w)))) (* (/ 1.0 t_0) (/ (pow l (exp w)) t_0))))
double code(double w, double l) {
return exp(-w) * pow(l, exp(w));
}
double code(double w, double l) {
double t_0 = sqrt(exp(w));
return (1.0 / t_0) * (pow(l, exp(w)) / t_0);
}
real(8) function code(w, l)
real(8), intent (in) :: w
real(8), intent (in) :: l
code = exp(-w) * (l ** exp(w))
end function
real(8) function code(w, l)
real(8), intent (in) :: w
real(8), intent (in) :: l
real(8) :: t_0
t_0 = sqrt(exp(w))
code = (1.0d0 / t_0) * ((l ** exp(w)) / t_0)
end function
public static double code(double w, double l) {
return Math.exp(-w) * Math.pow(l, Math.exp(w));
}
public static double code(double w, double l) {
double t_0 = Math.sqrt(Math.exp(w));
return (1.0 / t_0) * (Math.pow(l, Math.exp(w)) / t_0);
}
def code(w, l): return math.exp(-w) * math.pow(l, math.exp(w))
def code(w, l): t_0 = math.sqrt(math.exp(w)) return (1.0 / t_0) * (math.pow(l, math.exp(w)) / t_0)
function code(w, l) return Float64(exp(Float64(-w)) * (l ^ exp(w))) end
function code(w, l) t_0 = sqrt(exp(w)) return Float64(Float64(1.0 / t_0) * Float64((l ^ exp(w)) / t_0)) end
function tmp = code(w, l) tmp = exp(-w) * (l ^ exp(w)); end
function tmp = code(w, l) t_0 = sqrt(exp(w)); tmp = (1.0 / t_0) * ((l ^ exp(w)) / t_0); end
code[w_, l_] := N[(N[Exp[(-w)], $MachinePrecision] * N[Power[l, N[Exp[w], $MachinePrecision]], $MachinePrecision]), $MachinePrecision]
code[w_, l_] := Block[{t$95$0 = N[Sqrt[N[Exp[w], $MachinePrecision]], $MachinePrecision]}, N[(N[(1.0 / t$95$0), $MachinePrecision] * N[(N[Power[l, N[Exp[w], $MachinePrecision]], $MachinePrecision] / t$95$0), $MachinePrecision]), $MachinePrecision]]
e^{-w} \cdot {\ell}^{\left(e^{w}\right)}
\begin{array}{l}
t_0 := \sqrt{e^{w}}\\
\frac{1}{t_0} \cdot \frac{{\ell}^{\left(e^{w}\right)}}{t_0}
\end{array}
Results
Initial program 0.3
Simplified0.3
Applied egg-rr0.3
Final simplification0.3
herbie shell --seed 2022192
(FPCore (w l)
:name "exp-w crasher"
:precision binary64
(* (exp (- w)) (pow l (exp w))))