\left(3 \cdot \sqrt{x}\right) \cdot \left(\left(y + \frac{1}{x \cdot 9}\right) - 1\right)\left(-1\right) \cdot \left(3 \cdot \sqrt{x}\right) + \mathsf{fma}\left(3, y, \frac{0.3333333333333333148296162562473909929395}{x}\right) \cdot \sqrt{x}double f(double x, double y) {
double r22038532 = 3.0;
double r22038533 = x;
double r22038534 = sqrt(r22038533);
double r22038535 = r22038532 * r22038534;
double r22038536 = y;
double r22038537 = 1.0;
double r22038538 = 9.0;
double r22038539 = r22038533 * r22038538;
double r22038540 = r22038537 / r22038539;
double r22038541 = r22038536 + r22038540;
double r22038542 = r22038541 - r22038537;
double r22038543 = r22038535 * r22038542;
return r22038543;
}
double f(double x, double y) {
double r22038544 = 1.0;
double r22038545 = -r22038544;
double r22038546 = 3.0;
double r22038547 = x;
double r22038548 = sqrt(r22038547);
double r22038549 = r22038546 * r22038548;
double r22038550 = r22038545 * r22038549;
double r22038551 = y;
double r22038552 = 0.3333333333333333;
double r22038553 = r22038552 / r22038547;
double r22038554 = fma(r22038546, r22038551, r22038553);
double r22038555 = r22038554 * r22038548;
double r22038556 = r22038550 + r22038555;
return r22038556;
}




Bits error versus x




Bits error versus y
| Original | 0.4 |
|---|---|
| Target | 0.4 |
| Herbie | 0.4 |
Initial program 0.4
rmApplied sub-neg0.4
Applied distribute-rgt-in0.4
rmApplied associate-*r*0.4
rmApplied associate-/r*0.4
Taylor expanded around 0 0.4
Simplified0.4
Final simplification0.4
herbie shell --seed 2019168 +o rules:numerics
(FPCore (x y)
:name "Numeric.SpecFunctions:incompleteGamma from math-functions-0.1.5.2, B"
:herbie-target
(* 3.0 (+ (* y (sqrt x)) (* (- (/ 1.0 (* x 9.0)) 1.0) (sqrt x))))
(* (* 3.0 (sqrt x)) (- (+ y (/ 1.0 (* x 9.0))) 1.0)))