Home » Archimedes archive » Acorn Computing » 1995 02.adf » 9502 » Real3D/Poly5
Real3D/Poly5
This website contains an archive of files for the Acorn Electron, BBC Micro, Acorn Archimedes, Commodore 16 and Commodore 64 computers, which Dominic Ford has rescued from his private collection of floppy disks and cassettes.
Some of these files were originally commercial releases in the 1980s and 1990s, but they are now widely available online. I assume that copyright over them is no longer being asserted. If you own the copyright and would like files to be removed, please contact me.
Tape/disk: | Home » Archimedes archive » Acorn Computing » 1995 02.adf » 9502 |
Filename: | Real3D/Poly5 |
Read OK: | ✔ |
File size: | 1BEA bytes |
Load address: | 0000 |
Exec address: | 0000 |
File contents
10REM Fill any polygon 20REM Two-way lists and heap re-use 30REM ----------------------------- 40REM by Steve Turnbull 50REM (c) Acorn Computing 60REM ====================== 70 80MODE27:OFF:*FX4,1 90ON ERROR MODE MODE:REPORT:PRINT" at ";ERL:END 100PROCgrid 110 120PROCinitPolyData 130PROCoutlinePoly 140PROCmakeEdgeTable 150PROCfillPoly 160 170REPEAT UNTIL GET=32 180TRACE OFF 190*DESKTOP 200 210DEF PROCinitPolyData 220 RESTORE +0 230 READ N% 240 DIM v%(N%,2) 250 FOR V%=0 TO N%-1 260 READ v%(V%,0),v%(V%,1) 270 NEXT 280 290 heapsize%=&4000:hp%=0 300 DIM heap%heapsize% 310 320 REM === Edge Table === 330 340 edgeEntries%=my% DIV sy% 350 DIM ET% edgeEntries%*4 360 370 REM === Edge Table Entry === 380 P%=0:O%=heap% 390 [opt 6 400 .ET_next EQUD 0 410 .ET_edgeID EQUD 0 420 .ET_ymax EQUD 0 430 .ET_xmin EQUD 0 440 .ET_numerator EQUD 0 450 .ET_denominator EQUD 0 460 ]:ET_size=P% 470 480 REM === Active Edge List Entry === 490 P%=0:O%=heap% 500 [opt 6 510 .AEL_next EQUD 0 520 .AEL_prev EQUD 0 530 .AEL_edgeID EQUD 0 540 .AEL_ymax EQUD 0 550 .AEL_xcur EQUD 0 560 .AEL_numerator EQUD 0 570 .AEL_denominator EQUD 0 580 .AEL_increment EQUD 0 590 ]:AEL_size=P% 600 610 AEL_free%=0 620 630ENDPROC 640 650DATA 8 660DATA 14, 2 670DATA 4, 6 680DATA 4,18 690DATA 14,6 700DATA 26,24 710DATA 30,16 720DATA 28, 2 730DATA 22, 9 740 750DEF PROCoutlinePoly 760 LOCAL E%,F%:GCOL0,3 770 FOR E%=0 TO N%-1 780 F%=E%+1:IF F%>=N% F%-=N% 790 LINE FNx(v%(E%,0)),FNy(v%(E%,1)),FNx(v%(F%,0)),FNy(v%(F%,1)) 800 NEXT 810ENDPROC 820 830DEF PROCmakeEdgeTable 840 LOCAL E%,F%,P%,Q%,Y%,x0%,y0%,x1%,y1% 850 860 FOR Y%=0 TO edgeEntries%-1 :REM Zero the Edge Table 870 ET%!(Y%*4)=0 880 NEXT 890 900 FOR E%=0 TO N%-1 :REM Sort the start of each polygon edge 910 IF E%=N%-1 F%=0 ELSE F%=E%+1 920 x0%=v%(E%,0):y0%=v%(E%,1) 930 x1%=v%(F%,0):y1%=v%(F%,1) :REM We ignore horizontal lines 940 IF y1%<>y0% THEN 950 IF y1%<y0% SWAP y1%,y0%:SWAP x1%,x0% 960 Y%=y0%*4 970 P%=FNalloc(ET_size) 980 P%!ET_next = 0 990 P%!ET_edgeID = E% 1000 P%!ET_ymax = y1% 1010 P%!ET_xmin = x0% 1020 P%!ET_numerator = x1%-x0% 1030 P%!ET_denominator = y1%-y0% 1040 Q%=ET%!Y%:R%=0 1050 WHILE (P%!ET_xmin>Q%!ET_xmin) AND (Q%<>0) 1060 R%=Q% 1070 Q%=Q%!ET_next 1080 ENDWHILE 1090 IF R%=0 THEN 1100 P%!ET_next=ET%!Y% 1110 ET%!Y%=P% 1120 ELSE 1130 P%!ET_next=R%!ET_next 1140 R%!ET_next=P% 1150 ENDIF 1160 ENDIF 1170 NEXT 1180ENDPROC 1190 1200DEF PROCfillPoly 1210 LOCAL Y% 1220 Y%=0 1230 AEL_free%=0 1240 AEL_ptr%=0 1250 WHILE Y%<edgeEntries% 1260 PROCaddActiveEdges(Y%) 1270 PROCfillScanLine(Y%) 1280 Y%+=1 1290 PROCpruneScanLine(Y%) 1300 PROCincActiveEdges 1310 ENDWHILE 1320ENDPROC 1330 1340DEF PROCaddActiveEdges(Y%) 1350 LOCAL D%,O%,P%,Q%,R% 1360 O%=0 1370 P%=ET%!(Y%*4) 1380 Q%=AEL_ptr% 1390 WHILE P%>0 1400 R%=FNalloc_AEL : REM Create new entry for AEL 1410 R%!AEL_edgeID = P%!ET_edgeID 1420 R%!AEL_ymax = P%!ET_ymax 1430 R%!AEL_xcur = P%!ET_xmin 1440 R%!AEL_numerator = P%!ET_numerator 1450 R%!AEL_denominator = P%!ET_denominator 1460 R%!AEL_increment = P%!ET_denominator*SGN(P%!ET_numerator) 1470 R%!AEL_next = 0 1480 R%!AEL_prev = 0 1490 1500 IF Q%=0 THEN 1510 AEL_ptr%=R% 1520 Q%=R% 1530 ELSE 1540 IF R%!AEL_xcur<=Q%!AEL_xcur THEN 1550 S%=Q%!AEL_prev 1560 Q%!AEL_prev=R% 1570 R%!AEL_next=Q% 1580 IF S%<>0 THEN 1590 R%!AEL_prev=S% 1600 S%!AEL_next=R% 1610 ELSE 1620 AEL_ptr%=R% 1630 ENDIF 1640 Q%=R% 1650 ELSE 1660 WHILE (Q%!AEL_next<>0)AND(Q%!AEL_xcur<R%!AEL_xcur) 1670 Q%=Q%!AEL_next 1680 ENDWHILE 1690 IF Q%!AEL_xcur>=R%!AEL_xcur THEN 1700 S%=Q%!AEL_prev 1710 Q%!AEL_prev=R% 1720 R%!AEL_next=Q% 1730 R%!AEL_prev=S% 1740 S%!AEL_next=R% 1750 ELSE 1760 Q%!AEL_next=R% 1770 R%!AEL_prev=Q% 1780 Q%=R% 1790 ENDIF 1800 ENDIF 1810 ENDIF 1820 P%=P%!ET_next 1830 ENDWHILE 1840ENDPROC 1850 1860DEF PROCfillScanLine(Y%) 1870 LOCAL P%,Q%,x0%,x1%,inside% 1880 P%=AEL_ptr% 1890 WHILE P%<>0 1900 inside%=NOTinside% 1910 Q%=P% 1920 P%=P%!AEL_next 1930 IF inside% PROCfillSpan(Y%,Q%!AEL_xcur,P%!AEL_xcur) 1940 ENDWHILE 1950ENDPROC 1960 1970DEF PROCfillSpan(Y%,A%,B%) 1980 LOCAL X% 1990 FOR X%=A% TO B% 2000 PROCwritePixel(X%,Y%,5) 2010 NEXT 2020ENDPROC 2030 2040DEF PROCpruneScanLine(Y%) 2050 LOCAL P%,Q%,R% 2060 P%=AEL_ptr% 2070 WHILE P%<>0 2080 IF P%!AEL_ymax=Y% THEN 2090 Q%=P%!AEL_prev 2100 R%=P%!AEL_next 2110 2120 IF Q%<>0 THEN Q%!AEL_next=R% ELSE AEL_ptr%=R% 2130 IF R%<>0 THEN R%!AEL_prev=Q% 2140 2150 P%!AEL_prev=0 2160 P%!AEL_next=AEL_free% 2170 AEL_free%=P% 2180 2190 P%=R% 2200 ELSE 2210 P%=P%!AEL_next 2220 ENDIF 2230 ENDWHILE 2240ENDPROC 2250 2260DEF PROCincActiveEdges 2270 LOCAL D%,I%,N%,Q%,P%,S% 2280 P%=AEL_ptr% 2290 WHILE P%<>0 2300 N%=P%!AEL_numerator 2310 IF N%<>0 THEN 2320 S%=SGN N% 2330 D%=P%!AEL_denominator 2340 I%=P%!AEL_increment 2350 2360 I%+=N% 2370 WHILE (ABS I%)>=D% 2380 P%!AEL_xcur+=S% 2390 I%-=D%*S% 2400 ENDWHILE 2410 2420 P%!AEL_increment=I% 2430 ENDIF 2440 Q%=P% 2450 P%=P%!AEL_next 2460 IF Q%!AEL_prev<>0 PROCsortActiveEdge(Q%) 2470 ENDWHILE 2480ENDPROC 2490 2500DEF PROCsortActiveEdge(P%) 2510 LOCAL Q%,S%,T%,U% 2520 S%=P%!AEL_prev 2530 IF S%!AEL_xcur>P%!AEL_xcur THEN 2540 WHILE (S%<>AEL_ptr%)AND(S%!AEL_xcur>P%!AEL_xcur) 2550 S%=S%!AEL_prev 2560 ENDWHILE 2570 2580 T%=P%!AEL_prev 2590 U%=P%!AEL_next 2600 T%!AEL_next=U% 2610 IF U%<>0 U%!AEL_prev=T% 2620 2630 IF S%!AEL_xcur<P%!AEL_xcur THEN 2640 Q%=S%!AEL_next 2650 P%!AEL_prev=S% 2660 P%!AEL_next=Q% 2670 S%!AEL_next=P% 2680 IF Q%<>0 Q%!AEL_prev=P% 2690 ELSE 2700 S%!AEL_prev=P% 2710 P%!AEL_prev=0 2720 P%!AEL_next=S% 2730 AEL_ptr%=P% 2740 ENDIF 2750 ENDIF 2760ENDPROC 2770 2780====================================== 2790 2800DEF PROCdump_ET:CLS 2810 LOCAL P%,Y% 2820 FOR Y%=0 TO edgeEntries%-1 2830 P%=ET%!(Y%*4) 2840 IF P%<>0 THEN 2850 PRINT 'Y%; 2860 WHILE P%<>0 2870 PRINTTAB(10)P%!ET_xmin,P%!ET_ymax 2880 P%=P%!ET_next 2890 ENDWHILE 2900 ENDIF 2910 NEXT 2920ENDPROC 2930 2940DEF PROCdump_AEL(Y%) 2950 LOCAL P%,@% 2960 @%=&20208 2970 P%=AEL_ptr% 2980 PRINTTAB(0,0)Y% 2990 WHILE P%<>0 3000 PRINT P%!AEL_edgeID,P%!AEL_increment,P%!AEL_numerator,P%!AEL_denominator 3010 P%=P%!AEL_next 3020 ENDWHILE 3030 PRINTSPC80:IFGET 3040ENDPROC 3050 3060============================================ 3070 3080DEF FNalloc_AEL 3090 LOCAL P% 3100 IF AEL_free%=0 THEN 3110 P%=FNalloc(AEL_size) 3120 ELSE 3130 P%=AEL_free% 3140 AEL_free%=P%!AEL_next 3150 ENDIF 3160=P% 3170 3180 3190DEF FNalloc(S%)LOCAL P%:P%=heap%+hp%:hp%+=S%:IF hp%>heapsize% ERROR 99,"No more heap space" 3200=P% 3210 3220DEF PROCgrid 3230 mx%=1280 3240 my%=1024 3250 sx%=32 3260 sy%=32 3270 ox%=(mx%/sx%)DIV2-1 3280 oy%=(my%/sy%)DIV2-1 3290 FOR X%=0 TO mx%-1 STEP sx% 3300 LINE X%,0,X%,my%-1 3310 NEXT 3320 FOR Y%=0 TO my%-1 STEP sy% 3330 LINE 0,Y%,mx%,Y% 3340 NEXT 3350ENDPROC 3360 3370DEF PROCwritePixel(x%,y%,C%)GCOL3,C% 3380 CIRCLE FILL FNx(x%),FNy(y%),sx%/2 3390ENDPROC 3400 3410DEF FNx(X%)=X%*sx% 3420 3430DEF FNy(Y%)=Y%*sy%
� Fill any polygon #� Two-way lists and heap re-use #� ----------------------------- (� by Steve Turnbull 2� (c) Acorn Computing <� ====================== F P�27:�:*FX4,1 Z� � � �:�:�" at ";�:� d �grid n x�initPolyData ��outlinePoly ��makeEdgeTable � �fillPoly � �� � �=32 �� � �*DESKTOP � �� �initPolyData � � +0 � � N% � � v%(N%,2) � � V%=0 � N%-1 � v%(V%,0),v%(V%,1) � " heapsize%=&4000:hp%=0 , � heap%heapsize% 6 @ � === Edge Table === J T edgeEntries%=my% � sy% ^ � ET% edgeEntries%*4 h r � === Edge Table Entry === | P%=0:O%=heap% � [opt 6 � .ET_next EQUD 0 � .ET_edgeID EQUD 0 � .ET_ymax EQUD 0 � .ET_xmin EQUD 0 � .ET_numerator EQUD 0 � .ET_denominator EQUD 0 � ]:ET_size=P% � �& � === Active Edge List Entry === � P%=0:O%=heap% � [opt 6 � .AEL_next EQUD 0 .AEL_prev EQUD 0 .AEL_edgeID EQUD 0 .AEL_ymax EQUD 0 & .AEL_xcur EQUD 0 0 .AEL_numerator EQUD 0 : .AEL_denominator EQUD 0 D .AEL_increment EQUD 0 N ]:AEL_size=P% X b AEL_free%=0 l v� � �� 8 �� 14, 2 �� 4, 6 �� 4,18 � � 14,6 �� 26,24 �� 30,16 �� 28, 2 �� 22, 9 � �� �outlinePoly � � E%,F%:�0,3 � E%=0 � N%-1 F%=E%+1:� F%>=N% F%-=N% = � �x(v%(E%,0)),�y(v%(E%,1)),�x(v%(F%,0)),�y(v%(F%,1)) � *� 4 >� �makeEdgeTable H& � E%,F%,P%,Q%,Y%,x0%,y0%,x1%,y1% R \7 � Y%=0 � edgeEntries%-1 :� Zero the Edge Table f ET%!(Y%*4)=0 p � z �G � E%=0 � N%-1 :� Sort the start of each polygon edge � � E%=N%-1 F%=0 � F%=E%+1 �! x0%=v%(E%,0):y0%=v%(E%,1) �A x1%=v%(F%,0):y1%=v%(F%,1) :� We ignore horizontal lines � � y1%<>y0% � �+ � y1%<y0% Ȕ y1%,y0%:Ȕ x1%,x0% � Y%=y0%*4 � P%=�alloc(ET_size) �! P%!ET_next = 0 �" P%!ET_edgeID = E% �# P%!ET_ymax = y1% �# P%!ET_xmin = x0% �' P%!ET_numerator = x1%-x0% ' P%!ET_denominator = y1%-y0% Q%=ET%!Y%:R%=0 0 ȕ (P%!ET_xmin>Q%!ET_xmin) � (Q%<>0) $ R%=Q% . Q%=Q%!ET_next 8 � B � R%=0 � L! P%!ET_next=ET%!Y% V ET%!Y%=P% ` � j% P%!ET_next=R%!ET_next t R%!ET_next=P% ~ � � � � � �� � �� �fillPoly � � Y% � Y%=0 � AEL_free%=0 � AEL_ptr%=0 � ȕ Y%<edgeEntries% � �addActiveEdges(Y%) � �fillScanLine(Y%) Y%+=1 �pruneScanLine(Y%) �incActiveEdges � (� 2 <� �addActiveEdges(Y%) F � D%,O%,P%,Q%,R% P O%=0 Z P%=ET%!(Y%*4) d Q%=AEL_ptr% n ȕ P%>0 x6 R%=�alloc_AEL : � Create new entry for AEL �) R%!AEL_edgeID = P%!ET_edgeID �' R%!AEL_ymax = P%!ET_ymax �' R%!AEL_xcur = P%!ET_xmin �, R%!AEL_numerator = P%!ET_numerator �. R%!AEL_denominator = P%!ET_denominator �A R%!AEL_increment = P%!ET_denominator*�(P%!ET_numerator) � R%!AEL_next = 0 � R%!AEL_prev = 0 � � � Q%=0 � � AEL_ptr%=R% � Q%=R% � � ( � R%!AEL_xcur<=Q%!AEL_xcur � S%=Q%!AEL_prev Q%!AEL_prev=R% " R%!AEL_next=Q% , � S%<>0 � 6" R%!AEL_prev=S% @" S%!AEL_next=R% J � T AEL_ptr%=R% ^ � h Q%=R% r � |= ȕ (Q%!AEL_next<>0)�(Q%!AEL_xcur<R%!AEL_xcur) � Q%=Q%!AEL_next � � �, � Q%!AEL_xcur>=R%!AEL_xcur � �" S%=Q%!AEL_prev �" Q%!AEL_prev=R% �" R%!AEL_next=Q% �" R%!AEL_prev=S% �" S%!AEL_next=R% � � �" Q%!AEL_next=R% �" R%!AEL_prev=Q% � Q%=R% � � � � P%=P%!ET_next & � 0� : D� �fillScanLine(Y%) N � P%,Q%,x0%,x1%,inside% X P%=AEL_ptr% b ȕ P%<>0 l inside%=�inside% v Q%=P% � P%=P%!AEL_next �7 � inside% �fillSpan(Y%,Q%!AEL_xcur,P%!AEL_xcur) � � �� � �� �fillSpan(Y%,A%,B%) � � X% � � X%=A% � B% � �writePixel(X%,Y%,5) � � �� � �� �pruneScanLine(Y%) � P%,Q%,R% P%=AEL_ptr% ȕ P%<>0 � P%!AEL_ymax=Y% � * Q%=P%!AEL_prev 4 R%=P%!AEL_next > H2 � Q%<>0 � Q%!AEL_next=R% � AEL_ptr%=R% R$ � R%<>0 � R%!AEL_prev=Q% \ f P%!AEL_prev=0 p! P%!AEL_next=AEL_free% z AEL_free%=P% � � P%=R% � � � P%=P%!AEL_next � � � � �� � �� �incActiveEdges � � D%,I%,N%,Q%,P%,S% � P%=AEL_ptr% � ȕ P%<>0 � N%=P%!AEL_numerator � N%<>0 � S%=� N% ! D%=P%!AEL_denominator $ I%=P%!AEL_increment . 8 I%+=N% B ȕ (� I%)>=D% L P%!AEL_xcur+=S% V I%-=D%*S% ` � j t P%!AEL_increment=I% ~ � � Q%=P% � P%=P%!AEL_next �, � Q%!AEL_prev<>0 �sortActiveEdge(Q%) � � �� � �� �sortActiveEdge(P%) � � Q%,S%,T%,U% � S%=P%!AEL_prev �! � S%!AEL_xcur>P%!AEL_xcur � �5 ȕ (S%<>AEL_ptr%)�(S%!AEL_xcur>P%!AEL_xcur) � S%=S%!AEL_prev � T%=P%!AEL_prev U%=P%!AEL_next ( T%!AEL_next=U% 2 � U%<>0 U%!AEL_prev=T% < F% � S%!AEL_xcur<P%!AEL_xcur � P Q%=S%!AEL_next Z P%!AEL_prev=S% d P%!AEL_next=Q% n S%!AEL_next=P% x$ � Q%<>0 Q%!AEL_prev=P% � � � S%!AEL_prev=P% � P%!AEL_prev=0 � P%!AEL_next=S% � AEL_ptr%=P% � � � � �� � �*====================================== � �� �dump_ET:� � � P%,Y% � Y%=0 � edgeEntries%-1 P%=ET%!(Y%*4) � P%<>0 � " � 'Y%; , ȕ P%<>0 6( �10)P%!ET_xmin,P%!ET_ymax @ P%=P%!ET_next J � T � ^ � h� r |� �dump_AEL(Y%) � � P%,@% � @%=&20208 � P%=AEL_ptr% � �0,0)Y% � ȕ P%<>0 �L � P%!AEL_edgeID,P%!AEL_increment,P%!AEL_numerator,P%!AEL_denominator � P%=P%!AEL_next � � � �80:� �� � �0============================================ � � �alloc_AEL � P% � AEL_free%=0 � & P%=�alloc(AEL_size) 0 � : P%=AEL_free% D AEL_free%=P%!AEL_next N � X=P% b l vS� �alloc(S%)� P%:P%=heap%+hp%:hp%+=S%:� hp%>heapsize% � 99,"No more heap space" �=P% � �� �grid � mx%=1280 � my%=1024 � sx%=32 � sy%=32 � ox%=(mx%/sx%)�2-1 � oy%=(my%/sy%)�2-1 � � X%=0 � mx%-1 � sx% � � X%,0,X%,my%-1 � � � � Y%=0 � my%-1 � sy% � 0,Y%,mx%,Y% � � * � �writePixel(x%,y%,C%)�3,C% 4 ȏ Ȑ �x(x%),�y(y%),sx%/2 >� H R� �x(X%)=X%*sx% \ f� �y(Y%)=Y%*sy% �
00000000 0d 00 0a 16 f4 20 46 69 6c 6c 20 61 6e 79 20 70 |..... Fill any p| 00000010 6f 6c 79 67 6f 6e 0d 00 14 23 f4 20 54 77 6f 2d |olygon...#. Two-| 00000020 77 61 79 20 6c 69 73 74 73 20 61 6e 64 20 68 65 |way lists and he| 00000030 61 70 20 72 65 2d 75 73 65 0d 00 1e 23 f4 20 2d |ap re-use...#. -| 00000040 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d |----------------| 00000050 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0d 00 28 17 |------------..(.| 00000060 f4 20 62 79 20 53 74 65 76 65 20 54 75 72 6e 62 |. by Steve Turnb| 00000070 75 6c 6c 0d 00 32 19 f4 20 28 63 29 20 41 63 6f |ull..2.. (c) Aco| 00000080 72 6e 20 43 6f 6d 70 75 74 69 6e 67 0d 00 3c 1c |rn Computing..<.| 00000090 f4 20 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d |. ==============| 000000a0 3d 3d 3d 3d 3d 3d 3d 3d 0d 00 46 04 0d 00 50 10 |========..F...P.| 000000b0 eb 32 37 3a 87 3a 2a 46 58 34 2c 31 0d 00 5a 19 |.27:.:*FX4,1..Z.| 000000c0 ee 20 85 20 eb 20 eb 3a f6 3a f1 22 20 61 74 20 |. . . .:.:." at | 000000d0 22 3b 9e 3a e0 0d 00 64 09 f2 67 72 69 64 0d 00 |";.:...d..grid..| 000000e0 6e 04 0d 00 78 11 f2 69 6e 69 74 50 6f 6c 79 44 |n...x..initPolyD| 000000f0 61 74 61 0d 00 82 10 f2 6f 75 74 6c 69 6e 65 50 |ata.....outlineP| 00000100 6f 6c 79 0d 00 8c 12 f2 6d 61 6b 65 45 64 67 65 |oly.....makeEdge| 00000110 54 61 62 6c 65 0d 00 96 0d f2 66 69 6c 6c 50 6f |Table.....fillPo| 00000120 6c 79 0d 00 a0 04 0d 00 aa 0c f5 20 fd 20 a5 3d |ly......... . .=| 00000130 33 32 0d 00 b4 07 fc 20 87 0d 00 be 0c 2a 44 45 |32..... .....*DE| 00000140 53 4b 54 4f 50 0d 00 c8 04 0d 00 d2 13 dd 20 f2 |SKTOP......... .| 00000150 69 6e 69 74 50 6f 6c 79 44 61 74 61 0d 00 dc 0a |initPolyData....| 00000160 20 20 f7 20 2b 30 0d 00 e6 0a 20 20 f3 20 4e 25 | . +0.... . N%| 00000170 0d 00 f0 10 20 20 de 20 76 25 28 4e 25 2c 32 29 |.... . v%(N%,2)| 00000180 0d 00 fa 13 20 20 e3 20 56 25 3d 30 20 b8 20 4e |.... . V%=0 . N| 00000190 25 2d 31 0d 01 04 1b 20 20 20 20 f3 20 76 25 28 |%-1.... . v%(| 000001a0 56 25 2c 30 29 2c 76 25 28 56 25 2c 31 29 0d 01 |V%,0),v%(V%,1)..| 000001b0 0e 09 20 20 20 20 ed 0d 01 18 04 0d 01 22 1b 20 |.. .......". | 000001c0 20 68 65 61 70 73 69 7a 65 25 3d 26 34 30 30 30 | heapsize%=&4000| 000001d0 3a 68 70 25 3d 30 0d 01 2c 16 20 20 de 20 68 65 |:hp%=0..,. . he| 000001e0 61 70 25 68 65 61 70 73 69 7a 65 25 0d 01 36 04 |ap%heapsize%..6.| 000001f0 0d 01 40 1a 20 20 f4 20 3d 3d 3d 20 45 64 67 65 |..@. . === Edge| 00000200 20 54 61 62 6c 65 20 3d 3d 3d 0d 01 4a 04 0d 01 | Table ===..J...| 00000210 54 1c 20 20 65 64 67 65 45 6e 74 72 69 65 73 25 |T. edgeEntries%| 00000220 3d 6d 79 25 20 81 20 73 79 25 0d 01 5e 1a 20 20 |=my% . sy%..^. | 00000230 de 20 45 54 25 20 65 64 67 65 45 6e 74 72 69 65 |. ET% edgeEntrie| 00000240 73 25 2a 34 0d 01 68 04 0d 01 72 20 20 20 f4 20 |s%*4..h...r . | 00000250 3d 3d 3d 20 45 64 67 65 20 54 61 62 6c 65 20 45 |=== Edge Table E| 00000260 6e 74 72 79 20 3d 3d 3d 0d 01 7c 13 20 20 50 25 |ntry ===..|. P%| 00000270 3d 30 3a 4f 25 3d 68 65 61 70 25 0d 01 86 0c 20 |=0:O%=heap%.... | 00000280 20 5b 6f 70 74 20 36 0d 01 90 1f 20 20 2e 45 54 | [opt 6.... .ET| 00000290 5f 6e 65 78 74 20 20 20 20 20 20 20 20 45 51 55 |_next EQU| 000002a0 44 20 20 20 20 30 0d 01 9a 1f 20 20 2e 45 54 5f |D 0.... .ET_| 000002b0 65 64 67 65 49 44 20 20 20 20 20 20 45 51 55 44 |edgeID EQUD| 000002c0 20 20 20 20 30 0d 01 a4 1f 20 20 2e 45 54 5f 79 | 0.... .ET_y| 000002d0 6d 61 78 20 20 20 20 20 20 20 20 45 51 55 44 20 |max EQUD | 000002e0 20 20 20 30 0d 01 ae 1f 20 20 2e 45 54 5f 78 6d | 0.... .ET_xm| 000002f0 69 6e 20 20 20 20 20 20 20 20 45 51 55 44 20 20 |in EQUD | 00000300 20 20 30 0d 01 b8 1f 20 20 2e 45 54 5f 6e 75 6d | 0.... .ET_num| 00000310 65 72 61 74 6f 72 20 20 20 45 51 55 44 20 20 20 |erator EQUD | 00000320 20 30 0d 01 c2 1f 20 20 2e 45 54 5f 64 65 6e 6f | 0.... .ET_deno| 00000330 6d 69 6e 61 74 6f 72 20 45 51 55 44 20 20 20 20 |minator EQUD | 00000340 30 0d 01 cc 12 20 20 5d 3a 45 54 5f 73 69 7a 65 |0.... ]:ET_size| 00000350 3d 50 25 0d 01 d6 04 0d 01 e0 26 20 20 f4 20 3d |=P%.......& . =| 00000360 3d 3d 20 41 63 74 69 76 65 20 45 64 67 65 20 4c |== Active Edge L| 00000370 69 73 74 20 45 6e 74 72 79 20 3d 3d 3d 0d 01 ea |ist Entry ===...| 00000380 13 20 20 50 25 3d 30 3a 4f 25 3d 68 65 61 70 25 |. P%=0:O%=heap%| 00000390 0d 01 f4 0c 20 20 5b 6f 70 74 20 36 0d 01 fe 20 |.... [opt 6... | 000003a0 20 20 2e 41 45 4c 5f 6e 65 78 74 20 20 20 20 20 | .AEL_next | 000003b0 20 20 20 45 51 55 44 20 20 20 20 30 0d 02 08 20 | EQUD 0... | 000003c0 20 20 2e 41 45 4c 5f 70 72 65 76 20 20 20 20 20 | .AEL_prev | 000003d0 20 20 20 45 51 55 44 20 20 20 20 30 0d 02 12 20 | EQUD 0... | 000003e0 20 20 2e 41 45 4c 5f 65 64 67 65 49 44 20 20 20 | .AEL_edgeID | 000003f0 20 20 20 45 51 55 44 20 20 20 20 30 0d 02 1c 20 | EQUD 0... | 00000400 20 20 2e 41 45 4c 5f 79 6d 61 78 20 20 20 20 20 | .AEL_ymax | 00000410 20 20 20 45 51 55 44 20 20 20 20 30 0d 02 26 20 | EQUD 0..& | 00000420 20 20 2e 41 45 4c 5f 78 63 75 72 20 20 20 20 20 | .AEL_xcur | 00000430 20 20 20 45 51 55 44 20 20 20 20 30 0d 02 30 20 | EQUD 0..0 | 00000440 20 20 2e 41 45 4c 5f 6e 75 6d 65 72 61 74 6f 72 | .AEL_numerator| 00000450 20 20 20 45 51 55 44 20 20 20 20 30 0d 02 3a 20 | EQUD 0..: | 00000460 20 20 2e 41 45 4c 5f 64 65 6e 6f 6d 69 6e 61 74 | .AEL_denominat| 00000470 6f 72 20 45 51 55 44 20 20 20 20 30 0d 02 44 20 |or EQUD 0..D | 00000480 20 20 2e 41 45 4c 5f 69 6e 63 72 65 6d 65 6e 74 | .AEL_increment| 00000490 20 20 20 45 51 55 44 20 20 20 20 30 0d 02 4e 13 | EQUD 0..N.| 000004a0 20 20 5d 3a 41 45 4c 5f 73 69 7a 65 3d 50 25 0d | ]:AEL_size=P%.| 000004b0 02 58 04 0d 02 62 11 20 20 41 45 4c 5f 66 72 65 |.X...b. AEL_fre| 000004c0 65 25 3d 30 0d 02 6c 04 0d 02 76 05 e1 0d 02 80 |e%=0..l...v.....| 000004d0 04 0d 02 8a 08 dc 20 20 38 0d 02 94 0b dc 20 31 |...... 8..... 1| 000004e0 34 2c 20 32 0d 02 9e 0b dc 20 20 34 2c 20 36 0d |4, 2..... 4, 6.| 000004f0 02 a8 0b dc 20 20 34 2c 31 38 0d 02 b2 0a dc 20 |.... 4,18..... | 00000500 31 34 2c 36 0d 02 bc 0b dc 20 32 36 2c 32 34 0d |14,6..... 26,24.| 00000510 02 c6 0b dc 20 33 30 2c 31 36 0d 02 d0 0b dc 20 |.... 30,16..... | 00000520 32 38 2c 20 32 0d 02 da 0b dc 20 32 32 2c 20 39 |28, 2..... 22, 9| 00000530 0d 02 e4 04 0d 02 ee 12 dd 20 f2 6f 75 74 6c 69 |......... .outli| 00000540 6e 65 50 6f 6c 79 0d 02 f8 12 20 20 ea 20 45 25 |nePoly.... . E%| 00000550 2c 46 25 3a e6 30 2c 33 0d 03 02 13 20 20 e3 20 |,F%:.0,3.... . | 00000560 45 25 3d 30 20 b8 20 4e 25 2d 31 0d 03 0c 1f 20 |E%=0 . N%-1.... | 00000570 20 20 20 46 25 3d 45 25 2b 31 3a e7 20 46 25 3e | F%=E%+1:. F%>| 00000580 3d 4e 25 20 46 25 2d 3d 4e 25 0d 03 16 3d 20 20 |=N% F%-=N%...= | 00000590 20 20 86 20 a4 78 28 76 25 28 45 25 2c 30 29 29 | . .x(v%(E%,0))| 000005a0 2c a4 79 28 76 25 28 45 25 2c 31 29 29 2c a4 78 |,.y(v%(E%,1)),.x| 000005b0 28 76 25 28 46 25 2c 30 29 29 2c a4 79 28 76 25 |(v%(F%,0)),.y(v%| 000005c0 28 46 25 2c 31 29 29 0d 03 20 09 20 20 20 20 ed |(F%,1)).. . .| 000005d0 0d 03 2a 05 e1 0d 03 34 04 0d 03 3e 14 dd 20 f2 |..*....4...>.. .| 000005e0 6d 61 6b 65 45 64 67 65 54 61 62 6c 65 0d 03 48 |makeEdgeTable..H| 000005f0 26 20 20 ea 20 45 25 2c 46 25 2c 50 25 2c 51 25 |& . E%,F%,P%,Q%| 00000600 2c 59 25 2c 78 30 25 2c 79 30 25 2c 78 31 25 2c |,Y%,x0%,y0%,x1%,| 00000610 79 31 25 0d 03 52 04 0d 03 5c 37 20 20 e3 20 59 |y1%..R...\7 . Y| 00000620 25 3d 30 20 b8 20 65 64 67 65 45 6e 74 72 69 65 |%=0 . edgeEntrie| 00000630 73 25 2d 31 20 20 20 20 3a f4 20 5a 65 72 6f 20 |s%-1 :. Zero | 00000640 74 68 65 20 45 64 67 65 20 54 61 62 6c 65 0d 03 |the Edge Table..| 00000650 66 14 20 20 20 20 45 54 25 21 28 59 25 2a 34 29 |f. ET%!(Y%*4)| 00000660 3d 30 0d 03 70 09 20 20 20 20 ed 0d 03 7a 04 0d |=0..p. ...z..| 00000670 03 84 47 20 20 e3 20 45 25 3d 30 20 b8 20 4e 25 |..G . E%=0 . N%| 00000680 2d 31 20 20 20 20 20 20 20 20 20 20 20 20 20 20 |-1 | 00000690 3a f4 20 53 6f 72 74 20 74 68 65 20 73 74 61 72 |:. Sort the star| 000006a0 74 20 6f 66 20 65 61 63 68 20 70 6f 6c 79 67 6f |t of each polygo| 000006b0 6e 20 65 64 67 65 0d 03 8e 20 20 20 20 20 e7 20 |n edge... . | 000006c0 45 25 3d 4e 25 2d 31 20 46 25 3d 30 20 8b 20 46 |E%=N%-1 F%=0 . F| 000006d0 25 3d 45 25 2b 31 0d 03 98 21 20 20 20 20 78 30 |%=E%+1...! x0| 000006e0 25 3d 76 25 28 45 25 2c 30 29 3a 79 30 25 3d 76 |%=v%(E%,0):y0%=v| 000006f0 25 28 45 25 2c 31 29 0d 03 a2 41 20 20 20 20 78 |%(E%,1)...A x| 00000700 31 25 3d 76 25 28 46 25 2c 30 29 3a 79 31 25 3d |1%=v%(F%,0):y1%=| 00000710 76 25 28 46 25 2c 31 29 20 20 20 3a f4 20 57 65 |v%(F%,1) :. We| 00000720 20 69 67 6e 6f 72 65 20 68 6f 72 69 7a 6f 6e 74 | ignore horizont| 00000730 61 6c 20 6c 69 6e 65 73 0d 03 ac 14 20 20 20 20 |al lines.... | 00000740 e7 20 79 31 25 3c 3e 79 30 25 20 8c 0d 03 b6 2b |. y1%<>y0% ....+| 00000750 20 20 20 20 20 20 20 20 e7 20 79 31 25 3c 79 30 | . y1%<y0| 00000760 25 20 c8 94 20 79 31 25 2c 79 30 25 3a c8 94 20 |% .. y1%,y0%:.. | 00000770 78 31 25 2c 78 30 25 0d 03 c0 14 20 20 20 20 20 |x1%,x0%.... | 00000780 20 20 20 59 25 3d 79 30 25 2a 34 0d 03 ca 1e 20 | Y%=y0%*4.... | 00000790 20 20 20 20 20 20 20 50 25 3d a4 61 6c 6c 6f 63 | P%=.alloc| 000007a0 28 45 54 5f 73 69 7a 65 29 0d 03 d4 21 20 20 20 |(ET_size)...! | 000007b0 20 20 20 20 20 50 25 21 45 54 5f 6e 65 78 74 20 | P%!ET_next | 000007c0 20 20 20 20 20 20 20 3d 20 30 0d 03 de 22 20 20 | = 0..." | 000007d0 20 20 20 20 20 20 50 25 21 45 54 5f 65 64 67 65 | P%!ET_edge| 000007e0 49 44 20 20 20 20 20 20 3d 20 45 25 0d 03 e8 23 |ID = E%...#| 000007f0 20 20 20 20 20 20 20 20 50 25 21 45 54 5f 79 6d | P%!ET_ym| 00000800 61 78 20 20 20 20 20 20 20 20 3d 20 79 31 25 0d |ax = y1%.| 00000810 03 f2 23 20 20 20 20 20 20 20 20 50 25 21 45 54 |..# P%!ET| 00000820 5f 78 6d 69 6e 20 20 20 20 20 20 20 20 3d 20 78 |_xmin = x| 00000830 30 25 0d 03 fc 27 20 20 20 20 20 20 20 20 50 25 |0%...' P%| 00000840 21 45 54 5f 6e 75 6d 65 72 61 74 6f 72 20 20 20 |!ET_numerator | 00000850 3d 20 78 31 25 2d 78 30 25 0d 04 06 27 20 20 20 |= x1%-x0%...' | 00000860 20 20 20 20 20 50 25 21 45 54 5f 64 65 6e 6f 6d | P%!ET_denom| 00000870 69 6e 61 74 6f 72 20 3d 20 79 31 25 2d 79 30 25 |inator = y1%-y0%| 00000880 0d 04 10 1a 20 20 20 20 20 20 20 20 51 25 3d 45 |.... Q%=E| 00000890 54 25 21 59 25 3a 52 25 3d 30 0d 04 1a 30 20 20 |T%!Y%:R%=0...0 | 000008a0 20 20 20 20 20 20 c8 95 20 28 50 25 21 45 54 5f | .. (P%!ET_| 000008b0 78 6d 69 6e 3e 51 25 21 45 54 5f 78 6d 69 6e 29 |xmin>Q%!ET_xmin)| 000008c0 20 80 20 28 51 25 3c 3e 30 29 0d 04 24 13 20 20 | . (Q%<>0)..$. | 000008d0 20 20 20 20 20 20 20 20 52 25 3d 51 25 0d 04 2e | R%=Q%...| 000008e0 1b 20 20 20 20 20 20 20 20 20 20 51 25 3d 51 25 |. Q%=Q%| 000008f0 21 45 54 5f 6e 65 78 74 0d 04 38 0f 20 20 20 20 |!ET_next..8. | 00000900 20 20 20 20 20 20 ce 0d 04 42 14 20 20 20 20 20 | ...B. | 00000910 20 20 20 e7 20 52 25 3d 30 20 8c 0d 04 4c 21 20 | . R%=0 ...L! | 00000920 20 20 20 20 20 20 20 20 20 20 20 50 25 21 45 54 | P%!ET| 00000930 5f 6e 65 78 74 3d 45 54 25 21 59 25 0d 04 56 19 |_next=ET%!Y%..V.| 00000940 20 20 20 20 20 20 20 20 20 20 20 20 45 54 25 21 | ET%!| 00000950 59 25 3d 50 25 0d 04 60 0f 20 20 20 20 20 20 20 |Y%=P%..`. | 00000960 20 20 20 cc 0d 04 6a 25 20 20 20 20 20 20 20 20 | ...j% | 00000970 20 20 20 20 50 25 21 45 54 5f 6e 65 78 74 3d 52 | P%!ET_next=R| 00000980 25 21 45 54 5f 6e 65 78 74 0d 04 74 1d 20 20 20 |%!ET_next..t. | 00000990 20 20 20 20 20 20 20 20 20 52 25 21 45 54 5f 6e | R%!ET_n| 000009a0 65 78 74 3d 50 25 0d 04 7e 0f 20 20 20 20 20 20 |ext=P%..~. | 000009b0 20 20 20 20 cd 0d 04 88 0b 20 20 20 20 20 20 cd | ..... .| 000009c0 0d 04 92 09 20 20 20 20 ed 0d 04 9c 05 e1 0d 04 |.... ........| 000009d0 a6 04 0d 04 b0 0f dd 20 f2 66 69 6c 6c 50 6f 6c |....... .fillPol| 000009e0 79 0d 04 ba 0a 20 20 ea 20 59 25 0d 04 c4 0a 20 |y.... . Y%.... | 000009f0 20 59 25 3d 30 0d 04 ce 11 20 20 41 45 4c 5f 66 | Y%=0.... AEL_f| 00000a00 72 65 65 25 3d 30 0d 04 d8 10 20 20 41 45 4c 5f |ree%=0.... AEL_| 00000a10 70 74 72 25 3d 30 0d 04 e2 18 20 20 c8 95 20 59 |ptr%=0.... .. Y| 00000a20 25 3c 65 64 67 65 45 6e 74 72 69 65 73 25 0d 04 |%<edgeEntries%..| 00000a30 ec 1b 20 20 20 20 f2 61 64 64 41 63 74 69 76 65 |.. .addActive| 00000a40 45 64 67 65 73 28 59 25 29 0d 04 f6 19 20 20 20 |Edges(Y%).... | 00000a50 20 f2 66 69 6c 6c 53 63 61 6e 4c 69 6e 65 28 59 | .fillScanLine(Y| 00000a60 25 29 0d 05 00 0d 20 20 20 20 59 25 2b 3d 31 0d |%).... Y%+=1.| 00000a70 05 0a 1a 20 20 20 20 f2 70 72 75 6e 65 53 63 61 |... .pruneSca| 00000a80 6e 4c 69 6e 65 28 59 25 29 0d 05 14 17 20 20 20 |nLine(Y%).... | 00000a90 20 f2 69 6e 63 41 63 74 69 76 65 45 64 67 65 73 | .incActiveEdges| 00000aa0 0d 05 1e 09 20 20 20 20 ce 0d 05 28 05 e1 0d 05 |.... ...(....| 00000ab0 32 04 0d 05 3c 19 dd 20 f2 61 64 64 41 63 74 69 |2...<.. .addActi| 00000ac0 76 65 45 64 67 65 73 28 59 25 29 0d 05 46 16 20 |veEdges(Y%)..F. | 00000ad0 20 ea 20 44 25 2c 4f 25 2c 50 25 2c 51 25 2c 52 | . D%,O%,P%,Q%,R| 00000ae0 25 0d 05 50 0a 20 20 4f 25 3d 30 0d 05 5a 13 20 |%..P. O%=0..Z. | 00000af0 20 50 25 3d 45 54 25 21 28 59 25 2a 34 29 0d 05 | P%=ET%!(Y%*4)..| 00000b00 64 11 20 20 51 25 3d 41 45 4c 5f 70 74 72 25 0d |d. Q%=AEL_ptr%.| 00000b10 05 6e 0d 20 20 c8 95 20 50 25 3e 30 0d 05 78 36 |.n. .. P%>0..x6| 00000b20 20 20 20 20 52 25 3d a4 61 6c 6c 6f 63 5f 41 45 | R%=.alloc_AE| 00000b30 4c 20 20 20 20 20 3a 20 f4 20 43 72 65 61 74 65 |L : . Create| 00000b40 20 6e 65 77 20 65 6e 74 72 79 20 66 6f 72 20 41 | new entry for A| 00000b50 45 4c 0d 05 82 29 20 20 20 20 52 25 21 41 45 4c |EL...) R%!AEL| 00000b60 5f 65 64 67 65 49 44 20 20 20 20 20 20 3d 20 50 |_edgeID = P| 00000b70 25 21 45 54 5f 65 64 67 65 49 44 0d 05 8c 27 20 |%!ET_edgeID...' | 00000b80 20 20 20 52 25 21 41 45 4c 5f 79 6d 61 78 20 20 | R%!AEL_ymax | 00000b90 20 20 20 20 20 20 3d 20 50 25 21 45 54 5f 79 6d | = P%!ET_ym| 00000ba0 61 78 0d 05 96 27 20 20 20 20 52 25 21 41 45 4c |ax...' R%!AEL| 00000bb0 5f 78 63 75 72 20 20 20 20 20 20 20 20 3d 20 50 |_xcur = P| 00000bc0 25 21 45 54 5f 78 6d 69 6e 0d 05 a0 2c 20 20 20 |%!ET_xmin..., | 00000bd0 20 52 25 21 41 45 4c 5f 6e 75 6d 65 72 61 74 6f | R%!AEL_numerato| 00000be0 72 20 20 20 3d 20 50 25 21 45 54 5f 6e 75 6d 65 |r = P%!ET_nume| 00000bf0 72 61 74 6f 72 0d 05 aa 2e 20 20 20 20 52 25 21 |rator.... R%!| 00000c00 41 45 4c 5f 64 65 6e 6f 6d 69 6e 61 74 6f 72 20 |AEL_denominator | 00000c10 3d 20 50 25 21 45 54 5f 64 65 6e 6f 6d 69 6e 61 |= P%!ET_denomina| 00000c20 74 6f 72 0d 05 b4 41 20 20 20 20 52 25 21 41 45 |tor...A R%!AE| 00000c30 4c 5f 69 6e 63 72 65 6d 65 6e 74 20 20 20 3d 20 |L_increment = | 00000c40 50 25 21 45 54 5f 64 65 6e 6f 6d 69 6e 61 74 6f |P%!ET_denominato| 00000c50 72 2a b4 28 50 25 21 45 54 5f 6e 75 6d 65 72 61 |r*.(P%!ET_numera| 00000c60 74 6f 72 29 0d 05 be 1e 20 20 20 20 52 25 21 41 |tor).... R%!A| 00000c70 45 4c 5f 6e 65 78 74 20 20 20 20 20 20 20 20 3d |EL_next =| 00000c80 20 30 0d 05 c8 1e 20 20 20 20 52 25 21 41 45 4c | 0.... R%!AEL| 00000c90 5f 70 72 65 76 20 20 20 20 20 20 20 20 3d 20 30 |_prev = 0| 00000ca0 0d 05 d2 04 0d 05 dc 10 20 20 20 20 e7 20 51 25 |........ . Q%| 00000cb0 3d 30 20 8c 0d 05 e6 17 20 20 20 20 20 20 20 20 |=0 ..... | 00000cc0 41 45 4c 5f 70 74 72 25 3d 52 25 0d 05 f0 11 20 |AEL_ptr%=R%.... | 00000cd0 20 20 20 20 20 20 20 51 25 3d 52 25 0d 05 fa 0b | Q%=R%....| 00000ce0 20 20 20 20 20 20 cc 0d 06 04 28 20 20 20 20 20 | ....( | 00000cf0 20 20 20 e7 20 52 25 21 41 45 4c 5f 78 63 75 72 | . R%!AEL_xcur| 00000d00 3c 3d 51 25 21 41 45 4c 5f 78 63 75 72 20 8c 0d |<=Q%!AEL_xcur ..| 00000d10 06 0e 1e 20 20 20 20 20 20 20 20 20 20 20 20 53 |... S| 00000d20 25 3d 51 25 21 41 45 4c 5f 70 72 65 76 0d 06 18 |%=Q%!AEL_prev...| 00000d30 1e 20 20 20 20 20 20 20 20 20 20 20 20 51 25 21 |. Q%!| 00000d40 41 45 4c 5f 70 72 65 76 3d 52 25 0d 06 22 1e 20 |AEL_prev=R%..". | 00000d50 20 20 20 20 20 20 20 20 20 20 20 52 25 21 41 45 | R%!AE| 00000d60 4c 5f 6e 65 78 74 3d 51 25 0d 06 2c 19 20 20 20 |L_next=Q%..,. | 00000d70 20 20 20 20 20 20 20 20 20 e7 20 53 25 3c 3e 30 | . S%<>0| 00000d80 20 8c 0d 06 36 22 20 20 20 20 20 20 20 20 20 20 | ...6" | 00000d90 20 20 20 20 20 20 52 25 21 41 45 4c 5f 70 72 65 | R%!AEL_pre| 00000da0 76 3d 53 25 0d 06 40 22 20 20 20 20 20 20 20 20 |v=S%..@" | 00000db0 20 20 20 20 20 20 20 20 53 25 21 41 45 4c 5f 6e | S%!AEL_n| 00000dc0 65 78 74 3d 52 25 0d 06 4a 13 20 20 20 20 20 20 |ext=R%..J. | 00000dd0 20 20 20 20 20 20 20 20 cc 0d 06 54 1f 20 20 20 | ...T. | 00000de0 20 20 20 20 20 20 20 20 20 20 20 20 20 41 45 4c | AEL| 00000df0 5f 70 74 72 25 3d 52 25 0d 06 5e 13 20 20 20 20 |_ptr%=R%..^. | 00000e00 20 20 20 20 20 20 20 20 20 20 cd 0d 06 68 15 20 | ...h. | 00000e10 20 20 20 20 20 20 20 20 20 20 20 51 25 3d 52 25 | Q%=R%| 00000e20 0d 06 72 0f 20 20 20 20 20 20 20 20 20 20 cc 0d |..r. ..| 00000e30 06 7c 3d 20 20 20 20 20 20 20 20 20 20 20 20 c8 |.|= .| 00000e40 95 20 28 51 25 21 41 45 4c 5f 6e 65 78 74 3c 3e |. (Q%!AEL_next<>| 00000e50 30 29 80 28 51 25 21 41 45 4c 5f 78 63 75 72 3c |0).(Q%!AEL_xcur<| 00000e60 52 25 21 41 45 4c 5f 78 63 75 72 29 0d 06 86 20 |R%!AEL_xcur)... | 00000e70 20 20 20 20 20 20 20 20 20 20 20 20 20 20 51 25 | Q%| 00000e80 3d 51 25 21 41 45 4c 5f 6e 65 78 74 0d 06 90 13 |=Q%!AEL_next....| 00000e90 20 20 20 20 20 20 20 20 20 20 20 20 20 20 ce 0d | ..| 00000ea0 06 9a 2c 20 20 20 20 20 20 20 20 20 20 20 20 e7 |.., .| 00000eb0 20 51 25 21 41 45 4c 5f 78 63 75 72 3e 3d 52 25 | Q%!AEL_xcur>=R%| 00000ec0 21 41 45 4c 5f 78 63 75 72 20 8c 0d 06 a4 22 20 |!AEL_xcur ...." | 00000ed0 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 53 | S| 00000ee0 25 3d 51 25 21 41 45 4c 5f 70 72 65 76 0d 06 ae |%=Q%!AEL_prev...| 00000ef0 22 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 |" | 00000f00 20 51 25 21 41 45 4c 5f 70 72 65 76 3d 52 25 0d | Q%!AEL_prev=R%.| 00000f10 06 b8 22 20 20 20 20 20 20 20 20 20 20 20 20 20 |.." | 00000f20 20 20 20 52 25 21 41 45 4c 5f 6e 65 78 74 3d 51 | R%!AEL_next=Q| 00000f30 25 0d 06 c2 22 20 20 20 20 20 20 20 20 20 20 20 |%..." | 00000f40 20 20 20 20 20 52 25 21 41 45 4c 5f 70 72 65 76 | R%!AEL_prev| 00000f50 3d 53 25 0d 06 cc 22 20 20 20 20 20 20 20 20 20 |=S%..." | 00000f60 20 20 20 20 20 20 20 53 25 21 41 45 4c 5f 6e 65 | S%!AEL_ne| 00000f70 78 74 3d 52 25 0d 06 d6 13 20 20 20 20 20 20 20 |xt=R%.... | 00000f80 20 20 20 20 20 20 20 cc 0d 06 e0 22 20 20 20 20 | ...." | 00000f90 20 20 20 20 20 20 20 20 20 20 20 20 51 25 21 41 | Q%!A| 00000fa0 45 4c 5f 6e 65 78 74 3d 52 25 0d 06 ea 22 20 20 |EL_next=R%..." | 00000fb0 20 20 20 20 20 20 20 20 20 20 20 20 20 20 52 25 | R%| 00000fc0 21 41 45 4c 5f 70 72 65 76 3d 51 25 0d 06 f4 19 |!AEL_prev=Q%....| 00000fd0 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 | | 00000fe0 51 25 3d 52 25 0d 06 fe 13 20 20 20 20 20 20 20 |Q%=R%.... | 00000ff0 20 20 20 20 20 20 20 cd 0d 07 08 0f 20 20 20 20 | ..... | 00001000 20 20 20 20 20 20 cd 0d 07 12 0b 20 20 20 20 20 | ..... | 00001010 20 cd 0d 07 1c 15 20 20 20 20 50 25 3d 50 25 21 | ..... P%=P%!| 00001020 45 54 5f 6e 65 78 74 0d 07 26 09 20 20 20 20 ce |ET_next..&. .| 00001030 0d 07 30 05 e1 0d 07 3a 04 0d 07 44 17 dd 20 f2 |..0....:...D.. .| 00001040 66 69 6c 6c 53 63 61 6e 4c 69 6e 65 28 59 25 29 |fillScanLine(Y%)| 00001050 0d 07 4e 1d 20 20 ea 20 50 25 2c 51 25 2c 78 30 |..N. . P%,Q%,x0| 00001060 25 2c 78 31 25 2c 69 6e 73 69 64 65 25 0d 07 58 |%,x1%,inside%..X| 00001070 11 20 20 50 25 3d 41 45 4c 5f 70 74 72 25 0d 07 |. P%=AEL_ptr%..| 00001080 62 0e 20 20 c8 95 20 50 25 3c 3e 30 0d 07 6c 18 |b. .. P%<>0..l.| 00001090 20 20 20 20 69 6e 73 69 64 65 25 3d ac 69 6e 73 | inside%=.ins| 000010a0 69 64 65 25 0d 07 76 0d 20 20 20 20 51 25 3d 50 |ide%..v. Q%=P| 000010b0 25 0d 07 80 16 20 20 20 20 50 25 3d 50 25 21 41 |%.... P%=P%!A| 000010c0 45 4c 5f 6e 65 78 74 0d 07 8a 37 20 20 20 20 e7 |EL_next...7 .| 000010d0 20 69 6e 73 69 64 65 25 20 f2 66 69 6c 6c 53 70 | inside% .fillSp| 000010e0 61 6e 28 59 25 2c 51 25 21 41 45 4c 5f 78 63 75 |an(Y%,Q%!AEL_xcu| 000010f0 72 2c 50 25 21 41 45 4c 5f 78 63 75 72 29 0d 07 |r,P%!AEL_xcur)..| 00001100 94 09 20 20 20 20 ce 0d 07 9e 05 e1 0d 07 a8 04 |.. ..........| 00001110 0d 07 b2 19 dd 20 f2 66 69 6c 6c 53 70 61 6e 28 |..... .fillSpan(| 00001120 59 25 2c 41 25 2c 42 25 29 0d 07 bc 0a 20 20 ea |Y%,A%,B%).... .| 00001130 20 58 25 0d 07 c6 12 20 20 e3 20 58 25 3d 41 25 | X%.... . X%=A%| 00001140 20 b8 20 42 25 0d 07 d0 1c 20 20 20 20 f2 77 72 | . B%.... .wr| 00001150 69 74 65 50 69 78 65 6c 28 58 25 2c 59 25 2c 35 |itePixel(X%,Y%,5| 00001160 29 0d 07 da 09 20 20 20 20 ed 0d 07 e4 05 e1 0d |).... .......| 00001170 07 ee 04 0d 07 f8 18 dd 20 f2 70 72 75 6e 65 53 |........ .pruneS| 00001180 63 61 6e 4c 69 6e 65 28 59 25 29 0d 08 02 10 20 |canLine(Y%).... | 00001190 20 ea 20 50 25 2c 51 25 2c 52 25 0d 08 0c 11 20 | . P%,Q%,R%.... | 000011a0 20 50 25 3d 41 45 4c 5f 70 74 72 25 0d 08 16 0e | P%=AEL_ptr%....| 000011b0 20 20 c8 95 20 50 25 3c 3e 30 0d 08 20 1a 20 20 | .. P%<>0.. . | 000011c0 20 20 e7 20 50 25 21 41 45 4c 5f 79 6d 61 78 3d | . P%!AEL_ymax=| 000011d0 59 25 20 8c 0d 08 2a 1a 20 20 20 20 20 20 20 20 |Y% ...*. | 000011e0 51 25 3d 50 25 21 41 45 4c 5f 70 72 65 76 0d 08 |Q%=P%!AEL_prev..| 000011f0 34 1a 20 20 20 20 20 20 20 20 52 25 3d 50 25 21 |4. R%=P%!| 00001200 41 45 4c 5f 6e 65 78 74 0d 08 3e 04 0d 08 48 32 |AEL_next..>...H2| 00001210 20 20 20 20 20 20 20 20 e7 20 51 25 3c 3e 30 20 | . Q%<>0 | 00001220 8c 20 51 25 21 41 45 4c 5f 6e 65 78 74 3d 52 25 |. Q%!AEL_next=R%| 00001230 20 8b 20 41 45 4c 5f 70 74 72 25 3d 52 25 0d 08 | . AEL_ptr%=R%..| 00001240 52 24 20 20 20 20 20 20 20 20 e7 20 52 25 3c 3e |R$ . R%<>| 00001250 30 20 8c 20 52 25 21 41 45 4c 5f 70 72 65 76 3d |0 . R%!AEL_prev=| 00001260 51 25 0d 08 5c 04 0d 08 66 19 20 20 20 20 20 20 |Q%..\...f. | 00001270 20 20 50 25 21 41 45 4c 5f 70 72 65 76 3d 30 0d | P%!AEL_prev=0.| 00001280 08 70 21 20 20 20 20 20 20 20 20 50 25 21 41 45 |.p! P%!AE| 00001290 4c 5f 6e 65 78 74 3d 41 45 4c 5f 66 72 65 65 25 |L_next=AEL_free%| 000012a0 0d 08 7a 18 20 20 20 20 20 20 20 20 41 45 4c 5f |..z. AEL_| 000012b0 66 72 65 65 25 3d 50 25 0d 08 84 04 0d 08 8e 11 |free%=P%........| 000012c0 20 20 20 20 20 20 20 20 50 25 3d 52 25 0d 08 98 | P%=R%...| 000012d0 0b 20 20 20 20 20 20 cc 0d 08 a2 1a 20 20 20 20 |. ..... | 000012e0 20 20 20 20 50 25 3d 50 25 21 41 45 4c 5f 6e 65 | P%=P%!AEL_ne| 000012f0 78 74 0d 08 ac 0b 20 20 20 20 20 20 cd 0d 08 b6 |xt.... ....| 00001300 09 20 20 20 20 ce 0d 08 c0 05 e1 0d 08 ca 04 0d |. ...........| 00001310 08 d4 15 dd 20 f2 69 6e 63 41 63 74 69 76 65 45 |.... .incActiveE| 00001320 64 67 65 73 0d 08 de 19 20 20 ea 20 44 25 2c 49 |dges.... . D%,I| 00001330 25 2c 4e 25 2c 51 25 2c 50 25 2c 53 25 0d 08 e8 |%,N%,Q%,P%,S%...| 00001340 11 20 20 50 25 3d 41 45 4c 5f 70 74 72 25 0d 08 |. P%=AEL_ptr%..| 00001350 f2 0e 20 20 c8 95 20 50 25 3c 3e 30 0d 08 fc 1b |.. .. P%<>0....| 00001360 20 20 20 20 4e 25 3d 50 25 21 41 45 4c 5f 6e 75 | N%=P%!AEL_nu| 00001370 6d 65 72 61 74 6f 72 0d 09 06 11 20 20 20 20 e7 |merator.... .| 00001380 20 4e 25 3c 3e 30 20 8c 0d 09 10 13 20 20 20 20 | N%<>0 ..... | 00001390 20 20 20 20 53 25 3d b4 20 4e 25 0d 09 1a 21 20 | S%=. N%...! | 000013a0 20 20 20 20 20 20 20 44 25 3d 50 25 21 41 45 4c | D%=P%!AEL| 000013b0 5f 64 65 6e 6f 6d 69 6e 61 74 6f 72 0d 09 24 1f |_denominator..$.| 000013c0 20 20 20 20 20 20 20 20 49 25 3d 50 25 21 41 45 | I%=P%!AE| 000013d0 4c 5f 69 6e 63 72 65 6d 65 6e 74 0d 09 2e 04 0d |L_increment.....| 000013e0 09 38 12 20 20 20 20 20 20 20 20 49 25 2b 3d 4e |.8. I%+=N| 000013f0 25 0d 09 42 19 20 20 20 20 20 20 20 20 c8 95 20 |%..B. .. | 00001400 28 94 20 49 25 29 3e 3d 44 25 0d 09 4c 1d 20 20 |(. I%)>=D%..L. | 00001410 20 20 20 20 20 20 20 20 50 25 21 41 45 4c 5f 78 | P%!AEL_x| 00001420 63 75 72 2b 3d 53 25 0d 09 56 17 20 20 20 20 20 |cur+=S%..V. | 00001430 20 20 20 20 20 49 25 2d 3d 44 25 2a 53 25 0d 09 | I%-=D%*S%..| 00001440 60 0f 20 20 20 20 20 20 20 20 20 20 ce 0d 09 6a |`. ...j| 00001450 04 0d 09 74 1f 20 20 20 20 20 20 20 20 50 25 21 |...t. P%!| 00001460 41 45 4c 5f 69 6e 63 72 65 6d 65 6e 74 3d 49 25 |AEL_increment=I%| 00001470 0d 09 7e 0b 20 20 20 20 20 20 cd 0d 09 88 0d 20 |..~. ..... | 00001480 20 20 20 51 25 3d 50 25 0d 09 92 16 20 20 20 20 | Q%=P%.... | 00001490 50 25 3d 50 25 21 41 45 4c 5f 6e 65 78 74 0d 09 |P%=P%!AEL_next..| 000014a0 9c 2c 20 20 20 20 e7 20 51 25 21 41 45 4c 5f 70 |., . Q%!AEL_p| 000014b0 72 65 76 3c 3e 30 20 f2 73 6f 72 74 41 63 74 69 |rev<>0 .sortActi| 000014c0 76 65 45 64 67 65 28 51 25 29 0d 09 a6 09 20 20 |veEdge(Q%).... | 000014d0 20 20 ce 0d 09 b0 05 e1 0d 09 ba 04 0d 09 c4 19 | ..............| 000014e0 dd 20 f2 73 6f 72 74 41 63 74 69 76 65 45 64 67 |. .sortActiveEdg| 000014f0 65 28 50 25 29 0d 09 ce 13 20 20 ea 20 51 25 2c |e(P%).... . Q%,| 00001500 53 25 2c 54 25 2c 55 25 0d 09 d8 14 20 20 53 25 |S%,T%,U%.... S%| 00001510 3d 50 25 21 41 45 4c 5f 70 72 65 76 0d 09 e2 21 |=P%!AEL_prev...!| 00001520 20 20 e7 20 53 25 21 41 45 4c 5f 78 63 75 72 3e | . S%!AEL_xcur>| 00001530 50 25 21 41 45 4c 5f 78 63 75 72 20 8c 0d 09 ec |P%!AEL_xcur ....| 00001540 35 20 20 20 20 20 20 c8 95 20 28 53 25 3c 3e 41 |5 .. (S%<>A| 00001550 45 4c 5f 70 74 72 25 29 80 28 53 25 21 41 45 4c |EL_ptr%).(S%!AEL| 00001560 5f 78 63 75 72 3e 50 25 21 41 45 4c 5f 78 63 75 |_xcur>P%!AEL_xcu| 00001570 72 29 0d 09 f6 1a 20 20 20 20 20 20 20 20 53 25 |r).... S%| 00001580 3d 53 25 21 41 45 4c 5f 70 72 65 76 0d 0a 00 0d |=S%!AEL_prev....| 00001590 20 20 20 20 20 20 20 20 ce 0d 0a 0a 04 0d 0a 14 | ........| 000015a0 18 20 20 20 20 20 20 54 25 3d 50 25 21 41 45 4c |. T%=P%!AEL| 000015b0 5f 70 72 65 76 0d 0a 1e 18 20 20 20 20 20 20 55 |_prev.... U| 000015c0 25 3d 50 25 21 41 45 4c 5f 6e 65 78 74 0d 0a 28 |%=P%!AEL_next..(| 000015d0 18 20 20 20 20 20 20 54 25 21 41 45 4c 5f 6e 65 |. T%!AEL_ne| 000015e0 78 74 3d 55 25 0d 0a 32 20 20 20 20 20 20 20 e7 |xt=U%..2 .| 000015f0 20 55 25 3c 3e 30 20 55 25 21 41 45 4c 5f 70 72 | U%<>0 U%!AEL_pr| 00001600 65 76 3d 54 25 0d 0a 3c 04 0d 0a 46 25 20 20 20 |ev=T%..<...F% | 00001610 20 20 20 e7 20 53 25 21 41 45 4c 5f 78 63 75 72 | . S%!AEL_xcur| 00001620 3c 50 25 21 41 45 4c 5f 78 63 75 72 20 8c 0d 0a |<P%!AEL_xcur ...| 00001630 50 1c 20 20 20 20 20 20 20 20 20 20 51 25 3d 53 |P. Q%=S| 00001640 25 21 41 45 4c 5f 6e 65 78 74 0d 0a 5a 1c 20 20 |%!AEL_next..Z. | 00001650 20 20 20 20 20 20 20 20 50 25 21 41 45 4c 5f 70 | P%!AEL_p| 00001660 72 65 76 3d 53 25 0d 0a 64 1c 20 20 20 20 20 20 |rev=S%..d. | 00001670 20 20 20 20 50 25 21 41 45 4c 5f 6e 65 78 74 3d | P%!AEL_next=| 00001680 51 25 0d 0a 6e 1c 20 20 20 20 20 20 20 20 20 20 |Q%..n. | 00001690 53 25 21 41 45 4c 5f 6e 65 78 74 3d 50 25 0d 0a |S%!AEL_next=P%..| 000016a0 78 24 20 20 20 20 20 20 20 20 20 20 e7 20 51 25 |x$ . Q%| 000016b0 3c 3e 30 20 51 25 21 41 45 4c 5f 70 72 65 76 3d |<>0 Q%!AEL_prev=| 000016c0 50 25 0d 0a 82 0d 20 20 20 20 20 20 20 20 cc 0d |P%.... ..| 000016d0 0a 8c 1c 20 20 20 20 20 20 20 20 20 20 53 25 21 |... S%!| 000016e0 41 45 4c 5f 70 72 65 76 3d 50 25 0d 0a 96 1b 20 |AEL_prev=P%.... | 000016f0 20 20 20 20 20 20 20 20 20 50 25 21 41 45 4c 5f | P%!AEL_| 00001700 70 72 65 76 3d 30 0d 0a a0 1c 20 20 20 20 20 20 |prev=0.... | 00001710 20 20 20 20 50 25 21 41 45 4c 5f 6e 65 78 74 3d | P%!AEL_next=| 00001720 53 25 0d 0a aa 19 20 20 20 20 20 20 20 20 20 20 |S%.... | 00001730 41 45 4c 5f 70 74 72 25 3d 50 25 0d 0a b4 0d 20 |AEL_ptr%=P%.... | 00001740 20 20 20 20 20 20 20 cd 0d 0a be 09 20 20 20 20 | ..... | 00001750 cd 0d 0a c8 05 e1 0d 0a d2 04 0d 0a dc 2a 3d 3d |.............*==| 00001760 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d |================| * 00001780 3d 3d 3d 3d 0d 0a e6 04 0d 0a f0 10 dd 20 f2 64 |====......... .d| 00001790 75 6d 70 5f 45 54 3a db 0d 0a fa 0d 20 20 ea 20 |ump_ET:..... . | 000017a0 50 25 2c 59 25 0d 0b 04 1d 20 20 e3 20 59 25 3d |P%,Y%.... . Y%=| 000017b0 30 20 b8 20 65 64 67 65 45 6e 74 72 69 65 73 25 |0 . edgeEntries%| 000017c0 2d 31 0d 0b 0e 15 20 20 20 20 50 25 3d 45 54 25 |-1.... P%=ET%| 000017d0 21 28 59 25 2a 34 29 0d 0b 18 11 20 20 20 20 e7 |!(Y%*4).... .| 000017e0 20 50 25 3c 3e 30 20 8c 0d 0b 22 12 20 20 20 20 | P%<>0 ...". | 000017f0 20 20 20 20 f1 20 27 59 25 3b 0d 0b 2c 14 20 20 | . 'Y%;..,. | 00001800 20 20 20 20 20 20 c8 95 20 50 25 3c 3e 30 0d 0b | .. P%<>0..| 00001810 36 28 20 20 20 20 20 20 20 20 20 20 f1 8a 31 30 |6( ..10| 00001820 29 50 25 21 45 54 5f 78 6d 69 6e 2c 50 25 21 45 |)P%!ET_xmin,P%!E| 00001830 54 5f 79 6d 61 78 0d 0b 40 1b 20 20 20 20 20 20 |T_ymax..@. | 00001840 20 20 20 20 50 25 3d 50 25 21 45 54 5f 6e 65 78 | P%=P%!ET_nex| 00001850 74 0d 0b 4a 0f 20 20 20 20 20 20 20 20 20 20 ce |t..J. .| 00001860 0d 0b 54 0b 20 20 20 20 20 20 cd 0d 0b 5e 09 20 |..T. ...^. | 00001870 20 20 20 ed 0d 0b 68 05 e1 0d 0b 72 04 0d 0b 7c | ...h....r...|| 00001880 13 dd 20 f2 64 75 6d 70 5f 41 45 4c 28 59 25 29 |.. .dump_AEL(Y%)| 00001890 0d 0b 86 0d 20 20 ea 20 50 25 2c 40 25 0d 0b 90 |.... . P%,@%...| 000018a0 0f 20 20 40 25 3d 26 32 30 32 30 38 0d 0b 9a 11 |. @%=&20208....| 000018b0 20 20 50 25 3d 41 45 4c 5f 70 74 72 25 0d 0b a4 | P%=AEL_ptr%...| 000018c0 0e 20 20 f1 8a 30 2c 30 29 59 25 0d 0b ae 0e 20 |. ..0,0)Y%.... | 000018d0 20 c8 95 20 50 25 3c 3e 30 0d 0b b8 4c 20 20 20 | .. P%<>0...L | 000018e0 20 f1 20 50 25 21 41 45 4c 5f 65 64 67 65 49 44 | . P%!AEL_edgeID| 000018f0 2c 50 25 21 41 45 4c 5f 69 6e 63 72 65 6d 65 6e |,P%!AEL_incremen| 00001900 74 2c 50 25 21 41 45 4c 5f 6e 75 6d 65 72 61 74 |t,P%!AEL_numerat| 00001910 6f 72 2c 50 25 21 41 45 4c 5f 64 65 6e 6f 6d 69 |or,P%!AEL_denomi| 00001920 6e 61 74 6f 72 0d 0b c2 16 20 20 20 20 50 25 3d |nator.... P%=| 00001930 50 25 21 41 45 4c 5f 6e 65 78 74 0d 0b cc 09 20 |P%!AEL_next.... | 00001940 20 20 20 ce 0d 0b d6 0d 20 20 f1 89 38 30 3a e7 | ..... ..80:.| 00001950 a5 0d 0b e0 05 e1 0d 0b ea 04 0d 0b f4 30 3d 3d |.............0==| 00001960 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d |================| * 00001980 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 0d 0b fe 04 0d 0c |==========......| 00001990 08 10 dd 20 a4 61 6c 6c 6f 63 5f 41 45 4c 0d 0c |... .alloc_AEL..| 000019a0 12 0a 20 20 ea 20 50 25 0d 0c 1c 15 20 20 e7 20 |.. . P%.... . | 000019b0 41 45 4c 5f 66 72 65 65 25 3d 30 20 8c 0d 0c 26 |AEL_free%=0 ...&| 000019c0 1d 20 20 20 20 20 20 50 25 3d a4 61 6c 6c 6f 63 |. P%=.alloc| 000019d0 28 41 45 4c 5f 73 69 7a 65 29 0d 0c 30 09 20 20 |(AEL_size)..0. | 000019e0 20 20 cc 0d 0c 3a 16 20 20 20 20 20 20 50 25 3d | ...:. P%=| 000019f0 41 45 4c 5f 66 72 65 65 25 0d 0c 44 1f 20 20 20 |AEL_free%..D. | 00001a00 20 20 20 41 45 4c 5f 66 72 65 65 25 3d 50 25 21 | AEL_free%=P%!| 00001a10 41 45 4c 5f 6e 65 78 74 0d 0c 4e 09 20 20 20 20 |AEL_next..N. | 00001a20 cd 0d 0c 58 07 3d 50 25 0d 0c 62 04 0d 0c 6c 04 |...X.=P%..b...l.| 00001a30 0d 0c 76 53 dd 20 a4 61 6c 6c 6f 63 28 53 25 29 |..vS. .alloc(S%)| 00001a40 ea 20 50 25 3a 50 25 3d 68 65 61 70 25 2b 68 70 |. P%:P%=heap%+hp| 00001a50 25 3a 68 70 25 2b 3d 53 25 3a e7 20 68 70 25 3e |%:hp%+=S%:. hp%>| 00001a60 68 65 61 70 73 69 7a 65 25 20 85 20 39 39 2c 22 |heapsize% . 99,"| 00001a70 4e 6f 20 6d 6f 72 65 20 68 65 61 70 20 73 70 61 |No more heap spa| 00001a80 63 65 22 0d 0c 80 07 3d 50 25 0d 0c 8a 04 0d 0c |ce"....=P%......| 00001a90 94 0b dd 20 f2 67 72 69 64 0d 0c 9e 0e 20 20 6d |... .grid.... m| 00001aa0 78 25 3d 31 32 38 30 0d 0c a8 0e 20 20 6d 79 25 |x%=1280.... my%| 00001ab0 3d 31 30 32 34 0d 0c b2 0c 20 20 73 78 25 3d 33 |=1024.... sx%=3| 00001ac0 32 0d 0c bc 0c 20 20 73 79 25 3d 33 32 0d 0c c6 |2.... sy%=32...| 00001ad0 17 20 20 6f 78 25 3d 28 6d 78 25 2f 73 78 25 29 |. ox%=(mx%/sx%)| 00001ae0 81 32 2d 31 0d 0c d0 17 20 20 6f 79 25 3d 28 6d |.2-1.... oy%=(m| 00001af0 79 25 2f 73 79 25 29 81 32 2d 31 0d 0c da 1a 20 |y%/sy%).2-1.... | 00001b00 20 e3 20 58 25 3d 30 20 b8 20 6d 78 25 2d 31 20 | . X%=0 . mx%-1 | 00001b10 88 20 73 78 25 0d 0c e4 17 20 20 20 20 86 20 58 |. sx%.... . X| 00001b20 25 2c 30 2c 58 25 2c 6d 79 25 2d 31 0d 0c ee 09 |%,0,X%,my%-1....| 00001b30 20 20 20 20 ed 0d 0c f8 1a 20 20 e3 20 59 25 3d | ..... . Y%=| 00001b40 30 20 b8 20 6d 79 25 2d 31 20 88 20 73 79 25 0d |0 . my%-1 . sy%.| 00001b50 0d 02 15 20 20 20 20 86 20 30 2c 59 25 2c 6d 78 |... . 0,Y%,mx| 00001b60 25 2c 59 25 0d 0d 0c 09 20 20 20 20 ed 0d 0d 16 |%,Y%.... ....| 00001b70 05 e1 0d 0d 20 04 0d 0d 2a 20 dd 20 f2 77 72 69 |.... ...* . .wri| 00001b80 74 65 50 69 78 65 6c 28 78 25 2c 79 25 2c 43 25 |tePixel(x%,y%,C%| 00001b90 29 e6 33 2c 43 25 0d 0d 34 1f 20 20 c8 8f 20 c8 |).3,C%..4. .. .| 00001ba0 90 20 a4 78 28 78 25 29 2c a4 79 28 79 25 29 2c |. .x(x%),.y(y%),| 00001bb0 73 78 25 2f 32 0d 0d 3e 05 e1 0d 0d 48 04 0d 0d |sx%/2..>....H...| 00001bc0 52 13 dd 20 a4 78 28 58 25 29 3d 58 25 2a 73 78 |R.. .x(X%)=X%*sx| 00001bd0 25 0d 0d 5c 04 0d 0d 66 13 dd 20 a4 79 28 59 25 |%..\...f.. .y(Y%| 00001be0 29 3d 59 25 2a 73 79 25 0d ff |)=Y%*sy%..| 00001bea