123 #include <fpu_control.h>
142 #define REALPRINT doubleprint
143 #define REALRAND doublerand
144 #define NARROWRAND narrowdoublerand
145 #define UNIFORMRAND uniformdoublerand
153 #define Absolute(a) ((a) >= 0.0 ? (a) : -(a))
169 #define Fast_Two_Sum_Tail(a, b, x, y) \
173 #define Fast_Two_Sum(a, b, x, y) \
174 x = (REAL) (a + b); \
175 Fast_Two_Sum_Tail(a, b, x, y)
177 #define Fast_Two_Diff_Tail(a, b, x, y) \
181 #define Fast_Two_Diff(a, b, x, y) \
182 x = (REAL) (a - b); \
183 Fast_Two_Diff_Tail(a, b, x, y)
185 #define Two_Sum_Tail(a, b, x, y) \
186 bvirt = (REAL) (x - a); \
188 bround = b - bvirt; \
189 around = a - avirt; \
192 #define Two_Sum(a, b, x, y) \
193 x = (REAL) (a + b); \
194 Two_Sum_Tail(a, b, x, y)
196 #define Two_Diff_Tail(a, b, x, y) \
197 bvirt = (REAL) (a - x); \
199 bround = bvirt - b; \
200 around = a - avirt; \
203 #define Two_Diff(a, b, x, y) \
204 x = (REAL) (a - b); \
205 Two_Diff_Tail(a, b, x, y)
207 #define Split(a, ahi, alo) \
208 c = (REAL) (splitter * a); \
209 abig = (REAL) (c - a); \
213 #define Two_Product_Tail(a, b, x, y) \
214 Split(a, ahi, alo); \
215 Split(b, bhi, blo); \
216 err1 = x - (ahi * bhi); \
217 err2 = err1 - (alo * bhi); \
218 err3 = err2 - (ahi * blo); \
219 y = (alo * blo) - err3
221 #define Two_Product(a, b, x, y) \
222 x = (REAL) (a * b); \
223 Two_Product_Tail(a, b, x, y)
228 #define Two_Product_Presplit(a, b, bhi, blo, x, y) \
229 x = (REAL) (a * b); \
230 Split(a, ahi, alo); \
231 err1 = x - (ahi * bhi); \
232 err2 = err1 - (alo * bhi); \
233 err3 = err2 - (ahi * blo); \
234 y = (alo * blo) - err3
239 #define Two_Product_2Presplit(a, ahi, alo, b, bhi, blo, x, y) \
240 x = (REAL) (a * b); \
241 err1 = x - (ahi * bhi); \
242 err2 = err1 - (alo * bhi); \
243 err3 = err2 - (ahi * blo); \
244 y = (alo * blo) - err3
248 #define Square_Tail(a, x, y) \
249 Split(a, ahi, alo); \
250 err1 = x - (ahi * ahi); \
251 err3 = err1 - ((ahi + ahi) * alo); \
252 y = (alo * alo) - err3
254 #define Square(a, x, y) \
255 x = (REAL) (a * a); \
261 #define Two_One_Sum(a1, a0, b, x2, x1, x0) \
262 Two_Sum(a0, b , _i, x0); \
263 Two_Sum(a1, _i, x2, x1)
265 #define Two_One_Diff(a1, a0, b, x2, x1, x0) \
266 Two_Diff(a0, b , _i, x0); \
267 Two_Sum( a1, _i, x2, x1)
269 #define Two_Two_Sum(a1, a0, b1, b0, x3, x2, x1, x0) \
270 Two_One_Sum(a1, a0, b0, _j, _0, x0); \
271 Two_One_Sum(_j, _0, b1, x3, x2, x1)
273 #define Two_Two_Diff(a1, a0, b1, b0, x3, x2, x1, x0) \
274 Two_One_Diff(a1, a0, b0, _j, _0, x0); \
275 Two_One_Diff(_j, _0, b1, x3, x2, x1)
277 #define Four_One_Sum(a3, a2, a1, a0, b, x4, x3, x2, x1, x0) \
278 Two_One_Sum(a1, a0, b , _j, x1, x0); \
279 Two_One_Sum(a3, a2, _j, x4, x3, x2)
281 #define Four_Two_Sum(a3, a2, a1, a0, b1, b0, x5, x4, x3, x2, x1, x0) \
282 Four_One_Sum(a3, a2, a1, a0, b0, _k, _2, _1, _0, x0); \
283 Four_One_Sum(_k, _2, _1, _0, b1, x5, x4, x3, x2, x1)
285 #define Four_Four_Sum(a3, a2, a1, a0, b4, b3, b1, b0, x7, x6, x5, x4, x3, x2, \
287 Four_Two_Sum(a3, a2, a1, a0, b1, b0, _l, _2, _1, _0, x1, x0); \
288 Four_Two_Sum(_l, _2, _1, _0, b4, b3, x7, x6, x5, x4, x3, x2)
290 #define Eight_One_Sum(a7, a6, a5, a4, a3, a2, a1, a0, b, x8, x7, x6, x5, x4, \
292 Four_One_Sum(a3, a2, a1, a0, b , _j, x3, x2, x1, x0); \
293 Four_One_Sum(a7, a6, a5, a4, _j, x8, x7, x6, x5, x4)
295 #define Eight_Two_Sum(a7, a6, a5, a4, a3, a2, a1, a0, b1, b0, x9, x8, x7, \
296 x6, x5, x4, x3, x2, x1, x0) \
297 Eight_One_Sum(a7, a6, a5, a4, a3, a2, a1, a0, b0, _k, _6, _5, _4, _3, _2, \
299 Eight_One_Sum(_k, _6, _5, _4, _3, _2, _1, _0, b1, x9, x8, x7, x6, x5, x4, \
302 #define Eight_Four_Sum(a7, a6, a5, a4, a3, a2, a1, a0, b4, b3, b1, b0, x11, \
303 x10, x9, x8, x7, x6, x5, x4, x3, x2, x1, x0) \
304 Eight_Two_Sum(a7, a6, a5, a4, a3, a2, a1, a0, b1, b0, _l, _6, _5, _4, _3, \
305 _2, _1, _0, x1, x0); \
306 Eight_Two_Sum(_l, _6, _5, _4, _3, _2, _1, _0, b4, b3, x11, x10, x9, x8, \
307 x7, x6, x5, x4, x3, x2)
311 #define Two_One_Product(a1, a0, b, x3, x2, x1, x0) \
312 Split(b, bhi, blo); \
313 Two_Product_Presplit(a0, b, bhi, blo, _i, x0); \
314 Two_Product_Presplit(a1, b, bhi, blo, _j, _0); \
315 Two_Sum(_i, _0, _k, x1); \
316 Fast_Two_Sum(_j, _k, x3, x2)
318 #define Four_One_Product(a3, a2, a1, a0, b, x7, x6, x5, x4, x3, x2, x1, x0) \
319 Split(b, bhi, blo); \
320 Two_Product_Presplit(a0, b, bhi, blo, _i, x0); \
321 Two_Product_Presplit(a1, b, bhi, blo, _j, _0); \
322 Two_Sum(_i, _0, _k, x1); \
323 Fast_Two_Sum(_j, _k, _i, x2); \
324 Two_Product_Presplit(a2, b, bhi, blo, _j, _0); \
325 Two_Sum(_i, _0, _k, x3); \
326 Fast_Two_Sum(_j, _k, _i, x4); \
327 Two_Product_Presplit(a3, b, bhi, blo, _j, _0); \
328 Two_Sum(_i, _0, _k, x5); \
329 Fast_Two_Sum(_j, _k, x7, x6)
331 #define Two_Two_Product(a1, a0, b1, b0, x7, x6, x5, x4, x3, x2, x1, x0) \
332 Split(a0, a0hi, a0lo); \
333 Split(b0, bhi, blo); \
334 Two_Product_2Presplit(a0, a0hi, a0lo, b0, bhi, blo, _i, x0); \
335 Split(a1, a1hi, a1lo); \
336 Two_Product_2Presplit(a1, a1hi, a1lo, b0, bhi, blo, _j, _0); \
337 Two_Sum(_i, _0, _k, _1); \
338 Fast_Two_Sum(_j, _k, _l, _2); \
339 Split(b1, bhi, blo); \
340 Two_Product_2Presplit(a0, a0hi, a0lo, b1, bhi, blo, _i, _0); \
341 Two_Sum(_1, _0, _k, x1); \
342 Two_Sum(_2, _k, _j, _1); \
343 Two_Sum(_l, _j, _m, _2); \
344 Two_Product_2Presplit(a1, a1hi, a1lo, b1, bhi, blo, _j, _0); \
345 Two_Sum(_i, _0, _n, _0); \
346 Two_Sum(_1, _0, _i, x2); \
347 Two_Sum(_2, _i, _k, _1); \
348 Two_Sum(_m, _k, _l, _2); \
349 Two_Sum(_j, _n, _k, _0); \
350 Two_Sum(_1, _0, _j, x3); \
351 Two_Sum(_2, _j, _i, _1); \
352 Two_Sum(_l, _i, _m, _2); \
353 Two_Sum(_1, _k, _i, x4); \
354 Two_Sum(_2, _i, _k, x5); \
355 Two_Sum(_m, _k, x7, x6)
361 #define Two_Square(a1, a0, x5, x4, x3, x2, x1, x0) \
362 Square(a0, _j, x0); \
364 Two_Product(a1, _0, _k, _1); \
365 Two_One_Sum(_k, _1, _j, _l, _2, x1); \
366 Square(a1, _j, _1); \
367 Two_Two_Sum(_j, _1, _l, _2, x5, x4, x3, x2)
667 REAL check, lastcheck;
675 _control87(_PC_24, _MCW_PC);
677 _control87(_PC_53, _MCW_PC);
706 every_other = !every_other;
708 }
while ((check != 1.0) && (check != lastcheck));
750 REAL avirt, bround, around;
753 for (eindex = 0; eindex < elen; eindex++) {
755 Two_Sum(Q, enow, Qnew, h[eindex]);
784 REAL avirt, bround, around;
788 for (eindex = 0; eindex < elen; eindex++) {
796 if ((Q != 0.0) || (hindex == 0)) {
820 int findex, hindex, hlast;
823 REAL avirt, bround, around;
826 for (hindex = 0; hindex < elen; hindex++) {
828 Two_Sum(Q, hnow, Qnew, h[hindex]);
833 for (findex = 1; findex < flen; findex++) {
835 for (hindex = findex; hindex <= hlast; hindex++) {
837 Two_Sum(Q, hnow, Qnew, h[hindex]);
864 int index, findex, hindex, hlast;
867 REAL avirt, bround, around;
870 for (hindex = 0; hindex < elen; hindex++) {
872 Two_Sum(Q, hnow, Qnew, h[hindex]);
877 for (findex = 1; findex < flen; findex++) {
879 for (hindex = findex; hindex <= hlast; hindex++) {
881 Two_Sum(Q, hnow, Qnew, h[hindex]);
887 for (index = 0; index <= hlast; index++) {
919 int eindex, findex, hindex, hlast;
922 REAL avirt, bround, around;
926 for (eindex = 0; eindex < elen; eindex++) {
936 for (findex = 1; findex < flen; findex++) {
939 for (eindex = 0; eindex <= hlast; eindex++) {
972 REAL avirt, bround, around;
973 int eindex, findex, hindex;
979 if ((fnow > enow) == (fnow > -enow)) {
987 if ((eindex < elen) && (findex < flen)) {
988 if ((fnow > enow) == (fnow > -enow)) {
997 while ((eindex < elen) && (findex < flen)) {
998 if ((fnow > enow) == (fnow > -enow)) {
999 Two_Sum(Q, enow, Qnew, h[hindex]);
1002 Two_Sum(Q, fnow, Qnew, h[hindex]);
1009 while (eindex < elen) {
1010 Two_Sum(Q, enow, Qnew, h[hindex]);
1015 while (findex < flen) {
1016 Two_Sum(Q, fnow, Qnew, h[hindex]);
1046 REAL avirt, bround, around;
1047 int eindex, findex, hindex;
1052 eindex = findex = 0;
1053 if ((fnow > enow) == (fnow > -enow)) {
1061 if ((eindex < elen) && (findex < flen)) {
1062 if ((fnow > enow) == (fnow > -enow)) {
1073 while ((eindex < elen) && (findex < flen)) {
1074 if ((fnow > enow) == (fnow > -enow)) {
1087 while (eindex < elen) {
1095 while (findex < flen) {
1103 if ((Q != 0.0) || (hindex == 0)) {
1127 REAL avirt, bround, around;
1128 int eindex, findex, hindex;
1134 eindex = findex = 0;
1135 if ((fnow > enow) == (fnow > -enow)) {
1142 if ((eindex < elen) && ((findex >= flen)
1143 || ((fnow > enow) == (fnow > -enow)))) {
1151 for (hindex = 0; hindex < elen + flen - 2; hindex++) {
1152 if ((eindex < elen) && ((findex >= flen)
1153 || ((fnow > enow) == (fnow > -enow)))) {
1188 REAL avirt, bround, around;
1189 int eindex, findex, hindex;
1196 eindex = findex = 0;
1198 if ((fnow > enow) == (fnow > -enow)) {
1205 if ((eindex < elen) && ((findex >= flen)
1206 || ((fnow > enow) == (fnow > -enow)))) {
1214 for (count = 2; count < elen + flen; count++) {
1215 if ((eindex < elen) && ((findex >= flen)
1216 || ((fnow > enow) == (fnow > -enow)))) {
1232 if ((Q != 0.0) || (hindex == 0)) {
1261 REAL avirt, bround, around;
1264 REAL ahi, alo, bhi, blo;
1265 REAL err1, err2, err3;
1270 for (eindex = 1; eindex < elen; eindex++) {
1273 Two_Sum(Q, product0, sum, h[hindex]);
1275 Two_Sum(product1, sum, Q, h[hindex]);
1307 REAL avirt, bround, around;
1310 REAL ahi, alo, bhi, blo;
1311 REAL err1, err2, err3;
1319 for (eindex = 1; eindex < elen; eindex++) {
1322 Two_Sum(Q, product0, sum, hh);
1331 if ((Q != 0.0) || (hindex == 0)) {
1361 for (eindex = elen - 2; eindex >= 0; eindex--) {
1372 for (hindex = bottom + 1; hindex < elen; hindex++) {
1398 for (eindex = 1; eindex < elen; eindex++) {
1432 REAL acx, bcx, acy, bcy;
1434 acx = pa[0] - pc[0];
1435 bcx = pb[0] - pc[0];
1436 acy = pa[1] - pc[1];
1437 bcy = pb[1] - pc[1];
1438 return acx * bcy - acy * bcx;
1443 INEXACT REAL axby1, axcy1, bxcy1, bxay1, cxay1, cxby1;
1444 REAL axby0, axcy0, bxcy0, bxay0, cxay0, cxby0;
1445 REAL aterms[4], bterms[4], cterms[4];
1448 int vlength, wlength;
1451 REAL avirt, bround, around;
1454 REAL ahi, alo, bhi, blo;
1455 REAL err1, err2, err3;
1462 aterms3, aterms[2], aterms[1], aterms[0]);
1463 aterms[3] = aterms3;
1468 bterms3, bterms[2], bterms[1], bterms[0]);
1469 bterms[3] = bterms3;
1474 cterms3, cterms[2], cterms[1], cterms[0]);
1475 cterms[3] = cterms3;
1480 return w[wlength - 1];
1486 REAL acxtail, acytail;
1487 REAL bcxtail, bcytail;
1488 REAL negate, negatetail;
1489 REAL axby[8], bxay[8];
1495 REAL avirt, bround, around;
1498 REAL a0hi, a0lo, a1hi, a1lo, bhi, blo;
1499 REAL err1, err2, err3;
1503 Two_Diff(pa[0], pc[0], acx, acxtail);
1504 Two_Diff(pa[1], pc[1], acy, acytail);
1505 Two_Diff(pb[0], pc[0], bcx, bcxtail);
1506 Two_Diff(pb[1], pc[1], bcy, bcytail);
1509 axby7, axby[6], axby[5], axby[4],
1510 axby[3], axby[2], axby[1], axby[0]);
1513 negatetail = -acytail;
1515 bxay7, bxay[6], bxay[5], bxay[4],
1516 bxay[3], bxay[2], bxay[1], bxay[0]);
1521 return deter[deterlen - 1];
1527 REAL acxtail, acytail, bcxtail, bcytail;
1529 REAL detlefttail, detrighttail;
1531 REAL B[4], C1[8], C2[12], D[16];
1533 int C1length, C2length, Dlength;
1540 REAL avirt, bround, around;
1543 REAL ahi, alo, bhi, blo;
1544 REAL err1, err2, err3;
1548 acx = (
REAL) (pa[0] - pc[0]);
1549 bcx = (
REAL) (pb[0] - pc[0]);
1550 acy = (
REAL) (pa[1] - pc[1]);
1551 bcy = (
REAL) (pb[1] - pc[1]);
1556 Two_Two_Diff(detleft, detlefttail, detright, detrighttail,
1557 B3, B[2], B[1], B[0]);
1562 if ((det >= errbound) || (-det >= errbound)) {
1571 if ((acxtail == 0.0) && (acytail == 0.0)
1572 && (bcxtail == 0.0) && (bcytail == 0.0)) {
1577 det += (acx * bcytail + bcy * acxtail)
1578 - (acy * bcxtail + bcx * acytail);
1579 if ((det >= errbound) || (-det >= errbound)) {
1601 return(D[Dlength - 1]);
1606 REAL detleft, detright, det;
1607 REAL detsum, errbound;
1609 detleft = (pa[0] - pc[0]) * (pb[1] - pc[1]);
1610 detright = (pa[1] - pc[1]) * (pb[0] - pc[0]);
1611 det = detleft - detright;
1613 if (detleft > 0.0) {
1614 if (detright <= 0.0) {
1617 detsum = detleft + detright;
1619 }
else if (detleft < 0.0) {
1620 if (detright >= 0.0) {
1623 detsum = -detleft - detright;
1630 if ((det >= errbound) || (-det >= errbound)) {
1672 adx = pa[0] - pd[0];
1673 bdx = pb[0] - pd[0];
1674 cdx = pc[0] - pd[0];
1675 ady = pa[1] - pd[1];
1676 bdy = pb[1] - pd[1];
1677 cdy = pc[1] - pd[1];
1678 adz = pa[2] - pd[2];
1679 bdz = pb[2] - pd[2];
1680 cdz = pc[2] - pd[2];
1682 return adx * (bdy * cdz - bdz * cdy)
1683 + bdx * (cdy * adz - cdz * ady)
1684 + cdx * (ady * bdz - adz * bdy);
1689 INEXACT REAL axby1, bxcy1, cxdy1, dxay1, axcy1, bxdy1;
1690 INEXACT REAL bxay1, cxby1, dxcy1, axdy1, cxay1, dxby1;
1691 REAL axby0, bxcy0, cxdy0, dxay0, axcy0, bxdy0;
1692 REAL bxay0, cxby0, dxcy0, axdy0, cxay0, dxby0;
1693 REAL ab[4], bc[4], cd[4], da[4], ac[4], bd[4];
1696 REAL abc[12], bcd[12], cda[12], dab[12];
1697 int abclen, bcdlen, cdalen, dablen;
1698 REAL adet[24], bdet[24], cdet[24], ddet[24];
1699 int alen, blen, clen, dlen;
1700 REAL abdet[48], cddet[48];
1707 REAL avirt, bround, around;
1710 REAL ahi, alo, bhi, blo;
1711 REAL err1, err2, err3;
1717 Two_Two_Diff(axby1, axby0, bxay1, bxay0, ab[3], ab[2], ab[1], ab[0]);
1721 Two_Two_Diff(bxcy1, bxcy0, cxby1, cxby0, bc[3], bc[2], bc[1], bc[0]);
1725 Two_Two_Diff(cxdy1, cxdy0, dxcy1, dxcy0, cd[3], cd[2], cd[1], cd[0]);
1729 Two_Two_Diff(dxay1, dxay0, axdy1, axdy0, da[3], da[2], da[1], da[0]);
1733 Two_Two_Diff(axcy1, axcy0, cxay1, cxay0, ac[3], ac[2], ac[1], ac[0]);
1737 Two_Two_Diff(bxdy1, bxdy0, dxby1, dxby0, bd[3], bd[2], bd[1], bd[0]);
1743 for (i = 0; i < 4; i++) {
1761 return deter[deterlen - 1];
1766 INEXACT REAL adx, ady, adz, bdx, bdy, bdz, cdx, cdy, cdz;
1767 REAL adxtail, adytail, adztail;
1768 REAL bdxtail, bdytail, bdztail;
1769 REAL cdxtail, cdytail, cdztail;
1770 REAL negate, negatetail;
1771 INEXACT REAL axby7, bxcy7, axcy7, bxay7, cxby7, cxay7;
1772 REAL axby[8], bxcy[8], axcy[8], bxay[8], cxby[8], cxay[8];
1773 REAL temp16[16], temp32[32], temp32t[32];
1774 int temp16len, temp32len, temp32tlen;
1775 REAL adet[64], bdet[64], cdet[64];
1776 int alen, blen, clen;
1783 REAL avirt, bround, around;
1786 REAL a0hi, a0lo, a1hi, a1lo, bhi, blo;
1787 REAL err1, err2, err3;
1791 Two_Diff(pa[0], pd[0], adx, adxtail);
1792 Two_Diff(pa[1], pd[1], ady, adytail);
1793 Two_Diff(pa[2], pd[2], adz, adztail);
1794 Two_Diff(pb[0], pd[0], bdx, bdxtail);
1795 Two_Diff(pb[1], pd[1], bdy, bdytail);
1796 Two_Diff(pb[2], pd[2], bdz, bdztail);
1797 Two_Diff(pc[0], pd[0], cdx, cdxtail);
1798 Two_Diff(pc[1], pd[1], cdy, cdytail);
1799 Two_Diff(pc[2], pd[2], cdz, cdztail);
1802 axby7, axby[6], axby[5], axby[4],
1803 axby[3], axby[2], axby[1], axby[0]);
1806 negatetail = -adytail;
1808 bxay7, bxay[6], bxay[5], bxay[4],
1809 bxay[3], bxay[2], bxay[1], bxay[0]);
1812 bxcy7, bxcy[6], bxcy[5], bxcy[4],
1813 bxcy[3], bxcy[2], bxcy[1], bxcy[0]);
1816 negatetail = -bdytail;
1818 cxby7, cxby[6], cxby[5], cxby[4],
1819 cxby[3], cxby[2], cxby[1], cxby[0]);
1822 cxay7, cxay[6], cxay[5], cxay[4],
1823 cxay[3], cxay[2], cxay[1], cxay[0]);
1826 negatetail = -cdytail;
1828 axcy7, axcy[6], axcy[5], axcy[4],
1829 axcy[3], axcy[2], axcy[1], axcy[0]);
1853 return deter[deterlen - 1];
1858 INEXACT REAL adx, bdx, cdx, ady, bdy, cdy, adz, bdz, cdz;
1861 INEXACT REAL bdxcdy1, cdxbdy1, cdxady1, adxcdy1, adxbdy1, bdxady1;
1862 REAL bdxcdy0, cdxbdy0, cdxady0, adxcdy0, adxbdy0, bdxady0;
1863 REAL bc[4], ca[4], ab[4];
1865 REAL adet[8], bdet[8], cdet[8];
1866 int alen, blen, clen;
1869 REAL *finnow, *finother, *finswap;
1870 REAL fin1[192], fin2[192];
1873 REAL adxtail, bdxtail, cdxtail;
1874 REAL adytail, bdytail, cdytail;
1875 REAL adztail, bdztail, cdztail;
1879 REAL at_b[4], at_c[4], bt_c[4], bt_a[4], ct_a[4], ct_b[4];
1880 int at_blen, at_clen, bt_clen, bt_alen, ct_alen, ct_blen;
1883 REAL bdxt_cdy0, cdxt_bdy0, cdxt_ady0;
1884 REAL adxt_cdy0, adxt_bdy0, bdxt_ady0;
1887 REAL bdyt_cdx0, cdyt_bdx0, cdyt_adx0;
1888 REAL adyt_cdx0, adyt_bdx0, bdyt_adx0;
1889 REAL bct[8], cat[8], abt[8];
1890 int bctlen, catlen, abtlen;
1893 REAL bdxt_cdyt0, cdxt_bdyt0, cdxt_adyt0;
1894 REAL adxt_cdyt0, adxt_bdyt0, bdxt_adyt0;
1895 REAL u[4], v[12], w[16];
1897 int vlength, wlength;
1901 REAL avirt, bround, around;
1904 REAL ahi, alo, bhi, blo;
1905 REAL err1, err2, err3;
1909 adx = (
REAL) (pa[0] - pd[0]);
1910 bdx = (
REAL) (pb[0] - pd[0]);
1911 cdx = (
REAL) (pc[0] - pd[0]);
1912 ady = (
REAL) (pa[1] - pd[1]);
1913 bdy = (
REAL) (pb[1] - pd[1]);
1914 cdy = (
REAL) (pc[1] - pd[1]);
1915 adz = (
REAL) (pa[2] - pd[2]);
1916 bdz = (
REAL) (pb[2] - pd[2]);
1917 cdz = (
REAL) (pc[2] - pd[2]);
1921 Two_Two_Diff(bdxcdy1, bdxcdy0, cdxbdy1, cdxbdy0, bc3, bc[2], bc[1], bc[0]);
1927 Two_Two_Diff(cdxady1, cdxady0, adxcdy1, adxcdy0, ca3, ca[2], ca[1], ca[0]);
1933 Two_Two_Diff(adxbdy1, adxbdy0, bdxady1, bdxady0, ab3, ab[2], ab[1], ab[0]);
1942 if ((det >= errbound) || (-det >= errbound)) {
1956 if ((adxtail == 0.0) && (bdxtail == 0.0) && (cdxtail == 0.0)
1957 && (adytail == 0.0) && (bdytail == 0.0) && (cdytail == 0.0)
1958 && (adztail == 0.0) && (bdztail == 0.0) && (cdztail == 0.0)) {
1963 det += (adz * ((bdx * cdytail + cdy * bdxtail)
1964 - (bdy * cdxtail + cdx * bdytail))
1965 + adztail * (bdx * cdy - bdy * cdx))
1966 + (bdz * ((cdx * adytail + ady * cdxtail)
1967 - (cdy * adxtail + adx * cdytail))
1968 + bdztail * (cdx * ady - cdy * adx))
1969 + (cdz * ((adx * bdytail + bdy * adxtail)
1970 - (ady * bdxtail + bdx * adytail))
1971 + cdztail * (adx * bdy - ady * bdx));
1972 if ((det >= errbound) || (-det >= errbound)) {
1979 if (adxtail == 0.0) {
1980 if (adytail == 0.0) {
1988 at_b[1] = at_blarge;
1991 at_c[1] = at_clarge;
1995 if (adytail == 0.0) {
1997 at_b[1] = at_blarge;
2001 at_c[1] = at_clarge;
2006 Two_Two_Diff(adxt_bdy1, adxt_bdy0, adyt_bdx1, adyt_bdx0,
2007 at_blarge, at_b[2], at_b[1], at_b[0]);
2008 at_b[3] = at_blarge;
2012 Two_Two_Diff(adyt_cdx1, adyt_cdx0, adxt_cdy1, adxt_cdy0,
2013 at_clarge, at_c[2], at_c[1], at_c[0]);
2014 at_c[3] = at_clarge;
2018 if (bdxtail == 0.0) {
2019 if (bdytail == 0.0) {
2027 bt_c[1] = bt_clarge;
2030 bt_a[1] = bt_alarge;
2034 if (bdytail == 0.0) {
2036 bt_c[1] = bt_clarge;
2040 bt_a[1] = bt_alarge;
2045 Two_Two_Diff(bdxt_cdy1, bdxt_cdy0, bdyt_cdx1, bdyt_cdx0,
2046 bt_clarge, bt_c[2], bt_c[1], bt_c[0]);
2047 bt_c[3] = bt_clarge;
2051 Two_Two_Diff(bdyt_adx1, bdyt_adx0, bdxt_ady1, bdxt_ady0,
2052 bt_alarge, bt_a[2], bt_a[1], bt_a[0]);
2053 bt_a[3] = bt_alarge;
2057 if (cdxtail == 0.0) {
2058 if (cdytail == 0.0) {
2066 ct_a[1] = ct_alarge;
2069 ct_b[1] = ct_blarge;
2073 if (cdytail == 0.0) {
2075 ct_a[1] = ct_alarge;
2079 ct_b[1] = ct_blarge;
2084 Two_Two_Diff(cdxt_ady1, cdxt_ady0, cdyt_adx1, cdyt_adx0,
2085 ct_alarge, ct_a[2], ct_a[1], ct_a[0]);
2086 ct_a[3] = ct_alarge;
2090 Two_Two_Diff(cdyt_bdx1, cdyt_bdx0, cdxt_bdy1, cdxt_bdy0,
2091 ct_blarge, ct_b[2], ct_b[1], ct_b[0]);
2092 ct_b[3] = ct_blarge;
2121 if (adztail != 0.0) {
2129 if (bdztail != 0.0) {
2137 if (cdztail != 0.0) {
2146 if (adxtail != 0.0) {
2147 if (bdytail != 0.0) {
2148 Two_Product(adxtail, bdytail, adxt_bdyt1, adxt_bdyt0);
2156 if (cdztail != 0.0) {
2157 Two_One_Product(adxt_bdyt1, adxt_bdyt0, cdztail, u3, u[2], u[1], u[0]);
2166 if (cdytail != 0.0) {
2168 Two_Product(negate, cdytail, adxt_cdyt1, adxt_cdyt0);
2176 if (bdztail != 0.0) {
2177 Two_One_Product(adxt_cdyt1, adxt_cdyt0, bdztail, u3, u[2], u[1], u[0]);
2187 if (bdxtail != 0.0) {
2188 if (cdytail != 0.0) {
2189 Two_Product(bdxtail, cdytail, bdxt_cdyt1, bdxt_cdyt0);
2197 if (adztail != 0.0) {
2198 Two_One_Product(bdxt_cdyt1, bdxt_cdyt0, adztail, u3, u[2], u[1], u[0]);
2207 if (adytail != 0.0) {
2209 Two_Product(negate, adytail, bdxt_adyt1, bdxt_adyt0);
2217 if (cdztail != 0.0) {
2218 Two_One_Product(bdxt_adyt1, bdxt_adyt0, cdztail, u3, u[2], u[1], u[0]);
2228 if (cdxtail != 0.0) {
2229 if (adytail != 0.0) {
2230 Two_Product(cdxtail, adytail, cdxt_adyt1, cdxt_adyt0);
2238 if (bdztail != 0.0) {
2239 Two_One_Product(cdxt_adyt1, cdxt_adyt0, bdztail, u3, u[2], u[1], u[0]);
2248 if (bdytail != 0.0) {
2250 Two_Product(negate, bdytail, cdxt_bdyt1, cdxt_bdyt0);
2258 if (adztail != 0.0) {
2259 Two_One_Product(cdxt_bdyt1, cdxt_bdyt0, adztail, u3, u[2], u[1], u[0]);
2270 if (adztail != 0.0) {
2278 if (bdztail != 0.0) {
2286 if (cdztail != 0.0) {
2295 return finnow[finlength - 1];
2300 REAL adx, bdx, cdx, ady, bdy, cdy, adz, bdz, cdz;
2301 REAL bdxcdy, cdxbdy, cdxady, adxcdy, adxbdy, bdxady;
2303 REAL permanent, errbound;
2305 adx = pa[0] - pd[0];
2306 bdx = pb[0] - pd[0];
2307 cdx = pc[0] - pd[0];
2308 ady = pa[1] - pd[1];
2309 bdy = pb[1] - pd[1];
2310 cdy = pc[1] - pd[1];
2311 adz = pa[2] - pd[2];
2312 bdz = pb[2] - pd[2];
2313 cdz = pc[2] - pd[2];
2324 det = adz * (bdxcdy - cdxbdy)
2325 + bdz * (cdxady - adxcdy)
2326 + cdz * (adxbdy - bdxady);
2332 if ((det > errbound) || (-det > errbound)) {
2367 REAL adx, ady, bdx, bdy, cdx, cdy;
2368 REAL abdet, bcdet, cadet;
2369 REAL alift, blift, clift;
2371 adx = pa[0] - pd[0];
2372 ady = pa[1] - pd[1];
2373 bdx = pb[0] - pd[0];
2374 bdy = pb[1] - pd[1];
2375 cdx = pc[0] - pd[0];
2376 cdy = pc[1] - pd[1];
2378 abdet = adx * bdy - bdx * ady;
2379 bcdet = bdx * cdy - cdx * bdy;
2380 cadet = cdx * ady - adx * cdy;
2381 alift = adx * adx + ady * ady;
2382 blift = bdx * bdx + bdy * bdy;
2383 clift = cdx * cdx + cdy * cdy;
2385 return alift * bcdet + blift * cadet + clift * abdet;
2390 INEXACT REAL axby1, bxcy1, cxdy1, dxay1, axcy1, bxdy1;
2391 INEXACT REAL bxay1, cxby1, dxcy1, axdy1, cxay1, dxby1;
2392 REAL axby0, bxcy0, cxdy0, dxay0, axcy0, bxdy0;
2393 REAL bxay0, cxby0, dxcy0, axdy0, cxay0, dxby0;
2394 REAL ab[4], bc[4], cd[4], da[4], ac[4], bd[4];
2397 REAL abc[12], bcd[12], cda[12], dab[12];
2398 int abclen, bcdlen, cdalen, dablen;
2399 REAL det24x[24], det24y[24], det48x[48], det48y[48];
2401 REAL adet[96], bdet[96], cdet[96], ddet[96];
2402 int alen, blen, clen, dlen;
2403 REAL abdet[192], cddet[192];
2410 REAL avirt, bround, around;
2413 REAL ahi, alo, bhi, blo;
2414 REAL err1, err2, err3;
2420 Two_Two_Diff(axby1, axby0, bxay1, bxay0, ab[3], ab[2], ab[1], ab[0]);
2424 Two_Two_Diff(bxcy1, bxcy0, cxby1, cxby0, bc[3], bc[2], bc[1], bc[0]);
2428 Two_Two_Diff(cxdy1, cxdy0, dxcy1, dxcy0, cd[3], cd[2], cd[1], cd[0]);
2432 Two_Two_Diff(dxay1, dxay0, axdy1, axdy0, da[3], da[2], da[1], da[0]);
2436 Two_Two_Diff(axcy1, axcy0, cxay1, cxay0, ac[3], ac[2], ac[1], ac[0]);
2440 Two_Two_Diff(bxdy1, bxdy0, dxby1, dxby0, bd[3], bd[2], bd[1], bd[0]);
2446 for (i = 0; i < 4; i++) {
2483 return deter[deterlen - 1];
2489 REAL adxtail, bdxtail, cdxtail;
2490 REAL adytail, bdytail, cdytail;
2491 REAL negate, negatetail;
2492 INEXACT REAL axby7, bxcy7, axcy7, bxay7, cxby7, cxay7;
2493 REAL axby[8], bxcy[8], axcy[8], bxay[8], cxby[8], cxay[8];
2496 REAL detx[32], detxx[64], detxt[32], detxxt[64], detxtxt[64];
2497 int xlen, xxlen, xtlen, xxtlen, xtxtlen;
2498 REAL x1[128], x2[192];
2500 REAL dety[32], detyy[64], detyt[32], detyyt[64], detytyt[64];
2501 int ylen, yylen, ytlen, yytlen, ytytlen;
2502 REAL y1[128], y2[192];
2504 REAL adet[384], bdet[384], cdet[384], abdet[768], deter[1152];
2505 int alen, blen, clen, ablen, deterlen;
2509 REAL avirt, bround, around;
2512 REAL a0hi, a0lo, a1hi, a1lo, bhi, blo;
2513 REAL err1, err2, err3;
2517 Two_Diff(pa[0], pd[0], adx, adxtail);
2518 Two_Diff(pa[1], pd[1], ady, adytail);
2519 Two_Diff(pb[0], pd[0], bdx, bdxtail);
2520 Two_Diff(pb[1], pd[1], bdy, bdytail);
2521 Two_Diff(pc[0], pd[0], cdx, cdxtail);
2522 Two_Diff(pc[1], pd[1], cdy, cdytail);
2525 axby7, axby[6], axby[5], axby[4],
2526 axby[3], axby[2], axby[1], axby[0]);
2529 negatetail = -adytail;
2531 bxay7, bxay[6], bxay[5], bxay[4],
2532 bxay[3], bxay[2], bxay[1], bxay[0]);
2535 bxcy7, bxcy[6], bxcy[5], bxcy[4],
2536 bxcy[3], bxcy[2], bxcy[1], bxcy[0]);
2539 negatetail = -bdytail;
2541 cxby7, cxby[6], cxby[5], cxby[4],
2542 cxby[3], cxby[2], cxby[1], cxby[0]);
2545 cxay7, cxay[6], cxay[5], cxay[4],
2546 cxay[3], cxay[2], cxay[1], cxay[0]);
2549 negatetail = -cdytail;
2551 axcy7, axcy[6], axcy[5], axcy[4],
2552 axcy[3], axcy[2], axcy[1], axcy[0]);
2562 for (i = 0; i < xxtlen; i++) {
2573 for (i = 0; i < yytlen; i++) {
2589 for (i = 0; i < xxtlen; i++) {
2600 for (i = 0; i < yytlen; i++) {
2616 for (i = 0; i < xxtlen; i++) {
2627 for (i = 0; i < yytlen; i++) {
2639 return deter[deterlen - 1];
2647 INEXACT REAL bdxcdy1, cdxbdy1, cdxady1, adxcdy1, adxbdy1, bdxady1;
2648 REAL bdxcdy0, cdxbdy0, cdxady0, adxcdy0, adxbdy0, bdxady0;
2649 REAL bc[4], ca[4], ab[4];
2651 REAL axbc[8], axxbc[16], aybc[8], ayybc[16], adet[32];
2652 int axbclen, axxbclen, aybclen, ayybclen, alen;
2653 REAL bxca[8], bxxca[16], byca[8], byyca[16], bdet[32];
2654 int bxcalen, bxxcalen, bycalen, byycalen, blen;
2655 REAL cxab[8], cxxab[16], cyab[8], cyyab[16], cdet[32];
2656 int cxablen, cxxablen, cyablen, cyyablen, clen;
2659 REAL fin1[1152], fin2[1152];
2660 REAL *finnow, *finother, *finswap;
2663 REAL adxtail, bdxtail, cdxtail, adytail, bdytail, cdytail;
2664 INEXACT REAL adxadx1, adyady1, bdxbdx1, bdybdy1, cdxcdx1, cdycdy1;
2665 REAL adxadx0, adyady0, bdxbdx0, bdybdy0, cdxcdx0, cdycdy0;
2666 REAL aa[4], bb[4], cc[4];
2672 REAL temp8[8], temp16a[16], temp16b[16], temp16c[16];
2673 REAL temp32a[32], temp32b[32], temp48[48], temp64[64];
2674 int temp8len, temp16alen, temp16blen, temp16clen;
2675 int temp32alen, temp32blen, temp48len, temp64len;
2676 REAL axtbb[8], axtcc[8], aytbb[8], aytcc[8];
2677 int axtbblen, axtcclen, aytbblen, aytcclen;
2678 REAL bxtaa[8], bxtcc[8], bytaa[8], bytcc[8];
2679 int bxtaalen, bxtcclen, bytaalen, bytcclen;
2680 REAL cxtaa[8], cxtbb[8], cytaa[8], cytbb[8];
2681 int cxtaalen, cxtbblen, cytaalen, cytbblen;
2682 REAL axtbc[8], aytbc[8], bxtca[8], bytca[8], cxtab[8], cytab[8];
2683 int axtbclen=0, aytbclen=0, bxtcalen=0, bytcalen=0, cxtablen=0, cytablen=0;
2684 REAL axtbct[16], aytbct[16], bxtcat[16], bytcat[16], cxtabt[16], cytabt[16];
2685 int axtbctlen, aytbctlen, bxtcatlen, bytcatlen, cxtabtlen, cytabtlen;
2686 REAL axtbctt[8], aytbctt[8], bxtcatt[8];
2687 REAL bytcatt[8], cxtabtt[8], cytabtt[8];
2688 int axtbcttlen, aytbcttlen, bxtcattlen, bytcattlen, cxtabttlen, cytabttlen;
2689 REAL abt[8], bct[8], cat[8];
2690 int abtlen, bctlen, catlen;
2691 REAL abtt[4], bctt[4], catt[4];
2692 int abttlen, bcttlen, cattlen;
2697 REAL avirt, bround, around;
2700 REAL ahi, alo, bhi, blo;
2701 REAL err1, err2, err3;
2705 adx = (
REAL) (pa[0] - pd[0]);
2706 bdx = (
REAL) (pb[0] - pd[0]);
2707 cdx = (
REAL) (pc[0] - pd[0]);
2708 ady = (
REAL) (pa[1] - pd[1]);
2709 bdy = (
REAL) (pb[1] - pd[1]);
2710 cdy = (
REAL) (pc[1] - pd[1]);
2714 Two_Two_Diff(bdxcdy1, bdxcdy0, cdxbdy1, cdxbdy0, bc3, bc[2], bc[1], bc[0]);
2724 Two_Two_Diff(cdxady1, cdxady0, adxcdy1, adxcdy0, ca3, ca[2], ca[1], ca[0]);
2734 Two_Two_Diff(adxbdy1, adxbdy0, bdxady1, bdxady0, ab3, ab[2], ab[1], ab[0]);
2747 if ((det >= errbound) || (-det >= errbound)) {
2757 if ((adxtail == 0.0) && (bdxtail == 0.0) && (cdxtail == 0.0)
2758 && (adytail == 0.0) && (bdytail == 0.0) && (cdytail == 0.0)) {
2763 det += ((adx * adx + ady * ady) * ((bdx * cdytail + cdy * bdxtail)
2764 - (bdy * cdxtail + cdx * bdytail))
2765 + 2.0 * (adx * adxtail + ady * adytail) * (bdx * cdy - bdy * cdx))
2766 + ((bdx * bdx + bdy * bdy) * ((cdx * adytail + ady * cdxtail)
2767 - (cdy * adxtail + adx * cdytail))
2768 + 2.0 * (bdx * bdxtail + bdy * bdytail) * (cdx * ady - cdy * adx))
2769 + ((cdx * cdx + cdy * cdy) * ((adx * bdytail + bdy * adxtail)
2770 - (ady * bdxtail + bdx * adytail))
2771 + 2.0 * (cdx * cdxtail + cdy * cdytail) * (adx * bdy - ady * bdx));
2772 if ((det >= errbound) || (-det >= errbound)) {
2779 if ((bdxtail != 0.0) || (bdytail != 0.0)
2780 || (cdxtail != 0.0) || (cdytail != 0.0)) {
2781 Square(adx, adxadx1, adxadx0);
2782 Square(ady, adyady1, adyady0);
2783 Two_Two_Sum(adxadx1, adxadx0, adyady1, adyady0, aa3, aa[2], aa[1], aa[0]);
2786 if ((cdxtail != 0.0) || (cdytail != 0.0)
2787 || (adxtail != 0.0) || (adytail != 0.0)) {
2788 Square(bdx, bdxbdx1, bdxbdx0);
2789 Square(bdy, bdybdy1, bdybdy0);
2790 Two_Two_Sum(bdxbdx1, bdxbdx0, bdybdy1, bdybdy0, bb3, bb[2], bb[1], bb[0]);
2793 if ((adxtail != 0.0) || (adytail != 0.0)
2794 || (bdxtail != 0.0) || (bdytail != 0.0)) {
2795 Square(cdx, cdxcdx1, cdxcdx0);
2796 Square(cdy, cdycdy1, cdycdy0);
2797 Two_Two_Sum(cdxcdx1, cdxcdx0, cdycdy1, cdycdy0, cc3, cc[2], cc[1], cc[0]);
2801 if (adxtail != 0.0) {
2813 temp16blen, temp16b, temp32a);
2815 temp32alen, temp32a, temp48);
2822 if (adytail != 0.0) {
2834 temp16blen, temp16b, temp32a);
2836 temp32alen, temp32a, temp48);
2843 if (bdxtail != 0.0) {
2855 temp16blen, temp16b, temp32a);
2857 temp32alen, temp32a, temp48);
2864 if (bdytail != 0.0) {
2876 temp16blen, temp16b, temp32a);
2878 temp32alen, temp32a, temp48);
2885 if (cdxtail != 0.0) {
2897 temp16blen, temp16b, temp32a);
2899 temp32alen, temp32a, temp48);
2906 if (cdytail != 0.0) {
2918 temp16blen, temp16b, temp32a);
2920 temp32alen, temp32a, temp48);
2928 if ((adxtail != 0.0) || (adytail != 0.0)) {
2929 if ((bdxtail != 0.0) || (bdytail != 0.0)
2930 || (cdxtail != 0.0) || (cdytail != 0.0)) {
2933 Two_Two_Sum(ti1, ti0, tj1, tj0, u3, u[2], u[1], u[0]);
2939 Two_Two_Sum(ti1, ti0, tj1, tj0, v3, v[2], v[1], v[0]);
2945 Two_Two_Diff(ti1, ti0, tj1, tj0, bctt3, bctt[2], bctt[1], bctt[0]);
2955 if (adxtail != 0.0) {
2961 temp32alen, temp32a, temp48);
2967 if (bdytail != 0.0) {
2977 if (cdytail != 0.0) {
2996 temp16blen, temp16b, temp32b);
2998 temp32blen, temp32b, temp64);
3005 if (adytail != 0.0) {
3011 temp32alen, temp32a, temp48);
3027 temp16blen, temp16b, temp32b);
3029 temp32blen, temp32b, temp64);
3037 if ((bdxtail != 0.0) || (bdytail != 0.0)) {
3038 if ((cdxtail != 0.0) || (cdytail != 0.0)
3039 || (adxtail != 0.0) || (adytail != 0.0)) {
3042 Two_Two_Sum(ti1, ti0, tj1, tj0, u3, u[2], u[1], u[0]);
3048 Two_Two_Sum(ti1, ti0, tj1, tj0, v3, v[2], v[1], v[0]);
3054 Two_Two_Diff(ti1, ti0, tj1, tj0, catt3, catt[2], catt[1], catt[0]);
3064 if (bdxtail != 0.0) {
3070 temp32alen, temp32a, temp48);
3076 if (cdytail != 0.0) {
3086 if (adytail != 0.0) {
3105 temp16blen, temp16b, temp32b);
3107 temp32blen, temp32b, temp64);
3114 if (bdytail != 0.0) {
3120 temp32alen, temp32a, temp48);
3136 temp16blen, temp16b, temp32b);
3138 temp32blen, temp32b, temp64);
3146 if ((cdxtail != 0.0) || (cdytail != 0.0)) {
3147 if ((adxtail != 0.0) || (adytail != 0.0)
3148 || (bdxtail != 0.0) || (bdytail != 0.0)) {
3151 Two_Two_Sum(ti1, ti0, tj1, tj0, u3, u[2], u[1], u[0]);
3157 Two_Two_Sum(ti1, ti0, tj1, tj0, v3, v[2], v[1], v[0]);
3163 Two_Two_Diff(ti1, ti0, tj1, tj0, abtt3, abtt[2], abtt[1], abtt[0]);
3173 if (cdxtail != 0.0) {
3179 temp32alen, temp32a, temp48);
3185 if (adytail != 0.0) {
3195 if (bdytail != 0.0) {
3214 temp16blen, temp16b, temp32b);
3216 temp32blen, temp32b, temp64);
3223 if (cdytail != 0.0) {
3229 temp32alen, temp32a, temp48);
3245 temp16blen, temp16b, temp32b);
3247 temp32blen, temp32b, temp64);
3256 return finnow[finlength - 1];
3261 REAL adx, bdx, cdx, ady, bdy, cdy;
3262 REAL bdxcdy, cdxbdy, cdxady, adxcdy, adxbdy, bdxady;
3263 REAL alift, blift, clift;
3265 REAL permanent, errbound;
3267 adx = pa[0] - pd[0];
3268 bdx = pb[0] - pd[0];
3269 cdx = pc[0] - pd[0];
3270 ady = pa[1] - pd[1];
3271 bdy = pb[1] - pd[1];
3272 cdy = pc[1] - pd[1];
3276 alift = adx * adx + ady * ady;
3280 blift = bdx * bdx + bdy * bdy;
3284 clift = cdx * cdx + cdy * cdy;
3286 det = alift * (bdxcdy - cdxbdy)
3287 + blift * (cdxady - adxcdy)
3288 + clift * (adxbdy - bdxady);
3294 if ((det > errbound) || (-det > errbound)) {
3330 REAL aex, bex, cex, dex;
3331 REAL aey, bey, cey, dey;
3332 REAL aez, bez, cez, dez;
3333 REAL alift, blift, clift, dlift;
3334 REAL ab, bc, cd, da, ac, bd;
3335 REAL abc, bcd, cda, dab;
3337 aex = pa[0] - pe[0];
3338 bex = pb[0] - pe[0];
3339 cex = pc[0] - pe[0];
3340 dex = pd[0] - pe[0];
3341 aey = pa[1] - pe[1];
3342 bey = pb[1] - pe[1];
3343 cey = pc[1] - pe[1];
3344 dey = pd[1] - pe[1];
3345 aez = pa[2] - pe[2];
3346 bez = pb[2] - pe[2];
3347 cez = pc[2] - pe[2];
3348 dez = pd[2] - pe[2];
3350 ab = aex * bey - bex * aey;
3351 bc = bex * cey - cex * bey;
3352 cd = cex * dey - dex * cey;
3353 da = dex * aey - aex * dey;
3355 ac = aex * cey - cex * aey;
3356 bd = bex * dey - dex * bey;
3358 abc = aez * bc - bez * ac + cez * ab;
3359 bcd = bez * cd - cez * bd + dez * bc;
3360 cda = cez * da + dez * ac + aez * cd;
3361 dab = dez * ab + aez * bd + bez * da;
3363 alift = aex * aex + aey * aey + aez * aez;
3364 blift = bex * bex + bey * bey + bez * bez;
3365 clift = cex * cex + cey * cey + cez * cez;
3366 dlift = dex * dex + dey * dey + dez * dez;
3368 return (dlift * abc - clift * dab) + (blift * cda - alift * bcd);
3377 REAL axby0, bxcy0, cxdy0, dxey0, exay0;
3378 REAL bxay0, cxby0, dxcy0, exdy0, axey0;
3379 REAL axcy0, bxdy0, cxey0, dxay0, exby0;
3380 REAL cxay0, dxby0, excy0, axdy0, bxey0;
3381 REAL ab[4], bc[4], cd[4], de[4], ea[4];
3382 REAL ac[4], bd[4], ce[4], da[4], eb[4];
3383 REAL temp8a[8], temp8b[8], temp16[16];
3384 int temp8alen, temp8blen, temp16len;
3385 REAL abc[24], bcd[24], cde[24], dea[24], eab[24];
3386 REAL abd[24], bce[24], cda[24], deb[24], eac[24];
3387 int abclen, bcdlen, cdelen, dealen, eablen;
3388 int abdlen, bcelen, cdalen, deblen, eaclen;
3389 REAL temp48a[48], temp48b[48];
3390 int temp48alen, temp48blen;
3391 REAL abcd[96], bcde[96], cdea[96], deab[96], eabc[96];
3392 int abcdlen, bcdelen, cdealen, deablen, eabclen;
3394 REAL det384x[384], det384y[384], det384z[384];
3395 int xlen, ylen, zlen;
3398 REAL adet[1152], bdet[1152], cdet[1152], ddet[1152], edet[1152];
3399 int alen, blen, clen, dlen, elen;
3400 REAL abdet[2304], cddet[2304], cdedet[3456];
3407 REAL avirt, bround, around;
3410 REAL ahi, alo, bhi, blo;
3411 REAL err1, err2, err3;
3417 Two_Two_Diff(axby1, axby0, bxay1, bxay0, ab[3], ab[2], ab[1], ab[0]);
3421 Two_Two_Diff(bxcy1, bxcy0, cxby1, cxby0, bc[3], bc[2], bc[1], bc[0]);
3425 Two_Two_Diff(cxdy1, cxdy0, dxcy1, dxcy0, cd[3], cd[2], cd[1], cd[0]);
3429 Two_Two_Diff(dxey1, dxey0, exdy1, exdy0, de[3], de[2], de[1], de[0]);
3433 Two_Two_Diff(exay1, exay0, axey1, axey0, ea[3], ea[2], ea[1], ea[0]);
3437 Two_Two_Diff(axcy1, axcy0, cxay1, cxay0, ac[3], ac[2], ac[1], ac[0]);
3441 Two_Two_Diff(bxdy1, bxdy0, dxby1, dxby0, bd[3], bd[2], bd[1], bd[0]);
3445 Two_Two_Diff(cxey1, cxey0, excy1, excy0, ce[3], ce[2], ce[1], ce[0]);
3449 Two_Two_Diff(dxay1, dxay0, axdy1, axdy0, da[3], da[2], da[1], da[0]);
3453 Two_Two_Diff(exby1, exby0, bxey1, bxey0, eb[3], eb[2], eb[1], eb[0]);
3537 for (i = 0; i < temp48blen; i++) {
3538 temp48b[i] = -temp48b[i];
3541 temp48blen, temp48b, bcde);
3553 for (i = 0; i < temp48blen; i++) {
3554 temp48b[i] = -temp48b[i];
3557 temp48blen, temp48b, cdea);
3569 for (i = 0; i < temp48blen; i++) {
3570 temp48b[i] = -temp48b[i];
3573 temp48blen, temp48b, deab);
3585 for (i = 0; i < temp48blen; i++) {
3586 temp48b[i] = -temp48b[i];
3589 temp48blen, temp48b, eabc);
3601 for (i = 0; i < temp48blen; i++) {
3602 temp48b[i] = -temp48b[i];
3605 temp48blen, temp48b, abcd);
3620 return deter[deterlen - 1];
3625 INEXACT REAL aex, bex, cex, dex, aey, bey, cey, dey, aez, bez, cez, dez;
3626 REAL aextail, bextail, cextail, dextail;
3627 REAL aeytail, beytail, ceytail, deytail;
3628 REAL aeztail, beztail, ceztail, deztail;
3629 REAL negate, negatetail;
3630 INEXACT REAL axby7, bxcy7, cxdy7, dxay7, axcy7, bxdy7;
3631 INEXACT REAL bxay7, cxby7, dxcy7, axdy7, cxay7, dxby7;
3632 REAL axby[8], bxcy[8], cxdy[8], dxay[8], axcy[8], bxdy[8];
3633 REAL bxay[8], cxby[8], dxcy[8], axdy[8], cxay[8], dxby[8];
3634 REAL ab[16], bc[16], cd[16], da[16], ac[16], bd[16];
3635 int ablen, bclen, cdlen, dalen, aclen, bdlen;
3636 REAL temp32a[32], temp32b[32], temp64a[64], temp64b[64], temp64c[64];
3637 int temp32alen, temp32blen, temp64alen, temp64blen, temp64clen;
3638 REAL temp128[128], temp192[192];
3639 int temp128len, temp192len;
3640 REAL detx[384], detxx[768], detxt[384], detxxt[768], detxtxt[768];
3641 int xlen, xxlen, xtlen, xxtlen, xtxtlen;
3642 REAL x1[1536], x2[2304];
3644 REAL dety[384], detyy[768], detyt[384], detyyt[768], detytyt[768];
3645 int ylen, yylen, ytlen, yytlen, ytytlen;
3646 REAL y1[1536], y2[2304];
3648 REAL detz[384], detzz[768], detzt[384], detzzt[768], detztzt[768];
3649 int zlen, zzlen, ztlen, zztlen, ztztlen;
3650 REAL z1[1536], z2[2304];
3654 REAL adet[6912], bdet[6912], cdet[6912], ddet[6912];
3655 int alen, blen, clen, dlen;
3656 REAL abdet[13824], cddet[13824], deter[27648];
3661 REAL avirt, bround, around;
3664 REAL a0hi, a0lo, a1hi, a1lo, bhi, blo;
3665 REAL err1, err2, err3;
3669 Two_Diff(pa[0], pe[0], aex, aextail);
3670 Two_Diff(pa[1], pe[1], aey, aeytail);
3671 Two_Diff(pa[2], pe[2], aez, aeztail);
3672 Two_Diff(pb[0], pe[0], bex, bextail);
3673 Two_Diff(pb[1], pe[1], bey, beytail);
3674 Two_Diff(pb[2], pe[2], bez, beztail);
3675 Two_Diff(pc[0], pe[0], cex, cextail);
3676 Two_Diff(pc[1], pe[1], cey, ceytail);
3677 Two_Diff(pc[2], pe[2], cez, ceztail);
3678 Two_Diff(pd[0], pe[0], dex, dextail);
3679 Two_Diff(pd[1], pe[1], dey, deytail);
3680 Two_Diff(pd[2], pe[2], dez, deztail);
3683 axby7, axby[6], axby[5], axby[4],
3684 axby[3], axby[2], axby[1], axby[0]);
3687 negatetail = -aeytail;
3689 bxay7, bxay[6], bxay[5], bxay[4],
3690 bxay[3], bxay[2], bxay[1], bxay[0]);
3694 bxcy7, bxcy[6], bxcy[5], bxcy[4],
3695 bxcy[3], bxcy[2], bxcy[1], bxcy[0]);
3698 negatetail = -beytail;
3700 cxby7, cxby[6], cxby[5], cxby[4],
3701 cxby[3], cxby[2], cxby[1], cxby[0]);
3705 cxdy7, cxdy[6], cxdy[5], cxdy[4],
3706 cxdy[3], cxdy[2], cxdy[1], cxdy[0]);
3709 negatetail = -ceytail;
3711 dxcy7, dxcy[6], dxcy[5], dxcy[4],
3712 dxcy[3], dxcy[2], dxcy[1], dxcy[0]);
3716 dxay7, dxay[6], dxay[5], dxay[4],
3717 dxay[3], dxay[2], dxay[1], dxay[0]);
3720 negatetail = -deytail;
3722 axdy7, axdy[6], axdy[5], axdy[4],
3723 axdy[3], axdy[2], axdy[1], axdy[0]);
3727 axcy7, axcy[6], axcy[5], axcy[4],
3728 axcy[3], axcy[2], axcy[1], axcy[0]);
3731 negatetail = -aeytail;
3733 cxay7, cxay[6], cxay[5], cxay[4],
3734 cxay[3], cxay[2], cxay[1], cxay[0]);
3738 bxdy7, bxdy[6], bxdy[5], bxdy[4],
3739 bxdy[3], bxdy[2], bxdy[1], bxdy[0]);
3742 negatetail = -beytail;
3744 dxby7, dxby[6], dxby[5], dxby[4],
3745 dxby[3], dxby[2], dxby[1], dxby[0]);
3752 temp32blen, temp32b, temp64a);
3756 temp32blen, temp32b, temp64b);
3760 temp32blen, temp32b, temp64c);
3762 temp64blen, temp64b, temp128);
3764 temp128len, temp128, temp192);
3769 for (i = 0; i < xxtlen; i++) {
3779 for (i = 0; i < yytlen; i++) {
3789 for (i = 0; i < zztlen; i++) {
3801 temp32blen, temp32b, temp64a);
3805 temp32blen, temp32b, temp64b);
3809 temp32blen, temp32b, temp64c);
3811 temp64blen, temp64b, temp128);
3813 temp128len, temp128, temp192);
3818 for (i = 0; i < xxtlen; i++) {
3828 for (i = 0; i < yytlen; i++) {
3838 for (i = 0; i < zztlen; i++) {
3850 temp32blen, temp32b, temp64a);
3854 temp32blen, temp32b, temp64b);
3858 temp32blen, temp32b, temp64c);
3860 temp64blen, temp64b, temp128);
3862 temp128len, temp128, temp192);
3867 for (i = 0; i < xxtlen; i++) {
3877 for (i = 0; i < yytlen; i++) {
3887 for (i = 0; i < zztlen; i++) {
3899 temp32blen, temp32b, temp64a);
3903 temp32blen, temp32b, temp64b);
3907 temp32blen, temp32b, temp64c);
3909 temp64blen, temp64b, temp128);
3911 temp128len, temp128, temp192);
3916 for (i = 0; i < xxtlen; i++) {
3926 for (i = 0; i < yytlen; i++) {
3936 for (i = 0; i < zztlen; i++) {
3949 return deter[deterlen - 1];
3955 INEXACT REAL aex, bex, cex, dex, aey, bey, cey, dey, aez, bez, cez, dez;
3961 REAL aexbey0, bexaey0, bexcey0, cexbey0;
3962 REAL cexdey0, dexcey0, dexaey0, aexdey0;
3963 REAL aexcey0, cexaey0, bexdey0, dexbey0;
3964 REAL ab[4], bc[4], cd[4], da[4], ac[4], bd[4];
3966 REAL abeps, bceps, cdeps, daeps, aceps, bdeps;
3967 REAL temp8a[8], temp8b[8], temp8c[8], temp16[16], temp24[24], temp48[48];
3968 int temp8alen, temp8blen, temp8clen, temp16len, temp24len, temp48len;
3969 REAL xdet[96], ydet[96], zdet[96], xydet[192];
3970 int xlen, ylen, zlen, xylen;
3971 REAL adet[288], bdet[288], cdet[288], ddet[288];
3972 int alen, blen, clen, dlen;
3973 REAL abdet[576], cddet[576];
3978 REAL aextail, bextail, cextail, dextail;
3979 REAL aeytail, beytail, ceytail, deytail;
3980 REAL aeztail, beztail, ceztail, deztail;
3983 REAL avirt, bround, around;
3986 REAL ahi, alo, bhi, blo;
3987 REAL err1, err2, err3;
3991 aex = (
REAL) (pa[0] - pe[0]);
3992 bex = (
REAL) (pb[0] - pe[0]);
3993 cex = (
REAL) (pc[0] - pe[0]);
3994 dex = (
REAL) (pd[0] - pe[0]);
3995 aey = (
REAL) (pa[1] - pe[1]);
3996 bey = (
REAL) (pb[1] - pe[1]);
3997 cey = (
REAL) (pc[1] - pe[1]);
3998 dey = (
REAL) (pd[1] - pe[1]);
3999 aez = (
REAL) (pa[2] - pe[2]);
4000 bez = (
REAL) (pb[2] - pe[2]);
4001 cez = (
REAL) (pc[2] - pe[2]);
4002 dez = (
REAL) (pd[2] - pe[2]);
4006 Two_Two_Diff(aexbey1, aexbey0, bexaey1, bexaey0, ab3, ab[2], ab[1], ab[0]);
4011 Two_Two_Diff(bexcey1, bexcey0, cexbey1, cexbey0, bc3, bc[2], bc[1], bc[0]);
4016 Two_Two_Diff(cexdey1, cexdey0, dexcey1, dexcey0, cd3, cd[2], cd[1], cd[0]);
4021 Two_Two_Diff(dexaey1, dexaey0, aexdey1, aexdey0, da3, da[2], da[1], da[0]);
4026 Two_Two_Diff(aexcey1, aexcey0, cexaey1, cexaey0, ac3, ac[2], ac[1], ac[0]);
4031 Two_Two_Diff(bexdey1, bexdey0, dexbey1, dexbey0, bd3, bd[2], bd[1], bd[0]);
4038 temp8blen, temp8b, temp16);
4040 temp16len, temp16, temp24);
4054 temp8blen, temp8b, temp16);
4056 temp16len, temp16, temp24);
4070 temp8blen, temp8b, temp16);
4072 temp16len, temp16, temp24);
4086 temp8blen, temp8b, temp16);
4088 temp16len, temp16, temp24);
4104 if ((det >= errbound) || (-det >= errbound)) {
4120 if ((aextail == 0.0) && (aeytail == 0.0) && (aeztail == 0.0)
4121 && (bextail == 0.0) && (beytail == 0.0) && (beztail == 0.0)
4122 && (cextail == 0.0) && (ceytail == 0.0) && (ceztail == 0.0)
4123 && (dextail == 0.0) && (deytail == 0.0) && (deztail == 0.0)) {
4128 abeps = (aex * beytail + bey * aextail)
4129 - (aey * bextail + bex * aeytail);
4130 bceps = (bex * ceytail + cey * bextail)
4131 - (bey * cextail + cex * beytail);
4132 cdeps = (cex * deytail + dey * cextail)
4133 - (cey * dextail + dex * ceytail);
4134 daeps = (dex * aeytail + aey * dextail)
4135 - (dey * aextail + aex * deytail);
4136 aceps = (aex * ceytail + cey * aextail)
4137 - (aey * cextail + cex * aeytail);
4138 bdeps = (bex * deytail + dey * bextail)
4139 - (bey * dextail + dex * beytail);
4140 det += (((bex * bex + bey * bey + bez * bez)
4141 * ((cez * daeps + dez * aceps + aez * cdeps)
4142 + (ceztail * da3 + deztail * ac3 + aeztail * cd3))
4143 + (dex * dex + dey * dey + dez * dez)
4144 * ((aez * bceps - bez * aceps + cez * abeps)
4145 + (aeztail * bc3 - beztail * ac3 + ceztail * ab3)))
4146 - ((aex * aex + aey * aey + aez * aez)
4147 * ((bez * cdeps - cez * bdeps + dez * bceps)
4148 + (beztail * cd3 - ceztail * bd3 + deztail * bc3))
4149 + (cex * cex + cey * cey + cez * cez)
4150 * ((dez * abeps + aez * bdeps + bez * daeps)
4151 + (deztail * ab3 + aeztail * bd3 + beztail * da3))))
4152 + 2.0 * (((bex * bextail + bey * beytail + bez * beztail)
4153 * (cez * da3 + dez * ac3 + aez * cd3)
4154 + (dex * dextail + dey * deytail + dez * deztail)
4155 * (aez * bc3 - bez * ac3 + cez * ab3))
4156 - ((aex * aextail + aey * aeytail + aez * aeztail)
4157 * (bez * cd3 - cez * bd3 + dez * bc3)
4158 + (cex * cextail + cey * ceytail + cez * ceztail)
4159 * (dez * ab3 + aez * bd3 + bez * da3)));
4160 if ((det >= errbound) || (-det >= errbound)) {
4169 REAL aex, bex, cex, dex;
4170 REAL aey, bey, cey, dey;
4171 REAL aez, bez, cez, dez;
4172 REAL aexbey, bexaey, bexcey, cexbey, cexdey, dexcey, dexaey, aexdey;
4173 REAL aexcey, cexaey, bexdey, dexbey;
4174 REAL alift, blift, clift, dlift;
4175 REAL ab, bc, cd, da, ac, bd;
4176 REAL abc, bcd, cda, dab;
4177 REAL aezplus, bezplus, cezplus, dezplus;
4178 REAL aexbeyplus, bexaeyplus, bexceyplus, cexbeyplus;
4179 REAL cexdeyplus, dexceyplus, dexaeyplus, aexdeyplus;
4180 REAL aexceyplus, cexaeyplus, bexdeyplus, dexbeyplus;
4182 REAL permanent, errbound;
4184 aex = pa[0] - pe[0];
4185 bex = pb[0] - pe[0];
4186 cex = pc[0] - pe[0];
4187 dex = pd[0] - pe[0];
4188 aey = pa[1] - pe[1];
4189 bey = pb[1] - pe[1];
4190 cey = pc[1] - pe[1];
4191 dey = pd[1] - pe[1];
4192 aez = pa[2] - pe[2];
4193 bez = pb[2] - pe[2];
4194 cez = pc[2] - pe[2];
4195 dez = pd[2] - pe[2];
4199 ab = aexbey - bexaey;
4202 bc = bexcey - cexbey;
4205 cd = cexdey - dexcey;
4208 da = dexaey - aexdey;
4212 ac = aexcey - cexaey;
4215 bd = bexdey - dexbey;
4217 abc = aez * bc - bez * ac + cez * ab;
4218 bcd = bez * cd - cez * bd + dez * bc;
4219 cda = cez * da + dez * ac + aez * cd;
4220 dab = dez * ab + aez * bd + bez * da;
4222 alift = aex * aex + aey * aey + aez * aez;
4223 blift = bex * bex + bey * bey + bez * bez;
4224 clift = cex * cex + cey * cey + cez * cez;
4225 dlift = dex * dex + dey * dey + dez * dez;
4227 det = (dlift * abc - clift * dab) + (blift * cda - alift * bcd);
4245 permanent = ((cexdeyplus + dexceyplus) * bezplus
4246 + (dexbeyplus + bexdeyplus) * cezplus
4247 + (bexceyplus + cexbeyplus) * dezplus)
4249 + ((dexaeyplus + aexdeyplus) * cezplus
4250 + (aexceyplus + cexaeyplus) * dezplus
4251 + (cexdeyplus + dexceyplus) * aezplus)
4253 + ((aexbeyplus + bexaeyplus) * dezplus
4254 + (bexdeyplus + dexbeyplus) * aezplus
4255 + (dexaeyplus + aexdeyplus) * bezplus)
4257 + ((bexceyplus + cexbeyplus) * aezplus
4258 + (cexaeyplus + aexceyplus) * bezplus
4259 + (aexbeyplus + bexaeyplus) * cezplus)
4262 if ((det > errbound) || (-det > errbound)) {