\frac{1}{3} \cdot \cos^{-1} \left(\frac{3 \cdot \frac{x}{y \cdot 27}}{z \cdot 2} \cdot \sqrt{t}\right)\left(\frac{1}{\sqrt[3]{3}} \cdot \cos^{-1} \left(\frac{\frac{x}{27 \cdot y} \cdot 3}{2 \cdot z} \cdot \sqrt{t}\right)\right) \cdot \frac{1}{\sqrt[3]{3} \cdot \sqrt[3]{3}}double f(double x, double y, double z, double t) {
double r34062043 = 1.0;
double r34062044 = 3.0;
double r34062045 = r34062043 / r34062044;
double r34062046 = x;
double r34062047 = y;
double r34062048 = 27.0;
double r34062049 = r34062047 * r34062048;
double r34062050 = r34062046 / r34062049;
double r34062051 = r34062044 * r34062050;
double r34062052 = z;
double r34062053 = 2.0;
double r34062054 = r34062052 * r34062053;
double r34062055 = r34062051 / r34062054;
double r34062056 = t;
double r34062057 = sqrt(r34062056);
double r34062058 = r34062055 * r34062057;
double r34062059 = acos(r34062058);
double r34062060 = r34062045 * r34062059;
return r34062060;
}
double f(double x, double y, double z, double t) {
double r34062061 = 1.0;
double r34062062 = 3.0;
double r34062063 = cbrt(r34062062);
double r34062064 = r34062061 / r34062063;
double r34062065 = x;
double r34062066 = 27.0;
double r34062067 = y;
double r34062068 = r34062066 * r34062067;
double r34062069 = r34062065 / r34062068;
double r34062070 = r34062069 * r34062062;
double r34062071 = 2.0;
double r34062072 = z;
double r34062073 = r34062071 * r34062072;
double r34062074 = r34062070 / r34062073;
double r34062075 = t;
double r34062076 = sqrt(r34062075);
double r34062077 = r34062074 * r34062076;
double r34062078 = acos(r34062077);
double r34062079 = r34062064 * r34062078;
double r34062080 = 1.0;
double r34062081 = r34062063 * r34062063;
double r34062082 = r34062080 / r34062081;
double r34062083 = r34062079 * r34062082;
return r34062083;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 1.3 |
|---|---|
| Target | 1.3 |
| Herbie | 0.4 |
Initial program 1.3
rmApplied add-cube-cbrt1.3
Applied *-un-lft-identity1.3
Applied times-frac0.4
Applied associate-*l*0.4
Final simplification0.4
herbie shell --seed 2019192 +o rules:numerics
(FPCore (x y z t)
:name "Diagrams.Solve.Polynomial:cubForm from diagrams-solve-0.1, D"
:herbie-target
(/ (acos (* (/ (/ x 27.0) (* y z)) (/ (sqrt t) (/ 2.0 3.0)))) 3.0)
(* (/ 1.0 3.0) (acos (* (/ (* 3.0 (/ x (* y 27.0))) (* z 2.0)) (sqrt t)))))