Octave 3.8, jcobi/3

Percentage Accurate: 94.3% → 99.8%
Time: 15.2s
Alternatives: 20
Speedup: 2.9×

Specification

?
\[\alpha > -1 \land \beta > -1\]
\[\begin{array}{l} \\ \begin{array}{l} t_0 := \left(\alpha + \beta\right) + 2 \cdot 1\\ \frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{t\_0}}{t\_0}}{t\_0 + 1} \end{array} \end{array} \]
(FPCore (alpha beta)
 :precision binary64
 (let* ((t_0 (+ (+ alpha beta) (* 2.0 1.0))))
   (/ (/ (/ (+ (+ (+ alpha beta) (* beta alpha)) 1.0) t_0) t_0) (+ t_0 1.0))))
double code(double alpha, double beta) {
	double t_0 = (alpha + beta) + (2.0 * 1.0);
	return (((((alpha + beta) + (beta * alpha)) + 1.0) / t_0) / t_0) / (t_0 + 1.0);
}
real(8) function code(alpha, beta)
    real(8), intent (in) :: alpha
    real(8), intent (in) :: beta
    real(8) :: t_0
    t_0 = (alpha + beta) + (2.0d0 * 1.0d0)
    code = (((((alpha + beta) + (beta * alpha)) + 1.0d0) / t_0) / t_0) / (t_0 + 1.0d0)
end function
public static double code(double alpha, double beta) {
	double t_0 = (alpha + beta) + (2.0 * 1.0);
	return (((((alpha + beta) + (beta * alpha)) + 1.0) / t_0) / t_0) / (t_0 + 1.0);
}
def code(alpha, beta):
	t_0 = (alpha + beta) + (2.0 * 1.0)
	return (((((alpha + beta) + (beta * alpha)) + 1.0) / t_0) / t_0) / (t_0 + 1.0)
function code(alpha, beta)
	t_0 = Float64(Float64(alpha + beta) + Float64(2.0 * 1.0))
	return Float64(Float64(Float64(Float64(Float64(Float64(alpha + beta) + Float64(beta * alpha)) + 1.0) / t_0) / t_0) / Float64(t_0 + 1.0))
end
function tmp = code(alpha, beta)
	t_0 = (alpha + beta) + (2.0 * 1.0);
	tmp = (((((alpha + beta) + (beta * alpha)) + 1.0) / t_0) / t_0) / (t_0 + 1.0);
end
code[alpha_, beta_] := Block[{t$95$0 = N[(N[(alpha + beta), $MachinePrecision] + N[(2.0 * 1.0), $MachinePrecision]), $MachinePrecision]}, N[(N[(N[(N[(N[(N[(alpha + beta), $MachinePrecision] + N[(beta * alpha), $MachinePrecision]), $MachinePrecision] + 1.0), $MachinePrecision] / t$95$0), $MachinePrecision] / t$95$0), $MachinePrecision] / N[(t$95$0 + 1.0), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \left(\alpha + \beta\right) + 2 \cdot 1\\
\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{t\_0}}{t\_0}}{t\_0 + 1}
\end{array}
\end{array}

Sampling outcomes in binary64 precision:

Local Percentage Accuracy vs ?

The average percentage accuracy by input value. Horizontal axis shows value of an input variable; the variable is choosen in the title. Vertical axis is accuracy; higher is better. Red represent the original program, while blue represents Herbie's suggestion. These can be toggled with buttons below the plot. The line is an average while dots represent individual samples.

Accuracy vs Speed?

Herbie found 20 alternatives:

AlternativeAccuracySpeedup
The accuracy (vertical axis) and speed (horizontal axis) of each alternatives. Up and to the right is better. The red square shows the initial program, and each blue circle shows an alternative.The line shows the best available speed-accuracy tradeoffs.

Initial Program: 94.3% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \left(\alpha + \beta\right) + 2 \cdot 1\\ \frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{t\_0}}{t\_0}}{t\_0 + 1} \end{array} \end{array} \]
(FPCore (alpha beta)
 :precision binary64
 (let* ((t_0 (+ (+ alpha beta) (* 2.0 1.0))))
   (/ (/ (/ (+ (+ (+ alpha beta) (* beta alpha)) 1.0) t_0) t_0) (+ t_0 1.0))))
double code(double alpha, double beta) {
	double t_0 = (alpha + beta) + (2.0 * 1.0);
	return (((((alpha + beta) + (beta * alpha)) + 1.0) / t_0) / t_0) / (t_0 + 1.0);
}
real(8) function code(alpha, beta)
    real(8), intent (in) :: alpha
    real(8), intent (in) :: beta
    real(8) :: t_0
    t_0 = (alpha + beta) + (2.0d0 * 1.0d0)
    code = (((((alpha + beta) + (beta * alpha)) + 1.0d0) / t_0) / t_0) / (t_0 + 1.0d0)
end function
public static double code(double alpha, double beta) {
	double t_0 = (alpha + beta) + (2.0 * 1.0);
	return (((((alpha + beta) + (beta * alpha)) + 1.0) / t_0) / t_0) / (t_0 + 1.0);
}
def code(alpha, beta):
	t_0 = (alpha + beta) + (2.0 * 1.0)
	return (((((alpha + beta) + (beta * alpha)) + 1.0) / t_0) / t_0) / (t_0 + 1.0)
function code(alpha, beta)
	t_0 = Float64(Float64(alpha + beta) + Float64(2.0 * 1.0))
	return Float64(Float64(Float64(Float64(Float64(Float64(alpha + beta) + Float64(beta * alpha)) + 1.0) / t_0) / t_0) / Float64(t_0 + 1.0))
end
function tmp = code(alpha, beta)
	t_0 = (alpha + beta) + (2.0 * 1.0);
	tmp = (((((alpha + beta) + (beta * alpha)) + 1.0) / t_0) / t_0) / (t_0 + 1.0);
end
code[alpha_, beta_] := Block[{t$95$0 = N[(N[(alpha + beta), $MachinePrecision] + N[(2.0 * 1.0), $MachinePrecision]), $MachinePrecision]}, N[(N[(N[(N[(N[(N[(alpha + beta), $MachinePrecision] + N[(beta * alpha), $MachinePrecision]), $MachinePrecision] + 1.0), $MachinePrecision] / t$95$0), $MachinePrecision] / t$95$0), $MachinePrecision] / N[(t$95$0 + 1.0), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \left(\alpha + \beta\right) + 2 \cdot 1\\
\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{t\_0}}{t\_0}}{t\_0 + 1}
\end{array}
\end{array}

Alternative 1: 99.8% accurate, 1.4× speedup?

\[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} t_0 := \beta + \left(\alpha + 2\right)\\ \frac{\frac{\frac{1 + \alpha}{t\_0}}{t\_0}}{\frac{\alpha + \left(\beta + 3\right)}{1 + \beta}} \end{array} \end{array} \]
NOTE: alpha and beta should be sorted in increasing order before calling this function.
(FPCore (alpha beta)
 :precision binary64
 (let* ((t_0 (+ beta (+ alpha 2.0))))
   (/ (/ (/ (+ 1.0 alpha) t_0) t_0) (/ (+ alpha (+ beta 3.0)) (+ 1.0 beta)))))
assert(alpha < beta);
double code(double alpha, double beta) {
	double t_0 = beta + (alpha + 2.0);
	return (((1.0 + alpha) / t_0) / t_0) / ((alpha + (beta + 3.0)) / (1.0 + beta));
}
NOTE: alpha and beta should be sorted in increasing order before calling this function.
real(8) function code(alpha, beta)
    real(8), intent (in) :: alpha
    real(8), intent (in) :: beta
    real(8) :: t_0
    t_0 = beta + (alpha + 2.0d0)
    code = (((1.0d0 + alpha) / t_0) / t_0) / ((alpha + (beta + 3.0d0)) / (1.0d0 + beta))
end function
assert alpha < beta;
public static double code(double alpha, double beta) {
	double t_0 = beta + (alpha + 2.0);
	return (((1.0 + alpha) / t_0) / t_0) / ((alpha + (beta + 3.0)) / (1.0 + beta));
}
[alpha, beta] = sort([alpha, beta])
def code(alpha, beta):
	t_0 = beta + (alpha + 2.0)
	return (((1.0 + alpha) / t_0) / t_0) / ((alpha + (beta + 3.0)) / (1.0 + beta))
alpha, beta = sort([alpha, beta])
function code(alpha, beta)
	t_0 = Float64(beta + Float64(alpha + 2.0))
	return Float64(Float64(Float64(Float64(1.0 + alpha) / t_0) / t_0) / Float64(Float64(alpha + Float64(beta + 3.0)) / Float64(1.0 + beta)))
end
alpha, beta = num2cell(sort([alpha, beta])){:}
function tmp = code(alpha, beta)
	t_0 = beta + (alpha + 2.0);
	tmp = (((1.0 + alpha) / t_0) / t_0) / ((alpha + (beta + 3.0)) / (1.0 + beta));
end
NOTE: alpha and beta should be sorted in increasing order before calling this function.
code[alpha_, beta_] := Block[{t$95$0 = N[(beta + N[(alpha + 2.0), $MachinePrecision]), $MachinePrecision]}, N[(N[(N[(N[(1.0 + alpha), $MachinePrecision] / t$95$0), $MachinePrecision] / t$95$0), $MachinePrecision] / N[(N[(alpha + N[(beta + 3.0), $MachinePrecision]), $MachinePrecision] / N[(1.0 + beta), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
[alpha, beta] = \mathsf{sort}([alpha, beta])\\
\\
\begin{array}{l}
t_0 := \beta + \left(\alpha + 2\right)\\
\frac{\frac{\frac{1 + \alpha}{t\_0}}{t\_0}}{\frac{\alpha + \left(\beta + 3\right)}{1 + \beta}}
\end{array}
\end{array}
Derivation
  1. Initial program 95.2%

    \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
  2. Step-by-step derivation
    1. associate-/l/N/A

      \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
    2. associate-/l/N/A

      \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
    3. /-lowering-/.f64N/A

      \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
    4. +-commutativeN/A

      \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    5. associate-+l+N/A

      \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    6. associate-+l+N/A

      \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    7. associate-+r+N/A

      \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    8. distribute-lft1-inN/A

      \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    9. *-commutativeN/A

      \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    10. distribute-lft1-inN/A

      \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    11. +-commutativeN/A

      \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    12. *-lowering-*.f64N/A

      \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    13. +-commutativeN/A

      \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    14. +-lowering-+.f64N/A

      \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    15. +-lowering-+.f64N/A

      \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
  3. Simplified84.9%

    \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
  4. Add Preprocessing
  5. Applied egg-rr99.2%

    \[\leadsto \color{blue}{\frac{1 + \beta}{\alpha + \left(\beta + 3\right)} \cdot {\left(\frac{\alpha + \left(\beta + 2\right)}{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}\right)}^{-1}} \]
  6. Step-by-step derivation
    1. *-commutativeN/A

      \[\leadsto {\left(\frac{\alpha + \left(\beta + 2\right)}{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}\right)}^{-1} \cdot \color{blue}{\frac{1 + \beta}{\alpha + \left(\beta + 3\right)}} \]
    2. unpow-1N/A

      \[\leadsto \frac{1}{\frac{\alpha + \left(\beta + 2\right)}{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}} \cdot \frac{\color{blue}{1 + \beta}}{\alpha + \left(\beta + 3\right)} \]
    3. clear-numN/A

      \[\leadsto \frac{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}{\alpha + \left(\beta + 2\right)} \cdot \frac{\color{blue}{1 + \beta}}{\alpha + \left(\beta + 3\right)} \]
    4. clear-numN/A

      \[\leadsto \frac{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}{\alpha + \left(\beta + 2\right)} \cdot \frac{1}{\color{blue}{\frac{\alpha + \left(\beta + 3\right)}{1 + \beta}}} \]
    5. un-div-invN/A

      \[\leadsto \frac{\frac{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}{\alpha + \left(\beta + 2\right)}}{\color{blue}{\frac{\alpha + \left(\beta + 3\right)}{1 + \beta}}} \]
    6. /-lowering-/.f64N/A

      \[\leadsto \mathsf{/.f64}\left(\left(\frac{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}{\alpha + \left(\beta + 2\right)}\right), \color{blue}{\left(\frac{\alpha + \left(\beta + 3\right)}{1 + \beta}\right)}\right) \]
  7. Applied egg-rr99.8%

    \[\leadsto \color{blue}{\frac{\frac{\frac{1 + \alpha}{\beta + \left(\alpha + 2\right)}}{\beta + \left(\alpha + 2\right)}}{\frac{\alpha + \left(\beta + 3\right)}{1 + \beta}}} \]
  8. Add Preprocessing

Alternative 2: 99.8% accurate, 1.2× speedup?

\[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} t_0 := 2 + \left(\alpha + \beta\right)\\ \mathbf{if}\;\beta \leq 62000000:\\ \;\;\;\;\frac{\left(1 + \alpha\right) \cdot \left(1 + \beta\right)}{t\_0 \cdot \left(t\_0 \cdot \left(3 + \left(\alpha + \beta\right)\right)\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{\frac{1 + \alpha}{\beta + \left(\alpha + 2\right)}}{-3 - \left(\alpha + \beta\right)}}{-1 + \frac{-1 - \alpha}{\beta}}\\ \end{array} \end{array} \]
NOTE: alpha and beta should be sorted in increasing order before calling this function.
(FPCore (alpha beta)
 :precision binary64
 (let* ((t_0 (+ 2.0 (+ alpha beta))))
   (if (<= beta 62000000.0)
     (/ (* (+ 1.0 alpha) (+ 1.0 beta)) (* t_0 (* t_0 (+ 3.0 (+ alpha beta)))))
     (/
      (/ (/ (+ 1.0 alpha) (+ beta (+ alpha 2.0))) (- -3.0 (+ alpha beta)))
      (+ -1.0 (/ (- -1.0 alpha) beta))))))
assert(alpha < beta);
double code(double alpha, double beta) {
	double t_0 = 2.0 + (alpha + beta);
	double tmp;
	if (beta <= 62000000.0) {
		tmp = ((1.0 + alpha) * (1.0 + beta)) / (t_0 * (t_0 * (3.0 + (alpha + beta))));
	} else {
		tmp = (((1.0 + alpha) / (beta + (alpha + 2.0))) / (-3.0 - (alpha + beta))) / (-1.0 + ((-1.0 - alpha) / beta));
	}
	return tmp;
}
NOTE: alpha and beta should be sorted in increasing order before calling this function.
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 = 2.0d0 + (alpha + beta)
    if (beta <= 62000000.0d0) then
        tmp = ((1.0d0 + alpha) * (1.0d0 + beta)) / (t_0 * (t_0 * (3.0d0 + (alpha + beta))))
    else
        tmp = (((1.0d0 + alpha) / (beta + (alpha + 2.0d0))) / ((-3.0d0) - (alpha + beta))) / ((-1.0d0) + (((-1.0d0) - alpha) / beta))
    end if
    code = tmp
end function
assert alpha < beta;
public static double code(double alpha, double beta) {
	double t_0 = 2.0 + (alpha + beta);
	double tmp;
	if (beta <= 62000000.0) {
		tmp = ((1.0 + alpha) * (1.0 + beta)) / (t_0 * (t_0 * (3.0 + (alpha + beta))));
	} else {
		tmp = (((1.0 + alpha) / (beta + (alpha + 2.0))) / (-3.0 - (alpha + beta))) / (-1.0 + ((-1.0 - alpha) / beta));
	}
	return tmp;
}
[alpha, beta] = sort([alpha, beta])
def code(alpha, beta):
	t_0 = 2.0 + (alpha + beta)
	tmp = 0
	if beta <= 62000000.0:
		tmp = ((1.0 + alpha) * (1.0 + beta)) / (t_0 * (t_0 * (3.0 + (alpha + beta))))
	else:
		tmp = (((1.0 + alpha) / (beta + (alpha + 2.0))) / (-3.0 - (alpha + beta))) / (-1.0 + ((-1.0 - alpha) / beta))
	return tmp
alpha, beta = sort([alpha, beta])
function code(alpha, beta)
	t_0 = Float64(2.0 + Float64(alpha + beta))
	tmp = 0.0
	if (beta <= 62000000.0)
		tmp = Float64(Float64(Float64(1.0 + alpha) * Float64(1.0 + beta)) / Float64(t_0 * Float64(t_0 * Float64(3.0 + Float64(alpha + beta)))));
	else
		tmp = Float64(Float64(Float64(Float64(1.0 + alpha) / Float64(beta + Float64(alpha + 2.0))) / Float64(-3.0 - Float64(alpha + beta))) / Float64(-1.0 + Float64(Float64(-1.0 - alpha) / beta)));
	end
	return tmp
end
alpha, beta = num2cell(sort([alpha, beta])){:}
function tmp_2 = code(alpha, beta)
	t_0 = 2.0 + (alpha + beta);
	tmp = 0.0;
	if (beta <= 62000000.0)
		tmp = ((1.0 + alpha) * (1.0 + beta)) / (t_0 * (t_0 * (3.0 + (alpha + beta))));
	else
		tmp = (((1.0 + alpha) / (beta + (alpha + 2.0))) / (-3.0 - (alpha + beta))) / (-1.0 + ((-1.0 - alpha) / beta));
	end
	tmp_2 = tmp;
end
NOTE: alpha and beta should be sorted in increasing order before calling this function.
code[alpha_, beta_] := Block[{t$95$0 = N[(2.0 + N[(alpha + beta), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[beta, 62000000.0], N[(N[(N[(1.0 + alpha), $MachinePrecision] * N[(1.0 + beta), $MachinePrecision]), $MachinePrecision] / N[(t$95$0 * N[(t$95$0 * N[(3.0 + N[(alpha + beta), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(N[(N[(1.0 + alpha), $MachinePrecision] / N[(beta + N[(alpha + 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(-3.0 - N[(alpha + beta), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(-1.0 + N[(N[(-1.0 - alpha), $MachinePrecision] / beta), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}
[alpha, beta] = \mathsf{sort}([alpha, beta])\\
\\
\begin{array}{l}
t_0 := 2 + \left(\alpha + \beta\right)\\
\mathbf{if}\;\beta \leq 62000000:\\
\;\;\;\;\frac{\left(1 + \alpha\right) \cdot \left(1 + \beta\right)}{t\_0 \cdot \left(t\_0 \cdot \left(3 + \left(\alpha + \beta\right)\right)\right)}\\

\mathbf{else}:\\
\;\;\;\;\frac{\frac{\frac{1 + \alpha}{\beta + \left(\alpha + 2\right)}}{-3 - \left(\alpha + \beta\right)}}{-1 + \frac{-1 - \alpha}{\beta}}\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if beta < 6.2e7

    1. Initial program 99.9%

      \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
    2. Step-by-step derivation
      1. associate-/l/N/A

        \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
      2. associate-/l/N/A

        \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
      3. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
      4. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      5. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      6. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      7. associate-+r+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      8. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      9. *-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      10. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      11. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      12. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      13. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      14. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      15. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    3. Simplified93.8%

      \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
    4. Add Preprocessing

    if 6.2e7 < beta

    1. Initial program 86.6%

      \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
    2. Step-by-step derivation
      1. associate-/l/N/A

        \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
      2. associate-/l/N/A

        \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
      3. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
      4. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      5. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      6. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      7. associate-+r+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      8. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      9. *-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      10. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      11. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      12. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      13. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      14. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      15. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    3. Simplified68.3%

      \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
    4. Add Preprocessing
    5. Applied egg-rr98.2%

      \[\leadsto \color{blue}{\frac{1 + \beta}{\alpha + \left(\beta + 3\right)} \cdot {\left(\frac{\alpha + \left(\beta + 2\right)}{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}\right)}^{-1}} \]
    6. Applied egg-rr99.8%

      \[\leadsto \color{blue}{\frac{\frac{\frac{1 + \alpha}{\beta + \left(\alpha + 2\right)}}{-3 - \left(\beta + \alpha\right)}}{\left(-2 - \left(\beta + \alpha\right)\right) \cdot \frac{1}{1 + \beta}}} \]
    7. Taylor expanded in beta around inf

      \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \color{blue}{\left(-1 \cdot \frac{1 + \alpha}{\beta} - 1\right)}\right) \]
    8. Step-by-step derivation
      1. sub-negN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \left(-1 \cdot \frac{1 + \alpha}{\beta} + \color{blue}{\left(\mathsf{neg}\left(1\right)\right)}\right)\right) \]
      2. metadata-evalN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \left(-1 \cdot \frac{1 + \alpha}{\beta} + -1\right)\right) \]
      3. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \mathsf{+.f64}\left(\left(-1 \cdot \frac{1 + \alpha}{\beta}\right), \color{blue}{-1}\right)\right) \]
      4. associate-*r/N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \mathsf{+.f64}\left(\left(\frac{-1 \cdot \left(1 + \alpha\right)}{\beta}\right), -1\right)\right) \]
      5. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{/.f64}\left(\left(-1 \cdot \left(1 + \alpha\right)\right), \beta\right), -1\right)\right) \]
      6. distribute-lft-inN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{/.f64}\left(\left(-1 \cdot 1 + -1 \cdot \alpha\right), \beta\right), -1\right)\right) \]
      7. metadata-evalN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{/.f64}\left(\left(-1 + -1 \cdot \alpha\right), \beta\right), -1\right)\right) \]
      8. mul-1-negN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{/.f64}\left(\left(-1 + \left(\mathsf{neg}\left(\alpha\right)\right)\right), \beta\right), -1\right)\right) \]
      9. unsub-negN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{/.f64}\left(\left(-1 - \alpha\right), \beta\right), -1\right)\right) \]
      10. --lowering--.f6499.5%

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{/.f64}\left(\mathsf{\_.f64}\left(-1, \alpha\right), \beta\right), -1\right)\right) \]
    9. Simplified99.5%

      \[\leadsto \frac{\frac{\frac{1 + \alpha}{\beta + \left(\alpha + 2\right)}}{-3 - \left(\beta + \alpha\right)}}{\color{blue}{\frac{-1 - \alpha}{\beta} + -1}} \]
  3. Recombined 2 regimes into one program.
  4. Final simplification95.8%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\beta \leq 62000000:\\ \;\;\;\;\frac{\left(1 + \alpha\right) \cdot \left(1 + \beta\right)}{\left(2 + \left(\alpha + \beta\right)\right) \cdot \left(\left(2 + \left(\alpha + \beta\right)\right) \cdot \left(3 + \left(\alpha + \beta\right)\right)\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{\frac{1 + \alpha}{\beta + \left(\alpha + 2\right)}}{-3 - \left(\alpha + \beta\right)}}{-1 + \frac{-1 - \alpha}{\beta}}\\ \end{array} \]
  5. Add Preprocessing

Alternative 3: 99.8% accurate, 1.2× speedup?

\[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} t_0 := \alpha + \left(\beta + 2\right)\\ \mathbf{if}\;\beta \leq 3 \cdot 10^{+20}:\\ \;\;\;\;\left(1 + \alpha\right) \cdot \frac{1 + \beta}{t\_0 \cdot \left(\left(\alpha + \left(\beta + 3\right)\right) \cdot t\_0\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{\frac{1 + \alpha}{\beta + \left(\alpha + 2\right)}}{-3 - \left(\alpha + \beta\right)}}{-1 + \frac{-1 - \alpha}{\beta}}\\ \end{array} \end{array} \]
NOTE: alpha and beta should be sorted in increasing order before calling this function.
(FPCore (alpha beta)
 :precision binary64
 (let* ((t_0 (+ alpha (+ beta 2.0))))
   (if (<= beta 3e+20)
     (* (+ 1.0 alpha) (/ (+ 1.0 beta) (* t_0 (* (+ alpha (+ beta 3.0)) t_0))))
     (/
      (/ (/ (+ 1.0 alpha) (+ beta (+ alpha 2.0))) (- -3.0 (+ alpha beta)))
      (+ -1.0 (/ (- -1.0 alpha) beta))))))
assert(alpha < beta);
double code(double alpha, double beta) {
	double t_0 = alpha + (beta + 2.0);
	double tmp;
	if (beta <= 3e+20) {
		tmp = (1.0 + alpha) * ((1.0 + beta) / (t_0 * ((alpha + (beta + 3.0)) * t_0)));
	} else {
		tmp = (((1.0 + alpha) / (beta + (alpha + 2.0))) / (-3.0 - (alpha + beta))) / (-1.0 + ((-1.0 - alpha) / beta));
	}
	return tmp;
}
NOTE: alpha and beta should be sorted in increasing order before calling this function.
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 = alpha + (beta + 2.0d0)
    if (beta <= 3d+20) then
        tmp = (1.0d0 + alpha) * ((1.0d0 + beta) / (t_0 * ((alpha + (beta + 3.0d0)) * t_0)))
    else
        tmp = (((1.0d0 + alpha) / (beta + (alpha + 2.0d0))) / ((-3.0d0) - (alpha + beta))) / ((-1.0d0) + (((-1.0d0) - alpha) / beta))
    end if
    code = tmp
end function
assert alpha < beta;
public static double code(double alpha, double beta) {
	double t_0 = alpha + (beta + 2.0);
	double tmp;
	if (beta <= 3e+20) {
		tmp = (1.0 + alpha) * ((1.0 + beta) / (t_0 * ((alpha + (beta + 3.0)) * t_0)));
	} else {
		tmp = (((1.0 + alpha) / (beta + (alpha + 2.0))) / (-3.0 - (alpha + beta))) / (-1.0 + ((-1.0 - alpha) / beta));
	}
	return tmp;
}
[alpha, beta] = sort([alpha, beta])
def code(alpha, beta):
	t_0 = alpha + (beta + 2.0)
	tmp = 0
	if beta <= 3e+20:
		tmp = (1.0 + alpha) * ((1.0 + beta) / (t_0 * ((alpha + (beta + 3.0)) * t_0)))
	else:
		tmp = (((1.0 + alpha) / (beta + (alpha + 2.0))) / (-3.0 - (alpha + beta))) / (-1.0 + ((-1.0 - alpha) / beta))
	return tmp
alpha, beta = sort([alpha, beta])
function code(alpha, beta)
	t_0 = Float64(alpha + Float64(beta + 2.0))
	tmp = 0.0
	if (beta <= 3e+20)
		tmp = Float64(Float64(1.0 + alpha) * Float64(Float64(1.0 + beta) / Float64(t_0 * Float64(Float64(alpha + Float64(beta + 3.0)) * t_0))));
	else
		tmp = Float64(Float64(Float64(Float64(1.0 + alpha) / Float64(beta + Float64(alpha + 2.0))) / Float64(-3.0 - Float64(alpha + beta))) / Float64(-1.0 + Float64(Float64(-1.0 - alpha) / beta)));
	end
	return tmp
end
alpha, beta = num2cell(sort([alpha, beta])){:}
function tmp_2 = code(alpha, beta)
	t_0 = alpha + (beta + 2.0);
	tmp = 0.0;
	if (beta <= 3e+20)
		tmp = (1.0 + alpha) * ((1.0 + beta) / (t_0 * ((alpha + (beta + 3.0)) * t_0)));
	else
		tmp = (((1.0 + alpha) / (beta + (alpha + 2.0))) / (-3.0 - (alpha + beta))) / (-1.0 + ((-1.0 - alpha) / beta));
	end
	tmp_2 = tmp;
end
NOTE: alpha and beta should be sorted in increasing order before calling this function.
code[alpha_, beta_] := Block[{t$95$0 = N[(alpha + N[(beta + 2.0), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[beta, 3e+20], N[(N[(1.0 + alpha), $MachinePrecision] * N[(N[(1.0 + beta), $MachinePrecision] / N[(t$95$0 * N[(N[(alpha + N[(beta + 3.0), $MachinePrecision]), $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(N[(N[(1.0 + alpha), $MachinePrecision] / N[(beta + N[(alpha + 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(-3.0 - N[(alpha + beta), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(-1.0 + N[(N[(-1.0 - alpha), $MachinePrecision] / beta), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}
[alpha, beta] = \mathsf{sort}([alpha, beta])\\
\\
\begin{array}{l}
t_0 := \alpha + \left(\beta + 2\right)\\
\mathbf{if}\;\beta \leq 3 \cdot 10^{+20}:\\
\;\;\;\;\left(1 + \alpha\right) \cdot \frac{1 + \beta}{t\_0 \cdot \left(\left(\alpha + \left(\beta + 3\right)\right) \cdot t\_0\right)}\\

\mathbf{else}:\\
\;\;\;\;\frac{\frac{\frac{1 + \alpha}{\beta + \left(\alpha + 2\right)}}{-3 - \left(\alpha + \beta\right)}}{-1 + \frac{-1 - \alpha}{\beta}}\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if beta < 3e20

    1. Initial program 99.8%

      \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
    2. Step-by-step derivation
      1. associate-/l/N/A

        \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
      2. associate-/l/N/A

        \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
      3. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
      4. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      5. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      6. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      7. associate-+r+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      8. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      9. *-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      10. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      11. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      12. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      13. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      14. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      15. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    3. Simplified93.9%

      \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
    4. Add Preprocessing
    5. Step-by-step derivation
      1. associate-/l*N/A

        \[\leadsto \left(\alpha + 1\right) \cdot \color{blue}{\frac{\beta + 1}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
      2. *-commutativeN/A

        \[\leadsto \frac{\beta + 1}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)} \cdot \color{blue}{\left(\alpha + 1\right)} \]
      3. *-lowering-*.f64N/A

        \[\leadsto \mathsf{*.f64}\left(\left(\frac{\beta + 1}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}\right), \color{blue}{\left(\alpha + 1\right)}\right) \]
    6. Applied egg-rr93.9%

      \[\leadsto \color{blue}{\frac{1 + \beta}{\left(\alpha + \left(\beta + 2\right)\right) \cdot \left(\left(\alpha + \left(\beta + 2\right)\right) \cdot \left(\alpha + \left(\beta + 3\right)\right)\right)} \cdot \left(\alpha + 1\right)} \]

    if 3e20 < beta

    1. Initial program 86.1%

      \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
    2. Step-by-step derivation
      1. associate-/l/N/A

        \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
      2. associate-/l/N/A

        \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
      3. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
      4. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      5. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      6. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      7. associate-+r+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      8. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      9. *-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      10. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      11. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      12. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      13. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      14. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      15. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    3. Simplified67.2%

      \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
    4. Add Preprocessing
    5. Applied egg-rr98.2%

      \[\leadsto \color{blue}{\frac{1 + \beta}{\alpha + \left(\beta + 3\right)} \cdot {\left(\frac{\alpha + \left(\beta + 2\right)}{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}\right)}^{-1}} \]
    6. Applied egg-rr99.8%

      \[\leadsto \color{blue}{\frac{\frac{\frac{1 + \alpha}{\beta + \left(\alpha + 2\right)}}{-3 - \left(\beta + \alpha\right)}}{\left(-2 - \left(\beta + \alpha\right)\right) \cdot \frac{1}{1 + \beta}}} \]
    7. Taylor expanded in beta around inf

      \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \color{blue}{\left(-1 \cdot \frac{1 + \alpha}{\beta} - 1\right)}\right) \]
    8. Step-by-step derivation
      1. sub-negN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \left(-1 \cdot \frac{1 + \alpha}{\beta} + \color{blue}{\left(\mathsf{neg}\left(1\right)\right)}\right)\right) \]
      2. metadata-evalN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \left(-1 \cdot \frac{1 + \alpha}{\beta} + -1\right)\right) \]
      3. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \mathsf{+.f64}\left(\left(-1 \cdot \frac{1 + \alpha}{\beta}\right), \color{blue}{-1}\right)\right) \]
      4. associate-*r/N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \mathsf{+.f64}\left(\left(\frac{-1 \cdot \left(1 + \alpha\right)}{\beta}\right), -1\right)\right) \]
      5. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{/.f64}\left(\left(-1 \cdot \left(1 + \alpha\right)\right), \beta\right), -1\right)\right) \]
      6. distribute-lft-inN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{/.f64}\left(\left(-1 \cdot 1 + -1 \cdot \alpha\right), \beta\right), -1\right)\right) \]
      7. metadata-evalN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{/.f64}\left(\left(-1 + -1 \cdot \alpha\right), \beta\right), -1\right)\right) \]
      8. mul-1-negN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{/.f64}\left(\left(-1 + \left(\mathsf{neg}\left(\alpha\right)\right)\right), \beta\right), -1\right)\right) \]
      9. unsub-negN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{/.f64}\left(\left(-1 - \alpha\right), \beta\right), -1\right)\right) \]
      10. --lowering--.f6499.8%

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{/.f64}\left(\mathsf{\_.f64}\left(-1, \alpha\right), \beta\right), -1\right)\right) \]
    9. Simplified99.8%

      \[\leadsto \frac{\frac{\frac{1 + \alpha}{\beta + \left(\alpha + 2\right)}}{-3 - \left(\beta + \alpha\right)}}{\color{blue}{\frac{-1 - \alpha}{\beta} + -1}} \]
  3. Recombined 2 regimes into one program.
  4. Final simplification95.9%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\beta \leq 3 \cdot 10^{+20}:\\ \;\;\;\;\left(1 + \alpha\right) \cdot \frac{1 + \beta}{\left(\alpha + \left(\beta + 2\right)\right) \cdot \left(\left(\alpha + \left(\beta + 3\right)\right) \cdot \left(\alpha + \left(\beta + 2\right)\right)\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{\frac{1 + \alpha}{\beta + \left(\alpha + 2\right)}}{-3 - \left(\alpha + \beta\right)}}{-1 + \frac{-1 - \alpha}{\beta}}\\ \end{array} \]
  5. Add Preprocessing

