\left(\left(\left(\left(\left(\left(x \cdot 18.0\right) \cdot y\right) \cdot z\right) \cdot t - \left(a \cdot 4.0\right) \cdot t\right) + b \cdot c\right) - \left(x \cdot 4.0\right) \cdot i\right) - \left(j \cdot 27.0\right) \cdot k
\begin{array}{l}
\mathbf{if}\;t \le -2.547922086558821 \cdot 10^{-88}:\\
\;\;\;\;\left(\left(b \cdot c + \left(\left(\left(\left(x \cdot 18.0\right) \cdot y\right) \cdot z\right) \cdot t - \left(a \cdot 4.0\right) \cdot t\right)\right) - \left(4.0 \cdot x\right) \cdot i\right) - 27.0 \cdot \left(j \cdot k\right)\\
\mathbf{elif}\;t \le 5.279639422401091 \cdot 10^{-09}:\\
\;\;\;\;\left(\left(b \cdot c + \left(\left(t \cdot z\right) \cdot \left(\left(x \cdot 18.0\right) \cdot y\right) - \left(a \cdot 4.0\right) \cdot t\right)\right) - \left(4.0 \cdot x\right) \cdot i\right) - \left(27.0 \cdot k\right) \cdot j\\
\mathbf{else}:\\
\;\;\;\;\left(\left(b \cdot c + \left(t \cdot \left(\left(x \cdot 18.0\right) \cdot \left(y \cdot z\right)\right) - \left(a \cdot 4.0\right) \cdot t\right)\right) - \left(4.0 \cdot x\right) \cdot i\right) - \left(27.0 \cdot k\right) \cdot j\\
\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 r20250063 = x;
double r20250064 = 18.0;
double r20250065 = r20250063 * r20250064;
double r20250066 = y;
double r20250067 = r20250065 * r20250066;
double r20250068 = z;
double r20250069 = r20250067 * r20250068;
double r20250070 = t;
double r20250071 = r20250069 * r20250070;
double r20250072 = a;
double r20250073 = 4.0;
double r20250074 = r20250072 * r20250073;
double r20250075 = r20250074 * r20250070;
double r20250076 = r20250071 - r20250075;
double r20250077 = b;
double r20250078 = c;
double r20250079 = r20250077 * r20250078;
double r20250080 = r20250076 + r20250079;
double r20250081 = r20250063 * r20250073;
double r20250082 = i;
double r20250083 = r20250081 * r20250082;
double r20250084 = r20250080 - r20250083;
double r20250085 = j;
double r20250086 = 27.0;
double r20250087 = r20250085 * r20250086;
double r20250088 = k;
double r20250089 = r20250087 * r20250088;
double r20250090 = r20250084 - r20250089;
return r20250090;
}
double f(double x, double y, double z, double t, double a, double b, double c, double i, double j, double k) {
double r20250091 = t;
double r20250092 = -2.547922086558821e-88;
bool r20250093 = r20250091 <= r20250092;
double r20250094 = b;
double r20250095 = c;
double r20250096 = r20250094 * r20250095;
double r20250097 = x;
double r20250098 = 18.0;
double r20250099 = r20250097 * r20250098;
double r20250100 = y;
double r20250101 = r20250099 * r20250100;
double r20250102 = z;
double r20250103 = r20250101 * r20250102;
double r20250104 = r20250103 * r20250091;
double r20250105 = a;
double r20250106 = 4.0;
double r20250107 = r20250105 * r20250106;
double r20250108 = r20250107 * r20250091;
double r20250109 = r20250104 - r20250108;
double r20250110 = r20250096 + r20250109;
double r20250111 = r20250106 * r20250097;
double r20250112 = i;
double r20250113 = r20250111 * r20250112;
double r20250114 = r20250110 - r20250113;
double r20250115 = 27.0;
double r20250116 = j;
double r20250117 = k;
double r20250118 = r20250116 * r20250117;
double r20250119 = r20250115 * r20250118;
double r20250120 = r20250114 - r20250119;
double r20250121 = 5.279639422401091e-09;
bool r20250122 = r20250091 <= r20250121;
double r20250123 = r20250091 * r20250102;
double r20250124 = r20250123 * r20250101;
double r20250125 = r20250124 - r20250108;
double r20250126 = r20250096 + r20250125;
double r20250127 = r20250126 - r20250113;
double r20250128 = r20250115 * r20250117;
double r20250129 = r20250128 * r20250116;
double r20250130 = r20250127 - r20250129;
double r20250131 = r20250100 * r20250102;
double r20250132 = r20250099 * r20250131;
double r20250133 = r20250091 * r20250132;
double r20250134 = r20250133 - r20250108;
double r20250135 = r20250096 + r20250134;
double r20250136 = r20250135 - r20250113;
double r20250137 = r20250136 - r20250129;
double r20250138 = r20250122 ? r20250130 : r20250137;
double r20250139 = r20250093 ? r20250120 : r20250138;
return r20250139;
}



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
Results
if t < -2.547922086558821e-88Initial program 2.6
rmApplied associate-*l*2.7
Taylor expanded around 0 2.6
if -2.547922086558821e-88 < t < 5.279639422401091e-09Initial program 7.2
rmApplied associate-*l*7.2
rmApplied associate-*l*4.1
if 5.279639422401091e-09 < t Initial program 1.7
rmApplied associate-*l*1.7
rmApplied associate-*l*2.3
Final simplification3.3
herbie shell --seed 2019112 +o rules:numerics
(FPCore (x y z t a b c i j k)
:name "Diagrams.Solve.Polynomial:cubForm from diagrams-solve-0.1"
(- (- (+ (- (* (* (* (* x 18.0) y) z) t) (* (* a 4.0) t)) (* b c)) (* (* x 4.0) i)) (* (* j 27.0) k)))