\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}\;j \le -8.098605839800467588832943275516974834805 \cdot 10^{-10} \lor \neg \left(j \le 1.934400928972068227614321657053659421626 \cdot 10^{59}\right):\\
\;\;\;\;\mathsf{fma}\left(x, \left(\sqrt[3]{y \cdot z - t \cdot a} \cdot \sqrt[3]{y \cdot z - t \cdot a}\right) \cdot \sqrt[3]{y \cdot z - t \cdot a}, \mathsf{fma}\left(b, t \cdot i - c \cdot z, j \cdot \left(c \cdot a - y \cdot i\right)\right)\right)\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(x, y \cdot z - t \cdot a, \mathsf{fma}\left(b, t \cdot i - c \cdot z, a \cdot \left(j \cdot c\right) + \left(-i \cdot \left(y \cdot j\right)\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 r702023 = x;
double r702024 = y;
double r702025 = z;
double r702026 = r702024 * r702025;
double r702027 = t;
double r702028 = a;
double r702029 = r702027 * r702028;
double r702030 = r702026 - r702029;
double r702031 = r702023 * r702030;
double r702032 = b;
double r702033 = c;
double r702034 = r702033 * r702025;
double r702035 = i;
double r702036 = r702027 * r702035;
double r702037 = r702034 - r702036;
double r702038 = r702032 * r702037;
double r702039 = r702031 - r702038;
double r702040 = j;
double r702041 = r702033 * r702028;
double r702042 = r702024 * r702035;
double r702043 = r702041 - r702042;
double r702044 = r702040 * r702043;
double r702045 = r702039 + r702044;
return r702045;
}
double f(double x, double y, double z, double t, double a, double b, double c, double i, double j) {
double r702046 = j;
double r702047 = -8.098605839800468e-10;
bool r702048 = r702046 <= r702047;
double r702049 = 1.9344009289720682e+59;
bool r702050 = r702046 <= r702049;
double r702051 = !r702050;
bool r702052 = r702048 || r702051;
double r702053 = x;
double r702054 = y;
double r702055 = z;
double r702056 = r702054 * r702055;
double r702057 = t;
double r702058 = a;
double r702059 = r702057 * r702058;
double r702060 = r702056 - r702059;
double r702061 = cbrt(r702060);
double r702062 = r702061 * r702061;
double r702063 = r702062 * r702061;
double r702064 = b;
double r702065 = i;
double r702066 = r702057 * r702065;
double r702067 = c;
double r702068 = r702067 * r702055;
double r702069 = r702066 - r702068;
double r702070 = r702067 * r702058;
double r702071 = r702054 * r702065;
double r702072 = r702070 - r702071;
double r702073 = r702046 * r702072;
double r702074 = fma(r702064, r702069, r702073);
double r702075 = fma(r702053, r702063, r702074);
double r702076 = r702046 * r702067;
double r702077 = r702058 * r702076;
double r702078 = r702054 * r702046;
double r702079 = r702065 * r702078;
double r702080 = -r702079;
double r702081 = r702077 + r702080;
double r702082 = fma(r702064, r702069, r702081);
double r702083 = fma(r702053, r702060, r702082);
double r702084 = r702052 ? r702075 : r702083;
return r702084;
}




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
| Original | 12.5 |
|---|---|
| Target | 20.4 |
| Herbie | 9.4 |
if j < -8.098605839800468e-10 or 1.9344009289720682e+59 < j Initial program 8.0
Simplified8.0
rmApplied add-cube-cbrt8.2
if -8.098605839800468e-10 < j < 1.9344009289720682e+59Initial program 15.1
Simplified15.1
rmApplied add-cube-cbrt15.3
Applied associate-*l*15.3
rmApplied sub-neg15.3
Applied distribute-lft-in15.3
Applied distribute-lft-in15.3
Simplified13.0
Simplified10.0
Final simplification9.4
herbie shell --seed 2019323 +o rules:numerics
(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)))))