792 const double *pa,
const double *pb,
const double *pc,
const double *pd,
double permanent)
794 INEXACT double adx, bdx, cdx, ady, bdy, cdy, adz, bdz, cdz;
795 double det, errbound;
797 INEXACT double bdxcdy1, cdxbdy1, cdxady1, adxcdy1, adxbdy1, bdxady1;
798 double bdxcdy0, cdxbdy0, cdxady0, adxcdy0, adxbdy0, bdxady0;
799 double bc[4], ca[4], ab[4];
801 double adet[8], bdet[8], cdet[8];
802 int alen, blen, clen;
805 double *finnow, *finother, *finswap;
806 double fin1[192], fin2[192];
809 double adxtail, bdxtail, cdxtail;
810 double adytail, bdytail, cdytail;
811 double adztail, bdztail, cdztail;
812 INEXACT double at_blarge, at_clarge;
813 INEXACT double bt_clarge, bt_alarge;
814 INEXACT double ct_alarge, ct_blarge;
815 double at_b[4], at_c[4], bt_c[4], bt_a[4], ct_a[4], ct_b[4];
816 int at_blen, at_clen, bt_clen, bt_alen, ct_alen, ct_blen;
817 INEXACT double bdxt_cdy1, cdxt_bdy1, cdxt_ady1;
818 INEXACT double adxt_cdy1, adxt_bdy1, bdxt_ady1;
819 double bdxt_cdy0, cdxt_bdy0, cdxt_ady0;
820 double adxt_cdy0, adxt_bdy0, bdxt_ady0;
821 INEXACT double bdyt_cdx1, cdyt_bdx1, cdyt_adx1;
822 INEXACT double adyt_cdx1, adyt_bdx1, bdyt_adx1;
823 double bdyt_cdx0, cdyt_bdx0, cdyt_adx0;
824 double adyt_cdx0, adyt_bdx0, bdyt_adx0;
825 double bct[8], cat[8], abt[8];
826 int bctlen, catlen, abtlen;
827 INEXACT double bdxt_cdyt1, cdxt_bdyt1, cdxt_adyt1;
828 INEXACT double adxt_cdyt1, adxt_bdyt1, bdxt_adyt1;
829 double bdxt_cdyt0, cdxt_bdyt0, cdxt_adyt0;
830 double adxt_cdyt0, adxt_bdyt0, bdxt_adyt0;
831 double u[4],
v[12],
w[16];
833 int vlength, wlength;
837 double avirt, bround, around;
840 double ahi, alo, bhi, blo;
841 double err1, err2, err3;
845 adx =
double(pa[0] - pd[0]);
846 bdx =
double(pb[0] - pd[0]);
847 cdx =
double(pc[0] - pd[0]);
848 ady =
double(pa[1] - pd[1]);
849 bdy =
double(pb[1] - pd[1]);
850 cdy =
double(pc[1] - pd[1]);
851 adz =
double(pa[2] - pd[2]);
852 bdz =
double(pb[2] - pd[2]);
853 cdz =
double(pc[2] - pd[2]);
857 Two_Two_Diff(bdxcdy1, bdxcdy0, cdxbdy1, cdxbdy0, bc3, bc[2], bc[1], bc[0]);
863 Two_Two_Diff(cdxady1, cdxady0, adxcdy1, adxcdy0, ca3, ca[2], ca[1], ca[0]);
869 Two_Two_Diff(adxbdy1, adxbdy0, bdxady1, bdxady0, ab3, ab[2], ab[1], ab[0]);
878 if ((det >= errbound) || (-det >= errbound)) {
892 if ((adxtail == 0.0) && (bdxtail == 0.0) && (cdxtail == 0.0) && (adytail == 0.0) &&
893 (bdytail == 0.0) && (cdytail == 0.0) && (adztail == 0.0) && (bdztail == 0.0) &&
900 det += (adz * ((bdx * cdytail + cdy * bdxtail) - (bdy * cdxtail + cdx * bdytail)) +
901 adztail * (bdx * cdy - bdy * cdx)) +
902 (bdz * ((cdx * adytail + ady * cdxtail) - (cdy * adxtail + adx * cdytail)) +
903 bdztail * (cdx * ady - cdy * adx)) +
904 (cdz * ((adx * bdytail + bdy * adxtail) - (ady * bdxtail + bdx * adytail)) +
905 cdztail * (adx * bdy - ady * bdx));
906 if ((det >= errbound) || (-det >= errbound)) {
913 if (adxtail == 0.0) {
914 if (adytail == 0.0) {
931 if (adytail == 0.0) {
944 adxt_bdy1, adxt_bdy0, adyt_bdx1, adyt_bdx0, at_blarge, at_b[2], at_b[1], at_b[0]);
950 adyt_cdx1, adyt_cdx0, adxt_cdy1, adxt_cdy0, at_clarge, at_c[2], at_c[1], at_c[0]);
955 if (bdxtail == 0.0) {
956 if (bdytail == 0.0) {
973 if (bdytail == 0.0) {
986 bdxt_cdy1, bdxt_cdy0, bdyt_cdx1, bdyt_cdx0, bt_clarge, bt_c[2], bt_c[1], bt_c[0]);
992 bdyt_adx1, bdyt_adx0, bdxt_ady1, bdxt_ady0, bt_alarge, bt_a[2], bt_a[1], bt_a[0]);
997 if (cdxtail == 0.0) {
998 if (cdytail == 0.0) {
1007 ct_a[1] = ct_alarge;
1010 ct_b[1] = ct_blarge;
1015 if (cdytail == 0.0) {
1017 ct_a[1] = ct_alarge;
1021 ct_b[1] = ct_blarge;
1028 cdxt_ady1, cdxt_ady0, cdyt_adx1, cdyt_adx0, ct_alarge, ct_a[2], ct_a[1], ct_a[0]);
1029 ct_a[3] = ct_alarge;
1034 cdyt_bdx1, cdyt_bdx0, cdxt_bdy1, cdxt_bdy0, ct_blarge, ct_b[2], ct_b[1], ct_b[0]);
1035 ct_b[3] = ct_blarge;
1061 if (adztail != 0.0) {
1068 if (bdztail != 0.0) {
1075 if (cdztail != 0.0) {
1083 if (adxtail != 0.0) {
1084 if (bdytail != 0.0) {
1085 Two_Product(adxtail, bdytail, adxt_bdyt1, adxt_bdyt0);
1092 if (cdztail != 0.0) {
1093 Two_One_Product(adxt_bdyt1, adxt_bdyt0, cdztail, u3, u[2], u[1], u[0]);
1101 if (cdytail != 0.0) {
1103 Two_Product(negate, cdytail, adxt_cdyt1, adxt_cdyt0);
1110 if (bdztail != 0.0) {
1111 Two_One_Product(adxt_cdyt1, adxt_cdyt0, bdztail, u3, u[2], u[1], u[0]);
1120 if (bdxtail != 0.0) {
1121 if (cdytail != 0.0) {
1122 Two_Product(bdxtail, cdytail, bdxt_cdyt1, bdxt_cdyt0);
1129 if (adztail != 0.0) {
1130 Two_One_Product(bdxt_cdyt1, bdxt_cdyt0, adztail, u3, u[2], u[1], u[0]);
1138 if (adytail != 0.0) {
1140 Two_Product(negate, adytail, bdxt_adyt1, bdxt_adyt0);
1147 if (cdztail != 0.0) {
1148 Two_One_Product(bdxt_adyt1, bdxt_adyt0, cdztail, u3, u[2], u[1], u[0]);
1157 if (cdxtail != 0.0) {
1158 if (adytail != 0.0) {
1159 Two_Product(cdxtail, adytail, cdxt_adyt1, cdxt_adyt0);
1166 if (bdztail != 0.0) {
1167 Two_One_Product(cdxt_adyt1, cdxt_adyt0, bdztail, u3, u[2], u[1], u[0]);
1175 if (bdytail != 0.0) {
1177 Two_Product(negate, bdytail, cdxt_bdyt1, cdxt_bdyt0);
1184 if (adztail != 0.0) {
1185 Two_One_Product(cdxt_bdyt1, cdxt_bdyt0, adztail, u3, u[2], u[1], u[0]);
1195 if (adztail != 0.0) {
1202 if (bdztail != 0.0) {
1209 if (cdztail != 0.0) {
1217 return finnow[finlength - 1];
1307 const double *pa,
const double *pb,
const double *pc,
const double *pd,
double permanent)
1309 INEXACT double adx, bdx, cdx, ady, bdy, cdy;
1310 double det, errbound;
1312 INEXACT double bdxcdy1, cdxbdy1, cdxady1, adxcdy1, adxbdy1, bdxady1;
1313 double bdxcdy0, cdxbdy0, cdxady0, adxcdy0, adxbdy0, bdxady0;
1314 double bc[4], ca[4], ab[4];
1316 double axbc[8], axxbc[16], aybc[8], ayybc[16], adet[32];
1317 int axbclen, axxbclen, aybclen, ayybclen, alen;
1318 double bxca[8], bxxca[16], byca[8], byyca[16], bdet[32];
1319 int bxcalen, bxxcalen, bycalen, byycalen, blen;
1320 double cxab[8], cxxab[16], cyab[8], cyyab[16], cdet[32];
1321 int cxablen, cxxablen, cyablen, cyyablen, clen;
1324 double fin1[1152], fin2[1152];
1325 double *finnow, *finother, *finswap;
1328 double adxtail, bdxtail, cdxtail, adytail, bdytail, cdytail;
1329 INEXACT double adxadx1, adyady1, bdxbdx1, bdybdy1, cdxcdx1, cdycdy1;
1330 double adxadx0, adyady0, bdxbdx0, bdybdy0, cdxcdx0, cdycdy0;
1331 double aa[4], bb[4], cc[4];
1337 double temp8[8], temp16a[16], temp16b[16], temp16c[16];
1338 double temp32a[32], temp32b[32], temp48[48], temp64[64];
1339 int temp8len, temp16alen, temp16blen, temp16clen;
1340 int temp32alen, temp32blen, temp48len, temp64len;
1341 double axtbb[8], axtcc[8], aytbb[8], aytcc[8];
1342 int axtbblen, axtcclen, aytbblen, aytcclen;
1343 double bxtaa[8], bxtcc[8], bytaa[8], bytcc[8];
1344 int bxtaalen, bxtcclen, bytaalen, bytcclen;
1345 double cxtaa[8], cxtbb[8], cytaa[8], cytbb[8];
1346 int cxtaalen, cxtbblen, cytaalen, cytbblen;
1347 double axtbc[8], aytbc[8], bxtca[8], bytca[8], cxtab[8], cytab[8];
1348 int axtbclen, aytbclen, bxtcalen, bytcalen, cxtablen, cytablen;
1349 double axtbct[16], aytbct[16], bxtcat[16], bytcat[16], cxtabt[16], cytabt[16];
1350 int axtbctlen, aytbctlen, bxtcatlen, bytcatlen, cxtabtlen, cytabtlen;
1351 double axtbctt[8], aytbctt[8], bxtcatt[8];
1352 double bytcatt[8], cxtabtt[8], cytabtt[8];
1353 int axtbcttlen, aytbcttlen, bxtcattlen, bytcattlen, cxtabttlen, cytabttlen;
1354 double abt[8], bct[8], cat[8];
1355 int abtlen, bctlen, catlen;
1356 double abtt[4], bctt[4], catt[4];
1357 int abttlen, bcttlen, cattlen;
1358 INEXACT double abtt3, bctt3, catt3;
1362 double avirt, bround, around;
1365 double ahi, alo, bhi, blo;
1366 double err1, err2, err3;
1370 adx =
double(pa[0] - pd[0]);
1371 bdx =
double(pb[0] - pd[0]);
1372 cdx =
double(pc[0] - pd[0]);
1373 ady =
double(pa[1] - pd[1]);
1374 bdy =
double(pb[1] - pd[1]);
1375 cdy =
double(pc[1] - pd[1]);
1379 Two_Two_Diff(bdxcdy1, bdxcdy0, cdxbdy1, cdxbdy0, bc3, bc[2], bc[1], bc[0]);
1389 Two_Two_Diff(cdxady1, cdxady0, adxcdy1, adxcdy0, ca3, ca[2], ca[1], ca[0]);
1399 Two_Two_Diff(adxbdy1, adxbdy0, bdxady1, bdxady0, ab3, ab[2], ab[1], ab[0]);
1412 if ((det >= errbound) || (-det >= errbound)) {
1422 if ((adxtail == 0.0) && (bdxtail == 0.0) && (cdxtail == 0.0) && (adytail == 0.0) &&
1423 (bdytail == 0.0) && (cdytail == 0.0))
1429 det += ((adx * adx + ady * ady) *
1430 ((bdx * cdytail + cdy * bdxtail) - (bdy * cdxtail + cdx * bdytail)) +
1431 2.0 * (adx * adxtail + ady * adytail) * (bdx * cdy - bdy * cdx)) +
1432 ((bdx * bdx + bdy * bdy) *
1433 ((cdx * adytail + ady * cdxtail) - (cdy * adxtail + adx * cdytail)) +
1434 2.0 * (bdx * bdxtail + bdy * bdytail) * (cdx * ady - cdy * adx)) +
1435 ((cdx * cdx + cdy * cdy) *
1436 ((adx * bdytail + bdy * adxtail) - (ady * bdxtail + bdx * adytail)) +
1437 2.0 * (cdx * cdxtail + cdy * cdytail) * (adx * bdy - ady * bdx));
1438 if ((det >= errbound) || (-det >= errbound)) {
1445 if ((bdxtail != 0.0) || (bdytail != 0.0) || (cdxtail != 0.0) || (cdytail != 0.0)) {
1446 Square(adx, adxadx1, adxadx0);
1447 Square(ady, adyady1, adyady0);
1448 Two_Two_Sum(adxadx1, adxadx0, adyady1, adyady0, aa3, aa[2], aa[1], aa[0]);
1451 if ((cdxtail != 0.0) || (cdytail != 0.0) || (adxtail != 0.0) || (adytail != 0.0)) {
1452 Square(bdx, bdxbdx1, bdxbdx0);
1453 Square(bdy, bdybdy1, bdybdy0);
1454 Two_Two_Sum(bdxbdx1, bdxbdx0, bdybdy1, bdybdy0, bb3, bb[2], bb[1], bb[0]);
1457 if ((adxtail != 0.0) || (adytail != 0.0) || (bdxtail != 0.0) || (bdytail != 0.0)) {
1458 Square(cdx, cdxcdx1, cdxcdx0);
1459 Square(cdy, cdycdy1, cdycdy0);
1460 Two_Two_Sum(cdxcdx1, cdxcdx0, cdycdy1, cdycdy0, cc3, cc[2], cc[1], cc[0]);
1464 if (adxtail != 0.0) {
1481 if (adytail != 0.0) {
1498 if (bdxtail != 0.0) {
1515 if (bdytail != 0.0) {
1532 if (cdxtail != 0.0) {
1549 if (cdytail != 0.0) {
1567 if ((adxtail != 0.0) || (adytail != 0.0)) {
1568 if ((bdxtail != 0.0) || (bdytail != 0.0) || (cdxtail != 0.0) || (cdytail != 0.0)) {
1571 Two_Two_Sum(ti1, ti0, tj1, tj0, u3, u[2], u[1], u[0]);
1583 Two_Two_Diff(ti1, ti0, tj1, tj0, bctt3, bctt[2], bctt[1], bctt[0]);
1594 if (adxtail != 0.0) {
1603 if (bdytail != 0.0) {
1611 if (cdytail != 0.0) {
1631 if (adytail != 0.0) {
1653 if ((bdxtail != 0.0) || (bdytail != 0.0)) {
1654 if ((cdxtail != 0.0) || (cdytail != 0.0) || (adxtail != 0.0) || (adytail != 0.0)) {
1657 Two_Two_Sum(ti1, ti0, tj1, tj0, u3, u[2], u[1], u[0]);
1669 Two_Two_Diff(ti1, ti0, tj1, tj0, catt3, catt[2], catt[1], catt[0]);
1680 if (bdxtail != 0.0) {
1689 if (cdytail != 0.0) {
1697 if (adytail != 0.0) {
1717 if (bdytail != 0.0) {
1739 if ((cdxtail != 0.0) || (cdytail != 0.0)) {
1740 if ((adxtail != 0.0) || (adytail != 0.0) || (bdxtail != 0.0) || (bdytail != 0.0)) {
1743 Two_Two_Sum(ti1, ti0, tj1, tj0, u3, u[2], u[1], u[0]);
1755 Two_Two_Diff(ti1, ti0, tj1, tj0, abtt3, abtt[2], abtt[1], abtt[0]);
1766 if (cdxtail != 0.0) {
1775 if (adytail != 0.0) {
1783 if (bdytail != 0.0) {
1803 if (cdytail != 0.0) {
1826 return finnow[finlength - 1];
1934 const double *pa,
const double *pb,
const double *pc,
const double *pd,
const double *pe)
1936 INEXACT double axby1, bxcy1, cxdy1, dxey1, exay1;
1937 INEXACT double bxay1, cxby1, dxcy1, exdy1, axey1;
1938 INEXACT double axcy1, bxdy1, cxey1, dxay1, exby1;
1939 INEXACT double cxay1, dxby1, excy1, axdy1, bxey1;
1940 double axby0, bxcy0, cxdy0, dxey0, exay0;
1941 double bxay0, cxby0, dxcy0, exdy0, axey0;
1942 double axcy0, bxdy0, cxey0, dxay0, exby0;
1943 double cxay0, dxby0, excy0, axdy0, bxey0;
1944 double ab[4], bc[4], cd[4], de[4], ea[4];
1945 double ac[4], bd[4], ce[4], da[4], eb[4];
1946 double temp8a[8], temp8b[8], temp16[16];
1947 int temp8alen, temp8blen, temp16len;
1948 double abc[24], bcd[24], cde[24], dea[24], eab[24];
1949 double abd[24], bce[24], cda[24], deb[24], eac[24];
1950 int abclen, bcdlen, cdelen, dealen, eablen;
1951 int abdlen, bcelen, cdalen, deblen, eaclen;
1952 double temp48a[48], temp48b[48];
1953 int temp48alen, temp48blen;
1954 double abcd[96], bcde[96], cdea[96], deab[96], eabc[96];
1955 int abcdlen, bcdelen, cdealen, deablen, eabclen;
1956 double temp192[192];
1957 double det384x[384], det384y[384], det384z[384];
1958 int xlen, ylen, zlen;
1961 double adet[1152], bdet[1152], cdet[1152], ddet[1152], edet[1152];
1962 int alen, blen, clen, dlen, elen;
1963 double abdet[2304], cddet[2304], cdedet[3456];
1970 double avirt, bround, around;
1973 double ahi, alo, bhi, blo;
1974 double err1, err2, err3;
1980 Two_Two_Diff(axby1, axby0, bxay1, bxay0, ab[3], ab[2], ab[1], ab[0]);
1984 Two_Two_Diff(bxcy1, bxcy0, cxby1, cxby0, bc[3], bc[2], bc[1], bc[0]);
1988 Two_Two_Diff(cxdy1, cxdy0, dxcy1, dxcy0, cd[3], cd[2], cd[1], cd[0]);
1992 Two_Two_Diff(dxey1, dxey0, exdy1, exdy0, de[3], de[2], de[1], de[0]);
1996 Two_Two_Diff(exay1, exay0, axey1, axey0, ea[3], ea[2], ea[1], ea[0]);
2000 Two_Two_Diff(axcy1, axcy0, cxay1, cxay0, ac[3], ac[2], ac[1], ac[0]);
2004 Two_Two_Diff(bxdy1, bxdy0, dxby1, dxby0, bd[3], bd[2], bd[1], bd[0]);
2008 Two_Two_Diff(cxey1, cxey0, excy1, excy0, ce[3], ce[2], ce[1], ce[0]);
2012 Two_Two_Diff(dxay1, dxay0, axdy1, axdy0, da[3], da[2], da[1], da[0]);
2016 Two_Two_Diff(exby1, exby0, bxey1, bxey0, eb[3], eb[2], eb[1], eb[0]);
2080 for (i = 0; i < temp48blen; i++) {
2081 temp48b[i] = -temp48b[i];
2095 for (i = 0; i < temp48blen; i++) {
2096 temp48b[i] = -temp48b[i];
2110 for (i = 0; i < temp48blen; i++) {
2111 temp48b[i] = -temp48b[i];
2125 for (i = 0; i < temp48blen; i++) {
2126 temp48b[i] = -temp48b[i];
2140 for (i = 0; i < temp48blen; i++) {
2141 temp48b[i] = -temp48b[i];
2158 return deter[deterlen - 1];
2168 INEXACT double aex, bex, cex, dex, aey, bey, cey, dey, aez, bez, cez, dez;
2169 double det, errbound;
2171 INEXACT double aexbey1, bexaey1, bexcey1, cexbey1;
2172 INEXACT double cexdey1, dexcey1, dexaey1, aexdey1;
2173 INEXACT double aexcey1, cexaey1, bexdey1, dexbey1;
2174 double aexbey0, bexaey0, bexcey0, cexbey0;
2175 double cexdey0, dexcey0, dexaey0, aexdey0;
2176 double aexcey0, cexaey0, bexdey0, dexbey0;
2177 double ab[4], bc[4], cd[4], da[4], ac[4], bd[4];
2178 INEXACT double ab3, bc3, cd3, da3, ac3, bd3;
2179 double abeps, bceps, cdeps, daeps, aceps, bdeps;
2180 double temp8a[8], temp8b[8], temp8c[8], temp16[16], temp24[24], temp48[48];
2181 int temp8alen, temp8blen, temp8clen, temp16len, temp24len, temp48len;
2182 double xdet[96], ydet[96], zdet[96], xydet[192];
2183 int xlen, ylen, zlen, xylen;
2184 double adet[288], bdet[288], cdet[288], ddet[288];
2185 int alen, blen, clen, dlen;
2186 double abdet[576], cddet[576];
2191 double aextail, bextail, cextail, dextail;
2192 double aeytail, beytail, ceytail, deytail;
2193 double aeztail, beztail, ceztail, deztail;
2196 double avirt, bround, around;
2199 double ahi, alo, bhi, blo;
2200 double err1, err2, err3;
2204 aex =
double(pa[0] - pe[0]);
2205 bex =
double(pb[0] - pe[0]);
2206 cex =
double(pc[0] - pe[0]);
2207 dex =
double(pd[0] - pe[0]);
2208 aey =
double(pa[1] - pe[1]);
2209 bey =
double(pb[1] - pe[1]);
2210 cey =
double(pc[1] - pe[1]);
2211 dey =
double(pd[1] - pe[1]);
2212 aez =
double(pa[2] - pe[2]);
2213 bez =
double(pb[2] - pe[2]);
2214 cez =
double(pc[2] - pe[2]);
2215 dez =
double(pd[2] - pe[2]);
2219 Two_Two_Diff(aexbey1, aexbey0, bexaey1, bexaey0, ab3, ab[2], ab[1], ab[0]);
2224 Two_Two_Diff(bexcey1, bexcey0, cexbey1, cexbey0, bc3, bc[2], bc[1], bc[0]);
2229 Two_Two_Diff(cexdey1, cexdey0, dexcey1, dexcey0, cd3, cd[2], cd[1], cd[0]);
2234 Two_Two_Diff(dexaey1, dexaey0, aexdey1, aexdey0, da3, da[2], da[1], da[0]);
2239 Two_Two_Diff(aexcey1, aexcey0, cexaey1, cexaey0, ac3, ac[2], ac[1], ac[0]);
2244 Two_Two_Diff(bexdey1, bexdey0, dexbey1, dexbey0, bd3, bd[2], bd[1], bd[0]);
2309 if ((det >= errbound) || (-det >= errbound)) {
2325 if ((aextail == 0.0) && (aeytail == 0.0) && (aeztail == 0.0) && (bextail == 0.0) &&
2326 (beytail == 0.0) && (beztail == 0.0) && (cextail == 0.0) && (ceytail == 0.0) &&
2327 (ceztail == 0.0) && (dextail == 0.0) && (deytail == 0.0) && (deztail == 0.0))
2333 abeps = (aex * beytail + bey * aextail) - (aey * bextail + bex * aeytail);
2334 bceps = (bex * ceytail + cey * bextail) - (bey * cextail + cex * beytail);
2335 cdeps = (cex * deytail + dey * cextail) - (cey * dextail + dex * ceytail);
2336 daeps = (dex * aeytail + aey * dextail) - (dey * aextail + aex * deytail);
2337 aceps = (aex * ceytail + cey * aextail) - (aey * cextail + cex * aeytail);
2338 bdeps = (bex * deytail + dey * bextail) - (bey * dextail + dex * beytail);
2340 (((bex * bex + bey * bey + bez * bez) * ((cez * daeps + dez * aceps + aez * cdeps) +
2341 (ceztail * da3 + deztail * ac3 + aeztail * cd3)) +
2342 (dex * dex + dey * dey + dez * dez) * ((aez * bceps - bez * aceps + cez * abeps) +
2343 (aeztail * bc3 - beztail * ac3 + ceztail * ab3))) -
2344 ((aex * aex + aey * aey + aez * aez) * ((bez * cdeps - cez * bdeps + dez * bceps) +
2345 (beztail * cd3 - ceztail * bd3 + deztail * bc3)) +
2346 (cex * cex + cey * cey + cez * cez) * ((dez * abeps + aez * bdeps + bez * daeps) +
2347 (deztail * ab3 + aeztail * bd3 + beztail * da3)))) +
2349 (((bex * bextail + bey * beytail + bez * beztail) * (cez * da3 + dez * ac3 + aez * cd3) +
2350 (dex * dextail + dey * deytail + dez * deztail) *
2351 (aez * bc3 - bez * ac3 + cez * ab3)) -
2352 ((aex * aextail + aey * aeytail + aez * aeztail) * (bez * cd3 - cez * bd3 + dez * bc3) +
2353 (cex * cextail + cey * ceytail + cez * ceztail) *
2354 (dez * ab3 + aez * bd3 + bez * da3)));
2355 if ((det >= errbound) || (-det >= errbound)) {