\left(3 \cdot \sqrt{x}\right) \cdot \left(\left(y + \frac{1}{x \cdot 9}\right) - 1\right)3 \cdot \left(\sqrt{x} \cdot \mathsf{fma}\left(\frac{1}{\sqrt{x}}, \frac{0.1111111111111111}{\sqrt{x}}, y - 1\right)\right)double f(double x, double y) {
double r528403 = 3.0;
double r528404 = x;
double r528405 = sqrt(r528404);
double r528406 = r528403 * r528405;
double r528407 = y;
double r528408 = 1.0;
double r528409 = 9.0;
double r528410 = r528404 * r528409;
double r528411 = r528408 / r528410;
double r528412 = r528407 + r528411;
double r528413 = r528412 - r528408;
double r528414 = r528406 * r528413;
return r528414;
}
double f(double x, double y) {
double r528415 = 3.0;
double r528416 = x;
double r528417 = sqrt(r528416);
double r528418 = 1.0;
double r528419 = r528418 / r528417;
double r528420 = 0.1111111111111111;
double r528421 = r528420 / r528417;
double r528422 = y;
double r528423 = 1.0;
double r528424 = r528422 - r528423;
double r528425 = fma(r528419, r528421, r528424);
double r528426 = r528417 * r528425;
double r528427 = r528415 * r528426;
return r528427;
}




Bits error versus x




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