Blob Blame History Raw
#include <math.h>
#include <stdio.h>
#include <pixman.h>

/* This code is basically the output of Maxima translated into C.
 *
 * See http://maxima.sourceforge.net/
 */
static void
quad_to_quad (double x0, double y0,
	      double x1, double y1,
	      double x2, double y2,
	      double x3, double y3,

	      double px0, double py0,
	      double px1, double py1,
	      double px2, double py2,
	      double px3, double py3,

	      struct pixman_f_transform *trans)
{
    double
	t1, t2, t3, t4, t5, t6, t7, t8, t9, t10, t11, t12, t13, t14, t15, t16, t17, t18,
	t19, t20, t21, t22, t23, t24, t25, t26, t27, t28, t29, t30, t31, t32, t33, t34,
	t35, t36, t37, t38, t39, t40, t41, t42, t43, t44, t45, t46, t47, t48, t49, t50,
	t51, t52, t53, t54, t55, t56, t57, t58, t59, t60, t61, t62, t63, t64, t65, t66,
	t67, t68, t69, t70, t71, t72, t73, t74, t75, t76, t77, t78, t79, t80, t81, t82,
	t83, t84, t85, t86, t87, t88, t89, t90, t91, t92, t93, t94, t95, t96, t97, t98,
	t99, t100, t101, t102, t103, t104, t105, t106, t107, t108, t109, t110, t111,
	t112, t113, t114, t115, t116, t117, t118, t119, t120, t121, t122, t123,
	t124, t125, t126, t127, t128, t129, t130, t131, t132, t133, t134, t135,
	t136, t137, t138, t139, t140, t141, t142, t143, t144, t145, t146, t147,
	t148, t149, t150, t151, t152, t153, t154, t155, t156, t157, t158, t159,
	t160, t161, t162, t163, t164, t165, t166, t167, t168, t169, t170, t171,
	t172, t173, t174, t175, t176, t177, t178, t179, t180, t181, t182, t183,
	t184, t185, t186, t187, t188, t189, t190, t191, t192, t193, t194, t195,
	t196, t197, t198, t199, t200, t201, t202, t203, t204, t205, t206, t207,
	t208, t209, t210, t211, t212, t213, t214, t215, t216, t217, t218, t219,
	t220, t221, t222, t223, t224, t225, t226, t227, t228, t229, t230, t231,
	t232, t233, t234, t235, t236, t237, t238, t239, t240, t241, t242, t243,
	t244, t245, t246, t247, t248, t249, t250, t251, t252, t253, t254, t255,
	t256, t257, t258, t259, t260, t261, t262, t263, t264, t265, t266, t267,
	t268, t269, t270, t271, t272, t273, t274, t275, t276, t277, t278, t279,
	t280, t281, t282, t283, t284, t285, t286, t287, t288, t289, t290, t291,
	t292, t293, t294, t295, t296, t297, t298, t299, t300, t301, t302, t303,
	t304, t305, t306, t307, t308, t309, t310, t311, t312, t313, t314, t315,
	t316, t317, t318, t319, t320, t321, t322, t323, t324, t325, t326, t327,
	t328, t329, t330, t331, t332, t333, t334, t335, t336, t337, t338, t339,
	t340, t341, t342, t343, t344, t345, t346, t347, t348, t349, t350, t351,
	t352, t353, t354, t355, t356, t357, t358, t359, t360, t361, t362, t363,
	t364, t365, t366, t367, t368, t369, t370, t371, t372, t373, t374, t375,
	t376, t377, t378, t379, t380, t381, t382, t383, t384, t385, t386, t387,
	t388, t389, t390, t391, t392, t393, t394, t395, t396, t397, t398, t399,
	t400, t401, t402, t403, t404, t405, t406, t407, t408, t409, t410, t411,
	t412, t413, t414, t415, t416, t417, t418, t419, t420, t421, t422, t423,
	t424, t425, t426, t427, t428, t429, t430, t431, t432, t433, t434, t435,
	t436, t437, t438, t439, t440, t441, t442, t443, t444, t445, t446, t447,
	t448, t449, t450, t451, t452, t453, t454, t455, t456, t457, t458, t459,
	t460, t461, t462, t463, t464, t465, t466, t467, t468, t469, t470, t471,
	t472, t473, t474, t475, t476, t477, t478, t479, t480, t481, t482, t483,
	t484, t485, t486, t487, t488, t489, t490, t491, t492, t493, t494, t495,
	t496, t497, t498, t499, t500, t501, t502, t503, t504, t505, t506, t507,
	t508, t509, t510, t511, t512, t513, t514, t515, t516, t517, t518, t519,
	t520, t521, t522, t523, t524, t525, t526, t527, t528, t529, t530, t531,
	t532, t533, t534, t535, t536, t537, t538, t539, t540, t541, t542, t543,
	t544, t545, t546, t547, t548, t549, t550, t551, t552, t553, t554, t555,
	t556, t557, t558, t559, t560, t561, t562, t563, t564, t565, t566, t567,
	t568, t569, t570, t571, t572, t573, t574, t575, t576, t577, t578, t579,
	t580, t581, t582, t583, t584, t585, t586, t587, t588, t589, t590, t591,
	t592, t593, t594, t595, t596, t597, t598, t599, t600, t601, t602, t603,
	t604, t605, t606, t607, t608, t609, t610, t611, t612, t613, t614, t615,
	t616, t617, t618, t619, t620, t621, t622, t623, t624, t625, t626, t627,
	t628, t629, t630, t631, t632, t633, t634, t635, t636, t637, t638, t639,
	t640, t641, t642, t643, t644, t645, t646, t647, t648, t649, t650, t651,
	t652, t653, t654, t655, t656, t657, t658, t659, t660, t661, t662, t663,
	t664, t665, t666, t667, t668, t669, t670, t671, t672, t673, t674, t675,
	t676, t677, t678, t679, t680, t681, t682, t683, t684, t685, t686, t687,
	t688, t689, t690, t691, t692, t693, t694, t695, t696, t697, t698, t699,
	t700, t701, t702, t703, t704, t705, t706, t707, t708, t709, t710, t711,
	t712, t713, t714, t715, t716, t717, t718, t719, t720, t721, t722, t723,
	t724, t725, t726, t727, t728, t729, t730, t731, t732, t733, t734, t735,
	t736, t737, t738, t739, t740, t741, t742, t743, t744, t745, t746, t747,
	t748, t749, t750, t751, t752, t753, t754, t755, t756, t757, t758, t759,
	t760, t761, t762, t763, t764, t765, t766, t767, t768, t769, t770, t771,
	t772, t773, t774, t775, t776, t777, t778, t779, t780, t781, t782, t783,
	t784, t785, t786, t787, t788, t789, t790, t791, t792, t793, t794, t795,
	t796, t797, t798, t799, t800, t801, t802, t803, t804, t805, t806, t807,
	t808, t809, t810, t811, t812, t813, t814, t815, t816, t817, t818, t819,
	t820, t821, t822, t823, t824, t825, t826, t827, t828, t829, t830, t831,
	t832, t833, t834, t835, t836, t837, t838, t839, t840, t841, t842, t843,
	t844, t845, t846, t847, t848, t849, t850, t851, t852, t853, t854, t855,
	t856, t857, t858, t859, t860, t861, t862, t863, t864, t865, t866, t867,
	t868, t869, t870, t871, t872, t873, t874, t875, t876, t877, t878, t879,
	t880, t881, t882, t883, t884, t885, t886, t887, t888, t889, t890, t891,
	t892, t893, t894, t895, t896, t897, t898, t899, t900, t901, t902, t903,
	t904, t905, t906, t907, t908, t909, t910, t911, t912, t913, t914, t915,
	t916, t917, t918, t919, t920, t921, t922, t923, t924, t925, t926, t927,
	t928, t929, t930, t931, t932, t933, t934, t935, t936, t937, t938, t939,
	t940, t941, t942, t943, t944, t945, t946, t947, t948, t949, t950, t951,
	t952, t953, t954, t955, t956, t957, t958, t959, t960, t961, t962, t963,
	t964, t965, t966, t967, t968, t969, t970, t971, t972, t973, t974, t975,
	t976, t977, t978, t979, t980, t981, t982, t983, t984, t985, t986, t987,
	t988, t989, t990, t991, t992, t993, t994, t995, t996, t997, t998, t999,
	t1000, t1001, t1002, t1003, t1004, t1005, t1006, t1007, t1008, t1009,
	t1010, t1011, t1012, t1013, t1014, t1015, t1016, t1017, t1018, t1019,
	t1020, t1021, t1022, t1023, t1024, t1025, t1026, t1027, t1028, t1029,
	t1030, t1031, t1032, t1033, t1034, t1035, t1036, t1037, t1038, t1039,
	t1040, t1041, t1042, t1043, t1044, t1045, t1046, t1047, t1048, t1049,
	t1050, t1051, t1052, t1053, t1054, t1055, t1056, t1057, t1058, t1059,
	t1060, t1061, t1062, t1063, t1064, t1065, t1066, t1067, t1068, t1069,
	t1070, t1071, t1072, t1073;

    t1 = y1 * y1;
    t2 = x3 * x3;
    t3 = px2 * px3 * t2;
    t4 = (t3 - px2 * px3 * x2 * x3) * y2;
    t5 = x2 * x2;
    t6 = px2 * px3 * t5 * y3;

    t7 = - px2 * px3 * x2 * x3 * y3;
    t8 = py1 * (t7 + t6 + t4);
    t9 = px3 * py2 * x2 * x3;

    t10 = - px3 * py2 * t2;
    t11 = (t10 + t9) * y2;
    t12 = - px2 * py3 * t5 * y3;

    t13 = px2 * py3 * x2 * x3 * y3;
    t14 = y0 * y0;
    t15 = - px3 * py2;
    t16 = px2 * py3;

    t17 = t16 + t15;
    t18 = t17 * x2;
    t19 = px3 * py2 * x3;
    t20 = - px2 * py3 * x3;

    t21 = t20 + t19 + t18;
    t22 = px2 * px3 * t5;
    t23 = - 2 * px2 * px3 * x2 * x3;

    t24 = py1 * (t3 + t23 + t22);
    t25 = - px2 * py3 * t5;
    t26 = px2 * py3 * x3;

    t27 = x2 * (t26 + t19);
    t28 = t10 + t27 + t25;
    t29 = x1 * x1;
    t30 = px3 * py2;

    t31 = - px2 * py3;
    t32 = t31 + t30;
    t33 = t32 * y2;
    t34 = - px3 * py2 * y3;

    t35 = px2 * py3 * y3;
    t36 = t35 + t34 + t33;
    t37 = - px2 * px3 * t2;

    t38 = (t37 + px2 * px3 * x2 * x3) * y2;
    t39 = - px2 * px3 * t5 * y3;

    t40 = px2 * px3 * x2 * x3 * y3;
    t41 = py1 * (t40 + t39 + t38);
    t42 = - px2 * py3 * x2 * x3;

    t43 = px3 * py2 * t2;
    t44 = (t43 + t42) * y2;
    t45 = px2 * py3 * t5 * y3;

    t46 = - px3 * py2 * x2 * x3 * y3;
    t47 = (px2 * px3 * x3 - px2 * px3 * x2) * y2;

    t48 = px2 * px3 * x2 * y3;
    t49 = - px2 * px3 * x3 * y3;
    t50 = py1 * (t49 + t48 + t47);

    t51 = px2 * py3 * x2;
    t52 = - 2 * px3 * py2 * x3;
    t53 = (t26 + t52 + t51) * y2;

    t54 = px3 * py2 * x3 * y3;
    t55 = px3 * py2 * y3;
    t56 = - 2 * px2 * py3 * y3;
    t57 = t56 + t55;

    t58 = x2 * t57;
    t59 = - px2 * px3 * t5;
    t60 = 2 * px2 * px3 * x2 * x3;
    t61 = - px2;

    t62 = px3 + t61;
    t63 = t62 * x2;
    t64 = px2 * x3;
    t65 = - px3 * x3;
    t66 = t65 + t64 + t63;

    t67 = px2 * t5;
    t68 = - px2 * x3;
    t69 = x2 * (t65 + t68);
    t70 = px3 * t2;

    t71 = t70 + t69 + t67;
    t72 = - px3;
    t73 = t72 + px2;
    t74 = - px2 * y3;
    t75 = px3 * y3;

