\left(\left(\left(\left(\left(\left(x \cdot 18\right) \cdot y\right) \cdot z\right) \cdot t - \left(a \cdot 4\right) \cdot t\right) + b \cdot c\right) - \left(x \cdot 4\right) \cdot i\right) - \left(j \cdot 27\right) \cdot k
\begin{array}{l}
\mathbf{if}\;z \le -4.995746752057705666616031777662888381911 \cdot 10^{-77}:\\
\;\;\;\;\mathsf{fma}\left(t, \left(x \cdot \left(18 \cdot y\right)\right) \cdot z - a \cdot 4, b \cdot c - \mathsf{fma}\left(x, 4 \cdot i, j \cdot \left(27 \cdot k\right)\right)\right)\\
\mathbf{elif}\;z \le 31.71288006302372508571352227590978145599:\\
\;\;\;\;t \cdot \left(18 \cdot \left(x \cdot \left(z \cdot y\right)\right) - a \cdot 4\right) + \left(b \cdot c - \mathsf{fma}\left(x, 4 \cdot i, j \cdot \left(27 \cdot k\right)\right)\right)\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(t, \left(\left(x \cdot 18\right) \cdot y\right) \cdot z - a \cdot 4, b \cdot c - \mathsf{fma}\left(x, 4 \cdot i, \left(\left(j \cdot 27\right) \cdot \left(\sqrt[3]{k} \cdot \sqrt[3]{k}\right)\right) \cdot \sqrt[3]{k}\right)\right)\\
\end{array}double f(double x, double y, double z, double t, double a, double b, double c, double i, double j, double k) {
double r145830 = x;
double r145831 = 18.0;
double r145832 = r145830 * r145831;
double r145833 = y;
double r145834 = r145832 * r145833;
double r145835 = z;
double r145836 = r145834 * r145835;
double r145837 = t;
double r145838 = r145836 * r145837;
double r145839 = a;
double r145840 = 4.0;
double r145841 = r145839 * r145840;
double r145842 = r145841 * r145837;
double r145843 = r145838 - r145842;
double r145844 = b;
double r145845 = c;
double r145846 = r145844 * r145845;
double r145847 = r145843 + r145846;
double r145848 = r145830 * r145840;
double r145849 = i;
double r145850 = r145848 * r145849;
double r145851 = r145847 - r145850;
double r145852 = j;
double r145853 = 27.0;
double r145854 = r145852 * r145853;
double r145855 = k;
double r145856 = r145854 * r145855;
double r145857 = r145851 - r145856;
return r145857;
}
double f(double x, double y, double z, double t, double a, double b, double c, double i, double j, double k) {
double r145858 = z;
double r145859 = -4.995746752057706e-77;
bool r145860 = r145858 <= r145859;
double r145861 = t;
double r145862 = x;
double r145863 = 18.0;
double r145864 = y;
double r145865 = r145863 * r145864;
double r145866 = r145862 * r145865;
double r145867 = r145866 * r145858;
double r145868 = a;
double r145869 = 4.0;
double r145870 = r145868 * r145869;
double r145871 = r145867 - r145870;
double r145872 = b;
double r145873 = c;
double r145874 = r145872 * r145873;
double r145875 = i;
double r145876 = r145869 * r145875;
double r145877 = j;
double r145878 = 27.0;
double r145879 = k;
double r145880 = r145878 * r145879;
double r145881 = r145877 * r145880;
double r145882 = fma(r145862, r145876, r145881);
double r145883 = r145874 - r145882;
double r145884 = fma(r145861, r145871, r145883);
double r145885 = 31.712880063023725;
bool r145886 = r145858 <= r145885;
double r145887 = r145858 * r145864;
double r145888 = r145862 * r145887;
double r145889 = r145863 * r145888;
double r145890 = r145889 - r145870;
double r145891 = r145861 * r145890;
double r145892 = r145891 + r145883;
double r145893 = r145862 * r145863;
double r145894 = r145893 * r145864;
double r145895 = r145894 * r145858;
double r145896 = r145895 - r145870;
double r145897 = r145877 * r145878;
double r145898 = cbrt(r145879);
double r145899 = r145898 * r145898;
double r145900 = r145897 * r145899;
double r145901 = r145900 * r145898;
double r145902 = fma(r145862, r145876, r145901);
double r145903 = r145874 - r145902;
double r145904 = fma(r145861, r145896, r145903);
double r145905 = r145886 ? r145892 : r145904;
double r145906 = r145860 ? r145884 : r145905;
return r145906;
}



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



Bits error versus j



Bits error versus k
if z < -4.995746752057706e-77Initial program 5.7
Simplified5.7
rmApplied associate-*l*5.8
rmApplied associate-*l*5.8
if -4.995746752057706e-77 < z < 31.712880063023725Initial program 4.6
Simplified4.6
rmApplied associate-*l*4.6
rmApplied fma-udef4.6
Taylor expanded around inf 1.2
if 31.712880063023725 < z Initial program 7.0
Simplified7.0
rmApplied add-cube-cbrt7.3
Applied associate-*r*7.3
Final simplification3.9
herbie shell --seed 2020002 +o rules:numerics
(FPCore (x y z t a b c i j k)
:name "Diagrams.Solve.Polynomial:cubForm from diagrams-solve-0.1"
:precision binary64
(- (- (+ (- (* (* (* (* x 18) y) z) t) (* (* a 4) t)) (* b c)) (* (* x 4) i)) (* (* j 27) k)))