Alternative 4: 98.8% accurate, 1.2× speedup?

\[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 1.26:\\ \;\;\;\;\frac{\frac{1 + \alpha}{\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)}}{1 + \left(2 + \left(\alpha + \beta\right)\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{\frac{1 + \alpha}{\beta + \left(\alpha + 2\right)}}{-3 - \left(\alpha + \beta\right)}}{-1 + \frac{-1 - \alpha}{\beta}}\\ \end{array} \end{array} \]
NOTE: alpha and beta should be sorted in increasing order before calling this function.
(FPCore (alpha beta)
 :precision binary64
 (if (<= beta 1.26)
   (/
    (/ (+ 1.0 alpha) (* (+ alpha 2.0) (+ alpha 2.0)))
    (+ 1.0 (+ 2.0 (+ alpha beta))))
   (/
    (/ (/ (+ 1.0 alpha) (+ beta (+ alpha 2.0))) (- -3.0 (+ alpha beta)))
    (+ -1.0 (/ (- -1.0 alpha) beta)))))
assert(alpha < beta);
double code(double alpha, double beta) {
	double tmp;
	if (beta <= 1.26) {
		tmp = ((1.0 + alpha) / ((alpha + 2.0) * (alpha + 2.0))) / (1.0 + (2.0 + (alpha + beta)));
	} else {
		tmp = (((1.0 + alpha) / (beta + (alpha + 2.0))) / (-3.0 - (alpha + beta))) / (-1.0 + ((-1.0 - alpha) / beta));
	}
	return tmp;
}
NOTE: alpha and beta should be sorted in increasing order before calling this function.
real(8) function code(alpha, beta)
    real(8), intent (in) :: alpha
    real(8), intent (in) :: beta
    real(8) :: tmp
    if (beta <= 1.26d0) then
        tmp = ((1.0d0 + alpha) / ((alpha + 2.0d0) * (alpha + 2.0d0))) / (1.0d0 + (2.0d0 + (alpha + beta)))
    else
        tmp = (((1.0d0 + alpha) / (beta + (alpha + 2.0d0))) / ((-3.0d0) - (alpha + beta))) / ((-1.0d0) + (((-1.0d0) - alpha) / beta))
    end if
    code = tmp
end function
assert alpha < beta;
public static double code(double alpha, double beta) {
	double tmp;
	if (beta <= 1.26) {
		tmp = ((1.0 + alpha) / ((alpha + 2.0) * (alpha + 2.0))) / (1.0 + (2.0 + (alpha + beta)));
	} else {
		tmp = (((1.0 + alpha) / (beta + (alpha + 2.0))) / (-3.0 - (alpha + beta))) / (-1.0 + ((-1.0 - alpha) / beta));
	}
	return tmp;
}
[alpha, beta] = sort([alpha, beta])
def code(alpha, beta):
	tmp = 0
	if beta <= 1.26:
		tmp = ((1.0 + alpha) / ((alpha + 2.0) * (alpha + 2.0))) / (1.0 + (2.0 + (alpha + beta)))
	else:
		tmp = (((1.0 + alpha) / (beta + (alpha + 2.0))) / (-3.0 - (alpha + beta))) / (-1.0 + ((-1.0 - alpha) / beta))
	return tmp
alpha, beta = sort([alpha, beta])
function code(alpha, beta)
	tmp = 0.0
	if (beta <= 1.26)
		tmp = Float64(Float64(Float64(1.0 + alpha) / Float64(Float64(alpha + 2.0) * Float64(alpha + 2.0))) / Float64(1.0 + Float64(2.0 + Float64(alpha + beta))));
	else
		tmp = Float64(Float64(Float64(Float64(1.0 + alpha) / Float64(beta + Float64(alpha + 2.0))) / Float64(-3.0 - Float64(alpha + beta))) / Float64(-1.0 + Float64(Float64(-1.0 - alpha) / beta)));
	end
	return tmp
end
alpha, beta = num2cell(sort([alpha, beta])){:}
function tmp_2 = code(alpha, beta)
	tmp = 0.0;
	if (beta <= 1.26)
		tmp = ((1.0 + alpha) / ((alpha + 2.0) * (alpha + 2.0))) / (1.0 + (2.0 + (alpha + beta)));
	else
		tmp = (((1.0 + alpha) / (beta + (alpha + 2.0))) / (-3.0 - (alpha + beta))) / (-1.0 + ((-1.0 - alpha) / beta));
	end
	tmp_2 = tmp;
end
NOTE: alpha and beta should be sorted in increasing order before calling this function.
code[alpha_, beta_] := If[LessEqual[beta, 1.26], N[(N[(N[(1.0 + alpha), $MachinePrecision] / N[(N[(alpha + 2.0), $MachinePrecision] * N[(alpha + 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(1.0 + N[(2.0 + N[(alpha + beta), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(N[(N[(1.0 + alpha), $MachinePrecision] / N[(beta + N[(alpha + 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(-3.0 - N[(alpha + beta), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(-1.0 + N[(N[(-1.0 - alpha), $MachinePrecision] / beta), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
[alpha, beta] = \mathsf{sort}([alpha, beta])\\
\\
\begin{array}{l}
\mathbf{if}\;\beta \leq 1.26:\\
\;\;\;\;\frac{\frac{1 + \alpha}{\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)}}{1 + \left(2 + \left(\alpha + \beta\right)\right)}\\

\mathbf{else}:\\
\;\;\;\;\frac{\frac{\frac{1 + \alpha}{\beta + \left(\alpha + 2\right)}}{-3 - \left(\alpha + \beta\right)}}{-1 + \frac{-1 - \alpha}{\beta}}\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if beta < 1.26000000000000001

    1. Initial program 99.9%

      \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
    2. Add Preprocessing
    3. Taylor expanded in beta around 0

      \[\leadsto \mathsf{/.f64}\left(\color{blue}{\left(\frac{1 + \alpha}{{\left(2 + \alpha\right)}^{2}}\right)}, \mathsf{+.f64}\left(\mathsf{+.f64}\left(\mathsf{+.f64}\left(\alpha, \beta\right), \mathsf{*.f64}\left(2, 1\right)\right), 1\right)\right) \]
    4. Step-by-step derivation
      1. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\left(1 + \alpha\right), \left({\left(2 + \alpha\right)}^{2}\right)\right), \mathsf{+.f64}\left(\color{blue}{\mathsf{+.f64}\left(\mathsf{+.f64}\left(\alpha, \beta\right), \mathsf{*.f64}\left(2, 1\right)\right)}, 1\right)\right) \]
      2. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left({\left(2 + \alpha\right)}^{2}\right)\right), \mathsf{+.f64}\left(\mathsf{+.f64}\left(\color{blue}{\mathsf{+.f64}\left(\alpha, \beta\right)}, \mathsf{*.f64}\left(2, 1\right)\right), 1\right)\right) \]
      3. unpow2N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\left(2 + \alpha\right) \cdot \left(2 + \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{+.f64}\left(\mathsf{+.f64}\left(\alpha, \beta\right), \color{blue}{\mathsf{*.f64}\left(2, 1\right)}\right), 1\right)\right) \]
      4. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left(2 + \alpha\right), \left(2 + \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{+.f64}\left(\mathsf{+.f64}\left(\alpha, \beta\right), \color{blue}{\mathsf{*.f64}\left(2, 1\right)}\right), 1\right)\right) \]
      5. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{+.f64}\left(2, \alpha\right), \left(2 + \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{+.f64}\left(\mathsf{+.f64}\left(\alpha, \beta\right), \mathsf{*.f64}\left(\color{blue}{2}, 1\right)\right), 1\right)\right) \]
      6. +-lowering-+.f6498.7%

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{+.f64}\left(2, \alpha\right), \mathsf{+.f64}\left(2, \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{+.f64}\left(\mathsf{+.f64}\left(\alpha, \beta\right), \mathsf{*.f64}\left(2, \color{blue}{1}\right)\right), 1\right)\right) \]
    5. Simplified98.7%

      \[\leadsto \frac{\color{blue}{\frac{1 + \alpha}{\left(2 + \alpha\right) \cdot \left(2 + \alpha\right)}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]

    if 1.26000000000000001 < beta

    1. Initial program 87.4%

      \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
    2. Step-by-step derivation
      1. associate-/l/N/A

        \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
      2. associate-/l/N/A

        \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
      3. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
      4. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      5. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      6. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      7. associate-+r+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      8. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      9. *-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      10. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      11. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      12. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      13. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      14. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      15. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    3. Simplified70.3%

      \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
    4. Add Preprocessing
    5. Applied egg-rr98.3%

      \[\leadsto \color{blue}{\frac{1 + \beta}{\alpha + \left(\beta + 3\right)} \cdot {\left(\frac{\alpha + \left(\beta + 2\right)}{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}\right)}^{-1}} \]
    6. Applied egg-rr99.7%

      \[\leadsto \color{blue}{\frac{\frac{\frac{1 + \alpha}{\beta + \left(\alpha + 2\right)}}{-3 - \left(\beta + \alpha\right)}}{\left(-2 - \left(\beta + \alpha\right)\right) \cdot \frac{1}{1 + \beta}}} \]
    7. Taylor expanded in beta around inf

      \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \color{blue}{\left(-1 \cdot \frac{1 + \alpha}{\beta} - 1\right)}\right) \]
    8. Step-by-step derivation
      1. sub-negN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \left(-1 \cdot \frac{1 + \alpha}{\beta} + \color{blue}{\left(\mathsf{neg}\left(1\right)\right)}\right)\right) \]
      2. metadata-evalN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \left(-1 \cdot \frac{1 + \alpha}{\beta} + -1\right)\right) \]
      3. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \mathsf{+.f64}\left(\left(-1 \cdot \frac{1 + \alpha}{\beta}\right), \color{blue}{-1}\right)\right) \]
      4. associate-*r/N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \mathsf{+.f64}\left(\left(\frac{-1 \cdot \left(1 + \alpha\right)}{\beta}\right), -1\right)\right) \]
      5. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{/.f64}\left(\left(-1 \cdot \left(1 + \alpha\right)\right), \beta\right), -1\right)\right) \]
      6. distribute-lft-inN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{/.f64}\left(\left(-1 \cdot 1 + -1 \cdot \alpha\right), \beta\right), -1\right)\right) \]
      7. metadata-evalN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{/.f64}\left(\left(-1 + -1 \cdot \alpha\right), \beta\right), -1\right)\right) \]
      8. mul-1-negN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{/.f64}\left(\left(-1 + \left(\mathsf{neg}\left(\alpha\right)\right)\right), \beta\right), -1\right)\right) \]
      9. unsub-negN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{/.f64}\left(\left(-1 - \alpha\right), \beta\right), -1\right)\right) \]
      10. --lowering--.f6497.8%

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\beta, \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{\_.f64}\left(-3, \mathsf{+.f64}\left(\beta, \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{/.f64}\left(\mathsf{\_.f64}\left(-1, \alpha\right), \beta\right), -1\right)\right) \]
    9. Simplified97.8%

      \[\leadsto \frac{\frac{\frac{1 + \alpha}{\beta + \left(\alpha + 2\right)}}{-3 - \left(\beta + \alpha\right)}}{\color{blue}{\frac{-1 - \alpha}{\beta} + -1}} \]
  3. Recombined 2 regimes into one program.
  4. Final simplification98.4%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\beta \leq 1.26:\\ \;\;\;\;\frac{\frac{1 + \alpha}{\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)}}{1 + \left(2 + \left(\alpha + \beta\right)\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{\frac{1 + \alpha}{\beta + \left(\alpha + 2\right)}}{-3 - \left(\alpha + \beta\right)}}{-1 + \frac{-1 - \alpha}{\beta}}\\ \end{array} \]
  5. Add Preprocessing

Alternative 5: 97.9% accurate, 1.5× speedup?

\[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 3.2:\\ \;\;\;\;\frac{\frac{1 + \alpha}{\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)}}{1 + \left(2 + \left(\alpha + \beta\right)\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{-1 - \alpha}{\alpha + \left(\beta + 3\right)}}{-2 - \left(\alpha + \beta\right)}\\ \end{array} \end{array} \]
NOTE: alpha and beta should be sorted in increasing order before calling this function.
(FPCore (alpha beta)
 :precision binary64
 (if (<= beta 3.2)
   (/
    (/ (+ 1.0 alpha) (* (+ alpha 2.0) (+ alpha 2.0)))
    (+ 1.0 (+ 2.0 (+ alpha beta))))
   (/ (/ (- -1.0 alpha) (+ alpha (+ beta 3.0))) (- -2.0 (+ alpha beta)))))
assert(alpha < beta);
double code(double alpha, double beta) {
	double tmp;
	if (beta <= 3.2) {
		tmp = ((1.0 + alpha) / ((alpha + 2.0) * (alpha + 2.0))) / (1.0 + (2.0 + (alpha + beta)));
	} else {
		tmp = ((-1.0 - alpha) / (alpha + (beta + 3.0))) / (-2.0 - (alpha + beta));
	}
	return tmp;
}
NOTE: alpha and beta should be sorted in increasing order before calling this function.
real(8) function code(alpha, beta)
    real(8), intent (in) :: alpha
    real(8), intent (in) :: beta
    real(8) :: tmp
    if (beta <= 3.2d0) then
        tmp = ((1.0d0 + alpha) / ((alpha + 2.0d0) * (alpha + 2.0d0))) / (1.0d0 + (2.0d0 + (alpha + beta)))
    else
        tmp = (((-1.0d0) - alpha) / (alpha + (beta + 3.0d0))) / ((-2.0d0) - (alpha + beta))
    end if
    code = tmp
end function
assert alpha < beta;
public static double code(double alpha, double beta) {
	double tmp;
	if (beta <= 3.2) {
		tmp = ((1.0 + alpha) / ((alpha + 2.0) * (alpha + 2.0))) / (1.0 + (2.0 + (alpha + beta)));
	} else {
		tmp = ((-1.0 - alpha) / (alpha + (beta + 3.0))) / (-2.0 - (alpha + beta));
	}
	return tmp;
}
[alpha, beta] = sort([alpha, beta])
def code(alpha, beta):
	tmp = 0
	if beta <= 3.2:
		tmp = ((1.0 + alpha) / ((alpha + 2.0) * (alpha + 2.0))) / (1.0 + (2.0 + (alpha + beta)))
	else:
		tmp = ((-1.0 - alpha) / (alpha + (beta + 3.0))) / (-2.0 - (alpha + beta))
	return tmp
alpha, beta = sort([alpha, beta])
function code(alpha, beta)
	tmp = 0.0
	if (beta <= 3.2)
		tmp = Float64(Float64(Float64(1.0 + alpha) / Float64(Float64(alpha + 2.0) * Float64(alpha + 2.0))) / Float64(1.0 + Float64(2.0 + Float64(alpha + beta))));
	else
		tmp = Float64(Float64(Float64(-1.0 - alpha) / Float64(alpha + Float64(beta + 3.0))) / Float64(-2.0 - Float64(alpha + beta)));
	end
	return tmp
end
alpha, beta = num2cell(sort([alpha, beta])){:}
function tmp_2 = code(alpha, beta)
	tmp = 0.0;
	if (beta <= 3.2)
		tmp = ((1.0 + alpha) / ((alpha + 2.0) * (alpha + 2.0))) / (1.0 + (2.0 + (alpha + beta)));
	else
		tmp = ((-1.0 - alpha) / (alpha + (beta + 3.0))) / (-2.0 - (alpha + beta));
	end
	tmp_2 = tmp;
end
NOTE: alpha and beta should be sorted in increasing order before calling this function.
code[alpha_, beta_] := If[LessEqual[beta, 3.2], N[(N[(N[(1.0 + alpha), $MachinePrecision] / N[(N[(alpha + 2.0), $MachinePrecision] * N[(alpha + 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(1.0 + N[(2.0 + N[(alpha + beta), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(N[(-1.0 - alpha), $MachinePrecision] / N[(alpha + N[(beta + 3.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(-2.0 - N[(alpha + beta), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
[alpha, beta] = \mathsf{sort}([alpha, beta])\\
\\
\begin{array}{l}
\mathbf{if}\;\beta \leq 3.2:\\
\;\;\;\;\frac{\frac{1 + \alpha}{\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)}}{1 + \left(2 + \left(\alpha + \beta\right)\right)}\\

\mathbf{else}:\\
\;\;\;\;\frac{\frac{-1 - \alpha}{\alpha + \left(\beta + 3\right)}}{-2 - \left(\alpha + \beta\right)}\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if beta < 3.2000000000000002

    1. Initial program 99.9%

      \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
    2. Add Preprocessing
    3. Taylor expanded in beta around 0

      \[\leadsto \mathsf{/.f64}\left(\color{blue}{\left(\frac{1 + \alpha}{{\left(2 + \alpha\right)}^{2}}\right)}, \mathsf{+.f64}\left(\mathsf{+.f64}\left(\mathsf{+.f64}\left(\alpha, \beta\right), \mathsf{*.f64}\left(2, 1\right)\right), 1\right)\right) \]
    4. Step-by-step derivation
      1. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\left(1 + \alpha\right), \left({\left(2 + \alpha\right)}^{2}\right)\right), \mathsf{+.f64}\left(\color{blue}{\mathsf{+.f64}\left(\mathsf{+.f64}\left(\alpha, \beta\right), \mathsf{*.f64}\left(2, 1\right)\right)}, 1\right)\right) \]
      2. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left({\left(2 + \alpha\right)}^{2}\right)\right), \mathsf{+.f64}\left(\mathsf{+.f64}\left(\color{blue}{\mathsf{+.f64}\left(\alpha, \beta\right)}, \mathsf{*.f64}\left(2, 1\right)\right), 1\right)\right) \]
      3. unpow2N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\left(2 + \alpha\right) \cdot \left(2 + \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{+.f64}\left(\mathsf{+.f64}\left(\alpha, \beta\right), \color{blue}{\mathsf{*.f64}\left(2, 1\right)}\right), 1\right)\right) \]
      4. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left(2 + \alpha\right), \left(2 + \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{+.f64}\left(\mathsf{+.f64}\left(\alpha, \beta\right), \color{blue}{\mathsf{*.f64}\left(2, 1\right)}\right), 1\right)\right) \]
      5. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{+.f64}\left(2, \alpha\right), \left(2 + \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{+.f64}\left(\mathsf{+.f64}\left(\alpha, \beta\right), \mathsf{*.f64}\left(\color{blue}{2}, 1\right)\right), 1\right)\right) \]
      6. +-lowering-+.f6498.7%

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{+.f64}\left(2, \alpha\right), \mathsf{+.f64}\left(2, \alpha\right)\right)\right), \mathsf{+.f64}\left(\mathsf{+.f64}\left(\mathsf{+.f64}\left(\alpha, \beta\right), \mathsf{*.f64}\left(2, \color{blue}{1}\right)\right), 1\right)\right) \]
    5. Simplified98.7%

      \[\leadsto \frac{\color{blue}{\frac{1 + \alpha}{\left(2 + \alpha\right) \cdot \left(2 + \alpha\right)}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]

    if 3.2000000000000002 < beta

    1. Initial program 87.4%

      \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
    2. Add Preprocessing
    3. Taylor expanded in beta around inf

      \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\color{blue}{\left(1 + \alpha\right)}, \mathsf{+.f64}\left(\mathsf{+.f64}\left(\alpha, \beta\right), \mathsf{*.f64}\left(2, 1\right)\right)\right), \mathsf{+.f64}\left(\mathsf{+.f64}\left(\mathsf{+.f64}\left(\alpha, \beta\right), \mathsf{*.f64}\left(2, 1\right)\right), 1\right)\right) \]
    4. Step-by-step derivation
      1. +-lowering-+.f6483.4%

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\mathsf{+.f64}\left(\alpha, \beta\right), \mathsf{*.f64}\left(2, 1\right)\right)\right), \mathsf{+.f64}\left(\mathsf{+.f64}\left(\color{blue}{\mathsf{+.f64}\left(\alpha, \beta\right)}, \mathsf{*.f64}\left(2, 1\right)\right), 1\right)\right) \]
    5. Simplified83.4%

      \[\leadsto \frac{\frac{\color{blue}{1 + \alpha}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
    6. Step-by-step derivation
      1. frac-2negN/A

        \[\leadsto \frac{\frac{\mathsf{neg}\left(\left(1 + \alpha\right)\right)}{\mathsf{neg}\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
      2. metadata-evalN/A

        \[\leadsto \frac{\frac{\mathsf{neg}\left(\left(1 + \alpha\right)\right)}{\mathsf{neg}\left(\left(\left(\alpha + \beta\right) + 2\right)\right)}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
      3. associate-+r+N/A

        \[\leadsto \frac{\frac{\mathsf{neg}\left(\left(1 + \alpha\right)\right)}{\mathsf{neg}\left(\left(\alpha + \left(\beta + 2\right)\right)\right)}}{\left(\left(\alpha + \beta\right) + \color{blue}{2} \cdot 1\right) + 1} \]
      4. metadata-evalN/A

        \[\leadsto \frac{\frac{\mathsf{neg}\left(\left(1 + \alpha\right)\right)}{\mathsf{neg}\left(\left(\alpha + \left(\beta + 2\right)\right)\right)}}{\left(\left(\alpha + \beta\right) + 2\right) + 1} \]
      5. associate-+l+N/A

        \[\leadsto \frac{\frac{\mathsf{neg}\left(\left(1 + \alpha\right)\right)}{\mathsf{neg}\left(\left(\alpha + \left(\beta + 2\right)\right)\right)}}{\left(\alpha + \beta\right) + \color{blue}{\left(2 + 1\right)}} \]
      6. metadata-evalN/A

        \[\leadsto \frac{\frac{\mathsf{neg}\left(\left(1 + \alpha\right)\right)}{\mathsf{neg}\left(\left(\alpha + \left(\beta + 2\right)\right)\right)}}{\left(\alpha + \beta\right) + 3} \]
      7. associate-+r+N/A

        \[\leadsto \frac{\frac{\mathsf{neg}\left(\left(1 + \alpha\right)\right)}{\mathsf{neg}\left(\left(\alpha + \left(\beta + 2\right)\right)\right)}}{\alpha + \color{blue}{\left(\beta + 3\right)}} \]
      8. associate-/l/N/A

        \[\leadsto \frac{\mathsf{neg}\left(\left(1 + \alpha\right)\right)}{\color{blue}{\left(\alpha + \left(\beta + 3\right)\right) \cdot \left(\mathsf{neg}\left(\left(\alpha + \left(\beta + 2\right)\right)\right)\right)}} \]
      9. associate-/r*N/A

        \[\leadsto \frac{\frac{\mathsf{neg}\left(\left(1 + \alpha\right)\right)}{\alpha + \left(\beta + 3\right)}}{\color{blue}{\mathsf{neg}\left(\left(\alpha + \left(\beta + 2\right)\right)\right)}} \]
      10. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\frac{\mathsf{neg}\left(\left(1 + \alpha\right)\right)}{\alpha + \left(\beta + 3\right)}\right), \color{blue}{\left(\mathsf{neg}\left(\left(\alpha + \left(\beta + 2\right)\right)\right)\right)}\right) \]
      11. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\left(\mathsf{neg}\left(\left(1 + \alpha\right)\right)\right), \left(\alpha + \left(\beta + 3\right)\right)\right), \left(\mathsf{neg}\left(\color{blue}{\left(\alpha + \left(\beta + 2\right)\right)}\right)\right)\right) \]
      12. distribute-neg-inN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\left(\left(\mathsf{neg}\left(1\right)\right) + \left(\mathsf{neg}\left(\alpha\right)\right)\right), \left(\alpha + \left(\beta + 3\right)\right)\right), \left(\mathsf{neg}\left(\left(\color{blue}{\alpha} + \left(\beta + 2\right)\right)\right)\right)\right) \]
      13. metadata-evalN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\left(-1 + \left(\mathsf{neg}\left(\alpha\right)\right)\right), \left(\alpha + \left(\beta + 3\right)\right)\right), \left(\mathsf{neg}\left(\left(\alpha + \left(\beta + 2\right)\right)\right)\right)\right) \]
      14. unsub-negN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\left(-1 - \alpha\right), \left(\alpha + \left(\beta + 3\right)\right)\right), \left(\mathsf{neg}\left(\left(\color{blue}{\alpha} + \left(\beta + 2\right)\right)\right)\right)\right) \]
      15. --lowering--.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{\_.f64}\left(-1, \alpha\right), \left(\alpha + \left(\beta + 3\right)\right)\right), \left(\mathsf{neg}\left(\left(\color{blue}{\alpha} + \left(\beta + 2\right)\right)\right)\right)\right) \]
      16. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{\_.f64}\left(-1, \alpha\right), \mathsf{+.f64}\left(\alpha, \left(\beta + 3\right)\right)\right), \left(\mathsf{neg}\left(\left(\alpha + \color{blue}{\left(\beta + 2\right)}\right)\right)\right)\right) \]
      17. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{\_.f64}\left(-1, \alpha\right), \mathsf{+.f64}\left(\alpha, \mathsf{+.f64}\left(\beta, 3\right)\right)\right), \left(\mathsf{neg}\left(\left(\alpha + \left(\beta + \color{blue}{2}\right)\right)\right)\right)\right) \]
      18. associate-+r+N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{\_.f64}\left(-1, \alpha\right), \mathsf{+.f64}\left(\alpha, \mathsf{+.f64}\left(\beta, 3\right)\right)\right), \left(\mathsf{neg}\left(\left(\left(\alpha + \beta\right) + 2\right)\right)\right)\right) \]
      19. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{\_.f64}\left(-1, \alpha\right), \mathsf{+.f64}\left(\alpha, \mathsf{+.f64}\left(\beta, 3\right)\right)\right), \left(\mathsf{neg}\left(\left(2 + \left(\alpha + \beta\right)\right)\right)\right)\right) \]
    7. Applied egg-rr83.4%

      \[\leadsto \color{blue}{\frac{\frac{-1 - \alpha}{\alpha + \left(\beta + 3\right)}}{-2 - \left(\beta + \alpha\right)}} \]
  3. Recombined 2 regimes into one program.
  4. Final simplification93.0%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\beta \leq 3.2:\\ \;\;\;\;\frac{\frac{1 + \alpha}{\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)}}{1 + \left(2 + \left(\alpha + \beta\right)\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{-1 - \alpha}{\alpha + \left(\beta + 3\right)}}{-2 - \left(\alpha + \beta\right)}\\ \end{array} \]
  5. Add Preprocessing