    t76 = t75 + t74 + t73 * y2;
    t77 = px2 * x2 * x3;
    t78 = - px3 * t2;
    t79 = - px2 * t5 * y3;

    t80 = px3 * x2 * x3 * y3;
    t81 = t80 + t79 + (t78 + t77) * y2;

    t82 = (px2 * px3 * x2 - px2 * px3 * x3) * y2;
    t83 = - px2 * px3 * x2 * y3;

    t84 = px2 * px3 * x3 * y3;
    t85 = - px2 * x2;
    t86 = 2 * px3 * x3;
    t87 = - px3 * x3 * y3;

    t88 = 2 * px2 * y3;
    t89 = - px3 * y3;
    t90 = t89 + t88;
    t91 = x2 * t90;

    t92 = t91 + t87 + (t86 + t68 + t85) * y2;
    t93 = px2 * py3 * t5;
    t94 = - px3 * py2 * x3;

    t95 = x2 * (t20 + t94);
    t96 = t32 * x2;
    t97 = t73 * x2;
    t98 = px3 * x3;

    t99 = t98 + t68 + t97;
    t100 = py1 * t99;
    t101 = - px2 * t5;
    t102 = x2 * (t98 + t64);

    t103 = t78 + t102 + t101;
    t104 = py1 * t103;
    t105 = - py2;
    t106 = py3 + t105;

    t107 = py2 * y3;
    t108 = - py3 * y3;
    t109 = t108 + t107 + t106 * y2;
    t110 = - px3 * x2 * x3;

    t111 = px2 * t5 * y3;
    t112 = - px2 * x2 * x3 * y3;
    t113 = t112 + t111 + (t70 + t110) * y2;

    t114 = - py2 * x3;
    t115 = py3 * x3;
    t116 = t115 + t114;
    t117 = py2 * x3 * y3;

    t118 = - py3 * x3 * y3;
    t119 = t118 + t117;
    t120 = x2 * t119;

    t121 = px1 * (t120 + x2 * t116 * y2);
    t122 = - px3 * py2 * x2;
    t123 = (t19 + t122) * y2;

    t124 = px2 * py3 * x2 * y3;
    t125 = - px2 * py3 * x3 * y3;
    t126 = px3 * x2;

    t127 = - px2 * x2 * y3;
    t128 = px2 * x3 * y3;
    t129 = t128 + t127 + (t65 + t126) * y2;

    t130 = - py3;
    t131 = t130 + py2;
    t132 = t131 * x2;
    t133 = py2 * x3;
    t134 = - py3 * x3;

    t135 = - py2 * x3 * y3;
    t136 = py3 * x3 * y3;
    t137 = - py2 * y3;
    t138 = py3 * y3;

    t139 = t138 + t137;
    t140 = x2 * t139;

    t141 = px1 * (t140 + t136 + t135 + (t134 + t133 + t132) * y2);
    t142 = y2 * y2;

    t143 = - px3 * py2 * x3 * y3;
    t144 = px2 * py3 * x3 * y3;
    t145 = t144 + t143;

    t146 = t142 * t145;
    t147 = y3 * y3;
    t148 = px3 * py2 * t147;
    t149 = - px2 * py3 * t147;

    t150 = t149 + t148;
    t151 = x2 * y2 * t150;
    t152 = t151 + t146;
    t153 = - px2 * py3 * y3;

    t154 = t153 + t55;
    t155 = t142 * t154;
    t156 = - px3 * py2 * t147;

    t157 = px2 * py3 * t147;
    t158 = t157 + t156;
    t159 = y2 * t158;
    t160 = t159 + t155;

    t161 = x0 * x0;
    t162 = py1 * t76;
    t163 = px1 * t109;
    t164 = px2 * y3;
    t165 = t89 + t164;

    t166 = - px2 * t147;
    t167 = px3 * t147;
    t168 = t167 + t166;

    t169 = y2 * t168 + t142 * t165;
    t170 = py1 * t169;
    t171 = py2 * t147;

    t172 = - py3 * t147;
    t173 = t172 + t171;
    t174 = y2 * t173 + t142 * t139;

    t175 = px1 * t174;
    t176 = t17 * t142;
    t177 = px2 * t147;
    t178 = - px3 * t147;

    t179 = t178 + t177 + t62 * t142;
    t180 = - py2 * t147;
    t181 = py3 * t147;

    t182 = t181 + t180 + t131 * t142;

    t183 = y1 * (px1 * t182 + py1 * t179 + t149 + t148 + t176)
	+ t175 + t170 + t159 + t1 * (t163 + t162 + t35 + t34 + t33) + t155;

    t184 = - px2 * px3 * t2 * t142;
    t185 = 2 * px2 * px3 * x2 * x3 * y2 * y3;

    t186 = - px2 * px3 * t5 * t147;
    t187 = py1 * (t186 + t185 + t184);

    t188 = px3 * py2 * t2 * t142;
    t189 = x2 * y2 * (t125 + t143);
    t190 = px2 * py3 * t5 * t147;

    t191 = t190 + t189 + t188;
    t192 = px2 * px3 * x3 * t142;
    t193 = y2 * (t49 + t83);

    t194 = px2 * px3 * x2 * t147;
    t195 = py1 * (t194 + t193 + t192);

    t196 = - px3 * py2 * x3 * t142;
    t197 = 2 * px3 * py2 * x3 * y3;
    t198 = 2 * px2 * py3 * y3;

    t199 = t198 + t34;
    t200 = x2 * t199;
    t201 = y2 * (t200 + t125 + t197);

    t202 = - px2 * py3 * x2 * t147;
    t203 = - px2 * x3 * y3;
    t204 = px3 * x3 * y3;

    t205 = t204 + t203;
    t206 = t142 * t205;
    t207 = t178 + t177;
    t208 = x2 * y2 * t207;

    t209 = t208 + t206;
    t210 = px2 * px3 * t2 * t142;
    t211 = - 2 * px2 * px3 * x2 * x3 * y2 * y3;

    t212 = px2 * px3 * t5 * t147;
    t213 = - px3 * t2 * t142;
    t214 = x2 * y2 * (t204 + t128);

    t215 = - px2 * t5 * t147;
    t216 = t215 + t214 + t213;
    t217 = - px2 * px3 * x3 * t142;

    t218 = y2 * (t84 + t48);
    t219 = - px2 * px3 * x2 * t147;
    t220 = px3 * x3 * t142;

    t221 = - 2 * px3 * x3 * y3;
    t222 = - 2 * px2 * y3;
    t223 = t75 + t222;
    t224 = x2 * t223;

    t225 = y2 * (t224 + t221 + t128);
    t226 = px2 * x2 * t147;
    t227 = t226 + t225 + t220;

    t228 = t125 + t54;
    t229 = t142 * t228;
    t230 = x2 * y2 * t158;
    t231 = t87 + t128;

    t232 = t142 * t231;
    t233 = x2 * y2 * t168;
    t234 = t233 + t232;
    t235 = py1 * t234;

    t236 = - px3 * py2 * t2 * t142;
    t237 = x2 * y2 * (t144 + t54);

    t238 = - px2 * py3 * t5 * t147;
    t239 = px3 * t2 * t142;
    t240 = x2 * y2 * (t87 + t203);

    t241 = px2 * t5 * t147;
    t242 = t241 + t240 + t239;
    t243 = py1 * t242;

    t244 = px2 * py3 * x3 * t142;
    t245 = - px2 * py3 * x2 * y3;
    t246 = y2 * (t143 + t245);

    t247 = px3 * py2 * x2 * t147;
    t248 = - px2 * x3 * t142;
    t249 = px2 * x2 * y3;

    t250 = y2 * (t204 + t249);
    t251 = - px3 * x2 * t147;
    t252 = t251 + t250 + t248;

    t253 = t134 + t133;
    t254 = t253 * t142;
    t255 = t108 + t107;
    t256 = x2 * t255;

    t257 = t256 + t136 + t135;
    t258 = y2 * t257;
    t259 = t181 + t180;
    t260 = x2 * t259;

    t261 = px1 * (t260 + t258 + t254);
    t262 = py1 * (t37 + t60 + t59);

    t263 = t43 + t95 + t93;
    t264 = px1 * t263;
    t265 = t26 + t94;
    t266 = x2 * t265 * y2;

    t267 = x2 * t228;
    t268 = t267 + t266;
    t269 = py1 * (t84 + t83 + t82);

    t270 = - 2 * px2 * py3;
    t271 = (t26 + (t270 + t30) * x2) * y2;
    t272 = px3 * py2 * x2 * y3;

    t273 = - 2 * px3 * py2 * x3 * y3;
    t274 = t149 + t148 + t176;

    t275 = py1 * (t212 + t211 + t210);
    t276 = t238 + t237 + t236;
    t277 = px1 * t276;

    t278 = py1 * (t219 + t218 + t217);
    t279 = 2 * px3 * py2 * x3;
    t280 = t20 + t279;

    t281 = t280 * t142;
    t282 = - px3 * py2 * x2 * y3;
    t283 = y2 * (t125 + t282);

    t284 = 2 * px2 * py3 * t147;
    t285 = x2 * (t284 + t156);
    t286 = px1 * t103;

    t287 = t98 + t68;
    t288 = x2 * t287 * y2;
    t289 = x2 * t231;
    t290 = t289 + t288;

    t291 = 2 * px2;
    t292 = - px3 * x2 * y3;
    t293 = 2 * px3 * x3 * y3;

    t294 = t293 + t203 + t292 + (t68 + (t72 + t291) * x2) * y2;
    t295 = px1 * t242;

    t296 = - 2 * px3 * x3;
    t297 = t296 + t64;
    t298 = px3 * x2 * y3;
    t299 = y2 * (t128 + t298);

    t300 = - 2 * px2 * t147;
    t301 = x2 * (t167 + t300) + t299 + t297 * t142;
    t302 = py1 * t71;

    t303 = py1 * t290;
    t304 = 2 * py2 * x3;
    t305 = - 2 * py3 * x3;
    t306 = - 2 * py2 * x3 * y3;

    t307 = 2 * py3 * x3 * y3;
    t308 = t307 + t306;
    t309 = - 2 * px2 * py3 * x3;

    t310 = (t309 + t19 + t51) * y2;
    t311 = - 2 * px3 * py2 * y3;
    t312 = t35 + t311;

    t313 = x2 * t312;
    t314 = 2 * px2 * x3;
    t315 = 2 * px3 * y3;
    t316 = t315 + t74;

    t317 = x2 * t316;
    t318 = t317 + t87 + (t65 + t314 + t85) * y2;
    t319 = t106 * x2;

    t320 = px1 * (t256 + t118 + t117 + (t115 + t114 + t319) * y2);
    t321 = py1 * t216;

    t322 = 2 * px2 * py3 * x3 * y3;
    t323 = 2 * px3 * py2 * y3;
    t324 = t153 + t323;

    t325 = x2 * t324;
    t326 = y2 * (t325 + t322 + t143);
    t327 = - 2 * px2 * x3 * y3;

    t328 = - 2 * px3 * y3;
    t329 = t328 + t164;
    t330 = x2 * t329;

    t331 = y2 * (t330 + t204 + t327);
    t332 = t226 + t331 + t220;
    t333 = t116 * t142;

    t334 = t140 + t118 + t117;
    t335 = y2 * t334;
    t336 = x2 * t173;

    t337 = px1 * (t336 + t335 + t333);
    t338 = t26 + t94 + t96;
    t339 = t17 * y2;

    t340 = t153 + t55 + t339;
    t341 = px2 * px3 * t142;
    t342 = - 2 * px2 * px3 * y2 * y3;

    t343 = px2 * px3 * t147;
    t344 = py1 * (t343 + t342 + t341);
    t345 = - px2 * py3 * t142;

    t346 = y2 * (t35 + t55);
    t347 = t156 + t346 + t345;
    t348 = px1 * t347 + t344;

    t349 = t89 + t164 + t62 * y2;
    t350 = - px2 * px3 * t142;
    t351 = 2 * px2 * px3 * y2 * y3;

    t352 = - px2 * px3 * t147;
    t353 = px2 * t142;
    t354 = y2 * (t89 + t74);

    t355 = t167 + t354 + t353;
    t356 = px1 * t355 + t352 + t351 + t350;
    t357 = py1 * t66;

