
(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 10 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.5)
(/
(- (+ 1.0 (* beta (- (- 1.0 (/ beta alpha)) (/ 3.0 alpha)))) (/ 2.0 alpha))
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.5) {
tmp = ((1.0 + (beta * ((1.0 - (beta / alpha)) - (3.0 / alpha)))) - (2.0 / alpha)) / 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.5d0)) then
tmp = ((1.0d0 + (beta * ((1.0d0 - (beta / alpha)) - (3.0d0 / alpha)))) - (2.0d0 / alpha)) / 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.5) {
tmp = ((1.0 + (beta * ((1.0 - (beta / alpha)) - (3.0 / alpha)))) - (2.0 / alpha)) / 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.5: tmp = ((1.0 + (beta * ((1.0 - (beta / alpha)) - (3.0 / alpha)))) - (2.0 / alpha)) / 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.5) tmp = Float64(Float64(Float64(1.0 + Float64(beta * Float64(Float64(1.0 - Float64(beta / alpha)) - Float64(3.0 / alpha)))) - Float64(2.0 / alpha)) / 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.5) tmp = ((1.0 + (beta * ((1.0 - (beta / alpha)) - (3.0 / alpha)))) - (2.0 / alpha)) / 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.5], N[(N[(N[(1.0 + N[(beta * N[(N[(1.0 - N[(beta / alpha), $MachinePrecision]), $MachinePrecision] - N[(3.0 / alpha), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] - N[(2.0 / alpha), $MachinePrecision]), $MachinePrecision] / alpha), $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.5:\\
\;\;\;\;\frac{\left(1 + \beta \cdot \left(\left(1 - \frac{\beta}{\alpha}\right) - \frac{3}{\alpha}\right)\right) - \frac{2}{\alpha}}{\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.5Initial program 6.4%
+-commutative6.4%
sub-neg6.4%
+-commutative6.4%
neg-sub06.4%
associate-+l-6.4%
sub0-neg6.4%
distribute-frac-neg6.4%
+-commutative6.4%
sub-neg6.4%
div-sub6.4%
sub-neg6.4%
metadata-eval6.4%
neg-mul-16.4%
*-commutative6.4%
+-commutative6.4%
associate-/l/6.4%
associate-*l/6.4%
Simplified6.2%
Taylor expanded in alpha around inf 97.3%
Taylor expanded in beta around 0 100.0%
mul-1-neg100.0%
associate-*r/100.0%
metadata-eval100.0%
associate-*r/100.0%
metadata-eval100.0%
Simplified100.0%
if -0.5 < (/.f64 (-.f64 beta alpha) (+.f64 (+.f64 alpha beta) #s(literal 2 binary64))) Initial 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%
Final simplification100.0%
(FPCore (alpha beta) :precision binary64 (if (<= (/ (- beta alpha) (+ (+ beta alpha) 2.0)) -0.5) (/ (+ beta 1.0) 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.5) {
tmp = (beta + 1.0) / 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.5d0)) then
tmp = (beta + 1.0d0) / 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.5) {
tmp = (beta + 1.0) / 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.5: tmp = (beta + 1.0) / 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.5) tmp = Float64(Float64(beta + 1.0) / 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.5) tmp = (beta + 1.0) / 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.5], N[(N[(beta + 1.0), $MachinePrecision] / alpha), $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.5:\\
\;\;\;\;\frac{\beta + 1}{\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.5Initial program 6.4%
+-commutative6.4%
Simplified6.4%
Taylor expanded in alpha around inf 99.8%
*-commutative99.8%
Simplified99.8%
Taylor expanded in beta around inf 99.4%
associate-/r*99.7%
Simplified99.7%
Taylor expanded in beta around 0 99.8%
lft-mult-inverse99.7%
associate-*l/99.3%
associate-/r*99.3%
*-lft-identity99.3%
associate-*l/99.3%
distribute-rgt-in99.4%
+-commutative99.4%
rgt-mult-inverse99.3%
associate-*r/96.6%
associate-/r*95.4%
*-lft-identity95.4%
distribute-rgt-in95.4%
associate-*l/95.4%
*-lft-identity95.4%
associate-/l*95.4%
times-frac99.8%
*-inverses99.8%
associate-*r/99.8%
*-lft-identity99.8%
Simplified99.8%
if -0.5 < (/.f64 (-.f64 beta alpha) (+.f64 (+.f64 alpha beta) #s(literal 2 binary64))) Initial 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%
Final simplification99.9%
(FPCore (alpha beta) :precision binary64 (if (<= alpha 1.5e-74) (+ 0.5 (* alpha -0.25)) (if (<= alpha 5.8e+19) 1.0 (/ (+ beta 1.0) alpha))))
double code(double alpha, double beta) {
double tmp;
if (alpha <= 1.5e-74) {
tmp = 0.5 + (alpha * -0.25);
} else if (alpha <= 5.8e+19) {
tmp = 1.0;
} else {
tmp = (beta + 1.0) / alpha;
}
return tmp;
}
real(8) function code(alpha, beta)
real(8), intent (in) :: alpha
real(8), intent (in) :: beta
real(8) :: tmp
if (alpha <= 1.5d-74) then
tmp = 0.5d0 + (alpha * (-0.25d0))
else if (alpha <= 5.8d+19) then
tmp = 1.0d0
else
tmp = (beta + 1.0d0) / alpha
end if
code = tmp
end function
public static double code(double alpha, double beta) {
double tmp;
if (alpha <= 1.5e-74) {
tmp = 0.5 + (alpha * -0.25);
} else if (alpha <= 5.8e+19) {
tmp = 1.0;
} else {
tmp = (beta + 1.0) / alpha;
}
return tmp;
}
def code(alpha, beta): tmp = 0 if alpha <= 1.5e-74: tmp = 0.5 + (alpha * -0.25) elif alpha <= 5.8e+19: tmp = 1.0 else: tmp = (beta + 1.0) / alpha return tmp
function code(alpha, beta) tmp = 0.0 if (alpha <= 1.5e-74) tmp = Float64(0.5 + Float64(alpha * -0.25)); elseif (alpha <= 5.8e+19) tmp = 1.0; else tmp = Float64(Float64(beta + 1.0) / alpha); end return tmp end
function tmp_2 = code(alpha, beta) tmp = 0.0; if (alpha <= 1.5e-74) tmp = 0.5 + (alpha * -0.25); elseif (alpha <= 5.8e+19) tmp = 1.0; else tmp = (beta + 1.0) / alpha; end tmp_2 = tmp; end
code[alpha_, beta_] := If[LessEqual[alpha, 1.5e-74], N[(0.5 + N[(alpha * -0.25), $MachinePrecision]), $MachinePrecision], If[LessEqual[alpha, 5.8e+19], 1.0, N[(N[(beta + 1.0), $MachinePrecision] / alpha), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\alpha \leq 1.5 \cdot 10^{-74}:\\
\;\;\;\;0.5 + \alpha \cdot -0.25\\
\mathbf{elif}\;\alpha \leq 5.8 \cdot 10^{+19}:\\
\;\;\;\;1\\
\mathbf{else}:\\
\;\;\;\;\frac{\beta + 1}{\alpha}\\
\end{array}
\end{array}
if alpha < 1.50000000000000003e-74Initial program 100.0%
+-commutative100.0%
Simplified100.0%
Taylor expanded in beta around 0 70.6%
+-commutative70.6%
Simplified70.6%
Taylor expanded in alpha around 0 70.5%
*-commutative70.5%
Simplified70.5%
if 1.50000000000000003e-74 < alpha < 5.8e19Initial program 96.5%
+-commutative96.5%
Simplified96.5%
Taylor expanded in alpha around 0 91.0%
+-commutative91.0%
Simplified91.0%
Taylor expanded in beta around inf 66.8%
if 5.8e19 < alpha Initial program 24.7%
+-commutative24.7%
Simplified24.7%
Taylor expanded in alpha around inf 81.6%
*-commutative81.6%
Simplified81.6%
Taylor expanded in beta around inf 81.2%
associate-/r*81.5%
Simplified81.5%
Taylor expanded in beta around 0 81.6%
lft-mult-inverse81.5%
associate-*l/81.2%
associate-/r*81.2%
*-lft-identity81.2%
associate-*l/81.2%
distribute-rgt-in81.2%
+-commutative81.2%
rgt-mult-inverse81.2%
associate-*r/78.5%
associate-/r*77.5%
*-lft-identity77.5%
distribute-rgt-in77.4%
associate-*l/77.5%
*-lft-identity77.5%
associate-/l*77.0%
times-frac81.6%
*-inverses81.6%
associate-*r/81.6%
*-lft-identity81.6%
Simplified81.6%
(FPCore (alpha beta) :precision binary64 (if (<= alpha 5.8e+19) (/ (+ 1.0 (/ beta (+ beta 2.0))) 2.0) (/ (/ (+ 2.0 (* beta 2.0)) alpha) 2.0)))
double code(double alpha, double beta) {
double tmp;
if (alpha <= 5.8e+19) {
tmp = (1.0 + (beta / (beta + 2.0))) / 2.0;
} else {
tmp = ((2.0 + (beta * 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) :: tmp
if (alpha <= 5.8d+19) then
tmp = (1.0d0 + (beta / (beta + 2.0d0))) / 2.0d0
else
tmp = ((2.0d0 + (beta * 2.0d0)) / alpha) / 2.0d0
end if
code = tmp
end function
public static double code(double alpha, double beta) {
double tmp;
if (alpha <= 5.8e+19) {
tmp = (1.0 + (beta / (beta + 2.0))) / 2.0;
} else {
tmp = ((2.0 + (beta * 2.0)) / alpha) / 2.0;
}
return tmp;
}
def code(alpha, beta): tmp = 0 if alpha <= 5.8e+19: tmp = (1.0 + (beta / (beta + 2.0))) / 2.0 else: tmp = ((2.0 + (beta * 2.0)) / alpha) / 2.0 return tmp
function code(alpha, beta) tmp = 0.0 if (alpha <= 5.8e+19) tmp = Float64(Float64(1.0 + Float64(beta / Float64(beta + 2.0))) / 2.0); else tmp = Float64(Float64(Float64(2.0 + Float64(beta * 2.0)) / alpha) / 2.0); end return tmp end
function tmp_2 = code(alpha, beta) tmp = 0.0; if (alpha <= 5.8e+19) tmp = (1.0 + (beta / (beta + 2.0))) / 2.0; else tmp = ((2.0 + (beta * 2.0)) / alpha) / 2.0; end tmp_2 = tmp; end
code[alpha_, beta_] := If[LessEqual[alpha, 5.8e+19], N[(N[(1.0 + N[(beta / N[(beta + 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / 2.0), $MachinePrecision], N[(N[(N[(2.0 + N[(beta * 2.0), $MachinePrecision]), $MachinePrecision] / alpha), $MachinePrecision] / 2.0), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\alpha \leq 5.8 \cdot 10^{+19}:\\
\;\;\;\;\frac{1 + \frac{\beta}{\beta + 2}}{2}\\
\mathbf{else}:\\
\;\;\;\;\frac{\frac{2 + \beta \cdot 2}{\alpha}}{2}\\
\end{array}
\end{array}
if alpha < 5.8e19Initial program 99.6%
+-commutative99.6%
Simplified99.6%
Taylor expanded in alpha around 0 98.5%
+-commutative98.5%
Simplified98.5%
if 5.8e19 < alpha Initial program 24.7%
+-commutative24.7%
Simplified24.7%
Taylor expanded in alpha around inf 81.6%
*-commutative81.6%
Simplified81.6%
Final simplification92.5%
(FPCore (alpha beta) :precision binary64 (if (<= alpha 5.8e+19) (/ (+ 1.0 (/ beta (+ beta 2.0))) 2.0) (/ (+ beta 1.0) alpha)))
double code(double alpha, double beta) {
double tmp;
if (alpha <= 5.8e+19) {
tmp = (1.0 + (beta / (beta + 2.0))) / 2.0;
} else {
tmp = (beta + 1.0) / alpha;
}
return tmp;
}
real(8) function code(alpha, beta)
real(8), intent (in) :: alpha
real(8), intent (in) :: beta
real(8) :: tmp
if (alpha <= 5.8d+19) then
tmp = (1.0d0 + (beta / (beta + 2.0d0))) / 2.0d0
else
tmp = (beta + 1.0d0) / alpha
end if
code = tmp
end function
public static double code(double alpha, double beta) {
double tmp;
if (alpha <= 5.8e+19) {
tmp = (1.0 + (beta / (beta + 2.0))) / 2.0;
} else {
tmp = (beta + 1.0) / alpha;
}
return tmp;
}
def code(alpha, beta): tmp = 0 if alpha <= 5.8e+19: tmp = (1.0 + (beta / (beta + 2.0))) / 2.0 else: tmp = (beta + 1.0) / alpha return tmp
function code(alpha, beta) tmp = 0.0 if (alpha <= 5.8e+19) tmp = Float64(Float64(1.0 + Float64(beta / Float64(beta + 2.0))) / 2.0); else tmp = Float64(Float64(beta + 1.0) / alpha); end return tmp end
function tmp_2 = code(alpha, beta) tmp = 0.0; if (alpha <= 5.8e+19) tmp = (1.0 + (beta / (beta + 2.0))) / 2.0; else tmp = (beta + 1.0) / alpha; end tmp_2 = tmp; end
code[alpha_, beta_] := If[LessEqual[alpha, 5.8e+19], N[(N[(1.0 + N[(beta / N[(beta + 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / 2.0), $MachinePrecision], N[(N[(beta + 1.0), $MachinePrecision] / alpha), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\alpha \leq 5.8 \cdot 10^{+19}:\\
\;\;\;\;\frac{1 + \frac{\beta}{\beta + 2}}{2}\\
\mathbf{else}:\\
\;\;\;\;\frac{\beta + 1}{\alpha}\\
\end{array}
\end{array}
if alpha < 5.8e19Initial program 99.6%
+-commutative99.6%
Simplified99.6%
Taylor expanded in alpha around 0 98.5%
+-commutative98.5%
Simplified98.5%
if 5.8e19 < alpha Initial program 24.7%
+-commutative24.7%
Simplified24.7%
Taylor expanded in alpha around inf 81.6%
*-commutative81.6%
Simplified81.6%
Taylor expanded in beta around inf 81.2%
associate-/r*81.5%
Simplified81.5%
Taylor expanded in beta around 0 81.6%
lft-mult-inverse81.5%
associate-*l/81.2%
associate-/r*81.2%
*-lft-identity81.2%
associate-*l/81.2%
distribute-rgt-in81.2%
+-commutative81.2%
rgt-mult-inverse81.2%
associate-*r/78.5%
associate-/r*77.5%
*-lft-identity77.5%
distribute-rgt-in77.4%
associate-*l/77.5%
*-lft-identity77.5%
associate-/l*77.0%
times-frac81.6%
*-inverses81.6%
associate-*r/81.6%
*-lft-identity81.6%
Simplified81.6%
Final simplification92.5%
(FPCore (alpha beta) :precision binary64 (if (<= beta 2.0) (+ 0.5 (* beta 0.25)) (- 1.0 (/ 1.0 beta))))
double code(double alpha, double beta) {
double tmp;
if (beta <= 2.0) {
tmp = 0.5 + (beta * 0.25);
} else {
tmp = 1.0 - (1.0 / beta);
}
return tmp;
}
real(8) function code(alpha, beta)
real(8), intent (in) :: alpha
real(8), intent (in) :: beta
real(8) :: tmp
if (beta <= 2.0d0) then
tmp = 0.5d0 + (beta * 0.25d0)
else
tmp = 1.0d0 - (1.0d0 / beta)
end if
code = tmp
end function
public static double code(double alpha, double beta) {
double tmp;
if (beta <= 2.0) {
tmp = 0.5 + (beta * 0.25);
} else {
tmp = 1.0 - (1.0 / beta);
}
return tmp;
}
def code(alpha, beta): tmp = 0 if beta <= 2.0: tmp = 0.5 + (beta * 0.25) else: tmp = 1.0 - (1.0 / beta) return tmp
function code(alpha, beta) tmp = 0.0 if (beta <= 2.0) tmp = Float64(0.5 + Float64(beta * 0.25)); else tmp = Float64(1.0 - Float64(1.0 / beta)); end return tmp end
function tmp_2 = code(alpha, beta) tmp = 0.0; if (beta <= 2.0) tmp = 0.5 + (beta * 0.25); else tmp = 1.0 - (1.0 / beta); end tmp_2 = tmp; end
code[alpha_, beta_] := If[LessEqual[beta, 2.0], N[(0.5 + N[(beta * 0.25), $MachinePrecision]), $MachinePrecision], N[(1.0 - N[(1.0 / beta), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\beta \leq 2:\\
\;\;\;\;0.5 + \beta \cdot 0.25\\
\mathbf{else}:\\
\;\;\;\;1 - \frac{1}{\beta}\\
\end{array}
\end{array}
if beta < 2Initial program 64.6%
+-commutative64.6%
Simplified64.6%
Taylor expanded in alpha around 0 63.1%
+-commutative63.1%
Simplified63.1%
Taylor expanded in beta around 0 62.0%
if 2 < beta Initial program 87.8%
+-commutative87.8%
Simplified87.8%
Taylor expanded in alpha around 0 85.5%
+-commutative85.5%
Simplified85.5%
Taylor expanded in beta around inf 85.5%
Final simplification70.5%
(FPCore (alpha beta) :precision binary64 (if (<= beta 2.0) (+ 0.5 (* beta 0.25)) 1.0))
double code(double alpha, double beta) {
double tmp;
if (beta <= 2.0) {
tmp = 0.5 + (beta * 0.25);
} 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 <= 2.0d0) then
tmp = 0.5d0 + (beta * 0.25d0)
else
tmp = 1.0d0
end if
code = tmp
end function
public static double code(double alpha, double beta) {
double tmp;
if (beta <= 2.0) {
tmp = 0.5 + (beta * 0.25);
} else {
tmp = 1.0;
}
return tmp;
}
def code(alpha, beta): tmp = 0 if beta <= 2.0: tmp = 0.5 + (beta * 0.25) else: tmp = 1.0 return tmp
function code(alpha, beta) tmp = 0.0 if (beta <= 2.0) tmp = Float64(0.5 + Float64(beta * 0.25)); else tmp = 1.0; end return tmp end
function tmp_2 = code(alpha, beta) tmp = 0.0; if (beta <= 2.0) tmp = 0.5 + (beta * 0.25); else tmp = 1.0; end tmp_2 = tmp; end
code[alpha_, beta_] := If[LessEqual[beta, 2.0], N[(0.5 + N[(beta * 0.25), $MachinePrecision]), $MachinePrecision], 1.0]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\beta \leq 2:\\
\;\;\;\;0.5 + \beta \cdot 0.25\\
\mathbf{else}:\\
\;\;\;\;1\\
\end{array}
\end{array}
if beta < 2Initial program 64.6%
+-commutative64.6%
Simplified64.6%
Taylor expanded in alpha around 0 63.1%
+-commutative63.1%
Simplified63.1%
Taylor expanded in beta around 0 62.0%
if 2 < beta Initial program 87.8%
+-commutative87.8%
Simplified87.8%
Taylor expanded in alpha around 0 85.5%
+-commutative85.5%
Simplified85.5%
Taylor expanded in beta around inf 84.7%
Final simplification70.2%
(FPCore (alpha beta) :precision binary64 (if (<= beta 5.5) 0.5 1.0))
double code(double alpha, double beta) {
double tmp;
if (beta <= 5.5) {
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 <= 5.5d0) 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 <= 5.5) {
tmp = 0.5;
} else {
tmp = 1.0;
}
return tmp;
}
def code(alpha, beta): tmp = 0 if beta <= 5.5: tmp = 0.5 else: tmp = 1.0 return tmp
function code(alpha, beta) tmp = 0.0 if (beta <= 5.5) tmp = 0.5; else tmp = 1.0; end return tmp end
function tmp_2 = code(alpha, beta) tmp = 0.0; if (beta <= 5.5) tmp = 0.5; else tmp = 1.0; end tmp_2 = tmp; end
code[alpha_, beta_] := If[LessEqual[beta, 5.5], 0.5, 1.0]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\beta \leq 5.5:\\
\;\;\;\;0.5\\
\mathbf{else}:\\
\;\;\;\;1\\
\end{array}
\end{array}
if beta < 5.5Initial program 64.2%
+-commutative64.2%
Simplified64.2%
Taylor expanded in alpha around 0 62.7%
+-commutative62.7%
Simplified62.7%
Taylor expanded in beta around 0 60.9%
if 5.5 < beta Initial program 88.7%
+-commutative88.7%
Simplified88.7%
Taylor expanded in alpha around 0 86.4%
+-commutative86.4%
Simplified86.4%
Taylor expanded in beta around inf 85.6%
(FPCore (alpha beta) :precision binary64 0.5)
double code(double alpha, double beta) {
return 0.5;
}
real(8) function code(alpha, beta)
real(8), intent (in) :: alpha
real(8), intent (in) :: beta
code = 0.5d0
end function
public static double code(double alpha, double beta) {
return 0.5;
}
def code(alpha, beta): return 0.5
function code(alpha, beta) return 0.5 end
function tmp = code(alpha, beta) tmp = 0.5; end
code[alpha_, beta_] := 0.5
\begin{array}{l}
\\
0.5
\end{array}
Initial program 72.9%
+-commutative72.9%
Simplified72.9%
Taylor expanded in alpha around 0 71.1%
+-commutative71.1%
Simplified71.1%
Taylor expanded in beta around 0 45.4%
(FPCore (alpha beta) :precision binary64 0.0)
double code(double alpha, double beta) {
return 0.0;
}
real(8) function code(alpha, beta)
real(8), intent (in) :: alpha
real(8), intent (in) :: beta
code = 0.0d0
end function
public static double code(double alpha, double beta) {
return 0.0;
}
def code(alpha, beta): return 0.0
function code(alpha, beta) return 0.0 end
function tmp = code(alpha, beta) tmp = 0.0; end
code[alpha_, beta_] := 0.0
\begin{array}{l}
\\
0
\end{array}
Initial program 72.9%
+-commutative72.9%
sub-neg72.9%
+-commutative72.9%
neg-sub072.9%
associate-+l-72.9%
sub0-neg72.9%
distribute-frac-neg72.9%
+-commutative72.9%
sub-neg72.9%
div-sub72.9%
sub-neg72.9%
metadata-eval72.9%
neg-mul-172.9%
*-commutative72.9%
+-commutative72.9%
associate-/l/72.9%
associate-*l/72.9%
Simplified72.9%
Taylor expanded in alpha around inf 3.9%
metadata-eval3.9%
Applied egg-rr3.9%
herbie shell --seed 2024182
(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))