\left(\left(x \cdot y + z \cdot z\right) + z \cdot z\right) + z \cdot z
\left(3 \cdot z\right) \cdot z + x \cdot y
double f(double x, double y, double z) {
double r534784 = x;
double r534785 = y;
double r534786 = r534784 * r534785;
double r534787 = z;
double r534788 = r534787 * r534787;
double r534789 = r534786 + r534788;
double r534790 = r534789 + r534788;
double r534791 = r534790 + r534788;
return r534791;
}
double f(double x, double y, double z) {
double r534792 = 3.0;
double r534793 = z;
double r534794 = r534792 * r534793;
double r534795 = r534794 * r534793;
double r534796 = x;
double r534797 = y;
double r534798 = r534796 * r534797;
double r534799 = r534795 + r534798;
return r534799;
}




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
Simplified0.1
rmApplied fma-udef0.1
rmApplied associate-*r*0.1
Final simplification0.1
herbie shell --seed 2019353 +o rules:numerics
(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)))