    t358 = py1 * t349;
    t359 = 2 * py2;
    t360 = - 2 * py3;
    t361 = - 2 * py2 * y3;

    t362 = 2 * py3 * y3;
    t363 = px3 * py2 * t142;
    t364 = y2 * (t153 + t34);

    t365 = - px3 * t142;
    t366 = y2 * (t75 + t164);
    t367 = t166 + t366 + t365;

    t368 = py1 * t367;
    t369 = px1 * (t172 + t171 + t106 * t142);
    t370 = t35 + t34;

    t371 = t142 * t370;
    t372 = y2 * t150;
    t373 = t372 + t371;
    t374 = t230 + t229;

    t375 = py1 * (t352 + t351 + t350);
    t376 = t157 + t364 + t363;
    t377 = px1 * t376 + t375;

    t378 = t75 + t74;
    t379 = y2 * t207 + t142 * t378;
    t380 = px1 * t367 + t343 + t342 + t341;

    t381 = py1 * t209;
    t382 = py1 * t355;
    t383 = py1 * t379;
    t384 = 2 * py2 * y3;

    t385 = - 2 * py3 * y3;
    t386 = t385 + t384;
    t387 = - 2 * py2 * t147;
    t388 = 2 * py3 * t147;

    t389 = px2 * py3 * t2;
    t390 = t389 + t10;
    t391 = x2 * t390 * y2;
    t392 = t5 * t228;

    t393 = - px2 * t2;
    t394 = t70 + t393;
    t395 = x2 * t394 * y2;
    t396 = t5 * t231;

    t397 = t396 + t395;
    t398 = py1 * t397;
    t399 = py2 * t2;
    t400 = - py3 * t2;

    t401 = t400 + t399;
    t402 = x2 * t401 * y2;
    t403 = t136 + t135;
    t404 = t5 * t403;

    t405 = t404 + t402;
    t406 = px1 * t405;
    t407 = t1 * (t406 + t398 + t392 + t391);

    t408 = t65 + t64;
    t409 = t5 * t408;
    t410 = x2 * t394;
    t411 = t410 + t409;

    t412 = py1 * t411;
    t413 = t5 * t116;
    t414 = x2 * t401;
    t415 = t414 + t413;

    t416 = px1 * t415;
    t417 = py2 * t5;
    t418 = x2 * (t134 + t114);
    t419 = py3 * t2;

    t420 = t419 + t418 + t417;
    t421 = px1 * t420;
    t422 = t265 * y2;
    t423 = x2 * t154;

    t424 = px2 * x2;
    t425 = (t68 + t424) * y2;
    t426 = - py2 * x2;
    t427 = (t133 + t426) * y2;

    t428 = py3 * x2 * y3;
    t429 = t20 + t19;
    t430 = x2 * t429;
    t431 = - px2 * py3 * t2;

    t432 = (t431 + t43 + t430) * y2;
    t433 = t5 * t370;
    t434 = x2 * t145;

    t435 = - px2 * x2 * x3;
    t436 = px2 * t2;
    t437 = (t436 + t435) * y2;
    t438 = px3 * t5 * y3;

    t439 = - px3 * x2 * x3 * y3;
    t440 = py2 * x2 * x3;
    t441 = - py2 * t2;

    t442 = (t441 + t440) * y2;
    t443 = - py3 * t5 * y3;
    t444 = py3 * x2 * x3 * y3;

    t445 = t5 * t287;
    t446 = t78 + t436;
    t447 = x2 * t446;
    t448 = - t2;

    t449 = t448 + 2 * x2 * x3 - t5;
    t450 = px1 * t449;
    t451 = (t98 + t85) * y2;
    t452 = - x2 * y3;

    t453 = x3 * y3;
    t454 = t453 + t452 + (x2 - x3) * y2;
    t455 = px1 * t454;
    t456 = t65 + t314;

    t457 = x2 * t456;
    t458 = (t78 + t457) * y2;
    t459 = x2 * (t293 + t203);

    t460 = - x2 * x3 * y3 + t5 * y3 + (t2 - x2 * x3) * y2;
    t461 = px1 * t460;
    t462 = t5 * t253;

    t463 = t419 + t441;
    t464 = x2 * t463;
    t465 = - py2 * t5;
    t466 = x2 * (t115 + t133);

    t467 = t2 - 2 * x2 * x3 + t5;
    t468 = py1 * t467;
    t469 = py2 * x2;
    t470 = (t134 + t469) * y2;

    t471 = - py2 * x2 * y3;
    t472 = x2 * y3;
    t473 = - x3 * y3;
    t474 = t473 + t472 + (x3 - x2) * y2;

    t475 = py1 * t474;
    t476 = - 2 * py2 * x3;
    t477 = t115 + t476;
    t478 = x2 * t477;

    t479 = (t419 + t478) * y2;
    t480 = py2 * t5 * y3;
    t481 = - 2 * py3 * x3 * y3;

    t482 = x2 * (t481 + t117);
    t483 = x2 * x3 * y3 - t5 * y3 + (t448 + x2 * x3) * y2;

    t484 = py1 * t483;
    t485 = t431 + t43;
    t486 = t485 * t142;
    t487 = t5 * t158;

    t488 = t446 * t142;
    t489 = t5 * t168;
    t490 = t489 + t488;
    t491 = py1 * t490;

    t492 = t463 * t142;
    t493 = t5 * t173;
    t494 = t493 + t492;
    t495 = px1 * t494;

    t496 = x1 * y1 * (t495 + t491 + t487 + t486);
    t497 = t142 * t119;
    t498 = x2 * y2 * t259;

    t499 = t498 + t497;
    t500 = px1 * t499;
    t501 = t29 * (t500 + t381 + t151 + t146);

    t502 = t429 * t142;
    t503 = x2 * t370;
    t504 = y2 * (t503 + t125 + t54);
    t505 = x2 * t158;

    t506 = - px3 * x3 * t142;
    t507 = - px2 * x2 * t147;
    t508 = py3 * x3 * t142;

    t509 = y2 * (t118 + t471);
    t510 = py2 * x2 * t147;
    t511 = - py2 * t142;

    t512 = y2 * (t138 + t107);
    t513 = t172 + t512 + t511;
    t514 = px1 * t513;

    t515 = y2 * t259 + t142 * t255;
    t516 = px1 * t515;
    t517 = py1 * t454;

    t518 = - py2 * x3 * t142;
    t519 = t108 + t384;
    t520 = x2 * t519;

    t521 = y2 * (t520 + t307 + t135);
    t522 = - py3 * x2 * t147;
    t523 = py2 * t142;

    t524 = y2 * (t108 + t137);
    t525 = - t147 + 2 * y2 * y3 - t142;
    t526 = py1 * t525;

    t527 = x2 * t147 + y2 * (t473 + t452) + x3 * t142;
    t528 = py1 * t527;
    t529 = px1 * t474;

    t530 = px2 * x3 * t142;
    t531 = px3 * x2 * t147;

    t532 = - x2 * t147 + y2 * (t453 + t472) - x3 * t142;
    t533 = px1 * t532;

    t534 = - px2 * t142;
    t535 = t147 - 2 * y2 * y3 + t142;
    t536 = px1 * t535;

    t537 = t447 + t445;
    t538 = py1 * t537;
    t539 = t464 + t462;
    t540 = px1 * t539;

    t541 = 2 * px3 * py2 * t2;
    t542 = - 2 * px2 * py3 * t2;
    t543 = x2 * t446 * y2;

    t544 = t5 * t205;
    t545 = t544 + t543;
    t546 = py1 * t545;
    t547 = x2 * t463 * y2;

    t548 = t5 * t119;
    t549 = t548 + t547;
    t550 = px1 * t549;
    t551 = x2 * t265;

    t552 = (t389 + t10 + t551) * y2;
    t553 = t5 * t154;
    t554 = 2 * px3 * t2;

    t555 = (t554 + t393 + t110) * y2;
    t556 = t5 * t90;
    t557 = py3 * x2 * x3;

    t558 = - 2 * py3 * t2;
    t559 = (t558 + t399 + t557) * y2;
    t560 = py2 * x2 * x3 * y3;

    t561 = t138 + t361;
    t562 = t5 * t561;
    t563 = t390 * t142;
    t564 = t5 * t150;

    t565 = - px2 * t2 * t142;
    t566 = - px3 * t5 * t147;
    t567 = t566 + t214 + t565;

    t568 = py1 * t567;
    t569 = py2 * t2 * t142;
    t570 = x2 * y2 * (t118 + t135);

    t571 = py3 * t5 * t147;
    t572 = t571 + t570 + t569;
    t573 = px1 * t572;
    t574 = t86 + t68;

    t575 = x2 * t574;
    t576 = (t78 + t575) * y2;
    t577 = 2 * px2 * x3 * y3;

    t578 = x2 * (t87 + t577);
    t579 = px1 * t527;

    t580 = - t5 * t147 + 2 * x2 * x3 * y2 * y3 - t2 * t142;
    t581 = px1 * t580;
    t582 = t305 + t133;

    t583 = x2 * t582;
    t584 = (t419 + t583) * y2;
    t585 = x2 * (t136 + t306);

    t586 = py1 * t532;
    t587 = - py3 * t2 * t142;
    t588 = x2 * y2 * (t136 + t117);

    t589 = - py2 * t5 * t147;
    t590 = t5 * t147 - 2 * x2 * x3 * y2 * y3 + t2 * t142;

    t591 = py1 * t590;
    t592 = t400 + t466 + t465;
    t593 = px1 * t592;
    t594 = t309 + t279;

    t595 = t198 + t311;
    t596 = x2 * t378;
    t597 = t596 + t408 * y2;
    t598 = py1 * t597;

    t599 = t256 + t116 * y2;
    t600 = px1 * t599;
    t601 = t178 + t366 + t534;

    t602 = py1 * t601;
    t603 = t181 + t524 + t523;
    t604 = px1 * t603;
    t605 = t265 * t142;

    t606 = t423 + t144 + t143;
    t607 = y2 * t606;
    t608 = x2 * t150;
    t609 = 2 * py2 * x3 * y3;

    t610 = t362 + t137;
    t611 = x2 * t610;
    t612 = y2 * (t611 + t118 + t609);

    t613 = py1 * t449;
    t614 = t419 + t613 + t418 + t417;
    t615 = py1 * t460;

    t616 = py1 * t535;
    t617 = t616 + t172 + t512 + t511;
    t618 = t134 + t304;

    t619 = t618 * t142;
    t620 = - py3 * x2 * y3;
    t621 = y2 * (t135 + t620);

    t622 = x2 * (t388 + t180);
    t623 = px1 * t467;
    t624 = t623 + t78 + t102 + t101;

    t625 = px1 * t483;
    t626 = px1 * t525;
    t627 = t167 + t626 + t354 + t353;

    t628 = - 2 * px2 * x3;
    t629 = t98 + t628;
    t630 = t629 * t142;
    t631 = - 2 * px3 * t147;

    t632 = x2 * (t631 + t177);
    t633 = - 2 * px2 * py3 * x3 * y3;
    t634 = t633 + t197;

    t635 = - 2 * px3 * py2 * t147;
    t636 = t142 * t403;
    t637 = x2 * y2 * t173;

    t638 = t637 + t636;
    t639 = px1 * t638;
    t640 = t589 + t588 + t587;
    t641 = px1 * t640;

    t642 = px1 * t590;
    t643 = py1 * t580;

