\left(3 \cdot \sqrt{x}\right) \cdot \left(\left(y + \frac{1}{x \cdot 9}\right) - 1\right)\left(3 \cdot \sqrt{x}\right) \cdot \left(\left(y + \frac{\frac{1}{\sqrt{x}}}{\sqrt{x} \cdot 9}\right) - 1\right)double f(double x, double y) {
double r450058 = 3.0;
double r450059 = x;
double r450060 = sqrt(r450059);
double r450061 = r450058 * r450060;
double r450062 = y;
double r450063 = 1.0;
double r450064 = 9.0;
double r450065 = r450059 * r450064;
double r450066 = r450063 / r450065;
double r450067 = r450062 + r450066;
double r450068 = r450067 - r450063;
double r450069 = r450061 * r450068;
return r450069;
}
double f(double x, double y) {
double r450070 = 3.0;
double r450071 = x;
double r450072 = sqrt(r450071);
double r450073 = r450070 * r450072;
double r450074 = y;
double r450075 = 1.0;
double r450076 = r450075 / r450072;
double r450077 = 9.0;
double r450078 = r450072 * r450077;
double r450079 = r450076 / r450078;
double r450080 = r450074 + r450079;
double r450081 = r450080 - r450075;
double r450082 = r450073 * r450081;
return r450082;
}




Bits error versus x




Bits error versus y
Results
| Original | 0.4 |
|---|---|
| Target | 0.4 |
| Herbie | 0.4 |
Initial program 0.4
rmApplied associate-/r*0.4
rmApplied *-un-lft-identity0.4
Applied add-sqr-sqrt0.4
Applied *-un-lft-identity0.4
Applied times-frac0.5
Applied times-frac0.5
Simplified0.5
rmApplied frac-times0.4
Simplified0.4
Final simplification0.4
herbie shell --seed 2020046 +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)))