Average Error: 3.6 → 2.7
Time: 31.3s
Precision: 64
\[\alpha \gt -1 \land \beta \gt -1\]
\[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1.0}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1.0}\]
\[\begin{array}{l} \mathbf{if}\;\alpha \le 3.9275252152036123 \cdot 10^{+114}:\\ \;\;\;\;\frac{\frac{\frac{1.0 + \left(\beta \cdot \alpha + \left(\beta + \alpha\right)\right)}{\left(\beta + \alpha\right) + 2}}{\left(\beta + \alpha\right) + 2}}{1.0 + \left(\left(\beta + \alpha\right) + 2\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{\left(1 - \frac{1.0}{\alpha}\right) + \frac{2.0}{\alpha \cdot \alpha}}{\left(\beta + \alpha\right) + 2}}{1.0 + \left(\left(\beta + \alpha\right) + 2\right)}\\ \end{array}\]
\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1.0}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1.0}
\begin{array}{l}
\mathbf{if}\;\alpha \le 3.9275252152036123 \cdot 10^{+114}:\\
\;\;\;\;\frac{\frac{\frac{1.0 + \left(\beta \cdot \alpha + \left(\beta + \alpha\right)\right)}{\left(\beta + \alpha\right) + 2}}{\left(\beta + \alpha\right) + 2}}{1.0 + \left(\left(\beta + \alpha\right) + 2\right)}\\

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

\end{array}
double f(double alpha, double beta) {
        double r2358310 = alpha;
        double r2358311 = beta;
        double r2358312 = r2358310 + r2358311;
        double r2358313 = r2358311 * r2358310;
        double r2358314 = r2358312 + r2358313;
        double r2358315 = 1.0;
        double r2358316 = r2358314 + r2358315;
        double r2358317 = 2.0;
        double r2358318 = 1.0;
        double r2358319 = r2358317 * r2358318;
        double r2358320 = r2358312 + r2358319;
        double r2358321 = r2358316 / r2358320;
        double r2358322 = r2358321 / r2358320;
        double r2358323 = r2358320 + r2358315;
        double r2358324 = r2358322 / r2358323;
        return r2358324;
}

double f(double alpha, double beta) {
        double r2358325 = alpha;
        double r2358326 = 3.9275252152036123e+114;
        bool r2358327 = r2358325 <= r2358326;
        double r2358328 = 1.0;
        double r2358329 = beta;
        double r2358330 = r2358329 * r2358325;
        double r2358331 = r2358329 + r2358325;
        double r2358332 = r2358330 + r2358331;
        double r2358333 = r2358328 + r2358332;
        double r2358334 = 2.0;
        double r2358335 = r2358331 + r2358334;
        double r2358336 = r2358333 / r2358335;
        double r2358337 = r2358336 / r2358335;
        double r2358338 = r2358328 + r2358335;
        double r2358339 = r2358337 / r2358338;
        double r2358340 = 1.0;
        double r2358341 = r2358328 / r2358325;
        double r2358342 = r2358340 - r2358341;
        double r2358343 = 2.0;
        double r2358344 = r2358325 * r2358325;
        double r2358345 = r2358343 / r2358344;
        double r2358346 = r2358342 + r2358345;
        double r2358347 = r2358346 / r2358335;
        double r2358348 = r2358347 / r2358338;
        double r2358349 = r2358327 ? r2358339 : r2358348;
        return r2358349;
}

Error

Bits error versus alpha

Bits error versus beta

Try it out

Your Program's Arguments

Results

Enter valid numbers for all inputs

Derivation

  1. Split input into 2 regimes
  2. if alpha < 3.9275252152036123e+114

    1. Initial program 0.8

      \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1.0}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1.0}\]
    2. Using strategy rm
    3. Applied +-commutative0.8

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

    if 3.9275252152036123e+114 < alpha

    1. Initial program 14.1

      \[\frac{\frac{\frac{\left(\left(\alpha + \beta\right) + \beta \cdot \alpha\right) + 1.0}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1.0}\]
    2. Taylor expanded around inf 9.6

      \[\leadsto \frac{\frac{\color{blue}{\left(2.0 \cdot \frac{1}{{\alpha}^{2}} + 1\right) - 1.0 \cdot \frac{1}{\alpha}}}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\left(\left(\alpha + \beta\right) + 2 \cdot 1\right) + 1.0}\]
    3. Simplified9.6

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

    \[\leadsto \begin{array}{l} \mathbf{if}\;\alpha \le 3.9275252152036123 \cdot 10^{+114}:\\ \;\;\;\;\frac{\frac{\frac{1.0 + \left(\beta \cdot \alpha + \left(\beta + \alpha\right)\right)}{\left(\beta + \alpha\right) + 2}}{\left(\beta + \alpha\right) + 2}}{1.0 + \left(\left(\beta + \alpha\right) + 2\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{\left(1 - \frac{1.0}{\alpha}\right) + \frac{2.0}{\alpha \cdot \alpha}}{\left(\beta + \alpha\right) + 2}}{1.0 + \left(\left(\beta + \alpha\right) + 2\right)}\\ \end{array}\]

Reproduce

herbie shell --seed 2019153 
(FPCore (alpha beta)
  :name "Octave 3.8, jcobi/3"
  :pre (and (> alpha -1) (> beta -1))
  (/ (/ (/ (+ (+ (+ alpha beta) (* beta alpha)) 1.0) (+ (+ alpha beta) (* 2 1))) (+ (+ alpha beta) (* 2 1))) (+ (+ (+ alpha beta) (* 2 1)) 1.0)))