\left(3 \cdot \sqrt{x}\right) \cdot \left(\left(y + \frac{1}{x \cdot 9}\right) - 1\right)\frac{0.3333333333333333}{\sqrt{x}} + \left(3 \cdot \left(\sqrt{x} \cdot y\right) - \sqrt{x} \cdot 3\right)(FPCore (x y) :precision binary64 (* (* 3.0 (sqrt x)) (- (+ y (/ 1.0 (* x 9.0))) 1.0)))
(FPCore (x y) :precision binary64 (+ (/ 0.3333333333333333 (sqrt x)) (- (* 3.0 (* (sqrt x) y)) (* (sqrt x) 3.0))))
double code(double x, double y) {
return (3.0 * sqrt(x)) * ((y + (1.0 / (x * 9.0))) - 1.0);
}
double code(double x, double y) {
return (0.3333333333333333 / sqrt(x)) + ((3.0 * (sqrt(x) * y)) - (sqrt(x) * 3.0));
}




Bits error versus x




Bits error versus y
Results
| Original | 0.4 |
|---|---|
| Target | 0.4 |
| Herbie | 0.4 |
Initial program 0.4
Taylor expanded around 0 0.4
Simplified0.4
rmApplied sqrt-div_binary64_191910.4
Applied associate-*r/_binary64_191160.4
Simplified0.4
Final simplification0.4
herbie shell --seed 2021176
(FPCore (x y)
:name "Numeric.SpecFunctions:incompleteGamma from math-functions-0.1.5.2, B"
:precision binary64
: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)))