x - \frac{\left(y \cdot 2\right) \cdot z}{\left(z \cdot 2\right) \cdot z - y \cdot t}x - \frac{y \cdot 2}{z \cdot 2 - t \cdot \frac{y}{z}}double f(double x, double y, double z, double t) {
double r401422 = x;
double r401423 = y;
double r401424 = 2.0;
double r401425 = r401423 * r401424;
double r401426 = z;
double r401427 = r401425 * r401426;
double r401428 = r401426 * r401424;
double r401429 = r401428 * r401426;
double r401430 = t;
double r401431 = r401423 * r401430;
double r401432 = r401429 - r401431;
double r401433 = r401427 / r401432;
double r401434 = r401422 - r401433;
return r401434;
}
double f(double x, double y, double z, double t) {
double r401435 = x;
double r401436 = y;
double r401437 = 2.0;
double r401438 = r401436 * r401437;
double r401439 = z;
double r401440 = r401439 * r401437;
double r401441 = t;
double r401442 = r401436 / r401439;
double r401443 = r401441 * r401442;
double r401444 = r401440 - r401443;
double r401445 = r401438 / r401444;
double r401446 = r401435 - r401445;
return r401446;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 11.7 |
|---|---|
| Target | 0.1 |
| Herbie | 2.3 |
Initial program 11.7
rmApplied associate-/l*6.7
rmApplied div-sub6.7
Simplified2.9
Simplified2.9
rmApplied *-un-lft-identity2.9
Applied times-frac2.3
Simplified2.3
Final simplification2.3
herbie shell --seed 2020001 +o rules:numerics
(FPCore (x y z t)
:name "Numeric.AD.Rank1.Halley:findZero from ad-4.2.4"
:precision binary64
:herbie-target
(- x (/ 1 (- (/ z y) (/ (/ t 2) z))))
(- x (/ (* (* y 2) z) (- (* (* z 2) z) (* y t)))))