\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}\;x \le -9.76110722553251634 \cdot 10^{-22}:\\
\;\;\;\;\left(x \cdot \left(y \cdot z - t \cdot a\right) - b \cdot \left(c \cdot z - i \cdot a\right)\right) + \left(\left(t \cdot j\right) \cdot c + \left(-\left(i \cdot j\right) \cdot y\right)\right)\\
\mathbf{elif}\;x \le 1.419491066943148 \cdot 10^{-153}:\\
\;\;\;\;\left(\left(x \cdot \left(z \cdot y\right) + \left(-a \cdot \left(x \cdot t\right)\right)\right) - b \cdot \left(c \cdot z - i \cdot a\right)\right) + \left(\left(t \cdot j\right) \cdot c + \left(-\left(\sqrt[3]{i} \cdot \sqrt[3]{i}\right) \cdot \left(\sqrt[3]{i} \cdot \left(j \cdot y\right)\right)\right)\right)\\
\mathbf{else}:\\
\;\;\;\;\left(x \cdot \left(y \cdot z - t \cdot a\right) - \left(z \cdot \left(b \cdot c\right) + \left(-i \cdot a\right) \cdot b\right)\right) + \left(\left(t \cdot j\right) \cdot c + \left(-i \cdot \left(j \cdot y\right)\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 r594057 = x;
double r594058 = y;
double r594059 = z;
double r594060 = r594058 * r594059;
double r594061 = t;
double r594062 = a;
double r594063 = r594061 * r594062;
double r594064 = r594060 - r594063;
double r594065 = r594057 * r594064;
double r594066 = b;
double r594067 = c;
double r594068 = r594067 * r594059;
double r594069 = i;
double r594070 = r594069 * r594062;
double r594071 = r594068 - r594070;
double r594072 = r594066 * r594071;
double r594073 = r594065 - r594072;
double r594074 = j;
double r594075 = r594067 * r594061;
double r594076 = r594069 * r594058;
double r594077 = r594075 - r594076;
double r594078 = r594074 * r594077;
double r594079 = r594073 + r594078;
return r594079;
}
double f(double x, double y, double z, double t, double a, double b, double c, double i, double j) {
double r594080 = x;
double r594081 = -9.761107225532516e-22;
bool r594082 = r594080 <= r594081;
double r594083 = y;
double r594084 = z;
double r594085 = r594083 * r594084;
double r594086 = t;
double r594087 = a;
double r594088 = r594086 * r594087;
double r594089 = r594085 - r594088;
double r594090 = r594080 * r594089;
double r594091 = b;
double r594092 = c;
double r594093 = r594092 * r594084;
double r594094 = i;
double r594095 = r594094 * r594087;
double r594096 = r594093 - r594095;
double r594097 = r594091 * r594096;
double r594098 = r594090 - r594097;
double r594099 = j;
double r594100 = r594086 * r594099;
double r594101 = r594100 * r594092;
double r594102 = r594094 * r594099;
double r594103 = r594102 * r594083;
double r594104 = -r594103;
double r594105 = r594101 + r594104;
double r594106 = r594098 + r594105;
double r594107 = 1.419491066943148e-153;
bool r594108 = r594080 <= r594107;
double r594109 = r594084 * r594083;
double r594110 = r594080 * r594109;
double r594111 = r594080 * r594086;
double r594112 = r594087 * r594111;
double r594113 = -r594112;
double r594114 = r594110 + r594113;
double r594115 = r594114 - r594097;
double r594116 = cbrt(r594094);
double r594117 = r594116 * r594116;
double r594118 = r594099 * r594083;
double r594119 = r594116 * r594118;
double r594120 = r594117 * r594119;
double r594121 = -r594120;
double r594122 = r594101 + r594121;
double r594123 = r594115 + r594122;
double r594124 = r594091 * r594092;
double r594125 = r594084 * r594124;
double r594126 = -r594095;
double r594127 = r594126 * r594091;
double r594128 = r594125 + r594127;
double r594129 = r594090 - r594128;
double r594130 = r594094 * r594118;
double r594131 = -r594130;
double r594132 = r594101 + r594131;
double r594133 = r594129 + r594132;
double r594134 = r594108 ? r594123 : r594133;
double r594135 = r594082 ? r594106 : r594134;
return r594135;
}




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.3 |
|---|---|
| Target | 16.3 |
| Herbie | 11.3 |
if x < -9.761107225532516e-22Initial program 7.4
rmApplied sub-neg7.4
Applied distribute-lft-in7.4
Simplified8.4
Simplified8.0
rmApplied associate-*r*8.1
rmApplied associate-*r*8.4
if -9.761107225532516e-22 < x < 1.419491066943148e-153Initial program 16.3
rmApplied sub-neg16.3
Applied distribute-lft-in16.3
Simplified16.4
Simplified16.2
rmApplied associate-*r*16.3
rmApplied add-cube-cbrt16.4
Applied associate-*l*16.4
rmApplied sub-neg16.4
Applied distribute-lft-in16.4
Simplified16.4
Simplified13.7
if 1.419491066943148e-153 < x Initial program 10.0
rmApplied sub-neg10.0
Applied distribute-lft-in10.0
Simplified10.8
Simplified10.5
rmApplied associate-*r*10.1
rmApplied sub-neg10.1
Applied distribute-lft-in10.1
Simplified10.1
Simplified10.1
Final simplification11.3
herbie shell --seed 2020047
(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)))))