\left(3 \cdot \sqrt{x}\right) \cdot \left(\left(y + \frac{1}{x \cdot 9}\right) - 1\right)\left(\left(\sqrt[3]{3} \cdot \sqrt[3]{3}\right) \cdot {\left({\left(\sqrt[3]{3}\right)}^{2} \cdot x\right)}^{\frac{1}{2}}\right) \cdot \left(\left(y + \frac{1}{x \cdot 9}\right) - 1\right)double f(double x, double y) {
double r375981 = 3.0;
double r375982 = x;
double r375983 = sqrt(r375982);
double r375984 = r375981 * r375983;
double r375985 = y;
double r375986 = 1.0;
double r375987 = 9.0;
double r375988 = r375982 * r375987;
double r375989 = r375986 / r375988;
double r375990 = r375985 + r375989;
double r375991 = r375990 - r375986;
double r375992 = r375984 * r375991;
return r375992;
}
double f(double x, double y) {
double r375993 = 3.0;
double r375994 = cbrt(r375993);
double r375995 = r375994 * r375994;
double r375996 = 2.0;
double r375997 = pow(r375994, r375996);
double r375998 = x;
double r375999 = r375997 * r375998;
double r376000 = 0.5;
double r376001 = pow(r375999, r376000);
double r376002 = r375995 * r376001;
double r376003 = y;
double r376004 = 1.0;
double r376005 = 9.0;
double r376006 = r375998 * r376005;
double r376007 = r376004 / r376006;
double r376008 = r376003 + r376007;
double r376009 = r376008 - r376004;
double r376010 = r376002 * r376009;
return r376010;
}




Bits error versus x




Bits error versus y
Results
| Original | 0.4 |
|---|---|
| Target | 0.4 |
| Herbie | 0.4 |
Initial program 0.4
rmApplied add-cube-cbrt0.4
Applied associate-*l*0.6
rmApplied add-sqr-sqrt0.6
Applied associate-*l*0.5
rmApplied pow10.5
Applied sqrt-pow10.5
Applied pow10.5
Applied sqrt-pow10.5
Applied pow-prod-down0.5
Applied pow10.5
Applied sqrt-pow10.5
Applied pow-prod-down0.6
Simplified0.4
Final simplification0.4
herbie shell --seed 2019353 +o rules:numerics
(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)))