    t644 = (x0 * (px0 * (y1 * (x1 * (t528 + t522 + t612 + t518)
			       + t643 + t571 + t570 + t569)
			 + t29 * t515 + x1 * t638 + t1 * (t615 + t444 + t443 + t442))
		  + py0 * (y1 * (x1 * (t533 + t531 + t331 + t530)
				 + t642 + t566 + t214 + t565)
			   + x1 * t234 + t29 * t379 + t1 * (t625 + t439 + t438 + t437))
		  + y1 * (x1 * (px1 * (t622 + t621 + t619) + py1 * (t632 + t299 + t630)
				+ t608 + t607 + t605)
			  + t641 + t243 + t564 + t563)
		  + x1 * (t639 + t235 + x2 * y2 * (t284 + t635) + t142 * t634)
		  + t29 * (t175 + t170)
		  + t1 * (px1 * (t482 + t480 + t479) + py1 * (t459 + t79 + t458) + t434
			  + t433 + t432))
	    + y0 * (x0 * (py0 * (x1 * (t579 + t632 + t299 + t630)
				 + t489 + t29 * t627
				 + y1 * (x1 * t597 + t625 + t556 + t112 + t555) + t488
				 + t624 * t1)
			  + px0 * (x1 * (t586 + t622 + t621 + t619)
				   + t29 * t617 + t493
				   + y1 * (x1 * t599 + t615 + t562 + t560 + t559) + t492
				   + t614 * t1)
			  + x1 * (px1 * (t522 + t612 + t518) + py1 * (t531 + t331 + t530)
				  + t608 + t607 + t605)
			  + t29 * (t604 + t602) + t487
			  + y1 * (x1 * (t600 + t598 + x2 * t595 + t594 * y2)
				  + px1 * (t585 + t480 + t584) + py1 * (t578 + t79 + t576) + t267
				  + t553 + t552) + t486 + (t593 + t302) * t1)
		    + px0 * (x1 * (t591 + t589 + t588 + t587)
			     + t29 * (t586 + t510 + t509 + t508)
			     + y1 * (x1 * (t484 + t585 + t480 + t584) + t548 + t547) + t415 * t1)
		    + py0 * (x1 * (t581 + t241 + t240 + t239)
			     + t29 * (t579 + t507 + t250 + t506)
			     + y1 * (x1 * (t461 + t578 + t79 + t576) + t544 + t543) + t411 * t1)
		    + x1 * (t573 + t568 + t564 + t563)
		    + t29 * (px1 * (t522 + t521 + t518) + py1 * (t531 + t225 + t530) + t505
			     + t504 + t502)
		    + y1 * (x1 * (px1 * (t562 + t560 + t559) + py1 * (t556 + t112 + t555)
				  + t267 + t553 + t552)
			    + t550 + t546 + t5 * (t322 + t273) + x2 * (t542 + t541) * y2)
		    + (t540 + t538) * t1)
	    + t161 * (py0 * (y1 * (x1 * (t536 + t178 + t366 + t534)
				   + t533 + t531 + t225 + t530)
			     + x1 * t169 + t208 + t1 * (t529 + t204 + t292 + t425) + t206)
		      + px0 * (y1 * (t528 + x1 * (t181 + t526 + t524 + t523) + t522 + t521
				     + t518)
			       + x1 * t174 + t498 + t1 * (t517 + t118 + t428 + t427) + t497)
		      + x1 * (t516 + t383)
		      + y1 * (x1 * (t514 + t382) + px1 * (t510 + t509 + t508)
			      + py1 * (t507 + t250 + t506) + t505 + t504
			      + t502) + t151
		      + t1 * (px1 * (t136 + t471 + t470) + py1 * (t87 + t249 + t451) + t423
			      + t422) + t146) + t501 + t496
	    + t14 * (px0 * (x1 * (t484 + t482 + t480 + t479)
			    + t29 * (t475 + t136 + t471 + t470) + t404 + t402
			    + (x1 * (t468 + t400 + t466 + t465) + t464 + t462) * y1)
		     + py0 * (x1 * (t461 + t459 + t79 + t458)
			      + t29 * (t455 + t87 + t249 + t451) + t396 + t395
			      + (x1 * (t70 + t450 + t69 + t67) + t447 + t445) * y1)
		     + x1 * (px1 * (t444 + t443 + t442) + py1 * (t439 + t438 + t437) + t434
			     + t433 + t432)
		     + t29 * (px1 * (t118 + t428 + t427) + py1 * (t204 + t292 + t425) + t423
			      + t422) + t392 + t391
		     + (x1 * (t421 + t104) + t416 + t412) * y1) + t407);
    t645 = t5 * t265;

    t646 = t115 + t114 + t132;
    t647 = px1 * t646;
    t648 = x2 * t485;
    t649 = t32 * t5;

    t650 = t70 + t393 + t73 * t5;
    t651 = t400 + t399 + t106 * t5;

    t652 = t540 + x1 * (px1 * t651 + py1 * t650 + t389 + t10 + t649) + t538 + t648
	+ t29 * (t647 + t357 + t20 + t19 + t18) + t645;
    t653 = t648 + t645;

    t654 = t392 + t391;
    t655 = px1 * t654;
    t656 = t309 + t19;
    t657 = x2 * t656;

    t658 = (t389 + t657) * y2;
    t659 = px3 * py2 * t5 * y3;
    t660 = x2 * (t144 + t273);

    t661 = - px3 * py2 * t5;
    t662 = t431 + t27 + t661;
    t663 = px1 * t662 + t24;

    t664 = t5 * t429;
    t665 = x2 * t390;
    t666 = t665 + t664;
    t667 = px3 * py2 * x2;

    t668 = (t20 + t667) * y2;
    t669 = x2 * t485 * y2;
    t670 = t5 * t145;
    t671 = t670 + t669;

    t672 = px1 * t671;
    t673 = t26 + t52;
    t674 = x2 * t673;
    t675 = (t389 + t674) * y2;

    t676 = x2 * (t633 + t54);
    t677 = px3 * t5;
    t678 = t436 + t69 + t677;

    t679 = px1 * t678 + t37 + t60 + t59;
    t680 = - px3 * x2;

    t681 = t203 + t298 + (t64 + t680) * y2;
    t682 = px1 * t545;
    t683 = - px3 * t5 * y3;

    t684 = t578 + t683 + (t393 + t575) * y2;
    t685 = 2 * py3 * x3;
    t686 = t685 + t476;

    t687 = 2 * py2 * t2;
    t688 = px1 * (t419 + t441 + t131 * t5);
    t689 = - px2 * py3 * x2;

    t690 = 2 * px2 * py3 * x3;
    t691 = (t690 + t94 + t689) * y2;

    t692 = t330 + t204 + (t98 + t628 + t424) * y2;
    t693 = t134 + t133 + t319;

    t694 = px1 * (t140 + t118 + t117 + t693 * y2);
    t695 = (t542 + t43 + t9) * y2;

    t696 = t5 * t312;
    t697 = 2 * px2 * t2;
    t698 = t5 * t316 + t112 + (t78 + t697 + t110) * y2;

    t699 = x2 * t253;
    t700 = t5 * t255;
    t701 = x2 * t403;

    t702 = px1 * (t701 + t700 + (t419 + t441 + t699) * y2);
    t703 = px2 * py3 * x2 * x3;

    t704 = (t10 + t703) * y2;
    t705 = px3 * py2 * x2 * x3 * y3;
    t706 = (t20 + t279 + t689) * y2;

    t707 = t439 + t111 + (t70 + t435) * y2;
    t708 = t224 + t204 + (t296 + t64 + t424) * y2;

    t709 = - 2 * py2;
    t710 = 2 * py3;
    t711 = py1 * t678;

    t712 = t459 + t683 + (t393 + t457) * y2;
    t713 = x2 * t116;
    t714 = t5 * t139;

    t715 = px1 * (t120 + t714 + (t400 + t399 + t713) * y2);
    t716 = 2 * px2 * py3;

    t717 = (t94 + (t716 + t15) * x2) * y2;
    t718 = - 2 * px2;

    t719 = t221 + t128 + t249 + (t98 + (px3 + t718) * x2) * y2;

    t720 = px1 * (t256 + t136 + t135 + t646 * y2);
    t721 = - px2 * py3 * t2 * t142;

    t722 = - px3 * py2 * t5 * t147;
    t723 = t722 + t237 + t721;
    t724 = - px2 * py3 * x3 * t142;

    t725 = y2 * (t54 + t124);
    t726 = px1 * y2 * t257;
    t727 = - px3 * py2 * x2 * t147;

    t728 = y2 * (t87 + t127);
    t729 = t531 + t728 + t530;
    t730 = px2 * py3 * t2 * t142;

    t731 = px3 * py2 * t5 * t147;
    t732 = px1 * t397;
    t733 = t251 + t299 + t248;

    t734 = px2 * t2 * t142;
    t735 = px3 * t5 * t147;
    t736 = t735 + t240 + t734;

    t737 = t389 + t10 + t649;
    t738 = t731 + t189 + t730;
    t739 = px1 * t738;

    t740 = x2 * t165;
    t741 = t740 + t204 + t203;
    t742 = py1 * y2 * t741;
    t743 = py1 * t736;

    t744 = px2 * py3 * t142;
    t745 = px1 * t567;
    t746 = t148 + t364 + t744;

    t747 = px3 * py2 * t5;
    t748 = t389 + t95 + t747;
    t749 = (t26 + t122) * y2;

    t750 = x2 * t280;
    t751 = (t431 + t750) * y2;
    t752 = - px3 * py2 * t5 * y3;

    t753 = x2 * (t322 + t143);
    t754 = - px3 * t5;
    t755 = t393 + t102 + t754;

    t756 = t128 + t292 + (t68 + t126) * y2;
    t757 = x2 * t297;
    t758 = x2 * (t204 + t327);

    t759 = t758 + t438 + (t436 + t757) * y2;
    t760 = (t94 + t667) * y2;

    t761 = t203 + t249 + (t98 + t680) * y2;
    t762 = px1 * (t140 + t253 * y2);

    t763 = - px3 * py2 * x2 * x3;
    t764 = (t43 + t763) * y2;
    t765 = - px2 * py3 * x2 * x3 * y3;

    t766 = px3 * x2 * x3;
    t767 = px2 * x2 * x3 * y3;
    t768 = t767 + t79 + (t78 + t766) * y2;

    t769 = px1 * (t120 + t700 + (t419 + t441 + t713) * y2);
    t770 = t501 + t496 + t407;

    t771 = px3 * py2 * x3 * t142;
    t772 = y2 * (t313 + t633 + t54);

    t773 = px2 * py3 * x2 * t147;
    t774 = - px3 * py2 * t142;
    t775 = t149 + t346 + t774;

    t776 = y2 * (t317 + t87 + t577);
    t777 = t507 + t776 + t506;
    t778 = px3 * t142;

    t779 = t177 + t354 + t778;
    t780 = y2 * (t144 + t272);
    t781 = y2 * (t203 + t292);

    t782 = t531 + t781 + t530;
    t783 = px1 * (t336 + t258 + t333);
    t784 = t690 + t94;

    t785 = x2 * t784;
    t786 = (t431 + t785) * y2;
    t787 = x2 * (t125 + t197);

    t788 = x2 * t629;
    t789 = x2 * (t221 + t128);
    t790 = t789 + t438 + (t436 + t788) * y2;

    t791 = - 2 * py2 * t2;
    t792 = 2 * py3 * t2;
    t793 = 2 * px2 * py3 * t2;

    t794 = (t793 + t10 + t42) * y2;
    t795 = t5 * t324;
    t796 = - 2 * px2 * t2;

    t797 = t5 * t329 + t80 + (t70 + t796 + t77) * y2;

    t798 = px1 * (t701 + t714 + (t400 + t399 + t699) * y2);

    t799 = px1 * (t5 * t259 + t401 * t142);
    t800 = t429 * y2;
    t801 = t503 + t800;

    t802 = t487 + t486;
    t803 = t673 * t142;
    t804 = - 2 * px2 * py3 * t147;

    t805 = x2 * (t804 + t148);
    t806 = 2 * px2 * t147;

    t807 = x2 * (t178 + t806) + t728 + t574 * t142;
    t808 = py1 * t755;
    t809 = py1 * t779;

    t810 = y2 * (t58 + t144 + t273);
    t811 = y2 * (t91 + t293 + t203);

    t812 = t507 + t811 + t506;
    t813 = px1 * (t260 + t335 + t254);
    t814 = 2 * py2 * t147;

    t815 = - 2 * py3 * t147;
    t816 = (t389 + t42) * y2;
    t817 = - py2 * py3 * t2;

    t818 = (t817 + py2 * py3 * x2 * x3) * y2;
    t819 = - py2 * py3 * t5 * y3;

    t820 = py2 * py3 * x2 * x3 * y3;
    t821 = px1 * (t820 + t819 + t818);
    t822 = - py2 * py3 * t5;

    t823 = 2 * py2 * py3 * x2 * x3;
    t824 = px1 * (t817 + t823 + t822);
    t825 = (t431 + t9) * y2;

    t826 = py2 * py3 * t2;
    t827 = (t826 - py2 * py3 * x2 * x3) * y2;
    t828 = py2 * py3 * t5 * y3;

