\left(\frac{\left(\left(d1 \cdot d2\right) - \left(d1 \cdot d3\right)\right)}{\left(d4 \cdot d1\right)}\right) - \left(d1 \cdot d1\right)d1 \cdot \left(\mathsf{qms}\left(\left(\mathsf{qms}\left(\left(\left(d4 + d2\right)\right), d1, 1.0\right)\right), d3, 1.0\right)\right)double f(double d1, double d2, double d3, double d4) {
double r922462 = d1;
double r922463 = d2;
double r922464 = r922462 * r922463;
double r922465 = d3;
double r922466 = r922462 * r922465;
double r922467 = r922464 - r922466;
double r922468 = d4;
double r922469 = r922468 * r922462;
double r922470 = r922467 + r922469;
double r922471 = r922462 * r922462;
double r922472 = r922470 - r922471;
return r922472;
}
double f(double d1, double d2, double d3, double d4) {
double r922473 = d1;
double r922474 = d4;
double r922475 = d2;
double r922476 = r922474 + r922475;
double r922477 = /*Error: no posit support in C */;
double r922478 = 1.0;
double r922479 = /*Error: no posit support in C */;
double r922480 = d3;
double r922481 = /*Error: no posit support in C */;
double r922482 = /*Error: no posit support in C */;
double r922483 = r922473 * r922482;
return r922483;
}



Bits error versus d1



Bits error versus d2



Bits error versus d3



Bits error versus d4
Initial program 0.5
Simplified0.4
rmApplied sub-neg0.4
Applied associate-+l+0.4
Simplified0.4
rmApplied associate-+r-0.4
rmApplied associate--r+0.4
rmApplied introduce-quire0.4
Applied insert-quire-sub0.4
Applied insert-quire-sub0.3
Final simplification0.3
herbie shell --seed 2019153
(FPCore (d1 d2 d3 d4)
:name "FastMath dist4"
(-.p16 (+.p16 (-.p16 (*.p16 d1 d2) (*.p16 d1 d3)) (*.p16 d4 d1)) (*.p16 d1 d1)))