\left(\left(x \cdot y + z \cdot z\right) + z \cdot z\right) + z \cdot z
\left(x \cdot y + z \cdot z\right) + z \cdot \left(z + z\right)
double f(double x, double y, double z) {
double r510240 = x;
double r510241 = y;
double r510242 = r510240 * r510241;
double r510243 = z;
double r510244 = r510243 * r510243;
double r510245 = r510242 + r510244;
double r510246 = r510245 + r510244;
double r510247 = r510246 + r510244;
return r510247;
}
double f(double x, double y, double z) {
double r510248 = x;
double r510249 = y;
double r510250 = r510248 * r510249;
double r510251 = z;
double r510252 = r510251 * r510251;
double r510253 = r510250 + r510252;
double r510254 = r510251 + r510251;
double r510255 = r510251 * r510254;
double r510256 = r510253 + r510255;
return r510256;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 0.1 |
|---|---|
| Target | 0.1 |
| Herbie | 0.1 |
Initial program 0.1
rmApplied associate-+l+0.1
Simplified0.1
Final simplification0.1
herbie shell --seed 2020024
(FPCore (x y z)
:name "Linear.Quaternion:$c/ from linear-1.19.1.3, A"
:precision binary64
:herbie-target
(+ (* (* 3 z) z) (* y x))
(+ (+ (+ (* x y) (* z z)) (* z z)) (* z z)))