x \cdot \left(1 + y \cdot y\right)
1 \cdot x + y \cdot \left(x \cdot y\right)
double f(double x, double y) {
double r290035 = x;
double r290036 = 1.0;
double r290037 = y;
double r290038 = r290037 * r290037;
double r290039 = r290036 + r290038;
double r290040 = r290035 * r290039;
return r290040;
}
double f(double x, double y) {
double r290041 = 1.0;
double r290042 = x;
double r290043 = r290041 * r290042;
double r290044 = y;
double r290045 = r290042 * r290044;
double r290046 = r290044 * r290045;
double r290047 = r290043 + r290046;
return r290047;
}




Bits error versus x




Bits error versus y
Results
| Original | 5.3 |
|---|---|
| Target | 0.1 |
| Herbie | 0.1 |
Initial program 5.3
rmApplied distribute-lft-in5.3
Simplified5.3
Simplified5.3
rmApplied associate-*l*0.1
Simplified0.1
Final simplification0.1
herbie shell --seed 2019306 +o rules:numerics
(FPCore (x y)
:name "Numeric.Integration.TanhSinh:everywhere from integration-0.2.1"
:precision binary64
:herbie-target
(+ x (* (* x y) y))
(* x (+ 1 (* y y))))