\frac{1}{3} \cdot \cos^{-1} \left(\frac{3 \cdot \frac{x}{y \cdot 27}}{z \cdot 2} \cdot \sqrt{t}\right)\frac{1}{\sqrt[3]{3} \cdot \sqrt[3]{3}} \cdot \left(\frac{1}{\sqrt[3]{3}} \cdot \cos^{-1} \left(\frac{3 \cdot \frac{x}{y \cdot 27}}{z \cdot 2} \cdot \sqrt{t}\right)\right)double f(double x, double y, double z, double t) {
double r86563936 = 1.0;
double r86563937 = 3.0;
double r86563938 = r86563936 / r86563937;
double r86563939 = x;
double r86563940 = y;
double r86563941 = 27.0;
double r86563942 = r86563940 * r86563941;
double r86563943 = r86563939 / r86563942;
double r86563944 = r86563937 * r86563943;
double r86563945 = z;
double r86563946 = 2.0;
double r86563947 = r86563945 * r86563946;
double r86563948 = r86563944 / r86563947;
double r86563949 = t;
double r86563950 = sqrt(r86563949);
double r86563951 = r86563948 * r86563950;
double r86563952 = acos(r86563951);
double r86563953 = r86563938 * r86563952;
return r86563953;
}
double f(double x, double y, double z, double t) {
double r86563954 = 1.0;
double r86563955 = 3.0;
double r86563956 = cbrt(r86563955);
double r86563957 = r86563956 * r86563956;
double r86563958 = r86563954 / r86563957;
double r86563959 = 1.0;
double r86563960 = r86563959 / r86563956;
double r86563961 = x;
double r86563962 = y;
double r86563963 = 27.0;
double r86563964 = r86563962 * r86563963;
double r86563965 = r86563961 / r86563964;
double r86563966 = r86563955 * r86563965;
double r86563967 = z;
double r86563968 = 2.0;
double r86563969 = r86563967 * r86563968;
double r86563970 = r86563966 / r86563969;
double r86563971 = t;
double r86563972 = sqrt(r86563971);
double r86563973 = r86563970 * r86563972;
double r86563974 = acos(r86563973);
double r86563975 = r86563960 * r86563974;
double r86563976 = r86563958 * r86563975;
return r86563976;
}




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 2019173 +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)))))