2 \cdot \left(\left(x \cdot y + z \cdot t\right) - \left(\left(a + b \cdot c\right) \cdot c\right) \cdot i\right)
2 \cdot \left(\left(x \cdot y + z \cdot t\right) - \left(\sqrt[3]{a + b \cdot c} \cdot \sqrt[3]{a + b \cdot c}\right) \cdot \left(\sqrt[3]{a + b \cdot c} \cdot \left(i \cdot c\right)\right)\right)double f(double x, double y, double z, double t, double a, double b, double c, double i) {
double r864901 = 2.0;
double r864902 = x;
double r864903 = y;
double r864904 = r864902 * r864903;
double r864905 = z;
double r864906 = t;
double r864907 = r864905 * r864906;
double r864908 = r864904 + r864907;
double r864909 = a;
double r864910 = b;
double r864911 = c;
double r864912 = r864910 * r864911;
double r864913 = r864909 + r864912;
double r864914 = r864913 * r864911;
double r864915 = i;
double r864916 = r864914 * r864915;
double r864917 = r864908 - r864916;
double r864918 = r864901 * r864917;
return r864918;
}
double f(double x, double y, double z, double t, double a, double b, double c, double i) {
double r864919 = 2.0;
double r864920 = x;
double r864921 = y;
double r864922 = r864920 * r864921;
double r864923 = z;
double r864924 = t;
double r864925 = r864923 * r864924;
double r864926 = r864922 + r864925;
double r864927 = a;
double r864928 = b;
double r864929 = c;
double r864930 = r864928 * r864929;
double r864931 = r864927 + r864930;
double r864932 = cbrt(r864931);
double r864933 = r864932 * r864932;
double r864934 = i;
double r864935 = r864934 * r864929;
double r864936 = r864932 * r864935;
double r864937 = r864933 * r864936;
double r864938 = r864926 - r864937;
double r864939 = r864919 * r864938;
return r864939;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a




Bits error versus b




Bits error versus c




Bits error versus i
Results
| Original | 6.5 |
|---|---|
| Target | 1.8 |
| Herbie | 2.1 |
Initial program 6.5
rmApplied associate-*l*1.8
Simplified1.8
rmApplied add-cube-cbrt2.1
Applied associate-*l*2.1
Final simplification2.1
herbie shell --seed 2020046
(FPCore (x y z t a b c i)
:name "Diagrams.ThreeD.Shapes:frustum from diagrams-lib-1.3.0.3, A"
:precision binary64
:herbie-target
(* 2 (- (+ (* x y) (* z t)) (* (+ a (* b c)) (* c i))))
(* 2 (- (+ (* x y) (* z t)) (* (* (+ a (* b c)) c) i))))