\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 -4.01645147109428022 \cdot 10^{-173} \lor \neg \left(x \le 1.58691066146071069 \cdot 10^{-234}\right):\\
\;\;\;\;\left(x \cdot \left(y \cdot z - t \cdot a\right) - b \cdot \left(c \cdot z - i \cdot a\right)\right) + \left(t \cdot \left(j \cdot c\right) + \left(-j\right) \cdot \left(i \cdot y\right)\right)\\
\mathbf{else}:\\
\;\;\;\;\left(0 - b \cdot \left(c \cdot z - i \cdot a\right)\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 r583941 = x;
double r583942 = y;
double r583943 = z;
double r583944 = r583942 * r583943;
double r583945 = t;
double r583946 = a;
double r583947 = r583945 * r583946;
double r583948 = r583944 - r583947;
double r583949 = r583941 * r583948;
double r583950 = b;
double r583951 = c;
double r583952 = r583951 * r583943;
double r583953 = i;
double r583954 = r583953 * r583946;
double r583955 = r583952 - r583954;
double r583956 = r583950 * r583955;
double r583957 = r583949 - r583956;
double r583958 = j;
double r583959 = r583951 * r583945;
double r583960 = r583953 * r583942;
double r583961 = r583959 - r583960;
double r583962 = r583958 * r583961;
double r583963 = r583957 + r583962;
return r583963;
}
double f(double x, double y, double z, double t, double a, double b, double c, double i, double j) {
double r583964 = x;
double r583965 = -4.01645147109428e-173;
bool r583966 = r583964 <= r583965;
double r583967 = 1.5869106614607107e-234;
bool r583968 = r583964 <= r583967;
double r583969 = !r583968;
bool r583970 = r583966 || r583969;
double r583971 = y;
double r583972 = z;
double r583973 = r583971 * r583972;
double r583974 = t;
double r583975 = a;
double r583976 = r583974 * r583975;
double r583977 = r583973 - r583976;
double r583978 = r583964 * r583977;
double r583979 = b;
double r583980 = c;
double r583981 = r583980 * r583972;
double r583982 = i;
double r583983 = r583982 * r583975;
double r583984 = r583981 - r583983;
double r583985 = r583979 * r583984;
double r583986 = r583978 - r583985;
double r583987 = j;
double r583988 = r583987 * r583980;
double r583989 = r583974 * r583988;
double r583990 = -r583987;
double r583991 = r583982 * r583971;
double r583992 = r583990 * r583991;
double r583993 = r583989 + r583992;
double r583994 = r583986 + r583993;
double r583995 = 0.0;
double r583996 = r583995 - r583985;
double r583997 = r583980 * r583974;
double r583998 = r583997 - r583991;
double r583999 = r583987 * r583998;
double r584000 = r583996 + r583999;
double r584001 = r583970 ? r583994 : r584000;
return r584001;
}




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.2 |
| Herbie | 12.5 |
if x < -4.01645147109428e-173 or 1.5869106614607107e-234 < x Initial program 11.0
rmApplied add-cube-cbrt11.3
Applied associate-*l*11.3
rmApplied sub-neg11.3
Applied distribute-lft-in11.3
Applied distribute-lft-in11.3
Simplified11.4
Simplified11.3
if -4.01645147109428e-173 < x < 1.5869106614607107e-234Initial program 17.8
Taylor expanded around 0 17.2
Final simplification12.5
herbie shell --seed 2020018
(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)))))