\left(3 \cdot \sqrt{x}\right) \cdot \left(\left(y + \frac{1}{x \cdot 9}\right) - 1\right)\left(3 \cdot \left(y + \frac{\frac{1}{x}}{9}\right)\right) \cdot \sqrt{x} + 3 \cdot \left(\left(-1\right) \cdot \sqrt{x}\right)double f(double x, double y) {
double r504204 = 3.0;
double r504205 = x;
double r504206 = sqrt(r504205);
double r504207 = r504204 * r504206;
double r504208 = y;
double r504209 = 1.0;
double r504210 = 9.0;
double r504211 = r504205 * r504210;
double r504212 = r504209 / r504211;
double r504213 = r504208 + r504212;
double r504214 = r504213 - r504209;
double r504215 = r504207 * r504214;
return r504215;
}
double f(double x, double y) {
double r504216 = 3.0;
double r504217 = y;
double r504218 = 1.0;
double r504219 = x;
double r504220 = r504218 / r504219;
double r504221 = 9.0;
double r504222 = r504220 / r504221;
double r504223 = r504217 + r504222;
double r504224 = r504216 * r504223;
double r504225 = sqrt(r504219);
double r504226 = r504224 * r504225;
double r504227 = -r504218;
double r504228 = r504227 * r504225;
double r504229 = r504216 * r504228;
double r504230 = r504226 + r504229;
return r504230;
}




Bits error versus x




Bits error versus y
Results
| Original | 0.4 |
|---|---|
| Target | 0.4 |
| Herbie | 0.5 |
Initial program 0.4
rmApplied associate-*l*0.4
rmApplied sub-neg0.4
Applied distribute-lft-in0.4
Applied distribute-lft-in0.4
Simplified0.4
Simplified0.4
rmApplied associate-*r*0.5
rmApplied associate-/r*0.5
Final simplification0.5
herbie shell --seed 2020035 +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)))