\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)\left(\left(\left(d2 + d4\right) - d1\right) - d3\right) \cdot d1
double f(double d1, double d2, double d3, double d4) {
double r3527317 = d1;
double r3527318 = d2;
double r3527319 = r3527317 * r3527318;
double r3527320 = d3;
double r3527321 = r3527317 * r3527320;
double r3527322 = r3527319 - r3527321;
double r3527323 = d4;
double r3527324 = r3527323 * r3527317;
double r3527325 = r3527322 + r3527324;
double r3527326 = r3527317 * r3527317;
double r3527327 = r3527325 - r3527326;
return r3527327;
}
double f(double d1, double d2, double d3, double d4) {
double r3527328 = d2;
double r3527329 = d4;
double r3527330 = r3527328 + r3527329;
double r3527331 = d1;
double r3527332 = r3527330 - r3527331;
double r3527333 = d3;
double r3527334 = r3527332 - r3527333;
double r3527335 = r3527334 * r3527331;
return r3527335;
}



Bits error versus d1



Bits error versus d2



Bits error versus d3



Bits error versus d4
Initial program 0.5
Simplified0.4
rmApplied associate-+r-0.4
rmApplied sub-neg0.4
Applied associate-+l+0.4
Simplified0.4
Simplified0.4
rmApplied associate--r+0.4
Final simplification0.4
herbie shell --seed 2019128 +o rules:numerics
(FPCore (d1 d2 d3 d4)
:name "FastMath dist4"
(-.p16 (+.p16 (-.p16 (*.p16 d1 d2) (*.p16 d1 d3)) (*.p16 d4 d1)) (*.p16 d1 d1)))