\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 r427698 = 3.0;
double r427699 = x;
double r427700 = sqrt(r427699);
double r427701 = r427698 * r427700;
double r427702 = y;
double r427703 = 1.0;
double r427704 = 9.0;
double r427705 = r427699 * r427704;
double r427706 = r427703 / r427705;
double r427707 = r427702 + r427706;
double r427708 = r427707 - r427703;
double r427709 = r427701 * r427708;
return r427709;
}
double f(double x, double y) {
double r427710 = 3.0;
double r427711 = cbrt(r427710);
double r427712 = r427711 * r427711;
double r427713 = 2.0;
double r427714 = pow(r427711, r427713);
double r427715 = x;
double r427716 = r427714 * r427715;
double r427717 = 0.5;
double r427718 = pow(r427716, r427717);
double r427719 = r427712 * r427718;
double r427720 = y;
double r427721 = 1.0;
double r427722 = 9.0;
double r427723 = r427715 * r427722;
double r427724 = r427721 / r427723;
double r427725 = r427720 + r427724;
double r427726 = r427725 - r427721;
double r427727 = r427719 * r427726;
return r427727;
}




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
(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)))