\left(3 \cdot \sqrt{x}\right) \cdot \left(\left(y + \frac{1}{x \cdot 9}\right) - 1\right)\mathsf{fma}\left(3, y, \left(\frac{\frac{0.3333333333333333148296162562473909929395}{\sqrt{x}}}{\sqrt{x}} - 3\right) + \left(\left(-3\right) + 3\right)\right) \cdot \sqrt{x}double f(double x, double y) {
double r348354 = 3.0;
double r348355 = x;
double r348356 = sqrt(r348355);
double r348357 = r348354 * r348356;
double r348358 = y;
double r348359 = 1.0;
double r348360 = 9.0;
double r348361 = r348355 * r348360;
double r348362 = r348359 / r348361;
double r348363 = r348358 + r348362;
double r348364 = r348363 - r348359;
double r348365 = r348357 * r348364;
return r348365;
}
double f(double x, double y) {
double r348366 = 3.0;
double r348367 = y;
double r348368 = 0.3333333333333333;
double r348369 = x;
double r348370 = sqrt(r348369);
double r348371 = r348368 / r348370;
double r348372 = r348371 / r348370;
double r348373 = r348372 - r348366;
double r348374 = -r348366;
double r348375 = r348374 + r348366;
double r348376 = r348373 + r348375;
double r348377 = fma(r348366, r348367, r348376);
double r348378 = r348377 * r348370;
return r348378;
}




Bits error versus x




Bits error versus y
| Original | 0.4 |
|---|---|
| Target | 0.4 |
| Herbie | 0.4 |
Initial program 0.4
rmApplied associate-*l*0.4
rmApplied pow10.4
Applied pow10.4
Applied pow-prod-down0.4
Applied pow10.4
Applied pow-prod-down0.4
Simplified0.4
Taylor expanded around 0 0.4
Simplified0.4
rmApplied add-cube-cbrt0.4
Applied add-sqr-sqrt0.4
Applied *-un-lft-identity0.4
Applied times-frac0.4
Applied prod-diff0.4
Simplified0.4
Simplified0.4
Final simplification0.4
herbie shell --seed 2019212 +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)))