\left(\left(x \cdot y + \frac{z \cdot t}{16}\right) - \frac{a \cdot b}{4}\right) + c\left(\left(x \cdot y + \frac{z \cdot t}{16}\right) - \frac{a \cdot b}{4}\right) + cdouble f(double x, double y, double z, double t, double a, double b, double c) {
double r217304 = x;
double r217305 = y;
double r217306 = r217304 * r217305;
double r217307 = z;
double r217308 = t;
double r217309 = r217307 * r217308;
double r217310 = 16.0;
double r217311 = r217309 / r217310;
double r217312 = r217306 + r217311;
double r217313 = a;
double r217314 = b;
double r217315 = r217313 * r217314;
double r217316 = 4.0;
double r217317 = r217315 / r217316;
double r217318 = r217312 - r217317;
double r217319 = c;
double r217320 = r217318 + r217319;
return r217320;
}
double f(double x, double y, double z, double t, double a, double b, double c) {
double r217321 = x;
double r217322 = y;
double r217323 = r217321 * r217322;
double r217324 = z;
double r217325 = t;
double r217326 = r217324 * r217325;
double r217327 = 16.0;
double r217328 = r217326 / r217327;
double r217329 = r217323 + r217328;
double r217330 = a;
double r217331 = b;
double r217332 = r217330 * r217331;
double r217333 = 4.0;
double r217334 = r217332 / r217333;
double r217335 = r217329 - r217334;
double r217336 = c;
double r217337 = r217335 + r217336;
return r217337;
}



Bits error versus x



Bits error versus y



Bits error versus z



Bits error versus t



Bits error versus a



Bits error versus b



Bits error versus c
Results
Initial program 0.1
Final simplification0.1
herbie shell --seed 2020060
(FPCore (x y z t a b c)
:name "Diagrams.Solve.Polynomial:quartForm from diagrams-solve-0.1, C"
:precision binary64
(+ (- (+ (* x y) (/ (* z t) 16)) (/ (* a b) 4)) c))