Octave 3.8, jcobi/3

Percentage Accurate: 94.4% → 99.3%
Time: 13.7s
Alternatives: 21
Speedup: 3.1×

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 21 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.4% 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.3% accurate, 1.3× speedup?

\[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} t_0 := \alpha + \left(\beta + 2\right)\\ \mathbf{if}\;\beta \leq 1.2 \cdot 10^{+17}:\\ \;\;\;\;\frac{\frac{\alpha + \mathsf{fma}\left(\alpha + 1, \beta, 1\right)}{t\_0}}{t\_0 \cdot \left(\alpha + \left(\beta + 3\right)\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{\alpha + 1}{\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
 (let* ((t_0 (+ alpha (+ beta 2.0))))
   (if (<= beta 1.2e+17)
     (/
      (/ (+ alpha (fma (+ alpha 1.0) beta 1.0)) t_0)
      (* t_0 (+ alpha (+ beta 3.0))))
     (/ (/ (+ alpha 1.0) beta) beta))))
assert(alpha < beta);
double code(double alpha, double beta) {
	double t_0 = alpha + (beta + 2.0);
	double tmp;
	if (beta <= 1.2e+17) {
		tmp = ((alpha + fma((alpha + 1.0), beta, 1.0)) / t_0) / (t_0 * (alpha + (beta + 3.0)));
	} else {
		tmp = ((alpha + 1.0) / beta) / 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 <= 1.2e+17)
		tmp = Float64(Float64(Float64(alpha + fma(Float64(alpha + 1.0), beta, 1.0)) / t_0) / Float64(t_0 * Float64(alpha + Float64(beta + 3.0))));
	else
		tmp = Float64(Float64(Float64(alpha + 1.0) / beta) / beta);
	end
	return 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, 1.2e+17], N[(N[(N[(alpha + N[(N[(alpha + 1.0), $MachinePrecision] * beta + 1.0), $MachinePrecision]), $MachinePrecision] / t$95$0), $MachinePrecision] / N[(t$95$0 * N[(alpha + N[(beta + 3.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(N[(alpha + 1.0), $MachinePrecision] / beta), $MachinePrecision] / beta), $MachinePrecision]]]
\begin{array}{l}
[alpha, beta] = \mathsf{sort}([alpha, beta])\\
\\
\begin{array}{l}
t_0 := \alpha + \left(\beta + 2\right)\\
\mathbf{if}\;\beta \leq 1.2 \cdot 10^{+17}:\\
\;\;\;\;\frac{\frac{\alpha + \mathsf{fma}\left(\alpha + 1, \beta, 1\right)}{t\_0}}{t\_0 \cdot \left(\alpha + \left(\beta + 3\right)\right)}\\

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


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

    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. Step-by-step derivation
      1. associate-/l/N/A

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

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

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

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

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

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

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

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

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

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

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

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

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

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

        \[\leadsto \frac{\frac{\alpha + \mathsf{fma}\left(\alpha + 1, \beta, 1\right)}{\alpha + \left(\beta + 2\right)}}{\color{blue}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) \cdot \left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)}} \]
    4. Applied egg-rr98.6%

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

    if 1.2e17 < beta

    1. Initial program 87.0%

      \[\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 \color{blue}{\frac{1 + \alpha}{{\beta}^{2}}} \]
    4. Step-by-step derivation
      1. /-lowering-/.f64N/A

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

        \[\leadsto \frac{\color{blue}{1 + \alpha}}{{\beta}^{2}} \]
      3. unpow2N/A

        \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
      4. *-lowering-*.f6479.6

        \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
    5. Simplified79.6%

      \[\leadsto \color{blue}{\frac{1 + \alpha}{\beta \cdot \beta}} \]
    6. Step-by-step derivation
      1. associate-/r*N/A

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

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

        \[\leadsto \frac{\color{blue}{\frac{1 + \alpha}{\beta}}}{\beta} \]
      4. +-lowering-+.f6485.0

        \[\leadsto \frac{\frac{\color{blue}{1 + \alpha}}{\beta}}{\beta} \]
    7. Applied egg-rr85.0%

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

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

Alternative 2: 99.4% accurate, 1.4× speedup?

\[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} t_0 := \alpha + \left(\beta + 2\right)\\ \mathbf{if}\;\beta \leq 2 \cdot 10^{+85}:\\ \;\;\;\;\frac{\alpha + \mathsf{fma}\left(\alpha + 1, \beta, 1\right)}{t\_0 \cdot \left(t\_0 \cdot \left(\alpha + \left(\beta + 3\right)\right)\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{\alpha + 1}{\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
 (let* ((t_0 (+ alpha (+ beta 2.0))))
   (if (<= beta 2e+85)
     (/
      (+ alpha (fma (+ alpha 1.0) beta 1.0))
      (* t_0 (* t_0 (+ alpha (+ beta 3.0)))))
     (/ (/ (+ alpha 1.0) beta) beta))))
assert(alpha < beta);
double code(double alpha, double beta) {
	double t_0 = alpha + (beta + 2.0);
	double tmp;
	if (beta <= 2e+85) {
		tmp = (alpha + fma((alpha + 1.0), beta, 1.0)) / (t_0 * (t_0 * (alpha + (beta + 3.0))));
	} else {
		tmp = ((alpha + 1.0) / beta) / 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 <= 2e+85)
		tmp = Float64(Float64(alpha + fma(Float64(alpha + 1.0), beta, 1.0)) / Float64(t_0 * Float64(t_0 * Float64(alpha + Float64(beta + 3.0)))));
	else
		tmp = Float64(Float64(Float64(alpha + 1.0) / beta) / beta);
	end
	return 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, 2e+85], N[(N[(alpha + N[(N[(alpha + 1.0), $MachinePrecision] * beta + 1.0), $MachinePrecision]), $MachinePrecision] / N[(t$95$0 * N[(t$95$0 * N[(alpha + N[(beta + 3.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(N[(alpha + 1.0), $MachinePrecision] / beta), $MachinePrecision] / beta), $MachinePrecision]]]
\begin{array}{l}
[alpha, beta] = \mathsf{sort}([alpha, beta])\\
\\
\begin{array}{l}
t_0 := \alpha + \left(\beta + 2\right)\\
\mathbf{if}\;\beta \leq 2 \cdot 10^{+85}:\\
\;\;\;\;\frac{\alpha + \mathsf{fma}\left(\alpha + 1, \beta, 1\right)}{t\_0 \cdot \left(t\_0 \cdot \left(\alpha + \left(\beta + 3\right)\right)\right)}\\

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


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

    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. Add Preprocessing
    3. Step-by-step derivation
      1. associate-/l/N/A

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

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

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

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

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

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

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

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

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

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

        \[\leadsto \frac{\alpha + \mathsf{fma}\left(\alpha + 1, \beta, 1\right)}{\color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot 1\right)}} \]
    4. Applied egg-rr91.5%

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

    if 2e85 < beta

    1. Initial program 83.3%

      \[\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 \color{blue}{\frac{1 + \alpha}{{\beta}^{2}}} \]
    4. Step-by-step derivation
      1. /-lowering-/.f64N/A

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

        \[\leadsto \frac{\color{blue}{1 + \alpha}}{{\beta}^{2}} \]
      3. unpow2N/A

        \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
      4. *-lowering-*.f6481.1

        \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
    5. Simplified81.1%

      \[\leadsto \color{blue}{\frac{1 + \alpha}{\beta \cdot \beta}} \]
    6. Step-by-step derivation
      1. associate-/r*N/A

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

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

        \[\leadsto \frac{\color{blue}{\frac{1 + \alpha}{\beta}}}{\beta} \]
      4. +-lowering-+.f6488.2

        \[\leadsto \frac{\frac{\color{blue}{1 + \alpha}}{\beta}}{\beta} \]
    7. Applied egg-rr88.2%

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

    \[\leadsto \begin{array}{l} \mathbf{if}\;\beta \leq 2 \cdot 10^{+85}:\\ \;\;\;\;\frac{\alpha + \mathsf{fma}\left(\alpha + 1, \beta, 1\right)}{\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)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{\alpha + 1}{\beta}}{\beta}\\ \end{array} \]
  5. Add Preprocessing

Alternative 3: 98.8% accurate, 1.7× speedup?

\[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 4 \cdot 10^{+16}:\\ \;\;\;\;\frac{\frac{\beta + 1}{\beta + 2}}{\left(\beta + 2\right) \cdot \left(\alpha + \left(\beta + 3\right)\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{\alpha + 1}{\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 4e+16)
   (/ (/ (+ beta 1.0) (+ beta 2.0)) (* (+ beta 2.0) (+ alpha (+ beta 3.0))))
   (/ (/ (+ alpha 1.0) beta) beta)))
assert(alpha < beta);
double code(double alpha, double beta) {
	double tmp;
	if (beta <= 4e+16) {
		tmp = ((beta + 1.0) / (beta + 2.0)) / ((beta + 2.0) * (alpha + (beta + 3.0)));
	} else {
		tmp = ((alpha + 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 <= 4d+16) then
        tmp = ((beta + 1.0d0) / (beta + 2.0d0)) / ((beta + 2.0d0) * (alpha + (beta + 3.0d0)))
    else
        tmp = ((alpha + 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 <= 4e+16) {
		tmp = ((beta + 1.0) / (beta + 2.0)) / ((beta + 2.0) * (alpha + (beta + 3.0)));
	} else {
		tmp = ((alpha + 1.0) / beta) / beta;
	}
	return tmp;
}
[alpha, beta] = sort([alpha, beta])
def code(alpha, beta):
	tmp = 0
	if beta <= 4e+16:
		tmp = ((beta + 1.0) / (beta + 2.0)) / ((beta + 2.0) * (alpha + (beta + 3.0)))
	else:
		tmp = ((alpha + 1.0) / beta) / beta
	return tmp
alpha, beta = sort([alpha, beta])
function code(alpha, beta)
	tmp = 0.0
	if (beta <= 4e+16)
		tmp = Float64(Float64(Float64(beta + 1.0) / Float64(beta + 2.0)) / Float64(Float64(beta + 2.0) * Float64(alpha + Float64(beta + 3.0))));
	else
		tmp = Float64(Float64(Float64(alpha + 1.0) / beta) / beta);
	end
	return tmp
end
alpha, beta = num2cell(sort([alpha, beta])){:}
function tmp_2 = code(alpha, beta)
	tmp = 0.0;
	if (beta <= 4e+16)
		tmp = ((beta + 1.0) / (beta + 2.0)) / ((beta + 2.0) * (alpha + (beta + 3.0)));
	else
		tmp = ((alpha + 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, 4e+16], N[(N[(N[(beta + 1.0), $MachinePrecision] / N[(beta + 2.0), $MachinePrecision]), $MachinePrecision] / N[(N[(beta + 2.0), $MachinePrecision] * N[(alpha + N[(beta + 3.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(N[(alpha + 1.0), $MachinePrecision] / beta), $MachinePrecision] / beta), $MachinePrecision]]
\begin{array}{l}
[alpha, beta] = \mathsf{sort}([alpha, beta])\\
\\
\begin{array}{l}
\mathbf{if}\;\beta \leq 4 \cdot 10^{+16}:\\
\;\;\;\;\frac{\frac{\beta + 1}{\beta + 2}}{\left(\beta + 2\right) \cdot \left(\alpha + \left(\beta + 3\right)\right)}\\

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


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

    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 alpha around 0

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

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

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

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

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

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

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

        \[\leadsto \frac{\frac{1 + \beta}{\left(\beta + 2\right) \cdot \color{blue}{\left(\beta + 2\right)}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
      8. +-lowering-+.f6466.1

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    if 4e16 < beta

    1. Initial program 87.0%

      \[\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 \color{blue}{\frac{1 + \alpha}{{\beta}^{2}}} \]
    4. Step-by-step derivation
      1. /-lowering-/.f64N/A

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

        \[\leadsto \frac{\color{blue}{1 + \alpha}}{{\beta}^{2}} \]
      3. unpow2N/A

        \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
      4. *-lowering-*.f6479.6

        \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
    5. Simplified79.6%

      \[\leadsto \color{blue}{\frac{1 + \alpha}{\beta \cdot \beta}} \]
    6. Step-by-step derivation
      1. associate-/r*N/A

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

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

        \[\leadsto \frac{\color{blue}{\frac{1 + \alpha}{\beta}}}{\beta} \]
      4. +-lowering-+.f6485.0

        \[\leadsto \frac{\frac{\color{blue}{1 + \alpha}}{\beta}}{\beta} \]
    7. Applied egg-rr85.0%

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

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

Alternative 4: 98.8% accurate, 1.7× speedup?

\[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 2.4 \cdot 10^{+16}:\\ \;\;\;\;\left(\beta + 1\right) \cdot \frac{1}{\left(\alpha + \left(\beta + 3\right)\right) \cdot \left(\left(\beta + 2\right) \cdot \left(\beta + 2\right)\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{\alpha + 1}{\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.4e+16)
   (*
    (+ beta 1.0)
    (/ 1.0 (* (+ alpha (+ beta 3.0)) (* (+ beta 2.0) (+ beta 2.0)))))
   (/ (/ (+ alpha 1.0) beta) beta)))
assert(alpha < beta);
double code(double alpha, double beta) {
	double tmp;
	if (beta <= 2.4e+16) {
		tmp = (beta + 1.0) * (1.0 / ((alpha + (beta + 3.0)) * ((beta + 2.0) * (beta + 2.0))));
	} else {
		tmp = ((alpha + 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 <= 2.4d+16) then
        tmp = (beta + 1.0d0) * (1.0d0 / ((alpha + (beta + 3.0d0)) * ((beta + 2.0d0) * (beta + 2.0d0))))
    else
        tmp = ((alpha + 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 <= 2.4e+16) {
		tmp = (beta + 1.0) * (1.0 / ((alpha + (beta + 3.0)) * ((beta + 2.0) * (beta + 2.0))));
	} else {
		tmp = ((alpha + 1.0) / beta) / beta;
	}
	return tmp;
}
[alpha, beta] = sort([alpha, beta])
def code(alpha, beta):
	tmp = 0
	if beta <= 2.4e+16:
		tmp = (beta + 1.0) * (1.0 / ((alpha + (beta + 3.0)) * ((beta + 2.0) * (beta + 2.0))))
	else:
		tmp = ((alpha + 1.0) / beta) / beta
	return tmp
alpha, beta = sort([alpha, beta])
function code(alpha, beta)
	tmp = 0.0
	if (beta <= 2.4e+16)
		tmp = Float64(Float64(beta + 1.0) * Float64(1.0 / Float64(Float64(alpha + Float64(beta + 3.0)) * Float64(Float64(beta + 2.0) * Float64(beta + 2.0)))));
	else
		tmp = Float64(Float64(Float64(alpha + 1.0) / beta) / beta);
	end
	return tmp
end
alpha, beta = num2cell(sort([alpha, beta])){:}
function tmp_2 = code(alpha, beta)
	tmp = 0.0;
	if (beta <= 2.4e+16)
		tmp = (beta + 1.0) * (1.0 / ((alpha + (beta + 3.0)) * ((beta + 2.0) * (beta + 2.0))));
	else
		tmp = ((alpha + 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, 2.4e+16], N[(N[(beta + 1.0), $MachinePrecision] * N[(1.0 / N[(N[(alpha + N[(beta + 3.0), $MachinePrecision]), $MachinePrecision] * N[(N[(beta + 2.0), $MachinePrecision] * N[(beta + 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(N[(alpha + 1.0), $MachinePrecision] / beta), $MachinePrecision] / beta), $MachinePrecision]]
\begin{array}{l}
[alpha, beta] = \mathsf{sort}([alpha, beta])\\
\\
\begin{array}{l}
\mathbf{if}\;\beta \leq 2.4 \cdot 10^{+16}:\\
\;\;\;\;\left(\beta + 1\right) \cdot \frac{1}{\left(\alpha + \left(\beta + 3\right)\right) \cdot \left(\left(\beta + 2\right) \cdot \left(\beta + 2\right)\right)}\\

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


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

    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 alpha around 0

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

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

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

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

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

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

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

        \[\leadsto \frac{\frac{1 + \beta}{\left(\beta + 2\right) \cdot \color{blue}{\left(\beta + 2\right)}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
      8. +-lowering-+.f6466.1

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

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

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

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

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

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

        \[\leadsto \color{blue}{\left(1 + \beta\right)} \cdot \left(\frac{1}{\left(\beta + 2\right) \cdot \left(\beta + 2\right)} \cdot \frac{1}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1}\right) \]
      6. inv-powN/A

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

        \[\leadsto \left(1 + \beta\right) \cdot \left({\left(\left(\beta + 2\right) \cdot \left(\beta + 2\right)\right)}^{-1} \cdot \color{blue}{{\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right)}^{-1}}\right) \]
      8. pow-prod-downN/A

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

        \[\leadsto \left(1 + \beta\right) \cdot {\color{blue}{\left(\left(\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1\right) \cdot \left(\left(\beta + 2\right) \cdot \left(\beta + 2\right)\right)\right)}}^{-1} \]
      10. inv-powN/A

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

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

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

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

    if 2.4e16 < beta

    1. Initial program 87.0%

      \[\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 \color{blue}{\frac{1 + \alpha}{{\beta}^{2}}} \]
    4. Step-by-step derivation
      1. /-lowering-/.f64N/A

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

        \[\leadsto \frac{\color{blue}{1 + \alpha}}{{\beta}^{2}} \]
      3. unpow2N/A

        \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
      4. *-lowering-*.f6479.6

        \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
    5. Simplified79.6%

      \[\leadsto \color{blue}{\frac{1 + \alpha}{\beta \cdot \beta}} \]
    6. Step-by-step derivation
      1. associate-/r*N/A

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

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

        \[\leadsto \frac{\color{blue}{\frac{1 + \alpha}{\beta}}}{\beta} \]
      4. +-lowering-+.f6485.0

        \[\leadsto \frac{\frac{\color{blue}{1 + \alpha}}{\beta}}{\beta} \]
    7. Applied egg-rr85.0%

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

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

Alternative 5: 98.4% accurate, 1.9× speedup?

\[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 8.8 \cdot 10^{+16}:\\ \;\;\;\;\frac{\frac{\beta + 1}{\beta + 2}}{\mathsf{fma}\left(\beta, \beta + 5, 6\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{\alpha + 1}{\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 8.8e+16)
   (/ (/ (+ beta 1.0) (+ beta 2.0)) (fma beta (+ beta 5.0) 6.0))
   (/ (/ (+ alpha 1.0) beta) beta)))
assert(alpha < beta);
double code(double alpha, double beta) {
	double tmp;
	if (beta <= 8.8e+16) {
		tmp = ((beta + 1.0) / (beta + 2.0)) / fma(beta, (beta + 5.0), 6.0);
	} else {
		tmp = ((alpha + 1.0) / beta) / beta;
	}
	return tmp;
}
alpha, beta = sort([alpha, beta])
function code(alpha, beta)
	tmp = 0.0
	if (beta <= 8.8e+16)
		tmp = Float64(Float64(Float64(beta + 1.0) / Float64(beta + 2.0)) / fma(beta, Float64(beta + 5.0), 6.0));
	else
		tmp = Float64(Float64(Float64(alpha + 1.0) / beta) / beta);
	end
	return tmp
end
NOTE: alpha and beta should be sorted in increasing order before calling this function.
code[alpha_, beta_] := If[LessEqual[beta, 8.8e+16], N[(N[(N[(beta + 1.0), $MachinePrecision] / N[(beta + 2.0), $MachinePrecision]), $MachinePrecision] / N[(beta * N[(beta + 5.0), $MachinePrecision] + 6.0), $MachinePrecision]), $MachinePrecision], N[(N[(N[(alpha + 1.0), $MachinePrecision] / beta), $MachinePrecision] / beta), $MachinePrecision]]
\begin{array}{l}
[alpha, beta] = \mathsf{sort}([alpha, beta])\\
\\
\begin{array}{l}
\mathbf{if}\;\beta \leq 8.8 \cdot 10^{+16}:\\
\;\;\;\;\frac{\frac{\beta + 1}{\beta + 2}}{\mathsf{fma}\left(\beta, \beta + 5, 6\right)}\\

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


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

    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 alpha around 0

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

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

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

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

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

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

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

        \[\leadsto \frac{\frac{1 + \beta}{\left(\beta + 2\right) \cdot \color{blue}{\left(\beta + 2\right)}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
      8. +-lowering-+.f6466.1

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

        \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\left(\beta + 2\right) \cdot \color{blue}{\left(3 + \beta\right)}} \]
    10. Simplified64.3%

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

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

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

        \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\beta \cdot \left(\color{blue}{5 \cdot 1} + \beta\right) + 6} \]
      3. lft-mult-inverseN/A

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

        \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\beta \cdot \left(\color{blue}{\left(5 \cdot \frac{1}{\beta}\right) \cdot \beta} + \beta\right) + 6} \]
      5. *-lft-identityN/A

        \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\beta \cdot \left(\left(5 \cdot \frac{1}{\beta}\right) \cdot \beta + \color{blue}{1 \cdot \beta}\right) + 6} \]
      6. distribute-rgt-inN/A

        \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\beta \cdot \color{blue}{\left(\beta \cdot \left(5 \cdot \frac{1}{\beta} + 1\right)\right)} + 6} \]
      7. +-commutativeN/A

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

        \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\beta \cdot \color{blue}{\left(\left(1 + 5 \cdot \frac{1}{\beta}\right) \cdot \beta\right)} + 6} \]
      9. accelerator-lowering-fma.f64N/A

        \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\color{blue}{\mathsf{fma}\left(\beta, \left(1 + 5 \cdot \frac{1}{\beta}\right) \cdot \beta, 6\right)}} \]
      10. *-commutativeN/A

        \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\mathsf{fma}\left(\beta, \color{blue}{\beta \cdot \left(1 + 5 \cdot \frac{1}{\beta}\right)}, 6\right)} \]
      11. distribute-rgt-inN/A

        \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\mathsf{fma}\left(\beta, \color{blue}{1 \cdot \beta + \left(5 \cdot \frac{1}{\beta}\right) \cdot \beta}, 6\right)} \]
      12. *-lft-identityN/A

        \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\mathsf{fma}\left(\beta, \color{blue}{\beta} + \left(5 \cdot \frac{1}{\beta}\right) \cdot \beta, 6\right)} \]
      13. associate-*l*N/A

        \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\mathsf{fma}\left(\beta, \beta + \color{blue}{5 \cdot \left(\frac{1}{\beta} \cdot \beta\right)}, 6\right)} \]
      14. lft-mult-inverseN/A

        \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\mathsf{fma}\left(\beta, \beta + 5 \cdot \color{blue}{1}, 6\right)} \]
      15. metadata-evalN/A

        \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\mathsf{fma}\left(\beta, \beta + \color{blue}{5}, 6\right)} \]
      16. +-lowering-+.f6464.3

        \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\mathsf{fma}\left(\beta, \color{blue}{\beta + 5}, 6\right)} \]
    13. Simplified64.3%

      \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\color{blue}{\mathsf{fma}\left(\beta, \beta + 5, 6\right)}} \]

    if 8.8e16 < beta

    1. Initial program 87.0%

      \[\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 \color{blue}{\frac{1 + \alpha}{{\beta}^{2}}} \]
    4. Step-by-step derivation
      1. /-lowering-/.f64N/A

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

        \[\leadsto \frac{\color{blue}{1 + \alpha}}{{\beta}^{2}} \]
      3. unpow2N/A

        \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
      4. *-lowering-*.f6479.6

        \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
    5. Simplified79.6%

      \[\leadsto \color{blue}{\frac{1 + \alpha}{\beta \cdot \beta}} \]
    6. Step-by-step derivation
      1. associate-/r*N/A

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

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

        \[\leadsto \frac{\color{blue}{\frac{1 + \alpha}{\beta}}}{\beta} \]
      4. +-lowering-+.f6485.0

        \[\leadsto \frac{\frac{\color{blue}{1 + \alpha}}{\beta}}{\beta} \]
    7. Applied egg-rr85.0%

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

    \[\leadsto \begin{array}{l} \mathbf{if}\;\beta \leq 8.8 \cdot 10^{+16}:\\ \;\;\;\;\frac{\frac{\beta + 1}{\beta + 2}}{\mathsf{fma}\left(\beta, \beta + 5, 6\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{\alpha + 1}{\beta}}{\beta}\\ \end{array} \]
  5. Add Preprocessing

Alternative 6: 98.4% accurate, 2.1× speedup?

\[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 3.4 \cdot 10^{+16}:\\ \;\;\;\;\frac{\beta + 1}{\left(\beta + 2\right) \cdot \left(\left(\beta + 2\right) \cdot \left(\beta + 3\right)\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{\alpha + 1}{\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.4e+16)
   (/ (+ beta 1.0) (* (+ beta 2.0) (* (+ beta 2.0) (+ beta 3.0))))
   (/ (/ (+ alpha 1.0) beta) beta)))
assert(alpha < beta);
double code(double alpha, double beta) {
	double tmp;
	if (beta <= 3.4e+16) {
		tmp = (beta + 1.0) / ((beta + 2.0) * ((beta + 2.0) * (beta + 3.0)));
	} else {
		tmp = ((alpha + 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.4d+16) then
        tmp = (beta + 1.0d0) / ((beta + 2.0d0) * ((beta + 2.0d0) * (beta + 3.0d0)))
    else
        tmp = ((alpha + 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.4e+16) {
		tmp = (beta + 1.0) / ((beta + 2.0) * ((beta + 2.0) * (beta + 3.0)));
	} else {
		tmp = ((alpha + 1.0) / beta) / beta;
	}
	return tmp;
}
[alpha, beta] = sort([alpha, beta])
def code(alpha, beta):
	tmp = 0
	if beta <= 3.4e+16:
		tmp = (beta + 1.0) / ((beta + 2.0) * ((beta + 2.0) * (beta + 3.0)))
	else:
		tmp = ((alpha + 1.0) / beta) / beta
	return tmp
alpha, beta = sort([alpha, beta])
function code(alpha, beta)
	tmp = 0.0
	if (beta <= 3.4e+16)
		tmp = Float64(Float64(beta + 1.0) / Float64(Float64(beta + 2.0) * Float64(Float64(beta + 2.0) * Float64(beta + 3.0))));
	else
		tmp = Float64(Float64(Float64(alpha + 1.0) / beta) / beta);
	end
	return tmp
end
alpha, beta = num2cell(sort([alpha, beta])){:}
function tmp_2 = code(alpha, beta)
	tmp = 0.0;
	if (beta <= 3.4e+16)
		tmp = (beta + 1.0) / ((beta + 2.0) * ((beta + 2.0) * (beta + 3.0)));
	else
		tmp = ((alpha + 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.4e+16], N[(N[(beta + 1.0), $MachinePrecision] / N[(N[(beta + 2.0), $MachinePrecision] * N[(N[(beta + 2.0), $MachinePrecision] * N[(beta + 3.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(N[(alpha + 1.0), $MachinePrecision] / beta), $MachinePrecision] / beta), $MachinePrecision]]
\begin{array}{l}
[alpha, beta] = \mathsf{sort}([alpha, beta])\\
\\
\begin{array}{l}
\mathbf{if}\;\beta \leq 3.4 \cdot 10^{+16}:\\
\;\;\;\;\frac{\beta + 1}{\left(\beta + 2\right) \cdot \left(\left(\beta + 2\right) \cdot \left(\beta + 3\right)\right)}\\

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


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

    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 alpha around 0

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

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

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

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

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

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

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

        \[\leadsto \frac{\frac{1 + \beta}{\left(\beta + 2\right) \cdot \color{blue}{\left(\beta + 2\right)}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
      8. +-lowering-+.f6466.1

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

        \[\leadsto \frac{\color{blue}{\beta + 1}}{{\left(2 + \beta\right)}^{2} \cdot \left(3 + \beta\right)} \]
      4. unpow2N/A

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

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

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

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

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

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

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

        \[\leadsto \frac{\beta + 1}{\left(\beta + 2\right) \cdot \left(\color{blue}{\left(\beta + 2\right)} \cdot \left(3 + \beta\right)\right)} \]
      12. +-lowering-+.f6464.3

        \[\leadsto \frac{\beta + 1}{\left(\beta + 2\right) \cdot \left(\left(\beta + 2\right) \cdot \color{blue}{\left(3 + \beta\right)}\right)} \]
    10. Simplified64.3%

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

    if 3.4e16 < beta

    1. Initial program 87.0%

      \[\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 \color{blue}{\frac{1 + \alpha}{{\beta}^{2}}} \]
    4. Step-by-step derivation
      1. /-lowering-/.f64N/A

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

        \[\leadsto \frac{\color{blue}{1 + \alpha}}{{\beta}^{2}} \]
      3. unpow2N/A

        \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
      4. *-lowering-*.f6479.6

        \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
    5. Simplified79.6%

      \[\leadsto \color{blue}{\frac{1 + \alpha}{\beta \cdot \beta}} \]
    6. Step-by-step derivation
      1. associate-/r*N/A

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

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

        \[\leadsto \frac{\color{blue}{\frac{1 + \alpha}{\beta}}}{\beta} \]
      4. +-lowering-+.f6485.0

        \[\leadsto \frac{\frac{\color{blue}{1 + \alpha}}{\beta}}{\beta} \]
    7. Applied egg-rr85.0%

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

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

Alternative 7: 98.4% accurate, 2.1× speedup?

\[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 1.55 \cdot 10^{+15}:\\ \;\;\;\;\frac{\beta + 1}{\left(\beta + 3\right) \cdot \left(\left(\beta + 2\right) \cdot \left(\beta + 2\right)\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{\alpha + 1}{\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 1.55e+15)
   (/ (+ beta 1.0) (* (+ beta 3.0) (* (+ beta 2.0) (+ beta 2.0))))
   (/ (/ (+ alpha 1.0) beta) beta)))
assert(alpha < beta);
double code(double alpha, double beta) {
	double tmp;
	if (beta <= 1.55e+15) {
		tmp = (beta + 1.0) / ((beta + 3.0) * ((beta + 2.0) * (beta + 2.0)));
	} else {
		tmp = ((alpha + 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 <= 1.55d+15) then
        tmp = (beta + 1.0d0) / ((beta + 3.0d0) * ((beta + 2.0d0) * (beta + 2.0d0)))
    else
        tmp = ((alpha + 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 <= 1.55e+15) {
		tmp = (beta + 1.0) / ((beta + 3.0) * ((beta + 2.0) * (beta + 2.0)));
	} else {
		tmp = ((alpha + 1.0) / beta) / beta;
	}
	return tmp;
}
[alpha, beta] = sort([alpha, beta])
def code(alpha, beta):
	tmp = 0
	if beta <= 1.55e+15:
		tmp = (beta + 1.0) / ((beta + 3.0) * ((beta + 2.0) * (beta + 2.0)))
	else:
		tmp = ((alpha + 1.0) / beta) / beta
	return tmp
alpha, beta = sort([alpha, beta])
function code(alpha, beta)
	tmp = 0.0
	if (beta <= 1.55e+15)
		tmp = Float64(Float64(beta + 1.0) / Float64(Float64(beta + 3.0) * Float64(Float64(beta + 2.0) * Float64(beta + 2.0))));
	else
		tmp = Float64(Float64(Float64(alpha + 1.0) / beta) / beta);
	end
	return tmp
end
alpha, beta = num2cell(sort([alpha, beta])){:}
function tmp_2 = code(alpha, beta)
	tmp = 0.0;
	if (beta <= 1.55e+15)
		tmp = (beta + 1.0) / ((beta + 3.0) * ((beta + 2.0) * (beta + 2.0)));
	else
		tmp = ((alpha + 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, 1.55e+15], N[(N[(beta + 1.0), $MachinePrecision] / N[(N[(beta + 3.0), $MachinePrecision] * N[(N[(beta + 2.0), $MachinePrecision] * N[(beta + 2.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(N[(alpha + 1.0), $MachinePrecision] / beta), $MachinePrecision] / beta), $MachinePrecision]]
\begin{array}{l}
[alpha, beta] = \mathsf{sort}([alpha, beta])\\
\\
\begin{array}{l}
\mathbf{if}\;\beta \leq 1.55 \cdot 10^{+15}:\\
\;\;\;\;\frac{\beta + 1}{\left(\beta + 3\right) \cdot \left(\left(\beta + 2\right) \cdot \left(\beta + 2\right)\right)}\\

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


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

    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 alpha around 0

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

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

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

        \[\leadsto \frac{1 + \beta}{\color{blue}{{\left(2 + \beta\right)}^{2} \cdot \left(3 + \beta\right)}} \]
      4. unpow2N/A

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

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

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

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

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

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

        \[\leadsto \frac{1 + \beta}{\left(\left(\beta + 2\right) \cdot \left(\beta + 2\right)\right) \cdot \color{blue}{\left(\beta + 3\right)}} \]
      11. +-lowering-+.f6464.3

        \[\leadsto \frac{1 + \beta}{\left(\left(\beta + 2\right) \cdot \left(\beta + 2\right)\right) \cdot \color{blue}{\left(\beta + 3\right)}} \]
    5. Simplified64.3%

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

    if 1.55e15 < beta

    1. Initial program 87.0%

      \[\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 \color{blue}{\frac{1 + \alpha}{{\beta}^{2}}} \]
    4. Step-by-step derivation
      1. /-lowering-/.f64N/A

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

        \[\leadsto \frac{\color{blue}{1 + \alpha}}{{\beta}^{2}} \]
      3. unpow2N/A

        \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
      4. *-lowering-*.f6479.6

        \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
    5. Simplified79.6%

      \[\leadsto \color{blue}{\frac{1 + \alpha}{\beta \cdot \beta}} \]
    6. Step-by-step derivation
      1. associate-/r*N/A

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

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

        \[\leadsto \frac{\color{blue}{\frac{1 + \alpha}{\beta}}}{\beta} \]
      4. +-lowering-+.f6485.0

        \[\leadsto \frac{\frac{\color{blue}{1 + \alpha}}{\beta}}{\beta} \]
    7. Applied egg-rr85.0%

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

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

Alternative 8: 97.1% accurate, 2.4× speedup?

\[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 7.6:\\ \;\;\;\;\frac{0.25}{2 + \left(1 + \left(\beta + \alpha\right)\right)}\\ \mathbf{elif}\;\beta \leq 2.1 \cdot 10^{+155}:\\ \;\;\;\;\frac{\alpha + 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 7.6)
   (/ 0.25 (+ 2.0 (+ 1.0 (+ beta alpha))))
   (if (<= beta 2.1e+155)
     (/ (+ alpha 1.0) (* beta beta))
     (/ (/ alpha beta) beta))))
assert(alpha < beta);
double code(double alpha, double beta) {
	double tmp;
	if (beta <= 7.6) {
		tmp = 0.25 / (2.0 + (1.0 + (beta + alpha)));
	} else if (beta <= 2.1e+155) {
		tmp = (alpha + 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 <= 7.6d0) then
        tmp = 0.25d0 / (2.0d0 + (1.0d0 + (beta + alpha)))
    else if (beta <= 2.1d+155) then
        tmp = (alpha + 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 <= 7.6) {
		tmp = 0.25 / (2.0 + (1.0 + (beta + alpha)));
	} else if (beta <= 2.1e+155) {
		tmp = (alpha + 1.0) / (beta * beta);
	} else {
		tmp = (alpha / beta) / beta;
	}
	return tmp;
}
[alpha, beta] = sort([alpha, beta])
def code(alpha, beta):
	tmp = 0
	if beta <= 7.6:
		tmp = 0.25 / (2.0 + (1.0 + (beta + alpha)))
	elif beta <= 2.1e+155:
		tmp = (alpha + 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 <= 7.6)
		tmp = Float64(0.25 / Float64(2.0 + Float64(1.0 + Float64(beta + alpha))));
	elseif (beta <= 2.1e+155)
		tmp = Float64(Float64(alpha + 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 <= 7.6)
		tmp = 0.25 / (2.0 + (1.0 + (beta + alpha)));
	elseif (beta <= 2.1e+155)
		tmp = (alpha + 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, 7.6], N[(0.25 / N[(2.0 + N[(1.0 + N[(beta + alpha), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[beta, 2.1e+155], N[(N[(alpha + 1.0), $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 7.6:\\
\;\;\;\;\frac{0.25}{2 + \left(1 + \left(\beta + \alpha\right)\right)}\\

\mathbf{elif}\;\beta \leq 2.1 \cdot 10^{+155}:\\
\;\;\;\;\frac{\alpha + 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 < 7.5999999999999996

    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 alpha around 0

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

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

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

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

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

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

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

        \[\leadsto \frac{\frac{1 + \beta}{\left(\beta + 2\right) \cdot \color{blue}{\left(\beta + 2\right)}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
      8. +-lowering-+.f6465.5

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

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

      \[\leadsto \frac{\color{blue}{\frac{1}{4}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
    7. Step-by-step derivation
      1. Simplified65.1%

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

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

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

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

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

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

          \[\leadsto \frac{\frac{1}{4}}{\left(1 + \color{blue}{\left(\beta + \alpha\right)}\right) + 2} \]
        7. +-lowering-+.f6465.1

          \[\leadsto \frac{0.25}{\left(1 + \color{blue}{\left(\beta + \alpha\right)}\right) + 2} \]
      3. Applied egg-rr65.1%

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

      if 7.5999999999999996 < beta < 2.1e155

      1. Initial program 94.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. Add Preprocessing
      3. Taylor expanded in beta around inf

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

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

          \[\leadsto \frac{\color{blue}{1 + \alpha}}{{\beta}^{2}} \]
        3. unpow2N/A

          \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
        4. *-lowering-*.f6466.7

          \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
      5. Simplified66.7%

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

      if 2.1e155 < beta

      1. Initial program 82.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. Add Preprocessing
      3. Taylor expanded in beta around inf

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

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

          \[\leadsto \frac{\color{blue}{1 + \alpha}}{{\beta}^{2}} \]
        3. unpow2N/A

          \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
        4. *-lowering-*.f6485.5

          \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
      5. Simplified85.5%

        \[\leadsto \color{blue}{\frac{1 + \alpha}{\beta \cdot \beta}} \]
      6. Step-by-step derivation
        1. associate-/r*N/A

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

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

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

          \[\leadsto \frac{\frac{\color{blue}{1 + \alpha}}{\beta}}{\beta} \]
      7. Applied egg-rr94.4%

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

        \[\leadsto \frac{\color{blue}{\frac{\alpha}{\beta}}}{\beta} \]
      9. Step-by-step derivation
        1. /-lowering-/.f6492.4

          \[\leadsto \frac{\color{blue}{\frac{\alpha}{\beta}}}{\beta} \]
      10. Simplified92.4%

        \[\leadsto \frac{\color{blue}{\frac{\alpha}{\beta}}}{\beta} \]
    8. Recombined 3 regimes into one program.
    9. Final simplification70.8%

      \[\leadsto \begin{array}{l} \mathbf{if}\;\beta \leq 7.6:\\ \;\;\;\;\frac{0.25}{2 + \left(1 + \left(\beta + \alpha\right)\right)}\\ \mathbf{elif}\;\beta \leq 2.1 \cdot 10^{+155}:\\ \;\;\;\;\frac{\alpha + 1}{\beta \cdot \beta}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{\alpha}{\beta}}{\beta}\\ \end{array} \]
    10. Add Preprocessing

    Alternative 9: 97.6% accurate, 2.4× speedup?

    \[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 4.5:\\ \;\;\;\;\frac{0.25}{2 + \left(1 + \left(\beta + \alpha\right)\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{\alpha + 1}{\beta}}{\beta + 3}\\ \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 4.5)
       (/ 0.25 (+ 2.0 (+ 1.0 (+ beta alpha))))
       (/ (/ (+ alpha 1.0) beta) (+ beta 3.0))))
    assert(alpha < beta);
    double code(double alpha, double beta) {
    	double tmp;
    	if (beta <= 4.5) {
    		tmp = 0.25 / (2.0 + (1.0 + (beta + alpha)));
    	} else {
    		tmp = ((alpha + 1.0) / beta) / (beta + 3.0);
    	}
    	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 <= 4.5d0) then
            tmp = 0.25d0 / (2.0d0 + (1.0d0 + (beta + alpha)))
        else
            tmp = ((alpha + 1.0d0) / beta) / (beta + 3.0d0)
        end if
        code = tmp
    end function
    
    assert alpha < beta;
    public static double code(double alpha, double beta) {
    	double tmp;
    	if (beta <= 4.5) {
    		tmp = 0.25 / (2.0 + (1.0 + (beta + alpha)));
    	} else {
    		tmp = ((alpha + 1.0) / beta) / (beta + 3.0);
    	}
    	return tmp;
    }
    
    [alpha, beta] = sort([alpha, beta])
    def code(alpha, beta):
    	tmp = 0
    	if beta <= 4.5:
    		tmp = 0.25 / (2.0 + (1.0 + (beta + alpha)))
    	else:
    		tmp = ((alpha + 1.0) / beta) / (beta + 3.0)
    	return tmp
    
    alpha, beta = sort([alpha, beta])
    function code(alpha, beta)
    	tmp = 0.0
    	if (beta <= 4.5)
    		tmp = Float64(0.25 / Float64(2.0 + Float64(1.0 + Float64(beta + alpha))));
    	else
    		tmp = Float64(Float64(Float64(alpha + 1.0) / beta) / Float64(beta + 3.0));
    	end
    	return tmp
    end
    
    alpha, beta = num2cell(sort([alpha, beta])){:}
    function tmp_2 = code(alpha, beta)
    	tmp = 0.0;
    	if (beta <= 4.5)
    		tmp = 0.25 / (2.0 + (1.0 + (beta + alpha)));
    	else
    		tmp = ((alpha + 1.0) / beta) / (beta + 3.0);
    	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, 4.5], N[(0.25 / N[(2.0 + N[(1.0 + N[(beta + alpha), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(N[(alpha + 1.0), $MachinePrecision] / beta), $MachinePrecision] / N[(beta + 3.0), $MachinePrecision]), $MachinePrecision]]
    
    \begin{array}{l}
    [alpha, beta] = \mathsf{sort}([alpha, beta])\\
    \\
    \begin{array}{l}
    \mathbf{if}\;\beta \leq 4.5:\\
    \;\;\;\;\frac{0.25}{2 + \left(1 + \left(\beta + \alpha\right)\right)}\\
    
    \mathbf{else}:\\
    \;\;\;\;\frac{\frac{\alpha + 1}{\beta}}{\beta + 3}\\
    
    
    \end{array}
    \end{array}
    
    Derivation
    1. Split input into 2 regimes
    2. if beta < 4.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. Add Preprocessing
      3. Taylor expanded in alpha around 0

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

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

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

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

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

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

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

          \[\leadsto \frac{\frac{1 + \beta}{\left(\beta + 2\right) \cdot \color{blue}{\left(\beta + 2\right)}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
        8. +-lowering-+.f6465.5

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

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

        \[\leadsto \frac{\color{blue}{\frac{1}{4}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
      7. Step-by-step derivation
        1. Simplified65.1%

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

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

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

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

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

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

            \[\leadsto \frac{\frac{1}{4}}{\left(1 + \color{blue}{\left(\beta + \alpha\right)}\right) + 2} \]
          7. +-lowering-+.f6465.1

            \[\leadsto \frac{0.25}{\left(1 + \color{blue}{\left(\beta + \alpha\right)}\right) + 2} \]
        3. Applied egg-rr65.1%

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

        if 4.5 < beta

        1. Initial program 87.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. Add Preprocessing
        3. Taylor expanded in beta around inf

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

            \[\leadsto \frac{\color{blue}{\frac{1 + \alpha}{\beta}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
          2. +-lowering-+.f6482.7

            \[\leadsto \frac{\frac{\color{blue}{1 + \alpha}}{\beta}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
        5. Simplified82.7%

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

          \[\leadsto \frac{\frac{1 + \alpha}{\beta}}{\color{blue}{3 + \beta}} \]
        7. Step-by-step derivation
          1. +-commutativeN/A

            \[\leadsto \frac{\frac{1 + \alpha}{\beta}}{\color{blue}{\beta + 3}} \]
          2. +-lowering-+.f6482.5

            \[\leadsto \frac{\frac{1 + \alpha}{\beta}}{\color{blue}{\beta + 3}} \]
        8. Simplified82.5%

          \[\leadsto \frac{\frac{1 + \alpha}{\beta}}{\color{blue}{\beta + 3}} \]
      8. Recombined 2 regimes into one program.
      9. Final simplification71.3%

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

      Alternative 10: 97.6% accurate, 2.6× speedup?

      \[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 6.2:\\ \;\;\;\;\frac{0.25}{2 + \left(1 + \left(\beta + \alpha\right)\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{\alpha + 1}{\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 6.2)
         (/ 0.25 (+ 2.0 (+ 1.0 (+ beta alpha))))
         (/ (/ (+ alpha 1.0) beta) beta)))
      assert(alpha < beta);
      double code(double alpha, double beta) {
      	double tmp;
      	if (beta <= 6.2) {
      		tmp = 0.25 / (2.0 + (1.0 + (beta + alpha)));
      	} else {
      		tmp = ((alpha + 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 <= 6.2d0) then
              tmp = 0.25d0 / (2.0d0 + (1.0d0 + (beta + alpha)))
          else
              tmp = ((alpha + 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 <= 6.2) {
      		tmp = 0.25 / (2.0 + (1.0 + (beta + alpha)));
      	} else {
      		tmp = ((alpha + 1.0) / beta) / beta;
      	}
      	return tmp;
      }
      
      [alpha, beta] = sort([alpha, beta])
      def code(alpha, beta):
      	tmp = 0
      	if beta <= 6.2:
      		tmp = 0.25 / (2.0 + (1.0 + (beta + alpha)))
      	else:
      		tmp = ((alpha + 1.0) / beta) / beta
      	return tmp
      
      alpha, beta = sort([alpha, beta])
      function code(alpha, beta)
      	tmp = 0.0
      	if (beta <= 6.2)
      		tmp = Float64(0.25 / Float64(2.0 + Float64(1.0 + Float64(beta + alpha))));
      	else
      		tmp = Float64(Float64(Float64(alpha + 1.0) / beta) / beta);
      	end
      	return tmp
      end
      
      alpha, beta = num2cell(sort([alpha, beta])){:}
      function tmp_2 = code(alpha, beta)
      	tmp = 0.0;
      	if (beta <= 6.2)
      		tmp = 0.25 / (2.0 + (1.0 + (beta + alpha)));
      	else
      		tmp = ((alpha + 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, 6.2], N[(0.25 / N[(2.0 + N[(1.0 + N[(beta + alpha), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(N[(alpha + 1.0), $MachinePrecision] / beta), $MachinePrecision] / beta), $MachinePrecision]]
      
      \begin{array}{l}
      [alpha, beta] = \mathsf{sort}([alpha, beta])\\
      \\
      \begin{array}{l}
      \mathbf{if}\;\beta \leq 6.2:\\
      \;\;\;\;\frac{0.25}{2 + \left(1 + \left(\beta + \alpha\right)\right)}\\
      
      \mathbf{else}:\\
      \;\;\;\;\frac{\frac{\alpha + 1}{\beta}}{\beta}\\
      
      
      \end{array}
      \end{array}
      
      Derivation
      1. Split input into 2 regimes
      2. if beta < 6.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. Add Preprocessing
        3. Taylor expanded in alpha around 0

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

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

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

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

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

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

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

            \[\leadsto \frac{\frac{1 + \beta}{\left(\beta + 2\right) \cdot \color{blue}{\left(\beta + 2\right)}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
          8. +-lowering-+.f6465.5

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

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

          \[\leadsto \frac{\color{blue}{\frac{1}{4}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
        7. Step-by-step derivation
          1. Simplified65.1%

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

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

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

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

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

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

              \[\leadsto \frac{\frac{1}{4}}{\left(1 + \color{blue}{\left(\beta + \alpha\right)}\right) + 2} \]
            7. +-lowering-+.f6465.1

              \[\leadsto \frac{0.25}{\left(1 + \color{blue}{\left(\beta + \alpha\right)}\right) + 2} \]
          3. Applied egg-rr65.1%

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

          if 6.20000000000000018 < beta

          1. Initial program 87.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. Add Preprocessing
          3. Taylor expanded in beta around inf

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

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

              \[\leadsto \frac{\color{blue}{1 + \alpha}}{{\beta}^{2}} \]
            3. unpow2N/A

              \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
            4. *-lowering-*.f6477.4

              \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
          5. Simplified77.4%

            \[\leadsto \color{blue}{\frac{1 + \alpha}{\beta \cdot \beta}} \]
          6. Step-by-step derivation
            1. associate-/r*N/A

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

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

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

              \[\leadsto \frac{\frac{\color{blue}{1 + \alpha}}{\beta}}{\beta} \]
          7. Applied egg-rr82.4%

            \[\leadsto \color{blue}{\frac{\frac{1 + \alpha}{\beta}}{\beta}} \]
        8. Recombined 2 regimes into one program.
        9. Final simplification71.2%

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

        Alternative 11: 94.4% accurate, 3.1× speedup?

        \[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 6.5:\\ \;\;\;\;\frac{0.25}{2 + \left(1 + \left(\beta + \alpha\right)\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\alpha + 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 6.5)
           (/ 0.25 (+ 2.0 (+ 1.0 (+ beta alpha))))
           (/ (+ alpha 1.0) (* beta beta))))
        assert(alpha < beta);
        double code(double alpha, double beta) {
        	double tmp;
        	if (beta <= 6.5) {
        		tmp = 0.25 / (2.0 + (1.0 + (beta + alpha)));
        	} else {
        		tmp = (alpha + 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 <= 6.5d0) then
                tmp = 0.25d0 / (2.0d0 + (1.0d0 + (beta + alpha)))
            else
                tmp = (alpha + 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 <= 6.5) {
        		tmp = 0.25 / (2.0 + (1.0 + (beta + alpha)));
        	} else {
        		tmp = (alpha + 1.0) / (beta * beta);
        	}
        	return tmp;
        }
        
        [alpha, beta] = sort([alpha, beta])
        def code(alpha, beta):
        	tmp = 0
        	if beta <= 6.5:
        		tmp = 0.25 / (2.0 + (1.0 + (beta + alpha)))
        	else:
        		tmp = (alpha + 1.0) / (beta * beta)
        	return tmp
        
        alpha, beta = sort([alpha, beta])
        function code(alpha, beta)
        	tmp = 0.0
        	if (beta <= 6.5)
        		tmp = Float64(0.25 / Float64(2.0 + Float64(1.0 + Float64(beta + alpha))));
        	else
        		tmp = Float64(Float64(alpha + 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 <= 6.5)
        		tmp = 0.25 / (2.0 + (1.0 + (beta + alpha)));
        	else
        		tmp = (alpha + 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, 6.5], N[(0.25 / N[(2.0 + N[(1.0 + N[(beta + alpha), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(alpha + 1.0), $MachinePrecision] / N[(beta * beta), $MachinePrecision]), $MachinePrecision]]
        
        \begin{array}{l}
        [alpha, beta] = \mathsf{sort}([alpha, beta])\\
        \\
        \begin{array}{l}
        \mathbf{if}\;\beta \leq 6.5:\\
        \;\;\;\;\frac{0.25}{2 + \left(1 + \left(\beta + \alpha\right)\right)}\\
        
        \mathbf{else}:\\
        \;\;\;\;\frac{\alpha + 1}{\beta \cdot \beta}\\
        
        
        \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. Add Preprocessing
          3. Taylor expanded in alpha around 0

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

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

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

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

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

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

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

              \[\leadsto \frac{\frac{1 + \beta}{\left(\beta + 2\right) \cdot \color{blue}{\left(\beta + 2\right)}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
            8. +-lowering-+.f6465.5

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

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

            \[\leadsto \frac{\color{blue}{\frac{1}{4}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
          7. Step-by-step derivation
            1. Simplified65.1%

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

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

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

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

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

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

                \[\leadsto \frac{\frac{1}{4}}{\left(1 + \color{blue}{\left(\beta + \alpha\right)}\right) + 2} \]
              7. +-lowering-+.f6465.1

                \[\leadsto \frac{0.25}{\left(1 + \color{blue}{\left(\beta + \alpha\right)}\right) + 2} \]
            3. Applied egg-rr65.1%

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

            if 6.5 < beta

            1. Initial program 87.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. Add Preprocessing
            3. Taylor expanded in beta around inf

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

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

                \[\leadsto \frac{\color{blue}{1 + \alpha}}{{\beta}^{2}} \]
              3. unpow2N/A

                \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
              4. *-lowering-*.f6477.4

                \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
            5. Simplified77.4%

              \[\leadsto \color{blue}{\frac{1 + \alpha}{\beta \cdot \beta}} \]
          8. Recombined 2 regimes into one program.
          9. Final simplification69.4%

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

          Alternative 12: 94.2% accurate, 3.2× speedup?

          \[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 2.3:\\ \;\;\;\;\mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, 0.024691358024691357, -0.011574074074074073\right), -0.027777777777777776\right), 0.08333333333333333\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{\alpha + 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 2.3)
             (fma
              beta
              (fma
               beta
               (fma beta 0.024691358024691357 -0.011574074074074073)
               -0.027777777777777776)
              0.08333333333333333)
             (/ (+ alpha 1.0) (* beta beta))))
          assert(alpha < beta);
          double code(double alpha, double beta) {
          	double tmp;
          	if (beta <= 2.3) {
          		tmp = fma(beta, fma(beta, fma(beta, 0.024691358024691357, -0.011574074074074073), -0.027777777777777776), 0.08333333333333333);
          	} else {
          		tmp = (alpha + 1.0) / (beta * beta);
          	}
          	return tmp;
          }
          
          alpha, beta = sort([alpha, beta])
          function code(alpha, beta)
          	tmp = 0.0
          	if (beta <= 2.3)
          		tmp = fma(beta, fma(beta, fma(beta, 0.024691358024691357, -0.011574074074074073), -0.027777777777777776), 0.08333333333333333);
          	else
          		tmp = Float64(Float64(alpha + 1.0) / Float64(beta * beta));
          	end
          	return tmp
          end
          
          NOTE: alpha and beta should be sorted in increasing order before calling this function.
          code[alpha_, beta_] := If[LessEqual[beta, 2.3], N[(beta * N[(beta * N[(beta * 0.024691358024691357 + -0.011574074074074073), $MachinePrecision] + -0.027777777777777776), $MachinePrecision] + 0.08333333333333333), $MachinePrecision], N[(N[(alpha + 1.0), $MachinePrecision] / N[(beta * beta), $MachinePrecision]), $MachinePrecision]]
          
          \begin{array}{l}
          [alpha, beta] = \mathsf{sort}([alpha, beta])\\
          \\
          \begin{array}{l}
          \mathbf{if}\;\beta \leq 2.3:\\
          \;\;\;\;\mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, 0.024691358024691357, -0.011574074074074073\right), -0.027777777777777776\right), 0.08333333333333333\right)\\
          
          \mathbf{else}:\\
          \;\;\;\;\frac{\alpha + 1}{\beta \cdot \beta}\\
          
          
          \end{array}
          \end{array}
          
          Derivation
          1. Split input into 2 regimes
          2. if beta < 2.2999999999999998

            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 alpha around 0

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

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

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

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

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

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

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

                \[\leadsto \frac{\frac{1 + \beta}{\left(\beta + 2\right) \cdot \color{blue}{\left(\beta + 2\right)}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
              8. +-lowering-+.f6465.5

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

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

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

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

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

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

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

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

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

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

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

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

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

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

                \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\left(\alpha + \color{blue}{\left(\beta + 3\right)}\right) \cdot \left(\beta + 2\right)} \]
              14. +-lowering-+.f6465.5

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

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

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

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

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

                \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\color{blue}{\left(\beta + 2\right)} \cdot \left(3 + \beta\right)} \]
              4. +-lowering-+.f6463.6

                \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\left(\beta + 2\right) \cdot \color{blue}{\left(3 + \beta\right)}} \]
            10. Simplified63.6%

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

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

                \[\leadsto \color{blue}{\beta \cdot \left(\beta \cdot \left(\frac{2}{81} \cdot \beta - \frac{5}{432}\right) - \frac{1}{36}\right) + \frac{1}{12}} \]
              2. accelerator-lowering-fma.f64N/A

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

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

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

                \[\leadsto \mathsf{fma}\left(\beta, \color{blue}{\mathsf{fma}\left(\beta, \frac{2}{81} \cdot \beta - \frac{5}{432}, \frac{-1}{36}\right)}, \frac{1}{12}\right) \]
              6. sub-negN/A

                \[\leadsto \mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, \color{blue}{\frac{2}{81} \cdot \beta + \left(\mathsf{neg}\left(\frac{5}{432}\right)\right)}, \frac{-1}{36}\right), \frac{1}{12}\right) \]
              7. *-commutativeN/A

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

                \[\leadsto \mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, \beta \cdot \frac{2}{81} + \color{blue}{\frac{-5}{432}}, \frac{-1}{36}\right), \frac{1}{12}\right) \]
              9. accelerator-lowering-fma.f6463.4

                \[\leadsto \mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, \color{blue}{\mathsf{fma}\left(\beta, 0.024691358024691357, -0.011574074074074073\right)}, -0.027777777777777776\right), 0.08333333333333333\right) \]
            13. Simplified63.4%

              \[\leadsto \color{blue}{\mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, 0.024691358024691357, -0.011574074074074073\right), -0.027777777777777776\right), 0.08333333333333333\right)} \]

            if 2.2999999999999998 < beta

            1. Initial program 87.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. Add Preprocessing
            3. Taylor expanded in beta around inf

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

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

                \[\leadsto \frac{\color{blue}{1 + \alpha}}{{\beta}^{2}} \]
              3. unpow2N/A

                \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
              4. *-lowering-*.f6477.4

                \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
            5. Simplified77.4%

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

            \[\leadsto \begin{array}{l} \mathbf{if}\;\beta \leq 2.3:\\ \;\;\;\;\mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, 0.024691358024691357, -0.011574074074074073\right), -0.027777777777777776\right), 0.08333333333333333\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{\alpha + 1}{\beta \cdot \beta}\\ \end{array} \]
          5. Add Preprocessing

          Alternative 13: 91.5% accurate, 3.2× speedup?

          \[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 1.7:\\ \;\;\;\;\mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, 0.024691358024691357, -0.011574074074074073\right), -0.027777777777777776\right), 0.08333333333333333\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\beta \cdot \left(\beta + 3\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 1.7)
             (fma
              beta
              (fma
               beta
               (fma beta 0.024691358024691357 -0.011574074074074073)
               -0.027777777777777776)
              0.08333333333333333)
             (/ 1.0 (* beta (+ beta 3.0)))))
          assert(alpha < beta);
          double code(double alpha, double beta) {
          	double tmp;
          	if (beta <= 1.7) {
          		tmp = fma(beta, fma(beta, fma(beta, 0.024691358024691357, -0.011574074074074073), -0.027777777777777776), 0.08333333333333333);
          	} else {
          		tmp = 1.0 / (beta * (beta + 3.0));
          	}
          	return tmp;
          }
          
          alpha, beta = sort([alpha, beta])
          function code(alpha, beta)
          	tmp = 0.0
          	if (beta <= 1.7)
          		tmp = fma(beta, fma(beta, fma(beta, 0.024691358024691357, -0.011574074074074073), -0.027777777777777776), 0.08333333333333333);
          	else
          		tmp = Float64(1.0 / Float64(beta * Float64(beta + 3.0)));
          	end
          	return tmp
          end
          
          NOTE: alpha and beta should be sorted in increasing order before calling this function.
          code[alpha_, beta_] := If[LessEqual[beta, 1.7], N[(beta * N[(beta * N[(beta * 0.024691358024691357 + -0.011574074074074073), $MachinePrecision] + -0.027777777777777776), $MachinePrecision] + 0.08333333333333333), $MachinePrecision], N[(1.0 / N[(beta * N[(beta + 3.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
          
          \begin{array}{l}
          [alpha, beta] = \mathsf{sort}([alpha, beta])\\
          \\
          \begin{array}{l}
          \mathbf{if}\;\beta \leq 1.7:\\
          \;\;\;\;\mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, 0.024691358024691357, -0.011574074074074073\right), -0.027777777777777776\right), 0.08333333333333333\right)\\
          
          \mathbf{else}:\\
          \;\;\;\;\frac{1}{\beta \cdot \left(\beta + 3\right)}\\
          
          
          \end{array}
          \end{array}
          
          Derivation
          1. Split input into 2 regimes
          2. if beta < 1.69999999999999996

            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 alpha around 0

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

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

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

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

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

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

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

                \[\leadsto \frac{\frac{1 + \beta}{\left(\beta + 2\right) \cdot \color{blue}{\left(\beta + 2\right)}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
              8. +-lowering-+.f6465.5

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

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

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

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

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

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

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

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

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

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

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

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

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

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

                \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\left(\alpha + \color{blue}{\left(\beta + 3\right)}\right) \cdot \left(\beta + 2\right)} \]
              14. +-lowering-+.f6465.5

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

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

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

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

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

                \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\color{blue}{\left(\beta + 2\right)} \cdot \left(3 + \beta\right)} \]
              4. +-lowering-+.f6463.6

                \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\left(\beta + 2\right) \cdot \color{blue}{\left(3 + \beta\right)}} \]
            10. Simplified63.6%

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

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

                \[\leadsto \color{blue}{\beta \cdot \left(\beta \cdot \left(\frac{2}{81} \cdot \beta - \frac{5}{432}\right) - \frac{1}{36}\right) + \frac{1}{12}} \]
              2. accelerator-lowering-fma.f64N/A

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

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

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

                \[\leadsto \mathsf{fma}\left(\beta, \color{blue}{\mathsf{fma}\left(\beta, \frac{2}{81} \cdot \beta - \frac{5}{432}, \frac{-1}{36}\right)}, \frac{1}{12}\right) \]
              6. sub-negN/A

                \[\leadsto \mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, \color{blue}{\frac{2}{81} \cdot \beta + \left(\mathsf{neg}\left(\frac{5}{432}\right)\right)}, \frac{-1}{36}\right), \frac{1}{12}\right) \]
              7. *-commutativeN/A

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

                \[\leadsto \mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, \beta \cdot \frac{2}{81} + \color{blue}{\frac{-5}{432}}, \frac{-1}{36}\right), \frac{1}{12}\right) \]
              9. accelerator-lowering-fma.f6463.4

                \[\leadsto \mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, \color{blue}{\mathsf{fma}\left(\beta, 0.024691358024691357, -0.011574074074074073\right)}, -0.027777777777777776\right), 0.08333333333333333\right) \]
            13. Simplified63.4%

              \[\leadsto \color{blue}{\mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, 0.024691358024691357, -0.011574074074074073\right), -0.027777777777777776\right), 0.08333333333333333\right)} \]

            if 1.69999999999999996 < beta

            1. Initial program 87.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. Add Preprocessing
            3. Taylor expanded in beta around inf

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

                \[\leadsto \frac{\color{blue}{\frac{1 + \alpha}{\beta}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
              2. +-lowering-+.f6482.7

                \[\leadsto \frac{\frac{\color{blue}{1 + \alpha}}{\beta}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
            5. Simplified82.7%

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

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

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

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

                \[\leadsto \frac{1}{\beta \cdot \color{blue}{\left(\beta + 3\right)}} \]
              4. +-lowering-+.f6474.1

                \[\leadsto \frac{1}{\beta \cdot \color{blue}{\left(\beta + 3\right)}} \]
            8. Simplified74.1%

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

          Alternative 14: 91.5% accurate, 3.4× speedup?

          \[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 2.15:\\ \;\;\;\;\mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, 0.024691358024691357, -0.011574074074074073\right), -0.027777777777777776\right), 0.08333333333333333\right)\\ \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 2.15)
             (fma
              beta
              (fma
               beta
               (fma beta 0.024691358024691357 -0.011574074074074073)
               -0.027777777777777776)
              0.08333333333333333)
             (/ 1.0 (* beta beta))))
          assert(alpha < beta);
          double code(double alpha, double beta) {
          	double tmp;
          	if (beta <= 2.15) {
          		tmp = fma(beta, fma(beta, fma(beta, 0.024691358024691357, -0.011574074074074073), -0.027777777777777776), 0.08333333333333333);
          	} else {
          		tmp = 1.0 / (beta * beta);
          	}
          	return tmp;
          }
          
          alpha, beta = sort([alpha, beta])
          function code(alpha, beta)
          	tmp = 0.0
          	if (beta <= 2.15)
          		tmp = fma(beta, fma(beta, fma(beta, 0.024691358024691357, -0.011574074074074073), -0.027777777777777776), 0.08333333333333333);
          	else
          		tmp = Float64(1.0 / Float64(beta * beta));
          	end
          	return tmp
          end
          
          NOTE: alpha and beta should be sorted in increasing order before calling this function.
          code[alpha_, beta_] := If[LessEqual[beta, 2.15], N[(beta * N[(beta * N[(beta * 0.024691358024691357 + -0.011574074074074073), $MachinePrecision] + -0.027777777777777776), $MachinePrecision] + 0.08333333333333333), $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 2.15:\\
          \;\;\;\;\mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, 0.024691358024691357, -0.011574074074074073\right), -0.027777777777777776\right), 0.08333333333333333\right)\\
          
          \mathbf{else}:\\
          \;\;\;\;\frac{1}{\beta \cdot \beta}\\
          
          
          \end{array}
          \end{array}
          
          Derivation
          1. Split input into 2 regimes
          2. if beta < 2.14999999999999991

            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 alpha around 0

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

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

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

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

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

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

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

                \[\leadsto \frac{\frac{1 + \beta}{\left(\beta + 2\right) \cdot \color{blue}{\left(\beta + 2\right)}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
              8. +-lowering-+.f6465.5

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

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

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

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

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

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

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

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

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

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

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

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

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

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

                \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\left(\alpha + \color{blue}{\left(\beta + 3\right)}\right) \cdot \left(\beta + 2\right)} \]
              14. +-lowering-+.f6465.5

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

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

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

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

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

                \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\color{blue}{\left(\beta + 2\right)} \cdot \left(3 + \beta\right)} \]
              4. +-lowering-+.f6463.6

                \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\left(\beta + 2\right) \cdot \color{blue}{\left(3 + \beta\right)}} \]
            10. Simplified63.6%

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

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

                \[\leadsto \color{blue}{\beta \cdot \left(\beta \cdot \left(\frac{2}{81} \cdot \beta - \frac{5}{432}\right) - \frac{1}{36}\right) + \frac{1}{12}} \]
              2. accelerator-lowering-fma.f64N/A

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

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

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

                \[\leadsto \mathsf{fma}\left(\beta, \color{blue}{\mathsf{fma}\left(\beta, \frac{2}{81} \cdot \beta - \frac{5}{432}, \frac{-1}{36}\right)}, \frac{1}{12}\right) \]
              6. sub-negN/A

                \[\leadsto \mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, \color{blue}{\frac{2}{81} \cdot \beta + \left(\mathsf{neg}\left(\frac{5}{432}\right)\right)}, \frac{-1}{36}\right), \frac{1}{12}\right) \]
              7. *-commutativeN/A

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

                \[\leadsto \mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, \beta \cdot \frac{2}{81} + \color{blue}{\frac{-5}{432}}, \frac{-1}{36}\right), \frac{1}{12}\right) \]
              9. accelerator-lowering-fma.f6463.4

                \[\leadsto \mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, \color{blue}{\mathsf{fma}\left(\beta, 0.024691358024691357, -0.011574074074074073\right)}, -0.027777777777777776\right), 0.08333333333333333\right) \]
            13. Simplified63.4%

              \[\leadsto \color{blue}{\mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, 0.024691358024691357, -0.011574074074074073\right), -0.027777777777777776\right), 0.08333333333333333\right)} \]

            if 2.14999999999999991 < beta

            1. Initial program 87.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. Add Preprocessing
            3. Taylor expanded in beta around inf

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

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

                \[\leadsto \frac{\color{blue}{1 + \alpha}}{{\beta}^{2}} \]
              3. unpow2N/A

                \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
              4. *-lowering-*.f6477.4

                \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
            5. Simplified77.4%

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

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

                \[\leadsto \color{blue}{\frac{1}{{\beta}^{2}}} \]
              2. unpow2N/A

                \[\leadsto \frac{1}{\color{blue}{\beta \cdot \beta}} \]
              3. *-lowering-*.f6474.0

                \[\leadsto \frac{1}{\color{blue}{\beta \cdot \beta}} \]
            8. Simplified74.0%

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

          Alternative 15: 91.4% accurate, 3.6× speedup?

          \[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 1.65:\\ \;\;\;\;\mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, -0.011574074074074073, -0.027777777777777776\right), 0.08333333333333333\right)\\ \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 1.65)
             (fma
              beta
              (fma beta -0.011574074074074073 -0.027777777777777776)
              0.08333333333333333)
             (/ 1.0 (* beta beta))))
          assert(alpha < beta);
          double code(double alpha, double beta) {
          	double tmp;
          	if (beta <= 1.65) {
          		tmp = fma(beta, fma(beta, -0.011574074074074073, -0.027777777777777776), 0.08333333333333333);
          	} else {
          		tmp = 1.0 / (beta * beta);
          	}
          	return tmp;
          }
          
          alpha, beta = sort([alpha, beta])
          function code(alpha, beta)
          	tmp = 0.0
          	if (beta <= 1.65)
          		tmp = fma(beta, fma(beta, -0.011574074074074073, -0.027777777777777776), 0.08333333333333333);
          	else
          		tmp = Float64(1.0 / Float64(beta * beta));
          	end
          	return tmp
          end
          
          NOTE: alpha and beta should be sorted in increasing order before calling this function.
          code[alpha_, beta_] := If[LessEqual[beta, 1.65], N[(beta * N[(beta * -0.011574074074074073 + -0.027777777777777776), $MachinePrecision] + 0.08333333333333333), $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 1.65:\\
          \;\;\;\;\mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, -0.011574074074074073, -0.027777777777777776\right), 0.08333333333333333\right)\\
          
          \mathbf{else}:\\
          \;\;\;\;\frac{1}{\beta \cdot \beta}\\
          
          
          \end{array}
          \end{array}
          
          Derivation
          1. Split input into 2 regimes
          2. if beta < 1.6499999999999999

            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 alpha around 0

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

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

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

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

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

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

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

                \[\leadsto \frac{\frac{1 + \beta}{\left(\beta + 2\right) \cdot \color{blue}{\left(\beta + 2\right)}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
              8. +-lowering-+.f6465.5

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

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

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

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

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

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

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

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

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

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

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

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

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

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

                \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\left(\alpha + \color{blue}{\left(\beta + 3\right)}\right) \cdot \left(\beta + 2\right)} \]
              14. +-lowering-+.f6465.5

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

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

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

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

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

                \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\color{blue}{\left(\beta + 2\right)} \cdot \left(3 + \beta\right)} \]
              4. +-lowering-+.f6463.6

                \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\left(\beta + 2\right) \cdot \color{blue}{\left(3 + \beta\right)}} \]
            10. Simplified63.6%

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

              \[\leadsto \color{blue}{\frac{1}{12} + \beta \cdot \left(\frac{-5}{432} \cdot \beta - \frac{1}{36}\right)} \]
            12. Step-by-step derivation
              1. +-commutativeN/A

                \[\leadsto \color{blue}{\beta \cdot \left(\frac{-5}{432} \cdot \beta - \frac{1}{36}\right) + \frac{1}{12}} \]
              2. accelerator-lowering-fma.f64N/A

                \[\leadsto \color{blue}{\mathsf{fma}\left(\beta, \frac{-5}{432} \cdot \beta - \frac{1}{36}, \frac{1}{12}\right)} \]
              3. sub-negN/A

                \[\leadsto \mathsf{fma}\left(\beta, \color{blue}{\frac{-5}{432} \cdot \beta + \left(\mathsf{neg}\left(\frac{1}{36}\right)\right)}, \frac{1}{12}\right) \]
              4. *-commutativeN/A

                \[\leadsto \mathsf{fma}\left(\beta, \color{blue}{\beta \cdot \frac{-5}{432}} + \left(\mathsf{neg}\left(\frac{1}{36}\right)\right), \frac{1}{12}\right) \]
              5. metadata-evalN/A

                \[\leadsto \mathsf{fma}\left(\beta, \beta \cdot \frac{-5}{432} + \color{blue}{\frac{-1}{36}}, \frac{1}{12}\right) \]
              6. accelerator-lowering-fma.f6463.3

                \[\leadsto \mathsf{fma}\left(\beta, \color{blue}{\mathsf{fma}\left(\beta, -0.011574074074074073, -0.027777777777777776\right)}, 0.08333333333333333\right) \]
            13. Simplified63.3%

              \[\leadsto \color{blue}{\mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, -0.011574074074074073, -0.027777777777777776\right), 0.08333333333333333\right)} \]

            if 1.6499999999999999 < beta

            1. Initial program 87.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. Add Preprocessing
            3. Taylor expanded in beta around inf

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

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

                \[\leadsto \frac{\color{blue}{1 + \alpha}}{{\beta}^{2}} \]
              3. unpow2N/A

                \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
              4. *-lowering-*.f6477.4

                \[\leadsto \frac{1 + \alpha}{\color{blue}{\beta \cdot \beta}} \]
            5. Simplified77.4%

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

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

                \[\leadsto \color{blue}{\frac{1}{{\beta}^{2}}} \]
              2. unpow2N/A

                \[\leadsto \frac{1}{\color{blue}{\beta \cdot \beta}} \]
              3. *-lowering-*.f6474.0

                \[\leadsto \frac{1}{\color{blue}{\beta \cdot \beta}} \]
            8. Simplified74.0%

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

          Alternative 16: 48.4% accurate, 3.6× speedup?

          \[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\alpha \leq 2.8 \cdot 10^{+113}:\\ \;\;\;\;\frac{0.25}{\beta + 3}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\alpha \cdot \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 (<= alpha 2.8e+113) (/ 0.25 (+ beta 3.0)) (/ 1.0 (* alpha alpha))))
          assert(alpha < beta);
          double code(double alpha, double beta) {
          	double tmp;
          	if (alpha <= 2.8e+113) {
          		tmp = 0.25 / (beta + 3.0);
          	} else {
          		tmp = 1.0 / (alpha * 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 (alpha <= 2.8d+113) then
                  tmp = 0.25d0 / (beta + 3.0d0)
              else
                  tmp = 1.0d0 / (alpha * alpha)
              end if
              code = tmp
          end function
          
          assert alpha < beta;
          public static double code(double alpha, double beta) {
          	double tmp;
          	if (alpha <= 2.8e+113) {
          		tmp = 0.25 / (beta + 3.0);
          	} else {
          		tmp = 1.0 / (alpha * alpha);
          	}
          	return tmp;
          }
          
          [alpha, beta] = sort([alpha, beta])
          def code(alpha, beta):
          	tmp = 0
          	if alpha <= 2.8e+113:
          		tmp = 0.25 / (beta + 3.0)
          	else:
          		tmp = 1.0 / (alpha * alpha)
          	return tmp
          
          alpha, beta = sort([alpha, beta])
          function code(alpha, beta)
          	tmp = 0.0
          	if (alpha <= 2.8e+113)
          		tmp = Float64(0.25 / Float64(beta + 3.0));
          	else
          		tmp = Float64(1.0 / Float64(alpha * alpha));
          	end
          	return tmp
          end
          
          alpha, beta = num2cell(sort([alpha, beta])){:}
          function tmp_2 = code(alpha, beta)
          	tmp = 0.0;
          	if (alpha <= 2.8e+113)
          		tmp = 0.25 / (beta + 3.0);
          	else
          		tmp = 1.0 / (alpha * 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[alpha, 2.8e+113], N[(0.25 / N[(beta + 3.0), $MachinePrecision]), $MachinePrecision], N[(1.0 / N[(alpha * alpha), $MachinePrecision]), $MachinePrecision]]
          
          \begin{array}{l}
          [alpha, beta] = \mathsf{sort}([alpha, beta])\\
          \\
          \begin{array}{l}
          \mathbf{if}\;\alpha \leq 2.8 \cdot 10^{+113}:\\
          \;\;\;\;\frac{0.25}{\beta + 3}\\
          
          \mathbf{else}:\\
          \;\;\;\;\frac{1}{\alpha \cdot \alpha}\\
          
          
          \end{array}
          \end{array}
          
          Derivation
          1. Split input into 2 regimes
          2. if alpha < 2.79999999999999998e113

            1. Initial program 99.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 alpha around 0

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

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

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

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

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

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

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

                \[\leadsto \frac{\frac{1 + \beta}{\left(\beta + 2\right) \cdot \color{blue}{\left(\beta + 2\right)}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
              8. +-lowering-+.f6486.2

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

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

              \[\leadsto \frac{\color{blue}{\frac{1}{4}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
            7. Step-by-step derivation
              1. Simplified56.4%

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

                \[\leadsto \frac{\frac{1}{4}}{\color{blue}{3 + \beta}} \]
              3. Step-by-step derivation
                1. +-lowering-+.f6455.5

                  \[\leadsto \frac{0.25}{\color{blue}{3 + \beta}} \]
              4. Simplified55.5%

                \[\leadsto \frac{0.25}{\color{blue}{3 + \beta}} \]

              if 2.79999999999999998e113 < alpha

              1. Initial program 83.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. Add Preprocessing
              3. Taylor expanded in beta around 0

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

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

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

                  \[\leadsto \frac{1 + \alpha}{\color{blue}{{\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)}} \]
                4. unpow2N/A

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

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

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

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

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

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

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

                  \[\leadsto \color{blue}{\frac{1}{{\alpha}^{2}}} \]
                2. unpow2N/A

                  \[\leadsto \frac{1}{\color{blue}{\alpha \cdot \alpha}} \]
                3. *-lowering-*.f6479.6

                  \[\leadsto \frac{1}{\color{blue}{\alpha \cdot \alpha}} \]
              8. Simplified79.6%

                \[\leadsto \color{blue}{\frac{1}{\alpha \cdot \alpha}} \]
            8. Recombined 2 regimes into one program.
            9. Final simplification61.1%

              \[\leadsto \begin{array}{l} \mathbf{if}\;\alpha \leq 2.8 \cdot 10^{+113}:\\ \;\;\;\;\frac{0.25}{\beta + 3}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\alpha \cdot \alpha}\\ \end{array} \]
            10. Add Preprocessing

            Alternative 17: 47.6% accurate, 4.4× speedup?

            \[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 1.56:\\ \;\;\;\;\mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, -0.011574074074074073, -0.027777777777777776\right), 0.08333333333333333\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{0.25}{\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.56)
               (fma
                beta
                (fma beta -0.011574074074074073 -0.027777777777777776)
                0.08333333333333333)
               (/ 0.25 beta)))
            assert(alpha < beta);
            double code(double alpha, double beta) {
            	double tmp;
            	if (beta <= 1.56) {
            		tmp = fma(beta, fma(beta, -0.011574074074074073, -0.027777777777777776), 0.08333333333333333);
            	} else {
            		tmp = 0.25 / beta;
            	}
            	return tmp;
            }
            
            alpha, beta = sort([alpha, beta])
            function code(alpha, beta)
            	tmp = 0.0
            	if (beta <= 1.56)
            		tmp = fma(beta, fma(beta, -0.011574074074074073, -0.027777777777777776), 0.08333333333333333);
            	else
            		tmp = Float64(0.25 / beta);
            	end
            	return tmp
            end
            
            NOTE: alpha and beta should be sorted in increasing order before calling this function.
            code[alpha_, beta_] := If[LessEqual[beta, 1.56], N[(beta * N[(beta * -0.011574074074074073 + -0.027777777777777776), $MachinePrecision] + 0.08333333333333333), $MachinePrecision], N[(0.25 / beta), $MachinePrecision]]
            
            \begin{array}{l}
            [alpha, beta] = \mathsf{sort}([alpha, beta])\\
            \\
            \begin{array}{l}
            \mathbf{if}\;\beta \leq 1.56:\\
            \;\;\;\;\mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, -0.011574074074074073, -0.027777777777777776\right), 0.08333333333333333\right)\\
            
            \mathbf{else}:\\
            \;\;\;\;\frac{0.25}{\beta}\\
            
            
            \end{array}
            \end{array}
            
            Derivation
            1. Split input into 2 regimes
            2. if beta < 1.5600000000000001

              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 alpha around 0

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

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

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

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

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

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

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

                  \[\leadsto \frac{\frac{1 + \beta}{\left(\beta + 2\right) \cdot \color{blue}{\left(\beta + 2\right)}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
                8. +-lowering-+.f6465.5

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

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

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

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

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

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

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

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

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

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

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

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

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

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

                  \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\left(\alpha + \color{blue}{\left(\beta + 3\right)}\right) \cdot \left(\beta + 2\right)} \]
                14. +-lowering-+.f6465.5

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

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

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

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

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

                  \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\color{blue}{\left(\beta + 2\right)} \cdot \left(3 + \beta\right)} \]
                4. +-lowering-+.f6463.6

                  \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\left(\beta + 2\right) \cdot \color{blue}{\left(3 + \beta\right)}} \]
              10. Simplified63.6%

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

                \[\leadsto \color{blue}{\frac{1}{12} + \beta \cdot \left(\frac{-5}{432} \cdot \beta - \frac{1}{36}\right)} \]
              12. Step-by-step derivation
                1. +-commutativeN/A

                  \[\leadsto \color{blue}{\beta \cdot \left(\frac{-5}{432} \cdot \beta - \frac{1}{36}\right) + \frac{1}{12}} \]
                2. accelerator-lowering-fma.f64N/A

                  \[\leadsto \color{blue}{\mathsf{fma}\left(\beta, \frac{-5}{432} \cdot \beta - \frac{1}{36}, \frac{1}{12}\right)} \]
                3. sub-negN/A

                  \[\leadsto \mathsf{fma}\left(\beta, \color{blue}{\frac{-5}{432} \cdot \beta + \left(\mathsf{neg}\left(\frac{1}{36}\right)\right)}, \frac{1}{12}\right) \]
                4. *-commutativeN/A

                  \[\leadsto \mathsf{fma}\left(\beta, \color{blue}{\beta \cdot \frac{-5}{432}} + \left(\mathsf{neg}\left(\frac{1}{36}\right)\right), \frac{1}{12}\right) \]
                5. metadata-evalN/A

                  \[\leadsto \mathsf{fma}\left(\beta, \beta \cdot \frac{-5}{432} + \color{blue}{\frac{-1}{36}}, \frac{1}{12}\right) \]
                6. accelerator-lowering-fma.f6463.3

                  \[\leadsto \mathsf{fma}\left(\beta, \color{blue}{\mathsf{fma}\left(\beta, -0.011574074074074073, -0.027777777777777776\right)}, 0.08333333333333333\right) \]
              13. Simplified63.3%

                \[\leadsto \color{blue}{\mathsf{fma}\left(\beta, \mathsf{fma}\left(\beta, -0.011574074074074073, -0.027777777777777776\right), 0.08333333333333333\right)} \]

              if 1.5600000000000001 < beta

              1. Initial program 87.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. Add Preprocessing
              3. Taylor expanded in alpha around 0

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

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

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

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

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

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

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

                  \[\leadsto \frac{\frac{1 + \beta}{\left(\beta + 2\right) \cdot \color{blue}{\left(\beta + 2\right)}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
                8. +-lowering-+.f6478.6

                  \[\leadsto \frac{\frac{1 + \beta}{\left(\beta + 2\right) \cdot \color{blue}{\left(\beta + 2\right)}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
              5. Simplified78.6%

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

                \[\leadsto \frac{\color{blue}{\frac{1}{4}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
              7. Step-by-step derivation
                1. Simplified7.4%

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

                  \[\leadsto \frac{\frac{1}{4}}{\color{blue}{\beta}} \]
                3. Step-by-step derivation
                  1. Simplified6.9%

                    \[\leadsto \frac{0.25}{\color{blue}{\beta}} \]
                4. Recombined 2 regimes into one program.
                5. Add Preprocessing

                Alternative 18: 47.5% accurate, 4.7× speedup?

                \[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \begin{array}{l} \mathbf{if}\;\beta \leq 2.6:\\ \;\;\;\;\mathsf{fma}\left(-0.027777777777777776, \beta, 0.08333333333333333\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{0.25}{\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.6)
                   (fma -0.027777777777777776 beta 0.08333333333333333)
                   (/ 0.25 beta)))
                assert(alpha < beta);
                double code(double alpha, double beta) {
                	double tmp;
                	if (beta <= 2.6) {
                		tmp = fma(-0.027777777777777776, beta, 0.08333333333333333);
                	} else {
                		tmp = 0.25 / beta;
                	}
                	return tmp;
                }
                
                alpha, beta = sort([alpha, beta])
                function code(alpha, beta)
                	tmp = 0.0
                	if (beta <= 2.6)
                		tmp = fma(-0.027777777777777776, beta, 0.08333333333333333);
                	else
                		tmp = Float64(0.25 / beta);
                	end
                	return tmp
                end
                
                NOTE: alpha and beta should be sorted in increasing order before calling this function.
                code[alpha_, beta_] := If[LessEqual[beta, 2.6], N[(-0.027777777777777776 * beta + 0.08333333333333333), $MachinePrecision], N[(0.25 / beta), $MachinePrecision]]
                
                \begin{array}{l}
                [alpha, beta] = \mathsf{sort}([alpha, beta])\\
                \\
                \begin{array}{l}
                \mathbf{if}\;\beta \leq 2.6:\\
                \;\;\;\;\mathsf{fma}\left(-0.027777777777777776, \beta, 0.08333333333333333\right)\\
                
                \mathbf{else}:\\
                \;\;\;\;\frac{0.25}{\beta}\\
                
                
                \end{array}
                \end{array}
                
                Derivation
                1. Split input into 2 regimes
                2. if beta < 2.60000000000000009

                  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 alpha around 0

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

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

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

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

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

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

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

                      \[\leadsto \frac{\frac{1 + \beta}{\left(\beta + 2\right) \cdot \color{blue}{\left(\beta + 2\right)}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
                    8. +-lowering-+.f6465.5

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

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

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

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

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

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

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

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

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

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

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

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

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

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

                      \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\left(\alpha + \color{blue}{\left(\beta + 3\right)}\right) \cdot \left(\beta + 2\right)} \]
                    14. +-lowering-+.f6465.5

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

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

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

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

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

                      \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\color{blue}{\left(\beta + 2\right)} \cdot \left(3 + \beta\right)} \]
                    4. +-lowering-+.f6463.6

                      \[\leadsto \frac{\frac{1 + \beta}{\beta + 2}}{\left(\beta + 2\right) \cdot \color{blue}{\left(3 + \beta\right)}} \]
                  10. Simplified63.6%

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

                    \[\leadsto \color{blue}{\frac{1}{12} + \frac{-1}{36} \cdot \beta} \]
                  12. Step-by-step derivation
                    1. +-commutativeN/A

                      \[\leadsto \color{blue}{\frac{-1}{36} \cdot \beta + \frac{1}{12}} \]
                    2. accelerator-lowering-fma.f6463.3

                      \[\leadsto \color{blue}{\mathsf{fma}\left(-0.027777777777777776, \beta, 0.08333333333333333\right)} \]
                  13. Simplified63.3%

                    \[\leadsto \color{blue}{\mathsf{fma}\left(-0.027777777777777776, \beta, 0.08333333333333333\right)} \]

                  if 2.60000000000000009 < beta

                  1. Initial program 87.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. Add Preprocessing
                  3. Taylor expanded in alpha around 0

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

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

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

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

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

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

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

                      \[\leadsto \frac{\frac{1 + \beta}{\left(\beta + 2\right) \cdot \color{blue}{\left(\beta + 2\right)}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
                    8. +-lowering-+.f6478.6

                      \[\leadsto \frac{\frac{1 + \beta}{\left(\beta + 2\right) \cdot \color{blue}{\left(\beta + 2\right)}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
                  5. Simplified78.6%

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

                    \[\leadsto \frac{\color{blue}{\frac{1}{4}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
                  7. Step-by-step derivation
                    1. Simplified7.4%

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

                      \[\leadsto \frac{\frac{1}{4}}{\color{blue}{\beta}} \]
                    3. Step-by-step derivation
                      1. Simplified6.9%

                        \[\leadsto \frac{0.25}{\color{blue}{\beta}} \]
                    4. Recombined 2 regimes into one program.
                    5. Add Preprocessing

                    Alternative 19: 47.4% accurate, 5.6× speedup?

                    \[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \frac{0.25}{\beta + 3} \end{array} \]
                    NOTE: alpha and beta should be sorted in increasing order before calling this function.
                    (FPCore (alpha beta) :precision binary64 (/ 0.25 (+ beta 3.0)))
                    assert(alpha < beta);
                    double code(double alpha, double beta) {
                    	return 0.25 / (beta + 3.0);
                    }
                    
                    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.25d0 / (beta + 3.0d0)
                    end function
                    
                    assert alpha < beta;
                    public static double code(double alpha, double beta) {
                    	return 0.25 / (beta + 3.0);
                    }
                    
                    [alpha, beta] = sort([alpha, beta])
                    def code(alpha, beta):
                    	return 0.25 / (beta + 3.0)
                    
                    alpha, beta = sort([alpha, beta])
                    function code(alpha, beta)
                    	return Float64(0.25 / Float64(beta + 3.0))
                    end
                    
                    alpha, beta = num2cell(sort([alpha, beta])){:}
                    function tmp = code(alpha, beta)
                    	tmp = 0.25 / (beta + 3.0);
                    end
                    
                    NOTE: alpha and beta should be sorted in increasing order before calling this function.
                    code[alpha_, beta_] := N[(0.25 / N[(beta + 3.0), $MachinePrecision]), $MachinePrecision]
                    
                    \begin{array}{l}
                    [alpha, beta] = \mathsf{sort}([alpha, beta])\\
                    \\
                    \frac{0.25}{\beta + 3}
                    \end{array}
                    
                    Derivation
                    1. Initial program 95.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. Add Preprocessing
                    3. Taylor expanded in alpha around 0

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

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

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

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

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

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

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

                        \[\leadsto \frac{\frac{1 + \beta}{\left(\beta + 2\right) \cdot \color{blue}{\left(\beta + 2\right)}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
                      8. +-lowering-+.f6470.1

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

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

                      \[\leadsto \frac{\color{blue}{\frac{1}{4}}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1} \]
                    7. Step-by-step derivation
                      1. Simplified44.8%

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

                        \[\leadsto \frac{\frac{1}{4}}{\color{blue}{3 + \beta}} \]
                      3. Step-by-step derivation
                        1. +-lowering-+.f6443.4

                          \[\leadsto \frac{0.25}{\color{blue}{3 + \beta}} \]
                      4. Simplified43.4%

                        \[\leadsto \frac{0.25}{\color{blue}{3 + \beta}} \]
                      5. Final simplification43.4%

                        \[\leadsto \frac{0.25}{\beta + 3} \]
                      6. Add Preprocessing

                      Alternative 20: 45.6% accurate, 12.0× speedup?

                      \[\begin{array}{l} [alpha, beta] = \mathsf{sort}([alpha, beta])\\ \\ \mathsf{fma}\left(\alpha, -0.027777777777777776, 0.08333333333333333\right) \end{array} \]
                      NOTE: alpha and beta should be sorted in increasing order before calling this function.
                      (FPCore (alpha beta)
                       :precision binary64
                       (fma alpha -0.027777777777777776 0.08333333333333333))
                      assert(alpha < beta);
                      double code(double alpha, double beta) {
                      	return fma(alpha, -0.027777777777777776, 0.08333333333333333);
                      }
                      
                      alpha, beta = sort([alpha, beta])
                      function code(alpha, beta)
                      	return fma(alpha, -0.027777777777777776, 0.08333333333333333)
                      end
                      
                      NOTE: alpha and beta should be sorted in increasing order before calling this function.
                      code[alpha_, beta_] := N[(alpha * -0.027777777777777776 + 0.08333333333333333), $MachinePrecision]
                      
                      \begin{array}{l}
                      [alpha, beta] = \mathsf{sort}([alpha, beta])\\
                      \\
                      \mathsf{fma}\left(\alpha, -0.027777777777777776, 0.08333333333333333\right)
                      \end{array}
                      
                      Derivation
                      1. Initial program 95.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. Add Preprocessing
                      3. Taylor expanded in beta around 0

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

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

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

                          \[\leadsto \frac{1 + \alpha}{\color{blue}{{\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)}} \]
                        4. unpow2N/A

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

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

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

                          \[\leadsto \frac{1 + \alpha}{\left(\left(2 + \alpha\right) \cdot \color{blue}{\left(2 + \alpha\right)}\right) \cdot \left(3 + \alpha\right)} \]
                        8. +-lowering-+.f6464.6

                          \[\leadsto \frac{1 + \alpha}{\left(\left(2 + \alpha\right) \cdot \left(2 + \alpha\right)\right) \cdot \color{blue}{\left(3 + \alpha\right)}} \]
                      5. Simplified64.6%

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

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

                          \[\leadsto \color{blue}{\frac{-1}{36} \cdot \alpha + \frac{1}{12}} \]
                        2. *-commutativeN/A

                          \[\leadsto \color{blue}{\alpha \cdot \frac{-1}{36}} + \frac{1}{12} \]
                        3. accelerator-lowering-fma.f6441.8

                          \[\leadsto \color{blue}{\mathsf{fma}\left(\alpha, -0.027777777777777776, 0.08333333333333333\right)} \]
                      8. Simplified41.8%

                        \[\leadsto \color{blue}{\mathsf{fma}\left(\alpha, -0.027777777777777776, 0.08333333333333333\right)} \]
                      9. Add Preprocessing

                      Alternative 21: 45.3% accurate, 84.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.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. Add Preprocessing
                      3. Taylor expanded in beta around 0

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

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

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

                          \[\leadsto \frac{1 + \alpha}{\color{blue}{{\left(2 + \alpha\right)}^{2} \cdot \left(3 + \alpha\right)}} \]
                        4. unpow2N/A

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

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

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

                          \[\leadsto \frac{1 + \alpha}{\left(\left(2 + \alpha\right) \cdot \color{blue}{\left(2 + \alpha\right)}\right) \cdot \left(3 + \alpha\right)} \]
                        8. +-lowering-+.f6464.6

                          \[\leadsto \frac{1 + \alpha}{\left(\left(2 + \alpha\right) \cdot \left(2 + \alpha\right)\right) \cdot \color{blue}{\left(3 + \alpha\right)}} \]
                      5. Simplified64.6%

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

                        \[\leadsto \color{blue}{\frac{1}{12}} \]
                      7. Step-by-step derivation
                        1. Simplified42.1%

                          \[\leadsto \color{blue}{0.08333333333333333} \]
                        2. Add Preprocessing

                        Reproduce

                        ?
                        herbie shell --seed 2024197 
                        (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)))