    t829 = - py2 * py3 * x2 * x3 * y3;
    t830 = px1 * (t829 + t828 + t827);

    t831 = (py2 * py3 * x2 - py2 * py3 * x3) * y2;
    t832 = - py2 * py3 * x2 * y3;

    t833 = py2 * py3 * x3 * y3;
    t834 = px1 * (t833 + t832 + t831);

    t835 = (t690 + t94 + t122) * y2;
    t836 = px1 * t693;
    t837 = - py2 * t5 * y3;

    t838 = t560 + t837 + (t400 + t557) * y2;
    t839 = x2 * t205;

    t840 = py1 * (t839 + x2 * t408 * y2);
    t841 = (t20 + t51) * y2;
    t842 = - py3 * x2;

    t843 = py2 * x2 * y3;
    t844 = t135 + t843 + (t115 + t842) * y2;

    t845 = py1 * (t740 + t87 + t128 + (t98 + t68 + t63) * y2);
    t846 = py2 * py3 * t5;

    t847 = - 2 * py2 * py3 * x2 * x3;
    t848 = - py2 * x2 * x3;
    t849 = - py3 * x2 * x3 * y3;

    t850 = t849 + t480 + (t419 + t848) * y2;
    t851 = (py2 * py3 * x3 - py2 * py3 * x2) * y2;

    t852 = py2 * py3 * x2 * y3;
    t853 = - py2 * py3 * x3 * y3;
    t854 = x2 * t561;

    t855 = t854 + t136 + (t305 + t133 + t469) * y2;
    t856 = py2 * py3 * t2 * t142;

    t857 = - 2 * py2 * py3 * x2 * x3 * y2 * y3;
    t858 = py2 * py3 * t5 * t147;

    t859 = px1 * (t858 + t857 + t856);
    t860 = - py2 * py3 * x3 * t142;

    t861 = y2 * (t833 + t852);
    t862 = - py2 * py3 * x2 * t147;

    t863 = px1 * (t862 + t861 + t860);
    t864 = - py2 * py3 * t2 * t142;

    t865 = 2 * py2 * py3 * x2 * x3 * y2 * y3;
    t866 = - py2 * py3 * t5 * t147;

    t867 = py3 * t2 * t142;
    t868 = py2 * t5 * t147;
    t869 = t868 + t570 + t867;

    t870 = py2 * py3 * x3 * t142;
    t871 = y2 * (t853 + t832);
    t872 = py2 * py3 * x2 * t147;

    t873 = - py3 * x3 * t142;
    t874 = - py2 * x2 * t147;
    t875 = t874 + t521 + t873;

    t876 = py2 * x3 * t142;
    t877 = py3 * x2 * t147;
    t878 = t877 + t509 + t876;

    t879 = t287 * t142;
    t880 = t596 + t87 + t128;
    t881 = y2 * t880;
    t882 = x2 * t207;

    t883 = py1 * (t882 + t881 + t879);
    t884 = py1 * t662;

    t885 = px1 * (t826 + t847 + t846);
    t886 = 2 * px3 * py2;

    t887 = (t94 + (t31 + t886) * x2) * y2;
    t888 = px1 * (t853 + t852 + t851);

    t889 = py1 * t738;
    t890 = px1 * (t866 + t865 + t864);

    t891 = px1 * (t872 + t871 + t870);
    t892 = t656 * t142;
    t893 = x2 * (t157 + t635);

    t894 = t221 + t577;
    t895 = x2 * t253 * y2;
    t896 = t701 + t895;
    t897 = px1 * t896;

    t898 = (t20 + t279 + t122) * y2;

    t899 = py1 * (t596 + t204 + t203 + (t65 + t64 + t97) * y2);
    t900 = t385 + t107;

    t901 = x2 * t900;
    t902 = t901 + t136 + (t115 + t476 + t469) * y2;
    t903 = px1 * t869;

    t904 = t874 + t612 + t873;
    t905 = t408 * t142;
    t906 = y2 * t741;
    t907 = x2 * t168;

    t908 = py1 * (t907 + t906 + t905);
    t909 = - py2 * py3 * t142;

    t910 = 2 * py2 * py3 * y2 * y3;
    t911 = - py2 * py3 * t147;

    t912 = px1 * (t911 + t910 + t909);
    t913 = t912 + py1 * t376;

    t914 = t481 + t117 + t428 + (t133 + (py3 + t709) * x2) * y2;
    t915 = 2 * px3;

    t916 = t138 + t137 + t131 * y2;
    t917 = px1 * t916;

    t918 = py1 * (t167 + t166 + t73 * t142);
    t919 = py3 * t142;
    t920 = t171 + t524 + t919;

    t921 = px1 * t920;
    t922 = py2 * py3 * t142;
    t923 = - 2 * py2 * py3 * y2 * y3;

    t924 = py2 * py3 * t147;
    t925 = py1 * t513 + t924 + t923 + t922;
    t926 = py1 * t420;

    t927 = py1 * t640;
    t928 = t685 + t114;
    t929 = x2 * (t172 + t814) + t621 + t928 * t142;

    t930 = px1 * (t924 + t923 + t922);
    t931 = t930 + py1 * t347;

    t932 = py1 * t920 + t911 + t910 + t909;
    t933 = t315 + t222;
    t934 = py1 * t654;

    t935 = (t10 + t750) * y2;
    t936 = t824 + py1 * t263;
    t937 = py1 * t671;

    t938 = (t19 + t689) * y2;
    t939 = (t10 + t785) * y2;
    t940 = t296 + t314;

    t941 = py1 * (t78 + t436 + t62 * t5);
    t942 = (t26 + t52 + t667) * y2;

    t943 = py1 * (t740 + t204 + t203 + t99 * y2);

    t944 = t611 + t118 + (t134 + t304 + t426) * y2;
    t945 = (t431 + t541 + t42) * y2;

    t946 = t5 * t199;
    t947 = t5 * t900 + t560 + (t419 + t791 + t557) * y2;
    t948 = x2 * t287;

    t949 = t5 * t378;
    t950 = py1 * (t289 + t949 + (t78 + t436 + t948) * y2);

    t951 = - py3 * t5;
    t952 = t441 + t466 + t951;
    t953 = py1 * t952 + t826 + t847 + t846;

    t954 = py3 * x2;
    t955 = t117 + t620 + (t114 + t954) * y2;
    t956 = py1 * t549;

    t957 = py3 * t5 * y3;
    t958 = t585 + t957 + (t399 + t583) * y2;
    t959 = (t389 + t763) * y2;

    t960 = (t309 + t19 + t667) * y2;
    t961 = - 2 * px3;
    t962 = px1 * t952;
    t963 = x2 * t408;

    t964 = t5 * t165;
    t965 = py1 * (t839 + t964 + (t70 + t393 + t963) * y2);

    t966 = t482 + t957 + (t399 + t478) * y2;
    t967 = - 2 * px3 * py2;

    t968 = (t26 + (t16 + t967) * x2) * y2;

    t969 = t307 + t135 + t471 + (t134 + (t130 + t359) * x2) * y2;

    t970 = py1 * (t596 + t87 + t128 + t66 * y2);
    t971 = t444 + t837 + (t400 + t440) * y2;

    t972 = t520 + t118 + (t685 + t114 + t426) * y2;
    t973 = py1 * t405;

    t974 = t877 + t621 + t876;
    t975 = - py2 * t2 * t142;
    t976 = - py3 * t5 * t147;

    t977 = t976 + t588 + t975;
    t978 = py1 * y2 * t880;
    t979 = y2 * (t136 + t843);

    t980 = t522 + t979 + t518;
    t981 = py1 * t276;
    t982 = py1 * t572;
    t983 = px1 * y2 * t334;

    t984 = px1 * t977;
    t985 = (t94 + t51) * y2;
    t986 = (t43 + t657) * y2;

    t987 = (t26 + t689) * y2;
    t988 = t117 + t471 + (t134 + t954) * y2;

    t989 = py1 * (t740 + t287 * y2);
    t990 = (t431 + t703) * y2;
    t991 = - py3 * x2 * x3;

    t992 = - py2 * x2 * x3 * y3;
    t993 = t992 + t480 + (t419 + t991) * y2;

    t994 = py1 * (t839 + t949 + (t78 + t436 + t963) * y2);
    t995 = py3 * t5;

    t996 = t399 + t418 + t995;
    t997 = t135 + t428 + (t133 + t842) * y2;
    t998 = x2 * t928;

    t999 = x2 * (t118 + t609);
    t1000 = t999 + t443 + (t441 + t998) * y2;

    t1001 = y2 * (t901 + t136 + t306);
    t1002 = t510 + t1001 + t508;
    t1003 = - py3 * t142;

    t1004 = t180 + t512 + t1003;
    t1005 = y2 * (t117 + t428);
    t1006 = t522 + t1005 + t518;

    t1007 = py1 * (t907 + t881 + t905);
    t1008 = y2 * (t854 + t481 + t117);

    t1009 = t510 + t1008 + t508;
    t1010 = 2 * px3 * t147;

    t1011 = py1 * (t5 * t207 + t394 * t142);
    t1012 = t784 * t142;

    t1013 = 2 * px3 * py2 * t147;
    t1014 = x2 * (t149 + t1013);

    t1015 = py1 * (t882 + t906 + t879);
    t1016 = x2 * (t181 + t387) + t979 + t582 * t142;

    t1017 = (t43 + t674) * y2;
    t1018 = x2 * t618;
    t1019 = x2 * (t307 + t135);

    t1020 = t1019 + t443 + (t441 + t1018) * y2;
    t1021 = - 2 * px3 * t2;

    t1022 = - 2 * px3 * py2 * t2;
    t1023 = (t389 + t1022 + t9) * y2;
    t1024 = t5 * t57;

    t1025 = t5 * t610 + t849 + (t400 + t687 + t848) * y2;

    t1026 = py1 * (t289 + t964 + (t70 + t393 + t948) * y2);
    t1027 = px1 * t996;

    t1028 = px1 * t1004;
    t1029 = x2 * t429 * y2;
    t1030 = (t436 + t110) * y2;

    t1031 = (t441 + t557) * y2;
    t1032 = (t393 + t77) * y2;
    t1033 = (t399 + t848) * y2;

    t1034 = (t26 + t94 + t18) * y2;
    t1035 = (t64 + t85) * y2;
    t1036 = (t114 + t469) * y2;

    t1037 = (t98 + t628 + t126) * y2;
    t1038 = (t134 + t304 + t842) * y2;

    t1039 = (t20 + t19 + t96) * y2;
    t1040 = (t296 + t64 + t126) * y2;

    t1041 = (t685 + t114 + t842) * y2;
    t1042 = (t98 + (t961 + px2) * x2) * y2;

    t1043 = t456 * t142;
    t1044 = x2 * (t1010 + t166);

    t1045 = (t134 + (t710 + t105) * x2) * y2;
    t1046 = t477 * t142;

    t1047 = x2 * (t815 + t171);
    t1048 = t32 * t142;
    t1049 = t171 + t526 + t524 + t919;

    t1050 = t536 + t166 + t366 + t365;
    t1051 = (t389 + t10 + t430) * y2;

    t1052 = (t393 + t766) * y2;
    t1053 = (t399 + t991) * y2;
    t1054 = t17 * t5;

    t1055 = (t431 + t43 + t551) * y2;
    t1056 = (t1021 + t436 + t77) * y2;
    t1057 = t5 * t223;

    t1058 = (t792 + t441 + t848) * y2;
    t1059 = t5 * t519;
    t1060 = t338 * y2;

    t1061 = (t86 + t68 + t680) * y2;
    t1062 = (t305 + t133 + t954) * y2;

    t1063 = (t115 + t426) * y2;
    t1064 = (t400 + t1018) * y2;
    t1065 = (t65 + t424) * y2;

    t1066 = (t70 + t788) * y2;
    t1067 = (t70 + t757) * y2;
    t1068 = (t400 + t998) * y2;

    t1069 = t21 * y2;
    t1070 = (t68 + (t915 + t61) * x2) * y2;

    t1071 = (t133 + (t360 + py2) * x2) * y2;
    t1072 = (t115 + t476 + t954) * y2;

    t1073 = (t65 + t314 + t680) * y2;

