791 const double *pa,
const double *pb,
const double *pc,
const double *pd,
double permanent)
793 INEXACT double adx, bdx, cdx, ady, bdy, cdy, adz, bdz, cdz;
794 double det, errbound;
796 INEXACT double bdxcdy1, cdxbdy1, cdxady1, adxcdy1, adxbdy1, bdxady1;
797 double bdxcdy0, cdxbdy0, cdxady0, adxcdy0, adxbdy0, bdxady0;
798 double bc[4], ca[4], ab[4];
800 double adet[8], bdet[8], cdet[8];
801 int alen, blen, clen;
804 double *finnow, *finother, *finswap;
805 double fin1[192], fin2[192];
808 double adxtail, bdxtail, cdxtail;
809 double adytail, bdytail, cdytail;
810 double adztail, bdztail, cdztail;
811 INEXACT double at_blarge, at_clarge;
812 INEXACT double bt_clarge, bt_alarge;
813 INEXACT double ct_alarge, ct_blarge;
814 double at_b[4], at_c[4], bt_c[4], bt_a[4], ct_a[4], ct_b[4];
815 int at_blen, at_clen, bt_clen, bt_alen, ct_alen, ct_blen;
816 INEXACT double bdxt_cdy1, cdxt_bdy1, cdxt_ady1;
817 INEXACT double adxt_cdy1, adxt_bdy1, bdxt_ady1;
818 double bdxt_cdy0, cdxt_bdy0, cdxt_ady0;
819 double adxt_cdy0, adxt_bdy0, bdxt_ady0;
820 INEXACT double bdyt_cdx1, cdyt_bdx1, cdyt_adx1;
821 INEXACT double adyt_cdx1, adyt_bdx1, bdyt_adx1;
822 double bdyt_cdx0, cdyt_bdx0, cdyt_adx0;
823 double adyt_cdx0, adyt_bdx0, bdyt_adx0;
824 double bct[8], cat[8], abt[8];
825 int bctlen, catlen, abtlen;
826 INEXACT double bdxt_cdyt1, cdxt_bdyt1, cdxt_adyt1;
827 INEXACT double adxt_cdyt1, adxt_bdyt1, bdxt_adyt1;
828 double bdxt_cdyt0, cdxt_bdyt0, cdxt_adyt0;
829 double adxt_cdyt0, adxt_bdyt0, bdxt_adyt0;
830 double u[4],
v[12],
w[16];
832 int vlength, wlength;
836 double avirt, bround, around;
839 double ahi, alo, bhi, blo;
840 double err1, err2, err3;
844 adx = double(pa[0] - pd[0]);
845 bdx = double(pb[0] - pd[0]);
846 cdx = double(pc[0] - pd[0]);
847 ady = double(pa[1] - pd[1]);
848 bdy = double(pb[1] - pd[1]);
849 cdy = double(pc[1] - pd[1]);
850 adz = double(pa[2] - pd[2]);
851 bdz = double(pb[2] - pd[2]);
852 cdz = double(pc[2] - pd[2]);
856 Two_Two_Diff(bdxcdy1, bdxcdy0, cdxbdy1, cdxbdy0, bc3, bc[2], bc[1], bc[0]);
862 Two_Two_Diff(cdxady1, cdxady0, adxcdy1, adxcdy0, ca3, ca[2], ca[1], ca[0]);
868 Two_Two_Diff(adxbdy1, adxbdy0, bdxady1, bdxady0, ab3, ab[2], ab[1], ab[0]);
877 if ((det >= errbound) || (-det >= errbound)) {
891 if ((adxtail == 0.0) && (bdxtail == 0.0) && (cdxtail == 0.0) && (adytail == 0.0) &&
892 (bdytail == 0.0) && (cdytail == 0.0) && (adztail == 0.0) && (bdztail == 0.0) &&
899 det += (adz * ((bdx * cdytail + cdy * bdxtail) - (bdy * cdxtail + cdx * bdytail)) +
900 adztail * (bdx * cdy - bdy * cdx)) +
901 (bdz * ((cdx * adytail + ady * cdxtail) - (cdy * adxtail + adx * cdytail)) +
902 bdztail * (cdx * ady - cdy * adx)) +
903 (cdz * ((adx * bdytail + bdy * adxtail) - (ady * bdxtail + bdx * adytail)) +
904 cdztail * (adx * bdy - ady * bdx));
905 if ((det >= errbound) || (-det >= errbound)) {
912 if (adxtail == 0.0) {
913 if (adytail == 0.0) {
930 if (adytail == 0.0) {
943 adxt_bdy1, adxt_bdy0, adyt_bdx1, adyt_bdx0, at_blarge, at_b[2], at_b[1], at_b[0]);
949 adyt_cdx1, adyt_cdx0, adxt_cdy1, adxt_cdy0, at_clarge, at_c[2], at_c[1], at_c[0]);
954 if (bdxtail == 0.0) {
955 if (bdytail == 0.0) {
972 if (bdytail == 0.0) {
985 bdxt_cdy1, bdxt_cdy0, bdyt_cdx1, bdyt_cdx0, bt_clarge, bt_c[2], bt_c[1], bt_c[0]);
991 bdyt_adx1, bdyt_adx0, bdxt_ady1, bdxt_ady0, bt_alarge, bt_a[2], bt_a[1], bt_a[0]);
996 if (cdxtail == 0.0) {
997 if (cdytail == 0.0) {
1006 ct_a[1] = ct_alarge;
1009 ct_b[1] = ct_blarge;
1014 if (cdytail == 0.0) {
1016 ct_a[1] = ct_alarge;
1020 ct_b[1] = ct_blarge;
1027 cdxt_ady1, cdxt_ady0, cdyt_adx1, cdyt_adx0, ct_alarge, ct_a[2], ct_a[1], ct_a[0]);
1028 ct_a[3] = ct_alarge;
1033 cdyt_bdx1, cdyt_bdx0, cdxt_bdy1, cdxt_bdy0, ct_blarge, ct_b[2], ct_b[1], ct_b[0]);
1034 ct_b[3] = ct_blarge;
1060 if (adztail != 0.0) {
1067 if (bdztail != 0.0) {
1074 if (cdztail != 0.0) {
1082 if (adxtail != 0.0) {
1083 if (bdytail != 0.0) {
1084 Two_Product(adxtail, bdytail, adxt_bdyt1, adxt_bdyt0);
1091 if (cdztail != 0.0) {
1092 Two_One_Product(adxt_bdyt1, adxt_bdyt0, cdztail, u3, u[2], u[1], u[0]);
1100 if (cdytail != 0.0) {
1102 Two_Product(negate, cdytail, adxt_cdyt1, adxt_cdyt0);
1109 if (bdztail != 0.0) {
1110 Two_One_Product(adxt_cdyt1, adxt_cdyt0, bdztail, u3, u[2], u[1], u[0]);
1119 if (bdxtail != 0.0) {
1120 if (cdytail != 0.0) {
1121 Two_Product(bdxtail, cdytail, bdxt_cdyt1, bdxt_cdyt0);
1128 if (adztail != 0.0) {
1129 Two_One_Product(bdxt_cdyt1, bdxt_cdyt0, adztail, u3, u[2], u[1], u[0]);
1137 if (adytail != 0.0) {
1139 Two_Product(negate, adytail, bdxt_adyt1, bdxt_adyt0);
1146 if (cdztail != 0.0) {
1147 Two_One_Product(bdxt_adyt1, bdxt_adyt0, cdztail, u3, u[2], u[1], u[0]);
1156 if (cdxtail != 0.0) {
1157 if (adytail != 0.0) {
1158 Two_Product(cdxtail, adytail, cdxt_adyt1, cdxt_adyt0);
1165 if (bdztail != 0.0) {
1166 Two_One_Product(cdxt_adyt1, cdxt_adyt0, bdztail, u3, u[2], u[1], u[0]);
1174 if (bdytail != 0.0) {
1176 Two_Product(negate, bdytail, cdxt_bdyt1, cdxt_bdyt0);
1183 if (adztail != 0.0) {
1184 Two_One_Product(cdxt_bdyt1, cdxt_bdyt0, adztail, u3, u[2], u[1], u[0]);
1194 if (adztail != 0.0) {
1201 if (bdztail != 0.0) {
1208 if (cdztail != 0.0) {
1216 return finnow[finlength - 1];
1306 const double *pa,
const double *pb,
const double *pc,
const double *pd,
double permanent)
1308 INEXACT double adx, bdx, cdx, ady, bdy, cdy;
1309 double det, errbound;
1311 INEXACT double bdxcdy1, cdxbdy1, cdxady1, adxcdy1, adxbdy1, bdxady1;
1312 double bdxcdy0, cdxbdy0, cdxady0, adxcdy0, adxbdy0, bdxady0;
1313 double bc[4], ca[4], ab[4];
1315 double axbc[8], axxbc[16], aybc[8], ayybc[16], adet[32];
1316 int axbclen, axxbclen, aybclen, ayybclen, alen;
1317 double bxca[8], bxxca[16], byca[8], byyca[16], bdet[32];
1318 int bxcalen, bxxcalen, bycalen, byycalen, blen;
1319 double cxab[8], cxxab[16], cyab[8], cyyab[16], cdet[32];
1320 int cxablen, cxxablen, cyablen, cyyablen, clen;
1323 double fin1[1152], fin2[1152];
1324 double *finnow, *finother, *finswap;
1327 double adxtail, bdxtail, cdxtail, adytail, bdytail, cdytail;
1328 INEXACT double adxadx1, adyady1, bdxbdx1, bdybdy1, cdxcdx1, cdycdy1;
1329 double adxadx0, adyady0, bdxbdx0, bdybdy0, cdxcdx0, cdycdy0;
1330 double aa[4], bb[4], cc[4];
1336 double temp8[8], temp16a[16], temp16b[16], temp16c[16];
1337 double temp32a[32], temp32b[32], temp48[48], temp64[64];
1338 int temp8len, temp16alen, temp16blen, temp16clen;
1339 int temp32alen, temp32blen, temp48len, temp64len;
1340 double axtbb[8], axtcc[8], aytbb[8], aytcc[8];
1341 int axtbblen, axtcclen, aytbblen, aytcclen;
1342 double bxtaa[8], bxtcc[8], bytaa[8], bytcc[8];
1343 int bxtaalen, bxtcclen, bytaalen, bytcclen;
1344 double cxtaa[8], cxtbb[8], cytaa[8], cytbb[8];
1345 int cxtaalen, cxtbblen, cytaalen, cytbblen;
1346 double axtbc[8], aytbc[8], bxtca[8], bytca[8], cxtab[8], cytab[8];
1347 int axtbclen, aytbclen, bxtcalen, bytcalen, cxtablen, cytablen;
1348 double axtbct[16], aytbct[16], bxtcat[16], bytcat[16], cxtabt[16], cytabt[16];
1349 int axtbctlen, aytbctlen, bxtcatlen, bytcatlen, cxtabtlen, cytabtlen;
1350 double axtbctt[8], aytbctt[8], bxtcatt[8];
1351 double bytcatt[8], cxtabtt[8], cytabtt[8];
1352 int axtbcttlen, aytbcttlen, bxtcattlen, bytcattlen, cxtabttlen, cytabttlen;
1353 double abt[8], bct[8], cat[8];
1354 int abtlen, bctlen, catlen;
1355 double abtt[4], bctt[4], catt[4];
1356 int abttlen, bcttlen, cattlen;
1357 INEXACT double abtt3, bctt3, catt3;
1361 double avirt, bround, around;
1364 double ahi, alo, bhi, blo;
1365 double err1, err2, err3;
1369 adx = double(pa[0] - pd[0]);
1370 bdx = double(pb[0] - pd[0]);
1371 cdx = double(pc[0] - pd[0]);
1372 ady = double(pa[1] - pd[1]);
1373 bdy = double(pb[1] - pd[1]);
1374 cdy = double(pc[1] - pd[1]);
1378 Two_Two_Diff(bdxcdy1, bdxcdy0, cdxbdy1, cdxbdy0, bc3, bc[2], bc[1], bc[0]);
1388 Two_Two_Diff(cdxady1, cdxady0, adxcdy1, adxcdy0, ca3, ca[2], ca[1], ca[0]);
1398 Two_Two_Diff(adxbdy1, adxbdy0, bdxady1, bdxady0, ab3, ab[2], ab[1], ab[0]);
1411 if ((det >= errbound) || (-det >= errbound)) {
1421 if ((adxtail == 0.0) && (bdxtail == 0.0) && (cdxtail == 0.0) && (adytail == 0.0) &&
1422 (bdytail == 0.0) && (cdytail == 0.0))
1428 det += ((adx * adx + ady * ady) *
1429 ((bdx * cdytail + cdy * bdxtail) - (bdy * cdxtail + cdx * bdytail)) +
1430 2.0 * (adx * adxtail + ady * adytail) * (bdx * cdy - bdy * cdx)) +
1431 ((bdx * bdx + bdy * bdy) *
1432 ((cdx * adytail + ady * cdxtail) - (cdy * adxtail + adx * cdytail)) +
1433 2.0 * (bdx * bdxtail + bdy * bdytail) * (cdx * ady - cdy * adx)) +
1434 ((cdx * cdx + cdy * cdy) *
1435 ((adx * bdytail + bdy * adxtail) - (ady * bdxtail + bdx * adytail)) +
1436 2.0 * (cdx * cdxtail + cdy * cdytail) * (adx * bdy - ady * bdx));
1437 if ((det >= errbound) || (-det >= errbound)) {
1444 if ((bdxtail != 0.0) || (bdytail != 0.0) || (cdxtail != 0.0) || (cdytail != 0.0)) {
1445 Square(adx, adxadx1, adxadx0);
1446 Square(ady, adyady1, adyady0);
1447 Two_Two_Sum(adxadx1, adxadx0, adyady1, adyady0, aa3, aa[2], aa[1], aa[0]);
1450 if ((cdxtail != 0.0) || (cdytail != 0.0) || (adxtail != 0.0) || (adytail != 0.0)) {
1451 Square(bdx, bdxbdx1, bdxbdx0);
1452 Square(bdy, bdybdy1, bdybdy0);
1453 Two_Two_Sum(bdxbdx1, bdxbdx0, bdybdy1, bdybdy0, bb3, bb[2], bb[1], bb[0]);
1456 if ((adxtail != 0.0) || (adytail != 0.0) || (bdxtail != 0.0) || (bdytail != 0.0)) {
1457 Square(cdx, cdxcdx1, cdxcdx0);
1458 Square(cdy, cdycdy1, cdycdy0);
1459 Two_Two_Sum(cdxcdx1, cdxcdx0, cdycdy1, cdycdy0, cc3, cc[2], cc[1], cc[0]);
1463 if (adxtail != 0.0) {
1480 if (adytail != 0.0) {
1497 if (bdxtail != 0.0) {
1514 if (bdytail != 0.0) {
1531 if (cdxtail != 0.0) {
1548 if (cdytail != 0.0) {
1566 if ((adxtail != 0.0) || (adytail != 0.0)) {
1567 if ((bdxtail != 0.0) || (bdytail != 0.0) || (cdxtail != 0.0) || (cdytail != 0.0)) {
1570 Two_Two_Sum(ti1, ti0, tj1, tj0, u3, u[2], u[1], u[0]);
1582 Two_Two_Diff(ti1, ti0, tj1, tj0, bctt3, bctt[2], bctt[1], bctt[0]);
1593 if (adxtail != 0.0) {
1602 if (bdytail != 0.0) {
1610 if (cdytail != 0.0) {
1630 if (adytail != 0.0) {
1652 if ((bdxtail != 0.0) || (bdytail != 0.0)) {
1653 if ((cdxtail != 0.0) || (cdytail != 0.0) || (adxtail != 0.0) || (adytail != 0.0)) {
1656 Two_Two_Sum(ti1, ti0, tj1, tj0, u3, u[2], u[1], u[0]);
1668 Two_Two_Diff(ti1, ti0, tj1, tj0, catt3, catt[2], catt[1], catt[0]);
1679 if (bdxtail != 0.0) {
1688 if (cdytail != 0.0) {
1696 if (adytail != 0.0) {
1716 if (bdytail != 0.0) {
1738 if ((cdxtail != 0.0) || (cdytail != 0.0)) {
1739 if ((adxtail != 0.0) || (adytail != 0.0) || (bdxtail != 0.0) || (bdytail != 0.0)) {
1742 Two_Two_Sum(ti1, ti0, tj1, tj0, u3, u[2], u[1], u[0]);
1754 Two_Two_Diff(ti1, ti0, tj1, tj0, abtt3, abtt[2], abtt[1], abtt[0]);
1765 if (cdxtail != 0.0) {
1774 if (adytail != 0.0) {
1782 if (bdytail != 0.0) {
1802 if (cdytail != 0.0) {
1825 return finnow[finlength - 1];
1933 const double *pa,
const double *pb,
const double *pc,
const double *pd,
const double *pe)
1935 INEXACT double axby1, bxcy1, cxdy1, dxey1, exay1;
1936 INEXACT double bxay1, cxby1, dxcy1, exdy1, axey1;
1937 INEXACT double axcy1, bxdy1, cxey1, dxay1, exby1;
1938 INEXACT double cxay1, dxby1, excy1, axdy1, bxey1;
1939 double axby0, bxcy0, cxdy0, dxey0, exay0;
1940 double bxay0, cxby0, dxcy0, exdy0, axey0;
1941 double axcy0, bxdy0, cxey0, dxay0, exby0;
1942 double cxay0, dxby0, excy0, axdy0, bxey0;
1943 double ab[4], bc[4], cd[4], de[4], ea[4];
1944 double ac[4], bd[4], ce[4], da[4], eb[4];
1945 double temp8a[8], temp8b[8], temp16[16];
1946 int temp8alen, temp8blen, temp16len;
1947 double abc[24], bcd[24], cde[24], dea[24], eab[24];
1948 double abd[24], bce[24], cda[24], deb[24], eac[24];
1949 int abclen, bcdlen, cdelen, dealen, eablen;
1950 int abdlen, bcelen, cdalen, deblen, eaclen;
1951 double temp48a[48], temp48b[48];
1952 int temp48alen, temp48blen;
1953 double abcd[96], bcde[96], cdea[96], deab[96], eabc[96];
1954 int abcdlen, bcdelen, cdealen, deablen, eabclen;
1955 double temp192[192];
1956 double det384x[384], det384y[384], det384z[384];
1957 int xlen, ylen, zlen;
1960 double adet[1152], bdet[1152], cdet[1152], ddet[1152], edet[1152];
1961 int alen, blen, clen, dlen, elen;
1962 double abdet[2304], cddet[2304], cdedet[3456];
1969 double avirt, bround, around;
1972 double ahi, alo, bhi, blo;
1973 double err1, err2, err3;
1979 Two_Two_Diff(axby1, axby0, bxay1, bxay0, ab[3], ab[2], ab[1], ab[0]);
1983 Two_Two_Diff(bxcy1, bxcy0, cxby1, cxby0, bc[3], bc[2], bc[1], bc[0]);
1987 Two_Two_Diff(cxdy1, cxdy0, dxcy1, dxcy0, cd[3], cd[2], cd[1], cd[0]);
1991 Two_Two_Diff(dxey1, dxey0, exdy1, exdy0, de[3], de[2], de[1], de[0]);
1995 Two_Two_Diff(exay1, exay0, axey1, axey0, ea[3], ea[2], ea[1], ea[0]);
1999 Two_Two_Diff(axcy1, axcy0, cxay1, cxay0, ac[3], ac[2], ac[1], ac[0]);
2003 Two_Two_Diff(bxdy1, bxdy0, dxby1, dxby0, bd[3], bd[2], bd[1], bd[0]);
2007 Two_Two_Diff(cxey1, cxey0, excy1, excy0, ce[3], ce[2], ce[1], ce[0]);
2011 Two_Two_Diff(dxay1, dxay0, axdy1, axdy0, da[3], da[2], da[1], da[0]);
2015 Two_Two_Diff(exby1, exby0, bxey1, bxey0, eb[3], eb[2], eb[1], eb[0]);
2079 for (
i = 0;
i < temp48blen;
i++) {
2080 temp48b[
i] = -temp48b[
i];
2094 for (
i = 0;
i < temp48blen;
i++) {
2095 temp48b[
i] = -temp48b[
i];
2109 for (
i = 0;
i < temp48blen;
i++) {
2110 temp48b[
i] = -temp48b[
i];
2124 for (
i = 0;
i < temp48blen;
i++) {
2125 temp48b[
i] = -temp48b[
i];
2139 for (
i = 0;
i < temp48blen;
i++) {
2140 temp48b[
i] = -temp48b[
i];
2157 return deter[deterlen - 1];
2167 INEXACT double aex, bex, cex, dex, aey, bey, cey, dey, aez, bez, cez, dez;
2168 double det, errbound;
2170 INEXACT double aexbey1, bexaey1, bexcey1, cexbey1;
2171 INEXACT double cexdey1, dexcey1, dexaey1, aexdey1;
2172 INEXACT double aexcey1, cexaey1, bexdey1, dexbey1;
2173 double aexbey0, bexaey0, bexcey0, cexbey0;
2174 double cexdey0, dexcey0, dexaey0, aexdey0;
2175 double aexcey0, cexaey0, bexdey0, dexbey0;
2176 double ab[4], bc[4], cd[4], da[4], ac[4], bd[4];
2177 INEXACT double ab3, bc3, cd3, da3, ac3, bd3;
2178 double abeps, bceps, cdeps, daeps, aceps, bdeps;
2179 double temp8a[8], temp8b[8], temp8c[8], temp16[16], temp24[24], temp48[48];
2180 int temp8alen, temp8blen, temp8clen, temp16len, temp24len, temp48len;
2181 double xdet[96], ydet[96], zdet[96], xydet[192];
2182 int xlen, ylen, zlen, xylen;
2183 double adet[288], bdet[288], cdet[288], ddet[288];
2184 int alen, blen, clen, dlen;
2185 double abdet[576], cddet[576];
2190 double aextail, bextail, cextail, dextail;
2191 double aeytail, beytail, ceytail, deytail;
2192 double aeztail, beztail, ceztail, deztail;
2195 double avirt, bround, around;
2198 double ahi, alo, bhi, blo;
2199 double err1, err2, err3;
2203 aex = double(pa[0] - pe[0]);
2204 bex = double(pb[0] - pe[0]);
2205 cex = double(pc[0] - pe[0]);
2206 dex = double(pd[0] - pe[0]);
2207 aey = double(pa[1] - pe[1]);
2208 bey = double(pb[1] - pe[1]);
2209 cey = double(pc[1] - pe[1]);
2210 dey = double(pd[1] - pe[1]);
2211 aez = double(pa[2] - pe[2]);
2212 bez = double(pb[2] - pe[2]);
2213 cez = double(pc[2] - pe[2]);
2214 dez = double(pd[2] - pe[2]);
2218 Two_Two_Diff(aexbey1, aexbey0, bexaey1, bexaey0, ab3, ab[2], ab[1], ab[0]);
2223 Two_Two_Diff(bexcey1, bexcey0, cexbey1, cexbey0, bc3, bc[2], bc[1], bc[0]);
2228 Two_Two_Diff(cexdey1, cexdey0, dexcey1, dexcey0, cd3, cd[2], cd[1], cd[0]);
2233 Two_Two_Diff(dexaey1, dexaey0, aexdey1, aexdey0, da3, da[2], da[1], da[0]);
2238 Two_Two_Diff(aexcey1, aexcey0, cexaey1, cexaey0, ac3, ac[2], ac[1], ac[0]);
2243 Two_Two_Diff(bexdey1, bexdey0, dexbey1, dexbey0, bd3, bd[2], bd[1], bd[0]);
2308 if ((det >= errbound) || (-det >= errbound)) {
2324 if ((aextail == 0.0) && (aeytail == 0.0) && (aeztail == 0.0) && (bextail == 0.0) &&
2325 (beytail == 0.0) && (beztail == 0.0) && (cextail == 0.0) && (ceytail == 0.0) &&
2326 (ceztail == 0.0) && (dextail == 0.0) && (deytail == 0.0) && (deztail == 0.0))
2332 abeps = (aex * beytail + bey * aextail) - (aey * bextail + bex * aeytail);
2333 bceps = (bex * ceytail + cey * bextail) - (bey * cextail + cex * beytail);
2334 cdeps = (cex * deytail + dey * cextail) - (cey * dextail + dex * ceytail);
2335 daeps = (dex * aeytail + aey * dextail) - (dey * aextail + aex * deytail);
2336 aceps = (aex * ceytail + cey * aextail) - (aey * cextail + cex * aeytail);
2337 bdeps = (bex * deytail + dey * bextail) - (bey * dextail + dex * beytail);
2339 (((bex * bex + bey * bey + bez * bez) * ((cez * daeps + dez * aceps + aez * cdeps) +
2340 (ceztail * da3 + deztail * ac3 + aeztail * cd3)) +
2341 (dex * dex + dey * dey + dez * dez) * ((aez * bceps - bez * aceps + cez * abeps) +
2342 (aeztail * bc3 - beztail * ac3 + ceztail * ab3))) -
2343 ((aex * aex + aey * aey + aez * aez) * ((bez * cdeps - cez * bdeps + dez * bceps) +
2344 (beztail * cd3 - ceztail * bd3 + deztail * bc3)) +
2345 (cex * cex + cey * cey + cez * cez) * ((dez * abeps + aez * bdeps + bez * daeps) +
2346 (deztail * ab3 + aeztail * bd3 + beztail * da3)))) +
2348 (((bex * bextail + bey * beytail + bez * beztail) * (cez * da3 + dez * ac3 + aez * cd3) +
2349 (dex * dextail + dey * deytail + dez * deztail) *
2350 (aez * bc3 - bez * ac3 + cez * ab3)) -
2351 ((aex * aextail + aey * aeytail + aez * aeztail) * (bez * cd3 - cez * bd3 + dez * bc3) +
2352 (cex * cextail + cey * ceytail + cez * ceztail) *
2353 (dez * ab3 + aez * bd3 + bez * da3)));
2354 if ((det >= errbound) || (-det >= errbound)) {