
(FPCore (c0 w h D d M) :precision binary64 (let* ((t_0 (/ (* c0 (* d d)) (* (* w h) (* D D))))) (* (/ c0 (* 2.0 w)) (+ t_0 (sqrt (- (* t_0 t_0) (* M M)))))))
double code(double c0, double w, double h, double D, double d, double M) {
double t_0 = (c0 * (d * d)) / ((w * h) * (D * D));
return (c0 / (2.0 * w)) * (t_0 + sqrt(((t_0 * t_0) - (M * M))));
}
real(8) function code(c0, w, h, d, d_1, m)
real(8), intent (in) :: c0
real(8), intent (in) :: w
real(8), intent (in) :: h
real(8), intent (in) :: d
real(8), intent (in) :: d_1
real(8), intent (in) :: m
real(8) :: t_0
t_0 = (c0 * (d_1 * d_1)) / ((w * h) * (d * d))
code = (c0 / (2.0d0 * w)) * (t_0 + sqrt(((t_0 * t_0) - (m * m))))
end function
public static double code(double c0, double w, double h, double D, double d, double M) {
double t_0 = (c0 * (d * d)) / ((w * h) * (D * D));
return (c0 / (2.0 * w)) * (t_0 + Math.sqrt(((t_0 * t_0) - (M * M))));
}
def code(c0, w, h, D, d, M): t_0 = (c0 * (d * d)) / ((w * h) * (D * D)) return (c0 / (2.0 * w)) * (t_0 + math.sqrt(((t_0 * t_0) - (M * M))))
function code(c0, w, h, D, d, M) t_0 = Float64(Float64(c0 * Float64(d * d)) / Float64(Float64(w * h) * Float64(D * D))) return Float64(Float64(c0 / Float64(2.0 * w)) * Float64(t_0 + sqrt(Float64(Float64(t_0 * t_0) - Float64(M * M))))) end
function tmp = code(c0, w, h, D, d, M) t_0 = (c0 * (d * d)) / ((w * h) * (D * D)); tmp = (c0 / (2.0 * w)) * (t_0 + sqrt(((t_0 * t_0) - (M * M)))); end
code[c0_, w_, h_, D_, d_, M_] := Block[{t$95$0 = N[(N[(c0 * N[(d * d), $MachinePrecision]), $MachinePrecision] / N[(N[(w * h), $MachinePrecision] * N[(D * D), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, N[(N[(c0 / N[(2.0 * w), $MachinePrecision]), $MachinePrecision] * N[(t$95$0 + N[Sqrt[N[(N[(t$95$0 * t$95$0), $MachinePrecision] - N[(M * M), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \frac{c0 \cdot \left(d \cdot d\right)}{\left(w \cdot h\right) \cdot \left(D \cdot D\right)}\\
\frac{c0}{2 \cdot w} \cdot \left(t\_0 + \sqrt{t\_0 \cdot t\_0 - M \cdot M}\right)
\end{array}
\end{array}
Sampling outcomes in binary64 precision:
Herbie found 10 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (c0 w h D d M) :precision binary64 (let* ((t_0 (/ (* c0 (* d d)) (* (* w h) (* D D))))) (* (/ c0 (* 2.0 w)) (+ t_0 (sqrt (- (* t_0 t_0) (* M M)))))))
double code(double c0, double w, double h, double D, double d, double M) {
double t_0 = (c0 * (d * d)) / ((w * h) * (D * D));
return (c0 / (2.0 * w)) * (t_0 + sqrt(((t_0 * t_0) - (M * M))));
}
real(8) function code(c0, w, h, d, d_1, m)
real(8), intent (in) :: c0
real(8), intent (in) :: w
real(8), intent (in) :: h
real(8), intent (in) :: d
real(8), intent (in) :: d_1
real(8), intent (in) :: m
real(8) :: t_0
t_0 = (c0 * (d_1 * d_1)) / ((w * h) * (d * d))
code = (c0 / (2.0d0 * w)) * (t_0 + sqrt(((t_0 * t_0) - (m * m))))
end function
public static double code(double c0, double w, double h, double D, double d, double M) {
double t_0 = (c0 * (d * d)) / ((w * h) * (D * D));
return (c0 / (2.0 * w)) * (t_0 + Math.sqrt(((t_0 * t_0) - (M * M))));
}
def code(c0, w, h, D, d, M): t_0 = (c0 * (d * d)) / ((w * h) * (D * D)) return (c0 / (2.0 * w)) * (t_0 + math.sqrt(((t_0 * t_0) - (M * M))))
function code(c0, w, h, D, d, M) t_0 = Float64(Float64(c0 * Float64(d * d)) / Float64(Float64(w * h) * Float64(D * D))) return Float64(Float64(c0 / Float64(2.0 * w)) * Float64(t_0 + sqrt(Float64(Float64(t_0 * t_0) - Float64(M * M))))) end
function tmp = code(c0, w, h, D, d, M) t_0 = (c0 * (d * d)) / ((w * h) * (D * D)); tmp = (c0 / (2.0 * w)) * (t_0 + sqrt(((t_0 * t_0) - (M * M)))); end
code[c0_, w_, h_, D_, d_, M_] := Block[{t$95$0 = N[(N[(c0 * N[(d * d), $MachinePrecision]), $MachinePrecision] / N[(N[(w * h), $MachinePrecision] * N[(D * D), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, N[(N[(c0 / N[(2.0 * w), $MachinePrecision]), $MachinePrecision] * N[(t$95$0 + N[Sqrt[N[(N[(t$95$0 * t$95$0), $MachinePrecision] - N[(M * M), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \frac{c0 \cdot \left(d \cdot d\right)}{\left(w \cdot h\right) \cdot \left(D \cdot D\right)}\\
\frac{c0}{2 \cdot w} \cdot \left(t\_0 + \sqrt{t\_0 \cdot t\_0 - M \cdot M}\right)
\end{array}
\end{array}
(FPCore (c0 w h D d M)
:precision binary64
(let* ((t_0 (/ (* c0 (* d d)) (* (* w h) (* D D)))))
(if (<=
(* (/ c0 (* 2.0 w)) (+ t_0 (sqrt (- (* t_0 t_0) (* M M)))))
INFINITY)
(/ (/ (/ d D) (/ 2.0 (/ c0 w))) (/ (/ D d) (/ (* 2.0 (/ c0 w)) h)))
0.0)))
double code(double c0, double w, double h, double D, double d, double M) {
double t_0 = (c0 * (d * d)) / ((w * h) * (D * D));
double tmp;
if (((c0 / (2.0 * w)) * (t_0 + sqrt(((t_0 * t_0) - (M * M))))) <= ((double) INFINITY)) {
tmp = ((d / D) / (2.0 / (c0 / w))) / ((D / d) / ((2.0 * (c0 / w)) / h));
} else {
tmp = 0.0;
}
return tmp;
}
public static double code(double c0, double w, double h, double D, double d, double M) {
double t_0 = (c0 * (d * d)) / ((w * h) * (D * D));
double tmp;
if (((c0 / (2.0 * w)) * (t_0 + Math.sqrt(((t_0 * t_0) - (M * M))))) <= Double.POSITIVE_INFINITY) {
tmp = ((d / D) / (2.0 / (c0 / w))) / ((D / d) / ((2.0 * (c0 / w)) / h));
} else {
tmp = 0.0;
}
return tmp;
}
def code(c0, w, h, D, d, M): t_0 = (c0 * (d * d)) / ((w * h) * (D * D)) tmp = 0 if ((c0 / (2.0 * w)) * (t_0 + math.sqrt(((t_0 * t_0) - (M * M))))) <= math.inf: tmp = ((d / D) / (2.0 / (c0 / w))) / ((D / d) / ((2.0 * (c0 / w)) / h)) else: tmp = 0.0 return tmp
function code(c0, w, h, D, d, M) t_0 = Float64(Float64(c0 * Float64(d * d)) / Float64(Float64(w * h) * Float64(D * D))) tmp = 0.0 if (Float64(Float64(c0 / Float64(2.0 * w)) * Float64(t_0 + sqrt(Float64(Float64(t_0 * t_0) - Float64(M * M))))) <= Inf) tmp = Float64(Float64(Float64(d / D) / Float64(2.0 / Float64(c0 / w))) / Float64(Float64(D / d) / Float64(Float64(2.0 * Float64(c0 / w)) / h))); else tmp = 0.0; end return tmp end
function tmp_2 = code(c0, w, h, D, d, M) t_0 = (c0 * (d * d)) / ((w * h) * (D * D)); tmp = 0.0; if (((c0 / (2.0 * w)) * (t_0 + sqrt(((t_0 * t_0) - (M * M))))) <= Inf) tmp = ((d / D) / (2.0 / (c0 / w))) / ((D / d) / ((2.0 * (c0 / w)) / h)); else tmp = 0.0; end tmp_2 = tmp; end
code[c0_, w_, h_, D_, d_, M_] := Block[{t$95$0 = N[(N[(c0 * N[(d * d), $MachinePrecision]), $MachinePrecision] / N[(N[(w * h), $MachinePrecision] * N[(D * D), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[N[(N[(c0 / N[(2.0 * w), $MachinePrecision]), $MachinePrecision] * N[(t$95$0 + N[Sqrt[N[(N[(t$95$0 * t$95$0), $MachinePrecision] - N[(M * M), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], Infinity], N[(N[(N[(d / D), $MachinePrecision] / N[(2.0 / N[(c0 / w), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(N[(D / d), $MachinePrecision] / N[(N[(2.0 * N[(c0 / w), $MachinePrecision]), $MachinePrecision] / h), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], 0.0]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \frac{c0 \cdot \left(d \cdot d\right)}{\left(w \cdot h\right) \cdot \left(D \cdot D\right)}\\
\mathbf{if}\;\frac{c0}{2 \cdot w} \cdot \left(t\_0 + \sqrt{t\_0 \cdot t\_0 - M \cdot M}\right) \leq \infty:\\
\;\;\;\;\frac{\frac{\frac{d}{D}}{\frac{2}{\frac{c0}{w}}}}{\frac{\frac{D}{d}}{\frac{2 \cdot \frac{c0}{w}}{h}}}\\
\mathbf{else}:\\
\;\;\;\;0\\
\end{array}
\end{array}
if (*.f64 (/.f64 c0 (*.f64 #s(literal 2 binary64) w)) (+.f64 (/.f64 (*.f64 c0 (*.f64 d d)) (*.f64 (*.f64 w h) (*.f64 D D))) (sqrt.f64 (-.f64 (*.f64 (/.f64 (*.f64 c0 (*.f64 d d)) (*.f64 (*.f64 w h) (*.f64 D D))) (/.f64 (*.f64 c0 (*.f64 d d)) (*.f64 (*.f64 w h) (*.f64 D D)))) (*.f64 M M))))) < +inf.0Initial program 76.0%
*-lowering-*.f64N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
+-lowering-+.f64N/A
Simplified68.6%
Taylor expanded in c0 around inf
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f6476.5%
Simplified76.5%
associate-*r*N/A
*-commutativeN/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
*-commutativeN/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f6474.1%
Applied egg-rr74.1%
*-commutativeN/A
times-fracN/A
associate-*l*N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
times-fracN/A
clear-numN/A
frac-timesN/A
metadata-evalN/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f6483.8%
Applied egg-rr83.8%
associate-*r*N/A
clear-numN/A
clear-numN/A
frac-timesN/A
metadata-evalN/A
un-div-invN/A
/-lowering-/.f64N/A
Applied egg-rr87.1%
if +inf.0 < (*.f64 (/.f64 c0 (*.f64 #s(literal 2 binary64) w)) (+.f64 (/.f64 (*.f64 c0 (*.f64 d d)) (*.f64 (*.f64 w h) (*.f64 D D))) (sqrt.f64 (-.f64 (*.f64 (/.f64 (*.f64 c0 (*.f64 d d)) (*.f64 (*.f64 w h) (*.f64 D D))) (/.f64 (*.f64 c0 (*.f64 d d)) (*.f64 (*.f64 w h) (*.f64 D D)))) (*.f64 M M))))) Initial program 0.0%
*-lowering-*.f64N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
+-lowering-+.f64N/A
Simplified0.0%
Taylor expanded in c0 around -inf
associate-*r*N/A
mul-1-negN/A
distribute-lft1-inN/A
metadata-evalN/A
mul0-lftN/A
distribute-lft-neg-inN/A
distribute-rgt-neg-inN/A
metadata-evalN/A
*-lowering-*.f6440.0%
Simplified40.0%
mul0-rgtN/A
mul0-rgt44.4%
Applied egg-rr44.4%
(FPCore (c0 w h D d M)
:precision binary64
(let* ((t_0 (/ (* (* c0 d) (* c0 d)) (* w (* D (* (* w h) D))))))
(if (<= d 4e-169)
t_0
(if (<= d 2.9e+115)
(* (* (/ c0 (* w (* 2.0 D))) (/ c0 h)) (/ (* 2.0 (* d d)) (* w D)))
(if (<= d 3e+209) t_0 0.0)))))
double code(double c0, double w, double h, double D, double d, double M) {
double t_0 = ((c0 * d) * (c0 * d)) / (w * (D * ((w * h) * D)));
double tmp;
if (d <= 4e-169) {
tmp = t_0;
} else if (d <= 2.9e+115) {
tmp = ((c0 / (w * (2.0 * D))) * (c0 / h)) * ((2.0 * (d * d)) / (w * D));
} else if (d <= 3e+209) {
tmp = t_0;
} else {
tmp = 0.0;
}
return tmp;
}
real(8) function code(c0, w, h, d, d_1, m)
real(8), intent (in) :: c0
real(8), intent (in) :: w
real(8), intent (in) :: h
real(8), intent (in) :: d
real(8), intent (in) :: d_1
real(8), intent (in) :: m
real(8) :: t_0
real(8) :: tmp
t_0 = ((c0 * d_1) * (c0 * d_1)) / (w * (d * ((w * h) * d)))
if (d_1 <= 4d-169) then
tmp = t_0
else if (d_1 <= 2.9d+115) then
tmp = ((c0 / (w * (2.0d0 * d))) * (c0 / h)) * ((2.0d0 * (d_1 * d_1)) / (w * d))
else if (d_1 <= 3d+209) then
tmp = t_0
else
tmp = 0.0d0
end if
code = tmp
end function
public static double code(double c0, double w, double h, double D, double d, double M) {
double t_0 = ((c0 * d) * (c0 * d)) / (w * (D * ((w * h) * D)));
double tmp;
if (d <= 4e-169) {
tmp = t_0;
} else if (d <= 2.9e+115) {
tmp = ((c0 / (w * (2.0 * D))) * (c0 / h)) * ((2.0 * (d * d)) / (w * D));
} else if (d <= 3e+209) {
tmp = t_0;
} else {
tmp = 0.0;
}
return tmp;
}
def code(c0, w, h, D, d, M): t_0 = ((c0 * d) * (c0 * d)) / (w * (D * ((w * h) * D))) tmp = 0 if d <= 4e-169: tmp = t_0 elif d <= 2.9e+115: tmp = ((c0 / (w * (2.0 * D))) * (c0 / h)) * ((2.0 * (d * d)) / (w * D)) elif d <= 3e+209: tmp = t_0 else: tmp = 0.0 return tmp
function code(c0, w, h, D, d, M) t_0 = Float64(Float64(Float64(c0 * d) * Float64(c0 * d)) / Float64(w * Float64(D * Float64(Float64(w * h) * D)))) tmp = 0.0 if (d <= 4e-169) tmp = t_0; elseif (d <= 2.9e+115) tmp = Float64(Float64(Float64(c0 / Float64(w * Float64(2.0 * D))) * Float64(c0 / h)) * Float64(Float64(2.0 * Float64(d * d)) / Float64(w * D))); elseif (d <= 3e+209) tmp = t_0; else tmp = 0.0; end return tmp end
function tmp_2 = code(c0, w, h, D, d, M) t_0 = ((c0 * d) * (c0 * d)) / (w * (D * ((w * h) * D))); tmp = 0.0; if (d <= 4e-169) tmp = t_0; elseif (d <= 2.9e+115) tmp = ((c0 / (w * (2.0 * D))) * (c0 / h)) * ((2.0 * (d * d)) / (w * D)); elseif (d <= 3e+209) tmp = t_0; else tmp = 0.0; end tmp_2 = tmp; end
code[c0_, w_, h_, D_, d_, M_] := Block[{t$95$0 = N[(N[(N[(c0 * d), $MachinePrecision] * N[(c0 * d), $MachinePrecision]), $MachinePrecision] / N[(w * N[(D * N[(N[(w * h), $MachinePrecision] * D), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[d, 4e-169], t$95$0, If[LessEqual[d, 2.9e+115], N[(N[(N[(c0 / N[(w * N[(2.0 * D), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(c0 / h), $MachinePrecision]), $MachinePrecision] * N[(N[(2.0 * N[(d * d), $MachinePrecision]), $MachinePrecision] / N[(w * D), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[d, 3e+209], t$95$0, 0.0]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \frac{\left(c0 \cdot d\right) \cdot \left(c0 \cdot d\right)}{w \cdot \left(D \cdot \left(\left(w \cdot h\right) \cdot D\right)\right)}\\
\mathbf{if}\;d \leq 4 \cdot 10^{-169}:\\
\;\;\;\;t\_0\\
\mathbf{elif}\;d \leq 2.9 \cdot 10^{+115}:\\
\;\;\;\;\left(\frac{c0}{w \cdot \left(2 \cdot D\right)} \cdot \frac{c0}{h}\right) \cdot \frac{2 \cdot \left(d \cdot d\right)}{w \cdot D}\\
\mathbf{elif}\;d \leq 3 \cdot 10^{+209}:\\
\;\;\;\;t\_0\\
\mathbf{else}:\\
\;\;\;\;0\\
\end{array}
\end{array}
if d < 4.00000000000000008e-169 or 2.90000000000000005e115 < d < 2.99999999999999985e209Initial program 27.2%
*-lowering-*.f64N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
+-lowering-+.f64N/A
Simplified24.4%
Taylor expanded in c0 around inf
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f6437.7%
Simplified37.7%
associate-*r/N/A
associate-*l*N/A
*-commutativeN/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
associate-/l/N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f6442.7%
Applied egg-rr42.7%
Taylor expanded in c0 around 0
/-lowering-/.f64N/A
unpow2N/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
associate-*r*N/A
unpow2N/A
associate-*r*N/A
associate-*r*N/A
*-lowering-*.f64N/A
unpow2N/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f6436.6%
Simplified36.6%
associate-*r*N/A
unswap-sqrN/A
*-commutativeN/A
*-commutativeN/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f6443.7%
Applied egg-rr43.7%
if 4.00000000000000008e-169 < d < 2.90000000000000005e115Initial program 27.9%
*-lowering-*.f64N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
+-lowering-+.f64N/A
Simplified24.8%
Taylor expanded in c0 around inf
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f6437.1%
Simplified37.1%
associate-*r/N/A
associate-*l*N/A
*-commutativeN/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
associate-/l/N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f6446.8%
Applied egg-rr46.8%
times-fracN/A
associate-*r*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
associate-/l/N/A
associate-/l/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-commutativeN/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f6447.3%
Applied egg-rr47.3%
if 2.99999999999999985e209 < d Initial program 12.2%
*-lowering-*.f64N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
+-lowering-+.f64N/A
Simplified12.2%
Taylor expanded in c0 around -inf
associate-*r*N/A
mul-1-negN/A
distribute-lft1-inN/A
metadata-evalN/A
mul0-lftN/A
distribute-lft-neg-inN/A
distribute-rgt-neg-inN/A
metadata-evalN/A
*-lowering-*.f6452.8%
Simplified52.8%
mul0-rgtN/A
mul0-rgt57.9%
Applied egg-rr57.9%
Final simplification46.9%
(FPCore (c0 w h D d M)
:precision binary64
(let* ((t_0 (/ (* (* c0 d) (* c0 d)) (* w (* D (* (* w h) D))))))
(if (<= d 2.55e-89)
t_0
(if (<= d 4e+140)
(* (/ (* c0 (* d d)) D) (/ c0 (* w (* w (* h D)))))
(if (<= d 2.7e+209) t_0 0.0)))))
double code(double c0, double w, double h, double D, double d, double M) {
double t_0 = ((c0 * d) * (c0 * d)) / (w * (D * ((w * h) * D)));
double tmp;
if (d <= 2.55e-89) {
tmp = t_0;
} else if (d <= 4e+140) {
tmp = ((c0 * (d * d)) / D) * (c0 / (w * (w * (h * D))));
} else if (d <= 2.7e+209) {
tmp = t_0;
} else {
tmp = 0.0;
}
return tmp;
}
real(8) function code(c0, w, h, d, d_1, m)
real(8), intent (in) :: c0
real(8), intent (in) :: w
real(8), intent (in) :: h
real(8), intent (in) :: d
real(8), intent (in) :: d_1
real(8), intent (in) :: m
real(8) :: t_0
real(8) :: tmp
t_0 = ((c0 * d_1) * (c0 * d_1)) / (w * (d * ((w * h) * d)))
if (d_1 <= 2.55d-89) then
tmp = t_0
else if (d_1 <= 4d+140) then
tmp = ((c0 * (d_1 * d_1)) / d) * (c0 / (w * (w * (h * d))))
else if (d_1 <= 2.7d+209) then
tmp = t_0
else
tmp = 0.0d0
end if
code = tmp
end function
public static double code(double c0, double w, double h, double D, double d, double M) {
double t_0 = ((c0 * d) * (c0 * d)) / (w * (D * ((w * h) * D)));
double tmp;
if (d <= 2.55e-89) {
tmp = t_0;
} else if (d <= 4e+140) {
tmp = ((c0 * (d * d)) / D) * (c0 / (w * (w * (h * D))));
} else if (d <= 2.7e+209) {
tmp = t_0;
} else {
tmp = 0.0;
}
return tmp;
}
def code(c0, w, h, D, d, M): t_0 = ((c0 * d) * (c0 * d)) / (w * (D * ((w * h) * D))) tmp = 0 if d <= 2.55e-89: tmp = t_0 elif d <= 4e+140: tmp = ((c0 * (d * d)) / D) * (c0 / (w * (w * (h * D)))) elif d <= 2.7e+209: tmp = t_0 else: tmp = 0.0 return tmp
function code(c0, w, h, D, d, M) t_0 = Float64(Float64(Float64(c0 * d) * Float64(c0 * d)) / Float64(w * Float64(D * Float64(Float64(w * h) * D)))) tmp = 0.0 if (d <= 2.55e-89) tmp = t_0; elseif (d <= 4e+140) tmp = Float64(Float64(Float64(c0 * Float64(d * d)) / D) * Float64(c0 / Float64(w * Float64(w * Float64(h * D))))); elseif (d <= 2.7e+209) tmp = t_0; else tmp = 0.0; end return tmp end
function tmp_2 = code(c0, w, h, D, d, M) t_0 = ((c0 * d) * (c0 * d)) / (w * (D * ((w * h) * D))); tmp = 0.0; if (d <= 2.55e-89) tmp = t_0; elseif (d <= 4e+140) tmp = ((c0 * (d * d)) / D) * (c0 / (w * (w * (h * D)))); elseif (d <= 2.7e+209) tmp = t_0; else tmp = 0.0; end tmp_2 = tmp; end
code[c0_, w_, h_, D_, d_, M_] := Block[{t$95$0 = N[(N[(N[(c0 * d), $MachinePrecision] * N[(c0 * d), $MachinePrecision]), $MachinePrecision] / N[(w * N[(D * N[(N[(w * h), $MachinePrecision] * D), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[d, 2.55e-89], t$95$0, If[LessEqual[d, 4e+140], N[(N[(N[(c0 * N[(d * d), $MachinePrecision]), $MachinePrecision] / D), $MachinePrecision] * N[(c0 / N[(w * N[(w * N[(h * D), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[d, 2.7e+209], t$95$0, 0.0]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \frac{\left(c0 \cdot d\right) \cdot \left(c0 \cdot d\right)}{w \cdot \left(D \cdot \left(\left(w \cdot h\right) \cdot D\right)\right)}\\
\mathbf{if}\;d \leq 2.55 \cdot 10^{-89}:\\
\;\;\;\;t\_0\\
\mathbf{elif}\;d \leq 4 \cdot 10^{+140}:\\
\;\;\;\;\frac{c0 \cdot \left(d \cdot d\right)}{D} \cdot \frac{c0}{w \cdot \left(w \cdot \left(h \cdot D\right)\right)}\\
\mathbf{elif}\;d \leq 2.7 \cdot 10^{+209}:\\
\;\;\;\;t\_0\\
\mathbf{else}:\\
\;\;\;\;0\\
\end{array}
\end{array}
if d < 2.55000000000000002e-89 or 4.00000000000000024e140 < d < 2.7e209Initial program 24.8%
*-lowering-*.f64N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
+-lowering-+.f64N/A
Simplified22.7%
Taylor expanded in c0 around inf
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f6434.5%
Simplified34.5%
associate-*r/N/A
associate-*l*N/A
*-commutativeN/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
associate-/l/N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f6440.2%
Applied egg-rr40.2%
Taylor expanded in c0 around 0
/-lowering-/.f64N/A
unpow2N/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
associate-*r*N/A
unpow2N/A
associate-*r*N/A
associate-*r*N/A
*-lowering-*.f64N/A
unpow2N/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f6435.1%
Simplified35.1%
associate-*r*N/A
unswap-sqrN/A
*-commutativeN/A
*-commutativeN/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f6442.1%
Applied egg-rr42.1%
if 2.55000000000000002e-89 < d < 4.00000000000000024e140Initial program 34.5%
*-lowering-*.f64N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
+-lowering-+.f64N/A
Simplified29.5%
Taylor expanded in c0 around inf
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f6445.7%
Simplified45.7%
associate-*r/N/A
associate-*l*N/A
*-commutativeN/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
associate-/l/N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f6454.1%
Applied egg-rr54.1%
Taylor expanded in c0 around 0
/-lowering-/.f64N/A
unpow2N/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
associate-*r*N/A
unpow2N/A
associate-*r*N/A
associate-*r*N/A
*-lowering-*.f64N/A
unpow2N/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f6441.4%
Simplified41.4%
*-commutativeN/A
associate-*l*N/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
*-commutativeN/A
associate-*r*N/A
*-commutativeN/A
*-commutativeN/A
*-commutativeN/A
*-lowering-*.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f6448.7%
Applied egg-rr48.7%
if 2.7e209 < d Initial program 12.2%
*-lowering-*.f64N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
+-lowering-+.f64N/A
Simplified12.2%
Taylor expanded in c0 around -inf
associate-*r*N/A
mul-1-negN/A
distribute-lft1-inN/A
metadata-evalN/A
mul0-lftN/A
distribute-lft-neg-inN/A
distribute-rgt-neg-inN/A
metadata-evalN/A
*-lowering-*.f6452.8%
Simplified52.8%
mul0-rgtN/A
mul0-rgt57.9%
Applied egg-rr57.9%
Final simplification46.1%
(FPCore (c0 w h D d M)
:precision binary64
(if (<= d 6.8e-139)
0.0
(if (<= d 2e+139)
(* (/ (* c0 (* d d)) D) (/ c0 (* w (* w (* h D)))))
(if (<= d 2.7e+209)
(/ (* c0 (* d (* c0 d))) (* w (* D (* (* w h) D))))
0.0))))
double code(double c0, double w, double h, double D, double d, double M) {
double tmp;
if (d <= 6.8e-139) {
tmp = 0.0;
} else if (d <= 2e+139) {
tmp = ((c0 * (d * d)) / D) * (c0 / (w * (w * (h * D))));
} else if (d <= 2.7e+209) {
tmp = (c0 * (d * (c0 * d))) / (w * (D * ((w * h) * D)));
} else {
tmp = 0.0;
}
return tmp;
}
real(8) function code(c0, w, h, d, d_1, m)
real(8), intent (in) :: c0
real(8), intent (in) :: w
real(8), intent (in) :: h
real(8), intent (in) :: d
real(8), intent (in) :: d_1
real(8), intent (in) :: m
real(8) :: tmp
if (d_1 <= 6.8d-139) then
tmp = 0.0d0
else if (d_1 <= 2d+139) then
tmp = ((c0 * (d_1 * d_1)) / d) * (c0 / (w * (w * (h * d))))
else if (d_1 <= 2.7d+209) then
tmp = (c0 * (d_1 * (c0 * d_1))) / (w * (d * ((w * h) * d)))
else
tmp = 0.0d0
end if
code = tmp
end function
public static double code(double c0, double w, double h, double D, double d, double M) {
double tmp;
if (d <= 6.8e-139) {
tmp = 0.0;
} else if (d <= 2e+139) {
tmp = ((c0 * (d * d)) / D) * (c0 / (w * (w * (h * D))));
} else if (d <= 2.7e+209) {
tmp = (c0 * (d * (c0 * d))) / (w * (D * ((w * h) * D)));
} else {
tmp = 0.0;
}
return tmp;
}
def code(c0, w, h, D, d, M): tmp = 0 if d <= 6.8e-139: tmp = 0.0 elif d <= 2e+139: tmp = ((c0 * (d * d)) / D) * (c0 / (w * (w * (h * D)))) elif d <= 2.7e+209: tmp = (c0 * (d * (c0 * d))) / (w * (D * ((w * h) * D))) else: tmp = 0.0 return tmp
function code(c0, w, h, D, d, M) tmp = 0.0 if (d <= 6.8e-139) tmp = 0.0; elseif (d <= 2e+139) tmp = Float64(Float64(Float64(c0 * Float64(d * d)) / D) * Float64(c0 / Float64(w * Float64(w * Float64(h * D))))); elseif (d <= 2.7e+209) tmp = Float64(Float64(c0 * Float64(d * Float64(c0 * d))) / Float64(w * Float64(D * Float64(Float64(w * h) * D)))); else tmp = 0.0; end return tmp end
function tmp_2 = code(c0, w, h, D, d, M) tmp = 0.0; if (d <= 6.8e-139) tmp = 0.0; elseif (d <= 2e+139) tmp = ((c0 * (d * d)) / D) * (c0 / (w * (w * (h * D)))); elseif (d <= 2.7e+209) tmp = (c0 * (d * (c0 * d))) / (w * (D * ((w * h) * D))); else tmp = 0.0; end tmp_2 = tmp; end
code[c0_, w_, h_, D_, d_, M_] := If[LessEqual[d, 6.8e-139], 0.0, If[LessEqual[d, 2e+139], N[(N[(N[(c0 * N[(d * d), $MachinePrecision]), $MachinePrecision] / D), $MachinePrecision] * N[(c0 / N[(w * N[(w * N[(h * D), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[d, 2.7e+209], N[(N[(c0 * N[(d * N[(c0 * d), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(w * N[(D * N[(N[(w * h), $MachinePrecision] * D), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], 0.0]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;d \leq 6.8 \cdot 10^{-139}:\\
\;\;\;\;0\\
\mathbf{elif}\;d \leq 2 \cdot 10^{+139}:\\
\;\;\;\;\frac{c0 \cdot \left(d \cdot d\right)}{D} \cdot \frac{c0}{w \cdot \left(w \cdot \left(h \cdot D\right)\right)}\\
\mathbf{elif}\;d \leq 2.7 \cdot 10^{+209}:\\
\;\;\;\;\frac{c0 \cdot \left(d \cdot \left(c0 \cdot d\right)\right)}{w \cdot \left(D \cdot \left(\left(w \cdot h\right) \cdot D\right)\right)}\\
\mathbf{else}:\\
\;\;\;\;0\\
\end{array}
\end{array}
if d < 6.79999999999999998e-139 or 2.7e209 < d Initial program 22.0%
*-lowering-*.f64N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
+-lowering-+.f64N/A
Simplified20.6%
Taylor expanded in c0 around -inf
associate-*r*N/A
mul-1-negN/A
distribute-lft1-inN/A
metadata-evalN/A
mul0-lftN/A
distribute-lft-neg-inN/A
distribute-rgt-neg-inN/A
metadata-evalN/A
*-lowering-*.f6430.1%
Simplified30.1%
mul0-rgtN/A
mul0-rgt32.8%
Applied egg-rr32.8%
if 6.79999999999999998e-139 < d < 2.00000000000000007e139Initial program 30.5%
*-lowering-*.f64N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
+-lowering-+.f64N/A
Simplified26.3%
Taylor expanded in c0 around inf
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f6441.6%
Simplified41.6%
associate-*r/N/A
associate-*l*N/A
*-commutativeN/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
associate-/l/N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f6451.6%
Applied egg-rr51.6%
Taylor expanded in c0 around 0
/-lowering-/.f64N/A
unpow2N/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
associate-*r*N/A
unpow2N/A
associate-*r*N/A
associate-*r*N/A
*-lowering-*.f64N/A
unpow2N/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f6441.7%
Simplified41.7%
*-commutativeN/A
associate-*l*N/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
*-commutativeN/A
associate-*r*N/A
*-commutativeN/A
*-commutativeN/A
*-commutativeN/A
*-lowering-*.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f6446.5%
Applied egg-rr46.5%
if 2.00000000000000007e139 < d < 2.7e209Initial program 29.4%
*-lowering-*.f64N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
+-lowering-+.f64N/A
Simplified25.2%
Taylor expanded in c0 around inf
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f6434.5%
Simplified34.5%
associate-*r/N/A
associate-*l*N/A
*-commutativeN/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
associate-/l/N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f6431.3%
Applied egg-rr31.3%
Taylor expanded in c0 around 0
/-lowering-/.f64N/A
unpow2N/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
associate-*r*N/A
unpow2N/A
associate-*r*N/A
associate-*r*N/A
*-lowering-*.f64N/A
unpow2N/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f6434.5%
Simplified34.5%
associate-*r*N/A
*-commutativeN/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f6442.6%
Applied egg-rr42.6%
Final simplification37.4%
(FPCore (c0 w h D d M)
:precision binary64
(if (<= d 2.9e-140)
0.0
(if (<= d 3.5e+187)
(* (/ (* c0 (* d d)) D) (/ c0 (* w (* w (* h D)))))
0.0)))
double code(double c0, double w, double h, double D, double d, double M) {
double tmp;
if (d <= 2.9e-140) {
tmp = 0.0;
} else if (d <= 3.5e+187) {
tmp = ((c0 * (d * d)) / D) * (c0 / (w * (w * (h * D))));
} else {
tmp = 0.0;
}
return tmp;
}
real(8) function code(c0, w, h, d, d_1, m)
real(8), intent (in) :: c0
real(8), intent (in) :: w
real(8), intent (in) :: h
real(8), intent (in) :: d
real(8), intent (in) :: d_1
real(8), intent (in) :: m
real(8) :: tmp
if (d_1 <= 2.9d-140) then
tmp = 0.0d0
else if (d_1 <= 3.5d+187) then
tmp = ((c0 * (d_1 * d_1)) / d) * (c0 / (w * (w * (h * d))))
else
tmp = 0.0d0
end if
code = tmp
end function
public static double code(double c0, double w, double h, double D, double d, double M) {
double tmp;
if (d <= 2.9e-140) {
tmp = 0.0;
} else if (d <= 3.5e+187) {
tmp = ((c0 * (d * d)) / D) * (c0 / (w * (w * (h * D))));
} else {
tmp = 0.0;
}
return tmp;
}
def code(c0, w, h, D, d, M): tmp = 0 if d <= 2.9e-140: tmp = 0.0 elif d <= 3.5e+187: tmp = ((c0 * (d * d)) / D) * (c0 / (w * (w * (h * D)))) else: tmp = 0.0 return tmp
function code(c0, w, h, D, d, M) tmp = 0.0 if (d <= 2.9e-140) tmp = 0.0; elseif (d <= 3.5e+187) tmp = Float64(Float64(Float64(c0 * Float64(d * d)) / D) * Float64(c0 / Float64(w * Float64(w * Float64(h * D))))); else tmp = 0.0; end return tmp end
function tmp_2 = code(c0, w, h, D, d, M) tmp = 0.0; if (d <= 2.9e-140) tmp = 0.0; elseif (d <= 3.5e+187) tmp = ((c0 * (d * d)) / D) * (c0 / (w * (w * (h * D)))); else tmp = 0.0; end tmp_2 = tmp; end
code[c0_, w_, h_, D_, d_, M_] := If[LessEqual[d, 2.9e-140], 0.0, If[LessEqual[d, 3.5e+187], N[(N[(N[(c0 * N[(d * d), $MachinePrecision]), $MachinePrecision] / D), $MachinePrecision] * N[(c0 / N[(w * N[(w * N[(h * D), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], 0.0]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;d \leq 2.9 \cdot 10^{-140}:\\
\;\;\;\;0\\
\mathbf{elif}\;d \leq 3.5 \cdot 10^{+187}:\\
\;\;\;\;\frac{c0 \cdot \left(d \cdot d\right)}{D} \cdot \frac{c0}{w \cdot \left(w \cdot \left(h \cdot D\right)\right)}\\
\mathbf{else}:\\
\;\;\;\;0\\
\end{array}
\end{array}
if d < 2.89999999999999997e-140 or 3.4999999999999998e187 < d Initial program 21.8%
*-lowering-*.f64N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
+-lowering-+.f64N/A
Simplified20.4%
Taylor expanded in c0 around -inf
associate-*r*N/A
mul-1-negN/A
distribute-lft1-inN/A
metadata-evalN/A
mul0-lftN/A
distribute-lft-neg-inN/A
distribute-rgt-neg-inN/A
metadata-evalN/A
*-lowering-*.f6430.3%
Simplified30.3%
mul0-rgtN/A
mul0-rgt32.9%
Applied egg-rr32.9%
if 2.89999999999999997e-140 < d < 3.4999999999999998e187Initial program 31.2%
*-lowering-*.f64N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
+-lowering-+.f64N/A
Simplified26.7%
Taylor expanded in c0 around inf
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f6440.2%
Simplified40.2%
associate-*r/N/A
associate-*l*N/A
*-commutativeN/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
associate-/l/N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f6447.0%
Applied egg-rr47.0%
Taylor expanded in c0 around 0
/-lowering-/.f64N/A
unpow2N/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
associate-*r*N/A
unpow2N/A
associate-*r*N/A
associate-*r*N/A
*-lowering-*.f64N/A
unpow2N/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f6440.2%
Simplified40.2%
*-commutativeN/A
associate-*l*N/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
*-commutativeN/A
associate-*r*N/A
*-commutativeN/A
*-commutativeN/A
*-commutativeN/A
*-lowering-*.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f6444.0%
Applied egg-rr44.0%
Final simplification36.6%
(FPCore (c0 w h D d M)
:precision binary64
(let* ((t_0 (* w (* h D))))
(if (<= c0 -2.15e-119)
(* (/ (* c0 c0) (* D t_0)) (/ (* d d) w))
(if (<= c0 7.5e-52) 0.0 (* (/ (* c0 c0) D) (/ (* d d) (* w t_0)))))))
double code(double c0, double w, double h, double D, double d, double M) {
double t_0 = w * (h * D);
double tmp;
if (c0 <= -2.15e-119) {
tmp = ((c0 * c0) / (D * t_0)) * ((d * d) / w);
} else if (c0 <= 7.5e-52) {
tmp = 0.0;
} else {
tmp = ((c0 * c0) / D) * ((d * d) / (w * t_0));
}
return tmp;
}
real(8) function code(c0, w, h, d, d_1, m)
real(8), intent (in) :: c0
real(8), intent (in) :: w
real(8), intent (in) :: h
real(8), intent (in) :: d
real(8), intent (in) :: d_1
real(8), intent (in) :: m
real(8) :: t_0
real(8) :: tmp
t_0 = w * (h * d)
if (c0 <= (-2.15d-119)) then
tmp = ((c0 * c0) / (d * t_0)) * ((d_1 * d_1) / w)
else if (c0 <= 7.5d-52) then
tmp = 0.0d0
else
tmp = ((c0 * c0) / d) * ((d_1 * d_1) / (w * t_0))
end if
code = tmp
end function
public static double code(double c0, double w, double h, double D, double d, double M) {
double t_0 = w * (h * D);
double tmp;
if (c0 <= -2.15e-119) {
tmp = ((c0 * c0) / (D * t_0)) * ((d * d) / w);
} else if (c0 <= 7.5e-52) {
tmp = 0.0;
} else {
tmp = ((c0 * c0) / D) * ((d * d) / (w * t_0));
}
return tmp;
}
def code(c0, w, h, D, d, M): t_0 = w * (h * D) tmp = 0 if c0 <= -2.15e-119: tmp = ((c0 * c0) / (D * t_0)) * ((d * d) / w) elif c0 <= 7.5e-52: tmp = 0.0 else: tmp = ((c0 * c0) / D) * ((d * d) / (w * t_0)) return tmp
function code(c0, w, h, D, d, M) t_0 = Float64(w * Float64(h * D)) tmp = 0.0 if (c0 <= -2.15e-119) tmp = Float64(Float64(Float64(c0 * c0) / Float64(D * t_0)) * Float64(Float64(d * d) / w)); elseif (c0 <= 7.5e-52) tmp = 0.0; else tmp = Float64(Float64(Float64(c0 * c0) / D) * Float64(Float64(d * d) / Float64(w * t_0))); end return tmp end
function tmp_2 = code(c0, w, h, D, d, M) t_0 = w * (h * D); tmp = 0.0; if (c0 <= -2.15e-119) tmp = ((c0 * c0) / (D * t_0)) * ((d * d) / w); elseif (c0 <= 7.5e-52) tmp = 0.0; else tmp = ((c0 * c0) / D) * ((d * d) / (w * t_0)); end tmp_2 = tmp; end
code[c0_, w_, h_, D_, d_, M_] := Block[{t$95$0 = N[(w * N[(h * D), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[c0, -2.15e-119], N[(N[(N[(c0 * c0), $MachinePrecision] / N[(D * t$95$0), $MachinePrecision]), $MachinePrecision] * N[(N[(d * d), $MachinePrecision] / w), $MachinePrecision]), $MachinePrecision], If[LessEqual[c0, 7.5e-52], 0.0, N[(N[(N[(c0 * c0), $MachinePrecision] / D), $MachinePrecision] * N[(N[(d * d), $MachinePrecision] / N[(w * t$95$0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := w \cdot \left(h \cdot D\right)\\
\mathbf{if}\;c0 \leq -2.15 \cdot 10^{-119}:\\
\;\;\;\;\frac{c0 \cdot c0}{D \cdot t\_0} \cdot \frac{d \cdot d}{w}\\
\mathbf{elif}\;c0 \leq 7.5 \cdot 10^{-52}:\\
\;\;\;\;0\\
\mathbf{else}:\\
\;\;\;\;\frac{c0 \cdot c0}{D} \cdot \frac{d \cdot d}{w \cdot t\_0}\\
\end{array}
\end{array}
if c0 < -2.15e-119Initial program 26.1%
*-lowering-*.f64N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
+-lowering-+.f64N/A
Simplified25.7%
Taylor expanded in c0 around inf
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f6437.5%
Simplified37.5%
associate-*r/N/A
associate-*l*N/A
*-commutativeN/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
associate-/l/N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f6445.9%
Applied egg-rr45.9%
Taylor expanded in c0 around 0
/-lowering-/.f64N/A
unpow2N/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
associate-*r*N/A
unpow2N/A
associate-*r*N/A
associate-*r*N/A
*-lowering-*.f64N/A
unpow2N/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f6437.2%
Simplified37.2%
associate-*r*N/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-commutativeN/A
associate-*r*N/A
*-commutativeN/A
*-commutativeN/A
*-lowering-*.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f6439.2%
Applied egg-rr39.2%
if -2.15e-119 < c0 < 7.50000000000000006e-52Initial program 21.7%
*-lowering-*.f64N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
+-lowering-+.f64N/A
Simplified16.8%
Taylor expanded in c0 around -inf
associate-*r*N/A
mul-1-negN/A
distribute-lft1-inN/A
metadata-evalN/A
mul0-lftN/A
distribute-lft-neg-inN/A
distribute-rgt-neg-inN/A
metadata-evalN/A
*-lowering-*.f6450.5%
Simplified50.5%
mul0-rgtN/A
mul0-rgt50.5%
Applied egg-rr50.5%
if 7.50000000000000006e-52 < c0 Initial program 26.8%
*-lowering-*.f64N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
+-lowering-+.f64N/A
Simplified24.4%
Taylor expanded in c0 around inf
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f6442.7%
Simplified42.7%
associate-*r/N/A
associate-*l*N/A
*-commutativeN/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
associate-/l/N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f6445.6%
Applied egg-rr45.6%
Taylor expanded in c0 around 0
/-lowering-/.f64N/A
unpow2N/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
associate-*r*N/A
unpow2N/A
associate-*r*N/A
associate-*r*N/A
*-lowering-*.f64N/A
unpow2N/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f6444.5%
Simplified44.5%
associate-*r*N/A
associate-*l*N/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-commutativeN/A
associate-*r*N/A
*-commutativeN/A
*-commutativeN/A
*-commutativeN/A
*-lowering-*.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f6444.0%
Applied egg-rr44.0%
Final simplification44.2%
(FPCore (c0 w h D d M) :precision binary64 (let* ((t_0 (* (/ (* c0 c0) D) (/ (* d d) (* w (* w (* h D))))))) (if (<= c0 -4.6e-117) t_0 (if (<= c0 8.6e-51) 0.0 t_0))))
double code(double c0, double w, double h, double D, double d, double M) {
double t_0 = ((c0 * c0) / D) * ((d * d) / (w * (w * (h * D))));
double tmp;
if (c0 <= -4.6e-117) {
tmp = t_0;
} else if (c0 <= 8.6e-51) {
tmp = 0.0;
} else {
tmp = t_0;
}
return tmp;
}
real(8) function code(c0, w, h, d, d_1, m)
real(8), intent (in) :: c0
real(8), intent (in) :: w
real(8), intent (in) :: h
real(8), intent (in) :: d
real(8), intent (in) :: d_1
real(8), intent (in) :: m
real(8) :: t_0
real(8) :: tmp
t_0 = ((c0 * c0) / d) * ((d_1 * d_1) / (w * (w * (h * d))))
if (c0 <= (-4.6d-117)) then
tmp = t_0
else if (c0 <= 8.6d-51) then
tmp = 0.0d0
else
tmp = t_0
end if
code = tmp
end function
public static double code(double c0, double w, double h, double D, double d, double M) {
double t_0 = ((c0 * c0) / D) * ((d * d) / (w * (w * (h * D))));
double tmp;
if (c0 <= -4.6e-117) {
tmp = t_0;
} else if (c0 <= 8.6e-51) {
tmp = 0.0;
} else {
tmp = t_0;
}
return tmp;
}
def code(c0, w, h, D, d, M): t_0 = ((c0 * c0) / D) * ((d * d) / (w * (w * (h * D)))) tmp = 0 if c0 <= -4.6e-117: tmp = t_0 elif c0 <= 8.6e-51: tmp = 0.0 else: tmp = t_0 return tmp
function code(c0, w, h, D, d, M) t_0 = Float64(Float64(Float64(c0 * c0) / D) * Float64(Float64(d * d) / Float64(w * Float64(w * Float64(h * D))))) tmp = 0.0 if (c0 <= -4.6e-117) tmp = t_0; elseif (c0 <= 8.6e-51) tmp = 0.0; else tmp = t_0; end return tmp end
function tmp_2 = code(c0, w, h, D, d, M) t_0 = ((c0 * c0) / D) * ((d * d) / (w * (w * (h * D)))); tmp = 0.0; if (c0 <= -4.6e-117) tmp = t_0; elseif (c0 <= 8.6e-51) tmp = 0.0; else tmp = t_0; end tmp_2 = tmp; end
code[c0_, w_, h_, D_, d_, M_] := Block[{t$95$0 = N[(N[(N[(c0 * c0), $MachinePrecision] / D), $MachinePrecision] * N[(N[(d * d), $MachinePrecision] / N[(w * N[(w * N[(h * D), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[c0, -4.6e-117], t$95$0, If[LessEqual[c0, 8.6e-51], 0.0, t$95$0]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \frac{c0 \cdot c0}{D} \cdot \frac{d \cdot d}{w \cdot \left(w \cdot \left(h \cdot D\right)\right)}\\
\mathbf{if}\;c0 \leq -4.6 \cdot 10^{-117}:\\
\;\;\;\;t\_0\\
\mathbf{elif}\;c0 \leq 8.6 \cdot 10^{-51}:\\
\;\;\;\;0\\
\mathbf{else}:\\
\;\;\;\;t\_0\\
\end{array}
\end{array}
if c0 < -4.59999999999999989e-117 or 8.5999999999999995e-51 < c0 Initial program 26.3%
*-lowering-*.f64N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
+-lowering-+.f64N/A
Simplified24.9%
Taylor expanded in c0 around inf
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f6439.7%
Simplified39.7%
associate-*r/N/A
associate-*l*N/A
*-commutativeN/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
associate-/l/N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f6445.4%
Applied egg-rr45.4%
Taylor expanded in c0 around 0
/-lowering-/.f64N/A
unpow2N/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
associate-*r*N/A
unpow2N/A
associate-*r*N/A
associate-*r*N/A
*-lowering-*.f64N/A
unpow2N/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f6440.7%
Simplified40.7%
associate-*r*N/A
associate-*l*N/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-commutativeN/A
associate-*r*N/A
*-commutativeN/A
*-commutativeN/A
*-commutativeN/A
*-lowering-*.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f6440.0%
Applied egg-rr40.0%
if -4.59999999999999989e-117 < c0 < 8.5999999999999995e-51Initial program 22.0%
*-lowering-*.f64N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
+-lowering-+.f64N/A
Simplified17.3%
Taylor expanded in c0 around -inf
associate-*r*N/A
mul-1-negN/A
distribute-lft1-inN/A
metadata-evalN/A
mul0-lftN/A
distribute-lft-neg-inN/A
distribute-rgt-neg-inN/A
metadata-evalN/A
*-lowering-*.f6449.9%
Simplified49.9%
mul0-rgtN/A
mul0-rgt49.9%
Applied egg-rr49.9%
Final simplification43.1%
(FPCore (c0 w h D d M) :precision binary64 (if (<= D 1.9e-239) 0.0 (* (/ d D) (/ (/ (/ d D) (/ h (* 2.0 (/ c0 w)))) (/ 2.0 (/ c0 w))))))
double code(double c0, double w, double h, double D, double d, double M) {
double tmp;
if (D <= 1.9e-239) {
tmp = 0.0;
} else {
tmp = (d / D) * (((d / D) / (h / (2.0 * (c0 / w)))) / (2.0 / (c0 / w)));
}
return tmp;
}
real(8) function code(c0, w, h, d, d_1, m)
real(8), intent (in) :: c0
real(8), intent (in) :: w
real(8), intent (in) :: h
real(8), intent (in) :: d
real(8), intent (in) :: d_1
real(8), intent (in) :: m
real(8) :: tmp
if (d <= 1.9d-239) then
tmp = 0.0d0
else
tmp = (d_1 / d) * (((d_1 / d) / (h / (2.0d0 * (c0 / w)))) / (2.0d0 / (c0 / w)))
end if
code = tmp
end function
public static double code(double c0, double w, double h, double D, double d, double M) {
double tmp;
if (D <= 1.9e-239) {
tmp = 0.0;
} else {
tmp = (d / D) * (((d / D) / (h / (2.0 * (c0 / w)))) / (2.0 / (c0 / w)));
}
return tmp;
}
def code(c0, w, h, D, d, M): tmp = 0 if D <= 1.9e-239: tmp = 0.0 else: tmp = (d / D) * (((d / D) / (h / (2.0 * (c0 / w)))) / (2.0 / (c0 / w))) return tmp
function code(c0, w, h, D, d, M) tmp = 0.0 if (D <= 1.9e-239) tmp = 0.0; else tmp = Float64(Float64(d / D) * Float64(Float64(Float64(d / D) / Float64(h / Float64(2.0 * Float64(c0 / w)))) / Float64(2.0 / Float64(c0 / w)))); end return tmp end
function tmp_2 = code(c0, w, h, D, d, M) tmp = 0.0; if (D <= 1.9e-239) tmp = 0.0; else tmp = (d / D) * (((d / D) / (h / (2.0 * (c0 / w)))) / (2.0 / (c0 / w))); end tmp_2 = tmp; end
code[c0_, w_, h_, D_, d_, M_] := If[LessEqual[D, 1.9e-239], 0.0, N[(N[(d / D), $MachinePrecision] * N[(N[(N[(d / D), $MachinePrecision] / N[(h / N[(2.0 * N[(c0 / w), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(2.0 / N[(c0 / w), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;D \leq 1.9 \cdot 10^{-239}:\\
\;\;\;\;0\\
\mathbf{else}:\\
\;\;\;\;\frac{d}{D} \cdot \frac{\frac{\frac{d}{D}}{\frac{h}{2 \cdot \frac{c0}{w}}}}{\frac{2}{\frac{c0}{w}}}\\
\end{array}
\end{array}
if D < 1.9000000000000001e-239Initial program 22.6%
*-lowering-*.f64N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
+-lowering-+.f64N/A
Simplified20.4%
Taylor expanded in c0 around -inf
associate-*r*N/A
mul-1-negN/A
distribute-lft1-inN/A
metadata-evalN/A
mul0-lftN/A
distribute-lft-neg-inN/A
distribute-rgt-neg-inN/A
metadata-evalN/A
*-lowering-*.f6431.9%
Simplified31.9%
mul0-rgtN/A
mul0-rgt36.0%
Applied egg-rr36.0%
if 1.9000000000000001e-239 < D Initial program 28.8%
*-lowering-*.f64N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
+-lowering-+.f64N/A
Simplified26.0%
Taylor expanded in c0 around inf
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f6438.5%
Simplified38.5%
associate-*r*N/A
*-commutativeN/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
*-commutativeN/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f6434.8%
Applied egg-rr34.8%
*-commutativeN/A
times-fracN/A
associate-*l*N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
times-fracN/A
clear-numN/A
frac-timesN/A
metadata-evalN/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
/-lowering-/.f6454.2%
Applied egg-rr54.2%
associate-/l/N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
clear-numN/A
un-div-invN/A
/-lowering-/.f64N/A
Applied egg-rr55.0%
(FPCore (c0 w h D d M) :precision binary64 (if (<= D 2.1e-239) 0.0 (* (/ d D) (* (/ d D) (/ (/ c0 (* 2.0 w)) (/ (* w h) (* c0 2.0)))))))
double code(double c0, double w, double h, double D, double d, double M) {
double tmp;
if (D <= 2.1e-239) {
tmp = 0.0;
} else {
tmp = (d / D) * ((d / D) * ((c0 / (2.0 * w)) / ((w * h) / (c0 * 2.0))));
}
return tmp;
}
real(8) function code(c0, w, h, d, d_1, m)
real(8), intent (in) :: c0
real(8), intent (in) :: w
real(8), intent (in) :: h
real(8), intent (in) :: d
real(8), intent (in) :: d_1
real(8), intent (in) :: m
real(8) :: tmp
if (d <= 2.1d-239) then
tmp = 0.0d0
else
tmp = (d_1 / d) * ((d_1 / d) * ((c0 / (2.0d0 * w)) / ((w * h) / (c0 * 2.0d0))))
end if
code = tmp
end function
public static double code(double c0, double w, double h, double D, double d, double M) {
double tmp;
if (D <= 2.1e-239) {
tmp = 0.0;
} else {
tmp = (d / D) * ((d / D) * ((c0 / (2.0 * w)) / ((w * h) / (c0 * 2.0))));
}
return tmp;
}
def code(c0, w, h, D, d, M): tmp = 0 if D <= 2.1e-239: tmp = 0.0 else: tmp = (d / D) * ((d / D) * ((c0 / (2.0 * w)) / ((w * h) / (c0 * 2.0)))) return tmp
function code(c0, w, h, D, d, M) tmp = 0.0 if (D <= 2.1e-239) tmp = 0.0; else tmp = Float64(Float64(d / D) * Float64(Float64(d / D) * Float64(Float64(c0 / Float64(2.0 * w)) / Float64(Float64(w * h) / Float64(c0 * 2.0))))); end return tmp end
function tmp_2 = code(c0, w, h, D, d, M) tmp = 0.0; if (D <= 2.1e-239) tmp = 0.0; else tmp = (d / D) * ((d / D) * ((c0 / (2.0 * w)) / ((w * h) / (c0 * 2.0)))); end tmp_2 = tmp; end
code[c0_, w_, h_, D_, d_, M_] := If[LessEqual[D, 2.1e-239], 0.0, N[(N[(d / D), $MachinePrecision] * N[(N[(d / D), $MachinePrecision] * N[(N[(c0 / N[(2.0 * w), $MachinePrecision]), $MachinePrecision] / N[(N[(w * h), $MachinePrecision] / N[(c0 * 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;D \leq 2.1 \cdot 10^{-239}:\\
\;\;\;\;0\\
\mathbf{else}:\\
\;\;\;\;\frac{d}{D} \cdot \left(\frac{d}{D} \cdot \frac{\frac{c0}{2 \cdot w}}{\frac{w \cdot h}{c0 \cdot 2}}\right)\\
\end{array}
\end{array}
if D < 2.1000000000000002e-239Initial program 22.6%
*-lowering-*.f64N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
+-lowering-+.f64N/A
Simplified20.4%
Taylor expanded in c0 around -inf
associate-*r*N/A
mul-1-negN/A
distribute-lft1-inN/A
metadata-evalN/A
mul0-lftN/A
distribute-lft-neg-inN/A
distribute-rgt-neg-inN/A
metadata-evalN/A
*-lowering-*.f6431.9%
Simplified31.9%
mul0-rgtN/A
mul0-rgt36.0%
Applied egg-rr36.0%
if 2.1000000000000002e-239 < D Initial program 28.8%
*-lowering-*.f64N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
+-lowering-+.f64N/A
Simplified26.0%
Taylor expanded in c0 around inf
associate-*r/N/A
/-lowering-/.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
unpow2N/A
*-lowering-*.f64N/A
*-commutativeN/A
*-lowering-*.f6438.5%
Simplified38.5%
associate-*r/N/A
associate-*l*N/A
*-commutativeN/A
times-fracN/A
*-lowering-*.f64N/A
/-lowering-/.f64N/A
associate-/l/N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-lowering-*.f64N/A
*-commutativeN/A
associate-*l*N/A
*-lowering-*.f64N/A
*-lowering-*.f6442.5%
Applied egg-rr42.5%
associate-*l/N/A
associate-/l*N/A
associate-/r*N/A
associate-/l/N/A
associate-*r*N/A
*-commutativeN/A
associate-/r*N/A
*-commutativeN/A
associate-*r*N/A
associate-*l/N/A
associate-/r*N/A
associate-*r/N/A
associate-*r*N/A
times-fracN/A
Applied egg-rr50.3%
Final simplification41.4%
(FPCore (c0 w h D d M) :precision binary64 0.0)
double code(double c0, double w, double h, double D, double d, double M) {
return 0.0;
}
real(8) function code(c0, w, h, d, d_1, m)
real(8), intent (in) :: c0
real(8), intent (in) :: w
real(8), intent (in) :: h
real(8), intent (in) :: d
real(8), intent (in) :: d_1
real(8), intent (in) :: m
code = 0.0d0
end function
public static double code(double c0, double w, double h, double D, double d, double M) {
return 0.0;
}
def code(c0, w, h, D, d, M): return 0.0
function code(c0, w, h, D, d, M) return 0.0 end
function tmp = code(c0, w, h, D, d, M) tmp = 0.0; end
code[c0_, w_, h_, D_, d_, M_] := 0.0
\begin{array}{l}
\\
0
\end{array}
Initial program 24.9%
*-lowering-*.f64N/A
associate-/r*N/A
/-lowering-/.f64N/A
/-lowering-/.f64N/A
+-lowering-+.f64N/A
Simplified22.5%
Taylor expanded in c0 around -inf
associate-*r*N/A
mul-1-negN/A
distribute-lft1-inN/A
metadata-evalN/A
mul0-lftN/A
distribute-lft-neg-inN/A
distribute-rgt-neg-inN/A
metadata-evalN/A
*-lowering-*.f6430.4%
Simplified30.4%
mul0-rgtN/A
mul0-rgt33.8%
Applied egg-rr33.8%
herbie shell --seed 2024161
(FPCore (c0 w h D d M)
:name "Henrywood and Agarwal, Equation (13)"
:precision binary64
(* (/ c0 (* 2.0 w)) (+ (/ (* c0 (* d d)) (* (* w h) (* D D))) (sqrt (- (* (/ (* c0 (* d d)) (* (* w h) (* D D))) (/ (* c0 (* d d)) (* (* w h) (* D D)))) (* M M))))))