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 r553417 = 2.0;
double r553418 = x;
double r553419 = r553418 * r553418;
double r553420 = y;
double r553421 = r553418 * r553420;
double r553422 = r553419 + r553421;
double r553423 = r553417 * r553422;
return r553423;
}
double f(double x, double y) {
double r553424 = x;
double r553425 = y;
double r553426 = r553424 + r553425;
double r553427 = 2.0;
double r553428 = r553426 * r553427;
double r553429 = r553424 * r553428;
return r553429;
}




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 2020045
(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))))