\sqrt{\left(\left(\left(\left(\frac{\left(\frac{\left(\frac{a}{b}\right)}{c}\right)}{\left(2\right)}\right) \cdot \left(\left(\frac{\left(\frac{\left(\frac{a}{b}\right)}{c}\right)}{\left(2\right)}\right) - a\right)\right) \cdot \left(\left(\frac{\left(\frac{\left(\frac{a}{b}\right)}{c}\right)}{\left(2\right)}\right) - b\right)\right) \cdot \left(\left(\frac{\left(\frac{\left(\frac{a}{b}\right)}{c}\right)}{\left(2\right)}\right) - c\right)\right)}\sqrt{\left(\left(\frac{\left(a + b\right) + c}{2} \cdot \left(\frac{\left(a + b\right) + c}{2} - a\right)\right) \cdot \left(\frac{1.0}{\frac{2}{a + \left(c + b\right)}} - b\right)\right) \cdot \frac{\frac{\left(c + b\right) + a}{2} \cdot \frac{\left(c + b\right) + a}{2} - c \cdot c}{\frac{\left(c + b\right) + a}{2} + c}}double f(double a, double b, double c) {
double r1609111 = a;
double r1609112 = b;
double r1609113 = r1609111 + r1609112;
double r1609114 = c;
double r1609115 = r1609113 + r1609114;
double r1609116 = 2.0;
double r1609117 = /* ERROR: no posit support in C */;
double r1609118 = r1609115 / r1609117;
double r1609119 = r1609118 - r1609111;
double r1609120 = r1609118 * r1609119;
double r1609121 = r1609118 - r1609112;
double r1609122 = r1609120 * r1609121;
double r1609123 = r1609118 - r1609114;
double r1609124 = r1609122 * r1609123;
double r1609125 = sqrt(r1609124);
return r1609125;
}
double f(double a, double b, double c) {
double r1609126 = a;
double r1609127 = b;
double r1609128 = r1609126 + r1609127;
double r1609129 = c;
double r1609130 = r1609128 + r1609129;
double r1609131 = 2.0;
double r1609132 = r1609130 / r1609131;
double r1609133 = r1609132 - r1609126;
double r1609134 = r1609132 * r1609133;
double r1609135 = 1.0;
double r1609136 = r1609129 + r1609127;
double r1609137 = r1609126 + r1609136;
double r1609138 = r1609131 / r1609137;
double r1609139 = r1609135 / r1609138;
double r1609140 = r1609139 - r1609127;
double r1609141 = r1609134 * r1609140;
double r1609142 = r1609136 + r1609126;
double r1609143 = r1609142 / r1609131;
double r1609144 = r1609143 * r1609143;
double r1609145 = r1609129 * r1609129;
double r1609146 = r1609144 - r1609145;
double r1609147 = r1609143 + r1609129;
double r1609148 = r1609146 / r1609147;
double r1609149 = r1609141 * r1609148;
double r1609150 = sqrt(r1609149);
return r1609150;
}



Bits error versus a



Bits error versus b



Bits error versus c
Initial program 0.2
rmApplied p16-*-un-lft-identity0.2
Applied associate-/r*0.2
Simplified0.2
rmApplied p16-*-un-lft-identity0.2
Applied associate-/r*0.2
Simplified0.2
rmApplied p16-*-un-lft-identity0.2
Applied associate-/l*0.2
rmApplied p16-flip--0.2
Final simplification0.2
herbie shell --seed 2019154 +o rules:numerics
(FPCore (a b c)
:name "Area of a triangle"
:pre (and (<.p16 (real->posit16 0) a) (<.p16 (real->posit16 0) b) (<.p16 (real->posit16 0) c))
(sqrt.p16 (*.p16 (*.p16 (*.p16 (/.p16 (+.p16 (+.p16 a b) c) (real->posit16 2)) (-.p16 (/.p16 (+.p16 (+.p16 a b) c) (real->posit16 2)) a)) (-.p16 (/.p16 (+.p16 (+.p16 a b) c) (real->posit16 2)) b)) (-.p16 (/.p16 (+.p16 (+.p16 a b) c) (real->posit16 2)) c))))