
(FPCore (alpha beta) :precision binary64 (/ (+ (/ (- beta alpha) (+ (+ alpha beta) 2.0)) 1.0) 2.0))
double code(double alpha, double beta) {
return (((beta - alpha) / ((alpha + beta) + 2.0)) + 1.0) / 2.0;
}
real(8) function code(alpha, beta)
real(8), intent (in) :: alpha
real(8), intent (in) :: beta
code = (((beta - alpha) / ((alpha + beta) + 2.0d0)) + 1.0d0) / 2.0d0
end function
public static double code(double alpha, double beta) {
return (((beta - alpha) / ((alpha + beta) + 2.0)) + 1.0) / 2.0;
}
def code(alpha, beta): return (((beta - alpha) / ((alpha + beta) + 2.0)) + 1.0) / 2.0
function code(alpha, beta) return Float64(Float64(Float64(Float64(beta - alpha) / Float64(Float64(alpha + beta) + 2.0)) + 1.0) / 2.0) end
function tmp = code(alpha, beta) tmp = (((beta - alpha) / ((alpha + beta) + 2.0)) + 1.0) / 2.0; end
code[alpha_, beta_] := N[(N[(N[(N[(beta - alpha), $MachinePrecision] / N[(N[(alpha + beta), $MachinePrecision] + 2.0), $MachinePrecision]), $MachinePrecision] + 1.0), $MachinePrecision] / 2.0), $MachinePrecision]
\begin{array}{l}
\\
\frac{\frac{\beta - \alpha}{\left(\alpha + \beta\right) + 2} + 1}{2}
\end{array}
Sampling outcomes in binary64 precision:
Herbie found 8 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (alpha beta) :precision binary64 (/ (+ (/ (- beta alpha) (+ (+ alpha beta) 2.0)) 1.0) 2.0))
double code(double alpha, double beta) {
return (((beta - alpha) / ((alpha + beta) + 2.0)) + 1.0) / 2.0;
}
real(8) function code(alpha, beta)
real(8), intent (in) :: alpha
real(8), intent (in) :: beta
code = (((beta - alpha) / ((alpha + beta) + 2.0d0)) + 1.0d0) / 2.0d0
end function
public static double code(double alpha, double beta) {
return (((beta - alpha) / ((alpha + beta) + 2.0)) + 1.0) / 2.0;
}
def code(alpha, beta): return (((beta - alpha) / ((alpha + beta) + 2.0)) + 1.0) / 2.0
function code(alpha, beta) return Float64(Float64(Float64(Float64(beta - alpha) / Float64(Float64(alpha + beta) + 2.0)) + 1.0) / 2.0) end
function tmp = code(alpha, beta) tmp = (((beta - alpha) / ((alpha + beta) + 2.0)) + 1.0) / 2.0; end
code[alpha_, beta_] := N[(N[(N[(N[(beta - alpha), $MachinePrecision] / N[(N[(alpha + beta), $MachinePrecision] + 2.0), $MachinePrecision]), $MachinePrecision] + 1.0), $MachinePrecision] / 2.0), $MachinePrecision]
\begin{array}{l}
\\
\frac{\frac{\beta - \alpha}{\left(\alpha + \beta\right) + 2} + 1}{2}
\end{array}
(FPCore (alpha beta) :precision binary64 (if (<= (/ (- beta alpha) (+ (+ beta alpha) 2.0)) -0.9999999) (* -0.5 (/ (- (- -2.0 beta) beta) alpha)) (+ 0.5 (* (- alpha beta) (/ -0.5 (+ (+ (+ beta alpha) 3.0) -1.0))))))
double code(double alpha, double beta) {
double tmp;
if (((beta - alpha) / ((beta + alpha) + 2.0)) <= -0.9999999) {
tmp = -0.5 * (((-2.0 - beta) - beta) / alpha);
} else {
tmp = 0.5 + ((alpha - beta) * (-0.5 / (((beta + alpha) + 3.0) + -1.0)));
}
return tmp;
}
real(8) function code(alpha, beta)
real(8), intent (in) :: alpha
real(8), intent (in) :: beta
real(8) :: tmp
if (((beta - alpha) / ((beta + alpha) + 2.0d0)) <= (-0.9999999d0)) then
tmp = (-0.5d0) * ((((-2.0d0) - beta) - beta) / alpha)
else
tmp = 0.5d0 + ((alpha - beta) * ((-0.5d0) / (((beta + alpha) + 3.0d0) + (-1.0d0))))
end if
code = tmp
end function
public static double code(double alpha, double beta) {
double tmp;
if (((beta - alpha) / ((beta + alpha) + 2.0)) <= -0.9999999) {
tmp = -0.5 * (((-2.0 - beta) - beta) / alpha);
} else {
tmp = 0.5 + ((alpha - beta) * (-0.5 / (((beta + alpha) + 3.0) + -1.0)));
}
return tmp;
}
def code(alpha, beta): tmp = 0 if ((beta - alpha) / ((beta + alpha) + 2.0)) <= -0.9999999: tmp = -0.5 * (((-2.0 - beta) - beta) / alpha) else: tmp = 0.5 + ((alpha - beta) * (-0.5 / (((beta + alpha) + 3.0) + -1.0))) return tmp
function code(alpha, beta) tmp = 0.0 if (Float64(Float64(beta - alpha) / Float64(Float64(beta + alpha) + 2.0)) <= -0.9999999) tmp = Float64(-0.5 * Float64(Float64(Float64(-2.0 - beta) - beta) / alpha)); else tmp = Float64(0.5 + Float64(Float64(alpha - beta) * Float64(-0.5 / Float64(Float64(Float64(beta + alpha) + 3.0) + -1.0)))); end return tmp end
function tmp_2 = code(alpha, beta) tmp = 0.0; if (((beta - alpha) / ((beta + alpha) + 2.0)) <= -0.9999999) tmp = -0.5 * (((-2.0 - beta) - beta) / alpha); else tmp = 0.5 + ((alpha - beta) * (-0.5 / (((beta + alpha) + 3.0) + -1.0))); end tmp_2 = tmp; end
code[alpha_, beta_] := If[LessEqual[N[(N[(beta - alpha), $MachinePrecision] / N[(N[(beta + alpha), $MachinePrecision] + 2.0), $MachinePrecision]), $MachinePrecision], -0.9999999], N[(-0.5 * N[(N[(N[(-2.0 - beta), $MachinePrecision] - beta), $MachinePrecision] / alpha), $MachinePrecision]), $MachinePrecision], N[(0.5 + N[(N[(alpha - beta), $MachinePrecision] * N[(-0.5 / N[(N[(N[(beta + alpha), $MachinePrecision] + 3.0), $MachinePrecision] + -1.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\frac{\beta - \alpha}{\left(\beta + \alpha\right) + 2} \leq -0.9999999:\\
\;\;\;\;-0.5 \cdot \frac{\left(-2 - \beta\right) - \beta}{\alpha}\\
\mathbf{else}:\\
\;\;\;\;0.5 + \left(\alpha - \beta\right) \cdot \frac{-0.5}{\left(\left(\beta + \alpha\right) + 3\right) + -1}\\
\end{array}
\end{array}
if (/.f64 (-.f64 beta alpha) (+.f64 (+.f64 alpha beta) #s(literal 2 binary64))) < -0.999999900000000053Initial program 6.5%
+-commutative6.5%
sub-neg6.5%
+-commutative6.5%
neg-sub06.5%
associate-+l-6.5%
sub0-neg6.5%
distribute-frac-neg6.5%
+-commutative6.5%
sub-neg6.5%
div-sub6.5%
sub-neg6.5%
metadata-eval6.5%
neg-mul-16.5%
*-commutative6.5%
+-commutative6.5%
associate-/l/6.5%
associate-*l/6.5%
Simplified6.7%
Taylor expanded in alpha around inf 99.4%
associate--r+99.4%
sub-neg99.4%
neg-mul-199.4%
distribute-neg-in99.4%
+-commutative99.4%
distribute-neg-in99.4%
metadata-eval99.4%
unsub-neg99.4%
Simplified99.4%
if -0.999999900000000053 < (/.f64 (-.f64 beta alpha) (+.f64 (+.f64 alpha beta) #s(literal 2 binary64))) Initial program 99.8%
+-commutative99.8%
sub-neg99.8%
+-commutative99.8%
neg-sub099.8%
associate-+l-99.8%
sub0-neg99.8%
distribute-frac-neg99.8%
+-commutative99.8%
sub-neg99.8%
div-sub99.8%
sub-neg99.8%
metadata-eval99.8%
neg-mul-199.8%
*-commutative99.8%
+-commutative99.8%
associate-/l/99.8%
associate-*l/99.8%
Simplified99.8%
associate-+r+99.8%
expm1-log1p-u96.7%
expm1-undefine96.6%
associate-+r+96.6%
+-commutative96.6%
associate-+l+96.6%
Applied egg-rr96.6%
sub-neg96.6%
log1p-undefine96.6%
rem-exp-log99.8%
associate-+r+99.8%
+-commutative99.8%
associate-+r+99.8%
associate-+r+99.8%
metadata-eval99.8%
+-commutative99.8%
metadata-eval99.8%
Simplified99.8%
Final simplification99.6%
(FPCore (alpha beta) :precision binary64 (if (<= (/ (- beta alpha) (+ (+ beta alpha) 2.0)) -0.9999999) (* -0.5 (/ (- (- -2.0 beta) beta) alpha)) (+ 0.5 (* (- alpha beta) (/ -0.5 (+ beta (+ alpha 2.0)))))))
double code(double alpha, double beta) {
double tmp;
if (((beta - alpha) / ((beta + alpha) + 2.0)) <= -0.9999999) {
tmp = -0.5 * (((-2.0 - beta) - beta) / alpha);
} else {
tmp = 0.5 + ((alpha - beta) * (-0.5 / (beta + (alpha + 2.0))));
}
return tmp;
}
real(8) function code(alpha, beta)
real(8), intent (in) :: alpha
real(8), intent (in) :: beta
real(8) :: tmp
if (((beta - alpha) / ((beta + alpha) + 2.0d0)) <= (-0.9999999d0)) then
tmp = (-0.5d0) * ((((-2.0d0) - beta) - beta) / alpha)
else
tmp = 0.5d0 + ((alpha - beta) * ((-0.5d0) / (beta + (alpha + 2.0d0))))
end if
code = tmp
end function
public static double code(double alpha, double beta) {
double tmp;
if (((beta - alpha) / ((beta + alpha) + 2.0)) <= -0.9999999) {
tmp = -0.5 * (((-2.0 - beta) - beta) / alpha);
} else {
tmp = 0.5 + ((alpha - beta) * (-0.5 / (beta + (alpha + 2.0))));
}
return tmp;
}
def code(alpha, beta): tmp = 0 if ((beta - alpha) / ((beta + alpha) + 2.0)) <= -0.9999999: tmp = -0.5 * (((-2.0 - beta) - beta) / alpha) else: tmp = 0.5 + ((alpha - beta) * (-0.5 / (beta + (alpha + 2.0)))) return tmp
function code(alpha, beta) tmp = 0.0 if (Float64(Float64(beta - alpha) / Float64(Float64(beta + alpha) + 2.0)) <= -0.9999999) tmp = Float64(-0.5 * Float64(Float64(Float64(-2.0 - beta) - beta) / alpha)); else tmp = Float64(0.5 + Float64(Float64(alpha - beta) * Float64(-0.5 / Float64(beta + Float64(alpha + 2.0))))); end return tmp end
function tmp_2 = code(alpha, beta) tmp = 0.0; if (((beta - alpha) / ((beta + alpha) + 2.0)) <= -0.9999999) tmp = -0.5 * (((-2.0 - beta) - beta) / alpha); else tmp = 0.5 + ((alpha - beta) * (-0.5 / (beta + (alpha + 2.0)))); end tmp_2 = tmp; end
code[alpha_, beta_] := If[LessEqual[N[(N[(beta - alpha), $MachinePrecision] / N[(N[(beta + alpha), $MachinePrecision] + 2.0), $MachinePrecision]), $MachinePrecision], -0.9999999], N[(-0.5 * N[(N[(N[(-2.0 - beta), $MachinePrecision] - beta), $MachinePrecision] / alpha), $MachinePrecision]), $MachinePrecision], N[(0.5 + N[(N[(alpha - beta), $MachinePrecision] * N[(-0.5 / N[(beta + N[(alpha + 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\frac{\beta - \alpha}{\left(\beta + \alpha\right) + 2} \leq -0.9999999:\\
\;\;\;\;-0.5 \cdot \frac{\left(-2 - \beta\right) - \beta}{\alpha}\\
\mathbf{else}:\\
\;\;\;\;0.5 + \left(\alpha - \beta\right) \cdot \frac{-0.5}{\beta + \left(\alpha + 2\right)}\\
\end{array}
\end{array}
if (/.f64 (-.f64 beta alpha) (+.f64 (+.f64 alpha beta) #s(literal 2 binary64))) < -0.999999900000000053Initial program 6.5%
+-commutative6.5%
sub-neg6.5%
+-commutative6.5%
neg-sub06.5%
associate-+l-6.5%
sub0-neg6.5%
distribute-frac-neg6.5%
+-commutative6.5%
sub-neg6.5%
div-sub6.5%
sub-neg6.5%
metadata-eval6.5%
neg-mul-16.5%
*-commutative6.5%
+-commutative6.5%
associate-/l/6.5%
associate-*l/6.5%
Simplified6.7%
Taylor expanded in alpha around inf 99.4%
associate--r+99.4%
sub-neg99.4%
neg-mul-199.4%
distribute-neg-in99.4%
+-commutative99.4%
distribute-neg-in99.4%
metadata-eval99.4%
unsub-neg99.4%
Simplified99.4%
if -0.999999900000000053 < (/.f64 (-.f64 beta alpha) (+.f64 (+.f64 alpha beta) #s(literal 2 binary64))) Initial program 99.8%
+-commutative99.8%
sub-neg99.8%
+-commutative99.8%
neg-sub099.8%
associate-+l-99.8%
sub0-neg99.8%
distribute-frac-neg99.8%
+-commutative99.8%
sub-neg99.8%
div-sub99.8%
sub-neg99.8%
metadata-eval99.8%
neg-mul-199.8%
*-commutative99.8%
+-commutative99.8%
associate-/l/99.8%
associate-*l/99.8%
Simplified99.8%
Final simplification99.6%
(FPCore (alpha beta)
:precision binary64
(let* ((t_0 (+ 0.5 (* alpha -0.25))))
(if (<= alpha -5.2e-204)
t_0
(if (<= alpha -3e-258)
1.0
(if (<= alpha 2.0) t_0 (* -0.5 (/ (- (- -2.0 beta) beta) alpha)))))))
double code(double alpha, double beta) {
double t_0 = 0.5 + (alpha * -0.25);
double tmp;
if (alpha <= -5.2e-204) {
tmp = t_0;
} else if (alpha <= -3e-258) {
tmp = 1.0;
} else if (alpha <= 2.0) {
tmp = t_0;
} else {
tmp = -0.5 * (((-2.0 - beta) - beta) / alpha);
}
return tmp;
}
real(8) function code(alpha, beta)
real(8), intent (in) :: alpha
real(8), intent (in) :: beta
real(8) :: t_0
real(8) :: tmp
t_0 = 0.5d0 + (alpha * (-0.25d0))
if (alpha <= (-5.2d-204)) then
tmp = t_0
else if (alpha <= (-3d-258)) then
tmp = 1.0d0
else if (alpha <= 2.0d0) then
tmp = t_0
else
tmp = (-0.5d0) * ((((-2.0d0) - beta) - beta) / alpha)
end if
code = tmp
end function
public static double code(double alpha, double beta) {
double t_0 = 0.5 + (alpha * -0.25);
double tmp;
if (alpha <= -5.2e-204) {
tmp = t_0;
} else if (alpha <= -3e-258) {
tmp = 1.0;
} else if (alpha <= 2.0) {
tmp = t_0;
} else {
tmp = -0.5 * (((-2.0 - beta) - beta) / alpha);
}
return tmp;
}
def code(alpha, beta): t_0 = 0.5 + (alpha * -0.25) tmp = 0 if alpha <= -5.2e-204: tmp = t_0 elif alpha <= -3e-258: tmp = 1.0 elif alpha <= 2.0: tmp = t_0 else: tmp = -0.5 * (((-2.0 - beta) - beta) / alpha) return tmp
function code(alpha, beta) t_0 = Float64(0.5 + Float64(alpha * -0.25)) tmp = 0.0 if (alpha <= -5.2e-204) tmp = t_0; elseif (alpha <= -3e-258) tmp = 1.0; elseif (alpha <= 2.0) tmp = t_0; else tmp = Float64(-0.5 * Float64(Float64(Float64(-2.0 - beta) - beta) / alpha)); end return tmp end
function tmp_2 = code(alpha, beta) t_0 = 0.5 + (alpha * -0.25); tmp = 0.0; if (alpha <= -5.2e-204) tmp = t_0; elseif (alpha <= -3e-258) tmp = 1.0; elseif (alpha <= 2.0) tmp = t_0; else tmp = -0.5 * (((-2.0 - beta) - beta) / alpha); end tmp_2 = tmp; end
code[alpha_, beta_] := Block[{t$95$0 = N[(0.5 + N[(alpha * -0.25), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[alpha, -5.2e-204], t$95$0, If[LessEqual[alpha, -3e-258], 1.0, If[LessEqual[alpha, 2.0], t$95$0, N[(-0.5 * N[(N[(N[(-2.0 - beta), $MachinePrecision] - beta), $MachinePrecision] / alpha), $MachinePrecision]), $MachinePrecision]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := 0.5 + \alpha \cdot -0.25\\
\mathbf{if}\;\alpha \leq -5.2 \cdot 10^{-204}:\\
\;\;\;\;t\_0\\
\mathbf{elif}\;\alpha \leq -3 \cdot 10^{-258}:\\
\;\;\;\;1\\
\mathbf{elif}\;\alpha \leq 2:\\
\;\;\;\;t\_0\\
\mathbf{else}:\\
\;\;\;\;-0.5 \cdot \frac{\left(-2 - \beta\right) - \beta}{\alpha}\\
\end{array}
\end{array}
if alpha < -5.19999999999999965e-204 or -3.00000000000000021e-258 < alpha < 2Initial program 100.0%
+-commutative100.0%
sub-neg100.0%
+-commutative100.0%
neg-sub0100.0%
associate-+l-100.0%
sub0-neg100.0%
distribute-frac-neg100.0%
+-commutative100.0%
sub-neg100.0%
div-sub100.0%
sub-neg100.0%
metadata-eval100.0%
neg-mul-1100.0%
*-commutative100.0%
+-commutative100.0%
associate-/l/100.0%
associate-*l/100.0%
Simplified100.0%
Taylor expanded in alpha around 0 98.9%
+-commutative98.9%
Simplified98.9%
Taylor expanded in beta around 0 72.3%
*-commutative72.3%
Simplified72.3%
if -5.19999999999999965e-204 < alpha < -3.00000000000000021e-258Initial program 100.0%
+-commutative100.0%
sub-neg100.0%
+-commutative100.0%
neg-sub0100.0%
associate-+l-100.0%
sub0-neg100.0%
distribute-frac-neg100.0%
+-commutative100.0%
sub-neg100.0%
div-sub100.0%
sub-neg100.0%
metadata-eval100.0%
neg-mul-1100.0%
*-commutative100.0%
+-commutative100.0%
associate-/l/100.0%
associate-*l/100.0%
Simplified100.0%
Taylor expanded in beta around inf 74.6%
if 2 < alpha Initial program 19.6%
+-commutative19.6%
sub-neg19.6%
+-commutative19.6%
neg-sub019.6%
associate-+l-19.6%
sub0-neg19.6%
distribute-frac-neg19.6%
+-commutative19.6%
sub-neg19.6%
div-sub19.6%
sub-neg19.6%
metadata-eval19.6%
neg-mul-119.6%
*-commutative19.6%
+-commutative19.6%
associate-/l/19.6%
associate-*l/19.6%
Simplified19.8%
Taylor expanded in alpha around inf 86.6%
associate--r+86.6%
sub-neg86.6%
neg-mul-186.6%
distribute-neg-in86.6%
+-commutative86.6%
distribute-neg-in86.6%
metadata-eval86.6%
unsub-neg86.6%
Simplified86.6%
Final simplification78.2%
(FPCore (alpha beta)
:precision binary64
(let* ((t_0 (+ 0.5 (* alpha -0.25))))
(if (<= alpha -5e-203)
t_0
(if (<= alpha -5e-258)
1.0
(if (<= alpha 0.88) t_0 (/ (/ 2.0 alpha) 2.0))))))
double code(double alpha, double beta) {
double t_0 = 0.5 + (alpha * -0.25);
double tmp;
if (alpha <= -5e-203) {
tmp = t_0;
} else if (alpha <= -5e-258) {
tmp = 1.0;
} else if (alpha <= 0.88) {
tmp = t_0;
} else {
tmp = (2.0 / alpha) / 2.0;
}
return tmp;
}
real(8) function code(alpha, beta)
real(8), intent (in) :: alpha
real(8), intent (in) :: beta
real(8) :: t_0
real(8) :: tmp
t_0 = 0.5d0 + (alpha * (-0.25d0))
if (alpha <= (-5d-203)) then
tmp = t_0
else if (alpha <= (-5d-258)) then
tmp = 1.0d0
else if (alpha <= 0.88d0) then
tmp = t_0
else
tmp = (2.0d0 / alpha) / 2.0d0
end if
code = tmp
end function
public static double code(double alpha, double beta) {
double t_0 = 0.5 + (alpha * -0.25);
double tmp;
if (alpha <= -5e-203) {
tmp = t_0;
} else if (alpha <= -5e-258) {
tmp = 1.0;
} else if (alpha <= 0.88) {
tmp = t_0;
} else {
tmp = (2.0 / alpha) / 2.0;
}
return tmp;
}
def code(alpha, beta): t_0 = 0.5 + (alpha * -0.25) tmp = 0 if alpha <= -5e-203: tmp = t_0 elif alpha <= -5e-258: tmp = 1.0 elif alpha <= 0.88: tmp = t_0 else: tmp = (2.0 / alpha) / 2.0 return tmp
function code(alpha, beta) t_0 = Float64(0.5 + Float64(alpha * -0.25)) tmp = 0.0 if (alpha <= -5e-203) tmp = t_0; elseif (alpha <= -5e-258) tmp = 1.0; elseif (alpha <= 0.88) tmp = t_0; else tmp = Float64(Float64(2.0 / alpha) / 2.0); end return tmp end
function tmp_2 = code(alpha, beta) t_0 = 0.5 + (alpha * -0.25); tmp = 0.0; if (alpha <= -5e-203) tmp = t_0; elseif (alpha <= -5e-258) tmp = 1.0; elseif (alpha <= 0.88) tmp = t_0; else tmp = (2.0 / alpha) / 2.0; end tmp_2 = tmp; end
code[alpha_, beta_] := Block[{t$95$0 = N[(0.5 + N[(alpha * -0.25), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[alpha, -5e-203], t$95$0, If[LessEqual[alpha, -5e-258], 1.0, If[LessEqual[alpha, 0.88], t$95$0, N[(N[(2.0 / alpha), $MachinePrecision] / 2.0), $MachinePrecision]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := 0.5 + \alpha \cdot -0.25\\
\mathbf{if}\;\alpha \leq -5 \cdot 10^{-203}:\\
\;\;\;\;t\_0\\
\mathbf{elif}\;\alpha \leq -5 \cdot 10^{-258}:\\
\;\;\;\;1\\
\mathbf{elif}\;\alpha \leq 0.88:\\
\;\;\;\;t\_0\\
\mathbf{else}:\\
\;\;\;\;\frac{\frac{2}{\alpha}}{2}\\
\end{array}
\end{array}
if alpha < -5.0000000000000002e-203 or -4.9999999999999999e-258 < alpha < 0.880000000000000004Initial program 100.0%
+-commutative100.0%
sub-neg100.0%
+-commutative100.0%
neg-sub0100.0%
associate-+l-100.0%
sub0-neg100.0%
distribute-frac-neg100.0%
+-commutative100.0%
sub-neg100.0%
div-sub100.0%
sub-neg100.0%
metadata-eval100.0%
neg-mul-1100.0%
*-commutative100.0%
+-commutative100.0%
associate-/l/100.0%
associate-*l/100.0%
Simplified100.0%
Taylor expanded in alpha around 0 98.9%
+-commutative98.9%
Simplified98.9%
Taylor expanded in beta around 0 72.3%
*-commutative72.3%
Simplified72.3%
if -5.0000000000000002e-203 < alpha < -4.9999999999999999e-258Initial program 100.0%
+-commutative100.0%
sub-neg100.0%
+-commutative100.0%
neg-sub0100.0%
associate-+l-100.0%
sub0-neg100.0%
distribute-frac-neg100.0%
+-commutative100.0%
sub-neg100.0%
div-sub100.0%
sub-neg100.0%
metadata-eval100.0%
neg-mul-1100.0%
*-commutative100.0%
+-commutative100.0%
associate-/l/100.0%
associate-*l/100.0%
Simplified100.0%
Taylor expanded in beta around inf 74.6%
if 0.880000000000000004 < alpha Initial program 19.6%
+-commutative19.6%
Simplified19.6%
expm1-log1p-u19.4%
expm1-undefine19.4%
associate-+r+19.4%
+-commutative19.4%
associate-+l+19.4%
Applied egg-rr19.4%
sub-neg19.4%
log1p-undefine19.5%
rem-exp-log19.7%
+-commutative19.7%
associate-+r+19.7%
metadata-eval19.7%
+-commutative19.7%
+-commutative19.7%
associate-+r+19.7%
metadata-eval19.7%
Simplified19.7%
Taylor expanded in beta around 0 6.2%
+-commutative6.2%
Simplified6.2%
Taylor expanded in alpha around inf 65.0%
Final simplification69.5%
(FPCore (alpha beta) :precision binary64 (if (<= alpha 1200000000.0) (+ 0.5 (* (- alpha beta) (/ -0.5 (+ beta 2.0)))) (* -0.5 (/ (- (- -2.0 beta) beta) alpha))))
double code(double alpha, double beta) {
double tmp;
if (alpha <= 1200000000.0) {
tmp = 0.5 + ((alpha - beta) * (-0.5 / (beta + 2.0)));
} else {
tmp = -0.5 * (((-2.0 - beta) - beta) / alpha);
}
return tmp;
}
real(8) function code(alpha, beta)
real(8), intent (in) :: alpha
real(8), intent (in) :: beta
real(8) :: tmp
if (alpha <= 1200000000.0d0) then
tmp = 0.5d0 + ((alpha - beta) * ((-0.5d0) / (beta + 2.0d0)))
else
tmp = (-0.5d0) * ((((-2.0d0) - beta) - beta) / alpha)
end if
code = tmp
end function
public static double code(double alpha, double beta) {
double tmp;
if (alpha <= 1200000000.0) {
tmp = 0.5 + ((alpha - beta) * (-0.5 / (beta + 2.0)));
} else {
tmp = -0.5 * (((-2.0 - beta) - beta) / alpha);
}
return tmp;
}
def code(alpha, beta): tmp = 0 if alpha <= 1200000000.0: tmp = 0.5 + ((alpha - beta) * (-0.5 / (beta + 2.0))) else: tmp = -0.5 * (((-2.0 - beta) - beta) / alpha) return tmp
function code(alpha, beta) tmp = 0.0 if (alpha <= 1200000000.0) tmp = Float64(0.5 + Float64(Float64(alpha - beta) * Float64(-0.5 / Float64(beta + 2.0)))); else tmp = Float64(-0.5 * Float64(Float64(Float64(-2.0 - beta) - beta) / alpha)); end return tmp end
function tmp_2 = code(alpha, beta) tmp = 0.0; if (alpha <= 1200000000.0) tmp = 0.5 + ((alpha - beta) * (-0.5 / (beta + 2.0))); else tmp = -0.5 * (((-2.0 - beta) - beta) / alpha); end tmp_2 = tmp; end
code[alpha_, beta_] := If[LessEqual[alpha, 1200000000.0], N[(0.5 + N[(N[(alpha - beta), $MachinePrecision] * N[(-0.5 / N[(beta + 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(-0.5 * N[(N[(N[(-2.0 - beta), $MachinePrecision] - beta), $MachinePrecision] / alpha), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\alpha \leq 1200000000:\\
\;\;\;\;0.5 + \left(\alpha - \beta\right) \cdot \frac{-0.5}{\beta + 2}\\
\mathbf{else}:\\
\;\;\;\;-0.5 \cdot \frac{\left(-2 - \beta\right) - \beta}{\alpha}\\
\end{array}
\end{array}
if alpha < 1.2e9Initial program 100.0%
+-commutative100.0%
sub-neg100.0%
+-commutative100.0%
neg-sub0100.0%
associate-+l-100.0%
sub0-neg100.0%
distribute-frac-neg100.0%
+-commutative100.0%
sub-neg100.0%
div-sub100.0%
sub-neg100.0%
metadata-eval100.0%
neg-mul-1100.0%
*-commutative100.0%
+-commutative100.0%
associate-/l/100.0%
associate-*l/100.0%
Simplified100.0%
Taylor expanded in alpha around 0 99.0%
+-commutative99.0%
Simplified99.0%
if 1.2e9 < alpha Initial program 18.9%
+-commutative18.9%
sub-neg18.9%
+-commutative18.9%
neg-sub018.9%
associate-+l-18.9%
sub0-neg18.9%
distribute-frac-neg18.9%
+-commutative18.9%
sub-neg18.9%
div-sub18.9%
sub-neg18.9%
metadata-eval18.9%
neg-mul-118.9%
*-commutative18.9%
+-commutative18.9%
associate-/l/18.9%
associate-*l/18.9%
Simplified19.0%
Taylor expanded in alpha around inf 87.4%
associate--r+87.4%
sub-neg87.4%
neg-mul-187.4%
distribute-neg-in87.4%
+-commutative87.4%
distribute-neg-in87.4%
metadata-eval87.4%
unsub-neg87.4%
Simplified87.4%
Final simplification94.3%
(FPCore (alpha beta) :precision binary64 (if (<= alpha 900000000.0) (/ (+ (/ beta (+ beta 2.0)) 1.0) 2.0) (* -0.5 (/ (- (- -2.0 beta) beta) alpha))))
double code(double alpha, double beta) {
double tmp;
if (alpha <= 900000000.0) {
tmp = ((beta / (beta + 2.0)) + 1.0) / 2.0;
} else {
tmp = -0.5 * (((-2.0 - beta) - beta) / alpha);
}
return tmp;
}
real(8) function code(alpha, beta)
real(8), intent (in) :: alpha
real(8), intent (in) :: beta
real(8) :: tmp
if (alpha <= 900000000.0d0) then
tmp = ((beta / (beta + 2.0d0)) + 1.0d0) / 2.0d0
else
tmp = (-0.5d0) * ((((-2.0d0) - beta) - beta) / alpha)
end if
code = tmp
end function
public static double code(double alpha, double beta) {
double tmp;
if (alpha <= 900000000.0) {
tmp = ((beta / (beta + 2.0)) + 1.0) / 2.0;
} else {
tmp = -0.5 * (((-2.0 - beta) - beta) / alpha);
}
return tmp;
}
def code(alpha, beta): tmp = 0 if alpha <= 900000000.0: tmp = ((beta / (beta + 2.0)) + 1.0) / 2.0 else: tmp = -0.5 * (((-2.0 - beta) - beta) / alpha) return tmp
function code(alpha, beta) tmp = 0.0 if (alpha <= 900000000.0) tmp = Float64(Float64(Float64(beta / Float64(beta + 2.0)) + 1.0) / 2.0); else tmp = Float64(-0.5 * Float64(Float64(Float64(-2.0 - beta) - beta) / alpha)); end return tmp end
function tmp_2 = code(alpha, beta) tmp = 0.0; if (alpha <= 900000000.0) tmp = ((beta / (beta + 2.0)) + 1.0) / 2.0; else tmp = -0.5 * (((-2.0 - beta) - beta) / alpha); end tmp_2 = tmp; end
code[alpha_, beta_] := If[LessEqual[alpha, 900000000.0], N[(N[(N[(beta / N[(beta + 2.0), $MachinePrecision]), $MachinePrecision] + 1.0), $MachinePrecision] / 2.0), $MachinePrecision], N[(-0.5 * N[(N[(N[(-2.0 - beta), $MachinePrecision] - beta), $MachinePrecision] / alpha), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\alpha \leq 900000000:\\
\;\;\;\;\frac{\frac{\beta}{\beta + 2} + 1}{2}\\
\mathbf{else}:\\
\;\;\;\;-0.5 \cdot \frac{\left(-2 - \beta\right) - \beta}{\alpha}\\
\end{array}
\end{array}
if alpha < 9e8Initial program 100.0%
+-commutative100.0%
Simplified100.0%
Taylor expanded in alpha around 0 98.4%
+-commutative98.4%
+-commutative98.4%
Simplified98.4%
if 9e8 < alpha Initial program 18.9%
+-commutative18.9%
sub-neg18.9%
+-commutative18.9%
neg-sub018.9%
associate-+l-18.9%
sub0-neg18.9%
distribute-frac-neg18.9%
+-commutative18.9%
sub-neg18.9%
div-sub18.9%
sub-neg18.9%
metadata-eval18.9%
neg-mul-118.9%
*-commutative18.9%
+-commutative18.9%
associate-/l/18.9%
associate-*l/18.9%
Simplified19.0%
Taylor expanded in alpha around inf 87.4%
associate--r+87.4%
sub-neg87.4%
neg-mul-187.4%
distribute-neg-in87.4%
+-commutative87.4%
distribute-neg-in87.4%
metadata-eval87.4%
unsub-neg87.4%
Simplified87.4%
Final simplification94.0%
(FPCore (alpha beta) :precision binary64 (if (<= beta 225.0) 0.5 1.0))
double code(double alpha, double beta) {
double tmp;
if (beta <= 225.0) {
tmp = 0.5;
} else {
tmp = 1.0;
}
return tmp;
}
real(8) function code(alpha, beta)
real(8), intent (in) :: alpha
real(8), intent (in) :: beta
real(8) :: tmp
if (beta <= 225.0d0) then
tmp = 0.5d0
else
tmp = 1.0d0
end if
code = tmp
end function
public static double code(double alpha, double beta) {
double tmp;
if (beta <= 225.0) {
tmp = 0.5;
} else {
tmp = 1.0;
}
return tmp;
}
def code(alpha, beta): tmp = 0 if beta <= 225.0: tmp = 0.5 else: tmp = 1.0 return tmp
function code(alpha, beta) tmp = 0.0 if (beta <= 225.0) tmp = 0.5; else tmp = 1.0; end return tmp end
function tmp_2 = code(alpha, beta) tmp = 0.0; if (beta <= 225.0) tmp = 0.5; else tmp = 1.0; end tmp_2 = tmp; end
code[alpha_, beta_] := If[LessEqual[beta, 225.0], 0.5, 1.0]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\beta \leq 225:\\
\;\;\;\;0.5\\
\mathbf{else}:\\
\;\;\;\;1\\
\end{array}
\end{array}
if beta < 225Initial program 62.2%
+-commutative62.2%
Simplified62.2%
expm1-log1p-u62.2%
expm1-undefine62.2%
associate-+r+62.2%
+-commutative62.2%
associate-+l+62.2%
Applied egg-rr62.2%
sub-neg62.2%
log1p-undefine62.2%
rem-exp-log62.2%
+-commutative62.2%
associate-+r+62.2%
metadata-eval62.2%
+-commutative62.2%
+-commutative62.2%
associate-+r+62.2%
metadata-eval62.2%
Simplified62.2%
Taylor expanded in beta around 0 61.0%
+-commutative61.0%
Simplified61.0%
Taylor expanded in alpha around 0 58.7%
if 225 < beta Initial program 77.0%
+-commutative77.0%
sub-neg77.0%
+-commutative77.0%
neg-sub077.0%
associate-+l-77.0%
sub0-neg77.0%
distribute-frac-neg77.0%
+-commutative77.0%
sub-neg77.0%
div-sub77.0%
sub-neg77.0%
metadata-eval77.0%
neg-mul-177.0%
*-commutative77.0%
+-commutative77.0%
associate-/l/77.0%
associate-*l/77.0%
Simplified77.2%
Taylor expanded in beta around inf 74.5%
Final simplification64.2%
(FPCore (alpha beta) :precision binary64 1.0)
double code(double alpha, double beta) {
return 1.0;
}
real(8) function code(alpha, beta)
real(8), intent (in) :: alpha
real(8), intent (in) :: beta
code = 1.0d0
end function
public static double code(double alpha, double beta) {
return 1.0;
}
def code(alpha, beta): return 1.0
function code(alpha, beta) return 1.0 end
function tmp = code(alpha, beta) tmp = 1.0; end
code[alpha_, beta_] := 1.0
\begin{array}{l}
\\
1
\end{array}
Initial program 67.3%
+-commutative67.3%
sub-neg67.3%
+-commutative67.3%
neg-sub067.3%
associate-+l-67.3%
sub0-neg67.3%
distribute-frac-neg67.3%
+-commutative67.3%
sub-neg67.3%
div-sub67.3%
sub-neg67.3%
metadata-eval67.3%
neg-mul-167.3%
*-commutative67.3%
+-commutative67.3%
associate-/l/67.3%
associate-*l/67.3%
Simplified67.4%
Taylor expanded in beta around inf 34.5%
Final simplification34.5%
herbie shell --seed 2024079
(FPCore (alpha beta)
:name "Octave 3.8, jcobi/1"
:precision binary64
:pre (and (> alpha -1.0) (> beta -1.0))
(/ (+ (/ (- beta alpha) (+ (+ alpha beta) 2.0)) 1.0) 2.0))