\frac{\frac{\left(i \cdot \left(\left(\alpha + \beta\right) + i\right)\right) \cdot \left(\beta \cdot \alpha + i \cdot \left(\left(\alpha + \beta\right) + i\right)\right)}{\left(\left(\alpha + \beta\right) + 2 \cdot i\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot i\right)}}{\left(\left(\alpha + \beta\right) + 2 \cdot i\right) \cdot \left(\left(\alpha + \beta\right) + 2 \cdot i\right) - 1}\begin{array}{l}
\mathbf{if}\;\alpha \le 1.4341699009264947 \cdot 10^{199}:\\
\;\;\;\;\frac{\left(\frac{i}{\left(\left(\alpha + \beta\right) + 2 \cdot i\right) + \sqrt{1}} \cdot \frac{\left(\alpha + \beta\right) + i}{\left(\left(\alpha + \beta\right) + 2 \cdot i\right) - \sqrt{1}}\right) \cdot \sqrt{\mathsf{fma}\left(\beta, \alpha, i \cdot \left(\left(\alpha + \beta\right) + i\right)\right)}}{\frac{\mathsf{fma}\left(i, 2, \alpha + \beta\right)}{\frac{\sqrt{\mathsf{fma}\left(\beta, \alpha, i \cdot \left(\left(\alpha + \beta\right) + i\right)\right)}}{\mathsf{fma}\left(i, 2, \alpha + \beta\right)}}}\\
\mathbf{else}:\\
\;\;\;\;0\\
\end{array}double f(double alpha, double beta, double i) {
double r373 = i;
double r374 = alpha;
double r375 = beta;
double r376 = r374 + r375;
double r377 = r376 + r373;
double r378 = r373 * r377;
double r379 = r375 * r374;
double r380 = r379 + r378;
double r381 = r378 * r380;
double r382 = 2.0;
double r383 = r382 * r373;
double r384 = r376 + r383;
double r385 = r384 * r384;
double r386 = r381 / r385;
double r387 = 1.0;
double r388 = r385 - r387;
double r389 = r386 / r388;
return r389;
}
double f(double alpha, double beta, double i) {
double r390 = alpha;
double r391 = 1.4341699009264947e+199;
bool r392 = r390 <= r391;
double r393 = i;
double r394 = beta;
double r395 = r390 + r394;
double r396 = 2.0;
double r397 = r396 * r393;
double r398 = r395 + r397;
double r399 = 1.0;
double r400 = sqrt(r399);
double r401 = r398 + r400;
double r402 = r393 / r401;
double r403 = r395 + r393;
double r404 = r398 - r400;
double r405 = r403 / r404;
double r406 = r402 * r405;
double r407 = r393 * r403;
double r408 = fma(r394, r390, r407);
double r409 = sqrt(r408);
double r410 = r406 * r409;
double r411 = fma(r393, r396, r395);
double r412 = r409 / r411;
double r413 = r411 / r412;
double r414 = r410 / r413;
double r415 = 0.0;
double r416 = r392 ? r414 : r415;
return r416;
}



Bits error versus alpha



Bits error versus beta



Bits error versus i
if alpha < 1.4341699009264947e+199Initial program 52.2
Simplified51.6
rmApplied associate-/l*47.1
rmApplied *-un-lft-identity47.1
Applied add-sqr-sqrt47.1
Applied times-frac47.1
Applied times-frac38.2
Applied associate-/r*36.4
Simplified36.4
rmApplied add-sqr-sqrt36.4
Applied difference-of-squares36.4
Applied times-frac34.3
if 1.4341699009264947e+199 < alpha Initial program 64.0
Simplified55.5
Taylor expanded around inf 43.7
Final simplification35.4
herbie shell --seed 2020025 +o rules:numerics
(FPCore (alpha beta i)
:name "Octave 3.8, jcobi/4"
:precision binary64
:pre (and (> alpha -1) (> beta -1) (> i 1))
(/ (/ (* (* i (+ (+ alpha beta) i)) (+ (* beta alpha) (* i (+ (+ alpha beta) i)))) (* (+ (+ alpha beta) (* 2 i)) (+ (+ alpha beta) (* 2 i)))) (- (* (+ (+ alpha beta) (* 2 i)) (+ (+ alpha beta) (* 2 i))) 1)))