Alternative 6: 97.4% accurate, 1.7× speedup?

\[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 9.5:\\ \;\;\;\;\frac{\frac{1 + \alpha}{\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)}}{\alpha + 3}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{-1 - \alpha}{\alpha + \left(\beta + 3\right)}}{-2 - \left(\alpha + \beta\right)}\\ \end{array} \end{array} \]
NOTE: alpha and beta should be sorted in increasing order before calling this function.
(FPCore (alpha beta)
 :precision binary64
 (if (<= beta 9.5)
   (/ (/ (+ 1.0 alpha) (* (+ alpha 2.0) (+ alpha 2.0))) (+ alpha 3.0))
   (/ (/ (- -1.0 alpha) (+ alpha (+ beta 3.0))) (- -2.0 (+ alpha beta)))))
assert(alpha < beta);
double code(double alpha, double beta) {
	double tmp;
	if (beta <= 9.5) {
		tmp = ((1.0 + alpha) / ((alpha + 2.0) * (alpha + 2.0))) / (alpha + 3.0);
	} else {
		tmp = ((-1.0 - alpha) / (alpha + (beta + 3.0))) / (-2.0 - (alpha + beta));
	}
	return tmp;
}
NOTE: alpha and beta should be sorted in increasing order before calling this function.
real(8) function code(alpha, beta)
    real(8), intent (in) :: alpha
    real(8), intent (in) :: beta
    real(8) :: tmp
    if (beta <= 9.5d0) then
        tmp = ((1.0d0 + alpha) / ((alpha + 2.0d0) * (alpha + 2.0d0))) / (alpha + 3.0d0)
    else
        tmp = (((-1.0d0) - alpha) / (alpha + (beta + 3.0d0))) / ((-2.0d0) - (alpha + beta))
    end if
    code = tmp
end function
assert alpha < beta;
public static double code(double alpha, double beta) {
	double tmp;
	if (beta <= 9.5) {
		tmp = ((1.0 + alpha) / ((alpha + 2.0) * (alpha + 2.0))) / (alpha + 3.0);
	} else {
		tmp = ((-1.0 - alpha) / (alpha + (beta + 3.0))) / (-2.0 - (alpha + beta));
	}
	return tmp;
}
[alpha, beta] = sort([alpha, beta])
def code(alpha, beta):
	tmp = 0
	if beta <= 9.5:
		tmp = ((1.0 + alpha) / ((alpha + 2.0) * (alpha + 2.0))) / (alpha + 3.0)
	else:
		tmp = ((-1.0 - alpha) / (alpha + (beta + 3.0))) / (-2.0 - (alpha + beta))
	return tmp
alpha, beta = sort([alpha, beta])
function code(alpha, beta)
	tmp = 0.0
	if (beta <= 9.5)
		tmp = Float64(Float64(Float64(1.0 + alpha) / Float64(Float64(alpha + 2.0) * Float64(alpha + 2.0))) / Float64(alpha + 3.0));
	else
		tmp = Float64(Float64(Float64(-1.0 - alpha) / Float64(alpha + Float64(beta + 3.0))) / Float64(-2.0 - Float64(alpha + beta)));
	end
	return tmp
end
alpha, beta = num2cell(sort([alpha, beta])){:}
function tmp_2 = code(alpha, beta)
	tmp = 0.0;
	if (beta <= 9.5)
		tmp = ((1.0 + alpha) / ((alpha + 2.0) * (alpha + 2.0))) / (alpha + 3.0);
	else
		tmp = ((-1.0 - alpha) / (alpha + (beta + 3.0))) / (-2.0 - (alpha + beta));
	end
	tmp_2 = tmp;
end
NOTE: alpha and beta should be sorted in increasing order before calling this function.
code[alpha_, beta_] := If[LessEqual[beta, 9.5], N[(N[(N[(1.0 + alpha), $MachinePrecision] / N[(N[(alpha + 2.0), $MachinePrecision] * N[(alpha + 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(alpha + 3.0), $MachinePrecision]), $MachinePrecision], N[(N[(N[(-1.0 - alpha), $MachinePrecision] / N[(alpha + N[(beta + 3.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(-2.0 - N[(alpha + beta), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
[alpha, beta] = \mathsf{sort}([alpha, beta])\\
\\
\begin{array}{l}
\mathbf{if}\;\beta \leq 9.5:\\
\;\;\;\;\frac{\frac{1 + \alpha}{\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)}}{\alpha + 3}\\

\mathbf{else}:\\
\;\;\;\;\frac{\frac{-1 - \alpha}{\alpha + \left(\beta + 3\right)}}{-2 - \left(\alpha + \beta\right)}\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if beta < 9.5

    1. Initial program 99.9%

      \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
    2. Step-by-step derivation
      1. associate-/l/N/A

        \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
      2. associate-/l/N/A

        \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
      3. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
      4. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      5. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      6. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      7. associate-+r+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      8. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      9. *-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      10. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      11. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      12. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      13. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      14. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      15. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    3. Simplified93.6%

      \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
    4. Add Preprocessing
    5. Applied egg-rr99.8%

      \[\leadsto \color{blue}{\frac{1 + \beta}{\alpha + \left(\beta + 3\right)} \cdot {\left(\frac{\alpha + \left(\beta + 2\right)}{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}\right)}^{-1}} \]
    6. Taylor expanded in beta around 0

      \[\leadsto \color{blue}{\frac{1 + \alpha}{{\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)}} \]
    7. Step-by-step derivation
      1. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(1 + \alpha\right), \color{blue}{\left({\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)\right)}\right) \]
      2. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\color{blue}{{\left(2 + \alpha\right)}^{2}} \cdot \left(3 + \alpha\right)\right)\right) \]
      3. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left({\left(2 + \alpha\right)}^{2}\right), \color{blue}{\left(3 + \alpha\right)}\right)\right) \]
      4. unpow2N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left(\left(2 + \alpha\right) \cdot \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
      5. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(2 + \alpha\right), \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
      6. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 2\right), \left(2 + \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
      7. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \left(2 + \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
      8. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \left(\alpha + 2\right)\right), \left(3 + \alpha\right)\right)\right) \]
      9. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \left(3 + \alpha\right)\right)\right) \]
      10. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \left(\alpha + \color{blue}{3}\right)\right)\right) \]
      11. +-lowering-+.f6492.2%

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \mathsf{+.f64}\left(\alpha, \color{blue}{3}\right)\right)\right) \]
    8. Simplified92.2%

      \[\leadsto \color{blue}{\frac{1 + \alpha}{\left(\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)\right) \cdot \left(\alpha + 3\right)}} \]
    9. Step-by-step derivation
      1. associate-/r*N/A

        \[\leadsto \frac{\frac{1 + \alpha}{\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)}}{\color{blue}{\alpha + 3}} \]
      2. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\frac{1 + \alpha}{\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)}\right), \color{blue}{\left(\alpha + 3\right)}\right) \]
      3. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\left(1 + \alpha\right), \left(\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)\right)\right), \left(\color{blue}{\alpha} + 3\right)\right) \]
      4. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)\right)\right), \left(\alpha + 3\right)\right) \]
      5. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left(\alpha + 2\right), \left(\alpha + 2\right)\right)\right), \left(\alpha + 3\right)\right) \]
      6. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \left(\alpha + 2\right)\right)\right), \left(\alpha + 3\right)\right) \]
      7. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \left(\alpha + 3\right)\right) \]
      8. +-lowering-+.f6497.9%

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{+.f64}\left(\alpha, \color{blue}{3}\right)\right) \]
    10. Applied egg-rr97.9%

      \[\leadsto \color{blue}{\frac{\frac{1 + \alpha}{\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)}}{\alpha + 3}} \]

    if 9.5 < beta

    1. Initial program 87.4%

      \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
    2. Add Preprocessing
    3. Taylor expanded in beta around inf

      \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\color{blue}{\left(1 + \alpha\right)}, \mathsf{+.f64}\left(\mathsf{+.f64}\left(\alpha, \beta\right), \mathsf{*.f64}\left(2, 1\right)\right)\right), \mathsf{+.f64}\left(\mathsf{+.f64}\left(\mathsf{+.f64}\left(\alpha, \beta\right), \mathsf{*.f64}\left(2, 1\right)\right), 1\right)\right) \]
    4. Step-by-step derivation
      1. +-lowering-+.f6483.4%

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{+.f64}\left(\mathsf{+.f64}\left(\alpha, \beta\right), \mathsf{*.f64}\left(2, 1\right)\right)\right), \mathsf{+.f64}\left(\mathsf{+.f64}\left(\color{blue}{\mathsf{+.f64}\left(\alpha, \beta\right)}, \mathsf{*.f64}\left(2, 1\right)\right), 1\right)\right) \]
    5. Simplified83.4%

      \[\leadsto \frac{\frac{\color{blue}{1 + \alpha}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
    6. Step-by-step derivation
      1. frac-2negN/A

        \[\leadsto \frac{\frac{\mathsf{neg}\left(\left(1 + \alpha\right)\right)}{\mathsf{neg}\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
      2. metadata-evalN/A

        \[\leadsto \frac{\frac{\mathsf{neg}\left(\left(1 + \alpha\right)\right)}{\mathsf{neg}\left(\left(\left(\alpha + \beta\right) + 2\right)\right)}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
      3. associate-+r+N/A

        \[\leadsto \frac{\frac{\mathsf{neg}\left(\left(1 + \alpha\right)\right)}{\mathsf{neg}\left(\left(\alpha + \left(\beta + 2\right)\right)\right)}}{\left(\left(\alpha + \beta\right) + \color{blue}{2} \cdot 1\right) + 1} \]
      4. metadata-evalN/A

        \[\leadsto \frac{\frac{\mathsf{neg}\left(\left(1 + \alpha\right)\right)}{\mathsf{neg}\left(\left(\alpha + \left(\beta + 2\right)\right)\right)}}{\left(\left(\alpha + \beta\right) + 2\right) + 1} \]
      5. associate-+l+N/A

        \[\leadsto \frac{\frac{\mathsf{neg}\left(\left(1 + \alpha\right)\right)}{\mathsf{neg}\left(\left(\alpha + \left(\beta + 2\right)\right)\right)}}{\left(\alpha + \beta\right) + \color{blue}{\left(2 + 1\right)}} \]
      6. metadata-evalN/A

        \[\leadsto \frac{\frac{\mathsf{neg}\left(\left(1 + \alpha\right)\right)}{\mathsf{neg}\left(\left(\alpha + \left(\beta + 2\right)\right)\right)}}{\left(\alpha + \beta\right) + 3} \]
      7. associate-+r+N/A

        \[\leadsto \frac{\frac{\mathsf{neg}\left(\left(1 + \alpha\right)\right)}{\mathsf{neg}\left(\left(\alpha + \left(\beta + 2\right)\right)\right)}}{\alpha + \color{blue}{\left(\beta + 3\right)}} \]
      8. associate-/l/N/A

        \[\leadsto \frac{\mathsf{neg}\left(\left(1 + \alpha\right)\right)}{\color{blue}{\left(\alpha + \left(\beta + 3\right)\right) \cdot \left(\mathsf{neg}\left(\left(\alpha + \left(\beta + 2\right)\right)\right)\right)}} \]
      9. associate-/r*N/A

        \[\leadsto \frac{\frac{\mathsf{neg}\left(\left(1 + \alpha\right)\right)}{\alpha + \left(\beta + 3\right)}}{\color{blue}{\mathsf{neg}\left(\left(\alpha + \left(\beta + 2\right)\right)\right)}} \]
      10. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\frac{\mathsf{neg}\left(\left(1 + \alpha\right)\right)}{\alpha + \left(\beta + 3\right)}\right), \color{blue}{\left(\mathsf{neg}\left(\left(\alpha + \left(\beta + 2\right)\right)\right)\right)}\right) \]
      11. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\left(\mathsf{neg}\left(\left(1 + \alpha\right)\right)\right), \left(\alpha + \left(\beta + 3\right)\right)\right), \left(\mathsf{neg}\left(\color{blue}{\left(\alpha + \left(\beta + 2\right)\right)}\right)\right)\right) \]
      12. distribute-neg-inN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\left(\left(\mathsf{neg}\left(1\right)\right) + \left(\mathsf{neg}\left(\alpha\right)\right)\right), \left(\alpha + \left(\beta + 3\right)\right)\right), \left(\mathsf{neg}\left(\left(\color{blue}{\alpha} + \left(\beta + 2\right)\right)\right)\right)\right) \]
      13. metadata-evalN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\left(-1 + \left(\mathsf{neg}\left(\alpha\right)\right)\right), \left(\alpha + \left(\beta + 3\right)\right)\right), \left(\mathsf{neg}\left(\left(\alpha + \left(\beta + 2\right)\right)\right)\right)\right) \]
      14. unsub-negN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\left(-1 - \alpha\right), \left(\alpha + \left(\beta + 3\right)\right)\right), \left(\mathsf{neg}\left(\left(\color{blue}{\alpha} + \left(\beta + 2\right)\right)\right)\right)\right) \]
      15. --lowering--.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{\_.f64}\left(-1, \alpha\right), \left(\alpha + \left(\beta + 3\right)\right)\right), \left(\mathsf{neg}\left(\left(\color{blue}{\alpha} + \left(\beta + 2\right)\right)\right)\right)\right) \]
      16. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{\_.f64}\left(-1, \alpha\right), \mathsf{+.f64}\left(\alpha, \left(\beta + 3\right)\right)\right), \left(\mathsf{neg}\left(\left(\alpha + \color{blue}{\left(\beta + 2\right)}\right)\right)\right)\right) \]
      17. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{\_.f64}\left(-1, \alpha\right), \mathsf{+.f64}\left(\alpha, \mathsf{+.f64}\left(\beta, 3\right)\right)\right), \left(\mathsf{neg}\left(\left(\alpha + \left(\beta + \color{blue}{2}\right)\right)\right)\right)\right) \]
      18. associate-+r+N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{\_.f64}\left(-1, \alpha\right), \mathsf{+.f64}\left(\alpha, \mathsf{+.f64}\left(\beta, 3\right)\right)\right), \left(\mathsf{neg}\left(\left(\left(\alpha + \beta\right) + 2\right)\right)\right)\right) \]
      19. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{\_.f64}\left(-1, \alpha\right), \mathsf{+.f64}\left(\alpha, \mathsf{+.f64}\left(\beta, 3\right)\right)\right), \left(\mathsf{neg}\left(\left(2 + \left(\alpha + \beta\right)\right)\right)\right)\right) \]
    7. Applied egg-rr83.4%

      \[\leadsto \color{blue}{\frac{\frac{-1 - \alpha}{\alpha + \left(\beta + 3\right)}}{-2 - \left(\beta + \alpha\right)}} \]
  3. Recombined 2 regimes into one program.
  4. Final simplification92.5%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\beta \leq 9.5:\\ \;\;\;\;\frac{\frac{1 + \alpha}{\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)}}{\alpha + 3}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{-1 - \alpha}{\alpha + \left(\beta + 3\right)}}{-2 - \left(\alpha + \beta\right)}\\ \end{array} \]
  5. Add Preprocessing

Alternative 7: 97.4% accurate, 1.7× speedup?

\[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 2.5:\\ \;\;\;\;\frac{\frac{1 + \alpha}{\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)}}{\alpha + 3}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{1 + \alpha}{\beta}}{1 + \left(2 + \left(\alpha + \beta\right)\right)}\\ \end{array} \end{array} \]
NOTE: alpha and beta should be sorted in increasing order before calling this function.
(FPCore (alpha beta)
 :precision binary64
 (if (<= beta 2.5)
   (/ (/ (+ 1.0 alpha) (* (+ alpha 2.0) (+ alpha 2.0))) (+ alpha 3.0))
   (/ (/ (+ 1.0 alpha) beta) (+ 1.0 (+ 2.0 (+ alpha beta))))))
assert(alpha < beta);
double code(double alpha, double beta) {
	double tmp;
	if (beta <= 2.5) {
		tmp = ((1.0 + alpha) / ((alpha + 2.0) * (alpha + 2.0))) / (alpha + 3.0);
	} else {
		tmp = ((1.0 + alpha) / beta) / (1.0 + (2.0 + (alpha + beta)));
	}
	return tmp;
}
NOTE: alpha and beta should be sorted in increasing order before calling this function.
real(8) function code(alpha, beta)
    real(8), intent (in) :: alpha
    real(8), intent (in) :: beta
    real(8) :: tmp
    if (beta <= 2.5d0) then
        tmp = ((1.0d0 + alpha) / ((alpha + 2.0d0) * (alpha + 2.0d0))) / (alpha + 3.0d0)
    else
        tmp = ((1.0d0 + alpha) / beta) / (1.0d0 + (2.0d0 + (alpha + beta)))
    end if
    code = tmp
end function
assert alpha < beta;
public static double code(double alpha, double beta) {
	double tmp;
	if (beta <= 2.5) {
		tmp = ((1.0 + alpha) / ((alpha + 2.0) * (alpha + 2.0))) / (alpha + 3.0);
	} else {
		tmp = ((1.0 + alpha) / beta) / (1.0 + (2.0 + (alpha + beta)));
	}
	return tmp;
}
[alpha, beta] = sort([alpha, beta])
def code(alpha, beta):
	tmp = 0
	if beta <= 2.5:
		tmp = ((1.0 + alpha) / ((alpha + 2.0) * (alpha + 2.0))) / (alpha + 3.0)
	else:
		tmp = ((1.0 + alpha) / beta) / (1.0 + (2.0 + (alpha + beta)))
	return tmp
alpha, beta = sort([alpha, beta])
function code(alpha, beta)
	tmp = 0.0
	if (beta <= 2.5)
		tmp = Float64(Float64(Float64(1.0 + alpha) / Float64(Float64(alpha + 2.0) * Float64(alpha + 2.0))) / Float64(alpha + 3.0));
	else
		tmp = Float64(Float64(Float64(1.0 + alpha) / beta) / Float64(1.0 + Float64(2.0 + Float64(alpha + beta))));
	end
	return tmp
end
alpha, beta = num2cell(sort([alpha, beta])){:}
function tmp_2 = code(alpha, beta)
	tmp = 0.0;
	if (beta <= 2.5)
		tmp = ((1.0 + alpha) / ((alpha + 2.0) * (alpha + 2.0))) / (alpha + 3.0);
	else
		tmp = ((1.0 + alpha) / beta) / (1.0 + (2.0 + (alpha + beta)));
	end
	tmp_2 = tmp;
end
NOTE: alpha and beta should be sorted in increasing order before calling this function.
code[alpha_, beta_] := If[LessEqual[beta, 2.5], N[(N[(N[(1.0 + alpha), $MachinePrecision] / N[(N[(alpha + 2.0), $MachinePrecision] * N[(alpha + 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(alpha + 3.0), $MachinePrecision]), $MachinePrecision], N[(N[(N[(1.0 + alpha), $MachinePrecision] / beta), $MachinePrecision] / N[(1.0 + N[(2.0 + N[(alpha + beta), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
[alpha, beta] = \mathsf{sort}([alpha, beta])\\
\\
\begin{array}{l}
\mathbf{if}\;\beta \leq 2.5:\\
\;\;\;\;\frac{\frac{1 + \alpha}{\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)}}{\alpha + 3}\\

\mathbf{else}:\\
\;\;\;\;\frac{\frac{1 + \alpha}{\beta}}{1 + \left(2 + \left(\alpha + \beta\right)\right)}\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if beta < 2.5

    1. Initial program 99.9%

      \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
    2. Step-by-step derivation
      1. associate-/l/N/A

        \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
      2. associate-/l/N/A

        \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
      3. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
      4. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      5. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      6. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      7. associate-+r+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      8. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      9. *-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      10. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      11. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      12. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      13. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      14. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      15. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    3. Simplified93.6%

      \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
    4. Add Preprocessing
    5. Applied egg-rr99.8%

      \[\leadsto \color{blue}{\frac{1 + \beta}{\alpha + \left(\beta + 3\right)} \cdot {\left(\frac{\alpha + \left(\beta + 2\right)}{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}\right)}^{-1}} \]
    6. Taylor expanded in beta around 0

      \[\leadsto \color{blue}{\frac{1 + \alpha}{{\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)}} \]
    7. Step-by-step derivation
      1. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(1 + \alpha\right), \color{blue}{\left({\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)\right)}\right) \]
      2. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\color{blue}{{\left(2 + \alpha\right)}^{2}} \cdot \left(3 + \alpha\right)\right)\right) \]
      3. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left({\left(2 + \alpha\right)}^{2}\right), \color{blue}{\left(3 + \alpha\right)}\right)\right) \]
      4. unpow2N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left(\left(2 + \alpha\right) \cdot \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
      5. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(2 + \alpha\right), \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
      6. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 2\right), \left(2 + \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
      7. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \left(2 + \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
      8. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \left(\alpha + 2\right)\right), \left(3 + \alpha\right)\right)\right) \]
      9. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \left(3 + \alpha\right)\right)\right) \]
      10. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \left(\alpha + \color{blue}{3}\right)\right)\right) \]
      11. +-lowering-+.f6492.2%

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \mathsf{+.f64}\left(\alpha, \color{blue}{3}\right)\right)\right) \]
    8. Simplified92.2%

      \[\leadsto \color{blue}{\frac{1 + \alpha}{\left(\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)\right) \cdot \left(\alpha + 3\right)}} \]
    9. Step-by-step derivation
      1. associate-/r*N/A

        \[\leadsto \frac{\frac{1 + \alpha}{\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)}}{\color{blue}{\alpha + 3}} \]
      2. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\frac{1 + \alpha}{\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)}\right), \color{blue}{\left(\alpha + 3\right)}\right) \]
      3. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\left(1 + \alpha\right), \left(\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)\right)\right), \left(\color{blue}{\alpha} + 3\right)\right) \]
      4. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)\right)\right), \left(\alpha + 3\right)\right) \]
      5. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left(\alpha + 2\right), \left(\alpha + 2\right)\right)\right), \left(\alpha + 3\right)\right) \]
      6. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \left(\alpha + 2\right)\right)\right), \left(\alpha + 3\right)\right) \]
      7. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \left(\alpha + 3\right)\right) \]
      8. +-lowering-+.f6497.9%

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right)\right), \mathsf{+.f64}\left(\alpha, \color{blue}{3}\right)\right) \]
    10. Applied egg-rr97.9%

      \[\leadsto \color{blue}{\frac{\frac{1 + \alpha}{\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)}}{\alpha + 3}} \]

    if 2.5 < beta

    1. Initial program 87.4%

      \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
    2. Add Preprocessing
    3. Taylor expanded in beta around inf

      \[\leadsto \mathsf{/.f64}\left(\color{blue}{\left(\frac{1 + \alpha}{\beta}\right)}, \mathsf{+.f64}\left(\mathsf{+.f64}\left(\mathsf{+.f64}\left(\alpha, \beta\right), \mathsf{*.f64}\left(2, 1\right)\right), 1\right)\right) \]
    4. Step-by-step derivation
      1. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\left(1 + \alpha\right), \beta\right), \mathsf{+.f64}\left(\color{blue}{\mathsf{+.f64}\left(\mathsf{+.f64}\left(\alpha, \beta\right), \mathsf{*.f64}\left(2, 1\right)\right)}, 1\right)\right) \]
      2. +-lowering-+.f6483.0%

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \beta\right), \mathsf{+.f64}\left(\mathsf{+.f64}\left(\color{blue}{\mathsf{+.f64}\left(\alpha, \beta\right)}, \mathsf{*.f64}\left(2, 1\right)\right), 1\right)\right) \]
    5. Simplified83.0%

      \[\leadsto \frac{\color{blue}{\frac{1 + \alpha}{\beta}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
  3. Recombined 2 regimes into one program.
  4. Final simplification92.4%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\beta \leq 2.5:\\ \;\;\;\;\frac{\frac{1 + \alpha}{\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)}}{\alpha + 3}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{1 + \alpha}{\beta}}{1 + \left(2 + \left(\alpha + \beta\right)\right)}\\ \end{array} \]
  5. Add Preprocessing

Alternative 8: 97.4% accurate, 1.7× speedup?

