\left(3 \cdot \sqrt{x}\right) \cdot \left(\left(y + \frac{1}{x \cdot 9}\right) - 1\right)\mathsf{fma}\left(y, 3, 0.3333333333333333148296162562473909929395 \cdot \frac{1}{x} - 3\right) \cdot \sqrt{x} + \left(\sqrt{x} \cdot \mathsf{fma}\left(-1, 1, 1\right)\right) \cdot 3double f(double x, double y) {
double r362239 = 3.0;
double r362240 = x;
double r362241 = sqrt(r362240);
double r362242 = r362239 * r362241;
double r362243 = y;
double r362244 = 1.0;
double r362245 = 9.0;
double r362246 = r362240 * r362245;
double r362247 = r362244 / r362246;
double r362248 = r362243 + r362247;
double r362249 = r362248 - r362244;
double r362250 = r362242 * r362249;
return r362250;
}
double f(double x, double y) {
double r362251 = y;
double r362252 = 3.0;
double r362253 = 0.3333333333333333;
double r362254 = 1.0;
double r362255 = x;
double r362256 = r362254 / r362255;
double r362257 = r362253 * r362256;
double r362258 = r362257 - r362252;
double r362259 = fma(r362251, r362252, r362258);
double r362260 = sqrt(r362255);
double r362261 = r362259 * r362260;
double r362262 = 1.0;
double r362263 = -r362262;
double r362264 = fma(r362263, r362254, r362262);
double r362265 = r362260 * r362264;
double r362266 = r362265 * r362252;
double r362267 = r362261 + r362266;
return r362267;
}




Bits error versus x




Bits error versus y
| Original | 0.4 |
|---|---|
| Target | 0.4 |
| Herbie | 0.5 |
Initial program 0.4
rmApplied associate-*l*0.4
rmApplied add-cube-cbrt0.4
Applied add-sqr-sqrt15.8
Applied prod-diff15.8
Applied distribute-lft-in15.8
Applied distribute-lft-in15.8
Simplified0.4
Simplified0.4
rmApplied associate-*r*0.5
Taylor expanded around 0 0.5
Simplified0.5
Final simplification0.5
herbie shell --seed 2019356 +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)))