\left(1 - \frac{1}{x \cdot 9}\right) - \frac{y}{3 \cdot \sqrt{x}}\left(1 - \frac{\frac{1}{x}}{9}\right) - \frac{y}{3} \cdot \frac{1}{\sqrt{x}}double f(double x, double y) {
double r375318 = 1.0;
double r375319 = x;
double r375320 = 9.0;
double r375321 = r375319 * r375320;
double r375322 = r375318 / r375321;
double r375323 = r375318 - r375322;
double r375324 = y;
double r375325 = 3.0;
double r375326 = sqrt(r375319);
double r375327 = r375325 * r375326;
double r375328 = r375324 / r375327;
double r375329 = r375323 - r375328;
return r375329;
}
double f(double x, double y) {
double r375330 = 1.0;
double r375331 = x;
double r375332 = r375330 / r375331;
double r375333 = 9.0;
double r375334 = r375332 / r375333;
double r375335 = r375330 - r375334;
double r375336 = y;
double r375337 = 3.0;
double r375338 = r375336 / r375337;
double r375339 = 1.0;
double r375340 = sqrt(r375331);
double r375341 = r375339 / r375340;
double r375342 = r375338 * r375341;
double r375343 = r375335 - r375342;
return r375343;
}




Bits error versus x




Bits error versus y
Results
| Original | 0.2 |
|---|---|
| Target | 0.2 |
| Herbie | 0.2 |
Initial program 0.2
rmApplied associate-/r*0.2
rmApplied *-un-lft-identity0.2
Applied times-frac0.3
rmApplied div-inv0.3
Applied associate-*r*0.3
Simplified0.2
Final simplification0.2
herbie shell --seed 2020062 +o rules:numerics
(FPCore (x y)
:name "Numeric.SpecFunctions:invIncompleteGamma from math-functions-0.1.5.2, D"
:precision binary64
:herbie-target
(- (- 1 (/ (/ 1 x) 9)) (/ y (* 3 (sqrt x))))
(- (- 1 (/ 1 (* x 9))) (/ y (* 3 (sqrt x)))))