\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}\;x \le -2.2224158461403074 \cdot 10^{-121}:\\
\;\;\;\;\left(c \cdot a - y \cdot i\right) \cdot j + \left(\left(\left(y \cdot z\right) \cdot x + \left(t \cdot x\right) \cdot \left(-a\right)\right) - \left(b \cdot \left(c \cdot z\right) + \left(-b \cdot \left(i \cdot t\right)\right)\right)\right)\\
\mathbf{elif}\;x \le 1.9015513961511429 \cdot 10^{-34}:\\
\;\;\;\;\left(c \cdot a - y \cdot i\right) \cdot j + \left(\left(\left(y \cdot x\right) \cdot z + \left(t \cdot x\right) \cdot \left(-a\right)\right) - \left(b \cdot \left(c \cdot z\right) + \left(i \cdot \left(-b\right)\right) \cdot t\right)\right)\\
\mathbf{else}:\\
\;\;\;\;\left(\left(\left(\sqrt{x} \cdot \left(\left(-a\right) \cdot t\right)\right) \cdot \sqrt{x} + \left(y \cdot z\right) \cdot x\right) - \left(c \cdot z - i \cdot t\right) \cdot b\right) + \left(c \cdot a - y \cdot i\right) \cdot j\\
\end{array}double f(double x, double y, double z, double t, double a, double b, double c, double i, double j) {
double r16113961 = x;
double r16113962 = y;
double r16113963 = z;
double r16113964 = r16113962 * r16113963;
double r16113965 = t;
double r16113966 = a;
double r16113967 = r16113965 * r16113966;
double r16113968 = r16113964 - r16113967;
double r16113969 = r16113961 * r16113968;
double r16113970 = b;
double r16113971 = c;
double r16113972 = r16113971 * r16113963;
double r16113973 = i;
double r16113974 = r16113965 * r16113973;
double r16113975 = r16113972 - r16113974;
double r16113976 = r16113970 * r16113975;
double r16113977 = r16113969 - r16113976;
double r16113978 = j;
double r16113979 = r16113971 * r16113966;
double r16113980 = r16113962 * r16113973;
double r16113981 = r16113979 - r16113980;
double r16113982 = r16113978 * r16113981;
double r16113983 = r16113977 + r16113982;
return r16113983;
}
double f(double x, double y, double z, double t, double a, double b, double c, double i, double j) {
double r16113984 = x;
double r16113985 = -2.2224158461403074e-121;
bool r16113986 = r16113984 <= r16113985;
double r16113987 = c;
double r16113988 = a;
double r16113989 = r16113987 * r16113988;
double r16113990 = y;
double r16113991 = i;
double r16113992 = r16113990 * r16113991;
double r16113993 = r16113989 - r16113992;
double r16113994 = j;
double r16113995 = r16113993 * r16113994;
double r16113996 = z;
double r16113997 = r16113990 * r16113996;
double r16113998 = r16113997 * r16113984;
double r16113999 = t;
double r16114000 = r16113999 * r16113984;
double r16114001 = -r16113988;
double r16114002 = r16114000 * r16114001;
double r16114003 = r16113998 + r16114002;
double r16114004 = b;
double r16114005 = r16113987 * r16113996;
double r16114006 = r16114004 * r16114005;
double r16114007 = r16113991 * r16113999;
double r16114008 = r16114004 * r16114007;
double r16114009 = -r16114008;
double r16114010 = r16114006 + r16114009;
double r16114011 = r16114003 - r16114010;
double r16114012 = r16113995 + r16114011;
double r16114013 = 1.9015513961511429e-34;
bool r16114014 = r16113984 <= r16114013;
double r16114015 = r16113990 * r16113984;
double r16114016 = r16114015 * r16113996;
double r16114017 = r16114016 + r16114002;
double r16114018 = -r16114004;
double r16114019 = r16113991 * r16114018;
double r16114020 = r16114019 * r16113999;
double r16114021 = r16114006 + r16114020;
double r16114022 = r16114017 - r16114021;
double r16114023 = r16113995 + r16114022;
double r16114024 = sqrt(r16113984);
double r16114025 = r16114001 * r16113999;
double r16114026 = r16114024 * r16114025;
double r16114027 = r16114026 * r16114024;
double r16114028 = r16114027 + r16113998;
double r16114029 = r16114005 - r16114007;
double r16114030 = r16114029 * r16114004;
double r16114031 = r16114028 - r16114030;
double r16114032 = r16114031 + r16113995;
double r16114033 = r16114014 ? r16114023 : r16114032;
double r16114034 = r16113986 ? r16114012 : r16114033;
return r16114034;
}




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 | 11.6 |
|---|---|
| Target | 18.6 |
| Herbie | 9.3 |
if x < -2.2224158461403074e-121Initial program 8.3
rmApplied sub-neg8.3
Applied distribute-lft-in8.3
rmApplied distribute-lft-neg-in8.3
Applied associate-*r*10.2
rmApplied sub-neg10.2
Applied distribute-lft-in10.2
Simplified11.0
rmApplied associate-*l*10.2
if -2.2224158461403074e-121 < x < 1.9015513961511429e-34Initial program 15.4
rmApplied sub-neg15.4
Applied distribute-lft-in15.4
rmApplied distribute-lft-neg-in15.4
Applied associate-*r*12.5
rmApplied sub-neg12.5
Applied distribute-lft-in12.5
Simplified12.2
rmApplied associate-*r*9.4
if 1.9015513961511429e-34 < x Initial program 7.9
rmApplied sub-neg7.9
Applied distribute-lft-in7.9
rmApplied add-sqr-sqrt7.9
Applied associate-*l*7.9
Final simplification9.3
herbie shell --seed 2019156
(FPCore (x y z t a b c i j)
:name "Data.Colour.Matrix:determinant from colour-2.3.3, A"
: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)))))