\left(3 \cdot \sqrt{x}\right) \cdot \left(\left(y + \frac{1}{x \cdot 9}\right) - 1\right)\left(3 \cdot \left(\frac{\frac{1}{9}}{x} + y\right) + 3 \cdot \left(-1\right)\right) \cdot \sqrt{x}double f(double x, double y) {
double r543716 = 3.0;
double r543717 = x;
double r543718 = sqrt(r543717);
double r543719 = r543716 * r543718;
double r543720 = y;
double r543721 = 1.0;
double r543722 = 9.0;
double r543723 = r543717 * r543722;
double r543724 = r543721 / r543723;
double r543725 = r543720 + r543724;
double r543726 = r543725 - r543721;
double r543727 = r543719 * r543726;
return r543727;
}
double f(double x, double y) {
double r543728 = 3.0;
double r543729 = 1.0;
double r543730 = 9.0;
double r543731 = r543729 / r543730;
double r543732 = x;
double r543733 = r543731 / r543732;
double r543734 = y;
double r543735 = r543733 + r543734;
double r543736 = r543728 * r543735;
double r543737 = -r543729;
double r543738 = r543728 * r543737;
double r543739 = r543736 + r543738;
double r543740 = sqrt(r543732);
double r543741 = r543739 * r543740;
return r543741;
}




Bits error versus x




Bits error versus y
Results
| Original | 0.4 |
|---|---|
| Target | 0.4 |
| Herbie | 0.4 |
Initial program 0.4
rmApplied add-sqr-sqrt0.4
rmApplied add-sqr-sqrt0.4
Applied times-frac0.4
Applied sqrt-prod0.5
Applied add-sqr-sqrt0.5
Applied times-frac0.5
Applied sqrt-prod0.5
Applied swap-sqr0.5
Simplified0.4
Simplified0.4
rmApplied pow10.4
Applied pow10.4
Applied pow10.4
Applied pow-prod-down0.4
Applied pow-prod-down0.4
Simplified0.4
rmApplied sub-neg0.4
Applied distribute-lft-in0.4
Final simplification0.4
herbie shell --seed 2020034
(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)))