\frac{\frac{\beta - \alpha}{\left(\alpha + \beta\right) + 2} + 1}{2}\begin{array}{l}
\mathbf{if}\;\alpha \le 16738773.27412901632487773895263671875:\\
\;\;\;\;\frac{e^{\log \left(\frac{\beta}{\left(\alpha + \beta\right) + 2} - \left(\frac{\alpha}{\left(\alpha + \beta\right) + 2} - 1\right)\right)}}{2}\\
\mathbf{else}:\\
\;\;\;\;\frac{\mathsf{fma}\left(\frac{\sqrt[3]{\beta} \cdot \sqrt[3]{\beta}}{\sqrt[3]{\left(\alpha + \beta\right) + 2} \cdot \sqrt[3]{\left(\alpha + \beta\right) + 2}}, \frac{\sqrt[3]{\beta}}{\sqrt[3]{\left(\alpha + \beta\right) + 2}}, -\left(\left(\frac{4}{\alpha \cdot \alpha} - \frac{2}{\alpha}\right) - \frac{8}{\alpha \cdot \left(\alpha \cdot \alpha\right)}\right)\right)}{2}\\
\end{array}double f(double alpha, double beta) {
double r10702563 = beta;
double r10702564 = alpha;
double r10702565 = r10702563 - r10702564;
double r10702566 = r10702564 + r10702563;
double r10702567 = 2.0;
double r10702568 = r10702566 + r10702567;
double r10702569 = r10702565 / r10702568;
double r10702570 = 1.0;
double r10702571 = r10702569 + r10702570;
double r10702572 = r10702571 / r10702567;
return r10702572;
}
double f(double alpha, double beta) {
double r10702573 = alpha;
double r10702574 = 16738773.274129016;
bool r10702575 = r10702573 <= r10702574;
double r10702576 = beta;
double r10702577 = r10702573 + r10702576;
double r10702578 = 2.0;
double r10702579 = r10702577 + r10702578;
double r10702580 = r10702576 / r10702579;
double r10702581 = r10702573 / r10702579;
double r10702582 = 1.0;
double r10702583 = r10702581 - r10702582;
double r10702584 = r10702580 - r10702583;
double r10702585 = log(r10702584);
double r10702586 = exp(r10702585);
double r10702587 = r10702586 / r10702578;
double r10702588 = cbrt(r10702576);
double r10702589 = r10702588 * r10702588;
double r10702590 = cbrt(r10702579);
double r10702591 = r10702590 * r10702590;
double r10702592 = r10702589 / r10702591;
double r10702593 = r10702588 / r10702590;
double r10702594 = 4.0;
double r10702595 = r10702573 * r10702573;
double r10702596 = r10702594 / r10702595;
double r10702597 = r10702578 / r10702573;
double r10702598 = r10702596 - r10702597;
double r10702599 = 8.0;
double r10702600 = r10702573 * r10702595;
double r10702601 = r10702599 / r10702600;
double r10702602 = r10702598 - r10702601;
double r10702603 = -r10702602;
double r10702604 = fma(r10702592, r10702593, r10702603);
double r10702605 = r10702604 / r10702578;
double r10702606 = r10702575 ? r10702587 : r10702605;
return r10702606;
}



Bits error versus alpha



Bits error versus beta
if alpha < 16738773.274129016Initial program 0.1
rmApplied div-sub0.1
Applied associate-+l-0.1
rmApplied add-exp-log0.1
if 16738773.274129016 < alpha Initial program 49.9
rmApplied div-sub49.9
Applied associate-+l-48.3
rmApplied add-cube-cbrt48.4
Applied add-cube-cbrt48.3
Applied times-frac48.3
Applied fma-neg48.3
Taylor expanded around inf 18.3
Simplified18.3
Final simplification6.1
herbie shell --seed 2019173 +o rules:numerics
(FPCore (alpha beta)
:name "Octave 3.8, jcobi/1"
:pre (and (> alpha -1.0) (> beta -1.0))
(/ (+ (/ (- beta alpha) (+ (+ alpha beta) 2.0)) 1.0) 2.0))