\[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 6.5:\\ \;\;\;\;\frac{1 + \alpha}{\left(\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)\right) \cdot \left(\alpha + 3\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{1 + \alpha}{\beta}}{1 + \left(2 + \left(\alpha + \beta\right)\right)}\\ \end{array} \end{array} \]
NOTE: alpha and beta should be sorted in increasing order before calling this function.
(FPCore (alpha beta)
 :precision binary64
 (if (<= beta 6.5)
   (/ (+ 1.0 alpha) (* (* (+ alpha 2.0) (+ alpha 2.0)) (+ alpha 3.0)))
   (/ (/ (+ 1.0 alpha) beta) (+ 1.0 (+ 2.0 (+ alpha beta))))))
assert(alpha < beta);
double code(double alpha, double beta) {
	double tmp;
	if (beta <= 6.5) {
		tmp = (1.0 + alpha) / (((alpha + 2.0) * (alpha + 2.0)) * (alpha + 3.0));
	} else {
		tmp = ((1.0 + alpha) / beta) / (1.0 + (2.0 + (alpha + beta)));
	}
	return tmp;
}
NOTE: alpha and beta should be sorted in increasing order before calling this function.
real(8) function code(alpha, beta)
    real(8), intent (in) :: alpha
    real(8), intent (in) :: beta
    real(8) :: tmp
    if (beta <= 6.5d0) then
        tmp = (1.0d0 + alpha) / (((alpha + 2.0d0) * (alpha + 2.0d0)) * (alpha + 3.0d0))
    else
        tmp = ((1.0d0 + alpha) / beta) / (1.0d0 + (2.0d0 + (alpha + beta)))
    end if
    code = tmp
end function
assert alpha < beta;
public static double code(double alpha, double beta) {
	double tmp;
	if (beta <= 6.5) {
		tmp = (1.0 + alpha) / (((alpha + 2.0) * (alpha + 2.0)) * (alpha + 3.0));
	} else {
		tmp = ((1.0 + alpha) / beta) / (1.0 + (2.0 + (alpha + beta)));
	}
	return tmp;
}
[alpha, beta] = sort([alpha, beta])
def code(alpha, beta):
	tmp = 0
	if beta <= 6.5:
		tmp = (1.0 + alpha) / (((alpha + 2.0) * (alpha + 2.0)) * (alpha + 3.0))
	else:
		tmp = ((1.0 + alpha) / beta) / (1.0 + (2.0 + (alpha + beta)))
	return tmp
alpha, beta = sort([alpha, beta])
function code(alpha, beta)
	tmp = 0.0
	if (beta <= 6.5)
		tmp = Float64(Float64(1.0 + alpha) / Float64(Float64(Float64(alpha + 2.0) * Float64(alpha + 2.0)) * Float64(alpha + 3.0)));
	else
		tmp = Float64(Float64(Float64(1.0 + alpha) / beta) / Float64(1.0 + Float64(2.0 + Float64(alpha + beta))));
	end
	return tmp
end
alpha, beta = num2cell(sort([alpha, beta])){:}
function tmp_2 = code(alpha, beta)
	tmp = 0.0;
	if (beta <= 6.5)
		tmp = (1.0 + alpha) / (((alpha + 2.0) * (alpha + 2.0)) * (alpha + 3.0));
	else
		tmp = ((1.0 + alpha) / beta) / (1.0 + (2.0 + (alpha + beta)));
	end
	tmp_2 = tmp;
end
NOTE: alpha and beta should be sorted in increasing order before calling this function.
code[alpha_, beta_] := If[LessEqual[beta, 6.5], N[(N[(1.0 + alpha), $MachinePrecision] / N[(N[(N[(alpha + 2.0), $MachinePrecision] * N[(alpha + 2.0), $MachinePrecision]), $MachinePrecision] * N[(alpha + 3.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(N[(1.0 + alpha), $MachinePrecision] / beta), $MachinePrecision] / N[(1.0 + N[(2.0 + N[(alpha + beta), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
[alpha, beta] = \mathsf{sort}([alpha, beta])\\
\\
\begin{array}{l}
\mathbf{if}\;\beta \leq 6.5:\\
\;\;\;\;\frac{1 + \alpha}{\left(\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)\right) \cdot \left(\alpha + 3\right)}\\

\mathbf{else}:\\
\;\;\;\;\frac{\frac{1 + \alpha}{\beta}}{1 + \left(2 + \left(\alpha + \beta\right)\right)}\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if beta < 6.5

    1. Initial program 99.9%

      \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
    2. Step-by-step derivation
      1. associate-/l/N/A

        \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
      2. associate-/l/N/A

        \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
      3. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
      4. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      5. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      6. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      7. associate-+r+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      8. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      9. *-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      10. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      11. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      12. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      13. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      14. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      15. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    3. Simplified93.6%

      \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
    4. Add Preprocessing
    5. Taylor expanded in beta around 0

      \[\leadsto \color{blue}{\frac{1 + \alpha}{{\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)}} \]
    6. Step-by-step derivation
      1. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(1 + \alpha\right), \color{blue}{\left({\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)\right)}\right) \]
      2. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\color{blue}{{\left(2 + \alpha\right)}^{2}} \cdot \left(3 + \alpha\right)\right)\right) \]
      3. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left({\left(2 + \alpha\right)}^{2}\right), \color{blue}{\left(3 + \alpha\right)}\right)\right) \]
      4. unpow2N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left(\left(2 + \alpha\right) \cdot \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
      5. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(2 + \alpha\right), \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
      6. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(2, \alpha\right), \left(2 + \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
      7. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(2, \alpha\right), \mathsf{+.f64}\left(2, \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
      8. +-lowering-+.f6492.2%

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(2, \alpha\right), \mathsf{+.f64}\left(2, \alpha\right)\right), \mathsf{+.f64}\left(3, \color{blue}{\alpha}\right)\right)\right) \]
    7. Simplified92.2%

      \[\leadsto \color{blue}{\frac{1 + \alpha}{\left(\left(2 + \alpha\right) \cdot \left(2 + \alpha\right)\right) \cdot \left(3 + \alpha\right)}} \]

    if 6.5 < beta

    1. Initial program 87.4%

      \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
    2. Add Preprocessing
    3. Taylor expanded in beta around inf

      \[\leadsto \mathsf{/.f64}\left(\color{blue}{\left(\frac{1 + \alpha}{\beta}\right)}, \mathsf{+.f64}\left(\mathsf{+.f64}\left(\mathsf{+.f64}\left(\alpha, \beta\right), \mathsf{*.f64}\left(2, 1\right)\right), 1\right)\right) \]
    4. Step-by-step derivation
      1. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\left(1 + \alpha\right), \beta\right), \mathsf{+.f64}\left(\color{blue}{\mathsf{+.f64}\left(\mathsf{+.f64}\left(\alpha, \beta\right), \mathsf{*.f64}\left(2, 1\right)\right)}, 1\right)\right) \]
      2. +-lowering-+.f6483.0%

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \beta\right), \mathsf{+.f64}\left(\mathsf{+.f64}\left(\color{blue}{\mathsf{+.f64}\left(\alpha, \beta\right)}, \mathsf{*.f64}\left(2, 1\right)\right), 1\right)\right) \]
    5. Simplified83.0%

      \[\leadsto \frac{\color{blue}{\frac{1 + \alpha}{\beta}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
  3. Recombined 2 regimes into one program.
  4. Final simplification88.8%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\beta \leq 6.5:\\ \;\;\;\;\frac{1 + \alpha}{\left(\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)\right) \cdot \left(\alpha + 3\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{1 + \alpha}{\beta}}{1 + \left(2 + \left(\alpha + \beta\right)\right)}\\ \end{array} \]
  5. Add Preprocessing

Alternative 9: 97.3% accurate, 1.7× speedup?

\[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 7.2:\\ \;\;\;\;\frac{1 + \alpha}{\left(\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)\right) \cdot \left(\alpha + 3\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{1}{\beta}}{\frac{\beta}{1 + \alpha}}\\ \end{array} \end{array} \]
NOTE: alpha and beta should be sorted in increasing order before calling this function.
(FPCore (alpha beta)
 :precision binary64
 (if (<= beta 7.2)
   (/ (+ 1.0 alpha) (* (* (+ alpha 2.0) (+ alpha 2.0)) (+ alpha 3.0)))
   (/ (/ 1.0 beta) (/ beta (+ 1.0 alpha)))))
assert(alpha < beta);
double code(double alpha, double beta) {
	double tmp;
	if (beta <= 7.2) {
		tmp = (1.0 + alpha) / (((alpha + 2.0) * (alpha + 2.0)) * (alpha + 3.0));
	} else {
		tmp = (1.0 / beta) / (beta / (1.0 + alpha));
	}
	return tmp;
}
NOTE: alpha and beta should be sorted in increasing order before calling this function.
real(8) function code(alpha, beta)
    real(8), intent (in) :: alpha
    real(8), intent (in) :: beta
    real(8) :: tmp
    if (beta <= 7.2d0) then
        tmp = (1.0d0 + alpha) / (((alpha + 2.0d0) * (alpha + 2.0d0)) * (alpha + 3.0d0))
    else
        tmp = (1.0d0 / beta) / (beta / (1.0d0 + alpha))
    end if
    code = tmp
end function
assert alpha < beta;
public static double code(double alpha, double beta) {
	double tmp;
	if (beta <= 7.2) {
		tmp = (1.0 + alpha) / (((alpha + 2.0) * (alpha + 2.0)) * (alpha + 3.0));
	} else {
		tmp = (1.0 / beta) / (beta / (1.0 + alpha));
	}
	return tmp;
}
[alpha, beta] = sort([alpha, beta])
def code(alpha, beta):
	tmp = 0
	if beta <= 7.2:
		tmp = (1.0 + alpha) / (((alpha + 2.0) * (alpha + 2.0)) * (alpha + 3.0))
	else:
		tmp = (1.0 / beta) / (beta / (1.0 + alpha))
	return tmp
alpha, beta = sort([alpha, beta])
function code(alpha, beta)
	tmp = 0.0
	if (beta <= 7.2)
		tmp = Float64(Float64(1.0 + alpha) / Float64(Float64(Float64(alpha + 2.0) * Float64(alpha + 2.0)) * Float64(alpha + 3.0)));
	else
		tmp = Float64(Float64(1.0 / beta) / Float64(beta / Float64(1.0 + alpha)));
	end
	return tmp
end
alpha, beta = num2cell(sort([alpha, beta])){:}
function tmp_2 = code(alpha, beta)
	tmp = 0.0;
	if (beta <= 7.2)
		tmp = (1.0 + alpha) / (((alpha + 2.0) * (alpha + 2.0)) * (alpha + 3.0));
	else
		tmp = (1.0 / beta) / (beta / (1.0 + alpha));
	end
	tmp_2 = tmp;
end
NOTE: alpha and beta should be sorted in increasing order before calling this function.
code[alpha_, beta_] := If[LessEqual[beta, 7.2], N[(N[(1.0 + alpha), $MachinePrecision] / N[(N[(N[(alpha + 2.0), $MachinePrecision] * N[(alpha + 2.0), $MachinePrecision]), $MachinePrecision] * N[(alpha + 3.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(1.0 / beta), $MachinePrecision] / N[(beta / N[(1.0 + alpha), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
[alpha, beta] = \mathsf{sort}([alpha, beta])\\
\\
\begin{array}{l}
\mathbf{if}\;\beta \leq 7.2:\\
\;\;\;\;\frac{1 + \alpha}{\left(\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)\right) \cdot \left(\alpha + 3\right)}\\

\mathbf{else}:\\
\;\;\;\;\frac{\frac{1}{\beta}}{\frac{\beta}{1 + \alpha}}\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if beta < 7.20000000000000018

    1. Initial program 99.9%

      \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
    2. Step-by-step derivation
      1. associate-/l/N/A

        \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
      2. associate-/l/N/A

        \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
      3. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
      4. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      5. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      6. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      7. associate-+r+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      8. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      9. *-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      10. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      11. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      12. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      13. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      14. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      15. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    3. Simplified93.6%

      \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
    4. Add Preprocessing
    5. Taylor expanded in beta around 0

      \[\leadsto \color{blue}{\frac{1 + \alpha}{{\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)}} \]
    6. Step-by-step derivation
      1. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(1 + \alpha\right), \color{blue}{\left({\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)\right)}\right) \]
      2. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\color{blue}{{\left(2 + \alpha\right)}^{2}} \cdot \left(3 + \alpha\right)\right)\right) \]
      3. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left({\left(2 + \alpha\right)}^{2}\right), \color{blue}{\left(3 + \alpha\right)}\right)\right) \]
      4. unpow2N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left(\left(2 + \alpha\right) \cdot \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
      5. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(2 + \alpha\right), \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
      6. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(2, \alpha\right), \left(2 + \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
      7. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(2, \alpha\right), \mathsf{+.f64}\left(2, \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
      8. +-lowering-+.f6492.2%

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(2, \alpha\right), \mathsf{+.f64}\left(2, \alpha\right)\right), \mathsf{+.f64}\left(3, \color{blue}{\alpha}\right)\right)\right) \]
    7. Simplified92.2%

      \[\leadsto \color{blue}{\frac{1 + \alpha}{\left(\left(2 + \alpha\right) \cdot \left(2 + \alpha\right)\right) \cdot \left(3 + \alpha\right)}} \]

    if 7.20000000000000018 < beta

    1. Initial program 87.4%

      \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
    2. Step-by-step derivation
      1. associate-/l/N/A

        \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
      2. associate-/l/N/A

        \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
      3. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
      4. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      5. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      6. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      7. associate-+r+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      8. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      9. *-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      10. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      11. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      12. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      13. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      14. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      15. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    3. Simplified70.3%

      \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
    4. Add Preprocessing
    5. Taylor expanded in beta around inf

      \[\leadsto \color{blue}{\frac{1 + \alpha}{{\beta}^{2}}} \]
    6. Step-by-step derivation
      1. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(1 + \alpha\right), \color{blue}{\left({\beta}^{2}\right)}\right) \]
      2. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left({\color{blue}{\beta}}^{2}\right)\right) \]
      3. unpow2N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\beta \cdot \color{blue}{\beta}\right)\right) \]
      4. *-lowering-*.f6477.5%

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\beta, \color{blue}{\beta}\right)\right) \]
    7. Simplified77.5%

      \[\leadsto \color{blue}{\frac{1 + \alpha}{\beta \cdot \beta}} \]
    8. Step-by-step derivation
      1. clear-numN/A

        \[\leadsto \frac{1}{\color{blue}{\frac{\beta \cdot \beta}{1 + \alpha}}} \]
      2. associate-/l*N/A

        \[\leadsto \frac{1}{\beta \cdot \color{blue}{\frac{\beta}{1 + \alpha}}} \]
      3. associate-/r*N/A

        \[\leadsto \frac{\frac{1}{\beta}}{\color{blue}{\frac{\beta}{1 + \alpha}}} \]
      4. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\frac{1}{\beta}\right), \color{blue}{\left(\frac{\beta}{1 + \alpha}\right)}\right) \]
      5. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(1, \beta\right), \left(\frac{\color{blue}{\beta}}{1 + \alpha}\right)\right) \]
      6. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(1, \beta\right), \mathsf{/.f64}\left(\beta, \color{blue}{\left(1 + \alpha\right)}\right)\right) \]
      7. +-lowering-+.f6482.8%

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(1, \beta\right), \mathsf{/.f64}\left(\beta, \mathsf{+.f64}\left(1, \color{blue}{\alpha}\right)\right)\right) \]
    9. Applied egg-rr82.8%

      \[\leadsto \color{blue}{\frac{\frac{1}{\beta}}{\frac{\beta}{1 + \alpha}}} \]
  3. Recombined 2 regimes into one program.
  4. Final simplification88.7%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\beta \leq 7.2:\\ \;\;\;\;\frac{1 + \alpha}{\left(\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)\right) \cdot \left(\alpha + 3\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{1}{\beta}}{\frac{\beta}{1 + \alpha}}\\ \end{array} \]
  5. Add Preprocessing

Alternative 10: 97.2% accurate, 1.9× speedup?

\[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 3.5:\\ \;\;\;\;0.08333333333333333 + \alpha \cdot \left(\alpha \cdot \left(\alpha \cdot 0.024691358024691357 + -0.011574074074074073\right) + -0.027777777777777776\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{1}{\beta}}{\frac{\beta}{1 + \alpha}}\\ \end{array} \end{array} \]
NOTE: alpha and beta should be sorted in increasing order before calling this function.
(FPCore (alpha beta)
 :precision binary64
 (if (<= beta 3.5)
   (+
    0.08333333333333333
    (*
     alpha
     (+
      (* alpha (+ (* alpha 0.024691358024691357) -0.011574074074074073))
      -0.027777777777777776)))
   (/ (/ 1.0 beta) (/ beta (+ 1.0 alpha)))))
assert(alpha < beta);
double code(double alpha, double beta) {
	double tmp;
	if (beta <= 3.5) {
		tmp = 0.08333333333333333 + (alpha * ((alpha * ((alpha * 0.024691358024691357) + -0.011574074074074073)) + -0.027777777777777776));
	} else {
		tmp = (1.0 / beta) / (beta / (1.0 + alpha));
	}
	return tmp;
}
NOTE: alpha and beta should be sorted in increasing order before calling this function.
real(8) function code(alpha, beta)
    real(8), intent (in) :: alpha
    real(8), intent (in) :: beta
    real(8) :: tmp
    if (beta <= 3.5d0) then
        tmp = 0.08333333333333333d0 + (alpha * ((alpha * ((alpha * 0.024691358024691357d0) + (-0.011574074074074073d0))) + (-0.027777777777777776d0)))
    else
        tmp = (1.0d0 / beta) / (beta / (1.0d0 + alpha))
    end if
    code = tmp
end function
assert alpha < beta;
public static double code(double alpha, double beta) {
	double tmp;
	if (beta <= 3.5) {
		tmp = 0.08333333333333333 + (alpha * ((alpha * ((alpha * 0.024691358024691357) + -0.011574074074074073)) + -0.027777777777777776));
	} else {
		tmp = (1.0 / beta) / (beta / (1.0 + alpha));
	}
	return tmp;
}
[alpha, beta] = sort([alpha, beta])
def code(alpha, beta):
	tmp = 0
	if beta <= 3.5:
		tmp = 0.08333333333333333 + (alpha * ((alpha * ((alpha * 0.024691358024691357) + -0.011574074074074073)) + -0.027777777777777776))
	else:
		tmp = (1.0 / beta) / (beta / (1.0 + alpha))
	return tmp
alpha, beta = sort([alpha, beta])
function code(alpha, beta)
	tmp = 0.0
	if (beta <= 3.5)
		tmp = Float64(0.08333333333333333 + Float64(alpha * Float64(Float64(alpha * Float64(Float64(alpha * 0.024691358024691357) + -0.011574074074074073)) + -0.027777777777777776)));
	else
		tmp = Float64(Float64(1.0 / beta) / Float64(beta / Float64(1.0 + alpha)));
	end
	return tmp
end
alpha, beta = num2cell(sort([alpha, beta])){:}
function tmp_2 = code(alpha, beta)
	tmp = 0.0;
	if (beta <= 3.5)
		tmp = 0.08333333333333333 + (alpha * ((alpha * ((alpha * 0.024691358024691357) + -0.011574074074074073)) + -0.027777777777777776));
	else
		tmp = (1.0 / beta) / (beta / (1.0 + alpha));
	end
	tmp_2 = tmp;
end
NOTE: alpha and beta should be sorted in increasing order before calling this function.
code[alpha_, beta_] := If[LessEqual[beta, 3.5], N[(0.08333333333333333 + N[(alpha * N[(N[(alpha * N[(N[(alpha * 0.024691358024691357), $MachinePrecision] + -0.011574074074074073), $MachinePrecision]), $MachinePrecision] + -0.027777777777777776), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(1.0 / beta), $MachinePrecision] / N[(beta / N[(1.0 + alpha), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
[alpha, beta] = \mathsf{sort}([alpha, beta])\\
\\
\begin{array}{l}
\mathbf{if}\;\beta \leq 3.5:\\
\;\;\;\;0.08333333333333333 + \alpha \cdot \left(\alpha \cdot \left(\alpha \cdot 0.024691358024691357 + -0.011574074074074073\right) + -0.027777777777777776\right)\\

\mathbf{else}:\\
\;\;\;\;\frac{\frac{1}{\beta}}{\frac{\beta}{1 + \alpha}}\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if beta < 3.5

    1. Initial program 99.9%

      \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
    2. Step-by-step derivation
      1. associate-/l/N/A

        \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
      2. associate-/l/N/A

        \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
      3. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
      4. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      5. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      6. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      7. associate-+r+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      8. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      9. *-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      10. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      11. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      12. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      13. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      14. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      15. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    3. Simplified93.6%

      \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
    4. Add Preprocessing
    5. Applied egg-rr99.8%

      \[\leadsto \color{blue}{\frac{1 + \beta}{\alpha + \left(\beta + 3\right)} \cdot {\left(\frac{\alpha + \left(\beta + 2\right)}{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}\right)}^{-1}} \]
    6. Taylor expanded in beta around 0

      \[\leadsto \color{blue}{\frac{1 + \alpha}{{\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)}} \]
    7. Step-by-step derivation
      1. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(1 + \alpha\right), \color{blue}{\left({\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)\right)}\right) \]
      2. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\color{blue}{{\left(2 + \alpha\right)}^{2}} \cdot \left(3 + \alpha\right)\right)\right) \]
      3. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left({\left(2 + \alpha\right)}^{2}\right), \color{blue}{\left(3 + \alpha\right)}\right)\right) \]
      4. unpow2N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left(\left(2 + \alpha\right) \cdot \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
      5. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(2 + \alpha\right), \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
      6. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 2\right), \left(2 + \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
      7. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \left(2 + \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
      8. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \left(\alpha + 2\right)\right), \left(3 + \alpha\right)\right)\right) \]
      9. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \left(3 + \alpha\right)\right)\right) \]
      10. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \left(\alpha + \color{blue}{3}\right)\right)\right) \]
      11. +-lowering-+.f6492.2%

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \mathsf{+.f64}\left(\alpha, \color{blue}{3}\right)\right)\right) \]
    8. Simplified92.2%

      \[\leadsto \color{blue}{\frac{1 + \alpha}{\left(\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)\right) \cdot \left(\alpha + 3\right)}} \]
    9. Taylor expanded in alpha around 0

      \[\leadsto \color{blue}{\frac{1}{12} + \alpha \cdot \left(\alpha \cdot \left(\frac{2}{81} \cdot \alpha - \frac{5}{432}\right) - \frac{1}{36}\right)} \]
    10. Step-by-step derivation
      1. +-lowering-+.f64N/A

        \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \color{blue}{\left(\alpha \cdot \left(\alpha \cdot \left(\frac{2}{81} \cdot \alpha - \frac{5}{432}\right) - \frac{1}{36}\right)\right)}\right) \]
      2. *-lowering-*.f64N/A

        \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \color{blue}{\left(\alpha \cdot \left(\frac{2}{81} \cdot \alpha - \frac{5}{432}\right) - \frac{1}{36}\right)}\right)\right) \]
      3. sub-negN/A

        \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \left(\alpha \cdot \left(\frac{2}{81} \cdot \alpha - \frac{5}{432}\right) + \color{blue}{\left(\mathsf{neg}\left(\frac{1}{36}\right)\right)}\right)\right)\right) \]
      4. metadata-evalN/A

        \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \left(\alpha \cdot \left(\frac{2}{81} \cdot \alpha - \frac{5}{432}\right) + \frac{-1}{36}\right)\right)\right) \]
      5. +-lowering-+.f64N/A

        \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \mathsf{+.f64}\left(\left(\alpha \cdot \left(\frac{2}{81} \cdot \alpha - \frac{5}{432}\right)\right), \color{blue}{\frac{-1}{36}}\right)\right)\right) \]
      6. *-lowering-*.f64N/A

        \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \mathsf{+.f64}\left(\mathsf{*.f64}\left(\alpha, \left(\frac{2}{81} \cdot \alpha - \frac{5}{432}\right)\right), \frac{-1}{36}\right)\right)\right) \]
      7. sub-negN/A

        \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \mathsf{+.f64}\left(\mathsf{*.f64}\left(\alpha, \left(\frac{2}{81} \cdot \alpha + \left(\mathsf{neg}\left(\frac{5}{432}\right)\right)\right)\right), \frac{-1}{36}\right)\right)\right) \]
      8. metadata-evalN/A

        \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \mathsf{+.f64}\left(\mathsf{*.f64}\left(\alpha, \left(\frac{2}{81} \cdot \alpha + \frac{-5}{432}\right)\right), \frac{-1}{36}\right)\right)\right) \]
      9. +-lowering-+.f64N/A

        \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \mathsf{+.f64}\left(\mathsf{*.f64}\left(\alpha, \mathsf{+.f64}\left(\left(\frac{2}{81} \cdot \alpha\right), \frac{-5}{432}\right)\right), \frac{-1}{36}\right)\right)\right) \]
      10. *-commutativeN/A

        \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \mathsf{+.f64}\left(\mathsf{*.f64}\left(\alpha, \mathsf{+.f64}\left(\left(\alpha \cdot \frac{2}{81}\right), \frac{-5}{432}\right)\right), \frac{-1}{36}\right)\right)\right) \]
      11. *-lowering-*.f6461.5%

        \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \mathsf{+.f64}\left(\mathsf{*.f64}\left(\alpha, \mathsf{+.f64}\left(\mathsf{*.f64}\left(\alpha, \frac{2}{81}\right), \frac{-5}{432}\right)\right), \frac{-1}{36}\right)\right)\right) \]
    11. Simplified61.5%

      \[\leadsto \color{blue}{0.08333333333333333 + \alpha \cdot \left(\alpha \cdot \left(\alpha \cdot 0.024691358024691357 + -0.011574074074074073\right) + -0.027777777777777776\right)} \]

    if 3.5 < beta

    1. Initial program 87.4%

      \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
    2. Step-by-step derivation
      1. associate-/l/N/A

        \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
      2. associate-/l/N/A

        \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
      3. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
      4. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      5. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      6. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      7. associate-+r+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      8. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      9. *-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      10. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      11. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      12. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      13. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      14. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      15. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    3. Simplified70.3%

      \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
    4. Add Preprocessing
    5. Taylor expanded in beta around inf

      \[\leadsto \color{blue}{\frac{1 + \alpha}{{\beta}^{2}}} \]
    6. Step-by-step derivation
      1. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(1 + \alpha\right), \color{blue}{\left({\beta}^{2}\right)}\right) \]
      2. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left({\color{blue}{\beta}}^{2}\right)\right) \]
      3. unpow2N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\beta \cdot \color{blue}{\beta}\right)\right) \]
      4. *-lowering-*.f6477.5%

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\beta, \color{blue}{\beta}\right)\right) \]
    7. Simplified77.5%

      \[\leadsto \color{blue}{\frac{1 + \alpha}{\beta \cdot \beta}} \]
    8. Step-by-step derivation
      1. clear-numN/A

        \[\leadsto \frac{1}{\color{blue}{\frac{\beta \cdot \beta}{1 + \alpha}}} \]
      2. associate-/l*N/A

        \[\leadsto \frac{1}{\beta \cdot \color{blue}{\frac{\beta}{1 + \alpha}}} \]
      3. associate-/r*N/A

        \[\leadsto \frac{\frac{1}{\beta}}{\color{blue}{\frac{\beta}{1 + \alpha}}} \]
      4. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\frac{1}{\beta}\right), \color{blue}{\left(\frac{\beta}{1 + \alpha}\right)}\right) \]
      5. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(1, \beta\right), \left(\frac{\color{blue}{\beta}}{1 + \alpha}\right)\right) \]
      6. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(1, \beta\right), \mathsf{/.f64}\left(\beta, \color{blue}{\left(1 + \alpha\right)}\right)\right) \]
      7. +-lowering-+.f6482.8%

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(1, \beta\right), \mathsf{/.f64}\left(\beta, \mathsf{+.f64}\left(1, \color{blue}{\alpha}\right)\right)\right) \]
    9. Applied egg-rr82.8%

      \[\leadsto \color{blue}{\frac{\frac{1}{\beta}}{\frac{\beta}{1 + \alpha}}} \]
  3. Recombined 2 regimes into one program.
  4. Add Preprocessing

