\frac{\left(\frac{\left(\frac{\left(\frac{\left(\frac{\left(\frac{\alpha}{\beta}\right)}{\left(\beta \cdot \alpha\right)}\right)}{\left(1.0\right)}\right)}{\left(\frac{\left(\frac{\alpha}{\beta}\right)}{\left(\left(2\right) \cdot \left(1\right)\right)}\right)}\right)}{\left(\frac{\left(\frac{\alpha}{\beta}\right)}{\left(\left(2\right) \cdot \left(1\right)\right)}\right)}\right)}{\left(\frac{\left(\frac{\left(\frac{\alpha}{\beta}\right)}{\left(\left(2\right) \cdot \left(1\right)\right)}\right)}{\left(1.0\right)}\right)}\frac{\frac{1.0}{\left(\alpha + \beta\right) + 2 \cdot 1}}{\frac{\left(1.0 + \left(\alpha + \beta\right)\right) + 1 \cdot 2}{\alpha + \left(\left(\alpha \cdot \beta + \beta\right) + 1.0\right)} \cdot \left(\left(1 \cdot 2 + \alpha\right) + \beta\right)}double f(double alpha, double beta) {
double r3775920 = alpha;
double r3775921 = beta;
double r3775922 = r3775920 + r3775921;
double r3775923 = r3775921 * r3775920;
double r3775924 = r3775922 + r3775923;
double r3775925 = 1.0;
double r3775926 = /* ERROR: no posit support in C */;
double r3775927 = r3775924 + r3775926;
double r3775928 = 2.0;
double r3775929 = /* ERROR: no posit support in C */;
double r3775930 = 1.0;
double r3775931 = /* ERROR: no posit support in C */;
double r3775932 = r3775929 * r3775931;
double r3775933 = r3775922 + r3775932;
double r3775934 = r3775927 / r3775933;
double r3775935 = r3775934 / r3775933;
double r3775936 = r3775933 + r3775926;
double r3775937 = r3775935 / r3775936;
return r3775937;
}
double f(double alpha, double beta) {
double r3775938 = 1.0;
double r3775939 = alpha;
double r3775940 = beta;
double r3775941 = r3775939 + r3775940;
double r3775942 = 2.0;
double r3775943 = 1.0;
double r3775944 = r3775942 * r3775943;
double r3775945 = r3775941 + r3775944;
double r3775946 = r3775938 / r3775945;
double r3775947 = r3775938 + r3775941;
double r3775948 = r3775943 * r3775942;
double r3775949 = r3775947 + r3775948;
double r3775950 = r3775939 * r3775940;
double r3775951 = r3775950 + r3775940;
double r3775952 = r3775951 + r3775938;
double r3775953 = r3775939 + r3775952;
double r3775954 = r3775949 / r3775953;
double r3775955 = r3775948 + r3775939;
double r3775956 = r3775955 + r3775940;
double r3775957 = r3775954 * r3775956;
double r3775958 = r3775946 / r3775957;
return r3775958;
}



Bits error versus alpha



Bits error versus beta
Initial program 0.4
rmApplied *p16-rgt-identity-expand0.4
Applied p16-*-un-lft-identity0.4
Applied p16-times-frac0.4
Applied associate-/l*0.4
Simplified0.4
Final simplification0.4
herbie shell --seed 2019165
(FPCore (alpha beta)
:name "Octave 3.8, jcobi/3"
:pre (and (>.p16 alpha (real->posit16 -1)) (>.p16 beta (real->posit16 -1)))
(/.p16 (/.p16 (/.p16 (+.p16 (+.p16 (+.p16 alpha beta) (*.p16 beta alpha)) (real->posit16 1.0)) (+.p16 (+.p16 alpha beta) (*.p16 (real->posit16 2) (real->posit16 1)))) (+.p16 (+.p16 alpha beta) (*.p16 (real->posit16 2) (real->posit16 1)))) (+.p16 (+.p16 (+.p16 alpha beta) (*.p16 (real->posit16 2) (real->posit16 1))) (real->posit16 1.0))))