\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}\;b \le -9.1167379607392149 \cdot 10^{-144} \lor \neg \left(b \le 2.65254915776862487 \cdot 10^{-221}\right):\\
\;\;\;\;\left(x \cdot \left(y \cdot z - t \cdot a\right) - b \cdot \left(c \cdot z - i \cdot a\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]{\left(j \cdot \left(\sqrt[3]{c \cdot t - i \cdot y} \cdot \sqrt[3]{c \cdot t - i \cdot y}\right)\right) \cdot \sqrt[3]{c \cdot t - i \cdot y}}\\
\mathbf{else}:\\
\;\;\;\;\left(x \cdot \left(y \cdot z - t \cdot a\right) - \left(\sqrt[3]{b} \cdot \sqrt[3]{b}\right) \cdot 0\right) + j \cdot \left(c \cdot t - i \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 r681467 = x;
double r681468 = y;
double r681469 = z;
double r681470 = r681468 * r681469;
double r681471 = t;
double r681472 = a;
double r681473 = r681471 * r681472;
double r681474 = r681470 - r681473;
double r681475 = r681467 * r681474;
double r681476 = b;
double r681477 = c;
double r681478 = r681477 * r681469;
double r681479 = i;
double r681480 = r681479 * r681472;
double r681481 = r681478 - r681480;
double r681482 = r681476 * r681481;
double r681483 = r681475 - r681482;
double r681484 = j;
double r681485 = r681477 * r681471;
double r681486 = r681479 * r681468;
double r681487 = r681485 - r681486;
double r681488 = r681484 * r681487;
double r681489 = r681483 + r681488;
return r681489;
}
double f(double x, double y, double z, double t, double a, double b, double c, double i, double j) {
double r681490 = b;
double r681491 = -9.116737960739215e-144;
bool r681492 = r681490 <= r681491;
double r681493 = 2.652549157768625e-221;
bool r681494 = r681490 <= r681493;
double r681495 = !r681494;
bool r681496 = r681492 || r681495;
double r681497 = x;
double r681498 = y;
double r681499 = z;
double r681500 = r681498 * r681499;
double r681501 = t;
double r681502 = a;
double r681503 = r681501 * r681502;
double r681504 = r681500 - r681503;
double r681505 = r681497 * r681504;
double r681506 = c;
double r681507 = r681506 * r681499;
double r681508 = i;
double r681509 = r681508 * r681502;
double r681510 = r681507 - r681509;
double r681511 = r681490 * r681510;
double r681512 = r681505 - r681511;
double r681513 = j;
double r681514 = r681506 * r681501;
double r681515 = r681508 * r681498;
double r681516 = r681514 - r681515;
double r681517 = r681513 * r681516;
double r681518 = cbrt(r681517);
double r681519 = r681518 * r681518;
double r681520 = cbrt(r681516);
double r681521 = r681520 * r681520;
double r681522 = r681513 * r681521;
double r681523 = r681522 * r681520;
double r681524 = cbrt(r681523);
double r681525 = r681519 * r681524;
double r681526 = r681512 + r681525;
double r681527 = cbrt(r681490);
double r681528 = r681527 * r681527;
double r681529 = 0.0;
double r681530 = r681528 * r681529;
double r681531 = r681505 - r681530;
double r681532 = r681531 + r681517;
double r681533 = r681496 ? r681526 : r681532;
return r681533;
}




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
| Original | 12.5 |
|---|---|
| Target | 16.6 |
| Herbie | 12.5 |
if b < -9.116737960739215e-144 or 2.652549157768625e-221 < b Initial program 10.5
rmApplied add-cube-cbrt10.7
rmApplied add-cube-cbrt10.7
Applied associate-*r*10.7
if -9.116737960739215e-144 < b < 2.652549157768625e-221Initial program 18.3
rmApplied add-cube-cbrt18.3
Applied associate-*l*18.3
Taylor expanded around 0 17.6
Final simplification12.5
herbie shell --seed 2020034
(FPCore (x y z t a b c i j)
:name "Linear.Matrix:det33 from linear-1.19.1.3"
:precision binary64
:herbie-target
(if (< t -8.120978919195912e-33) (- (* x (- (* z y) (* a t))) (- (* b (- (* z c) (* a i))) (* (- (* c t) (* y i)) j))) (if (< t -4.712553818218485e-169) (+ (- (* x (- (* y z) (* t a))) (* b (- (* c z) (* i a)))) (/ (* j (- (pow (* c t) 2) (pow (* i y) 2))) (+ (* c t) (* i y)))) (if (< t -7.633533346031584e-308) (- (* x (- (* z y) (* a t))) (- (* b (- (* z c) (* a i))) (* (- (* c t) (* y i)) j))) (if (< t 1.0535888557455487e-139) (+ (- (* x (- (* y z) (* t a))) (* b (- (* c z) (* i a)))) (/ (* j (- (pow (* c t) 2) (pow (* i y) 2))) (+ (* c t) (* i y)))) (- (* x (- (* z y) (* a t))) (- (* b (- (* z c) (* a i))) (* (- (* c t) (* y i)) j)))))))
(+ (- (* x (- (* y z) (* t a))) (* b (- (* c z) (* i a)))) (* j (- (* c t) (* i y)))))