Alternative 11: 96.6% accurate, 2.1× speedup?

\[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 3.4:\\ \;\;\;\;0.08333333333333333 + \alpha \cdot -0.027777777777777776\\ \mathbf{elif}\;\beta \leq 1.35 \cdot 10^{+154}:\\ \;\;\;\;\frac{1 + \alpha}{\beta \cdot \beta}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{\alpha}{\beta}}{\beta}\\ \end{array} \end{array} \]
NOTE: alpha and beta should be sorted in increasing order before calling this function.
(FPCore (alpha beta)
 :precision binary64
 (if (<= beta 3.4)
   (+ 0.08333333333333333 (* alpha -0.027777777777777776))
   (if (<= beta 1.35e+154)
     (/ (+ 1.0 alpha) (* beta beta))
     (/ (/ alpha beta) beta))))
assert(alpha < beta);
double code(double alpha, double beta) {
	double tmp;
	if (beta <= 3.4) {
		tmp = 0.08333333333333333 + (alpha * -0.027777777777777776);
	} else if (beta <= 1.35e+154) {
		tmp = (1.0 + alpha) / (beta * beta);
	} else {
		tmp = (alpha / beta) / beta;
	}
	return tmp;
}
NOTE: alpha and beta should be sorted in increasing order before calling this function.
real(8) function code(alpha, beta)
    real(8), intent (in) :: alpha
    real(8), intent (in) :: beta
    real(8) :: tmp
    if (beta <= 3.4d0) then
        tmp = 0.08333333333333333d0 + (alpha * (-0.027777777777777776d0))
    else if (beta <= 1.35d+154) then
        tmp = (1.0d0 + alpha) / (beta * beta)
    else
        tmp = (alpha / beta) / beta
    end if
    code = tmp
end function
assert alpha < beta;
public static double code(double alpha, double beta) {
	double tmp;
	if (beta <= 3.4) {
		tmp = 0.08333333333333333 + (alpha * -0.027777777777777776);
	} else if (beta <= 1.35e+154) {
		tmp = (1.0 + alpha) / (beta * beta);
	} else {
		tmp = (alpha / beta) / beta;
	}
	return tmp;
}
[alpha, beta] = sort([alpha, beta])
def code(alpha, beta):
	tmp = 0
	if beta <= 3.4:
		tmp = 0.08333333333333333 + (alpha * -0.027777777777777776)
	elif beta <= 1.35e+154:
		tmp = (1.0 + alpha) / (beta * beta)
	else:
		tmp = (alpha / beta) / beta
	return tmp
alpha, beta = sort([alpha, beta])
function code(alpha, beta)
	tmp = 0.0
	if (beta <= 3.4)
		tmp = Float64(0.08333333333333333 + Float64(alpha * -0.027777777777777776));
	elseif (beta <= 1.35e+154)
		tmp = Float64(Float64(1.0 + alpha) / Float64(beta * beta));
	else
		tmp = Float64(Float64(alpha / beta) / beta);
	end
	return tmp
end
alpha, beta = num2cell(sort([alpha, beta])){:}
function tmp_2 = code(alpha, beta)
	tmp = 0.0;
	if (beta <= 3.4)
		tmp = 0.08333333333333333 + (alpha * -0.027777777777777776);
	elseif (beta <= 1.35e+154)
		tmp = (1.0 + alpha) / (beta * beta);
	else
		tmp = (alpha / beta) / beta;
	end
	tmp_2 = tmp;
end
NOTE: alpha and beta should be sorted in increasing order before calling this function.
code[alpha_, beta_] := If[LessEqual[beta, 3.4], N[(0.08333333333333333 + N[(alpha * -0.027777777777777776), $MachinePrecision]), $MachinePrecision], If[LessEqual[beta, 1.35e+154], N[(N[(1.0 + alpha), $MachinePrecision] / N[(beta * beta), $MachinePrecision]), $MachinePrecision], N[(N[(alpha / beta), $MachinePrecision] / beta), $MachinePrecision]]]
\begin{array}{l}
[alpha, beta] = \mathsf{sort}([alpha, beta])\\
\\
\begin{array}{l}
\mathbf{if}\;\beta \leq 3.4:\\
\;\;\;\;0.08333333333333333 + \alpha \cdot -0.027777777777777776\\

\mathbf{elif}\;\beta \leq 1.35 \cdot 10^{+154}:\\
\;\;\;\;\frac{1 + \alpha}{\beta \cdot \beta}\\

\mathbf{else}:\\
\;\;\;\;\frac{\frac{\alpha}{\beta}}{\beta}\\


