\left(a + b\right) \cdot \left(a + b\right)
a \cdot \left(b + a\right) + \left(b + a\right) \cdot b
double f(double a, double b) {
double r3150305 = a;
double r3150306 = b;
double r3150307 = r3150305 + r3150306;
double r3150308 = r3150307 * r3150307;
return r3150308;
}
double f(double a, double b) {
double r3150309 = a;
double r3150310 = b;
double r3150311 = r3150310 + r3150309;
double r3150312 = r3150309 * r3150311;
double r3150313 = r3150311 * r3150310;
double r3150314 = r3150312 + r3150313;
return r3150314;
}




Bits error versus a




Bits error versus b
Results
| Original | 0.0 |
|---|---|
| Target | 0.0 |
| Herbie | 0.0 |
Initial program 0.0
rmApplied distribute-rgt-in0.0
Final simplification0.0
herbie shell --seed 2019163 +o rules:numerics
(FPCore (a b)
:name "Expression 4, p15"
:pre (and (<= 5 a 10) (<= 0 b 0.001))
:herbie-target
(+ (+ (+ (* b a) (* b b)) (* b a)) (* a a))
(* (+ a b) (+ a b)))