\left(3 \cdot \sqrt{x}\right) \cdot \left(\left(y + \frac{1}{x \cdot 9}\right) - 1\right)\left(3 \cdot y\right) \cdot \sqrt{x} + 3 \cdot \left(\left(\frac{\sqrt{1}}{x} \cdot \frac{\sqrt{1}}{9} - 1\right) \cdot \sqrt{x}\right)double f(double x, double y) {
double r343926 = 3.0;
double r343927 = x;
double r343928 = sqrt(r343927);
double r343929 = r343926 * r343928;
double r343930 = y;
double r343931 = 1.0;
double r343932 = 9.0;
double r343933 = r343927 * r343932;
double r343934 = r343931 / r343933;
double r343935 = r343930 + r343934;
double r343936 = r343935 - r343931;
double r343937 = r343929 * r343936;
return r343937;
}
double f(double x, double y) {
double r343938 = 3.0;
double r343939 = y;
double r343940 = r343938 * r343939;
double r343941 = x;
double r343942 = sqrt(r343941);
double r343943 = r343940 * r343942;
double r343944 = 1.0;
double r343945 = sqrt(r343944);
double r343946 = r343945 / r343941;
double r343947 = 9.0;
double r343948 = r343945 / r343947;
double r343949 = r343946 * r343948;
double r343950 = r343949 - r343944;
double r343951 = r343950 * r343942;
double r343952 = r343938 * r343951;
double r343953 = r343943 + r343952;
return r343953;
}




Bits error versus x




Bits error versus y
Results
| Original | 0.4 |
|---|---|
| Target | 0.4 |
| Herbie | 0.5 |
Initial program 0.4
rmApplied associate-*l*0.4
rmApplied associate--l+0.4
Applied distribute-lft-in0.4
Applied distribute-lft-in0.4
Simplified0.4
Simplified0.4
rmApplied associate-*r*0.4
rmApplied add-sqr-sqrt0.4
Applied times-frac0.5
Final simplification0.5
herbie shell --seed 2019354 +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)))