    trans->m[0][0]
	= (x0 * (px0 * (x1 * (px1 * (y2 * (t388 + t387) + t142 * t386)
			      + t383 + t372 + t371)
			+ y1 * (x1 * (t369 + t382 + t156 + t346 + t345)
				+ t337 + py1 * t301 + t285 + t283 + t281) + t381 + t151
			+ t1 * (t141 + py1 * t92 + t58 + t54 + t53) + t146)
		 + py0 * (y1 * (x1 * t380 + px1 * t332 + t219 + t218 + t217)
			  + px1 * t234 + px1 * x1 * t379 + t1 * (px1 * t129 + t49 + t48 + t47))
		 + y1 * (x1 * t377 + px1 * (t202 + t326 + t196) + t195) + px1 * t374
		 + px1 * x1 * t373 + t1 * (px1 * (t125 + t124 + t123) + t269))
	   + y0 * (x0 * (px0 * (t261 + x1 * (t369 + t368 + t157 + t364 + t363) + py1 * t227
				+ t202
				+ y1
				* (x1
				   * (px1 * (t362 + t361 + (t360 + t359) * y2)
				      + t358 + t153 + t55 + t339)
				   + t320 + py1 * t294 + t144 + t273 + t272 + t271)
				+ t201 + t196 + (t357 + t20 + t19 + t18) * t1)
			 + py0 * (x1 * t356 + px1 * t252 + t194
				  + y1 * (px1 * t318 + px1 * x1 * t349 + t84 + t83 + t82)
				  + t193 + t192 + px1 * t99 * t1) + x1 * t348
			 + px1 * (t247 + t246 + t244) + t278
			 + y1 * (px1 * (t313 + t54 + t310) + t50 + px1 * x1 * t340)
			 + px1 * t338 * t1)
		   + px0 * (x1 * (t337 + py1 * t332 + t202 + t326 + t196)
			    + t321 + px1 * t29 * t182 + t190
			    + y1 * (x1 * (t320 + py1 * t318 + t313 + t54 + t310)
				    + px1 * (x2 * t308 + x2 * (t305 + t304) * y2) + t303 + t267
				    + t266) + t189 + t188 + (t302 + t10 + t27 + t25) * t1)
		   + py0 * (x1 * (px1 * t301 + t194 + t193 + t192)
			    + t295 + px1 * t29 * t179 + t186
			    + y1 * (x1 * (px1 * t294 + t49 + t48 + t47) + px1 * t290) + t185 + t184
			    + (t286 + t3 + t23 + t22) * t1)
		   + x1 * (px1 * (t285 + t283 + t281) + t278) + t277 + t275 + px1 * t29 * t274
		   + y1 * (x1 * (px1 * (t144 + t273 + t272 + t271) + t269) + px1 * t268)
		   + (t264 + t262) * t1)
	   + px0 * (y1 * (x1 * (t261 + py1 * t252 + t247 + t246 + t244)
			  + t243 + t238 + t237 + t236)
		    + x1 * (t235 + t230 + t229) + px1 * t29 * t174
		    + t1 * (t121 + py1 * t81 + t46 + t45 + t44))
	   + py0 * (y1 * (x1 * (px1 * t227 + t219 + t218 + t217)
			  + px1 * t216 + t212 + t211 + t210)
		    + px1 * t29 * t169 + px1 * x1 * t209 + t1 * (px1 * t113 + t40 + t39 + t38))
	   + y1 * (x1 * (px1 * (t202 + t201 + t196) + t195) + px1 * t191 + t187)
	   + px0 * t161 * t183 + px1 * t29 * t160 + px1 * x1 * t152
	   + t14 * (px0 * (x1 * (t141 + py1 * t129 + t125 + t124 + t123)
			   + t121 + py1 * t113 + px1 * t29 * t109 + t13 + t12 + t11
			   + (t104 + t43 + x1 * (t100 + t26 + t94 + t96) + t95 + t93) * y1)
		    + py0 * (x1 * (px1 * t92 + t84 + t83 + t82)
			     + px1 * t81 + px1 * t29 * t76 + t7 + t6 + t4
			     + (px1 * t71 + t37 + px1 * x1 * t66 + t60 + t59) * y1)
		    + x1 * (px1 * (t58 + t54 + t53) + t50) + px1 * (t46 + t45 + t44) + t41
		    + px1 * t29 * t36 + (px1 * t28 + t24 + px1 * x1 * t21) * y1)
	   + t1 * (px1 * (t13 + t12 + t11) + t8));

    trans->m[0][1] =
	(t161 * (px0 * (x1 * (t382 + t156 + t346 + t345)
			+ py1 * t733 + t247
			+ y1 * (t694 + x1 * (t358 + t153 + t55 + t339) + py1 * t681
				+ t144 + t282 + t668) + t726 + t283 + t244
			+ px1 * t646 * t1)
		 + py0 * (x1 * (px1 * t601 + t343 + t342 + t341)
			  + px1 * t729 + t219
			  + y1 * (px1 * t692 + px1 * x1 * t76 + t49 + t48 + t47) + t218
			  + t217 + px1 * t66 * t1) + x1 * (px1 * t746 + t375)
		 + px1 * (t727 + t725 + t724) + t195
		 + y1 * (px1 * (t325 + t143 + t691) + t269 + px1 * x1 * t36)
		 + px1 * t21 * t1)
	 + x0 * (py0 * (t29 * t356 + t745 + t212
			+ y1
			* (x1 * (px1 * t719 + t84 + t83 + t82)
			   + px1 * t698 + t40 + t39 + t38) + px1 * x1 * y2 * t741
			+ t211 + t210 + px1 * t650 * t1)
		 + px0 * (t29 * (t602 + t148 + t364 + t744)
			  + t743 + t722
			  + y1 * (x1 * (t720 + py1 * t708 + t200 + t143 + t706)
				  + t702 + py1 * t684 + t676 + t659 + t675)
			  + x1 * (t607 + px1 * y2 * (x2 * (t362 + t361) + t481 + t609) + t742)
			  + t237 + t721 + px1 * t651 * t1) + t29 * t348 + t739 + t187
		 + y1 * (x1 * (px1 * (t125 + t197 + t245 + t717) + t50)
			 + px1 * (t696 + t13 + t695) + t8) + px1 * x1 * y2 * t606
		 + px1 * t737 * t1)
	 + py0 * (x1 * (px1 * t736 + t186 + t185 + t184)
		  + t29 * (px1 * t733 + t194 + t193 + t192)
		  + y1 * (x1 * (px1 * t712 + t7 + t6 + t4) + t732) + px1 * t537 * t1)
	 + px0 * (x1 * (t568 + t731 + t189 + t730)
		  + t29 * (py1 * t729 + t727 + t726 + t725 + t724)
		  + y1 * (x1 * (t715 + py1 * t707 + t705 + t12 + t704) + t546 + t670 + t669)
		  + px1 * t539 * t1) + x1 * (px1 * t723 + t275)
	 + t29 * (px1 * (t247 + t283 + t244) + t278)
	 + y0 * (x0 * (px0 * (x1 * (t720 + py1 * t719 + t125 + t197 + t245 + t717)
			      + t715 + py1 * t712 + t29 * (t162 + t35 + t34 + t33) + t660
			      + t659 + t658
			      + (t688 + t711 + t431
				 + x1
				 * (px1 * (t305 + t304 + (t710 + t709) * x2)
				    + t100 + t26 + t94 + t96) + t27 + t661)
			      * y1)
		       + py0 * (x1 * (px1 * t708 + t49 + t48 + t47)
				+ px1 * t707 + px1 * t29 * t349 + t40 + t39 + t38
				+ (t286 + t3 + px1 * x1 * t99 + t23 + t22) * y1)
		       + x1 * (px1 * (t200 + t143 + t706) + t269) + px1 * (t705 + t12 + t704)
		       + t8 + px1 * t29 * t340 + (t264 + t262 + px1 * x1 * t338) * y1)
		 + px0 * (x1 * (t702 + py1 * t698 + t696 + t13 + t695)
			  + t29 * (t694 + py1 * t692 + t325 + t143 + t691) + t398 + t392 + t391
			  + (x1 * (t688 + t104 + t43 + t95 + t93)
			     + px1 * (x2 * (t558 + t687) + t5 * t686) + t412 + t665 + t664)
			  * y1)
		 + py0 * (x1 * (px1 * t684 + t7 + t6 + t4) + t682
			  + t29 * (px1 * t681 + t84 + t83 + t82)
			  + (px1 * t411 + x1 * t679) * y1)
		 + x1 * (px1 * (t676 + t659 + t675) + t41) + t672
		 + t29 * (px1 * (t144 + t282 + t668) + t50) + (px1 * t666 + x1 * t663) * y1)
	 + y1 * (x1 * (px1 * (t660 + t659 + t658) + t41) + t655) + px1 * t653 * t1
	 + px0 * t652 * t14)
	;

    trans->m[0][2] =
	(x0 * (px0 * (y1 * (x1 * (t813 + py1 * t807 + t805 + t725 + t803)
			    + t799 + t568 + t731 + t189 + t730)
		      + x1 * (px1 * (x2 * y2 * (t815 + t814) + t142 * t308)
			      + t235 + t230 + t229) + t29 * (t170 + t159 + t155)
		      + t1 * (t769 + py1 * t759 + t753 + t752 + t751))
	       + py0 * (y1 * (x1 * (px1 * t812 + t194 + t193 + t192)
			      + t295 + t186 + t185 + t184)
			+ px1 * x1 * t234 + px1 * t29 * t379
			+ t1 * (px1 * t768 + t7 + t6 + t4))
	       + y1 * (x1 * (px1 * (t773 + t810 + t771) + t278) + t277 + t275)
	       + px1 * x1 * t374 + px1 * t29 * t373
	       + t1 * (px1 * (t765 + t45 + t764) + t41))
	 + y0 * (x0 * (px0 * (x1 * (t813 + py1 * t812 + t773 + t810 + t771)
			      + t495 + t29 * (t809 + t149 + t346 + t774)
			      + y1
			      * (x1
				 * (px1 * (x2 * t386 + t686 * y2)
				    + t598 + t503 + t800)
				 + t798 + py1 * t790 + t787 + t752 + t786)
			      + (t808 + t389 + t95 + t747) * t1)
		       + py0 * (x1 * (px1 * t807 + t219 + t218 + t217)
				+ px1 * t490 + t29 * t380
				+ y1 * (px1 * x1 * t597 + px1 * t797 + t7 + t6 + t4)
				+ t679 * t1)
		       + x1 * (px1 * (t805 + t725 + t803) + t195) + px1 * t802
		       + t29 * t377
		       + y1 * (px1 * x1 * t801 + px1 * (t795 + t46 + t794) + t41)
		       + t663 * t1)
		 + px0 * (x1 * (t799 + t243 + t238 + t237 + t236)
			  + t29 * (t783 + py1 * t777 + t773 + t772 + t771)
			  + y1 * (x1 * (t798 + py1 * t797 + t795 + t46 + t794)
				  + px1 * (t5 * (t481 + t609) + x2 * (t792 + t791) * y2)
				  + t546 + t670 + t669) + (t538 + t648 + t645) * t1)
		 + py0 * (x1 * (t745 + t212 + t211 + t210)
			  + t29 * (px1 * t782 + t219 + t218 + t217)
			  + y1 * (x1 * (px1 * t790 + t40 + t39 + t38) + t682)
			  + px1 * t411 * t1) + x1 * (t739 + t187)
		 + t29 * (px1 * (t727 + t780 + t724) + t195)
		 + y1 * (x1 * (px1 * (t787 + t752 + t786) + t8) + t672)
		 + px1 * t666 * t1)
	 + t161 * (px0 * (y1
			  * (t783 + x1 * (t368 + t157 + t364 + t363) + py1 * t782
			     + t727 + t780 + t724)
			  + x1 * (t383 + t372 + t371) + t500
			  + t1 * (t762 + py1 * t756 + t125 + t272 + t749))
		   + py0 * (y1
			    * (x1 * (px1 * t779 + t352 + t351 + t350)
			       + px1 * t777 + t194 + t193 + t192)
			    + px1 * x1 * t169 + px1 * t209
			    + t1 * (px1 * t761 + t84 + t83 + t82))
		   + y1 * (x1 * (px1 * t775 + t344) + px1 * (t773 + t772 + t771)
			   + t278) + px1 * x1 * t160
		   + px1 * t152 + t1 * (px1 * (t144 + t245 + t760) + t50))
	 + px0 * t770
	 + t14 * (px0 * (x1 * (t769 + py1 * t768 + t765 + t45 + t764)
			 + t29 * (t762 + py1 * t761 + t144 + t245 + t760) + t406
			 + (t412 + x1 * (t711 + t431 + t27 + t661) + t665 + t664)
			 * y1)
		  + py0 * (x1 * (px1 * t759 + t40 + t39 + t38)
			   + t732 + t29 * (px1 * t756 + t49 + t48 + t47)
			   + (px1 * t537 + x1 * (px1 * t755 + t3 + t23 + t22)) * y1)
		  + x1 * (px1 * (t753 + t752 + t751) + t8) + t655
		  + t29 * (px1 * (t125 + t272 + t749) + t269)
		  + (x1 * (px1 * t748 + t262) + px1 * t653) * y1));

