Home » Archimedes archive » Acorn User » AU 1998-08.adf » Regulars » StarInfo/Alexandrou/LineFract
StarInfo/Alexandrou/LineFract
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 User » AU 1998-08.adf » Regulars |
Filename: | StarInfo/Alexandrou/LineFract |
Read OK: | ✔ |
File size: | 176A bytes |
Load address: | 0000 |
Exec address: | 0000 |
File contents
10REM *** LineFract 20REM *** Written by Dean Alexandrou 30 40ON ERROR :MODE8:IF INKEY-1 PRINT"I Hope you had fun!"'''':END ELSE :IF ERR<>17 :REPORT:PRINT ERL:END: ELSE :IF ERR=17 :RUN 50 60MODE20 70COLOUR 15,255,255,255 80COLOUR 14,255,255,240 90COLOUR 13,255,255,220 100COLOUR 12,255,255,200 110COLOUR 11,255,220,200 120COLOUR 10,255,180,200 130COLOUR 9,255,120,200 140COLOUR 8,255,40,200 150COLOUR 7,240,0,200 160COLOUR 6,220,0,190 170COLOUR 5,200,0,180 180COLOUR 4,170,0,170 190COLOUR 3,130,0,160 200COLOUR 2,80,0,140 210COLOUR 1,0,0,100 220COLOUR 0,0,0,0 230COLOUR15 240: 250ORIGIN 0,512 260p$="L" 270i%=15 280gi$="ON" 290rot%=0 300hs$="ON" 310vs$="ON" 320PROCread_fractal_data 330: 340PROCplot_screen 350: 360MOUSE ON 370DIM line%(50,2),f(50,2) 380lx=0:ly=0 390: 400p=0 410REPEAT 420 p+=1 430 REPEAT 440 A$=CHR$(INKEY(0) AND &DF) 450 MOUSE x%,y%,z 460 x=x%:y=y% 470 IF INKEY-1=0 x=(x%+16) DIV 32 * 32:y=(y%+16*SGN(y)) DIV 32 * 32 480 GCOL3,RND(3)+11:LINE lx,ly,x,y:WAIT:WAIT:LINE lx,ly,x,y 490 IF (ASC(A$)=8 OR ASC(A$)=127) AND p>1 THEN 500 CLS:PROCplot_screen 510 p-=1:PROCdraw_line_so_far 520 lx=line%(p-1,1):ly=line%(p-1,2) 530 ENDIF 540 IF A$="O" THEN 550 CLS 560 PROCoptions 570 CLS 580 PROCplot_screen 590 PROCdraw_line_so_far 600 ENDIF 610 UNTIL z>0 OR A$="M" 620 IF SQR((1280-x)^2+y^2)<20 x=1280:y=0:z=1 630 GCOL0,15:LINE lx,ly,x,y:LINE lx+4,ly,x+4,y:LINE lx,ly+4,x,y+4 640 line%(p,1)=x:line%(p,2)=y 650 lx=x:ly=y 660 REPEAT:MOUSE x,y,zz:UNTIL zz=0 670UNTIL z=1 OR A$="M" 680: 690IF A$="M" PROCmenu 700: 710CLS 720: 730x=0:y=0 740FOR n%=1 TO p 750 nx=line%(n%,1):ny=line%(n%,2) 760 : 770 IF nx=x nx+=0.1 780 IF ny=y ny+=0.1 790 xlen=nx-x:ylen=ny-y 800 len=SQR(xlen*xlen+ylen*ylen) 810 ang=DEG(ATN(ylen/xlen)) 820 IF ang<0 ang=ABS(ang)+90 ELSE ang=90-ang 830 IF xlen<0 ang-=180 840 : 850 f(n%,1)=ang:f(n%,2)=len 860 : 870 x=nx:y=ny 880NEXT 890: 900CLS 910: 920MOUSE OFF 930IF gi$="ON" gi%=1 ELSE gi%=i% 940FOR deg=gi% TO i% 950 PRINTTAB(0,0)"Level of iteration:";deg 960 x=0:y=0:ad=0:d=deg 970 col%=deg+15-i% 980 GCOL0,col% 990 IF rot%=0 PROCfractal(0,1280) ELSE PROCcfractal(0,1280) 1000NEXT 1010REPEAT:UNTIL FALSE 1020END 1030 1040DEFPROCfractal(angoffset,len) 1050LOCAL n%,mf 1060: 1070ad+=1:mf=len/1280 1080IF ad>=d THEN 1090 IF hs$="ON":px=x*0.8+128 ELSE px=x 1100 IF vs$="ON":py=y*0.8 ELSE py=y 1110 MOVE px,py:MOVE px,py 1120 FOR n%=1 TO p 1130 a=RAD(f(n%,1)+angoffset):x+=SIN(a)*f(n%,2)*mf:y+=COS(a)*f(n%,2)*mf 1140 IF hs$="ON":px=x*0.8+128 ELSE px=x 1150 IF vs$="ON":py=y*0.8 ELSE py=y 1160 IF p$="L" DRAW px,py 1170 IF p$="F" PLOT85,px,py 1180 IF p$="P" AND POINT(px,y)=0 PLOT69,px,py 1190 NEXT 1200ELSE 1210 FOR n%=1 TO p 1220 PROCfractal(f(n%,1)+angoffset-90,f(n%,2)*mf) 1230 NEXT 1240ENDIF 1250ad-=1 1260ENDPROC 1270 1280DEFPROCcfractal(angoffset,len) 1290LOCAL n%,mf 1300: 1310ad+=1:mf=len/1280 1320IF ad>=d THEN 1330 c=x*0.28125:r%=y/2+256:a=RAD(c):px=SIN(a)*r%+640:py=COS(a)*r% 1340 MOVE px,py:MOVE px,py 1350 FOR n%=1 TO p 1360 a=RAD(f(n%,1)+angoffset):x+=SIN(a)*f(n%,2)*mf:y+=COS(a)*f(n%,2)*mf 1370 c=x*0.28125:r%=y/2+256:a=RAD(c):px=SIN(a)*r%+640:py=COS(a)*r% 1380 IF p$="L" DRAW px,py 1390 IF p$="F" PLOT85,px,py 1400 IF p$="P" AND POINT(px,y)=0 PLOT69,px,py 1410 NEXT 1420ELSE 1430 FOR n%=1 TO p 1440 PROCcfractal(f(n%,1)+angoffset-90,f(n%,2)*mf) 1450 NEXT 1460ENDIF 1470ad-=1 1480ENDPROC 1490 1500DEFPROCplot_screen 1510LOCAL x%,y% 1520: 1530GCOL0,1:FORy%=-512TO512STEP32:LINE0,y%,1280,y%:NEXT:FORx%=0TO1280STEP32:LINEx%,-512,x%,512:NEXT 1540: 1550PRINT"Fractal Generator - written by Dean Alexandrou (Jan 1998)" 1560PRINT''"Use the mouse to draw a fractal curve. Press a button to set the line."'"Finish by drawing to the White Circle. Alternatively, choose a fractal from the menu." 1570PRINT'"SHIFT = unlock grid"'"O = option screen"'"M = select fractal from Menu"'"ESCAPE = restarts"'"ESCAPE + SHIFT = quit" 1580: 1590GCOL0,3:FORy%=-512TO512STEP64:LINE0,y%,1280,y%:NEXT:FORx%=0TO1280STEP64:LINEx%,-512,x%,512:NEXT 1600GCOL0,5:FORy%=-512TO512STEP128:LINE0,y%,1280,y%:NEXT:FORx%=0TO1280STEP128:LINEx%,-512,x%,512:NEXT 1610GCOL0,11:LINE0,0,1280,0:LINE640,-512,640,512:GCOL0,15:CIRCLE FILL 1280,0,24 1620ENDPROC 1630 1640DEFPROCdraw_line_so_far 1650LOCAL n%,x,y,lx,ly 1660: 1670IF p<2 ENDPROC 1680REM xx=OPENUP("RAM::RamDisc0.$.FD") 1690FOR n%=1 TO p-1 1700 lx=line%(n%-1,1):ly=line%(n%-1,2) 1710 x=line%(n%,1):y=line%(n%,2) 1720REM s$=STR$(x)+","+STR$(y)+", " 1730REM BPUT#xx,s$ 1740 GCOL0,15:LINE lx,ly,x,y:LINE lx+4,ly,x+4,y:LINE lx,ly+4,x,y+4 1750NEXT 1760REM CLOSE#xx 1770ENDPROC 1780 1790DEFPROCoptions 1800LOCAL plot$,cf$,A$,s% 1810: 1820IF p$="P" plot$="Points" 1830IF p$="F" plot$="Filled Triangles" 1840IF p$="L" plot$="Lines" 1850: 1860IF rot%=0 cf$="Flat" ELSE cf$="Circular" 1870: 1880REPEAT 1890 CLS 1900 COLOUR15 1910 PRINT"OPTIONS" 1920 PRINT'"(P) Plotting Technique : ";plot$ 1930 PRINT"(N) Number of Iterations : ";i% 1940 PRINT"(G) Gradual iterating : ";gi$ 1950 PRINT"(C) Circular/Flat : ";cf$ 1960 PRINT"(H) Horizontal Squeeze : ";hs$ 1970 PRINT"(V) Vertical Squeeze : ";vs$ 1980 PRINT'"(E) Exit" 1990 : 2000 A$=CHR$(GET AND &DF) 2010 IF A$="P" THEN 2020 s%=1 2030 IF p$="L" plot$="Points":p$="P":s%=0 2040 IF p$="P" AND s%=1 plot$="Filled Triangles":p$="F":s%=0 2050 IF p$="F" AND s%=1 plot$="Lines":p$="L":s%=0 2060 ENDIF 2070 IF A$="N" i%+=1:IF i%=16:i%=2 2080 IF A$="G" THEN 2090 IF gi$="ON" gi$="OFF" ELSE gi$="ON" 2100 ENDIF 2110 IF A$="C" THEN 2120 IF rot%=0 rot%=1:cf$="Circular" ELSE rot%=0:cf$="Flat" 2130 ENDIF 2140 IF A$="H" THEN 2150 IF hs$="ON" hs$="OFF" ELSE hs$="ON" 2160 ENDIF 2170 IF A$="V" THEN 2180 IF vs$="ON" vs$="OFF" ELSE vs$="ON" 2190 ENDIF 2200UNTIL A$="E" 2210ENDPROC 2220 2230DEFPROCmenu 2240LOCAL n%,f% 2250: 2260CLS 2270PRINT"MENU"'' 2280FOR n%=1 TO fracs% 2290 PRINT;n%;")";TAB(4);frac$(n%) 2300NEXT 2310REPEAT:INPUT''"Which fractal would you like? :"f%:UNTIL f%>=1 AND f%<=fracs% 2320p=fdata%(f%,0,0) 2330FOR n%=1 TO p 2340 line%(n%,1)=fdata%(f%,n%,1) 2350 line%(n%,2)=fdata%(f%,n%,2) 2360NEXT 2370ENDPROC 2380 2390DEFPROCread_fractal_data 2400LOCAL n%,nn% 2410: 2420DATA "Simple Hill",2, 640,192, 1280,0 2430DATA "Koch curve",4, 427,0, 640,295, 853,0, 1280,0 2440DATA "3/2 curve",8, 320,0, 320,320, 640,320, 640,0, 640,-320, 960,-320, 960,0, 1280,0 2450DATA "Quaternary Dragon",13, 0,256, 256,256, 256,512, 512,512, 512,256, 512,0, 768,0, 768,-256, 778,-512, 1024,-512, 1024,-256, 1280,-256, 1280,0 2460DATA "FRAC",37, 64,0, 64,320, 256,320, 256,256, 128,256, 128,192, 256,192, 256,128, 128,128, 128,0, 384,0 2470DATA 384,320, 512,320, 576,256, 576,192, 512,128, 576,64, 576,0, 704,0, 704,256, 768,320, 832,320, 896,256 2480DATA 896,0, 1088,0, 1024,64, 1024,256, 1088,320, 1216,320, 1216,256, 1120,256, 1088,224, 1088,96, 1120,64 2490DATA 1216,64, 1216,0, 1280,0 2500DATA "",1,0,0 2510: 2520DIM frac$(100),fdata%(100,50,2) 2530: 2540n%=0 2550REPEAT 2560 n%+=1 2570 READ frac$(n%) 2580 READ fdata%(n%,0,0) 2590 FOR nn%=1 TO fdata%(n%,0,0) 2600 READ fdata%(n%,nn%,1),fdata%(n%,nn%,2) 2610 NEXT 2620UNTIL frac$(n%)="" 2630fracs%=n%-1 2640ENDPROC
� *** LineFract $� *** Written by Dean Alexandrou (P� � :�8:� �-1 �"I Hope you had fun!"'''':� � :� �<>17 :�:� �:�: � :� �=17 :� 2 <�20 F� 15,255,255,255 P� 14,255,255,240 Z� 13,255,255,220 d� 12,255,255,200 n� 11,255,220,200 x� 10,255,180,200 �� 9,255,120,200 �� 8,255,40,200 �� 7,240,0,200 �� 6,220,0,190 �� 5,200,0,180 �� 4,170,0,170 �� 3,130,0,160 �� 2,80,0,140 �� 1,0,0,100 � � 0,0,0,0 ��15 �: �ȑ 0,512 p$="L" i%=15 gi$="ON" " rot%=0 ,hs$="ON" 6vs$="ON" @�read_fractal_data J: T�plot_screen ^: hȗ � r� line%(50,2),f(50,2) | lx=0:ly=0 �: �p=0 �� � p+=1 � � � A$=�(�(0) � &DF) � ȗ x%,y%,z � x=x%:y=y% �: � �-1=0 x=(x%+16) � 32 * 32:y=(y%+16*�(y)) � 32 * 32 �. �3,�(3)+11:� lx,ly,x,y:Ȗ:Ȗ:� lx,ly,x,y �% � (�(A$)=8 � �(A$)=127) � p>1 � � �:�plot_screen � p-=1:�draw_line_so_far & lx=line%(p-1,1):ly=line%(p-1,2) � � A$="O" � & � 0 �options : � D �plot_screen N �draw_line_so_far X � b � z>0 � A$="M" l* � �((1280-x)^2+y^2)<20 x=1280:y=0:z=1 v6 �0,15:� lx,ly,x,y:� lx+4,ly,x+4,y:� lx,ly+4,x,y+4 � line%(p,1)=x:line%(p,2)=y � lx=x:ly=y � �:ȗ x,y,zz:� zz=0 �� z=1 � A$="M" �: �� A$="M" �menu �: �� �: �x=0:y=0 �� n%=1 � p �" nx=line%(n%,1):ny=line%(n%,2) � : � nx=x nx+=0.1 � ny=y ny+=0.1 xlen=nx-x:ylen=ny-y len=�(xlen*xlen+ylen*ylen) * ang=�(�(ylen/xlen)) 4' � ang<0 ang=�(ang)+90 � ang=90-ang > � xlen<0 ang-=180 H : R f(n%,1)=ang:f(n%,2)=len \ : f x=nx:y=ny p� z: �� �: �ȗ � �� gi$="ON" gi%=1 � gi%=i% �� deg=gi% � i% �$ �0,0)"Level of iteration:";deg � x=0:y=0:ad=0:d=deg � col%=deg+15-i% � �0,col% �2 � rot%=0 �fractal(0,1280) � �cfractal(0,1280) �� � �:� � �� ��fractal(angoffset,len) � n%,mf $: .ad+=1:mf=len/1280 8 � ad>=d � B# � hs$="ON":px=x*0.8+128 � px=x L � vs$="ON":py=y*0.8 � py=y V � px,py:� px,py ` � n%=1 � p jB a=�(f(n%,1)+angoffset):x+=�(a)*f(n%,2)*mf:y+=�(a)*f(n%,2)*mf t$ � hs$="ON":px=x*0.8+128 � px=x ~ � vs$="ON":py=y*0.8 � py=y � � p$="L" � px,py � � p$="F" �85,px,py �# � p$="P" � �px,y)=0 �69,px,py � � �� � � n%=1 � p �/ �fractal(f(n%,1)+angoffset-90,f(n%,2)*mf) � � �� � ad-=1 �� � ��cfractal(angoffset,len) � n%,mf : ad+=1:mf=len/1280 ( � ad>=d � 2< c=x*0.28125:r%=y/2+256:a=�(c):px=�(a)*r%+640:py=�(a)*r% < � px,py:� px,py F � n%=1 � p PB a=�(f(n%,1)+angoffset):x+=�(a)*f(n%,2)*mf:y+=�(a)*f(n%,2)*mf Z= c=x*0.28125:r%=y/2+256:a=�(c):px=�(a)*r%+640:py=�(a)*r% d � p$="L" � px,py n � p$="F" �85,px,py x# � p$="P" � �px,y)=0 �69,px,py � � �� � � n%=1 � p �0 �cfractal(f(n%,1)+angoffset-90,f(n%,2)*mf) � � �� � ad-=1 �� � ���plot_screen �� x%,y% �: �H�0,1:�y%=-512�512�32:�0,y%,1280,y%:�:�x%=0�1280�32:�x%,-512,x%,512:� : @�"Fractal Generator - written by Dean Alexandrou (Jan 1998)" ��''"Use the mouse to draw a fractal curve. Press a button to set the line."'"Finish by drawing to the White Circle. Alternatively, choose a fractal from the menu." "��'"SHIFT = unlock grid"'"O = option screen"'"M = select fractal from Menu"'"ESCAPE = restarts"'"ESCAPE + SHIFT = quit" ,: 6H�0,3:�y%=-512�512�64:�0,y%,1280,y%:�:�x%=0�1280�64:�x%,-512,x%,512:� @J�0,5:�y%=-512�512�128:�0,y%,1280,y%:�:�x%=0�1280�128:�x%,-512,x%,512:� J=�0,11:�0,0,1280,0:�640,-512,640,512:�0,15:ȏ Ȑ 1280,0,24 T� ^ h��draw_line_so_far r� n%,x,y,lx,ly |: �� p<2 � �%� xx=OPENUP("RAM::RamDisc0.$.FD") �� n%=1 � p-1 �& lx=line%(n%-1,1):ly=line%(n%-1,2) � x=line%(n%,1):y=line%(n%,2) �!� s$=STR$(x)+","+STR$(y)+", " �� BPUT#xx,s$ �6 �0,15:� lx,ly,x,y:� lx+4,ly,x+4,y:� lx,ly+4,x,y+4 �� �� CLOSE#xx �� � � ��options � plot$,cf$,A$,s% : � p$="P" plot$="Points" &%� p$="F" plot$="Filled Triangles" 0� p$="L" plot$="Lines" :: D(� rot%=0 cf$="Flat" � cf$="Circular" N: X� b � l �15 v �"OPTIONS" �* �'"(P) Plotting Technique : ";plot$ �& �"(N) Number of Iterations : ";i% �' �"(G) Gradual iterating : ";gi$ �' �"(C) Circular/Flat : ";cf$ �' �"(H) Horizontal Squeeze : ";hs$ �' �"(V) Vertical Squeeze : ";vs$ � �'"(E) Exit" � : � A$=�(� � &DF) � � A$="P" � � s%=1 �) � p$="L" plot$="Points":p$="P":s%=0 �: � p$="P" � s%=1 plot$="Filled Triangles":p$="F":s%=0 / � p$="F" � s%=1 plot$="Lines":p$="L":s%=0 � � A$="N" i%+=1:� i%=16:i%=2 � A$="G" � *% � gi$="ON" gi$="OFF" � gi$="ON" 4 � > � A$="C" � H8 � rot%=0 rot%=1:cf$="Circular" � rot%=0:cf$="Flat" R � \ � A$="H" � f% � hs$="ON" hs$="OFF" � hs$="ON" p � z � A$="V" � �% � vs$="ON" vs$="OFF" � vs$="ON" � � �� A$="E" �� � � ��menu �� n%,f% �: �� � �"MENU"'' �� n%=1 � fracs% � �;n%;")";�4);frac$(n%) �� A�:�''"Which fractal would you like? :"f%:� f%>=1 � f%<=fracs% p=fdata%(f%,0,0) � n%=1 � p $ line%(n%,1)=fdata%(f%,n%,1) . line%(n%,2)=fdata%(f%,n%,2) 8� B� L V��read_fractal_data `� n%,nn% j: t&� "Simple Hill",2, 640,192, 1280,0 ~3� "Koch curve",4, 427,0, 640,295, 853,0, 1280,0 �V� "3/2 curve",8, 320,0, 320,320, 640,320, 640,0, 640,-320, 960,-320, 960,0, 1280,0 ��� "Quaternary Dragon",13, 0,256, 256,256, 256,512, 512,512, 512,256, 512,0, 768,0, 768,-256, 778,-512, 1024,-512, 1024,-256, 1280,-256, 1280,0 �j� "FRAC",37, 64,0, 64,320, 256,320, 256,256, 128,256, 128,192, 256,192, 256,128, 128,128, 128,0, 384,0 �l� 384,320, 512,320, 576,256, 576,192, 512,128, 576,64, 576,0, 704,0, 704,256, 768,320, 832,320, 896,256 �k� 896,0, 1088,0, 1024,64, 1024,256, 1088,320, 1216,320, 1216,256, 1120,256, 1088,224, 1088,96, 1120,64 �� 1216,64, 1216,0, 1280,0 �� "",1,0,0 �: �!� frac$(100),fdata%(100,50,2) �: �n%=0 �� n%+=1 � frac$(n%) � fdata%(n%,0,0) � nn%=1 � fdata%(n%,0,0) () � fdata%(n%,nn%,1),fdata%(n%,nn%,2) 2 � <� frac$(n%)="" Ffracs%=n%-1 P� �
00000000 0d 00 0a 13 f4 20 2a 2a 2a 20 4c 69 6e 65 46 72 |..... *** LineFr| 00000010 61 63 74 0d 00 14 24 f4 20 2a 2a 2a 20 57 72 69 |act...$. *** Wri| 00000020 74 74 65 6e 20 62 79 20 44 65 61 6e 20 41 6c 65 |tten by Dean Ale| 00000030 78 61 6e 64 72 6f 75 0d 00 1e 04 0d 00 28 50 ee |xandrou......(P.| 00000040 20 85 20 3a eb 38 3a e7 20 a6 2d 31 20 f1 22 49 | . :.8:. .-1 ."I| 00000050 20 48 6f 70 65 20 79 6f 75 20 68 61 64 20 66 75 | Hope you had fu| 00000060 6e 21 22 27 27 27 27 3a e0 20 8b 20 3a e7 20 9f |n!"'''':. . :. .| 00000070 3c 3e 31 37 20 3a f6 3a f1 20 9e 3a e0 3a 20 8b |<>17 :.:. .:.: .| 00000080 20 3a e7 20 9f 3d 31 37 20 3a f9 0d 00 32 04 0d | :. .=17 :...2..| 00000090 00 3c 07 eb 32 30 0d 00 46 14 fb 20 31 35 2c 32 |.<..20..F.. 15,2| 000000a0 35 35 2c 32 35 35 2c 32 35 35 0d 00 50 14 fb 20 |55,255,255..P.. | 000000b0 31 34 2c 32 35 35 2c 32 35 35 2c 32 34 30 0d 00 |14,255,255,240..| 000000c0 5a 14 fb 20 31 33 2c 32 35 35 2c 32 35 35 2c 32 |Z.. 13,255,255,2| 000000d0 32 30 0d 00 64 14 fb 20 31 32 2c 32 35 35 2c 32 |20..d.. 12,255,2| 000000e0 35 35 2c 32 30 30 0d 00 6e 14 fb 20 31 31 2c 32 |55,200..n.. 11,2| 000000f0 35 35 2c 32 32 30 2c 32 30 30 0d 00 78 14 fb 20 |55,220,200..x.. | 00000100 31 30 2c 32 35 35 2c 31 38 30 2c 32 30 30 0d 00 |10,255,180,200..| 00000110 82 13 fb 20 39 2c 32 35 35 2c 31 32 30 2c 32 30 |... 9,255,120,20| 00000120 30 0d 00 8c 12 fb 20 38 2c 32 35 35 2c 34 30 2c |0..... 8,255,40,| 00000130 32 30 30 0d 00 96 11 fb 20 37 2c 32 34 30 2c 30 |200..... 7,240,0| 00000140 2c 32 30 30 0d 00 a0 11 fb 20 36 2c 32 32 30 2c |,200..... 6,220,| 00000150 30 2c 31 39 30 0d 00 aa 11 fb 20 35 2c 32 30 30 |0,190..... 5,200| 00000160 2c 30 2c 31 38 30 0d 00 b4 11 fb 20 34 2c 31 37 |,0,180..... 4,17| 00000170 30 2c 30 2c 31 37 30 0d 00 be 11 fb 20 33 2c 31 |0,0,170..... 3,1| 00000180 33 30 2c 30 2c 31 36 30 0d 00 c8 10 fb 20 32 2c |30,0,160..... 2,| 00000190 38 30 2c 30 2c 31 34 30 0d 00 d2 0f fb 20 31 2c |80,0,140..... 1,| 000001a0 30 2c 30 2c 31 30 30 0d 00 dc 0d fb 20 30 2c 30 |0,0,100..... 0,0| 000001b0 2c 30 2c 30 0d 00 e6 07 fb 31 35 0d 00 f0 05 3a |,0,0.....15....:| 000001c0 0d 00 fa 0c c8 91 20 30 2c 35 31 32 0d 01 04 0a |...... 0,512....| 000001d0 70 24 3d 22 4c 22 0d 01 0e 09 69 25 3d 31 35 0d |p$="L"....i%=15.| 000001e0 01 18 0c 67 69 24 3d 22 4f 4e 22 0d 01 22 0a 72 |...gi$="ON"..".r| 000001f0 6f 74 25 3d 30 0d 01 2c 0c 68 73 24 3d 22 4f 4e |ot%=0..,.hs$="ON| 00000200 22 0d 01 36 0c 76 73 24 3d 22 4f 4e 22 0d 01 40 |"..6.vs$="ON"..@| 00000210 16 f2 72 65 61 64 5f 66 72 61 63 74 61 6c 5f 64 |..read_fractal_d| 00000220 61 74 61 0d 01 4a 05 3a 0d 01 54 10 f2 70 6c 6f |ata..J.:..T..plo| 00000230 74 5f 73 63 72 65 65 6e 0d 01 5e 05 3a 0d 01 68 |t_screen..^.:..h| 00000240 08 c8 97 20 ee 0d 01 72 19 de 20 6c 69 6e 65 25 |... ...r.. line%| 00000250 28 35 30 2c 32 29 2c 66 28 35 30 2c 32 29 0d 01 |(50,2),f(50,2)..| 00000260 7c 0d 6c 78 3d 30 3a 6c 79 3d 30 0d 01 86 05 3a ||.lx=0:ly=0....:| 00000270 0d 01 90 07 70 3d 30 0d 01 9a 05 f5 0d 01 a4 09 |....p=0.........| 00000280 20 70 2b 3d 31 0d 01 ae 06 20 f5 0d 01 b8 16 20 | p+=1.... ..... | 00000290 20 41 24 3d bd 28 a6 28 30 29 20 80 20 26 44 46 | A$=.(.(0) . &DF| 000002a0 29 0d 01 c2 10 20 20 c8 97 20 78 25 2c 79 25 2c |).... .. x%,y%,| 000002b0 7a 0d 01 cc 0f 20 20 78 3d 78 25 3a 79 3d 79 25 |z.... x=x%:y=y%| 000002c0 0d 01 d6 3a 20 20 e7 20 a6 2d 31 3d 30 20 78 3d |...: . .-1=0 x=| 000002d0 28 78 25 2b 31 36 29 20 81 20 33 32 20 2a 20 33 |(x%+16) . 32 * 3| 000002e0 32 3a 79 3d 28 79 25 2b 31 36 2a b4 28 79 29 29 |2:y=(y%+16*.(y))| 000002f0 20 81 20 33 32 20 2a 20 33 32 0d 01 e0 2e 20 20 | . 32 * 32.... | 00000300 e6 33 2c b3 28 33 29 2b 31 31 3a 86 20 6c 78 2c |.3,.(3)+11:. lx,| 00000310 6c 79 2c 78 2c 79 3a c8 96 3a c8 96 3a 86 20 6c |ly,x,y:..:..:. l| 00000320 78 2c 6c 79 2c 78 2c 79 0d 01 ea 25 20 20 e7 20 |x,ly,x,y...% . | 00000330 28 97 28 41 24 29 3d 38 20 84 20 97 28 41 24 29 |(.(A$)=8 . .(A$)| 00000340 3d 31 32 37 29 20 80 20 70 3e 31 20 8c 0d 01 f4 |=127) . p>1 ....| 00000350 15 20 20 20 db 3a f2 70 6c 6f 74 5f 73 63 72 65 |. .:.plot_scre| 00000360 65 6e 0d 01 fe 1d 20 20 20 70 2d 3d 31 3a f2 64 |en.... p-=1:.d| 00000370 72 61 77 5f 6c 69 6e 65 5f 73 6f 5f 66 61 72 0d |raw_line_so_far.| 00000380 02 08 26 20 20 20 6c 78 3d 6c 69 6e 65 25 28 70 |..& lx=line%(p| 00000390 2d 31 2c 31 29 3a 6c 79 3d 6c 69 6e 65 25 28 70 |-1,1):ly=line%(p| 000003a0 2d 31 2c 32 29 0d 02 12 07 20 20 cd 0d 02 1c 10 |-1,2).... .....| 000003b0 20 20 e7 20 41 24 3d 22 4f 22 20 8c 0d 02 26 08 | . A$="O" ...&.| 000003c0 20 20 20 db 0d 02 30 0f 20 20 20 f2 6f 70 74 69 | ...0. .opti| 000003d0 6f 6e 73 0d 02 3a 08 20 20 20 db 0d 02 44 13 20 |ons..:. ...D. | 000003e0 20 20 f2 70 6c 6f 74 5f 73 63 72 65 65 6e 0d 02 | .plot_screen..| 000003f0 4e 18 20 20 20 f2 64 72 61 77 5f 6c 69 6e 65 5f |N. .draw_line_| 00000400 73 6f 5f 66 61 72 0d 02 58 07 20 20 cd 0d 02 62 |so_far..X. ...b| 00000410 13 20 fd 20 7a 3e 30 20 84 20 41 24 3d 22 4d 22 |. . z>0 . A$="M"| 00000420 0d 02 6c 2a 20 e7 20 b6 28 28 31 32 38 30 2d 78 |..l* . .((1280-x| 00000430 29 5e 32 2b 79 5e 32 29 3c 32 30 20 78 3d 31 32 |)^2+y^2)<20 x=12| 00000440 38 30 3a 79 3d 30 3a 7a 3d 31 0d 02 76 36 20 e6 |80:y=0:z=1..v6 .| 00000450 30 2c 31 35 3a 86 20 6c 78 2c 6c 79 2c 78 2c 79 |0,15:. lx,ly,x,y| 00000460 3a 86 20 6c 78 2b 34 2c 6c 79 2c 78 2b 34 2c 79 |:. lx+4,ly,x+4,y| 00000470 3a 86 20 6c 78 2c 6c 79 2b 34 2c 78 2c 79 2b 34 |:. lx,ly+4,x,y+4| 00000480 0d 02 80 1e 20 6c 69 6e 65 25 28 70 2c 31 29 3d |.... line%(p,1)=| 00000490 78 3a 6c 69 6e 65 25 28 70 2c 32 29 3d 79 0d 02 |x:line%(p,2)=y..| 000004a0 8a 0e 20 6c 78 3d 78 3a 6c 79 3d 79 0d 02 94 17 |.. lx=x:ly=y....| 000004b0 20 f5 3a c8 97 20 78 2c 79 2c 7a 7a 3a fd 20 7a | .:.. x,y,zz:. z| 000004c0 7a 3d 30 0d 02 9e 12 fd 20 7a 3d 31 20 84 20 41 |z=0..... z=1 . A| 000004d0 24 3d 22 4d 22 0d 02 a8 05 3a 0d 02 b2 12 e7 20 |$="M"....:..... | 000004e0 41 24 3d 22 4d 22 20 f2 6d 65 6e 75 0d 02 bc 05 |A$="M" .menu....| 000004f0 3a 0d 02 c6 05 db 0d 02 d0 05 3a 0d 02 da 0b 78 |:.........:....x| 00000500 3d 30 3a 79 3d 30 0d 02 e4 0e e3 20 6e 25 3d 31 |=0:y=0..... n%=1| 00000510 20 b8 20 70 0d 02 ee 22 20 6e 78 3d 6c 69 6e 65 | . p..." nx=line| 00000520 25 28 6e 25 2c 31 29 3a 6e 79 3d 6c 69 6e 65 25 |%(n%,1):ny=line%| 00000530 28 6e 25 2c 32 29 0d 02 f8 06 20 3a 0d 03 02 13 |(n%,2).... :....| 00000540 20 e7 20 6e 78 3d 78 20 6e 78 2b 3d 30 2e 31 0d | . nx=x nx+=0.1.| 00000550 03 0c 13 20 e7 20 6e 79 3d 79 20 6e 79 2b 3d 30 |... . ny=y ny+=0| 00000560 2e 31 0d 03 16 18 20 78 6c 65 6e 3d 6e 78 2d 78 |.1.... xlen=nx-x| 00000570 3a 79 6c 65 6e 3d 6e 79 2d 79 0d 03 20 1f 20 6c |:ylen=ny-y.. . l| 00000580 65 6e 3d b6 28 78 6c 65 6e 2a 78 6c 65 6e 2b 79 |en=.(xlen*xlen+y| 00000590 6c 65 6e 2a 79 6c 65 6e 29 0d 03 2a 18 20 61 6e |len*ylen)..*. an| 000005a0 67 3d 9d 28 99 28 79 6c 65 6e 2f 78 6c 65 6e 29 |g=.(.(ylen/xlen)| 000005b0 29 0d 03 34 27 20 e7 20 61 6e 67 3c 30 20 61 6e |)..4' . ang<0 an| 000005c0 67 3d 94 28 61 6e 67 29 2b 39 30 20 8b 20 61 6e |g=.(ang)+90 . an| 000005d0 67 3d 39 30 2d 61 6e 67 0d 03 3e 16 20 e7 20 78 |g=90-ang..>. . x| 000005e0 6c 65 6e 3c 30 20 61 6e 67 2d 3d 31 38 30 0d 03 |len<0 ang-=180..| 000005f0 48 06 20 3a 0d 03 52 1c 20 66 28 6e 25 2c 31 29 |H. :..R. f(n%,1)| 00000600 3d 61 6e 67 3a 66 28 6e 25 2c 32 29 3d 6c 65 6e |=ang:f(n%,2)=len| 00000610 0d 03 5c 06 20 3a 0d 03 66 0e 20 78 3d 6e 78 3a |..\. :..f. x=nx:| 00000620 79 3d 6e 79 0d 03 70 05 ed 0d 03 7a 05 3a 0d 03 |y=ny..p....z.:..| 00000630 84 05 db 0d 03 8e 05 3a 0d 03 98 08 c8 97 20 87 |.......:...... .| 00000640 0d 03 a2 1d e7 20 67 69 24 3d 22 4f 4e 22 20 67 |..... gi$="ON" g| 00000650 69 25 3d 31 20 8b 20 67 69 25 3d 69 25 0d 03 ac |i%=1 . gi%=i%...| 00000660 12 e3 20 64 65 67 3d 67 69 25 20 b8 20 69 25 0d |.. deg=gi% . i%.| 00000670 03 b6 24 20 f1 8a 30 2c 30 29 22 4c 65 76 65 6c |..$ ..0,0)"Level| 00000680 20 6f 66 20 69 74 65 72 61 74 69 6f 6e 3a 22 3b | of iteration:";| 00000690 64 65 67 0d 03 c0 17 20 78 3d 30 3a 79 3d 30 3a |deg.... x=0:y=0:| 000006a0 61 64 3d 30 3a 64 3d 64 65 67 0d 03 ca 13 20 63 |ad=0:d=deg.... c| 000006b0 6f 6c 25 3d 64 65 67 2b 31 35 2d 69 25 0d 03 d4 |ol%=deg+15-i%...| 000006c0 0c 20 e6 30 2c 63 6f 6c 25 0d 03 de 32 20 e7 20 |. .0,col%...2 . | 000006d0 72 6f 74 25 3d 30 20 f2 66 72 61 63 74 61 6c 28 |rot%=0 .fractal(| 000006e0 30 2c 31 32 38 30 29 20 8b 20 f2 63 66 72 61 63 |0,1280) . .cfrac| 000006f0 74 61 6c 28 30 2c 31 32 38 30 29 0d 03 e8 05 ed |tal(0,1280).....| 00000700 0d 03 f2 09 f5 3a fd 20 a3 0d 03 fc 05 e0 0d 04 |.....:. ........| 00000710 06 04 0d 04 10 1c dd f2 66 72 61 63 74 61 6c 28 |........fractal(| 00000720 61 6e 67 6f 66 66 73 65 74 2c 6c 65 6e 29 0d 04 |angoffset,len)..| 00000730 1a 0b ea 20 6e 25 2c 6d 66 0d 04 24 05 3a 0d 04 |... n%,mf..$.:..| 00000740 2e 15 61 64 2b 3d 31 3a 6d 66 3d 6c 65 6e 2f 31 |..ad+=1:mf=len/1| 00000750 32 38 30 0d 04 38 0d e7 20 61 64 3e 3d 64 20 8c |280..8.. ad>=d .| 00000760 0d 04 42 23 20 e7 20 68 73 24 3d 22 4f 4e 22 3a |..B# . hs$="ON":| 00000770 70 78 3d 78 2a 30 2e 38 2b 31 32 38 20 8b 20 70 |px=x*0.8+128 . p| 00000780 78 3d 78 0d 04 4c 1f 20 e7 20 76 73 24 3d 22 4f |x=x..L. . vs$="O| 00000790 4e 22 3a 70 79 3d 79 2a 30 2e 38 20 8b 20 70 79 |N":py=y*0.8 . py| 000007a0 3d 79 0d 04 56 14 20 ec 20 70 78 2c 70 79 3a ec |=y..V. . px,py:.| 000007b0 20 70 78 2c 70 79 0d 04 60 0f 20 e3 20 6e 25 3d | px,py..`. . n%=| 000007c0 31 20 b8 20 70 0d 04 6a 42 20 20 61 3d b2 28 66 |1 . p..jB a=.(f| 000007d0 28 6e 25 2c 31 29 2b 61 6e 67 6f 66 66 73 65 74 |(n%,1)+angoffset| 000007e0 29 3a 78 2b 3d b5 28 61 29 2a 66 28 6e 25 2c 32 |):x+=.(a)*f(n%,2| 000007f0 29 2a 6d 66 3a 79 2b 3d 9b 28 61 29 2a 66 28 6e |)*mf:y+=.(a)*f(n| 00000800 25 2c 32 29 2a 6d 66 0d 04 74 24 20 20 e7 20 68 |%,2)*mf..t$ . h| 00000810 73 24 3d 22 4f 4e 22 3a 70 78 3d 78 2a 30 2e 38 |s$="ON":px=x*0.8| 00000820 2b 31 32 38 20 8b 20 70 78 3d 78 0d 04 7e 20 20 |+128 . px=x..~ | 00000830 20 e7 20 76 73 24 3d 22 4f 4e 22 3a 70 79 3d 79 | . vs$="ON":py=y| 00000840 2a 30 2e 38 20 8b 20 70 79 3d 79 0d 04 88 16 20 |*0.8 . py=y.... | 00000850 20 e7 20 70 24 3d 22 4c 22 20 df 20 70 78 2c 70 | . p$="L" . px,p| 00000860 79 0d 04 92 18 20 20 e7 20 70 24 3d 22 46 22 20 |y.... . p$="F" | 00000870 f0 38 35 2c 70 78 2c 70 79 0d 04 9c 23 20 20 e7 |.85,px,py...# .| 00000880 20 70 24 3d 22 50 22 20 80 20 b0 70 78 2c 79 29 | p$="P" . .px,y)| 00000890 3d 30 20 f0 36 39 2c 70 78 2c 70 79 0d 04 a6 06 |=0 .69,px,py....| 000008a0 20 ed 0d 04 b0 05 cc 0d 04 ba 0f 20 e3 20 6e 25 | .......... . n%| 000008b0 3d 31 20 b8 20 70 0d 04 c4 2f 20 20 f2 66 72 61 |=1 . p.../ .fra| 000008c0 63 74 61 6c 28 66 28 6e 25 2c 31 29 2b 61 6e 67 |ctal(f(n%,1)+ang| 000008d0 6f 66 66 73 65 74 2d 39 30 2c 66 28 6e 25 2c 32 |offset-90,f(n%,2| 000008e0 29 2a 6d 66 29 0d 04 ce 06 20 ed 0d 04 d8 05 cd |)*mf).... ......| 000008f0 0d 04 e2 09 61 64 2d 3d 31 0d 04 ec 05 e1 0d 04 |....ad-=1.......| 00000900 f6 04 0d 05 00 1d dd f2 63 66 72 61 63 74 61 6c |........cfractal| 00000910 28 61 6e 67 6f 66 66 73 65 74 2c 6c 65 6e 29 0d |(angoffset,len).| 00000920 05 0a 0b ea 20 6e 25 2c 6d 66 0d 05 14 05 3a 0d |.... n%,mf....:.| 00000930 05 1e 15 61 64 2b 3d 31 3a 6d 66 3d 6c 65 6e 2f |...ad+=1:mf=len/| 00000940 31 32 38 30 0d 05 28 0d e7 20 61 64 3e 3d 64 20 |1280..(.. ad>=d | 00000950 8c 0d 05 32 3c 20 63 3d 78 2a 30 2e 32 38 31 32 |...2< c=x*0.2812| 00000960 35 3a 72 25 3d 79 2f 32 2b 32 35 36 3a 61 3d b2 |5:r%=y/2+256:a=.| 00000970 28 63 29 3a 70 78 3d b5 28 61 29 2a 72 25 2b 36 |(c):px=.(a)*r%+6| 00000980 34 30 3a 70 79 3d 9b 28 61 29 2a 72 25 0d 05 3c |40:py=.(a)*r%..<| 00000990 14 20 ec 20 70 78 2c 70 79 3a ec 20 70 78 2c 70 |. . px,py:. px,p| 000009a0 79 0d 05 46 0f 20 e3 20 6e 25 3d 31 20 b8 20 70 |y..F. . n%=1 . p| 000009b0 0d 05 50 42 20 20 61 3d b2 28 66 28 6e 25 2c 31 |..PB a=.(f(n%,1| 000009c0 29 2b 61 6e 67 6f 66 66 73 65 74 29 3a 78 2b 3d |)+angoffset):x+=| 000009d0 b5 28 61 29 2a 66 28 6e 25 2c 32 29 2a 6d 66 3a |.(a)*f(n%,2)*mf:| 000009e0 79 2b 3d 9b 28 61 29 2a 66 28 6e 25 2c 32 29 2a |y+=.(a)*f(n%,2)*| 000009f0 6d 66 0d 05 5a 3d 20 20 63 3d 78 2a 30 2e 32 38 |mf..Z= c=x*0.28| 00000a00 31 32 35 3a 72 25 3d 79 2f 32 2b 32 35 36 3a 61 |125:r%=y/2+256:a| 00000a10 3d b2 28 63 29 3a 70 78 3d b5 28 61 29 2a 72 25 |=.(c):px=.(a)*r%| 00000a20 2b 36 34 30 3a 70 79 3d 9b 28 61 29 2a 72 25 0d |+640:py=.(a)*r%.| 00000a30 05 64 16 20 20 e7 20 70 24 3d 22 4c 22 20 df 20 |.d. . p$="L" . | 00000a40 70 78 2c 70 79 0d 05 6e 18 20 20 e7 20 70 24 3d |px,py..n. . p$=| 00000a50 22 46 22 20 f0 38 35 2c 70 78 2c 70 79 0d 05 78 |"F" .85,px,py..x| 00000a60 23 20 20 e7 20 70 24 3d 22 50 22 20 80 20 b0 70 |# . p$="P" . .p| 00000a70 78 2c 79 29 3d 30 20 f0 36 39 2c 70 78 2c 70 79 |x,y)=0 .69,px,py| 00000a80 0d 05 82 06 20 ed 0d 05 8c 05 cc 0d 05 96 0f 20 |.... .......... | 00000a90 e3 20 6e 25 3d 31 20 b8 20 70 0d 05 a0 30 20 20 |. n%=1 . p...0 | 00000aa0 f2 63 66 72 61 63 74 61 6c 28 66 28 6e 25 2c 31 |.cfractal(f(n%,1| 00000ab0 29 2b 61 6e 67 6f 66 66 73 65 74 2d 39 30 2c 66 |)+angoffset-90,f| 00000ac0 28 6e 25 2c 32 29 2a 6d 66 29 0d 05 aa 06 20 ed |(n%,2)*mf).... .| 00000ad0 0d 05 b4 05 cd 0d 05 be 09 61 64 2d 3d 31 0d 05 |.........ad-=1..| 00000ae0 c8 05 e1 0d 05 d2 04 0d 05 dc 11 dd f2 70 6c 6f |.............plo| 00000af0 74 5f 73 63 72 65 65 6e 0d 05 e6 0b ea 20 78 25 |t_screen..... x%| 00000b00 2c 79 25 0d 05 f0 05 3a 0d 05 fa 48 e6 30 2c 31 |,y%....:...H.0,1| 00000b10 3a e3 79 25 3d 2d 35 31 32 b8 35 31 32 88 33 32 |:.y%=-512.512.32| 00000b20 3a 86 30 2c 79 25 2c 31 32 38 30 2c 79 25 3a ed |:.0,y%,1280,y%:.| 00000b30 3a e3 78 25 3d 30 b8 31 32 38 30 88 33 32 3a 86 |:.x%=0.1280.32:.| 00000b40 78 25 2c 2d 35 31 32 2c 78 25 2c 35 31 32 3a ed |x%,-512,x%,512:.| 00000b50 0d 06 04 05 3a 0d 06 0e 40 f1 22 46 72 61 63 74 |....:...@."Fract| 00000b60 61 6c 20 47 65 6e 65 72 61 74 6f 72 20 2d 20 77 |al Generator - w| 00000b70 72 69 74 74 65 6e 20 62 79 20 44 65 61 6e 20 41 |ritten by Dean A| 00000b80 6c 65 78 61 6e 64 72 6f 75 20 28 4a 61 6e 20 31 |lexandrou (Jan 1| 00000b90 39 39 38 29 22 0d 06 18 a7 f1 27 27 22 55 73 65 |998)".....''"Use| 00000ba0 20 74 68 65 20 6d 6f 75 73 65 20 74 6f 20 64 72 | the mouse to dr| 00000bb0 61 77 20 61 20 66 72 61 63 74 61 6c 20 63 75 72 |aw a fractal cur| 00000bc0 76 65 2e 20 50 72 65 73 73 20 61 20 62 75 74 74 |ve. Press a butt| 00000bd0 6f 6e 20 74 6f 20 73 65 74 20 74 68 65 20 6c 69 |on to set the li| 00000be0 6e 65 2e 22 27 22 46 69 6e 69 73 68 20 62 79 20 |ne."'"Finish by | 00000bf0 64 72 61 77 69 6e 67 20 74 6f 20 74 68 65 20 57 |drawing to the W| 00000c00 68 69 74 65 20 43 69 72 63 6c 65 2e 20 41 6c 74 |hite Circle. Alt| 00000c10 65 72 6e 61 74 69 76 65 6c 79 2c 20 63 68 6f 6f |ernatively, choo| 00000c20 73 65 20 61 20 66 72 61 63 74 61 6c 20 66 72 6f |se a fractal fro| 00000c30 6d 20 74 68 65 20 6d 65 6e 75 2e 22 0d 06 22 8f |m the menu."..".| 00000c40 f1 27 22 53 48 49 46 54 20 20 20 3d 20 20 75 6e |.'"SHIFT = un| 00000c50 6c 6f 63 6b 20 67 72 69 64 22 27 22 4f 20 20 20 |lock grid"'"O | 00000c60 20 20 20 20 3d 20 20 6f 70 74 69 6f 6e 20 73 63 | = option sc| 00000c70 72 65 65 6e 22 27 22 4d 20 20 20 20 20 20 20 3d |reen"'"M =| 00000c80 20 20 73 65 6c 65 63 74 20 66 72 61 63 74 61 6c | select fractal| 00000c90 20 66 72 6f 6d 20 4d 65 6e 75 22 27 22 45 53 43 | from Menu"'"ESC| 00000ca0 41 50 45 20 20 3d 20 20 72 65 73 74 61 72 74 73 |APE = restarts| 00000cb0 22 27 22 45 53 43 41 50 45 20 2b 20 53 48 49 46 |"'"ESCAPE + SHIF| 00000cc0 54 20 20 3d 20 20 71 75 69 74 22 0d 06 2c 05 3a |T = quit"..,.:| 00000cd0 0d 06 36 48 e6 30 2c 33 3a e3 79 25 3d 2d 35 31 |..6H.0,3:.y%=-51| 00000ce0 32 b8 35 31 32 88 36 34 3a 86 30 2c 79 25 2c 31 |2.512.64:.0,y%,1| 00000cf0 32 38 30 2c 79 25 3a ed 3a e3 78 25 3d 30 b8 31 |280,y%:.:.x%=0.1| 00000d00 32 38 30 88 36 34 3a 86 78 25 2c 2d 35 31 32 2c |280.64:.x%,-512,| 00000d10 78 25 2c 35 31 32 3a ed 0d 06 40 4a e6 30 2c 35 |x%,512:...@J.0,5| 00000d20 3a e3 79 25 3d 2d 35 31 32 b8 35 31 32 88 31 32 |:.y%=-512.512.12| 00000d30 38 3a 86 30 2c 79 25 2c 31 32 38 30 2c 79 25 3a |8:.0,y%,1280,y%:| 00000d40 ed 3a e3 78 25 3d 30 b8 31 32 38 30 88 31 32 38 |.:.x%=0.1280.128| 00000d50 3a 86 78 25 2c 2d 35 31 32 2c 78 25 2c 35 31 32 |:.x%,-512,x%,512| 00000d60 3a ed 0d 06 4a 3d e6 30 2c 31 31 3a 86 30 2c 30 |:...J=.0,11:.0,0| 00000d70 2c 31 32 38 30 2c 30 3a 86 36 34 30 2c 2d 35 31 |,1280,0:.640,-51| 00000d80 32 2c 36 34 30 2c 35 31 32 3a e6 30 2c 31 35 3a |2,640,512:.0,15:| 00000d90 c8 8f 20 c8 90 20 31 32 38 30 2c 30 2c 32 34 0d |.. .. 1280,0,24.| 00000da0 06 54 05 e1 0d 06 5e 04 0d 06 68 16 dd f2 64 72 |.T....^...h...dr| 00000db0 61 77 5f 6c 69 6e 65 5f 73 6f 5f 66 61 72 0d 06 |aw_line_so_far..| 00000dc0 72 12 ea 20 6e 25 2c 78 2c 79 2c 6c 78 2c 6c 79 |r.. n%,x,y,lx,ly| 00000dd0 0d 06 7c 05 3a 0d 06 86 0b e7 20 70 3c 32 20 e1 |..|.:..... p<2 .| 00000de0 0d 06 90 25 f4 20 78 78 3d 4f 50 45 4e 55 50 28 |...%. xx=OPENUP(| 00000df0 22 52 41 4d 3a 3a 52 61 6d 44 69 73 63 30 2e 24 |"RAM::RamDisc0.$| 00000e00 2e 46 44 22 29 0d 06 9a 10 e3 20 6e 25 3d 31 20 |.FD")..... n%=1 | 00000e10 b8 20 70 2d 31 0d 06 a4 26 20 6c 78 3d 6c 69 6e |. p-1...& lx=lin| 00000e20 65 25 28 6e 25 2d 31 2c 31 29 3a 6c 79 3d 6c 69 |e%(n%-1,1):ly=li| 00000e30 6e 65 25 28 6e 25 2d 31 2c 32 29 0d 06 ae 20 20 |ne%(n%-1,2)... | 00000e40 78 3d 6c 69 6e 65 25 28 6e 25 2c 31 29 3a 79 3d |x=line%(n%,1):y=| 00000e50 6c 69 6e 65 25 28 6e 25 2c 32 29 0d 06 b8 21 f4 |line%(n%,2)...!.| 00000e60 20 73 24 3d 53 54 52 24 28 78 29 2b 22 2c 22 2b | s$=STR$(x)+","+| 00000e70 53 54 52 24 28 79 29 2b 22 2c 20 22 0d 06 c2 10 |STR$(y)+", "....| 00000e80 f4 20 42 50 55 54 23 78 78 2c 73 24 0d 06 cc 36 |. BPUT#xx,s$...6| 00000e90 20 e6 30 2c 31 35 3a 86 20 6c 78 2c 6c 79 2c 78 | .0,15:. lx,ly,x| 00000ea0 2c 79 3a 86 20 6c 78 2b 34 2c 6c 79 2c 78 2b 34 |,y:. lx+4,ly,x+4| 00000eb0 2c 79 3a 86 20 6c 78 2c 6c 79 2b 34 2c 78 2c 79 |,y:. lx,ly+4,x,y| 00000ec0 2b 34 0d 06 d6 05 ed 0d 06 e0 0e f4 20 43 4c 4f |+4.......... CLO| 00000ed0 53 45 23 78 78 0d 06 ea 05 e1 0d 06 f4 04 0d 06 |SE#xx...........| 00000ee0 fe 0d dd f2 6f 70 74 69 6f 6e 73 0d 07 08 15 ea |....options.....| 00000ef0 20 70 6c 6f 74 24 2c 63 66 24 2c 41 24 2c 73 25 | plot$,cf$,A$,s%| 00000f00 0d 07 12 05 3a 0d 07 1c 1b e7 20 70 24 3d 22 50 |....:..... p$="P| 00000f10 22 20 70 6c 6f 74 24 3d 22 50 6f 69 6e 74 73 22 |" plot$="Points"| 00000f20 0d 07 26 25 e7 20 70 24 3d 22 46 22 20 70 6c 6f |..&%. p$="F" plo| 00000f30 74 24 3d 22 46 69 6c 6c 65 64 20 54 72 69 61 6e |t$="Filled Trian| 00000f40 67 6c 65 73 22 0d 07 30 1a e7 20 70 24 3d 22 4c |gles"..0.. p$="L| 00000f50 22 20 70 6c 6f 74 24 3d 22 4c 69 6e 65 73 22 0d |" plot$="Lines".| 00000f60 07 3a 05 3a 0d 07 44 28 e7 20 72 6f 74 25 3d 30 |.:.:..D(. rot%=0| 00000f70 20 63 66 24 3d 22 46 6c 61 74 22 20 8b 20 63 66 | cf$="Flat" . cf| 00000f80 24 3d 22 43 69 72 63 75 6c 61 72 22 0d 07 4e 05 |$="Circular"..N.| 00000f90 3a 0d 07 58 05 f5 0d 07 62 06 20 db 0d 07 6c 08 |:..X....b. ...l.| 00000fa0 20 fb 31 35 0d 07 76 0f 20 f1 22 4f 50 54 49 4f | .15..v. ."OPTIO| 00000fb0 4e 53 22 0d 07 80 2a 20 f1 27 22 28 50 29 20 50 |NS"...* .'"(P) P| 00000fc0 6c 6f 74 74 69 6e 67 20 54 65 63 68 6e 69 71 75 |lotting Techniqu| 00000fd0 65 20 20 20 3a 20 22 3b 70 6c 6f 74 24 0d 07 8a |e : ";plot$...| 00000fe0 26 20 f1 22 28 4e 29 20 4e 75 6d 62 65 72 20 6f |& ."(N) Number o| 00000ff0 66 20 49 74 65 72 61 74 69 6f 6e 73 20 3a 20 22 |f Iterations : "| 00001000 3b 69 25 0d 07 94 27 20 f1 22 28 47 29 20 47 72 |;i%...' ."(G) Gr| 00001010 61 64 75 61 6c 20 69 74 65 72 61 74 69 6e 67 20 |adual iterating | 00001020 20 20 20 3a 20 22 3b 67 69 24 0d 07 9e 27 20 f1 | : ";gi$...' .| 00001030 22 28 43 29 20 43 69 72 63 75 6c 61 72 2f 46 6c |"(C) Circular/Fl| 00001040 61 74 20 20 20 20 20 20 20 20 3a 20 22 3b 63 66 |at : ";cf| 00001050 24 0d 07 a8 27 20 f1 22 28 48 29 20 48 6f 72 69 |$...' ."(H) Hori| 00001060 7a 6f 6e 74 61 6c 20 53 71 75 65 65 7a 65 20 20 |zontal Squeeze | 00001070 20 3a 20 22 3b 68 73 24 0d 07 b2 27 20 f1 22 28 | : ";hs$...' ."(| 00001080 56 29 20 56 65 72 74 69 63 61 6c 20 53 71 75 65 |V) Vertical Sque| 00001090 65 7a 65 20 20 20 20 20 3a 20 22 3b 76 73 24 0d |eze : ";vs$.| 000010a0 07 bc 11 20 f1 27 22 28 45 29 20 45 78 69 74 22 |... .'"(E) Exit"| 000010b0 0d 07 c6 06 20 3a 0d 07 d0 12 20 41 24 3d bd 28 |.... :.... A$=.(| 000010c0 a5 20 80 20 26 44 46 29 0d 07 da 0f 20 e7 20 41 |. . &DF).... . A| 000010d0 24 3d 22 50 22 20 8c 0d 07 e4 0a 20 20 73 25 3d |$="P" ..... s%=| 000010e0 31 0d 07 ee 29 20 20 e7 20 70 24 3d 22 4c 22 20 |1...) . p$="L" | 000010f0 70 6c 6f 74 24 3d 22 50 6f 69 6e 74 73 22 3a 70 |plot$="Points":p| 00001100 24 3d 22 50 22 3a 73 25 3d 30 0d 07 f8 3a 20 20 |$="P":s%=0...: | 00001110 e7 20 70 24 3d 22 50 22 20 80 20 73 25 3d 31 20 |. p$="P" . s%=1 | 00001120 70 6c 6f 74 24 3d 22 46 69 6c 6c 65 64 20 54 72 |plot$="Filled Tr| 00001130 69 61 6e 67 6c 65 73 22 3a 70 24 3d 22 46 22 3a |iangles":p$="F":| 00001140 73 25 3d 30 0d 08 02 2f 20 20 e7 20 70 24 3d 22 |s%=0.../ . p$="| 00001150 46 22 20 80 20 73 25 3d 31 20 70 6c 6f 74 24 3d |F" . s%=1 plot$=| 00001160 22 4c 69 6e 65 73 22 3a 70 24 3d 22 4c 22 3a 73 |"Lines":p$="L":s| 00001170 25 3d 30 0d 08 0c 06 20 cd 0d 08 16 20 20 e7 20 |%=0.... .... . | 00001180 41 24 3d 22 4e 22 20 69 25 2b 3d 31 3a e7 20 69 |A$="N" i%+=1:. i| 00001190 25 3d 31 36 3a 69 25 3d 32 0d 08 20 0f 20 e7 20 |%=16:i%=2.. . . | 000011a0 41 24 3d 22 47 22 20 8c 0d 08 2a 25 20 20 e7 20 |A$="G" ...*% . | 000011b0 67 69 24 3d 22 4f 4e 22 20 67 69 24 3d 22 4f 46 |gi$="ON" gi$="OF| 000011c0 46 22 20 8b 20 67 69 24 3d 22 4f 4e 22 0d 08 34 |F" . gi$="ON"..4| 000011d0 06 20 cd 0d 08 3e 0f 20 e7 20 41 24 3d 22 43 22 |. ...>. . A$="C"| 000011e0 20 8c 0d 08 48 38 20 20 e7 20 72 6f 74 25 3d 30 | ...H8 . rot%=0| 000011f0 20 72 6f 74 25 3d 31 3a 63 66 24 3d 22 43 69 72 | rot%=1:cf$="Cir| 00001200 63 75 6c 61 72 22 20 8b 20 72 6f 74 25 3d 30 3a |cular" . rot%=0:| 00001210 63 66 24 3d 22 46 6c 61 74 22 0d 08 52 06 20 cd |cf$="Flat"..R. .| 00001220 0d 08 5c 0f 20 e7 20 41 24 3d 22 48 22 20 8c 0d |..\. . A$="H" ..| 00001230 08 66 25 20 20 e7 20 68 73 24 3d 22 4f 4e 22 20 |.f% . hs$="ON" | 00001240 68 73 24 3d 22 4f 46 46 22 20 8b 20 68 73 24 3d |hs$="OFF" . hs$=| 00001250 22 4f 4e 22 0d 08 70 06 20 cd 0d 08 7a 0f 20 e7 |"ON"..p. ...z. .| 00001260 20 41 24 3d 22 56 22 20 8c 0d 08 84 25 20 20 e7 | A$="V" ....% .| 00001270 20 76 73 24 3d 22 4f 4e 22 20 76 73 24 3d 22 4f | vs$="ON" vs$="O| 00001280 46 46 22 20 8b 20 76 73 24 3d 22 4f 4e 22 0d 08 |FF" . vs$="ON"..| 00001290 8e 06 20 cd 0d 08 98 0c fd 20 41 24 3d 22 45 22 |.. ...... A$="E"| 000012a0 0d 08 a2 05 e1 0d 08 ac 04 0d 08 b6 0a dd f2 6d |...............m| 000012b0 65 6e 75 0d 08 c0 0b ea 20 6e 25 2c 66 25 0d 08 |enu..... n%,f%..| 000012c0 ca 05 3a 0d 08 d4 05 db 0d 08 de 0d f1 22 4d 45 |..:.........."ME| 000012d0 4e 55 22 27 27 0d 08 e8 13 e3 20 6e 25 3d 31 20 |NU"''..... n%=1 | 000012e0 b8 20 66 72 61 63 73 25 0d 08 f2 1b 20 f1 3b 6e |. fracs%.... .;n| 000012f0 25 3b 22 29 22 3b 8a 34 29 3b 66 72 61 63 24 28 |%;")";.4);frac$(| 00001300 6e 25 29 0d 08 fc 05 ed 0d 09 06 41 f5 3a e8 27 |n%)........A.:.'| 00001310 27 22 57 68 69 63 68 20 66 72 61 63 74 61 6c 20 |'"Which fractal | 00001320 77 6f 75 6c 64 20 79 6f 75 20 6c 69 6b 65 3f 20 |would you like? | 00001330 3a 22 66 25 3a fd 20 66 25 3e 3d 31 20 80 20 66 |:"f%:. f%>=1 . f| 00001340 25 3c 3d 66 72 61 63 73 25 0d 09 10 14 70 3d 66 |%<=fracs%....p=f| 00001350 64 61 74 61 25 28 66 25 2c 30 2c 30 29 0d 09 1a |data%(f%,0,0)...| 00001360 0e e3 20 6e 25 3d 31 20 b8 20 70 0d 09 24 20 20 |.. n%=1 . p..$ | 00001370 6c 69 6e 65 25 28 6e 25 2c 31 29 3d 66 64 61 74 |line%(n%,1)=fdat| 00001380 61 25 28 66 25 2c 6e 25 2c 31 29 0d 09 2e 20 20 |a%(f%,n%,1)... | 00001390 6c 69 6e 65 25 28 6e 25 2c 32 29 3d 66 64 61 74 |line%(n%,2)=fdat| 000013a0 61 25 28 66 25 2c 6e 25 2c 32 29 0d 09 38 05 ed |a%(f%,n%,2)..8..| 000013b0 0d 09 42 05 e1 0d 09 4c 04 0d 09 56 17 dd f2 72 |..B....L...V...r| 000013c0 65 61 64 5f 66 72 61 63 74 61 6c 5f 64 61 74 61 |ead_fractal_data| 000013d0 0d 09 60 0c ea 20 6e 25 2c 6e 6e 25 0d 09 6a 05 |..`.. n%,nn%..j.| 000013e0 3a 0d 09 74 26 dc 20 22 53 69 6d 70 6c 65 20 48 |:..t&. "Simple H| 000013f0 69 6c 6c 22 2c 32 2c 20 36 34 30 2c 31 39 32 2c |ill",2, 640,192,| 00001400 20 31 32 38 30 2c 30 0d 09 7e 33 dc 20 22 4b 6f | 1280,0..~3. "Ko| 00001410 63 68 20 63 75 72 76 65 22 2c 34 2c 20 34 32 37 |ch curve",4, 427| 00001420 2c 30 2c 20 36 34 30 2c 32 39 35 2c 20 38 35 33 |,0, 640,295, 853| 00001430 2c 30 2c 20 31 32 38 30 2c 30 0d 09 88 56 dc 20 |,0, 1280,0...V. | 00001440 22 33 2f 32 20 63 75 72 76 65 22 2c 38 2c 20 33 |"3/2 curve",8, 3| 00001450 32 30 2c 30 2c 20 33 32 30 2c 33 32 30 2c 20 36 |20,0, 320,320, 6| 00001460 34 30 2c 33 32 30 2c 20 36 34 30 2c 30 2c 20 36 |40,320, 640,0, 6| 00001470 34 30 2c 2d 33 32 30 2c 20 39 36 30 2c 2d 33 32 |40,-320, 960,-32| 00001480 30 2c 20 39 36 30 2c 30 2c 20 31 32 38 30 2c 30 |0, 960,0, 1280,0| 00001490 0d 09 92 92 dc 20 22 51 75 61 74 65 72 6e 61 72 |..... "Quaternar| 000014a0 79 20 44 72 61 67 6f 6e 22 2c 31 33 2c 20 30 2c |y Dragon",13, 0,| 000014b0 32 35 36 2c 20 32 35 36 2c 32 35 36 2c 20 32 35 |256, 256,256, 25| 000014c0 36 2c 35 31 32 2c 20 35 31 32 2c 35 31 32 2c 20 |6,512, 512,512, | 000014d0 35 31 32 2c 32 35 36 2c 20 35 31 32 2c 30 2c 20 |512,256, 512,0, | 000014e0 37 36 38 2c 30 2c 20 37 36 38 2c 2d 32 35 36 2c |768,0, 768,-256,| 000014f0 20 37 37 38 2c 2d 35 31 32 2c 20 31 30 32 34 2c | 778,-512, 1024,| 00001500 2d 35 31 32 2c 20 31 30 32 34 2c 2d 32 35 36 2c |-512, 1024,-256,| 00001510 20 31 32 38 30 2c 2d 32 35 36 2c 20 31 32 38 30 | 1280,-256, 1280| 00001520 2c 30 0d 09 9c 6a dc 20 22 46 52 41 43 22 2c 33 |,0...j. "FRAC",3| 00001530 37 2c 20 36 34 2c 30 2c 20 36 34 2c 33 32 30 2c |7, 64,0, 64,320,| 00001540 20 32 35 36 2c 33 32 30 2c 20 32 35 36 2c 32 35 | 256,320, 256,25| 00001550 36 2c 20 31 32 38 2c 32 35 36 2c 20 31 32 38 2c |6, 128,256, 128,| 00001560 31 39 32 2c 20 32 35 36 2c 31 39 32 2c 20 32 35 |192, 256,192, 25| 00001570 36 2c 31 32 38 2c 20 31 32 38 2c 31 32 38 2c 20 |6,128, 128,128, | 00001580 31 32 38 2c 30 2c 20 33 38 34 2c 30 0d 09 a6 6c |128,0, 384,0...l| 00001590 dc 20 20 33 38 34 2c 33 32 30 2c 20 35 31 32 2c |. 384,320, 512,| 000015a0 33 32 30 2c 20 35 37 36 2c 32 35 36 2c 20 35 37 |320, 576,256, 57| 000015b0 36 2c 31 39 32 2c 20 35 31 32 2c 31 32 38 2c 20 |6,192, 512,128, | 000015c0 35 37 36 2c 36 34 2c 20 35 37 36 2c 30 2c 20 37 |576,64, 576,0, 7| 000015d0 30 34 2c 30 2c 20 37 30 34 2c 32 35 36 2c 20 37 |04,0, 704,256, 7| 000015e0 36 38 2c 33 32 30 2c 20 38 33 32 2c 33 32 30 2c |68,320, 832,320,| 000015f0 20 38 39 36 2c 32 35 36 0d 09 b0 6b dc 20 20 38 | 896,256...k. 8| 00001600 39 36 2c 30 2c 20 31 30 38 38 2c 30 2c 20 31 30 |96,0, 1088,0, 10| 00001610 32 34 2c 36 34 2c 20 31 30 32 34 2c 32 35 36 2c |24,64, 1024,256,| 00001620 20 31 30 38 38 2c 33 32 30 2c 20 31 32 31 36 2c | 1088,320, 1216,| 00001630 33 32 30 2c 20 31 32 31 36 2c 32 35 36 2c 20 31 |320, 1216,256, 1| 00001640 31 32 30 2c 32 35 36 2c 20 31 30 38 38 2c 32 32 |120,256, 1088,22| 00001650 34 2c 20 31 30 38 38 2c 39 36 2c 20 31 31 32 30 |4, 1088,96, 1120| 00001660 2c 36 34 0d 09 ba 1e dc 20 20 31 32 31 36 2c 36 |,64..... 1216,6| 00001670 34 2c 20 31 32 31 36 2c 30 2c 20 31 32 38 30 2c |4, 1216,0, 1280,| 00001680 30 0d 09 c4 0e dc 20 22 22 2c 31 2c 30 2c 30 0d |0..... "",1,0,0.| 00001690 09 ce 05 3a 0d 09 d8 21 de 20 66 72 61 63 24 28 |...:...!. frac$(| 000016a0 31 30 30 29 2c 66 64 61 74 61 25 28 31 30 30 2c |100),fdata%(100,| 000016b0 35 30 2c 32 29 0d 09 e2 05 3a 0d 09 ec 08 6e 25 |50,2)....:....n%| 000016c0 3d 30 0d 09 f6 05 f5 0d 0a 00 0a 20 6e 25 2b 3d |=0......... n%+=| 000016d0 31 0d 0a 0a 10 20 f3 20 66 72 61 63 24 28 6e 25 |1.... . frac$(n%| 000016e0 29 0d 0a 14 15 20 f3 20 66 64 61 74 61 25 28 6e |).... . fdata%(n| 000016f0 25 2c 30 2c 30 29 0d 0a 1e 1d 20 e3 20 6e 6e 25 |%,0,0).... . nn%| 00001700 3d 31 20 b8 20 66 64 61 74 61 25 28 6e 25 2c 30 |=1 . fdata%(n%,0| 00001710 2c 30 29 0d 0a 28 29 20 20 f3 20 66 64 61 74 61 |,0)..() . fdata| 00001720 25 28 6e 25 2c 6e 6e 25 2c 31 29 2c 66 64 61 74 |%(n%,nn%,1),fdat| 00001730 61 25 28 6e 25 2c 6e 6e 25 2c 32 29 0d 0a 32 06 |a%(n%,nn%,2)..2.| 00001740 20 ed 0d 0a 3c 12 fd 20 66 72 61 63 24 28 6e 25 | ...<.. frac$(n%| 00001750 29 3d 22 22 0d 0a 46 0f 66 72 61 63 73 25 3d 6e |)=""..F.fracs%=n| 00001760 25 2d 31 0d 0a 50 05 e1 0d ff |%-1..P....| 0000176a