\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.0}\begin{array}{l}
\mathbf{if}\;\beta \le 1.447602491634548 \cdot 10^{+178}:\\
\;\;\;\;\frac{\frac{\frac{i \cdot \left(i + \left(\beta + \alpha\right)\right) + \alpha \cdot \beta}{\left(\beta + \alpha\right) + 2 \cdot i} \cdot \frac{i \cdot \left(i + \left(\beta + \alpha\right)\right)}{\left(\beta + \alpha\right) + 2 \cdot i}}{\sqrt{1.0} + \left(\left(\beta + \alpha\right) + 2 \cdot i\right)}}{\left(\left(\beta + \alpha\right) + 2 \cdot i\right) - \sqrt{1.0}}\\
\mathbf{else}:\\
\;\;\;\;0\\
\end{array}double f(double alpha, double beta, double i) {
double r4054185 = i;
double r4054186 = alpha;
double r4054187 = beta;
double r4054188 = r4054186 + r4054187;
double r4054189 = r4054188 + r4054185;
double r4054190 = r4054185 * r4054189;
double r4054191 = r4054187 * r4054186;
double r4054192 = r4054191 + r4054190;
double r4054193 = r4054190 * r4054192;
double r4054194 = 2.0;
double r4054195 = r4054194 * r4054185;
double r4054196 = r4054188 + r4054195;
double r4054197 = r4054196 * r4054196;
double r4054198 = r4054193 / r4054197;
double r4054199 = 1.0;
double r4054200 = r4054197 - r4054199;
double r4054201 = r4054198 / r4054200;
return r4054201;
}
double f(double alpha, double beta, double i) {
double r4054202 = beta;
double r4054203 = 1.447602491634548e+178;
bool r4054204 = r4054202 <= r4054203;
double r4054205 = i;
double r4054206 = alpha;
double r4054207 = r4054202 + r4054206;
double r4054208 = r4054205 + r4054207;
double r4054209 = r4054205 * r4054208;
double r4054210 = r4054206 * r4054202;
double r4054211 = r4054209 + r4054210;
double r4054212 = 2.0;
double r4054213 = r4054212 * r4054205;
double r4054214 = r4054207 + r4054213;
double r4054215 = r4054211 / r4054214;
double r4054216 = r4054209 / r4054214;
double r4054217 = r4054215 * r4054216;
double r4054218 = 1.0;
double r4054219 = sqrt(r4054218);
double r4054220 = r4054219 + r4054214;
double r4054221 = r4054217 / r4054220;
double r4054222 = r4054214 - r4054219;
double r4054223 = r4054221 / r4054222;
double r4054224 = 0.0;
double r4054225 = r4054204 ? r4054223 : r4054224;
return r4054225;
}



Bits error versus alpha



Bits error versus beta



Bits error versus i
Results
if beta < 1.447602491634548e+178Initial program 51.1
rmApplied add-sqr-sqrt51.1
Applied difference-of-squares51.1
Applied times-frac35.8
Applied times-frac34.0
rmApplied associate-*r/34.0
rmApplied associate-*l/34.0
if 1.447602491634548e+178 < beta Initial program 62.6
Taylor expanded around inf 45.9
Final simplification35.7
herbie shell --seed 2019162 +o rules:numerics
(FPCore (alpha beta i)
:name "Octave 3.8, jcobi/4"
: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.0)))