\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}\;\beta \le 5.874077370608373 \cdot 10^{+160}:\\
\;\;\;\;\frac{\frac{\frac{1}{\frac{\left(\alpha + \beta\right) + 2}{1.0 + \mathsf{fma}\left(\beta, \alpha, \alpha + \beta\right)}}}{\left(\alpha + \beta\right) + 2}}{\left(\left(\alpha + \beta\right) + 2\right) + 1.0}\\
\mathbf{else}:\\
\;\;\;\;\frac{\frac{\frac{1}{\left(\frac{1}{\beta} - \frac{1}{\beta \cdot \beta}\right) + \frac{1}{\alpha}}}{\left(\alpha + \beta\right) + 2}}{\left(\left(\alpha + \beta\right) + 2\right) + 1.0}\\
\end{array}double f(double alpha, double beta) {
double r5188339 = alpha;
double r5188340 = beta;
double r5188341 = r5188339 + r5188340;
double r5188342 = r5188340 * r5188339;
double r5188343 = r5188341 + r5188342;
double r5188344 = 1.0;
double r5188345 = r5188343 + r5188344;
double r5188346 = 2.0;
double r5188347 = 1.0;
double r5188348 = r5188346 * r5188347;
double r5188349 = r5188341 + r5188348;
double r5188350 = r5188345 / r5188349;
double r5188351 = r5188350 / r5188349;
double r5188352 = r5188349 + r5188344;
double r5188353 = r5188351 / r5188352;
return r5188353;
}
double f(double alpha, double beta) {
double r5188354 = beta;
double r5188355 = 5.874077370608373e+160;
bool r5188356 = r5188354 <= r5188355;
double r5188357 = 1.0;
double r5188358 = alpha;
double r5188359 = r5188358 + r5188354;
double r5188360 = 2.0;
double r5188361 = r5188359 + r5188360;
double r5188362 = 1.0;
double r5188363 = fma(r5188354, r5188358, r5188359);
double r5188364 = r5188362 + r5188363;
double r5188365 = r5188361 / r5188364;
double r5188366 = r5188357 / r5188365;
double r5188367 = r5188366 / r5188361;
double r5188368 = r5188361 + r5188362;
double r5188369 = r5188367 / r5188368;
double r5188370 = r5188357 / r5188354;
double r5188371 = r5188354 * r5188354;
double r5188372 = r5188357 / r5188371;
double r5188373 = r5188370 - r5188372;
double r5188374 = r5188357 / r5188358;
double r5188375 = r5188373 + r5188374;
double r5188376 = r5188357 / r5188375;
double r5188377 = r5188376 / r5188361;
double r5188378 = r5188377 / r5188368;
double r5188379 = r5188356 ? r5188369 : r5188378;
return r5188379;
}



Bits error versus alpha



Bits error versus beta
if beta < 5.874077370608373e+160Initial program 1.0
Simplified1.0
rmApplied clear-num1.1
if 5.874077370608373e+160 < beta Initial program 16.3
Simplified16.3
rmApplied clear-num16.3
Taylor expanded around inf 0.1
Simplified0.1
Final simplification0.9
herbie shell --seed 2019146 +o rules:numerics
(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)))