2 \cdot \left(x \cdot x + x \cdot y\right)
x \cdot \left(\left(x + y\right) \cdot 2\right)
double f(double x, double y) {
double r683242 = 2.0;
double r683243 = x;
double r683244 = r683243 * r683243;
double r683245 = y;
double r683246 = r683243 * r683245;
double r683247 = r683244 + r683246;
double r683248 = r683242 * r683247;
return r683248;
}
double f(double x, double y) {
double r683249 = x;
double r683250 = y;
double r683251 = r683249 + r683250;
double r683252 = 2.0;
double r683253 = r683251 * r683252;
double r683254 = r683249 * r683253;
return r683254;
}




Bits error versus x




Bits error versus y
Results
| Original | 0.0 |
|---|---|
| Target | 0.0 |
| Herbie | 0.1 |
Initial program 0.0
Simplified0.0
rmApplied associate-*l*0.1
Final simplification0.1
herbie shell --seed 2020089
(FPCore (x y)
:name "Linear.Matrix:fromQuaternion from linear-1.19.1.3, B"
:precision binary64
:herbie-target
(* (* x 2) (+ x y))
(* 2 (+ (* x x) (* x y))))