\left(x \cdot \left(y \cdot z - t \cdot a\right) - b \cdot \left(c \cdot z - t \cdot i\right)\right) + j \cdot \left(c \cdot a - y \cdot i\right)
\begin{array}{l}
\mathbf{if}\;a \le -7.34696385450285961 \cdot 10^{-162}:\\
\;\;\;\;\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 - t \cdot i\right)\right) + j \cdot \left(c \cdot a - y \cdot i\right)\\
\mathbf{elif}\;a \le 2.9280986771833522 \cdot 10^{-207}:\\
\;\;\;\;\left(x \cdot \left(y \cdot z - t \cdot a\right) - \left(z \cdot \left(b \cdot c\right) + \left(-t \cdot i\right) \cdot b\right)\right) + j \cdot \left(c \cdot a - y \cdot i\right)\\
\mathbf{elif}\;a \le 2.00957151932431567 \cdot 10^{-45}:\\
\;\;\;\;\left(\left(\sqrt[3]{x \cdot \left(y \cdot z - t \cdot a\right)} \cdot \sqrt[3]{x \cdot \left(y \cdot z - t \cdot a\right)}\right) \cdot \sqrt[3]{x \cdot \left(y \cdot z - t \cdot a\right)} - b \cdot \left(c \cdot z - t \cdot i\right)\right) + j \cdot \left(c \cdot a - y \cdot i\right)\\
\mathbf{else}:\\
\;\;\;\;\left(x \cdot \left(y \cdot z - t \cdot a\right) - b \cdot \left(c \cdot z - t \cdot i\right)\right) + \left(a \cdot \left(j \cdot c\right) + j \cdot \left(-y \cdot i\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 r837012 = x;
double r837013 = y;
double r837014 = z;
double r837015 = r837013 * r837014;
double r837016 = t;
double r837017 = a;
double r837018 = r837016 * r837017;
double r837019 = r837015 - r837018;
double r837020 = r837012 * r837019;
double r837021 = b;
double r837022 = c;
double r837023 = r837022 * r837014;
double r837024 = i;
double r837025 = r837016 * r837024;
double r837026 = r837023 - r837025;
double r837027 = r837021 * r837026;
double r837028 = r837020 - r837027;
double r837029 = j;
double r837030 = r837022 * r837017;
double r837031 = r837013 * r837024;
double r837032 = r837030 - r837031;
double r837033 = r837029 * r837032;
double r837034 = r837028 + r837033;
return r837034;
}
double f(double x, double y, double z, double t, double a, double b, double c, double i, double j) {
double r837035 = a;
double r837036 = -7.34696385450286e-162;
bool r837037 = r837035 <= r837036;
double r837038 = x;
double r837039 = z;
double r837040 = y;
double r837041 = r837039 * r837040;
double r837042 = r837038 * r837041;
double r837043 = t;
double r837044 = r837038 * r837043;
double r837045 = r837035 * r837044;
double r837046 = -r837045;
double r837047 = r837042 + r837046;
double r837048 = b;
double r837049 = c;
double r837050 = r837049 * r837039;
double r837051 = i;
double r837052 = r837043 * r837051;
double r837053 = r837050 - r837052;
double r837054 = r837048 * r837053;
double r837055 = r837047 - r837054;
double r837056 = j;
double r837057 = r837049 * r837035;
double r837058 = r837040 * r837051;
double r837059 = r837057 - r837058;
double r837060 = r837056 * r837059;
double r837061 = r837055 + r837060;
double r837062 = 2.9280986771833522e-207;
bool r837063 = r837035 <= r837062;
double r837064 = r837040 * r837039;
double r837065 = r837043 * r837035;
double r837066 = r837064 - r837065;
double r837067 = r837038 * r837066;
double r837068 = r837048 * r837049;
double r837069 = r837039 * r837068;
double r837070 = -r837052;
double r837071 = r837070 * r837048;
double r837072 = r837069 + r837071;
double r837073 = r837067 - r837072;
double r837074 = r837073 + r837060;
double r837075 = 2.0095715193243157e-45;
bool r837076 = r837035 <= r837075;
double r837077 = cbrt(r837067);
double r837078 = r837077 * r837077;
double r837079 = r837078 * r837077;
double r837080 = r837079 - r837054;
double r837081 = r837080 + r837060;
double r837082 = r837067 - r837054;
double r837083 = r837056 * r837049;
double r837084 = r837035 * r837083;
double r837085 = -r837058;
double r837086 = r837056 * r837085;
double r837087 = r837084 + r837086;
double r837088 = r837082 + r837087;
double r837089 = r837076 ? r837081 : r837088;
double r837090 = r837063 ? r837074 : r837089;
double r837091 = r837037 ? r837061 : r837090;
return r837091;
}




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.1 |
|---|---|
| Target | 20.0 |
| Herbie | 11.3 |
if a < -7.34696385450286e-162Initial program 13.0
rmApplied sub-neg13.0
Applied distribute-lft-in13.0
Simplified13.0
Simplified12.5
if -7.34696385450286e-162 < a < 2.9280986771833522e-207Initial program 10.3
rmApplied sub-neg10.3
Applied distribute-lft-in10.3
Simplified10.9
Simplified10.9
if 2.9280986771833522e-207 < a < 2.0095715193243157e-45Initial program 8.9
rmApplied add-cube-cbrt9.2
if 2.0095715193243157e-45 < a Initial program 15.2
rmApplied sub-neg15.2
Applied distribute-lft-in15.2
Simplified11.4
Final simplification11.3
herbie shell --seed 2020045
(FPCore (x y z t a b c i j)
:name "Data.Colour.Matrix:determinant from colour-2.3.3, A"
:precision binary64
:herbie-target
(if (< x -1.469694296777705e-64) (+ (- (* x (- (* y z) (* t a))) (/ (* b (- (pow (* c z) 2) (pow (* t i) 2))) (+ (* c z) (* t i)))) (* j (- (* c a) (* y i)))) (if (< x 3.2113527362226803e-147) (- (* (- (* b i) (* x a)) t) (- (* z (* c b)) (* j (- (* c a) (* y i))))) (+ (- (* x (- (* y z) (* t a))) (/ (* b (- (pow (* c z) 2) (pow (* t i) 2))) (+ (* c z) (* t i)))) (* j (- (* c a) (* y i))))))
(+ (- (* x (- (* y z) (* t a))) (* b (- (* c z) (* t i)))) (* j (- (* c a) (* y i)))))