    trans->m[1][0] = (x0 * (py0 * (x1 * (t516 + py1 * (y2 * (t631 + t806) + t142 * t933) + t372
					 + t371)
				   + y1 * (px1 * t929 + x1 * (t514 + t918 + t157 + t364 + t363) + t908
					   + t893 + t725 + t892) + t500 + t151
				   + t1 * (px1 * t855 + t845 + t325 + t125 + t835) + t146)
			    + px0 * (y1 * (x1 * t932 + py1 * t904 + t872 + t871 + t870)
				     + py1 * x1 * t515 + py1 * t638
				     + t1 * (py1 * t844 + t833 + t832 + t831))
			    + y1 * (x1 * t931 + t863 + py1 * (t247 + t810 + t244)) + py1 * t374
			    + py1 * x1 * t373 + t1 * (t888 + py1 * (t54 + t282 + t841)))
		      + y0 * (px0 * (x1 * (py1 * t929 + t862 + t861 + t860)
				     + t927 + py1 * t29 * t182 + t858
				     + y1 * (py1 * t896 + x1 * (py1 * t914 + t833 + t832 + t831)) + t857
				     + t856 + (t926 + t817 + t823 + t822) * t1)
			      + x0 * (px0 * (x1 * t925 + py1 * t878 + t862
					     + y1
					     * (py1 * t902 + py1 * x1 * t916 + t853 + t852
						+ t851) + t861 + t860
					     + py1 * t693 * t1)
				      + py0 * (x1 * (t921 + t918 + t156 + t346 + t345)
					       + t883 + px1 * t875 + t247
					       + y1 * (x1 * (t917 + py1 * (t328 + t88 + (t915 + t718) * y2)
							     + t153 + t55 + t339)
						       + t899 + px1 * t914 + t322 + t143 + t245 + t887) + t772
					       + t244 + (t647 + t20 + t19 + t18) * t1) + x1 * t913 + t891
				      + py1 * (t202 + t780 + t196)
				      + y1 * (py1 * (t200 + t125 + t898) + t834 + py1 * x1 * t340)
				      + py1 * t338 * t1)
			      + py0 * (x1 * (t908 + px1 * t904 + t247 + t810 + t244)
				       + t903 + py1 * t29 * t179 + t722
				       + y1 * (x1 * (px1 * t902 + t899 + t200 + t125 + t898)
					       + t897 + py1 * (x2 * t894 + x2 * (t86 + t628) * y2) + t267
					       + t266) + t237 + t721 + (t593 + t389 + t95 + t747) * t1)
			      + x1 * (py1 * (t893 + t725 + t892) + t891) + t890 + t889 + py1 * t29 * t274
			      + y1 * (x1 * (t888 + py1 * (t322 + t143 + t245 + t887)) + py1 * t268)
			      + (t885 + t884) * t1)
		      + py0 * (y1 * (x1 * (t883 + px1 * t878 + t202 + t780 + t196)
				     + t641 + t731 + t189 + t730)
			       + x1 * (t639 + t230 + t229) + py1 * t29 * t169
			       + t1 * (t840 + px1 * t850 + t13 + t752 + t825))
		      + px0 * (y1 * (x1 * (py1 * t875 + t872 + t871 + t870)
				     + py1 * t869 + t866 + t865 + t864)
			       + py1 * x1 * t499 + py1 * t29 * t174
			       + t1 * (py1 * t838 + t829 + t828 + t827))
		      + y1 * (x1 * (t863 + py1 * (t247 + t772 + t244)) + t859 + py1 * t723)
		      + py0 * t161 * t183 + py1 * t29 * t160 + py1 * x1 * t152
		      + t14 * (px0 * (x1 * (py1 * t855 + t853 + t852 + t851)
				      + py1 * t850 + py1 * t29 * t109 + t820 + t819 + t818
				      + (py1 * t592 + t826 + py1 * x1 * t646 + t847 + t846) * y1)
			       + py0 * (x1 * (t845 + px1 * t844 + t54 + t282 + t841)
					+ t840 + px1 * t838 + py1 * t29 * t76 + t46 + t659 + t816
					+ (t421 + t431 + x1 * (t836 + t26 + t94 + t96) + t27 + t661) * y1)
			       + x1 * (py1 * (t325 + t125 + t835) + t834) + t830
			       + py1 * (t13 + t752 + t825) + py1 * t29 * t36
			       + (t824 + py1 * t748 + py1 * x1 * t21) * y1)
		      + t1 * (t821 + py1 * (t46 + t659 + t816)))
	;

    trans->m[1][1] = (t161 * (px0 * (x1 * (py1 * t603 + t911 + t910 + t909)
				     + py1 * t980 + t872
				     + y1 * (py1 * t944 + py1 * x1 * t109 + t833 + t832 + t831) + t871
				     + t870 + py1 * t646 * t1)
			      + py0 * (x1 * (t514 + t157 + t364 + t363)
				       + px1 * t974 + t202
				       + y1 * (x1 * (t917 + t153 + t55 + t339)
					       + t943 + px1 * t955 + t143 + t124 + t938) + t978 + t725
				       + t196 + py1 * t66 * t1) + x1 * (t930 + py1 * t775) + t863
			      + py1 * (t773 + t283 + t771)
			      + y1 * (py1 * (t58 + t144 + t942) + t888 + py1 * x1 * t36)
			      + py1 * t21 * t1)
		      + x0 * (py0 * (t29 * (t604 + t149 + t346 + t774)
				     + t984 + t190
				     + y1 * (x1 * (px1 * t972 + t970 + t313 + t144 + t960)
					     + px1 * t958 + t950 + t787 + t12 + t939)
				     + x1 * (t607 + t983 + py1 * y2 * (x2 * (t328 + t88) + t293 + t327))
				     + t189 + t188 + py1 * t650 * t1)
			      + px0 * (t29 * t925 + t982 + t866
				       + y1
				       * (x1 * (py1 * t969 + t853 + t852 + t851)
					  + py1 * t947 + t829 + t828 + t827)
				       + py1 * x1 * y2 * t334 + t865 + t864 + py1 * t651 * t1)
			      + t29 * t913 + t859 + t981
			      + y1 * (x1 * (t834 + py1 * (t633 + t54 + t272 + t968))
				      + py1 * (t946 + t46 + t945) + t821) + py1 * x1 * y2 * t606
			      + py1 * t737 * t1)
		      + py0 * (x1 * (t573 + t238 + t237 + t236)
			       + t29 * (px1 * t980 + t773 + t978 + t283 + t771)
			       + y1 * (x1 * (t965 + px1 * t971 + t765 + t659 + t959) + t550 + t670 + t669)
			       + py1 * t537 * t1)
		      + px0 * (x1 * (py1 * t977 + t858 + t857 + t856)
			       + t29 * (py1 * t974 + t862 + t861 + t860)
			       + y1 * (x1 * (py1 * t966 + t820 + t819 + t818) + t973) + py1 * t539 * t1)
		      + x1 * (t890 + py1 * t191) + t29 * (t891 + py1 * (t202 + t725 + t196))
		      + y0 * (x0 * (px0 * (x1 * (py1 * t972 + t833 + t832 + t831)
					   + py1 * t971 + py1 * t29 * t916 + t829 + t828 + t827
					   + (t926 + t817 + py1 * x1 * t693 + t823 + t822) * y1)
				    + py0 * (x1 * (t970 + px1 * t969 + t633 + t54 + t272 + t968)
					     + px1 * t966 + t965 + t29 * (t163 + t35 + t34 + t33) + t753 + t12
					     + t935
					     + (t962 + t941 + t43
						+ x1
						* (t836 + py1 * (t86 + t628 + (t961 + t291) * x2)
						   + t26 + t94 + t96) + t95 + t93)
					     * y1) + x1 * (py1 * (t313 + t144 + t960) + t888) + t821
				    + py1 * (t765 + t659 + t959) + py1 * t29 * t340
				    + (t885 + t884 + py1 * x1 * t338) * y1)
			      + px0 * (x1 * (py1 * t958 + t820 + t819 + t818)
				       + t956 + t29 * (py1 * t955 + t853 + t852 + t851)
				       + (py1 * t415 + x1 * t953) * y1)
			      + py0 * (x1 * (t950 + px1 * t947 + t946 + t46 + t945)
				       + t29 * (px1 * t944 + t943 + t58 + t144 + t942) + t406 + t392 + t391
				       + (x1 * (t421 + t941 + t431 + t27 + t661)
					  + t416 + py1 * (x2 * (t554 + t796) + t5 * t940) + t665 + t664)
				       * y1) + x1 * (py1 * (t787 + t12 + t939) + t830)
			      + t29 * (t834 + py1 * (t143 + t124 + t938)) + t937
			      + (x1 * t936 + py1 * t666) * y1)
		      + y1 * (x1 * (py1 * (t753 + t12 + t935) + t830) + t934) + py1 * t653 * t1
		      + py0 * t652 * t14)
	;

    trans->m[1][2] = (y0 * (x0 * (px0 * (x1 * (py1 * t1016 + t872 + t871 + t870)
					 + py1 * t494 + t29 * t932
					 + y1
					 * (py1 * t1025 + py1 * x1 * t599 + t820 + t819
					    + t818) + t953 * t1)
				  + py0 * (x1 * (t1015 + px1 * t1009 + t727 + t326 + t724)
					   + t29 * (t1028 + t148 + t364 + t744) + t491
					   + y1
					   * (x1
					      * (t600 + py1 * (x2 * t933 + t940 * y2) + t503
						 + t800)
					      + px1 * t1020 + t1026 + t676 + t45 + t1017)
					   + (t1027 + t10 + t27 + t25) * t1)
				  + x1 * (py1 * (t1014 + t283 + t1012) + t863) + t29 * t931
				  + py1 * t802
				  + y1 * (py1 * x1 * t801 + py1 * (t1024 + t13 + t1023) + t830)
				  + t936 * t1)
			    + py0 * (t29 * (t1007 + px1 * t1002 + t727 + t201 + t724)
				     + x1 * (t1011 + t641 + t731 + t189 + t730)
				     + y1 * (x1 * (t1026 + px1 * t1025 + t1024 + t13 + t1023)
					     + t550
					     + py1
					     * (t5 * (t293 + t327) + x2 * (t1021 + t697) * y2)
					     + t670 + t669) + (t540 + t648 + t645) * t1)
			    + px0 * (x1 * (t982 + t866 + t865 + t864)
				     + t29 * (py1 * t1006 + t872 + t871 + t870)
				     + y1 * (x1 * (py1 * t1020 + t829 + t828 + t827) + t956)
				     + py1 * t415 * t1) + x1 * (t859 + t981)
			    + t29 * (t863 + py1 * (t773 + t246 + t771))
			    + y1 * (x1 * (py1 * (t676 + t45 + t1017) + t821) + t937)
			    + py1 * t666 * t1)
		      + x0 * (py0 * (y1 * (x1 * (px1 * t1016 + t1015 + t1014 + t283 + t1012)
					   + t1011 + t573 + t238 + t237 + t236)
				     + x1 * (t639
					     + py1 * (x2 * y2 * (t1010 + t300) + t142 * t894)
					     + t230 + t229) + t29 * (t175 + t159 + t155)
				     + t1 * (px1 * t1000 + t994 + t660 + t45 + t986))
			      + px0 * (y1 * (x1 * (py1 * t1009 + t862 + t861 + t860)
					     + t927 + t858 + t857 + t856)
				       + py1 * t29 * t515 + py1 * x1 * t638
				       + t1 * (py1 * t993 + t820 + t819 + t818))
			      + y1 * (x1 * (t891 + py1 * (t727 + t326 + t724)) + t890 + t889)
			      + py1 * x1 * t374 + py1 * t29 * t373
			      + t1 * (t830 + py1 * (t705 + t752 + t990)))
		      + t161 * (py0 * (x1 * (t516 + t372 + t371)
				       + y1
				       * (x1 * (t921 + t156 + t346 + t345)
					  + t1007 + px1 * t1006 + t773 + t246 + t771) + t381
				       + t1 * (t989 + px1 * t997 + t54 + t245 + t985))
				+ px0 * (y1
					 * (x1 * (py1 * t1004 + t924 + t923 + t922)
					    + py1 * t1002 + t862 + t861 + t860)
					 + py1 * t499 + py1 * x1 * t174
					 + t1 * (py1 * t988 + t853 + t852 + t851))
				+ y1 * (x1 * (t912 + py1 * t746) + t891
					+ py1 * (t727 + t201 + t724))
				+ py1 * x1 * t160 + py1 * t152
				+ t1 * (t834 + py1 * (t143 + t272 + t987))) + py0 * t770
		      + t14 * (px0 * (x1 * (py1 * t1000 + t829 + t828 + t827)
				      + t973 + t29 * (py1 * t997 + t833 + t832 + t831)
				      + (py1 * t539 + x1 * (py1 * t996 + t817 + t823 + t822))
				      * y1)
			       + py0 * (x1 * (t994 + px1 * t993 + t705 + t752 + t990)
					+ t29 * (t989 + px1 * t988 + t143 + t272 + t987) + t398
					+ (t416 + x1 * (t962 + t43 + t95 + t93) + t665 + t664)
					* y1) + x1 * (py1 * (t660 + t45 + t986) + t821)
			       + t29 * (t888 + py1 * (t54 + t245 + t985)) + t934
			       + (x1 * (t885 + py1 * t28) + py1 * t653) * y1));