\end{array}
\end{array}
Derivation
  1. Split input into 3 regimes
  2. if beta < 3.39999999999999991

    1. Initial program 99.9%

      \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
    2. Step-by-step derivation
      1. associate-/l/N/A

        \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
      2. associate-/l/N/A

        \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
      3. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
      4. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      5. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      6. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      7. associate-+r+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      8. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      9. *-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      10. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      11. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      12. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      13. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      14. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      15. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    3. Simplified93.6%

      \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
    4. Add Preprocessing
    5. Applied egg-rr99.8%

      \[\leadsto \color{blue}{\frac{1 + \beta}{\alpha + \left(\beta + 3\right)} \cdot {\left(\frac{\alpha + \left(\beta + 2\right)}{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}\right)}^{-1}} \]
    6. Taylor expanded in beta around 0

      \[\leadsto \color{blue}{\frac{1 + \alpha}{{\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)}} \]
    7. Step-by-step derivation
      1. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(1 + \alpha\right), \color{blue}{\left({\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)\right)}\right) \]
      2. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\color{blue}{{\left(2 + \alpha\right)}^{2}} \cdot \left(3 + \alpha\right)\right)\right) \]
      3. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left({\left(2 + \alpha\right)}^{2}\right), \color{blue}{\left(3 + \alpha\right)}\right)\right) \]
      4. unpow2N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left(\left(2 + \alpha\right) \cdot \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
      5. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(2 + \alpha\right), \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
      6. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 2\right), \left(2 + \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
      7. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \left(2 + \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
      8. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \left(\alpha + 2\right)\right), \left(3 + \alpha\right)\right)\right) \]
      9. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \left(3 + \alpha\right)\right)\right) \]
      10. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \left(\alpha + \color{blue}{3}\right)\right)\right) \]
      11. +-lowering-+.f6492.2%

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \mathsf{+.f64}\left(\alpha, \color{blue}{3}\right)\right)\right) \]
    8. Simplified92.2%

      \[\leadsto \color{blue}{\frac{1 + \alpha}{\left(\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)\right) \cdot \left(\alpha + 3\right)}} \]
    9. Taylor expanded in alpha around 0

      \[\leadsto \color{blue}{\frac{1}{12} + \frac{-1}{36} \cdot \alpha} \]
    10. Step-by-step derivation
      1. +-lowering-+.f64N/A

        \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \color{blue}{\left(\frac{-1}{36} \cdot \alpha\right)}\right) \]
      2. *-commutativeN/A

        \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \left(\alpha \cdot \color{blue}{\frac{-1}{36}}\right)\right) \]
      3. *-lowering-*.f6461.1%

        \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \color{blue}{\frac{-1}{36}}\right)\right) \]
    11. Simplified61.1%

      \[\leadsto \color{blue}{0.08333333333333333 + \alpha \cdot -0.027777777777777776} \]

    if 3.39999999999999991 < beta < 1.35000000000000003e154

    1. Initial program 91.8%

      \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
    2. Step-by-step derivation
      1. associate-/l/N/A

        \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
      2. associate-/l/N/A

        \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
      3. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
      4. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      5. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      6. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      7. associate-+r+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      8. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      9. *-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      10. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      11. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      12. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      13. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      14. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      15. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    3. Simplified65.9%

      \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
    4. Add Preprocessing
    5. Taylor expanded in beta around inf

      \[\leadsto \color{blue}{\frac{1 + \alpha}{{\beta}^{2}}} \]
    6. Step-by-step derivation
      1. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(1 + \alpha\right), \color{blue}{\left({\beta}^{2}\right)}\right) \]
      2. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left({\color{blue}{\beta}}^{2}\right)\right) \]
      3. unpow2N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\beta \cdot \color{blue}{\beta}\right)\right) \]
      4. *-lowering-*.f6467.3%

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\beta, \color{blue}{\beta}\right)\right) \]
    7. Simplified67.3%

      \[\leadsto \color{blue}{\frac{1 + \alpha}{\beta \cdot \beta}} \]

    if 1.35000000000000003e154 < beta

    1. Initial program 82.5%

      \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
    2. Step-by-step derivation
      1. associate-/l/N/A

        \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
      2. associate-/l/N/A

        \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
      3. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
      4. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      5. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      6. associate-+l+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      7. associate-+r+N/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      8. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      9. *-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      10. distribute-lft1-inN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      11. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      12. *-lowering-*.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      13. +-commutativeN/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      14. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      15. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
    3. Simplified75.2%

      \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
    4. Add Preprocessing
    5. Taylor expanded in beta around inf

      \[\leadsto \color{blue}{\frac{1 + \alpha}{{\beta}^{2}}} \]
    6. Step-by-step derivation
      1. /-lowering-/.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\left(1 + \alpha\right), \color{blue}{\left({\beta}^{2}\right)}\right) \]
      2. +-lowering-+.f64N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left({\color{blue}{\beta}}^{2}\right)\right) \]
      3. unpow2N/A

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\beta \cdot \color{blue}{\beta}\right)\right) \]
      4. *-lowering-*.f6488.8%

        \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\beta, \color{blue}{\beta}\right)\right) \]
    7. Simplified88.8%

      \[\leadsto \color{blue}{\frac{1 + \alpha}{\beta \cdot \beta}} \]
    8. Step-by-step derivation
      1. clear-numN/A

        \[\leadsto \frac{1}{\color{blue}{\frac{\beta \cdot \beta}{1 + \alpha}}} \]
      2. associate-/r/N/A

        \[\leadsto \frac{1}{\beta \cdot \beta} \cdot \color{blue}{\left(1 + \alpha\right)} \]
      3. *-lowering-*.f64N/A

        \[\leadsto \mathsf{*.f64}\left(\left(\frac{1}{\beta \cdot \beta}\right), \color{blue}{\left(1 + \alpha\right)}\right) \]
      4. /-lowering-/.f64N/A

        \[\leadsto \mathsf{*.f64}\left(\mathsf{/.f64}\left(1, \left(\beta \cdot \beta\right)\right), \left(\color{blue}{1} + \alpha\right)\right) \]
      5. *-lowering-*.f64N/A

        \[\leadsto \mathsf{*.f64}\left(\mathsf{/.f64}\left(1, \mathsf{*.f64}\left(\beta, \beta\right)\right), \left(1 + \alpha\right)\right) \]
      6. +-lowering-+.f6488.8%

        \[\leadsto \mathsf{*.f64}\left(\mathsf{/.f64}\left(1, \mathsf{*.f64}\left(\beta, \beta\right)\right), \mathsf{+.f64}\left(1, \color{blue}{\alpha}\right)\right) \]
    9. Applied egg-rr88.8%

      \[\leadsto \color{blue}{\frac{1}{\beta \cdot \beta} \cdot \left(1 + \alpha\right)} \]
    10. Taylor expanded in alpha around inf

      \[\leadsto \mathsf{*.f64}\left(\mathsf{/.f64}\left(1, \mathsf{*.f64}\left(\beta, \beta\right)\right), \color{blue}{\alpha}\right) \]
    11. Step-by-step derivation
      1. Simplified88.8%

        \[\leadsto \frac{1}{\beta \cdot \beta} \cdot \color{blue}{\alpha} \]
      2. Step-by-step derivation
        1. *-commutativeN/A

          \[\leadsto \alpha \cdot \color{blue}{\frac{1}{\beta \cdot \beta}} \]
        2. un-div-invN/A

          \[\leadsto \frac{\alpha}{\color{blue}{\beta \cdot \beta}} \]
        3. associate-/r*N/A

          \[\leadsto \frac{\frac{\alpha}{\beta}}{\color{blue}{\beta}} \]
        4. /-lowering-/.f64N/A

          \[\leadsto \mathsf{/.f64}\left(\left(\frac{\alpha}{\beta}\right), \color{blue}{\beta}\right) \]
        5. /-lowering-/.f6498.8%

          \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\alpha, \beta\right), \beta\right) \]
      3. Applied egg-rr98.8%

        \[\leadsto \color{blue}{\frac{\frac{\alpha}{\beta}}{\beta}} \]
    12. Recombined 3 regimes into one program.
    13. Add Preprocessing

    Alternative 12: 93.7% accurate, 2.1× speedup?

    \[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 2.4:\\ \;\;\;\;0.08333333333333333 + \alpha \cdot -0.027777777777777776\\ \mathbf{elif}\;\beta \leq 1.35 \cdot 10^{+154}:\\ \;\;\;\;\frac{1}{\beta \cdot \left(\beta + 2\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{\alpha}{\beta}}{\beta}\\ \end{array} \end{array} \]
    NOTE: alpha and beta should be sorted in increasing order before calling this function.
    (FPCore (alpha beta)
     :precision binary64
     (if (<= beta 2.4)
       (+ 0.08333333333333333 (* alpha -0.027777777777777776))
       (if (<= beta 1.35e+154)
         (/ 1.0 (* beta (+ beta 2.0)))
         (/ (/ alpha beta) beta))))
    assert(alpha < beta);
    double code(double alpha, double beta) {
    	double tmp;
    	if (beta <= 2.4) {
    		tmp = 0.08333333333333333 + (alpha * -0.027777777777777776);
    	} else if (beta <= 1.35e+154) {
    		tmp = 1.0 / (beta * (beta + 2.0));
    	} else {
    		tmp = (alpha / beta) / beta;
    	}
    	return tmp;
    }
    
    NOTE: alpha and beta should be sorted in increasing order before calling this function.
    real(8) function code(alpha, beta)
        real(8), intent (in) :: alpha
        real(8), intent (in) :: beta
        real(8) :: tmp
        if (beta <= 2.4d0) then
            tmp = 0.08333333333333333d0 + (alpha * (-0.027777777777777776d0))
        else if (beta <= 1.35d+154) then
            tmp = 1.0d0 / (beta * (beta + 2.0d0))
        else
            tmp = (alpha / beta) / beta
        end if
        code = tmp
    end function
    
    assert alpha < beta;
    public static double code(double alpha, double beta) {
    	double tmp;
    	if (beta <= 2.4) {
    		tmp = 0.08333333333333333 + (alpha * -0.027777777777777776);
    	} else if (beta <= 1.35e+154) {
    		tmp = 1.0 / (beta * (beta + 2.0));
    	} else {
    		tmp = (alpha / beta) / beta;
    	}
    	return tmp;
    }
    
    [alpha, beta] = sort([alpha, beta])
    def code(alpha, beta):
    	tmp = 0
    	if beta <= 2.4:
    		tmp = 0.08333333333333333 + (alpha * -0.027777777777777776)
    	elif beta <= 1.35e+154:
    		tmp = 1.0 / (beta * (beta + 2.0))
    	else:
    		tmp = (alpha / beta) / beta
    	return tmp
    
    alpha, beta = sort([alpha, beta])
    function code(alpha, beta)
    	tmp = 0.0
    	if (beta <= 2.4)
    		tmp = Float64(0.08333333333333333 + Float64(alpha * -0.027777777777777776));
    	elseif (beta <= 1.35e+154)
    		tmp = Float64(1.0 / Float64(beta * Float64(beta + 2.0)));
    	else
    		tmp = Float64(Float64(alpha / beta) / beta);
    	end
    	return tmp
    end
    
    alpha, beta = num2cell(sort([alpha, beta])){:}
    function tmp_2 = code(alpha, beta)
    	tmp = 0.0;
    	if (beta <= 2.4)
    		tmp = 0.08333333333333333 + (alpha * -0.027777777777777776);
    	elseif (beta <= 1.35e+154)
    		tmp = 1.0 / (beta * (beta + 2.0));
    	else
    		tmp = (alpha / beta) / beta;
    	end
    	tmp_2 = tmp;
    end
    
    NOTE: alpha and beta should be sorted in increasing order before calling this function.
    code[alpha_, beta_] := If[LessEqual[beta, 2.4], N[(0.08333333333333333 + N[(alpha * -0.027777777777777776), $MachinePrecision]), $MachinePrecision], If[LessEqual[beta, 1.35e+154], N[(1.0 / N[(beta * N[(beta + 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(alpha / beta), $MachinePrecision] / beta), $MachinePrecision]]]
    
    \begin{array}{l}
    [alpha, beta] = \mathsf{sort}([alpha, beta])\\
    \\
    \begin{array}{l}
    \mathbf{if}\;\beta \leq 2.4:\\
    \;\;\;\;0.08333333333333333 + \alpha \cdot -0.027777777777777776\\
    
    \mathbf{elif}\;\beta \leq 1.35 \cdot 10^{+154}:\\
    \;\;\;\;\frac{1}{\beta \cdot \left(\beta + 2\right)}\\
    
    \mathbf{else}:\\
    \;\;\;\;\frac{\frac{\alpha}{\beta}}{\beta}\\
    
    
    \end{array}
    \end{array}
    
    Derivation
    1. Split input into 3 regimes
    2. if beta < 2.39999999999999991

      1. Initial program 99.9%

        \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
      2. Step-by-step derivation
        1. associate-/l/N/A

          \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
        2. associate-/l/N/A

          \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
        3. /-lowering-/.f64N/A

          \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
        4. +-commutativeN/A

          \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
        5. associate-+l+N/A

          \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
        6. associate-+l+N/A

          \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
        7. associate-+r+N/A

          \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
        8. distribute-lft1-inN/A

          \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
        9. *-commutativeN/A

          \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
        10. distribute-lft1-inN/A

          \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
        11. +-commutativeN/A

          \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
        12. *-lowering-*.f64N/A

          \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
        13. +-commutativeN/A

          \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
        14. +-lowering-+.f64N/A

          \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
        15. +-lowering-+.f64N/A

          \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      3. Simplified93.6%

        \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
      4. Add Preprocessing
      5. Applied egg-rr99.8%

        \[\leadsto \color{blue}{\frac{1 + \beta}{\alpha + \left(\beta + 3\right)} \cdot {\left(\frac{\alpha + \left(\beta + 2\right)}{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}\right)}^{-1}} \]
      6. Taylor expanded in beta around 0

        \[\leadsto \color{blue}{\frac{1 + \alpha}{{\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)}} \]
      7. Step-by-step derivation
        1. /-lowering-/.f64N/A

          \[\leadsto \mathsf{/.f64}\left(\left(1 + \alpha\right), \color{blue}{\left({\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)\right)}\right) \]
        2. +-lowering-+.f64N/A

          \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\color{blue}{{\left(2 + \alpha\right)}^{2}} \cdot \left(3 + \alpha\right)\right)\right) \]
        3. *-lowering-*.f64N/A

          \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left({\left(2 + \alpha\right)}^{2}\right), \color{blue}{\left(3 + \alpha\right)}\right)\right) \]
        4. unpow2N/A

          \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left(\left(2 + \alpha\right) \cdot \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
        5. *-lowering-*.f64N/A

          \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(2 + \alpha\right), \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
        6. +-commutativeN/A

          \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 2\right), \left(2 + \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
        7. +-lowering-+.f64N/A

          \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \left(2 + \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
        8. +-commutativeN/A

          \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \left(\alpha + 2\right)\right), \left(3 + \alpha\right)\right)\right) \]
        9. +-lowering-+.f64N/A

          \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \left(3 + \alpha\right)\right)\right) \]
        10. +-commutativeN/A

          \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \left(\alpha + \color{blue}{3}\right)\right)\right) \]
        11. +-lowering-+.f6492.2%

          \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \mathsf{+.f64}\left(\alpha, \color{blue}{3}\right)\right)\right) \]
      8. Simplified92.2%

        \[\leadsto \color{blue}{\frac{1 + \alpha}{\left(\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)\right) \cdot \left(\alpha + 3\right)}} \]
      9. Taylor expanded in alpha around 0

        \[\leadsto \color{blue}{\frac{1}{12} + \frac{-1}{36} \cdot \alpha} \]
      10. Step-by-step derivation
        1. +-lowering-+.f64N/A

          \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \color{blue}{\left(\frac{-1}{36} \cdot \alpha\right)}\right) \]
        2. *-commutativeN/A

          \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \left(\alpha \cdot \color{blue}{\frac{-1}{36}}\right)\right) \]
        3. *-lowering-*.f6461.1%

          \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \color{blue}{\frac{-1}{36}}\right)\right) \]
      11. Simplified61.1%

        \[\leadsto \color{blue}{0.08333333333333333 + \alpha \cdot -0.027777777777777776} \]

      if 2.39999999999999991 < beta < 1.35000000000000003e154

      1. Initial program 91.8%

        \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
      2. Step-by-step derivation
        1. associate-/l/N/A

          \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
        2. associate-/l/N/A

          \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
        3. /-lowering-/.f64N/A

          \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
        4. +-commutativeN/A

          \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
        5. associate-+l+N/A

          \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
        6. associate-+l+N/A

          \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
        7. associate-+r+N/A

          \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
        8. distribute-lft1-inN/A

          \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
        9. *-commutativeN/A

          \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
        10. distribute-lft1-inN/A

          \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
        11. +-commutativeN/A

          \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
        12. *-lowering-*.f64N/A

          \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
        13. +-commutativeN/A

          \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
        14. +-lowering-+.f64N/A

          \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
        15. +-lowering-+.f64N/A

          \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
      3. Simplified65.9%

        \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
      4. Add Preprocessing
      5. Step-by-step derivation
        1. times-fracN/A

          \[\leadsto \frac{\alpha + 1}{\left(\alpha + \beta\right) + 2} \cdot \color{blue}{\frac{\beta + 1}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)}} \]
        2. clear-numN/A

          \[\leadsto \frac{\alpha + 1}{\left(\alpha + \beta\right) + 2} \cdot \frac{1}{\color{blue}{\frac{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)}{\beta + 1}}} \]
        3. un-div-invN/A

          \[\leadsto \frac{\frac{\alpha + 1}{\left(\alpha + \beta\right) + 2}}{\color{blue}{\frac{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)}{\beta + 1}}} \]
        4. /-lowering-/.f64N/A

          \[\leadsto \mathsf{/.f64}\left(\left(\frac{\alpha + 1}{\left(\alpha + \beta\right) + 2}\right), \color{blue}{\left(\frac{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)}{\beta + 1}\right)}\right) \]
        5. /-lowering-/.f64N/A

          \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\left(\alpha + 1\right), \left(\left(\alpha + \beta\right) + 2\right)\right), \left(\frac{\color{blue}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)}}{\beta + 1}\right)\right) \]
        6. +-lowering-+.f64N/A

          \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\left(\alpha + \beta\right) + 2\right)\right), \left(\frac{\color{blue}{\left(\left(\alpha + \beta\right) + 2\right)} \cdot \left(\left(\alpha + \beta\right) + 3\right)}{\beta + 1}\right)\right) \]
        7. associate-+l+N/A

          \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\alpha + \left(\beta + 2\right)\right)\right), \left(\frac{\left(\left(\alpha + \beta\right) + 2\right) \cdot \color{blue}{\left(\left(\alpha + \beta\right) + 3\right)}}{\beta + 1}\right)\right) \]
        8. +-lowering-+.f64N/A

          \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\alpha, \left(\beta + 2\right)\right)\right), \left(\frac{\left(\left(\alpha + \beta\right) + 2\right) \cdot \color{blue}{\left(\left(\alpha + \beta\right) + 3\right)}}{\beta + 1}\right)\right) \]
        9. +-lowering-+.f64N/A

          \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\alpha, \mathsf{+.f64}\left(\beta, 2\right)\right)\right), \left(\frac{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + \color{blue}{3}\right)}{\beta + 1}\right)\right) \]
        10. /-lowering-/.f64N/A

          \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\alpha, \mathsf{+.f64}\left(\beta, 2\right)\right)\right), \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right), \color{blue}{\left(\beta + 1\right)}\right)\right) \]
      6. Applied egg-rr94.1%

        \[\leadsto \color{blue}{\frac{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}{\frac{\left(\alpha + \left(\beta + 2\right)\right) \cdot \left(\alpha + \left(\beta + 3\right)\right)}{1 + \beta}}} \]
      7. Taylor expanded in beta around inf

        \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\alpha, \mathsf{+.f64}\left(\beta, 2\right)\right)\right), \color{blue}{\beta}\right) \]
      8. Step-by-step derivation
        1. Simplified67.7%

          \[\leadsto \frac{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}{\color{blue}{\beta}} \]
        2. Taylor expanded in alpha around 0

          \[\leadsto \color{blue}{\frac{1}{\beta \cdot \left(2 + \beta\right)}} \]
        3. Step-by-step derivation
          1. /-lowering-/.f64N/A

            \[\leadsto \mathsf{/.f64}\left(1, \color{blue}{\left(\beta \cdot \left(2 + \beta\right)\right)}\right) \]
          2. *-lowering-*.f64N/A

            \[\leadsto \mathsf{/.f64}\left(1, \mathsf{*.f64}\left(\beta, \color{blue}{\left(2 + \beta\right)}\right)\right) \]
          3. +-commutativeN/A

            \[\leadsto \mathsf{/.f64}\left(1, \mathsf{*.f64}\left(\beta, \left(\beta + \color{blue}{2}\right)\right)\right) \]
          4. +-lowering-+.f6456.8%

            \[\leadsto \mathsf{/.f64}\left(1, \mathsf{*.f64}\left(\beta, \mathsf{+.f64}\left(\beta, \color{blue}{2}\right)\right)\right) \]
        4. Simplified56.8%

          \[\leadsto \color{blue}{\frac{1}{\beta \cdot \left(\beta + 2\right)}} \]

        if 1.35000000000000003e154 < beta

        1. Initial program 82.5%

          \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
        2. Step-by-step derivation
          1. associate-/l/N/A

            \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
          2. associate-/l/N/A

            \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
          3. /-lowering-/.f64N/A

            \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
          4. +-commutativeN/A

            \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
          5. associate-+l+N/A

            \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
          6. associate-+l+N/A

            \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
          7. associate-+r+N/A

            \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
          8. distribute-lft1-inN/A

            \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
          9. *-commutativeN/A

            \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
          10. distribute-lft1-inN/A

            \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
          11. +-commutativeN/A

            \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
          12. *-lowering-*.f64N/A

            \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
          13. +-commutativeN/A

            \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
          14. +-lowering-+.f64N/A

            \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
          15. +-lowering-+.f64N/A

            \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
        3. Simplified75.2%

          \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
        4. Add Preprocessing
        5. Taylor expanded in beta around inf

          \[\leadsto \color{blue}{\frac{1 + \alpha}{{\beta}^{2}}} \]
        6. Step-by-step derivation
          1. /-lowering-/.f64N/A

            \[\leadsto \mathsf{/.f64}\left(\left(1 + \alpha\right), \color{blue}{\left({\beta}^{2}\right)}\right) \]
          2. +-lowering-+.f64N/A

            \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left({\color{blue}{\beta}}^{2}\right)\right) \]
          3. unpow2N/A

            \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\beta \cdot \color{blue}{\beta}\right)\right) \]
          4. *-lowering-*.f6488.8%

            \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\beta, \color{blue}{\beta}\right)\right) \]
        7. Simplified88.8%

          \[\leadsto \color{blue}{\frac{1 + \alpha}{\beta \cdot \beta}} \]
        8. Step-by-step derivation
          1. clear-numN/A

            \[\leadsto \frac{1}{\color{blue}{\frac{\beta \cdot \beta}{1 + \alpha}}} \]
          2. associate-/r/N/A

            \[\leadsto \frac{1}{\beta \cdot \beta} \cdot \color{blue}{\left(1 + \alpha\right)} \]
          3. *-lowering-*.f64N/A

            \[\leadsto \mathsf{*.f64}\left(\left(\frac{1}{\beta \cdot \beta}\right), \color{blue}{\left(1 + \alpha\right)}\right) \]
          4. /-lowering-/.f64N/A

            \[\leadsto \mathsf{*.f64}\left(\mathsf{/.f64}\left(1, \left(\beta \cdot \beta\right)\right), \left(\color{blue}{1} + \alpha\right)\right) \]
          5. *-lowering-*.f64N/A

            \[\leadsto \mathsf{*.f64}\left(\mathsf{/.f64}\left(1, \mathsf{*.f64}\left(\beta, \beta\right)\right), \left(1 + \alpha\right)\right) \]
          6. +-lowering-+.f6488.8%

            \[\leadsto \mathsf{*.f64}\left(\mathsf{/.f64}\left(1, \mathsf{*.f64}\left(\beta, \beta\right)\right), \mathsf{+.f64}\left(1, \color{blue}{\alpha}\right)\right) \]
        9. Applied egg-rr88.8%

          \[\leadsto \color{blue}{\frac{1}{\beta \cdot \beta} \cdot \left(1 + \alpha\right)} \]
        10. Taylor expanded in alpha around inf

          \[\leadsto \mathsf{*.f64}\left(\mathsf{/.f64}\left(1, \mathsf{*.f64}\left(\beta, \beta\right)\right), \color{blue}{\alpha}\right) \]
        11. Step-by-step derivation
          1. Simplified88.8%

            \[\leadsto \frac{1}{\beta \cdot \beta} \cdot \color{blue}{\alpha} \]
          2. Step-by-step derivation
            1. *-commutativeN/A

              \[\leadsto \alpha \cdot \color{blue}{\frac{1}{\beta \cdot \beta}} \]
            2. un-div-invN/A

              \[\leadsto \frac{\alpha}{\color{blue}{\beta \cdot \beta}} \]
            3. associate-/r*N/A

              \[\leadsto \frac{\frac{\alpha}{\beta}}{\color{blue}{\beta}} \]
            4. /-lowering-/.f64N/A

              \[\leadsto \mathsf{/.f64}\left(\left(\frac{\alpha}{\beta}\right), \color{blue}{\beta}\right) \]
            5. /-lowering-/.f6498.8%

              \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\alpha, \beta\right), \beta\right) \]
          3. Applied egg-rr98.8%

            \[\leadsto \color{blue}{\frac{\frac{\alpha}{\beta}}{\beta}} \]
        12. Recombined 3 regimes into one program.
        13. Add Preprocessing

        Alternative 13: 93.7% accurate, 2.3× speedup?

        \[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 2.8:\\ \;\;\;\;0.08333333333333333 + \alpha \cdot -0.027777777777777776\\ \mathbf{elif}\;\beta \leq 1.4 \cdot 10^{+154}:\\ \;\;\;\;\frac{1}{\beta \cdot \beta}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{\alpha}{\beta}}{\beta}\\ \end{array} \end{array} \]
        NOTE: alpha and beta should be sorted in increasing order before calling this function.
        (FPCore (alpha beta)
         :precision binary64
         (if (<= beta 2.8)
           (+ 0.08333333333333333 (* alpha -0.027777777777777776))
           (if (<= beta 1.4e+154) (/ 1.0 (* beta beta)) (/ (/ alpha beta) beta))))
        assert(alpha < beta);
        double code(double alpha, double beta) {
        	double tmp;
        	if (beta <= 2.8) {
        		tmp = 0.08333333333333333 + (alpha * -0.027777777777777776);
        	} else if (beta <= 1.4e+154) {
        		tmp = 1.0 / (beta * beta);
        	} else {
        		tmp = (alpha / beta) / beta;
        	}
        	return tmp;
        }
        
        NOTE: alpha and beta should be sorted in increasing order before calling this function.
        real(8) function code(alpha, beta)
            real(8), intent (in) :: alpha
            real(8), intent (in) :: beta
            real(8) :: tmp
            if (beta <= 2.8d0) then
                tmp = 0.08333333333333333d0 + (alpha * (-0.027777777777777776d0))
            else if (beta <= 1.4d+154) then
                tmp = 1.0d0 / (beta * beta)
            else
                tmp = (alpha / beta) / beta
            end if
            code = tmp
        end function
        
        assert alpha < beta;
        public static double code(double alpha, double beta) {
        	double tmp;
        	if (beta <= 2.8) {
        		tmp = 0.08333333333333333 + (alpha * -0.027777777777777776);
        	} else if (beta <= 1.4e+154) {
        		tmp = 1.0 / (beta * beta);
        	} else {
        		tmp = (alpha / beta) / beta;
        	}
        	return tmp;
        }
        
        [alpha, beta] = sort([alpha, beta])
        def code(alpha, beta):
        	tmp = 0
        	if beta <= 2.8:
        		tmp = 0.08333333333333333 + (alpha * -0.027777777777777776)
        	elif beta <= 1.4e+154:
        		tmp = 1.0 / (beta * beta)
        	else:
        		tmp = (alpha / beta) / beta
        	return tmp
        
        alpha, beta = sort([alpha, beta])
        function code(alpha, beta)
        	tmp = 0.0
        	if (beta <= 2.8)
        		tmp = Float64(0.08333333333333333 + Float64(alpha * -0.027777777777777776));
        	elseif (beta <= 1.4e+154)
        		tmp = Float64(1.0 / Float64(beta * beta));
        	else
        		tmp = Float64(Float64(alpha / beta) / beta);
        	end
        	return tmp
        end
        
        alpha, beta = num2cell(sort([alpha, beta])){:}
        function tmp_2 = code(alpha, beta)
        	tmp = 0.0;
        	if (beta <= 2.8)
        		tmp = 0.08333333333333333 + (alpha * -0.027777777777777776);
        	elseif (beta <= 1.4e+154)
        		tmp = 1.0 / (beta * beta);
        	else
        		tmp = (alpha / beta) / beta;
        	end
        	tmp_2 = tmp;
        end
        
        NOTE: alpha and beta should be sorted in increasing order before calling this function.
        code[alpha_, beta_] := If[LessEqual[beta, 2.8], N[(0.08333333333333333 + N[(alpha * -0.027777777777777776), $MachinePrecision]), $MachinePrecision], If[LessEqual[beta, 1.4e+154], N[(1.0 / N[(beta * beta), $MachinePrecision]), $MachinePrecision], N[(N[(alpha / beta), $MachinePrecision] / beta), $MachinePrecision]]]
        
        \begin{array}{l}
        [alpha, beta] = \mathsf{sort}([alpha, beta])\\
        \\
        \begin{array}{l}
        \mathbf{if}\;\beta \leq 2.8:\\
        \;\;\;\;0.08333333333333333 + \alpha \cdot -0.027777777777777776\\
        
        \mathbf{elif}\;\beta \leq 1.4 \cdot 10^{+154}:\\
        \;\;\;\;\frac{1}{\beta \cdot \beta}\\
        
        \mathbf{else}:\\
        \;\;\;\;\frac{\frac{\alpha}{\beta}}{\beta}\\
        
        
        \end{array}
        \end{array}
        
        Derivation
        1. Split input into 3 regimes
        2. if beta < 2.7999999999999998

          1. Initial program 99.9%

            \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
          2. Step-by-step derivation
            1. associate-/l/N/A

              \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
            2. associate-/l/N/A

              \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
            3. /-lowering-/.f64N/A

              \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
            4. +-commutativeN/A

              \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            5. associate-+l+N/A

              \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            6. associate-+l+N/A

              \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            7. associate-+r+N/A

              \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            8. distribute-lft1-inN/A

              \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            9. *-commutativeN/A

              \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            10. distribute-lft1-inN/A

              \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            11. +-commutativeN/A

              \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            12. *-lowering-*.f64N/A

              \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            13. +-commutativeN/A

              \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            14. +-lowering-+.f64N/A

              \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            15. +-lowering-+.f64N/A

              \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
          3. Simplified93.6%

            \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
          4. Add Preprocessing
          5. Applied egg-rr99.8%

            \[\leadsto \color{blue}{\frac{1 + \beta}{\alpha + \left(\beta + 3\right)} \cdot {\left(\frac{\alpha + \left(\beta + 2\right)}{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}\right)}^{-1}} \]
          6. Taylor expanded in beta around 0

            \[\leadsto \color{blue}{\frac{1 + \alpha}{{\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)}} \]
          7. Step-by-step derivation
            1. /-lowering-/.f64N/A

              \[\leadsto \mathsf{/.f64}\left(\left(1 + \alpha\right), \color{blue}{\left({\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)\right)}\right) \]
            2. +-lowering-+.f64N/A

              \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\color{blue}{{\left(2 + \alpha\right)}^{2}} \cdot \left(3 + \alpha\right)\right)\right) \]
            3. *-lowering-*.f64N/A

              \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left({\left(2 + \alpha\right)}^{2}\right), \color{blue}{\left(3 + \alpha\right)}\right)\right) \]
            4. unpow2N/A

              \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left(\left(2 + \alpha\right) \cdot \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
            5. *-lowering-*.f64N/A

              \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(2 + \alpha\right), \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
            6. +-commutativeN/A

              \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 2\right), \left(2 + \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
            7. +-lowering-+.f64N/A

              \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \left(2 + \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
            8. +-commutativeN/A

              \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \left(\alpha + 2\right)\right), \left(3 + \alpha\right)\right)\right) \]
            9. +-lowering-+.f64N/A

              \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \left(3 + \alpha\right)\right)\right) \]
            10. +-commutativeN/A

              \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \left(\alpha + \color{blue}{3}\right)\right)\right) \]
            11. +-lowering-+.f6492.2%

              \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \mathsf{+.f64}\left(\alpha, \color{blue}{3}\right)\right)\right) \]
          8. Simplified92.2%

            \[\leadsto \color{blue}{\frac{1 + \alpha}{\left(\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)\right) \cdot \left(\alpha + 3\right)}} \]
          9. Taylor expanded in alpha around 0

            \[\leadsto \color{blue}{\frac{1}{12} + \frac{-1}{36} \cdot \alpha} \]
          10. Step-by-step derivation
            1. +-lowering-+.f64N/A

              \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \color{blue}{\left(\frac{-1}{36} \cdot \alpha\right)}\right) \]
            2. *-commutativeN/A

              \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \left(\alpha \cdot \color{blue}{\frac{-1}{36}}\right)\right) \]
            3. *-lowering-*.f6461.1%

              \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \color{blue}{\frac{-1}{36}}\right)\right) \]
          11. Simplified61.1%

            \[\leadsto \color{blue}{0.08333333333333333 + \alpha \cdot -0.027777777777777776} \]

          if 2.7999999999999998 < beta < 1.4e154

          1. Initial program 91.8%

            \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
          2. Step-by-step derivation
            1. associate-/l/N/A

              \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
            2. associate-/l/N/A

              \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
            3. /-lowering-/.f64N/A

              \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
            4. +-commutativeN/A

              \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            5. associate-+l+N/A

              \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            6. associate-+l+N/A

              \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            7. associate-+r+N/A

              \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            8. distribute-lft1-inN/A

              \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            9. *-commutativeN/A

              \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            10. distribute-lft1-inN/A

              \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            11. +-commutativeN/A

              \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            12. *-lowering-*.f64N/A

              \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            13. +-commutativeN/A

              \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            14. +-lowering-+.f64N/A

              \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            15. +-lowering-+.f64N/A

              \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
          3. Simplified65.9%

            \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
          4. Add Preprocessing
          5. Taylor expanded in beta around inf

            \[\leadsto \color{blue}{\frac{1 + \alpha}{{\beta}^{2}}} \]
          6. Step-by-step derivation
            1. /-lowering-/.f64N/A

              \[\leadsto \mathsf{/.f64}\left(\left(1 + \alpha\right), \color{blue}{\left({\beta}^{2}\right)}\right) \]
            2. +-lowering-+.f64N/A

              \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left({\color{blue}{\beta}}^{2}\right)\right) \]
            3. unpow2N/A

              \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\beta \cdot \color{blue}{\beta}\right)\right) \]
            4. *-lowering-*.f6467.3%

              \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\beta, \color{blue}{\beta}\right)\right) \]
          7. Simplified67.3%

            \[\leadsto \color{blue}{\frac{1 + \alpha}{\beta \cdot \beta}} \]
          8. Taylor expanded in alpha around 0

            \[\leadsto \color{blue}{\frac{1}{{\beta}^{2}}} \]
          9. Step-by-step derivation
            1. /-lowering-/.f64N/A

              \[\leadsto \mathsf{/.f64}\left(1, \color{blue}{\left({\beta}^{2}\right)}\right) \]
            2. unpow2N/A

              \[\leadsto \mathsf{/.f64}\left(1, \left(\beta \cdot \color{blue}{\beta}\right)\right) \]
            3. *-lowering-*.f6456.7%

              \[\leadsto \mathsf{/.f64}\left(1, \mathsf{*.f64}\left(\beta, \color{blue}{\beta}\right)\right) \]
          10. Simplified56.7%

            \[\leadsto \color{blue}{\frac{1}{\beta \cdot \beta}} \]

          if 1.4e154 < beta

          1. Initial program 82.5%

            \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
          2. Step-by-step derivation
            1. associate-/l/N/A

              \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
            2. associate-/l/N/A

              \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
            3. /-lowering-/.f64N/A

              \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
            4. +-commutativeN/A

              \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            5. associate-+l+N/A

              \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            6. associate-+l+N/A

              \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            7. associate-+r+N/A

              \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            8. distribute-lft1-inN/A

              \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            9. *-commutativeN/A

              \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            10. distribute-lft1-inN/A

              \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            11. +-commutativeN/A

              \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            12. *-lowering-*.f64N/A

              \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            13. +-commutativeN/A

              \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            14. +-lowering-+.f64N/A

              \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            15. +-lowering-+.f64N/A

              \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
          3. Simplified75.2%

            \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
          4. Add Preprocessing
          5. Taylor expanded in beta around inf

            \[\leadsto \color{blue}{\frac{1 + \alpha}{{\beta}^{2}}} \]
          6. Step-by-step derivation
            1. /-lowering-/.f64N/A

              \[\leadsto \mathsf{/.f64}\left(\left(1 + \alpha\right), \color{blue}{\left({\beta}^{2}\right)}\right) \]
            2. +-lowering-+.f64N/A

              \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left({\color{blue}{\beta}}^{2}\right)\right) \]
            3. unpow2N/A

              \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\beta \cdot \color{blue}{\beta}\right)\right) \]
            4. *-lowering-*.f6488.8%

              \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\beta, \color{blue}{\beta}\right)\right) \]
          7. Simplified88.8%

            \[\leadsto \color{blue}{\frac{1 + \alpha}{\beta \cdot \beta}} \]
          8. Step-by-step derivation
            1. clear-numN/A

              \[\leadsto \frac{1}{\color{blue}{\frac{\beta \cdot \beta}{1 + \alpha}}} \]
            2. associate-/r/N/A

              \[\leadsto \frac{1}{\beta \cdot \beta} \cdot \color{blue}{\left(1 + \alpha\right)} \]
            3. *-lowering-*.f64N/A

              \[\leadsto \mathsf{*.f64}\left(\left(\frac{1}{\beta \cdot \beta}\right), \color{blue}{\left(1 + \alpha\right)}\right) \]
            4. /-lowering-/.f64N/A

              \[\leadsto \mathsf{*.f64}\left(\mathsf{/.f64}\left(1, \left(\beta \cdot \beta\right)\right), \left(\color{blue}{1} + \alpha\right)\right) \]
            5. *-lowering-*.f64N/A

              \[\leadsto \mathsf{*.f64}\left(\mathsf{/.f64}\left(1, \mathsf{*.f64}\left(\beta, \beta\right)\right), \left(1 + \alpha\right)\right) \]
            6. +-lowering-+.f6488.8%

              \[\leadsto \mathsf{*.f64}\left(\mathsf{/.f64}\left(1, \mathsf{*.f64}\left(\beta, \beta\right)\right), \mathsf{+.f64}\left(1, \color{blue}{\alpha}\right)\right) \]
          9. Applied egg-rr88.8%

            \[\leadsto \color{blue}{\frac{1}{\beta \cdot \beta} \cdot \left(1 + \alpha\right)} \]
          10. Taylor expanded in alpha around inf

            \[\leadsto \mathsf{*.f64}\left(\mathsf{/.f64}\left(1, \mathsf{*.f64}\left(\beta, \beta\right)\right), \color{blue}{\alpha}\right) \]
          11. Step-by-step derivation
            1. Simplified88.8%

              \[\leadsto \frac{1}{\beta \cdot \beta} \cdot \color{blue}{\alpha} \]
            2. Step-by-step derivation
              1. *-commutativeN/A

                \[\leadsto \alpha \cdot \color{blue}{\frac{1}{\beta \cdot \beta}} \]
              2. un-div-invN/A

                \[\leadsto \frac{\alpha}{\color{blue}{\beta \cdot \beta}} \]
              3. associate-/r*N/A

                \[\leadsto \frac{\frac{\alpha}{\beta}}{\color{blue}{\beta}} \]
              4. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\frac{\alpha}{\beta}\right), \color{blue}{\beta}\right) \]
              5. /-lowering-/.f6498.8%

                \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\alpha, \beta\right), \beta\right) \]
            3. Applied egg-rr98.8%

              \[\leadsto \color{blue}{\frac{\frac{\alpha}{\beta}}{\beta}} \]
          12. Recombined 3 regimes into one program.
          13. Add Preprocessing

          Alternative 14: 97.1% accurate, 2.5× speedup?

          \[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 3.1:\\ \;\;\;\;0.08333333333333333 + \alpha \cdot \left(-0.027777777777777776 + \alpha \cdot -0.011574074074074073\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{1}{\beta}}{\frac{\beta}{1 + \alpha}}\\ \end{array} \end{array} \]
          NOTE: alpha and beta should be sorted in increasing order before calling this function.
          (FPCore (alpha beta)
           :precision binary64
           (if (<= beta 3.1)
             (+
              0.08333333333333333
              (* alpha (+ -0.027777777777777776 (* alpha -0.011574074074074073))))
             (/ (/ 1.0 beta) (/ beta (+ 1.0 alpha)))))
          assert(alpha < beta);
          double code(double alpha, double beta) {
          	double tmp;
          	if (beta <= 3.1) {
          		tmp = 0.08333333333333333 + (alpha * (-0.027777777777777776 + (alpha * -0.011574074074074073)));
          	} else {
          		tmp = (1.0 / beta) / (beta / (1.0 + alpha));
          	}
          	return tmp;
          }
          
          NOTE: alpha and beta should be sorted in increasing order before calling this function.
          real(8) function code(alpha, beta)
              real(8), intent (in) :: alpha
              real(8), intent (in) :: beta
              real(8) :: tmp
              if (beta <= 3.1d0) then
                  tmp = 0.08333333333333333d0 + (alpha * ((-0.027777777777777776d0) + (alpha * (-0.011574074074074073d0))))
              else
                  tmp = (1.0d0 / beta) / (beta / (1.0d0 + alpha))
              end if
              code = tmp
          end function
          
          assert alpha < beta;
          public static double code(double alpha, double beta) {
          	double tmp;
          	if (beta <= 3.1) {
          		tmp = 0.08333333333333333 + (alpha * (-0.027777777777777776 + (alpha * -0.011574074074074073)));
          	} else {
          		tmp = (1.0 / beta) / (beta / (1.0 + alpha));
          	}
          	return tmp;
          }
          
          [alpha, beta] = sort([alpha, beta])
          def code(alpha, beta):
          	tmp = 0
          	if beta <= 3.1:
          		tmp = 0.08333333333333333 + (alpha * (-0.027777777777777776 + (alpha * -0.011574074074074073)))
          	else:
          		tmp = (1.0 / beta) / (beta / (1.0 + alpha))
          	return tmp
          
          alpha, beta = sort([alpha, beta])
          function code(alpha, beta)
          	tmp = 0.0
          	if (beta <= 3.1)
          		tmp = Float64(0.08333333333333333 + Float64(alpha * Float64(-0.027777777777777776 + Float64(alpha * -0.011574074074074073))));
          	else
          		tmp = Float64(Float64(1.0 / beta) / Float64(beta / Float64(1.0 + alpha)));
          	end
          	return tmp
          end
          
          alpha, beta = num2cell(sort([alpha, beta])){:}
          function tmp_2 = code(alpha, beta)
          	tmp = 0.0;
          	if (beta <= 3.1)
          		tmp = 0.08333333333333333 + (alpha * (-0.027777777777777776 + (alpha * -0.011574074074074073)));
          	else
          		tmp = (1.0 / beta) / (beta / (1.0 + alpha));
          	end
          	tmp_2 = tmp;
          end
          
          NOTE: alpha and beta should be sorted in increasing order before calling this function.
          code[alpha_, beta_] := If[LessEqual[beta, 3.1], N[(0.08333333333333333 + N[(alpha * N[(-0.027777777777777776 + N[(alpha * -0.011574074074074073), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(1.0 / beta), $MachinePrecision] / N[(beta / N[(1.0 + alpha), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
          
          \begin{array}{l}
          [alpha, beta] = \mathsf{sort}([alpha, beta])\\
          \\
          \begin{array}{l}
          \mathbf{if}\;\beta \leq 3.1:\\
          \;\;\;\;0.08333333333333333 + \alpha \cdot \left(-0.027777777777777776 + \alpha \cdot -0.011574074074074073\right)\\
          
          \mathbf{else}:\\
          \;\;\;\;\frac{\frac{1}{\beta}}{\frac{\beta}{1 + \alpha}}\\
          
          
          \end{array}
          \end{array}
          
          Derivation
          1. Split input into 2 regimes
          2. if beta < 3.10000000000000009

            1. Initial program 99.9%

              \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
            2. Step-by-step derivation
              1. associate-/l/N/A

                \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
              2. associate-/l/N/A

                \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
              3. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
              4. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              5. associate-+l+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              6. associate-+l+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              7. associate-+r+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              8. distribute-lft1-inN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              9. *-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              10. distribute-lft1-inN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              11. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              12. *-lowering-*.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              13. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              14. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              15. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            3. Simplified93.6%

              \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
            4. Add Preprocessing
            5. Applied egg-rr99.8%

              \[\leadsto \color{blue}{\frac{1 + \beta}{\alpha + \left(\beta + 3\right)} \cdot {\left(\frac{\alpha + \left(\beta + 2\right)}{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}\right)}^{-1}} \]
            6. Taylor expanded in beta around 0

              \[\leadsto \color{blue}{\frac{1 + \alpha}{{\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)}} \]
            7. Step-by-step derivation
              1. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\left(1 + \alpha\right), \color{blue}{\left({\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)\right)}\right) \]
              2. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\color{blue}{{\left(2 + \alpha\right)}^{2}} \cdot \left(3 + \alpha\right)\right)\right) \]
              3. *-lowering-*.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left({\left(2 + \alpha\right)}^{2}\right), \color{blue}{\left(3 + \alpha\right)}\right)\right) \]
              4. unpow2N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left(\left(2 + \alpha\right) \cdot \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
              5. *-lowering-*.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(2 + \alpha\right), \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
              6. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 2\right), \left(2 + \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
              7. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \left(2 + \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
              8. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \left(\alpha + 2\right)\right), \left(3 + \alpha\right)\right)\right) \]
              9. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \left(3 + \alpha\right)\right)\right) \]
              10. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \left(\alpha + \color{blue}{3}\right)\right)\right) \]
              11. +-lowering-+.f6492.2%

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \mathsf{+.f64}\left(\alpha, \color{blue}{3}\right)\right)\right) \]
            8. Simplified92.2%

              \[\leadsto \color{blue}{\frac{1 + \alpha}{\left(\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)\right) \cdot \left(\alpha + 3\right)}} \]
            9. Taylor expanded in alpha around 0

              \[\leadsto \color{blue}{\frac{1}{12} + \alpha \cdot \left(\frac{-5}{432} \cdot \alpha - \frac{1}{36}\right)} \]
            10. Step-by-step derivation
              1. +-lowering-+.f64N/A

                \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \color{blue}{\left(\alpha \cdot \left(\frac{-5}{432} \cdot \alpha - \frac{1}{36}\right)\right)}\right) \]
              2. *-lowering-*.f64N/A

                \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \color{blue}{\left(\frac{-5}{432} \cdot \alpha - \frac{1}{36}\right)}\right)\right) \]
              3. sub-negN/A

                \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \left(\frac{-5}{432} \cdot \alpha + \color{blue}{\left(\mathsf{neg}\left(\frac{1}{36}\right)\right)}\right)\right)\right) \]
              4. metadata-evalN/A

                \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \left(\frac{-5}{432} \cdot \alpha + \frac{-1}{36}\right)\right)\right) \]
              5. +-lowering-+.f64N/A

                \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \mathsf{+.f64}\left(\left(\frac{-5}{432} \cdot \alpha\right), \color{blue}{\frac{-1}{36}}\right)\right)\right) \]
              6. *-commutativeN/A

                \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \mathsf{+.f64}\left(\left(\alpha \cdot \frac{-5}{432}\right), \frac{-1}{36}\right)\right)\right) \]
              7. *-lowering-*.f6461.3%

                \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \mathsf{+.f64}\left(\mathsf{*.f64}\left(\alpha, \frac{-5}{432}\right), \frac{-1}{36}\right)\right)\right) \]
            11. Simplified61.3%

              \[\leadsto \color{blue}{0.08333333333333333 + \alpha \cdot \left(\alpha \cdot -0.011574074074074073 + -0.027777777777777776\right)} \]

            if 3.10000000000000009 < beta

            1. Initial program 87.4%

              \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
            2. Step-by-step derivation
              1. associate-/l/N/A

                \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
              2. associate-/l/N/A

                \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
              3. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
              4. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              5. associate-+l+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              6. associate-+l+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              7. associate-+r+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              8. distribute-lft1-inN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              9. *-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              10. distribute-lft1-inN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              11. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              12. *-lowering-*.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              13. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              14. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              15. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            3. Simplified70.3%

              \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
            4. Add Preprocessing
            5. Taylor expanded in beta around inf

              \[\leadsto \color{blue}{\frac{1 + \alpha}{{\beta}^{2}}} \]
            6. Step-by-step derivation
              1. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\left(1 + \alpha\right), \color{blue}{\left({\beta}^{2}\right)}\right) \]
              2. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left({\color{blue}{\beta}}^{2}\right)\right) \]
              3. unpow2N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\beta \cdot \color{blue}{\beta}\right)\right) \]
              4. *-lowering-*.f6477.5%

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\beta, \color{blue}{\beta}\right)\right) \]
            7. Simplified77.5%

              \[\leadsto \color{blue}{\frac{1 + \alpha}{\beta \cdot \beta}} \]
            8. Step-by-step derivation
              1. clear-numN/A

                \[\leadsto \frac{1}{\color{blue}{\frac{\beta \cdot \beta}{1 + \alpha}}} \]
              2. associate-/l*N/A

                \[\leadsto \frac{1}{\beta \cdot \color{blue}{\frac{\beta}{1 + \alpha}}} \]
              3. associate-/r*N/A

                \[\leadsto \frac{\frac{1}{\beta}}{\color{blue}{\frac{\beta}{1 + \alpha}}} \]
              4. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\frac{1}{\beta}\right), \color{blue}{\left(\frac{\beta}{1 + \alpha}\right)}\right) \]
              5. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(1, \beta\right), \left(\frac{\color{blue}{\beta}}{1 + \alpha}\right)\right) \]
              6. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(1, \beta\right), \mathsf{/.f64}\left(\beta, \color{blue}{\left(1 + \alpha\right)}\right)\right) \]
              7. +-lowering-+.f6482.8%

                \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(1, \beta\right), \mathsf{/.f64}\left(\beta, \mathsf{+.f64}\left(1, \color{blue}{\alpha}\right)\right)\right) \]
            9. Applied egg-rr82.8%

              \[\leadsto \color{blue}{\frac{\frac{1}{\beta}}{\frac{\beta}{1 + \alpha}}} \]
          3. Recombined 2 regimes into one program.
          4. Final simplification69.3%

            \[\leadsto \begin{array}{l} \mathbf{if}\;\beta \leq 3.1:\\ \;\;\;\;0.08333333333333333 + \alpha \cdot \left(-0.027777777777777776 + \alpha \cdot -0.011574074074074073\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{1}{\beta}}{\frac{\beta}{1 + \alpha}}\\ \end{array} \]
          5. Add Preprocessing

          Alternative 15: 97.1% accurate, 2.5× speedup?

          \[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 3.25:\\ \;\;\;\;0.08333333333333333 + \alpha \cdot \left(-0.027777777777777776 + \alpha \cdot -0.011574074074074073\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{1 + \alpha}{\beta}}{\beta}\\ \end{array} \end{array} \]
          NOTE: alpha and beta should be sorted in increasing order before calling this function.
          (FPCore (alpha beta)
           :precision binary64
           (if (<= beta 3.25)
             (+
              0.08333333333333333
              (* alpha (+ -0.027777777777777776 (* alpha -0.011574074074074073))))
             (/ (/ (+ 1.0 alpha) beta) beta)))
          assert(alpha < beta);
          double code(double alpha, double beta) {
          	double tmp;
          	if (beta <= 3.25) {
          		tmp = 0.08333333333333333 + (alpha * (-0.027777777777777776 + (alpha * -0.011574074074074073)));
          	} else {
          		tmp = ((1.0 + alpha) / beta) / beta;
          	}
          	return tmp;
          }
          
          NOTE: alpha and beta should be sorted in increasing order before calling this function.
          real(8) function code(alpha, beta)
              real(8), intent (in) :: alpha
              real(8), intent (in) :: beta
              real(8) :: tmp
              if (beta <= 3.25d0) then
                  tmp = 0.08333333333333333d0 + (alpha * ((-0.027777777777777776d0) + (alpha * (-0.011574074074074073d0))))
              else
                  tmp = ((1.0d0 + alpha) / beta) / beta
              end if
              code = tmp
          end function
          
          assert alpha < beta;
          public static double code(double alpha, double beta) {
          	double tmp;
          	if (beta <= 3.25) {
          		tmp = 0.08333333333333333 + (alpha * (-0.027777777777777776 + (alpha * -0.011574074074074073)));
          	} else {
          		tmp = ((1.0 + alpha) / beta) / beta;
          	}
          	return tmp;
          }
          
          [alpha, beta] = sort([alpha, beta])
          def code(alpha, beta):
          	tmp = 0
          	if beta <= 3.25:
          		tmp = 0.08333333333333333 + (alpha * (-0.027777777777777776 + (alpha * -0.011574074074074073)))
          	else:
          		tmp = ((1.0 + alpha) / beta) / beta
          	return tmp
          
          alpha, beta = sort([alpha, beta])
          function code(alpha, beta)
          	tmp = 0.0
          	if (beta <= 3.25)
          		tmp = Float64(0.08333333333333333 + Float64(alpha * Float64(-0.027777777777777776 + Float64(alpha * -0.011574074074074073))));
          	else
          		tmp = Float64(Float64(Float64(1.0 + alpha) / beta) / beta);
          	end
          	return tmp
          end
          
          alpha, beta = num2cell(sort([alpha, beta])){:}
          function tmp_2 = code(alpha, beta)
          	tmp = 0.0;
          	if (beta <= 3.25)
          		tmp = 0.08333333333333333 + (alpha * (-0.027777777777777776 + (alpha * -0.011574074074074073)));
          	else
          		tmp = ((1.0 + alpha) / beta) / beta;
          	end
          	tmp_2 = tmp;
          end
          
          NOTE: alpha and beta should be sorted in increasing order before calling this function.
          code[alpha_, beta_] := If[LessEqual[beta, 3.25], N[(0.08333333333333333 + N[(alpha * N[(-0.027777777777777776 + N[(alpha * -0.011574074074074073), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(N[(1.0 + alpha), $MachinePrecision] / beta), $MachinePrecision] / beta), $MachinePrecision]]
          
          \begin{array}{l}
          [alpha, beta] = \mathsf{sort}([alpha, beta])\\
          \\
          \begin{array}{l}
          \mathbf{if}\;\beta \leq 3.25:\\
          \;\;\;\;0.08333333333333333 + \alpha \cdot \left(-0.027777777777777776 + \alpha \cdot -0.011574074074074073\right)\\
          
          \mathbf{else}:\\
          \;\;\;\;\frac{\frac{1 + \alpha}{\beta}}{\beta}\\
          
          
          \end{array}
          \end{array}
          
          Derivation
          1. Split input into 2 regimes
          2. if beta < 3.25

            1. Initial program 99.9%

              \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
            2. Step-by-step derivation
              1. associate-/l/N/A

                \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
              2. associate-/l/N/A

                \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
              3. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
              4. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              5. associate-+l+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              6. associate-+l+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              7. associate-+r+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              8. distribute-lft1-inN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              9. *-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              10. distribute-lft1-inN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              11. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              12. *-lowering-*.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              13. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              14. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              15. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            3. Simplified93.6%

              \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
            4. Add Preprocessing
            5. Applied egg-rr99.8%

              \[\leadsto \color{blue}{\frac{1 + \beta}{\alpha + \left(\beta + 3\right)} \cdot {\left(\frac{\alpha + \left(\beta + 2\right)}{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}\right)}^{-1}} \]
            6. Taylor expanded in beta around 0

              \[\leadsto \color{blue}{\frac{1 + \alpha}{{\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)}} \]
            7. Step-by-step derivation
              1. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\left(1 + \alpha\right), \color{blue}{\left({\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)\right)}\right) \]
              2. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\color{blue}{{\left(2 + \alpha\right)}^{2}} \cdot \left(3 + \alpha\right)\right)\right) \]
              3. *-lowering-*.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left({\left(2 + \alpha\right)}^{2}\right), \color{blue}{\left(3 + \alpha\right)}\right)\right) \]
              4. unpow2N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left(\left(2 + \alpha\right) \cdot \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
              5. *-lowering-*.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(2 + \alpha\right), \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
              6. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 2\right), \left(2 + \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
              7. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \left(2 + \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
              8. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \left(\alpha + 2\right)\right), \left(3 + \alpha\right)\right)\right) \]
              9. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \left(3 + \alpha\right)\right)\right) \]
              10. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \left(\alpha + \color{blue}{3}\right)\right)\right) \]
              11. +-lowering-+.f6492.2%

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \mathsf{+.f64}\left(\alpha, \color{blue}{3}\right)\right)\right) \]
            8. Simplified92.2%

              \[\leadsto \color{blue}{\frac{1 + \alpha}{\left(\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)\right) \cdot \left(\alpha + 3\right)}} \]
            9. Taylor expanded in alpha around 0

              \[\leadsto \color{blue}{\frac{1}{12} + \alpha \cdot \left(\frac{-5}{432} \cdot \alpha - \frac{1}{36}\right)} \]
            10. Step-by-step derivation
              1. +-lowering-+.f64N/A

                \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \color{blue}{\left(\alpha \cdot \left(\frac{-5}{432} \cdot \alpha - \frac{1}{36}\right)\right)}\right) \]
              2. *-lowering-*.f64N/A

                \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \color{blue}{\left(\frac{-5}{432} \cdot \alpha - \frac{1}{36}\right)}\right)\right) \]
              3. sub-negN/A

                \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \left(\frac{-5}{432} \cdot \alpha + \color{blue}{\left(\mathsf{neg}\left(\frac{1}{36}\right)\right)}\right)\right)\right) \]
              4. metadata-evalN/A

                \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \left(\frac{-5}{432} \cdot \alpha + \frac{-1}{36}\right)\right)\right) \]
              5. +-lowering-+.f64N/A

                \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \mathsf{+.f64}\left(\left(\frac{-5}{432} \cdot \alpha\right), \color{blue}{\frac{-1}{36}}\right)\right)\right) \]
              6. *-commutativeN/A

                \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \mathsf{+.f64}\left(\left(\alpha \cdot \frac{-5}{432}\right), \frac{-1}{36}\right)\right)\right) \]
              7. *-lowering-*.f6461.3%

                \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \mathsf{+.f64}\left(\mathsf{*.f64}\left(\alpha, \frac{-5}{432}\right), \frac{-1}{36}\right)\right)\right) \]
            11. Simplified61.3%

              \[\leadsto \color{blue}{0.08333333333333333 + \alpha \cdot \left(\alpha \cdot -0.011574074074074073 + -0.027777777777777776\right)} \]

            if 3.25 < beta

            1. Initial program 87.4%

              \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
            2. Step-by-step derivation
              1. associate-/l/N/A

                \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
              2. associate-/l/N/A

                \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
              3. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
              4. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              5. associate-+l+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              6. associate-+l+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              7. associate-+r+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              8. distribute-lft1-inN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              9. *-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              10. distribute-lft1-inN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              11. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              12. *-lowering-*.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              13. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              14. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              15. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            3. Simplified70.3%

              \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
            4. Add Preprocessing
            5. Taylor expanded in beta around inf

              \[\leadsto \color{blue}{\frac{1 + \alpha}{{\beta}^{2}}} \]
            6. Step-by-step derivation
              1. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\left(1 + \alpha\right), \color{blue}{\left({\beta}^{2}\right)}\right) \]
              2. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left({\color{blue}{\beta}}^{2}\right)\right) \]
              3. unpow2N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\beta \cdot \color{blue}{\beta}\right)\right) \]
              4. *-lowering-*.f6477.5%

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\beta, \color{blue}{\beta}\right)\right) \]
            7. Simplified77.5%

              \[\leadsto \color{blue}{\frac{1 + \alpha}{\beta \cdot \beta}} \]
            8. Step-by-step derivation
              1. associate-/r*N/A

                \[\leadsto \frac{\frac{1 + \alpha}{\beta}}{\color{blue}{\beta}} \]
              2. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\frac{1 + \alpha}{\beta}\right), \color{blue}{\beta}\right) \]
              3. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\left(1 + \alpha\right), \beta\right), \beta\right) \]
              4. +-lowering-+.f6482.8%

                \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \beta\right), \beta\right) \]
            9. Applied egg-rr82.8%

              \[\leadsto \color{blue}{\frac{\frac{1 + \alpha}{\beta}}{\beta}} \]
          3. Recombined 2 regimes into one program.
          4. Final simplification69.3%

            \[\leadsto \begin{array}{l} \mathbf{if}\;\beta \leq 3.25:\\ \;\;\;\;0.08333333333333333 + \alpha \cdot \left(-0.027777777777777776 + \alpha \cdot -0.011574074074074073\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{1 + \alpha}{\beta}}{\beta}\\ \end{array} \]
          5. Add Preprocessing

          Alternative 16: 97.0% accurate, 2.9× speedup?

          \[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 2.75:\\ \;\;\;\;0.08333333333333333 + \alpha \cdot -0.027777777777777776\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{1 + \alpha}{\beta}}{\beta}\\ \end{array} \end{array} \]
          NOTE: alpha and beta should be sorted in increasing order before calling this function.
          (FPCore (alpha beta)
           :precision binary64
           (if (<= beta 2.75)
             (+ 0.08333333333333333 (* alpha -0.027777777777777776))
             (/ (/ (+ 1.0 alpha) beta) beta)))
          assert(alpha < beta);
          double code(double alpha, double beta) {
          	double tmp;
          	if (beta <= 2.75) {
          		tmp = 0.08333333333333333 + (alpha * -0.027777777777777776);
          	} else {
          		tmp = ((1.0 + alpha) / beta) / beta;
          	}
          	return tmp;
          }
          
          NOTE: alpha and beta should be sorted in increasing order before calling this function.
          real(8) function code(alpha, beta)
              real(8), intent (in) :: alpha
              real(8), intent (in) :: beta
              real(8) :: tmp
              if (beta <= 2.75d0) then
                  tmp = 0.08333333333333333d0 + (alpha * (-0.027777777777777776d0))
              else
                  tmp = ((1.0d0 + alpha) / beta) / beta
              end if
              code = tmp
          end function
          
          assert alpha < beta;
          public static double code(double alpha, double beta) {
          	double tmp;
          	if (beta <= 2.75) {
          		tmp = 0.08333333333333333 + (alpha * -0.027777777777777776);
          	} else {
          		tmp = ((1.0 + alpha) / beta) / beta;
          	}
          	return tmp;
          }
          
          [alpha, beta] = sort([alpha, beta])
          def code(alpha, beta):
          	tmp = 0
          	if beta <= 2.75:
          		tmp = 0.08333333333333333 + (alpha * -0.027777777777777776)
          	else:
          		tmp = ((1.0 + alpha) / beta) / beta
          	return tmp
          
          alpha, beta = sort([alpha, beta])
          function code(alpha, beta)
          	tmp = 0.0
          	if (beta <= 2.75)
          		tmp = Float64(0.08333333333333333 + Float64(alpha * -0.027777777777777776));
          	else
          		tmp = Float64(Float64(Float64(1.0 + alpha) / beta) / beta);
          	end
          	return tmp
          end
          
          alpha, beta = num2cell(sort([alpha, beta])){:}
          function tmp_2 = code(alpha, beta)
          	tmp = 0.0;
          	if (beta <= 2.75)
          		tmp = 0.08333333333333333 + (alpha * -0.027777777777777776);
          	else
          		tmp = ((1.0 + alpha) / beta) / beta;
          	end
          	tmp_2 = tmp;
          end
          
          NOTE: alpha and beta should be sorted in increasing order before calling this function.
          code[alpha_, beta_] := If[LessEqual[beta, 2.75], N[(0.08333333333333333 + N[(alpha * -0.027777777777777776), $MachinePrecision]), $MachinePrecision], N[(N[(N[(1.0 + alpha), $MachinePrecision] / beta), $MachinePrecision] / beta), $MachinePrecision]]
          
          \begin{array}{l}
          [alpha, beta] = \mathsf{sort}([alpha, beta])\\
          \\
          \begin{array}{l}
          \mathbf{if}\;\beta \leq 2.75:\\
          \;\;\;\;0.08333333333333333 + \alpha \cdot -0.027777777777777776\\
          
          \mathbf{else}:\\
          \;\;\;\;\frac{\frac{1 + \alpha}{\beta}}{\beta}\\
          
          
          \end{array}
          \end{array}
          
          Derivation
          1. Split input into 2 regimes
          2. if beta < 2.75

            1. Initial program 99.9%

              \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
            2. Step-by-step derivation
              1. associate-/l/N/A

                \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
              2. associate-/l/N/A

                \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
              3. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
              4. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              5. associate-+l+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              6. associate-+l+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              7. associate-+r+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              8. distribute-lft1-inN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              9. *-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              10. distribute-lft1-inN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              11. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              12. *-lowering-*.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              13. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              14. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              15. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            3. Simplified93.6%

              \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
            4. Add Preprocessing
            5. Applied egg-rr99.8%

              \[\leadsto \color{blue}{\frac{1 + \beta}{\alpha + \left(\beta + 3\right)} \cdot {\left(\frac{\alpha + \left(\beta + 2\right)}{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}\right)}^{-1}} \]
            6. Taylor expanded in beta around 0

              \[\leadsto \color{blue}{\frac{1 + \alpha}{{\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)}} \]
            7. Step-by-step derivation
              1. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\left(1 + \alpha\right), \color{blue}{\left({\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)\right)}\right) \]
              2. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\color{blue}{{\left(2 + \alpha\right)}^{2}} \cdot \left(3 + \alpha\right)\right)\right) \]
              3. *-lowering-*.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left({\left(2 + \alpha\right)}^{2}\right), \color{blue}{\left(3 + \alpha\right)}\right)\right) \]
              4. unpow2N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left(\left(2 + \alpha\right) \cdot \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
              5. *-lowering-*.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(2 + \alpha\right), \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
              6. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 2\right), \left(2 + \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
              7. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \left(2 + \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
              8. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \left(\alpha + 2\right)\right), \left(3 + \alpha\right)\right)\right) \]
              9. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \left(3 + \alpha\right)\right)\right) \]
              10. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \left(\alpha + \color{blue}{3}\right)\right)\right) \]
              11. +-lowering-+.f6492.2%

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \mathsf{+.f64}\left(\alpha, \color{blue}{3}\right)\right)\right) \]
            8. Simplified92.2%

              \[\leadsto \color{blue}{\frac{1 + \alpha}{\left(\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)\right) \cdot \left(\alpha + 3\right)}} \]
            9. Taylor expanded in alpha around 0

              \[\leadsto \color{blue}{\frac{1}{12} + \frac{-1}{36} \cdot \alpha} \]
            10. Step-by-step derivation
              1. +-lowering-+.f64N/A

                \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \color{blue}{\left(\frac{-1}{36} \cdot \alpha\right)}\right) \]
              2. *-commutativeN/A

                \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \left(\alpha \cdot \color{blue}{\frac{-1}{36}}\right)\right) \]
              3. *-lowering-*.f6461.1%

                \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \color{blue}{\frac{-1}{36}}\right)\right) \]
            11. Simplified61.1%

              \[\leadsto \color{blue}{0.08333333333333333 + \alpha \cdot -0.027777777777777776} \]

            if 2.75 < beta

            1. Initial program 87.4%

              \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
            2. Step-by-step derivation
              1. associate-/l/N/A

                \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
              2. associate-/l/N/A

                \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
              3. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
              4. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              5. associate-+l+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              6. associate-+l+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              7. associate-+r+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              8. distribute-lft1-inN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              9. *-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              10. distribute-lft1-inN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              11. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              12. *-lowering-*.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              13. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              14. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              15. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            3. Simplified70.3%

              \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
            4. Add Preprocessing
            5. Taylor expanded in beta around inf

              \[\leadsto \color{blue}{\frac{1 + \alpha}{{\beta}^{2}}} \]
            6. Step-by-step derivation
              1. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\left(1 + \alpha\right), \color{blue}{\left({\beta}^{2}\right)}\right) \]
              2. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left({\color{blue}{\beta}}^{2}\right)\right) \]
              3. unpow2N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\beta \cdot \color{blue}{\beta}\right)\right) \]
              4. *-lowering-*.f6477.5%

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\beta, \color{blue}{\beta}\right)\right) \]
            7. Simplified77.5%

              \[\leadsto \color{blue}{\frac{1 + \alpha}{\beta \cdot \beta}} \]
            8. Step-by-step derivation
              1. associate-/r*N/A

                \[\leadsto \frac{\frac{1 + \alpha}{\beta}}{\color{blue}{\beta}} \]
              2. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\frac{1 + \alpha}{\beta}\right), \color{blue}{\beta}\right) \]
              3. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\left(1 + \alpha\right), \beta\right), \beta\right) \]
              4. +-lowering-+.f6482.8%

                \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \beta\right), \beta\right) \]
            9. Applied egg-rr82.8%

              \[\leadsto \color{blue}{\frac{\frac{1 + \alpha}{\beta}}{\beta}} \]
          3. Recombined 2 regimes into one program.
          4. Add Preprocessing

          Alternative 17: 91.1% accurate, 3.5× speedup?

          \[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 3.2:\\ \;\;\;\;0.08333333333333333 + \alpha \cdot -0.027777777777777776\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\beta \cdot \beta}\\ \end{array} \end{array} \]
          NOTE: alpha and beta should be sorted in increasing order before calling this function.
          (FPCore (alpha beta)
           :precision binary64
           (if (<= beta 3.2)
             (+ 0.08333333333333333 (* alpha -0.027777777777777776))
             (/ 1.0 (* beta beta))))
          assert(alpha < beta);
          double code(double alpha, double beta) {
          	double tmp;
          	if (beta <= 3.2) {
          		tmp = 0.08333333333333333 + (alpha * -0.027777777777777776);
          	} else {
          		tmp = 1.0 / (beta * beta);
          	}
          	return tmp;
          }
          
          NOTE: alpha and beta should be sorted in increasing order before calling this function.
          real(8) function code(alpha, beta)
              real(8), intent (in) :: alpha
              real(8), intent (in) :: beta
              real(8) :: tmp
              if (beta <= 3.2d0) then
                  tmp = 0.08333333333333333d0 + (alpha * (-0.027777777777777776d0))
              else
                  tmp = 1.0d0 / (beta * beta)
              end if
              code = tmp
          end function
          
          assert alpha < beta;
          public static double code(double alpha, double beta) {
          	double tmp;
          	if (beta <= 3.2) {
          		tmp = 0.08333333333333333 + (alpha * -0.027777777777777776);
          	} else {
          		tmp = 1.0 / (beta * beta);
          	}
          	return tmp;
          }
          
          [alpha, beta] = sort([alpha, beta])
          def code(alpha, beta):
          	tmp = 0
          	if beta <= 3.2:
          		tmp = 0.08333333333333333 + (alpha * -0.027777777777777776)
          	else:
          		tmp = 1.0 / (beta * beta)
          	return tmp
          
          alpha, beta = sort([alpha, beta])
          function code(alpha, beta)
          	tmp = 0.0
          	if (beta <= 3.2)
          		tmp = Float64(0.08333333333333333 + Float64(alpha * -0.027777777777777776));
          	else
          		tmp = Float64(1.0 / Float64(beta * beta));
          	end
          	return tmp
          end
          
          alpha, beta = num2cell(sort([alpha, beta])){:}
          function tmp_2 = code(alpha, beta)
          	tmp = 0.0;
          	if (beta <= 3.2)
          		tmp = 0.08333333333333333 + (alpha * -0.027777777777777776);
          	else
          		tmp = 1.0 / (beta * beta);
          	end
          	tmp_2 = tmp;
          end
          
          NOTE: alpha and beta should be sorted in increasing order before calling this function.
          code[alpha_, beta_] := If[LessEqual[beta, 3.2], N[(0.08333333333333333 + N[(alpha * -0.027777777777777776), $MachinePrecision]), $MachinePrecision], N[(1.0 / N[(beta * beta), $MachinePrecision]), $MachinePrecision]]
          
          \begin{array}{l}
          [alpha, beta] = \mathsf{sort}([alpha, beta])\\
          \\
          \begin{array}{l}
          \mathbf{if}\;\beta \leq 3.2:\\
          \;\;\;\;0.08333333333333333 + \alpha \cdot -0.027777777777777776\\
          
          \mathbf{else}:\\
          \;\;\;\;\frac{1}{\beta \cdot \beta}\\
          
          
          \end{array}
          \end{array}
          
          Derivation
          1. Split input into 2 regimes
          2. if beta < 3.2000000000000002

            1. Initial program 99.9%

              \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
            2. Step-by-step derivation
              1. associate-/l/N/A

                \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
              2. associate-/l/N/A

                \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
              3. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
              4. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              5. associate-+l+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              6. associate-+l+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              7. associate-+r+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              8. distribute-lft1-inN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              9. *-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              10. distribute-lft1-inN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              11. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              12. *-lowering-*.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              13. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              14. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              15. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            3. Simplified93.6%

              \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
            4. Add Preprocessing
            5. Applied egg-rr99.8%

              \[\leadsto \color{blue}{\frac{1 + \beta}{\alpha + \left(\beta + 3\right)} \cdot {\left(\frac{\alpha + \left(\beta + 2\right)}{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}\right)}^{-1}} \]
            6. Taylor expanded in beta around 0

              \[\leadsto \color{blue}{\frac{1 + \alpha}{{\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)}} \]
            7. Step-by-step derivation
              1. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\left(1 + \alpha\right), \color{blue}{\left({\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)\right)}\right) \]
              2. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\color{blue}{{\left(2 + \alpha\right)}^{2}} \cdot \left(3 + \alpha\right)\right)\right) \]
              3. *-lowering-*.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left({\left(2 + \alpha\right)}^{2}\right), \color{blue}{\left(3 + \alpha\right)}\right)\right) \]
              4. unpow2N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left(\left(2 + \alpha\right) \cdot \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
              5. *-lowering-*.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(2 + \alpha\right), \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
              6. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 2\right), \left(2 + \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
              7. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \left(2 + \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
              8. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \left(\alpha + 2\right)\right), \left(3 + \alpha\right)\right)\right) \]
              9. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \left(3 + \alpha\right)\right)\right) \]
              10. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \left(\alpha + \color{blue}{3}\right)\right)\right) \]
              11. +-lowering-+.f6492.2%

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \mathsf{+.f64}\left(\alpha, \color{blue}{3}\right)\right)\right) \]
            8. Simplified92.2%

              \[\leadsto \color{blue}{\frac{1 + \alpha}{\left(\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)\right) \cdot \left(\alpha + 3\right)}} \]
            9. Taylor expanded in alpha around 0

              \[\leadsto \color{blue}{\frac{1}{12} + \frac{-1}{36} \cdot \alpha} \]
            10. Step-by-step derivation
              1. +-lowering-+.f64N/A

                \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \color{blue}{\left(\frac{-1}{36} \cdot \alpha\right)}\right) \]
              2. *-commutativeN/A

                \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \left(\alpha \cdot \color{blue}{\frac{-1}{36}}\right)\right) \]
              3. *-lowering-*.f6461.1%

                \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \color{blue}{\frac{-1}{36}}\right)\right) \]
            11. Simplified61.1%

              \[\leadsto \color{blue}{0.08333333333333333 + \alpha \cdot -0.027777777777777776} \]

            if 3.2000000000000002 < beta

            1. Initial program 87.4%

              \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
            2. Step-by-step derivation
              1. associate-/l/N/A

                \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
              2. associate-/l/N/A

                \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
              3. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
              4. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              5. associate-+l+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              6. associate-+l+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              7. associate-+r+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              8. distribute-lft1-inN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              9. *-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              10. distribute-lft1-inN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              11. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              12. *-lowering-*.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              13. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              14. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              15. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            3. Simplified70.3%

              \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
            4. Add Preprocessing
            5. Taylor expanded in beta around inf

              \[\leadsto \color{blue}{\frac{1 + \alpha}{{\beta}^{2}}} \]
            6. Step-by-step derivation
              1. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\left(1 + \alpha\right), \color{blue}{\left({\beta}^{2}\right)}\right) \]
              2. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left({\color{blue}{\beta}}^{2}\right)\right) \]
              3. unpow2N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\beta \cdot \color{blue}{\beta}\right)\right) \]
              4. *-lowering-*.f6477.5%

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\beta, \color{blue}{\beta}\right)\right) \]
            7. Simplified77.5%

              \[\leadsto \color{blue}{\frac{1 + \alpha}{\beta \cdot \beta}} \]
            8. Taylor expanded in alpha around 0

              \[\leadsto \color{blue}{\frac{1}{{\beta}^{2}}} \]
            9. Step-by-step derivation
              1. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(1, \color{blue}{\left({\beta}^{2}\right)}\right) \]
              2. unpow2N/A

                \[\leadsto \mathsf{/.f64}\left(1, \left(\beta \cdot \color{blue}{\beta}\right)\right) \]
              3. *-lowering-*.f6471.9%

                \[\leadsto \mathsf{/.f64}\left(1, \mathsf{*.f64}\left(\beta, \color{blue}{\beta}\right)\right) \]
            10. Simplified71.9%

              \[\leadsto \color{blue}{\frac{1}{\beta \cdot \beta}} \]
          3. Recombined 2 regimes into one program.
          4. Add Preprocessing

          Alternative 18: 46.8% accurate, 3.5× speedup?

          \[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 9.5:\\ \;\;\;\;0.08333333333333333 + \alpha \cdot -0.027777777777777776\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\beta}\\ \end{array} \end{array} \]
          NOTE: alpha and beta should be sorted in increasing order before calling this function.
          (FPCore (alpha beta)
           :precision binary64
           (if (<= beta 9.5)
             (+ 0.08333333333333333 (* alpha -0.027777777777777776))
             (/ 1.0 beta)))
          assert(alpha < beta);
          double code(double alpha, double beta) {
          	double tmp;
          	if (beta <= 9.5) {
          		tmp = 0.08333333333333333 + (alpha * -0.027777777777777776);
          	} else {
          		tmp = 1.0 / beta;
          	}
          	return tmp;
          }
          
          NOTE: alpha and beta should be sorted in increasing order before calling this function.
          real(8) function code(alpha, beta)
              real(8), intent (in) :: alpha
              real(8), intent (in) :: beta
              real(8) :: tmp
              if (beta <= 9.5d0) then
                  tmp = 0.08333333333333333d0 + (alpha * (-0.027777777777777776d0))
              else
                  tmp = 1.0d0 / beta
              end if
              code = tmp
          end function
          
          assert alpha < beta;
          public static double code(double alpha, double beta) {
          	double tmp;
          	if (beta <= 9.5) {
          		tmp = 0.08333333333333333 + (alpha * -0.027777777777777776);
          	} else {
          		tmp = 1.0 / beta;
          	}
          	return tmp;
          }
          
          [alpha, beta] = sort([alpha, beta])
          def code(alpha, beta):
          	tmp = 0
          	if beta <= 9.5:
          		tmp = 0.08333333333333333 + (alpha * -0.027777777777777776)
          	else:
          		tmp = 1.0 / beta
          	return tmp
          
          alpha, beta = sort([alpha, beta])
          function code(alpha, beta)
          	tmp = 0.0
          	if (beta <= 9.5)
          		tmp = Float64(0.08333333333333333 + Float64(alpha * -0.027777777777777776));
          	else
          		tmp = Float64(1.0 / beta);
          	end
          	return tmp
          end
          
          alpha, beta = num2cell(sort([alpha, beta])){:}
          function tmp_2 = code(alpha, beta)
          	tmp = 0.0;
          	if (beta <= 9.5)
          		tmp = 0.08333333333333333 + (alpha * -0.027777777777777776);
          	else
          		tmp = 1.0 / beta;
          	end
          	tmp_2 = tmp;
          end
          
          NOTE: alpha and beta should be sorted in increasing order before calling this function.
          code[alpha_, beta_] := If[LessEqual[beta, 9.5], N[(0.08333333333333333 + N[(alpha * -0.027777777777777776), $MachinePrecision]), $MachinePrecision], N[(1.0 / beta), $MachinePrecision]]
          
          \begin{array}{l}
          [alpha, beta] = \mathsf{sort}([alpha, beta])\\
          \\
          \begin{array}{l}
          \mathbf{if}\;\beta \leq 9.5:\\
          \;\;\;\;0.08333333333333333 + \alpha \cdot -0.027777777777777776\\
          
          \mathbf{else}:\\
          \;\;\;\;\frac{1}{\beta}\\
          
          
          \end{array}
          \end{array}
          
          Derivation
          1. Split input into 2 regimes
          2. if beta < 9.5

            1. Initial program 99.9%

              \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
            2. Step-by-step derivation
              1. associate-/l/N/A

                \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
              2. associate-/l/N/A

                \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
              3. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
              4. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              5. associate-+l+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              6. associate-+l+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              7. associate-+r+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              8. distribute-lft1-inN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              9. *-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              10. distribute-lft1-inN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              11. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              12. *-lowering-*.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              13. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              14. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              15. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            3. Simplified93.6%

              \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
            4. Add Preprocessing
            5. Applied egg-rr99.8%

              \[\leadsto \color{blue}{\frac{1 + \beta}{\alpha + \left(\beta + 3\right)} \cdot {\left(\frac{\alpha + \left(\beta + 2\right)}{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}\right)}^{-1}} \]
            6. Taylor expanded in beta around 0

              \[\leadsto \color{blue}{\frac{1 + \alpha}{{\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)}} \]
            7. Step-by-step derivation
              1. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\left(1 + \alpha\right), \color{blue}{\left({\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)\right)}\right) \]
              2. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \left(\color{blue}{{\left(2 + \alpha\right)}^{2}} \cdot \left(3 + \alpha\right)\right)\right) \]
              3. *-lowering-*.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left({\left(2 + \alpha\right)}^{2}\right), \color{blue}{\left(3 + \alpha\right)}\right)\right) \]
              4. unpow2N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\left(\left(2 + \alpha\right) \cdot \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
              5. *-lowering-*.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(2 + \alpha\right), \left(2 + \alpha\right)\right), \left(\color{blue}{3} + \alpha\right)\right)\right) \]
              6. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 2\right), \left(2 + \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
              7. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \left(2 + \alpha\right)\right), \left(3 + \alpha\right)\right)\right) \]
              8. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \left(\alpha + 2\right)\right), \left(3 + \alpha\right)\right)\right) \]
              9. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \left(3 + \alpha\right)\right)\right) \]
              10. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \left(\alpha + \color{blue}{3}\right)\right)\right) \]
              11. +-lowering-+.f6492.2%

                \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \alpha\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 2\right), \mathsf{+.f64}\left(\alpha, 2\right)\right), \mathsf{+.f64}\left(\alpha, \color{blue}{3}\right)\right)\right) \]
            8. Simplified92.2%

              \[\leadsto \color{blue}{\frac{1 + \alpha}{\left(\left(\alpha + 2\right) \cdot \left(\alpha + 2\right)\right) \cdot \left(\alpha + 3\right)}} \]
            9. Taylor expanded in alpha around 0

              \[\leadsto \color{blue}{\frac{1}{12} + \frac{-1}{36} \cdot \alpha} \]
            10. Step-by-step derivation
              1. +-lowering-+.f64N/A

                \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \color{blue}{\left(\frac{-1}{36} \cdot \alpha\right)}\right) \]
              2. *-commutativeN/A

                \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \left(\alpha \cdot \color{blue}{\frac{-1}{36}}\right)\right) \]
              3. *-lowering-*.f6461.1%

                \[\leadsto \mathsf{+.f64}\left(\frac{1}{12}, \mathsf{*.f64}\left(\alpha, \color{blue}{\frac{-1}{36}}\right)\right) \]
            11. Simplified61.1%

              \[\leadsto \color{blue}{0.08333333333333333 + \alpha \cdot -0.027777777777777776} \]

            if 9.5 < beta

            1. Initial program 87.4%

              \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
            2. Step-by-step derivation
              1. associate-/l/N/A

                \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
              2. associate-/l/N/A

                \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
              3. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
              4. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              5. associate-+l+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              6. associate-+l+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              7. associate-+r+N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              8. distribute-lft1-inN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              9. *-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              10. distribute-lft1-inN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              11. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              12. *-lowering-*.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              13. +-commutativeN/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              14. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              15. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
            3. Simplified70.3%

              \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
            4. Add Preprocessing
            5. Step-by-step derivation
              1. times-fracN/A

                \[\leadsto \frac{\alpha + 1}{\left(\alpha + \beta\right) + 2} \cdot \color{blue}{\frac{\beta + 1}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)}} \]
              2. clear-numN/A

                \[\leadsto \frac{\alpha + 1}{\left(\alpha + \beta\right) + 2} \cdot \frac{1}{\color{blue}{\frac{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)}{\beta + 1}}} \]
              3. un-div-invN/A

                \[\leadsto \frac{\frac{\alpha + 1}{\left(\alpha + \beta\right) + 2}}{\color{blue}{\frac{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)}{\beta + 1}}} \]
              4. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\left(\frac{\alpha + 1}{\left(\alpha + \beta\right) + 2}\right), \color{blue}{\left(\frac{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)}{\beta + 1}\right)}\right) \]
              5. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\left(\alpha + 1\right), \left(\left(\alpha + \beta\right) + 2\right)\right), \left(\frac{\color{blue}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)}}{\beta + 1}\right)\right) \]
              6. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\left(\alpha + \beta\right) + 2\right)\right), \left(\frac{\color{blue}{\left(\left(\alpha + \beta\right) + 2\right)} \cdot \left(\left(\alpha + \beta\right) + 3\right)}{\beta + 1}\right)\right) \]
              7. associate-+l+N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\alpha + \left(\beta + 2\right)\right)\right), \left(\frac{\left(\left(\alpha + \beta\right) + 2\right) \cdot \color{blue}{\left(\left(\alpha + \beta\right) + 3\right)}}{\beta + 1}\right)\right) \]
              8. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\alpha, \left(\beta + 2\right)\right)\right), \left(\frac{\left(\left(\alpha + \beta\right) + 2\right) \cdot \color{blue}{\left(\left(\alpha + \beta\right) + 3\right)}}{\beta + 1}\right)\right) \]
              9. +-lowering-+.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\alpha, \mathsf{+.f64}\left(\beta, 2\right)\right)\right), \left(\frac{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + \color{blue}{3}\right)}{\beta + 1}\right)\right) \]
              10. /-lowering-/.f64N/A

                \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\alpha, \mathsf{+.f64}\left(\beta, 2\right)\right)\right), \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right), \color{blue}{\left(\beta + 1\right)}\right)\right) \]
            6. Applied egg-rr91.6%

              \[\leadsto \color{blue}{\frac{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}{\frac{\left(\alpha + \left(\beta + 2\right)\right) \cdot \left(\alpha + \left(\beta + 3\right)\right)}{1 + \beta}}} \]
            7. Taylor expanded in beta around inf

              \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\alpha, \mathsf{+.f64}\left(\beta, 2\right)\right)\right), \color{blue}{\beta}\right) \]
            8. Step-by-step derivation
              1. Simplified83.0%

                \[\leadsto \frac{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}{\color{blue}{\beta}} \]
              2. Taylor expanded in alpha around inf

                \[\leadsto \color{blue}{\frac{1}{\beta}} \]
              3. Step-by-step derivation
                1. /-lowering-/.f646.8%

                  \[\leadsto \mathsf{/.f64}\left(1, \color{blue}{\beta}\right) \]
              4. Simplified6.8%

                \[\leadsto \color{blue}{\frac{1}{\beta}} \]
            9. Recombined 2 regimes into one program.
            10. Add Preprocessing

            Alternative 19: 46.4% accurate, 4.4× speedup?

            \[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 12:\\ \;\;\;\;0.08333333333333333\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\beta}\\ \end{array} \end{array} \]
            NOTE: alpha and beta should be sorted in increasing order before calling this function.
            (FPCore (alpha beta)
             :precision binary64
             (if (<= beta 12.0) 0.08333333333333333 (/ 1.0 beta)))
            assert(alpha < beta);
            double code(double alpha, double beta) {
            	double tmp;
            	if (beta <= 12.0) {
            		tmp = 0.08333333333333333;
            	} else {
            		tmp = 1.0 / beta;
            	}
            	return tmp;
            }
            
            NOTE: alpha and beta should be sorted in increasing order before calling this function.
            real(8) function code(alpha, beta)
                real(8), intent (in) :: alpha
                real(8), intent (in) :: beta
                real(8) :: tmp
                if (beta <= 12.0d0) then
                    tmp = 0.08333333333333333d0
                else
                    tmp = 1.0d0 / beta
                end if
                code = tmp
            end function
            
            assert alpha < beta;
            public static double code(double alpha, double beta) {
            	double tmp;
            	if (beta <= 12.0) {
            		tmp = 0.08333333333333333;
            	} else {
            		tmp = 1.0 / beta;
            	}
            	return tmp;
            }
            
            [alpha, beta] = sort([alpha, beta])
            def code(alpha, beta):
            	tmp = 0
            	if beta <= 12.0:
            		tmp = 0.08333333333333333
            	else:
            		tmp = 1.0 / beta
            	return tmp
            
            alpha, beta = sort([alpha, beta])
            function code(alpha, beta)
            	tmp = 0.0
            	if (beta <= 12.0)
            		tmp = 0.08333333333333333;
            	else
            		tmp = Float64(1.0 / beta);
            	end
            	return tmp
            end
            
            alpha, beta = num2cell(sort([alpha, beta])){:}
            function tmp_2 = code(alpha, beta)
            	tmp = 0.0;
            	if (beta <= 12.0)
            		tmp = 0.08333333333333333;
            	else
            		tmp = 1.0 / beta;
            	end
            	tmp_2 = tmp;
            end
            
            NOTE: alpha and beta should be sorted in increasing order before calling this function.
            code[alpha_, beta_] := If[LessEqual[beta, 12.0], 0.08333333333333333, N[(1.0 / beta), $MachinePrecision]]
            
            \begin{array}{l}
            [alpha, beta] = \mathsf{sort}([alpha, beta])\\
            \\
            \begin{array}{l}
            \mathbf{if}\;\beta \leq 12:\\
            \;\;\;\;0.08333333333333333\\
            
            \mathbf{else}:\\
            \;\;\;\;\frac{1}{\beta}\\
            
            
            \end{array}
            \end{array}
            
            Derivation
            1. Split input into 2 regimes
            2. if beta < 12

              1. Initial program 99.9%

                \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
              2. Step-by-step derivation
                1. associate-/l/N/A

                  \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
                2. associate-/l/N/A

                  \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
                3. /-lowering-/.f64N/A

                  \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
                4. +-commutativeN/A

                  \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                5. associate-+l+N/A

                  \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                6. associate-+l+N/A

                  \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                7. associate-+r+N/A

                  \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                8. distribute-lft1-inN/A

                  \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                9. *-commutativeN/A

                  \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                10. distribute-lft1-inN/A

                  \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                11. +-commutativeN/A

                  \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                12. *-lowering-*.f64N/A

                  \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                13. +-commutativeN/A

                  \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                14. +-lowering-+.f64N/A

                  \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                15. +-lowering-+.f64N/A

                  \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
              3. Simplified93.6%

                \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
              4. Add Preprocessing
              5. Taylor expanded in alpha around 0

                \[\leadsto \color{blue}{\frac{1 + \beta}{{\left(2 + \beta\right)}^{2} \cdot \left(3 + \beta\right)}} \]
              6. Step-by-step derivation
                1. /-lowering-/.f64N/A

                  \[\leadsto \mathsf{/.f64}\left(\left(1 + \beta\right), \color{blue}{\left({\left(2 + \beta\right)}^{2} \cdot \left(3 + \beta\right)\right)}\right) \]
                2. +-lowering-+.f64N/A

                  \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \beta\right), \left(\color{blue}{{\left(2 + \beta\right)}^{2}} \cdot \left(3 + \beta\right)\right)\right) \]
                3. *-lowering-*.f64N/A

                  \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \beta\right), \mathsf{*.f64}\left(\left({\left(2 + \beta\right)}^{2}\right), \color{blue}{\left(3 + \beta\right)}\right)\right) \]
                4. unpow2N/A

                  \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \beta\right), \mathsf{*.f64}\left(\left(\left(2 + \beta\right) \cdot \left(2 + \beta\right)\right), \left(\color{blue}{3} + \beta\right)\right)\right) \]
                5. *-lowering-*.f64N/A

                  \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \beta\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(2 + \beta\right), \left(2 + \beta\right)\right), \left(\color{blue}{3} + \beta\right)\right)\right) \]
                6. +-commutativeN/A

                  \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \beta\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(\beta + 2\right), \left(2 + \beta\right)\right), \left(3 + \beta\right)\right)\right) \]
                7. +-lowering-+.f64N/A

                  \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \beta\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\beta, 2\right), \left(2 + \beta\right)\right), \left(3 + \beta\right)\right)\right) \]
                8. +-commutativeN/A

                  \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \beta\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\beta, 2\right), \left(\beta + 2\right)\right), \left(3 + \beta\right)\right)\right) \]
                9. +-lowering-+.f64N/A

                  \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \beta\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\beta, 2\right), \mathsf{+.f64}\left(\beta, 2\right)\right), \left(3 + \beta\right)\right)\right) \]
                10. +-commutativeN/A

                  \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \beta\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\beta, 2\right), \mathsf{+.f64}\left(\beta, 2\right)\right), \left(\beta + \color{blue}{3}\right)\right)\right) \]
                11. +-lowering-+.f6462.5%

                  \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \beta\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\beta, 2\right), \mathsf{+.f64}\left(\beta, 2\right)\right), \mathsf{+.f64}\left(\beta, \color{blue}{3}\right)\right)\right) \]
              7. Simplified62.5%

                \[\leadsto \color{blue}{\frac{1 + \beta}{\left(\left(\beta + 2\right) \cdot \left(\beta + 2\right)\right) \cdot \left(\beta + 3\right)}} \]
              8. Taylor expanded in beta around 0

                \[\leadsto \color{blue}{\frac{1}{12}} \]
              9. Step-by-step derivation
                1. Simplified61.2%

                  \[\leadsto \color{blue}{0.08333333333333333} \]

                if 12 < beta

                1. Initial program 87.4%

                  \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
                2. Step-by-step derivation
                  1. associate-/l/N/A

                    \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
                  2. associate-/l/N/A

                    \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
                  3. /-lowering-/.f64N/A

                    \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
                  4. +-commutativeN/A

                    \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                  5. associate-+l+N/A

                    \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                  6. associate-+l+N/A

                    \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                  7. associate-+r+N/A

                    \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                  8. distribute-lft1-inN/A

                    \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                  9. *-commutativeN/A

                    \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                  10. distribute-lft1-inN/A

                    \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                  11. +-commutativeN/A

                    \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                  12. *-lowering-*.f64N/A

                    \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                  13. +-commutativeN/A

                    \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                  14. +-lowering-+.f64N/A

                    \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                  15. +-lowering-+.f64N/A

                    \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                3. Simplified70.3%

                  \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
                4. Add Preprocessing
                5. Step-by-step derivation
                  1. times-fracN/A

                    \[\leadsto \frac{\alpha + 1}{\left(\alpha + \beta\right) + 2} \cdot \color{blue}{\frac{\beta + 1}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)}} \]
                  2. clear-numN/A

                    \[\leadsto \frac{\alpha + 1}{\left(\alpha + \beta\right) + 2} \cdot \frac{1}{\color{blue}{\frac{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)}{\beta + 1}}} \]
                  3. un-div-invN/A

                    \[\leadsto \frac{\frac{\alpha + 1}{\left(\alpha + \beta\right) + 2}}{\color{blue}{\frac{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)}{\beta + 1}}} \]
                  4. /-lowering-/.f64N/A

                    \[\leadsto \mathsf{/.f64}\left(\left(\frac{\alpha + 1}{\left(\alpha + \beta\right) + 2}\right), \color{blue}{\left(\frac{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)}{\beta + 1}\right)}\right) \]
                  5. /-lowering-/.f64N/A

                    \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\left(\alpha + 1\right), \left(\left(\alpha + \beta\right) + 2\right)\right), \left(\frac{\color{blue}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)}}{\beta + 1}\right)\right) \]
                  6. +-lowering-+.f64N/A

                    \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\left(\alpha + \beta\right) + 2\right)\right), \left(\frac{\color{blue}{\left(\left(\alpha + \beta\right) + 2\right)} \cdot \left(\left(\alpha + \beta\right) + 3\right)}{\beta + 1}\right)\right) \]
                  7. associate-+l+N/A

                    \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\alpha + \left(\beta + 2\right)\right)\right), \left(\frac{\left(\left(\alpha + \beta\right) + 2\right) \cdot \color{blue}{\left(\left(\alpha + \beta\right) + 3\right)}}{\beta + 1}\right)\right) \]
                  8. +-lowering-+.f64N/A

                    \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\alpha, \left(\beta + 2\right)\right)\right), \left(\frac{\left(\left(\alpha + \beta\right) + 2\right) \cdot \color{blue}{\left(\left(\alpha + \beta\right) + 3\right)}}{\beta + 1}\right)\right) \]
                  9. +-lowering-+.f64N/A

                    \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\alpha, \mathsf{+.f64}\left(\beta, 2\right)\right)\right), \left(\frac{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + \color{blue}{3}\right)}{\beta + 1}\right)\right) \]
                  10. /-lowering-/.f64N/A

                    \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\alpha, \mathsf{+.f64}\left(\beta, 2\right)\right)\right), \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right), \color{blue}{\left(\beta + 1\right)}\right)\right) \]
                6. Applied egg-rr91.6%

                  \[\leadsto \color{blue}{\frac{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}{\frac{\left(\alpha + \left(\beta + 2\right)\right) \cdot \left(\alpha + \left(\beta + 3\right)\right)}{1 + \beta}}} \]
                7. Taylor expanded in beta around inf

                  \[\leadsto \mathsf{/.f64}\left(\mathsf{/.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\alpha, \mathsf{+.f64}\left(\beta, 2\right)\right)\right), \color{blue}{\beta}\right) \]
                8. Step-by-step derivation
                  1. Simplified83.0%

                    \[\leadsto \frac{\frac{\alpha + 1}{\alpha + \left(\beta + 2\right)}}{\color{blue}{\beta}} \]
                  2. Taylor expanded in alpha around inf

                    \[\leadsto \color{blue}{\frac{1}{\beta}} \]
                  3. Step-by-step derivation
                    1. /-lowering-/.f646.8%

                      \[\leadsto \mathsf{/.f64}\left(1, \color{blue}{\beta}\right) \]
                  4. Simplified6.8%

                    \[\leadsto \color{blue}{\frac{1}{\beta}} \]
                9. Recombined 2 regimes into one program.
                10. Add Preprocessing

                Alternative 20: 44.7% accurate, 35.0× speedup?

                \[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ 0.08333333333333333 \end{array} \]
                NOTE: alpha and beta should be sorted in increasing order before calling this function.
                (FPCore (alpha beta) :precision binary64 0.08333333333333333)
                assert(alpha < beta);
                double code(double alpha, double beta) {
                	return 0.08333333333333333;
                }
                
                NOTE: alpha and beta should be sorted in increasing order before calling this function.
                real(8) function code(alpha, beta)
                    real(8), intent (in) :: alpha
                    real(8), intent (in) :: beta
                    code = 0.08333333333333333d0
                end function
                
                assert alpha < beta;
                public static double code(double alpha, double beta) {
                	return 0.08333333333333333;
                }
                
                [alpha, beta] = sort([alpha, beta])
                def code(alpha, beta):
                	return 0.08333333333333333
                
                alpha, beta = sort([alpha, beta])
                function code(alpha, beta)
                	return 0.08333333333333333
                end
                
                alpha, beta = num2cell(sort([alpha, beta])){:}
                function tmp = code(alpha, beta)
                	tmp = 0.08333333333333333;
                end
                
                NOTE: alpha and beta should be sorted in increasing order before calling this function.
                code[alpha_, beta_] := 0.08333333333333333
                
                \begin{array}{l}
                [alpha, beta] = \mathsf{sort}([alpha, beta])\\
                \\
                0.08333333333333333
                \end{array}
                
                Derivation
                1. Initial program 95.2%

                  \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
                2. Step-by-step derivation
                  1. associate-/l/N/A

                    \[\leadsto \frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1} \]
                  2. associate-/l/N/A

                    \[\leadsto \frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1}{\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)}} \]
                  3. /-lowering-/.f64N/A

                    \[\leadsto \mathsf{/.f64}\left(\left(\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1\right), \color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)}\right) \]
                  4. +-commutativeN/A

                    \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \left(\alpha + \beta\right)\right) + 1\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                  5. associate-+l+N/A

                    \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\left(\alpha + \beta\right) + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                  6. associate-+l+N/A

                    \[\leadsto \mathsf{/.f64}\left(\left(\beta \cdot \alpha + \left(\alpha + \left(\beta + 1\right)\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                  7. associate-+r+N/A

                    \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta \cdot \alpha + \alpha\right) + \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                  8. distribute-lft1-inN/A

                    \[\leadsto \mathsf{/.f64}\left(\left(\left(\beta + 1\right) \cdot \alpha + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                  9. *-commutativeN/A

                    \[\leadsto \mathsf{/.f64}\left(\left(\alpha \cdot \left(\beta + 1\right) + \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                  10. distribute-lft1-inN/A

                    \[\leadsto \mathsf{/.f64}\left(\left(\left(\alpha + 1\right) \cdot \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                  11. +-commutativeN/A

                    \[\leadsto \mathsf{/.f64}\left(\left(\left(1 + \alpha\right) \cdot \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                  12. *-lowering-*.f64N/A

                    \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(1 + \alpha\right), \left(\beta + 1\right)\right), \left(\color{blue}{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)} \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                  13. +-commutativeN/A

                    \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\left(\alpha + 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                  14. +-lowering-+.f64N/A

                    \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \left(\beta + 1\right)\right), \left(\left(\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right)} + 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                  15. +-lowering-+.f64N/A

                    \[\leadsto \mathsf{/.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\alpha, 1\right), \mathsf{+.f64}\left(\beta, 1\right)\right), \left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + \color{blue}{1}\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right)\right)\right) \]
                3. Simplified84.9%

                  \[\leadsto \color{blue}{\frac{\left(\alpha + 1\right) \cdot \left(\beta + 1\right)}{\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2\right) \cdot \left(\left(\alpha + \beta\right) + 3\right)\right)}} \]
                4. Add Preprocessing
                5. Taylor expanded in alpha around 0

                  \[\leadsto \color{blue}{\frac{1 + \beta}{{\left(2 + \beta\right)}^{2} \cdot \left(3 + \beta\right)}} \]
                6. Step-by-step derivation
                  1. /-lowering-/.f64N/A

                    \[\leadsto \mathsf{/.f64}\left(\left(1 + \beta\right), \color{blue}{\left({\left(2 + \beta\right)}^{2} \cdot \left(3 + \beta\right)\right)}\right) \]
                  2. +-lowering-+.f64N/A

                    \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \beta\right), \left(\color{blue}{{\left(2 + \beta\right)}^{2}} \cdot \left(3 + \beta\right)\right)\right) \]
                  3. *-lowering-*.f64N/A

                    \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \beta\right), \mathsf{*.f64}\left(\left({\left(2 + \beta\right)}^{2}\right), \color{blue}{\left(3 + \beta\right)}\right)\right) \]
                  4. unpow2N/A

                    \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \beta\right), \mathsf{*.f64}\left(\left(\left(2 + \beta\right) \cdot \left(2 + \beta\right)\right), \left(\color{blue}{3} + \beta\right)\right)\right) \]
                  5. *-lowering-*.f64N/A

                    \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \beta\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(2 + \beta\right), \left(2 + \beta\right)\right), \left(\color{blue}{3} + \beta\right)\right)\right) \]
                  6. +-commutativeN/A

                    \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \beta\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\left(\beta + 2\right), \left(2 + \beta\right)\right), \left(3 + \beta\right)\right)\right) \]
                  7. +-lowering-+.f64N/A

                    \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \beta\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\beta, 2\right), \left(2 + \beta\right)\right), \left(3 + \beta\right)\right)\right) \]
                  8. +-commutativeN/A

                    \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \beta\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\beta, 2\right), \left(\beta + 2\right)\right), \left(3 + \beta\right)\right)\right) \]
                  9. +-lowering-+.f64N/A

                    \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \beta\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\beta, 2\right), \mathsf{+.f64}\left(\beta, 2\right)\right), \left(3 + \beta\right)\right)\right) \]
                  10. +-commutativeN/A

                    \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \beta\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\beta, 2\right), \mathsf{+.f64}\left(\beta, 2\right)\right), \left(\beta + \color{blue}{3}\right)\right)\right) \]
                  11. +-lowering-+.f6464.3%

                    \[\leadsto \mathsf{/.f64}\left(\mathsf{+.f64}\left(1, \beta\right), \mathsf{*.f64}\left(\mathsf{*.f64}\left(\mathsf{+.f64}\left(\beta, 2\right), \mathsf{+.f64}\left(\beta, 2\right)\right), \mathsf{+.f64}\left(\beta, \color{blue}{3}\right)\right)\right) \]
                7. Simplified64.3%

                  \[\leadsto \color{blue}{\frac{1 + \beta}{\left(\left(\beta + 2\right) \cdot \left(\beta + 2\right)\right) \cdot \left(\beta + 3\right)}} \]
                8. Taylor expanded in beta around 0

                  \[\leadsto \color{blue}{\frac{1}{12}} \]
                9. Step-by-step derivation
                  1. Simplified40.0%

                    \[\leadsto \color{blue}{0.08333333333333333} \]
                  2. Add Preprocessing

                  Reproduce

                  ?
                  herbie shell --seed 2024159 
                  (FPCore (alpha beta)
                    :name "Octave 3.8, jcobi/3"
                    :precision binary64
                    :pre (and (> alpha -1.0) (> beta -1.0))
                    (/ (/ (/ (+ (+ (+ alpha beta) (* beta alpha)) 1.0) (+ (+ alpha beta) (* 2.0 1.0))) (+ (+ alpha beta) (* 2.0 1.0))) (+ (+ (+ alpha beta) (* 2.0 1.0)) 1.0)))