\left(3 \cdot \sqrt{x}\right) \cdot \left(\left(y + \frac{1}{x \cdot 9}\right) - 1\right)\left(\left(y + \frac{1}{x \cdot 9}\right) \cdot \sqrt{x}\right) \cdot 3 + \left(\left(-1\right) \cdot \sqrt{x}\right) \cdot 3double f(double x, double y) {
double r307467 = 3.0;
double r307468 = x;
double r307469 = sqrt(r307468);
double r307470 = r307467 * r307469;
double r307471 = y;
double r307472 = 1.0;
double r307473 = 9.0;
double r307474 = r307468 * r307473;
double r307475 = r307472 / r307474;
double r307476 = r307471 + r307475;
double r307477 = r307476 - r307472;
double r307478 = r307470 * r307477;
return r307478;
}
double f(double x, double y) {
double r307479 = y;
double r307480 = 1.0;
double r307481 = x;
double r307482 = 9.0;
double r307483 = r307481 * r307482;
double r307484 = r307480 / r307483;
double r307485 = r307479 + r307484;
double r307486 = sqrt(r307481);
double r307487 = r307485 * r307486;
double r307488 = 3.0;
double r307489 = r307487 * r307488;
double r307490 = -r307480;
double r307491 = r307490 * r307486;
double r307492 = r307491 * r307488;
double r307493 = r307489 + r307492;
return r307493;
}




Bits error versus x




Bits error versus y
Results
| Original | 0.4 |
|---|---|
| Target | 0.4 |
| Herbie | 0.4 |
Initial program 0.4
rmApplied associate-*l*0.4
rmApplied add-cube-cbrt0.4
Applied associate-*l*0.6
rmApplied sub-neg0.6
Applied distribute-lft-in0.6
Applied distribute-lft-in0.6
Applied distribute-lft-in0.6
Simplified0.5
Simplified0.4
Final simplification0.4
herbie shell --seed 2019303
(FPCore (x y)
:name "Numeric.SpecFunctions:incompleteGamma from math-functions-0.1.5.2, B"
:precision binary64
:herbie-target
(* 3 (+ (* y (sqrt x)) (* (- (/ 1 (* x 9)) 1) (sqrt x))))
(* (* 3 (sqrt x)) (- (+ y (/ 1 (* x 9))) 1)))