
(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 10 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 (* (exp (- 0.0 w)) (pow l (exp w))))
double code(double w, double l) {
return exp((0.0 - w)) * pow(l, exp(w));
}
real(8) function code(w, l)
real(8), intent (in) :: w
real(8), intent (in) :: l
code = exp((0.0d0 - w)) * (l ** exp(w))
end function
public static double code(double w, double l) {
return Math.exp((0.0 - w)) * Math.pow(l, Math.exp(w));
}
def code(w, l): return math.exp((0.0 - w)) * math.pow(l, math.exp(w))
function code(w, l) return Float64(exp(Float64(0.0 - w)) * (l ^ exp(w))) end
function tmp = code(w, l) tmp = exp((0.0 - w)) * (l ^ exp(w)); end
code[w_, l_] := N[(N[Exp[N[(0.0 - w), $MachinePrecision]], $MachinePrecision] * N[Power[l, N[Exp[w], $MachinePrecision]], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
e^{0 - w} \cdot {\ell}^{\left(e^{w}\right)}
\end{array}
Initial program 99.6%
Final simplification99.6%
(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 99.6%
exp-negN/A
associate-*l/N/A
*-lft-identityN/A
/-lowering-/.f64N/A
pow-lowering-pow.f64N/A
exp-lowering-exp.f64N/A
exp-lowering-exp.f6499.6%
Simplified99.6%
(FPCore (w l) :precision binary64 (* l (/ 1.0 (exp w))))
double code(double w, double l) {
return l * (1.0 / exp(w));
}
real(8) function code(w, l)
real(8), intent (in) :: w
real(8), intent (in) :: l
code = l * (1.0d0 / exp(w))
end function
public static double code(double w, double l) {
return l * (1.0 / Math.exp(w));
}
def code(w, l): return l * (1.0 / math.exp(w))
function code(w, l) return Float64(l * Float64(1.0 / exp(w))) end
function tmp = code(w, l) tmp = l * (1.0 / exp(w)); end
code[w_, l_] := N[(l * N[(1.0 / N[Exp[w], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\ell \cdot \frac{1}{e^{w}}
\end{array}
Initial program 99.6%
exp-negN/A
associate-*l/N/A
*-lft-identityN/A
/-lowering-/.f64N/A
pow-lowering-pow.f64N/A
exp-lowering-exp.f64N/A
exp-lowering-exp.f6499.6%
Simplified99.6%
Taylor expanded in w around 0
Simplified98.0%
clear-numN/A
associate-/r/N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
exp-lowering-exp.f6498.0%
Applied egg-rr98.0%
Final simplification98.0%
(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 99.6%
exp-negN/A
associate-*l/N/A
*-lft-identityN/A
/-lowering-/.f64N/A
pow-lowering-pow.f64N/A
exp-lowering-exp.f64N/A
exp-lowering-exp.f6499.6%
Simplified99.6%
Taylor expanded in w around 0
Simplified98.0%
(FPCore (w l)
:precision binary64
(let* ((t_0 (- 0.5 (* w 0.16666666666666666))))
(if (<= w -1e+156)
(* -0.16666666666666666 (* l (* w (* w w))))
(if (<= w 0.24)
(*
l
(+ (/ (* w (+ -1.0 (* w (* w (* t_0 t_0))))) (+ (* w t_0) 1.0)) 1.0))
0.0))))
double code(double w, double l) {
double t_0 = 0.5 - (w * 0.16666666666666666);
double tmp;
if (w <= -1e+156) {
tmp = -0.16666666666666666 * (l * (w * (w * w)));
} else if (w <= 0.24) {
tmp = l * (((w * (-1.0 + (w * (w * (t_0 * t_0))))) / ((w * t_0) + 1.0)) + 1.0);
} else {
tmp = 0.0;
}
return tmp;
}
real(8) function code(w, l)
real(8), intent (in) :: w
real(8), intent (in) :: l
real(8) :: t_0
real(8) :: tmp
t_0 = 0.5d0 - (w * 0.16666666666666666d0)
if (w <= (-1d+156)) then
tmp = (-0.16666666666666666d0) * (l * (w * (w * w)))
else if (w <= 0.24d0) then
tmp = l * (((w * ((-1.0d0) + (w * (w * (t_0 * t_0))))) / ((w * t_0) + 1.0d0)) + 1.0d0)
else
tmp = 0.0d0
end if
code = tmp
end function
public static double code(double w, double l) {
double t_0 = 0.5 - (w * 0.16666666666666666);
double tmp;
if (w <= -1e+156) {
tmp = -0.16666666666666666 * (l * (w * (w * w)));
} else if (w <= 0.24) {
tmp = l * (((w * (-1.0 + (w * (w * (t_0 * t_0))))) / ((w * t_0) + 1.0)) + 1.0);
} else {
tmp = 0.0;
}
return tmp;
}
def code(w, l): t_0 = 0.5 - (w * 0.16666666666666666) tmp = 0 if w <= -1e+156: tmp = -0.16666666666666666 * (l * (w * (w * w))) elif w <= 0.24: tmp = l * (((w * (-1.0 + (w * (w * (t_0 * t_0))))) / ((w * t_0) + 1.0)) + 1.0) else: tmp = 0.0 return tmp
function code(w, l) t_0 = Float64(0.5 - Float64(w * 0.16666666666666666)) tmp = 0.0 if (w <= -1e+156) tmp = Float64(-0.16666666666666666 * Float64(l * Float64(w * Float64(w * w)))); elseif (w <= 0.24) tmp = Float64(l * Float64(Float64(Float64(w * Float64(-1.0 + Float64(w * Float64(w * Float64(t_0 * t_0))))) / Float64(Float64(w * t_0) + 1.0)) + 1.0)); else tmp = 0.0; end return tmp end
function tmp_2 = code(w, l) t_0 = 0.5 - (w * 0.16666666666666666); tmp = 0.0; if (w <= -1e+156) tmp = -0.16666666666666666 * (l * (w * (w * w))); elseif (w <= 0.24) tmp = l * (((w * (-1.0 + (w * (w * (t_0 * t_0))))) / ((w * t_0) + 1.0)) + 1.0); else tmp = 0.0; end tmp_2 = tmp; end
code[w_, l_] := Block[{t$95$0 = N[(0.5 - N[(w * 0.16666666666666666), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[w, -1e+156], N[(-0.16666666666666666 * N[(l * N[(w * N[(w * w), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[w, 0.24], N[(l * N[(N[(N[(w * N[(-1.0 + N[(w * N[(w * N[(t$95$0 * t$95$0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[(w * t$95$0), $MachinePrecision] + 1.0), $MachinePrecision]), $MachinePrecision] + 1.0), $MachinePrecision]), $MachinePrecision], 0.0]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := 0.5 - w \cdot 0.16666666666666666\\
\mathbf{if}\;w \leq -1 \cdot 10^{+156}:\\
\;\;\;\;-0.16666666666666666 \cdot \left(\ell \cdot \left(w \cdot \left(w \cdot w\right)\right)\right)\\
\mathbf{elif}\;w \leq 0.24:\\
\;\;\;\;\ell \cdot \left(\frac{w \cdot \left(-1 + w \cdot \left(w \cdot \left(t\_0 \cdot t\_0\right)\right)\right)}{w \cdot t\_0 + 1} + 1\right)\\
\mathbf{else}:\\
\;\;\;\;0\\
\end{array}
\end{array}
if w < -9.9999999999999998e155Initial program 100.0%
exp-negN/A
associate-*l/N/A
*-lft-identityN/A
/-lowering-/.f64N/A
pow-lowering-pow.f64N/A
exp-lowering-exp.f64N/A
exp-lowering-exp.f64100.0%
Simplified100.0%
Taylor expanded in w around 0
Simplified100.0%
Taylor expanded in w around 0
Simplified95.8%
Taylor expanded in w around inf
cancel-sign-sub-invN/A
metadata-evalN/A
+-commutativeN/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
+-commutativeN/A
+-lowering-+.f64N/A
associate-*r/N/A
/-lowering-/.f64N/A
*-commutativeN/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f64100.0%
Simplified100.0%
Taylor expanded in w around inf
*-lowering-*.f64N/A
*-lowering-*.f64N/A
cube-multN/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64100.0%
Simplified100.0%
if -9.9999999999999998e155 < w < 0.23999999999999999Initial program 99.4%
exp-negN/A
associate-*l/N/A
*-lft-identityN/A
/-lowering-/.f64N/A
pow-lowering-pow.f64N/A
exp-lowering-exp.f64N/A
exp-lowering-exp.f6499.4%
Simplified99.4%
Taylor expanded in w around 0
Simplified97.6%
Taylor expanded in w around 0
Simplified88.1%
*-commutativeN/A
flip--N/A
associate-*l/N/A
/-lowering-/.f64N/A
Applied egg-rr63.1%
Taylor expanded in l around 0
*-lowering-*.f64N/A
+-lowering-+.f64N/A
/-lowering-/.f64N/A
Simplified93.6%
if 0.23999999999999999 < w Initial program 100.0%
Applied egg-rr100.0%
Final simplification95.8%
(FPCore (w l)
:precision binary64
(if (<= w -8.5e-17)
(*
(* w (* w w))
(- (/ (+ (* l 0.5) (/ (- (/ l w) l) w)) w) (* l 0.16666666666666666)))
(if (<= w 0.21) (+ l (* l (* (* w w) 0.5))) 0.0)))
double code(double w, double l) {
double tmp;
if (w <= -8.5e-17) {
tmp = (w * (w * w)) * ((((l * 0.5) + (((l / w) - l) / w)) / w) - (l * 0.16666666666666666));
} else if (w <= 0.21) {
tmp = l + (l * ((w * w) * 0.5));
} else {
tmp = 0.0;
}
return tmp;
}
real(8) function code(w, l)
real(8), intent (in) :: w
real(8), intent (in) :: l
real(8) :: tmp
if (w <= (-8.5d-17)) then
tmp = (w * (w * w)) * ((((l * 0.5d0) + (((l / w) - l) / w)) / w) - (l * 0.16666666666666666d0))
else if (w <= 0.21d0) then
tmp = l + (l * ((w * w) * 0.5d0))
else
tmp = 0.0d0
end if
code = tmp
end function
public static double code(double w, double l) {
double tmp;
if (w <= -8.5e-17) {
tmp = (w * (w * w)) * ((((l * 0.5) + (((l / w) - l) / w)) / w) - (l * 0.16666666666666666));
} else if (w <= 0.21) {
tmp = l + (l * ((w * w) * 0.5));
} else {
tmp = 0.0;
}
return tmp;
}
def code(w, l): tmp = 0 if w <= -8.5e-17: tmp = (w * (w * w)) * ((((l * 0.5) + (((l / w) - l) / w)) / w) - (l * 0.16666666666666666)) elif w <= 0.21: tmp = l + (l * ((w * w) * 0.5)) else: tmp = 0.0 return tmp
function code(w, l) tmp = 0.0 if (w <= -8.5e-17) tmp = Float64(Float64(w * Float64(w * w)) * Float64(Float64(Float64(Float64(l * 0.5) + Float64(Float64(Float64(l / w) - l) / w)) / w) - Float64(l * 0.16666666666666666))); elseif (w <= 0.21) tmp = Float64(l + Float64(l * Float64(Float64(w * w) * 0.5))); else tmp = 0.0; end return tmp end
function tmp_2 = code(w, l) tmp = 0.0; if (w <= -8.5e-17) tmp = (w * (w * w)) * ((((l * 0.5) + (((l / w) - l) / w)) / w) - (l * 0.16666666666666666)); elseif (w <= 0.21) tmp = l + (l * ((w * w) * 0.5)); else tmp = 0.0; end tmp_2 = tmp; end
code[w_, l_] := If[LessEqual[w, -8.5e-17], N[(N[(w * N[(w * w), $MachinePrecision]), $MachinePrecision] * N[(N[(N[(N[(l * 0.5), $MachinePrecision] + N[(N[(N[(l / w), $MachinePrecision] - l), $MachinePrecision] / w), $MachinePrecision]), $MachinePrecision] / w), $MachinePrecision] - N[(l * 0.16666666666666666), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[w, 0.21], N[(l + N[(l * N[(N[(w * w), $MachinePrecision] * 0.5), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], 0.0]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;w \leq -8.5 \cdot 10^{-17}:\\
\;\;\;\;\left(w \cdot \left(w \cdot w\right)\right) \cdot \left(\frac{\ell \cdot 0.5 + \frac{\frac{\ell}{w} - \ell}{w}}{w} - \ell \cdot 0.16666666666666666\right)\\
\mathbf{elif}\;w \leq 0.21:\\
\;\;\;\;\ell + \ell \cdot \left(\left(w \cdot w\right) \cdot 0.5\right)\\
\mathbf{else}:\\
\;\;\;\;0\\
\end{array}
\end{array}
if w < -8.5e-17Initial program 99.6%
exp-negN/A
associate-*l/N/A
*-lft-identityN/A
/-lowering-/.f64N/A
pow-lowering-pow.f64N/A
exp-lowering-exp.f64N/A
exp-lowering-exp.f6499.6%
Simplified99.6%
Taylor expanded in w around 0
Simplified98.4%
Taylor expanded in w around 0
Simplified76.6%
Taylor expanded in w around -inf
mul-1-negN/A
neg-sub0N/A
--lowering--.f64N/A
*-lowering-*.f64N/A
cube-multN/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
+-commutativeN/A
mul-1-negN/A
unsub-negN/A
--lowering--.f64N/A
Simplified84.5%
if -8.5e-17 < w < 0.209999999999999992Initial program 99.5%
exp-negN/A
associate-*l/N/A
*-lft-identityN/A
/-lowering-/.f64N/A
pow-lowering-pow.f64N/A
exp-lowering-exp.f64N/A
exp-lowering-exp.f6499.5%
Simplified99.5%
Taylor expanded in w around 0
Simplified97.9%
Taylor expanded in w around 0
Simplified97.9%
Taylor expanded in w around inf
cancel-sign-sub-invN/A
metadata-evalN/A
+-commutativeN/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
+-commutativeN/A
+-lowering-+.f64N/A
associate-*r/N/A
/-lowering-/.f64N/A
*-commutativeN/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f6472.0%
Simplified72.0%
Taylor expanded in w around 0
+-lowering-+.f64N/A
*-commutativeN/A
associate-*l*N/A
*-commutativeN/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f6497.9%
Simplified97.9%
if 0.209999999999999992 < w Initial program 100.0%
Applied egg-rr100.0%
Final simplification93.9%
(FPCore (w l) :precision binary64 (if (<= w -0.96) (* -0.16666666666666666 (* l (* w (* w w)))) (if (<= w 0.18) (* l (/ -1.0 (- -1.0 w))) 0.0)))
double code(double w, double l) {
double tmp;
if (w <= -0.96) {
tmp = -0.16666666666666666 * (l * (w * (w * w)));
} else if (w <= 0.18) {
tmp = l * (-1.0 / (-1.0 - w));
} else {
tmp = 0.0;
}
return tmp;
}
real(8) function code(w, l)
real(8), intent (in) :: w
real(8), intent (in) :: l
real(8) :: tmp
if (w <= (-0.96d0)) then
tmp = (-0.16666666666666666d0) * (l * (w * (w * w)))
else if (w <= 0.18d0) then
tmp = l * ((-1.0d0) / ((-1.0d0) - w))
else
tmp = 0.0d0
end if
code = tmp
end function
public static double code(double w, double l) {
double tmp;
if (w <= -0.96) {
tmp = -0.16666666666666666 * (l * (w * (w * w)));
} else if (w <= 0.18) {
tmp = l * (-1.0 / (-1.0 - w));
} else {
tmp = 0.0;
}
return tmp;
}
def code(w, l): tmp = 0 if w <= -0.96: tmp = -0.16666666666666666 * (l * (w * (w * w))) elif w <= 0.18: tmp = l * (-1.0 / (-1.0 - w)) else: tmp = 0.0 return tmp
function code(w, l) tmp = 0.0 if (w <= -0.96) tmp = Float64(-0.16666666666666666 * Float64(l * Float64(w * Float64(w * w)))); elseif (w <= 0.18) tmp = Float64(l * Float64(-1.0 / Float64(-1.0 - w))); else tmp = 0.0; end return tmp end
function tmp_2 = code(w, l) tmp = 0.0; if (w <= -0.96) tmp = -0.16666666666666666 * (l * (w * (w * w))); elseif (w <= 0.18) tmp = l * (-1.0 / (-1.0 - w)); else tmp = 0.0; end tmp_2 = tmp; end
code[w_, l_] := If[LessEqual[w, -0.96], N[(-0.16666666666666666 * N[(l * N[(w * N[(w * w), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[w, 0.18], N[(l * N[(-1.0 / N[(-1.0 - w), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], 0.0]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;w \leq -0.96:\\
\;\;\;\;-0.16666666666666666 \cdot \left(\ell \cdot \left(w \cdot \left(w \cdot w\right)\right)\right)\\
\mathbf{elif}\;w \leq 0.18:\\
\;\;\;\;\ell \cdot \frac{-1}{-1 - w}\\
\mathbf{else}:\\
\;\;\;\;0\\
\end{array}
\end{array}
if w < -0.95999999999999996Initial program 100.0%
exp-negN/A
associate-*l/N/A
*-lft-identityN/A
/-lowering-/.f64N/A
pow-lowering-pow.f64N/A
exp-lowering-exp.f64N/A
exp-lowering-exp.f64100.0%
Simplified100.0%
Taylor expanded in w around 0
Simplified100.0%
Taylor expanded in w around 0
Simplified77.1%
Taylor expanded in w around inf
cancel-sign-sub-invN/A
metadata-evalN/A
+-commutativeN/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
+-commutativeN/A
+-lowering-+.f64N/A
associate-*r/N/A
/-lowering-/.f64N/A
*-commutativeN/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f6479.4%
Simplified79.4%
Taylor expanded in w around inf
*-lowering-*.f64N/A
*-lowering-*.f64N/A
cube-multN/A
unpow2N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f6485.4%
Simplified85.4%
if -0.95999999999999996 < w < 0.17999999999999999Initial program 99.3%
exp-negN/A
associate-*l/N/A
*-lft-identityN/A
/-lowering-/.f64N/A
pow-lowering-pow.f64N/A
exp-lowering-exp.f64N/A
exp-lowering-exp.f6499.3%
Simplified99.3%
Taylor expanded in w around 0
Simplified97.0%
clear-numN/A
associate-/r/N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
exp-lowering-exp.f6497.0%
Applied egg-rr97.0%
Taylor expanded in w around 0
+-commutativeN/A
+-lowering-+.f6497.0%
Simplified97.0%
if 0.17999999999999999 < w Initial program 100.0%
Applied egg-rr100.0%
Final simplification93.9%
(FPCore (w l) :precision binary64 (if (<= w 0.135) (* l (- 1.0 w)) 0.0))
double code(double w, double l) {
double tmp;
if (w <= 0.135) {
tmp = l * (1.0 - w);
} else {
tmp = 0.0;
}
return tmp;
}
real(8) function code(w, l)
real(8), intent (in) :: w
real(8), intent (in) :: l
real(8) :: tmp
if (w <= 0.135d0) then
tmp = l * (1.0d0 - w)
else
tmp = 0.0d0
end if
code = tmp
end function
public static double code(double w, double l) {
double tmp;
if (w <= 0.135) {
tmp = l * (1.0 - w);
} else {
tmp = 0.0;
}
return tmp;
}
def code(w, l): tmp = 0 if w <= 0.135: tmp = l * (1.0 - w) else: tmp = 0.0 return tmp
function code(w, l) tmp = 0.0 if (w <= 0.135) tmp = Float64(l * Float64(1.0 - w)); else tmp = 0.0; end return tmp end
function tmp_2 = code(w, l) tmp = 0.0; if (w <= 0.135) tmp = l * (1.0 - w); else tmp = 0.0; end tmp_2 = tmp; end
code[w_, l_] := If[LessEqual[w, 0.135], N[(l * N[(1.0 - w), $MachinePrecision]), $MachinePrecision], 0.0]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;w \leq 0.135:\\
\;\;\;\;\ell \cdot \left(1 - w\right)\\
\mathbf{else}:\\
\;\;\;\;0\\
\end{array}
\end{array}
if w < 0.13500000000000001Initial program 99.5%
exp-negN/A
associate-*l/N/A
*-lft-identityN/A
/-lowering-/.f64N/A
pow-lowering-pow.f64N/A
exp-lowering-exp.f64N/A
exp-lowering-exp.f6499.5%
Simplified99.5%
Taylor expanded in w around 0
Simplified98.1%
Taylor expanded in w around 0
mul-1-negN/A
unsub-negN/A
*-rgt-identityN/A
distribute-lft-out--N/A
*-lowering-*.f64N/A
--lowering--.f6473.5%
Simplified73.5%
if 0.13500000000000001 < w Initial program 100.0%
Applied egg-rr100.0%
(FPCore (w l) :precision binary64 (if (<= w 0.145) l 0.0))
double code(double w, double l) {
double tmp;
if (w <= 0.145) {
tmp = l;
} else {
tmp = 0.0;
}
return tmp;
}
real(8) function code(w, l)
real(8), intent (in) :: w
real(8), intent (in) :: l
real(8) :: tmp
if (w <= 0.145d0) then
tmp = l
else
tmp = 0.0d0
end if
code = tmp
end function
public static double code(double w, double l) {
double tmp;
if (w <= 0.145) {
tmp = l;
} else {
tmp = 0.0;
}
return tmp;
}
def code(w, l): tmp = 0 if w <= 0.145: tmp = l else: tmp = 0.0 return tmp
function code(w, l) tmp = 0.0 if (w <= 0.145) tmp = l; else tmp = 0.0; end return tmp end
function tmp_2 = code(w, l) tmp = 0.0; if (w <= 0.145) tmp = l; else tmp = 0.0; end tmp_2 = tmp; end
code[w_, l_] := If[LessEqual[w, 0.145], l, 0.0]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;w \leq 0.145:\\
\;\;\;\;\ell\\
\mathbf{else}:\\
\;\;\;\;0\\
\end{array}
\end{array}
if w < 0.14499999999999999Initial program 99.5%
Taylor expanded in w around 0
Simplified62.9%
if 0.14499999999999999 < w Initial program 100.0%
Applied egg-rr100.0%
(FPCore (w l) :precision binary64 0.0)
double code(double w, double l) {
return 0.0;
}
real(8) function code(w, l)
real(8), intent (in) :: w
real(8), intent (in) :: l
code = 0.0d0
end function
public static double code(double w, double l) {
return 0.0;
}
def code(w, l): return 0.0
function code(w, l) return 0.0 end
function tmp = code(w, l) tmp = 0.0; end
code[w_, l_] := 0.0
\begin{array}{l}
\\
0
\end{array}
Initial program 99.6%
Applied egg-rr18.5%
herbie shell --seed 2024152
(FPCore (w l)
:name "exp-w (used to crash)"
:precision binary64
(* (exp (- w)) (pow l (exp w))))