\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{1.0}{\frac{\left(\mathsf{qma}\left(\left(\mathsf{qma}\left(\left(2.0\right), \alpha, 1.0\right)\right), \beta, 1.0\right)\right)}{\beta - \alpha}} + 1.0}{2.0}double f(double alpha, double beta) {
double r4041652 = beta;
double r4041653 = alpha;
double r4041654 = r4041652 - r4041653;
double r4041655 = r4041653 + r4041652;
double r4041656 = 2.0;
double r4041657 = /* ERROR: no posit support in C */;
double r4041658 = r4041655 + r4041657;
double r4041659 = r4041654 / r4041658;
double r4041660 = 1.0;
double r4041661 = /* ERROR: no posit support in C */;
double r4041662 = r4041659 + r4041661;
double r4041663 = r4041662 / r4041657;
return r4041663;
}
double f(double alpha, double beta) {
double r4041664 = 1.0;
double r4041665 = 2.0;
double r4041666 = /*Error: no posit support in C */;
double r4041667 = alpha;
double r4041668 = /*Error: no posit support in C */;
double r4041669 = beta;
double r4041670 = /*Error: no posit support in C */;
double r4041671 = /*Error: no posit support in C */;
double r4041672 = r4041669 - r4041667;
double r4041673 = r4041671 / r4041672;
double r4041674 = r4041664 / r4041673;
double r4041675 = r4041674 + r4041664;
double r4041676 = r4041675 / r4041665;
return r4041676;
}



Bits error versus alpha



Bits error versus beta
Initial program 0.8
rmApplied associate-+l+0.8
rmApplied *p16-rgt-identity-expand0.8
Applied associate-/l*0.8
Simplified0.8
rmApplied introduce-quire0.8
Applied insert-quire-add0.8
Applied insert-quire-add0.7
rmApplied p16-*-un-lft-identity0.7
Applied associate-/l*0.8
Final simplification0.8
herbie shell --seed 2019163 +o rules:numerics
(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)))