\frac{\left(\frac{\left(\frac{\left(\beta - \alpha\right)}{\left(\frac{\left(\frac{\alpha}{\beta}\right)}{\left(2.0\right)}\right)}\right)}{\left(1.0\right)}\right)}{\left(2.0\right)}\frac{\frac{\beta - \alpha}{\beta + \left(\alpha + 2.0\right)} + 1.0}{2.0}double f(double alpha, double beta) {
double r3280120 = beta;
double r3280121 = alpha;
double r3280122 = r3280120 - r3280121;
double r3280123 = r3280121 + r3280120;
double r3280124 = 2.0;
double r3280125 = /* ERROR: no posit support in C */;
double r3280126 = r3280123 + r3280125;
double r3280127 = r3280122 / r3280126;
double r3280128 = 1.0;
double r3280129 = /* ERROR: no posit support in C */;
double r3280130 = r3280127 + r3280129;
double r3280131 = r3280130 / r3280125;
return r3280131;
}
double f(double alpha, double beta) {
double r3280132 = beta;
double r3280133 = alpha;
double r3280134 = r3280132 - r3280133;
double r3280135 = 2.0;
double r3280136 = r3280133 + r3280135;
double r3280137 = r3280132 + r3280136;
double r3280138 = r3280134 / r3280137;
double r3280139 = 1.0;
double r3280140 = r3280138 + r3280139;
double r3280141 = r3280140 / r3280135;
return r3280141;
}



Bits error versus alpha



Bits error versus beta
Initial program 0.7
rmApplied p16-flip--1.3
Applied associate-/l/1.3
Simplified1.2
Simplified0.8
Final simplification0.8
herbie shell --seed 2019120
(FPCore (alpha beta)
:name "Octave 3.8, jcobi/1"
:pre (and (>.p16 alpha (real->posit16 -1)) (>.p16 beta (real->posit16 -1)))
(/.p16 (+.p16 (/.p16 (-.p16 beta alpha) (+.p16 (+.p16 alpha beta) (real->posit16 2.0))) (real->posit16 1.0)) (real->posit16 2.0)))