    trans->m[2][0] = (x0 * (px0 * (y1 * (x1 * t617 + t586 + t877 + t1008 + t876)
				   + x1 * t515 + t637 + t1 * (t475 + t136 + t620 + t1036) + t636)
			    + py0 * (y1 * (t579 + x1 * t627 + t251 + t811 + t248)
				     + x1 * t379 + t233 + t1 * (t455 + t87 + t298 + t1035) + t232)
			    + x1 * (t516 + t383 + y2 * (t804 + t1013) + t142 * t595)
			    + y1 * (px1 * (t1047 + t979 + t1046)
				    + x1 * (t921 + t368 + t157 + t156 + t1048)
				    + py1 * (t1044 + t728 + t1043) + t505 + t607 + t502) + t500 + t381
			    + t1 * (px1 * (t611 + t135 + t1038) + py1 * (t330 + t128 + t1037) + t423
				    + t125 + t54 + t1034))
		      + y0 * (x0 * (py0 * (x1 * t1050 + t533 + t226
					   + y1 * (t529 + t224 + x1 * t349 + t128 + t1040)
					   + t781 + t220 + t99 * t1)
				    + px0 * (t528 + x1 * t1049 + t874
					     + y1 * (t517 + x1 * t916 + t520 + t135 + t1041) + t1005
					     + t873 + t693 * t1)
				    + x1 * (t514 + t382 + t157 + t156 + t1048)
				    + px1 * (t877 + t1001 + t876) + py1 * (t251 + t776 + t248) + t608
				    + y1 * (x1 * (t917 + t358 + t56 + t323 + (t716 + t967) * y2)
					    + px1 * (t118 + t609 + t471 + t1045)
					    + py1 * (t204 + t327 + t249 + t1042) + t503 + t144 + t143
					    + t1039) + t504 + t605 + (t647 + t357) * t1)
			      + px0 * (x1 * (t528 + t1047 + t979 + t1046)
				       + t643 + t29 * t182 + t571
				       + y1 * (x1 * (t475 + t118 + t609 + t471 + t1045) + t701 + t895)
				       + t570 + t569 + (t468 + t441 + t466 + t951) * t1)
			      + py0 * (x1 * (t533 + t1044 + t728 + t1043)
				       + t642 + t29 * t179 + t566
				       + y1 * (x1 * (t455 + t204 + t327 + t249 + t1042) + t289 + t288)
				       + t214 + t565 + (t436 + t450 + t69 + t677) * t1)
			      + x1 * (px1 * (t877 + t1008 + t876) + py1 * (t251 + t811 + t248) + t505
				      + t607 + t502) + t984 + t743
			      + t29 * t274
			      + y1 * (x1 * (px1 * (t520 + t135 + t1041) + py1 * (t224 + t128 + t1040)
					    + t503 + t144 + t143 + t1039)
				      + t897 + t303 + x2 * t634 + x2 * (t690 + t52) * y2)
			      + (t1027 + t808) * t1)
		      + py0 * (y1 * (x1 * (t579 + t251 + t776 + t248) + t581 + t735 + t240 + t734)
			       + t29 * t169 + x1 * t209 + t1 * (t461 + t80 + t683 + t1032))
		      + px0 * (y1 * (x1 * (t586 + t877 + t1001 + t876) + t591 + t976 + t588 + t975)
			       + x1 * t499 + t29 * t174 + t1 * (t484 + t849 + t957 + t1033))
		      + y1 * (x1 * (px1 * (t874 + t1005 + t873) + py1 * (t226 + t781 + t220) + t608
				    + t504 + t605)
			      + t573 + t568) + t161 * t183 + x1 * (t639 + t235) + t29 * t160
		      + t14 * (px0 * (x1 * (t517 + t611 + t135 + t1038)
				      + t615 + t29 * t109 + t560 + t443 + t1031
				      + (t399 + t613 + x1 * t646 + t418 + t995) * y1)
			       + py0 * (x1 * (t529 + t330 + t128 + t1037)
					+ t625 + t29 * t76 + t112 + t438 + t1030
					+ (t623 + t393 + t102 + x1 * t66 + t754) * y1)
			       + x1 * (px1 * (t136 + t620 + t1036) + py1 * (t87 + t298 + t1035) + t423
				       + t125 + t54 + t1034)
			       + px1 * (t849 + t957 + t1033) + py1 * (t80 + t683 + t1032) + t434
			       + t29 * t36 + t1029 + (t962 + t711 + x1 * (t836 + t100)) * y1)
		      + t1 * (px1 * (t560 + t443 + t1031) + py1 * (t112 + t438 + t1030) + t434
			      + t1029))
	;

    trans->m[2][1] = (t161 * (px0 * (x1 * (t616 + t180 + t512 + t1003)
				     + t586 + t510 + y1 * (t475 + t854 + x1 * t109 + t117 + t1062)
				     + t621 + t508 + t646 * t1)
			      + py0 * (t579 + x1 * (t177 + t626 + t354 + t778) + t507
				       + y1 * (t455 + x1 * t76 + t91 + t203 + t1061) + t299
				       + t506 + t66 * t1) + x1 * (t921 + t368)
			      + px1 * (t874 + t979 + t873) + py1 * (t226 + t728 + t220)
			      + y1 * (x1 * (t917 + t358) + px1 * (t118 + t843 + t1063)
				      + py1 * (t204 + t127 + t1065) + t423 + t144
				      + t143 + t1060) + t504 + t21 * t1)
		      + x0 * (py0 * (t29 * t1050 + t581 + t241
				     + y1
				     * (x1 * (t529 + t87 + t577 + t292 + t1070)
					+ t461 + t1057 + t80 + t1056) + x1 * y2 * t741 + t240
				     + t239 + t650 * t1)
			      + px0 * (t591 + t29 * t1049 + t589
				       + y1 * (x1 * (t517 + t136 + t306 + t428 + t1071)
					       + t484 + t1059 + t849 + t1058) + x1 * y2 * t334 + t588
				       + t587 + t651 * t1) + t29 * (t1028 + t809) + t903 + t321
			      + y1 * (x1 * (px1 * (t901 + t117 + t1072) + py1 * (t317 + t203 + t1073)
					    + t503 + t125 + t54 + t1069)
				      + px1 * (t1019 + t837 + t1064) + py1 * (t789 + t111 + t1066) + t267
				      + t433 + t1055)
			      + x1 * (y2 * (x2 * (t56 + t323) + t322 + t273) + t983 + t742) + t737 * t1)
		      + py0 * (x1 * (t642 + t215 + t214 + t213) + t29 * (t533 + t226 + t728 + t220)
			       + y1
			       * (x1 * (t625 + t758 + t111 + t1067)
				  + t396 + t395) + t537 * t1)
		      + px0 * (x1 * (t643 + t868 + t570 + t867) + t29 * (t528 + t874 + t979 + t873)
			       + y1
			       * (x1 * (t615 + t999 + t837 + t1068)
				  + t404 + t402) + t539 * t1)
		      + x1 * (t641 + t243)
		      + t29 * (px1 * (t510 + t621 + t508) + py1 * (t507 + t299 + t506) + t504)
		      + y0 * (x0 * (py0 * (x1 * (t455 + t317 + t203 + t1073)
					   + t461 + t29 * t349 + t767 + t683 + t1052
					   + (t436 + t450 + x1 * t99 + t69 + t677) * y1)
				    + px0 * (x1 * (t475 + t901 + t117 + t1072)
					     + t484 + t29 * t916 + t992 + t957 + t1053
					     + (t468 + t441 + t466 + x1 * t693 + t951) * y1)
				    + x1 * (px1 * (t136 + t306 + t428 + t1071)
					    + py1 * (t87 + t577 + t292 + t1070) + t503 + t125 + t54 + t1069)
				    + px1 * (t999 + t837 + t1068) + py1 * (t758 + t111 + t1067)
				    + t29 * (t163 + t162) + t434 + t553 + t1051
				    + (t421 + t104 + t431 + t43
				       + x1 * (t836 + t100 + t690 + t52 + (t270 + t886) * x2)
				       + t1054)
				    * y1)
			      + py0 * (x1 * (t625 + t789 + t111 + t1066)
				       + t29 * (t529 + t204 + t127 + t1065) + t544 + t543
				       + (x1 * t624 + t410 + t409) * y1)
			      + px0 * (x1 * (t615 + t1019 + t837 + t1064)
				       + t29 * (t517 + t118 + t843 + t1063) + t548 + t547
				       + (x1 * t614 + t414 + t413) * y1)
			      + t29 * (px1 * (t854 + t117 + t1062) + py1 * (t91 + t203 + t1061) + t423
				       + t144 + t143 + t1060)
			      + x1 * (px1 * (t1059 + t849 + t1058) + py1 * (t1057 + t80 + t1056) + t267
				      + t433 + t1055) + t406 + t398
			      + (t416 + x1 * (t962 + t711 + t431 + t43 + t1054) + t412
				 + x2 * (t793 + t1022) + t5 * t594)
			      * y1)
		      + y1 * (x1 * (px1 * (t992 + t957 + t1053) + py1 * (t767 + t683 + t1052) + t434
				    + t553 + t1051)
			      + t550 + t546) + t653 * t1 + t652 * t14)
	;
    trans->m[2][2] = t644;
}

static void
print_trans (const char *header, struct pixman_f_transform *trans)
{
    int i, j;
    double max;

    max = 0;

    printf ("%s\n", header);

    for (i = 0; i < 3; ++i)
    {
	for (j = 0; j < 3; ++j)
	{
	    double a = fabs (trans->m[i][j]);

	    if (a > max)
		max = a;
	}
    }

    if (max == 0.0)
	max = 1.0;

    for (i = 0; i < 3; ++i)
    {
	printf ("{ ");
	for (j = 0; j < 3; ++j)
	{
	    printf ("D2F (%.5f)%s", 16384 * (trans->m[i][j] / max), j == 2 ? "" : ", ");
	}

	printf ("},\n");
    }
}

int
main ()
{
    struct pixman_f_transform t;

#if 0
    quad_to_quad (75, 200,
		  325, 200,
		  450, 335,
		  -50, 335,

		  0, 0,
		  400, 0,
		  400, 400,
		  0, 400,

		  &t);
#endif
    quad_to_quad (
	1, 0,
	1, 2,
	2, 2,
	2, 0,

	1, 0,
	1, 112,
	2, 2,
	2, 0,

	&t);

    print_trans ("0->0", &t);

    return 0;
}