\left(x \cdot \left(y \cdot z - t \cdot a\right) - b \cdot \left(c \cdot z - i \cdot a\right)\right) + j \cdot \left(c \cdot t - i \cdot y\right)
\begin{array}{l}
\mathbf{if}\;\left(x \cdot \left(y \cdot z - t \cdot a\right) - b \cdot \left(c \cdot z - i \cdot a\right)\right) + j \cdot \left(c \cdot t - i \cdot y\right) \le -5.81059302235525334 \cdot 10^{282}:\\
\;\;\;\;\left(x \cdot \left(y \cdot z - t \cdot a\right) - \left(\left(b \cdot c\right) \cdot z + b \cdot \left(-i \cdot a\right)\right)\right) + j \cdot \left(c \cdot t - i \cdot y\right)\\
\mathbf{elif}\;\left(x \cdot \left(y \cdot z - t \cdot a\right) - b \cdot \left(c \cdot z - i \cdot a\right)\right) + j \cdot \left(c \cdot t - i \cdot y\right) \le 1.7267276916147896 \cdot 10^{303}:\\
\;\;\;\;\left(x \cdot \left(y \cdot z - t \cdot a\right) - \left(b \cdot \left(c \cdot z\right) + b \cdot \left(-i \cdot a\right)\right)\right) + \left(\sqrt[3]{j \cdot \left(c \cdot t - i \cdot y\right)} \cdot \sqrt[3]{j \cdot \left(c \cdot t - i \cdot y\right)}\right) \cdot \sqrt[3]{j \cdot \left(c \cdot t - i \cdot y\right)}\\
\mathbf{else}:\\
\;\;\;\;\left(t \cdot \left(j \cdot c\right) + a \cdot \left(i \cdot b\right)\right) - i \cdot \left(j \cdot y\right)\\
\end{array}double f(double x, double y, double z, double t, double a, double b, double c, double i, double j) {
double r124214 = x;
double r124215 = y;
double r124216 = z;
double r124217 = r124215 * r124216;
double r124218 = t;
double r124219 = a;
double r124220 = r124218 * r124219;
double r124221 = r124217 - r124220;
double r124222 = r124214 * r124221;
double r124223 = b;
double r124224 = c;
double r124225 = r124224 * r124216;
double r124226 = i;
double r124227 = r124226 * r124219;
double r124228 = r124225 - r124227;
double r124229 = r124223 * r124228;
double r124230 = r124222 - r124229;
double r124231 = j;
double r124232 = r124224 * r124218;
double r124233 = r124226 * r124215;
double r124234 = r124232 - r124233;
double r124235 = r124231 * r124234;
double r124236 = r124230 + r124235;
return r124236;
}
double f(double x, double y, double z, double t, double a, double b, double c, double i, double j) {
double r124237 = x;
double r124238 = y;
double r124239 = z;
double r124240 = r124238 * r124239;
double r124241 = t;
double r124242 = a;
double r124243 = r124241 * r124242;
double r124244 = r124240 - r124243;
double r124245 = r124237 * r124244;
double r124246 = b;
double r124247 = c;
double r124248 = r124247 * r124239;
double r124249 = i;
double r124250 = r124249 * r124242;
double r124251 = r124248 - r124250;
double r124252 = r124246 * r124251;
double r124253 = r124245 - r124252;
double r124254 = j;
double r124255 = r124247 * r124241;
double r124256 = r124249 * r124238;
double r124257 = r124255 - r124256;
double r124258 = r124254 * r124257;
double r124259 = r124253 + r124258;
double r124260 = -5.810593022355253e+282;
bool r124261 = r124259 <= r124260;
double r124262 = r124246 * r124247;
double r124263 = r124262 * r124239;
double r124264 = -r124250;
double r124265 = r124246 * r124264;
double r124266 = r124263 + r124265;
double r124267 = r124245 - r124266;
double r124268 = r124267 + r124258;
double r124269 = 1.7267276916147896e+303;
bool r124270 = r124259 <= r124269;
double r124271 = r124246 * r124248;
double r124272 = r124271 + r124265;
double r124273 = r124245 - r124272;
double r124274 = cbrt(r124258);
double r124275 = r124274 * r124274;
double r124276 = r124275 * r124274;
double r124277 = r124273 + r124276;
double r124278 = r124254 * r124247;
double r124279 = r124241 * r124278;
double r124280 = r124249 * r124246;
double r124281 = r124242 * r124280;
double r124282 = r124279 + r124281;
double r124283 = r124254 * r124238;
double r124284 = r124249 * r124283;
double r124285 = r124282 - r124284;
double r124286 = r124270 ? r124277 : r124285;
double r124287 = r124261 ? r124268 : r124286;
return r124287;
}



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
Results
if (+ (- (* x (- (* y z) (* t a))) (* b (- (* c z) (* i a)))) (* j (- (* c t) (* i y)))) < -5.810593022355253e+282Initial program 45.6
rmApplied sub-neg45.6
Applied distribute-lft-in45.6
rmApplied associate-*r*40.3
if -5.810593022355253e+282 < (+ (- (* x (- (* y z) (* t a))) (* b (- (* c z) (* i a)))) (* j (- (* c t) (* i y)))) < 1.7267276916147896e+303Initial program 0.9
rmApplied sub-neg0.9
Applied distribute-lft-in0.9
rmApplied add-cube-cbrt1.3
if 1.7267276916147896e+303 < (+ (- (* x (- (* y z) (* t a))) (* b (- (* c z) (* i a)))) (* j (- (* c t) (* i y)))) Initial program 60.6
Taylor expanded around inf 36.3
Final simplification9.4
herbie shell --seed 2020065
(FPCore (x y z t a b c i j)
:name "Linear.Matrix:det33 from linear-1.19.1.3"
:precision binary64
(+ (- (* x (- (* y z) (* t a))) (* b (- (* c z) (* i a)))) (* j (- (* c t) (* i y)))))