Home » Archimedes archive » Acorn User » AU 1998-12.adf » Regulars » StarInfo/Granger/Docs/Original
StarInfo/Granger/Docs/Original
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-12.adf » Regulars |
Filename: | StarInfo/Granger/Docs/Original |
Read OK: | ✔ |
File size: | 10A2 bytes |
Load address: | 0000 |
Exec address: | 0000 |
File contents
10ON ERROR PRINT REPORT$+" at line "+STR$(ERL/10):END 20DIM e%(1,5,15) 30DIM em%(1,5,15) 40DIM ne%(1,5,15) 50DIM ns%(1,5,15) 60DIM m%(1,5) 70DIM forms$(1,5) 80DIM sym$(110) 90DIM name$(110) 100DIM atno%(110) 110DIM atms%(110) 120max_comps1=5 130max_elements=15 140PROCsetup 150PROCbreakdown(0,"Cu(SO4)2.H2O") 160PROCanalysis(0) 170PROCcompoundicons 180END 190 200DEF PROCsetup 210F=OPENIN "<Chem$Dir>.ChemData" 220n=1 230space%=68 240REPEAT 250L$=GET$#F 260p1=INSTR(L$,"!")+1:p2=INSTR(L$,"@")+1 270p3=INSTR(L$,"#")+1:p4=INSTR(L$,"$")+1 280p5=INSTR(L$,"%")+1:p6=INSTR(L$,"^")+1 290x=VAL(MID$(L$,0,p1))-1:y=VAL(MID$(L$,p1,p2-p1)) 300Sym$=MID$(L$,p2,p3-p2-1):Nm$=MID$(L$,p3,p4-p3-1) 310n1=VAL(MID$(L$,p4,p5-p4)):n2=VAL(MID$(L$,p5,p6-p5)) 320IF p1>1 THEN 330sym$(n)=Sym$:name$(n)=Nm$:atms%(n)=n1*10:atno%(n)=n2 340n+=1 350ENDIF 360UNTIL EOF#F 370CLOSE#F 380ENDPROC 390 400DEF PROCbreakdown(s,W$) 410E$="":n=0 420FOR c=1 TO LEN(W$) 430C$=MID$(W$,c,1) 440IF C$="+" THEN 450forms$(s,n)=E$:E$="":n+=1 460ELSE 470E$=E$+C$ 480ENDIF 490IF n>=max_comps1 THEN err=2:err1=s:c=LENW$ 500NEXTc 510IF n<=max_comps1 THEN forms$(s,n)=E$ 520ENDPROC 530 540DEF PROCdecode 550PROCclearvars 560PROCbreakdown(0,in$) 570PROCbreakdown(1,out$) 580IF err=0 THEN PROCanalysis(0) 590ENDPROC 600 610DEF PROCanalysis(what%) 620err=0:err1=0:err2=0:err3=0:err$="" 630FOR s=0 TO 1 640FOR n=0 TO max_comps1 650IF what%=1 THEN n=max_comps1+1 660W$=forms$(s,n) 670IF W$>"" THEN 680FOR c=1 TO LENW$ 690IF FNtype=4 THEN 700c+=1 710IF FNtype<>2 THEN W$=LEFT$(W$,c-2)+RIGHT$(W$,LENW$-c+1) 720ENDIF 730NEXT c 740c=1 750IF FNtype=2 THEN 760E$="" 770REPEAT 780c+=1 790E$+=C$ 800UNTIL FNtype<2 OR FNtype=3 OR c>LENW$ OR err 810m%(s,n)=VALE$ 820IF m%(s,n)>999 THEN err=4 830ENDIF 840n2=0:b=0:brst=0:r=0:nomult=0:cryst=0:crystpos=0 850REPEAT 860E$="":lastc=0 870loopcheck2=0 880REPEAT 890IF FNtype=3 THEN b=1:c+=1:brst=n2 900IF FNtype<2 THEN E$+=C$:c+=1 910IF loopcheck2=c THEN c=256 920loopcheck2=c 930UNTIL FNtype=-1 OR FNtype>0 OR c>LENW$ OR err 940id=FNsym_to_id(E$) 950IF id=-1 THEN 960IF E$>"" THEN err=1:err$=E$:err1=s:err2=n:err3=n2:E$="" 970ELSE 980IF n2>max_elements THEN err=5:err$=E$:err1=s ELSE E$="":r=0:e%(s,n,n2)=id 990ENDIF 1000loopcheck1=0:check=0 1010REPEAT 1020IF FNtype=2 THEN E$+=C$:c+=1 1030IF b=-1 THEN b=0:r=1:check=1 1040IF FNtype=4 THEN b=-1:PROCstopdotmult:c+=1 1050IF loopcheck1=c THEN c=256 1060loopcheck1=c 1070UNTIL FNtype=1 OR c>LENW$ OR FNtype>2 OR b=-1 OR err 1080PROCstopdotmult 1090IF FNtype=-1 THEN c+=1 1100IF VALE$=0 AND r=1 THEN c-=1 1110IF r=1 AND VALE$>0 THEN 1120r=0 1130FOR c2=brst TO n2-1 1140ns%(s,n,c2)=VALE$ 1150NEXT c2 1160ns%(s,n,c2-1)=VALE$+8888 1170n2-=1 1180ELSE 1190IF n2<max_elements AND VALE$>0 THEN em%(s,n,n2)=VALE$ 1200ENDIF 1210n2+=1 1220IF FNtype=5 THEN v=c:PROCstopdotmult:PROCdotmult 1230IF c=lastc THEN c=256 1240lastc=c 1250UNTIL c>LENW$ OR err OR c<0 OR n2>max_elements 1260PROCstopdotmult 1270ENDIF 1280NEXT n 1290NEXT s 1300ENDPROC 1310 1320DEF PROCstopdotmult 1330IF (FNtype=5 OR FNtype=3 OR c>LENW$ OR n2>max_elements) AND cryst THEN 1340FOR c2=crystpos TO n2-1 1350ns%(s,n,c2)=cryst 1360NEXT c2 1370ns%(s,n,n2)=cryst+8888 1380cryst=0 1390crystpos=0 1400ENDIF 1410ENDPROC 1420 1430DEF PROCdotmult 1440IF FNtype=5 THEN 1450c+=1:x=FNtype:c-=1 1460IF x=2 THEN 1470E$="" 1480c+=1 1490REPEAT 1500null=FNtype 1510E$+=C$ 1520c+=1 1530UNTIL FNtype<>2 OR c>LENW$ OR err 1540cryst=VALE$:E$="" 1550crystpos=n2 1560ELSE 1570c+=1 1580ENDIF 1590ENDIF 1600ENDPROC 1610 1620DEF FNtype 1630C$=MID$(W$,c,1) 1640tt=-1:A=ASC(C$) 1650IF A>=97 AND A<=122 THEN tt=0 1660IF A>=65 AND A<=90 THEN tt=1 1670IF A>=48 AND A<=57 THEN tt=2 1680IF A=40 THEN tt=3 1690IF A=41 THEN tt=4 1700IF A=46 THEN tt=5 1710=tt 1720 1730DEF FNsym_to_id(ch$) 1740fb=-1 1750FOR fd=0 TO 107 1760IF ch$=sym$(fd) AND ch$>"" THEN fb=fd:fd=107 1770NEXT fd 1780IF ch$="" THEN fb=-1 1790=fb 1800 1810DEF PROCcompoundicons 1820height=-80:pos=0:pos2=0:pos3=0:ram$="" 1830FOR s=0 TO 1 1840IF RIGHT$(ram$,3)=" + " THEN ram$=LEFT$(ram$,LEN(ram$)-3) 1850IF s=1 THEN ram$+=" =====> " 1860FOR n=0 TO max_comps1 1870IF forms$(s,n)>"" THEN 1880calc$=FNshowcalc(s,n) 1890nogo=0 1900LOCAL ERROR 1910ON ERROR LOCAL PRINT "EVAL error":nogo=1 1920IF nogo=0 THEN 1930tot$=STR$(EVAL(calc$))+" g" 1940PRINT forms$(s,n) 1950PRINT calc$+" = "+tot$ 1960ram$=ram$+tot$+" + " 1970ENDIF 1980RESTORE ERROR 1990ENDIF 2000NEXT n 2010IF ram$="" AND s=0 THEN ram$="0 g" 2020NEXT s 2030IF RIGHT$(ram$,3)=" + " THEN ram$=LEFT$(ram$,LEN(ram$)-3) 2040IF RIGHT$(ram$,2)="> " THEN ram$=ram$+" 0g" 2050ENDPROC 2060 2070DEF FNshowcalc(s1,n1) 2080out$="":cm=0:bs=0:mult=0 2090FOR c=0 TO max_elements 2100e=e%(s1,n1,c) 2110IF e THEN 2120IF c=0 THEN plus$="" ELSE plus$="+" 2130IF c=0 AND m%(s1,n1) THEN out$+=STR$(m%(s1,n1))+"*(":cm=1 2140IF ns%(s1,n1,c) AND bs=0 THEN 2150out$+=plus$+"(":bs=1:plus$="" 2160IF ns%(s1,n1,c)>8000 THEN mult=ns%(s1,n1,c)-8888 ELSE mult=ns%(s1,n1,c) 2170ENDIF 2180IF em%(s1,n1,c) THEN out$+=plus$+"("+LEFT$(STR$(atms%(e)/10),4)+"*"+STR$(em%(s1,n1,c))+")" ELSE out$+=plus$+LEFT$(STR$(atms%(e)/10),4) 2190ENDIF 2200 2210IF bs=1 AND (ns%(s1,n1,c)>8000 OR ns%(s1,n1,c)=0) THEN 2220IF mult>0 THEN out$+=")*"+STR$(mult) ELSE out$+=")" 2230bs=0:mult=0 2240ENDIF 2250NEXT c 2260IF cm=1 THEN out$+=")" 2270=out$
"� � � �$+" at line "+�(�/10):� � e%(1,5,15) � em%(1,5,15) (� ne%(1,5,15) 2� ns%(1,5,15) < � m%(1,5) F� forms$(1,5) P� sym$(110) Z� name$(110) d� atno%(110) n� atms%(110) xmax_comps1=5 �max_elements=15 � �setup � �breakdown(0,"Cu(SO4)2.H2O") ��analysis(0) ��compoundicons �� � �� �setup �F=� "<Chem$Dir>.ChemData" �n=1 � space%=68 �� � L$=�#F p1=�L$,"!")+1:p2=�L$,"@")+1 p3=�L$,"#")+1:p4=�L$,"$")+1 p5=�L$,"%")+1:p6=�L$,"^")+1 "'x=�(�L$,0,p1))-1:y=�(�L$,p1,p2-p1)) ,,Sym$=�L$,p2,p3-p2-1):Nm$=�L$,p3,p4-p3-1) 6+n1=�(�L$,p4,p5-p4)):n2=�(�L$,p5,p6-p5)) @� p1>1 � J8sym$(n)=Sym$:name$(n)=Nm$:atms%(n)=n1*10:atno%(n)=n2 Tn+=1 ^� h � �#F r�#F |� � �� �breakdown(s,W$) � E$="":n=0 �� c=1 � �(W$) �C$=�W$,c,1) �� C$="+" � �forms$(s,n)=E$:E$="":n+=1 �� �E$=E$+C$ �� �(� n>=max_comps1 � err=2:err1=s:c=�W$ ��c �$� n<=max_comps1 � forms$(s,n)=E$ � � �decode &�clearvars 0�breakdown(0,in$) :�breakdown(1,out$) D� err=0 � �analysis(0) N� X b� �analysis(what%) l&err=0:err1=0:err2=0:err3=0:err$="" v � s=0 � 1 �� n=0 � max_comps1 �� what%=1 � n=max_comps1+1 �W$=forms$(s,n) � � W$>"" � �� c=1 � �W$ �� �type=4 � �c+=1 �)� �type<>2 � W$=�W$,c-2)+�W$,�W$-c+1) �� �� c �c=1 �� �type=2 � � E$="" � c+=1 E$+=C$ %� �type<2 � �type=3 � c>�W$ � err *m%(s,n)=�E$ 4� m%(s,n)>999 � err=4 >� H3n2=0:b=0:brst=0:r=0:nomult=0:cryst=0:crystpos=0 R� \E$="":lastc=0 floopcheck2=0 p� z � �type=3 � b=1:c+=1:brst=n2 �� �type<2 � E$+=C$:c+=1 �� loopcheck2=c � c=256 �loopcheck2=c �&� �type=-1 � �type>0 � c>�W$ � err �id=�sym_to_id(E$) � � id=-1 � �7� E$>"" � err=1:err$=E$:err1=s:err2=n:err3=n2:E$="" �� �F� n2>max_elements � err=5:err$=E$:err1=s � E$="":r=0:e%(s,n,n2)=id �� �loopcheck1=0:check=0 �� �� �type=2 � E$+=C$:c+=1 � b=-1 � b=0:r=1:check=1 &� �type=4 � b=-1:�stopdotmult:c+=1 � loopcheck1=c � c=256 $loopcheck1=c .,� �type=1 � c>�W$ � �type>2 � b=-1 � err 8�stopdotmult B� �type=-1 � c+=1 L� �E$=0 � r=1 � c-=1 V� r=1 � �E$>0 � `r=0 j� c2=brst � n2-1 tns%(s,n,c2)=�E$ ~� c2 �ns%(s,n,c2-1)=�E$+8888 � n2-=1 �� �/� n2<max_elements � �E$>0 � em%(s,n,n2)=�E$ �� � n2+=1 �)� �type=5 � v=c:�stopdotmult:�dotmult �� c=lastc � c=256 �lastc=c �)� c>�W$ � err � c<0 � n2>max_elements ��stopdotmult �� � n � s � (� �stopdotmult 2=� (�type=5 � �type=3 � c>�W$ � n2>max_elements) � cryst � <� c2=crystpos � n2-1 Fns%(s,n,c2)=cryst P� c2 Zns%(s,n,n2)=cryst+8888 dcryst=0 ncrystpos=0 x� �� � �� �dotmult �� �type=5 � �c+=1:x=�type:c-=1 �� x=2 � � E$="" �c+=1 �� �null=�type � E$+=C$ �c+=1 �� �type<>2 � c>�W$ � err cryst=�E$:E$="" crystpos=n2 � "c+=1 ,� 6� @� J T� �type ^C$=�W$,c,1) htt=-1:A=�(C$) r� A>=97 � A<=122 � tt=0 |� A>=65 � A<=90 � tt=1 �� A>=48 � A<=57 � tt=2 �� A=40 � tt=3 �� A=41 � tt=4 �� A=46 � tt=5 �=tt � �� �sym_to_id(ch$) � fb=-1 �� fd=0 � 107 �*� ch$=sym$(fd) � ch$>"" � fb=fd:fd=107 �� fd �� ch$="" � fb=-1 �=fb � �compoundicons *height=-80:pos=0:pos2=0:pos3=0:ram$="" & � s=0 � 1 0,� �ram$,3)=" + " � ram$=�ram$,�(ram$)-3) :� s=1 � ram$+=" =====> " D� n=0 � max_comps1 N� forms$(s,n)>"" � Xcalc$=�showcalc(s,n) b nogo=0 l� � v� � � � "EVAL error":nogo=1 �� nogo=0 � �tot$=�(�(calc$))+" g" �� forms$(s,n) �� calc$+" = "+tot$ �ram$=ram$+tot$+" + " �� �� � �� �� n � � ram$="" � s=0 � ram$="0 g" �� s �,� �ram$,3)=" + " � ram$=�ram$,�(ram$)-3) �%� �ram$,2)="> " � ram$=ram$+" 0g" � � �showcalc(s1,n1) out$="":cm=0:bs=0:mult=0 *� c=0 � max_elements 4e=e%(s1,n1,c) > � e � H � c=0 � plus$="" � plus$="+" R4� c=0 � m%(s1,n1) � out$+=�(m%(s1,n1))+"*(":cm=1 \� ns%(s1,n1,c) � bs=0 � f!out$+=plus$+"(":bs=1:plus$="" pD� ns%(s1,n1,c)>8000 � mult=ns%(s1,n1,c)-8888 � mult=ns%(s1,n1,c) z� �p� em%(s1,n1,c) � out$+=plus$+"("+��(atms%(e)/10),4)+"*"+�(em%(s1,n1,c))+")" � out$+=plus$+��(atms%(e)/10),4) �� � �3� bs=1 � (ns%(s1,n1,c)>8000 � ns%(s1,n1,c)=0) � �-� mult>0 � out$+=")*"+�(mult) � out$+=")" �bs=0:mult=0 �� �� c �� cm=1 � out$+=")" � =out$ �
00000000 0d 00 0a 22 ee 20 85 20 f1 20 f6 24 2b 22 20 61 |...". . . .$+" a| 00000010 74 20 6c 69 6e 65 20 22 2b c3 28 9e 2f 31 30 29 |t line "+.(./10)| 00000020 3a e0 0d 00 14 10 de 20 65 25 28 31 2c 35 2c 31 |:...... e%(1,5,1| 00000030 35 29 0d 00 1e 11 de 20 65 6d 25 28 31 2c 35 2c |5)..... em%(1,5,| 00000040 31 35 29 0d 00 28 11 de 20 6e 65 25 28 31 2c 35 |15)..(.. ne%(1,5| 00000050 2c 31 35 29 0d 00 32 11 de 20 6e 73 25 28 31 2c |,15)..2.. ns%(1,| 00000060 35 2c 31 35 29 0d 00 3c 0d de 20 6d 25 28 31 2c |5,15)..<.. m%(1,| 00000070 35 29 0d 00 46 11 de 20 66 6f 72 6d 73 24 28 31 |5)..F.. forms$(1| 00000080 2c 35 29 0d 00 50 0f de 20 73 79 6d 24 28 31 31 |,5)..P.. sym$(11| 00000090 30 29 0d 00 5a 10 de 20 6e 61 6d 65 24 28 31 31 |0)..Z.. name$(11| 000000a0 30 29 0d 00 64 10 de 20 61 74 6e 6f 25 28 31 31 |0)..d.. atno%(11| 000000b0 30 29 0d 00 6e 10 de 20 61 74 6d 73 25 28 31 31 |0)..n.. atms%(11| 000000c0 30 29 0d 00 78 10 6d 61 78 5f 63 6f 6d 70 73 31 |0)..x.max_comps1| 000000d0 3d 35 0d 00 82 13 6d 61 78 5f 65 6c 65 6d 65 6e |=5....max_elemen| 000000e0 74 73 3d 31 35 0d 00 8c 0a f2 73 65 74 75 70 0d |ts=15.....setup.| 000000f0 00 96 20 f2 62 72 65 61 6b 64 6f 77 6e 28 30 2c |.. .breakdown(0,| 00000100 22 43 75 28 53 4f 34 29 32 2e 48 32 4f 22 29 0d |"Cu(SO4)2.H2O").| 00000110 00 a0 10 f2 61 6e 61 6c 79 73 69 73 28 30 29 0d |....analysis(0).| 00000120 00 aa 12 f2 63 6f 6d 70 6f 75 6e 64 69 63 6f 6e |....compoundicon| 00000130 73 0d 00 b4 05 e0 0d 00 be 04 0d 00 c8 0c dd 20 |s.............. | 00000140 f2 73 65 74 75 70 0d 00 d2 1d 46 3d 8e 20 22 3c |.setup....F=. "<| 00000150 43 68 65 6d 24 44 69 72 3e 2e 43 68 65 6d 44 61 |Chem$Dir>.ChemDa| 00000160 74 61 22 0d 00 dc 07 6e 3d 31 0d 00 e6 0d 73 70 |ta"....n=1....sp| 00000170 61 63 65 25 3d 36 38 0d 00 f0 05 f5 0d 00 fa 0a |ace%=68.........| 00000180 4c 24 3d be 23 46 0d 01 04 1f 70 31 3d a7 4c 24 |L$=.#F....p1=.L$| 00000190 2c 22 21 22 29 2b 31 3a 70 32 3d a7 4c 24 2c 22 |,"!")+1:p2=.L$,"| 000001a0 40 22 29 2b 31 0d 01 0e 1f 70 33 3d a7 4c 24 2c |@")+1....p3=.L$,| 000001b0 22 23 22 29 2b 31 3a 70 34 3d a7 4c 24 2c 22 24 |"#")+1:p4=.L$,"$| 000001c0 22 29 2b 31 0d 01 18 1f 70 35 3d a7 4c 24 2c 22 |")+1....p5=.L$,"| 000001d0 25 22 29 2b 31 3a 70 36 3d a7 4c 24 2c 22 5e 22 |%")+1:p6=.L$,"^"| 000001e0 29 2b 31 0d 01 22 27 78 3d bb 28 c1 4c 24 2c 30 |)+1.."'x=.(.L$,0| 000001f0 2c 70 31 29 29 2d 31 3a 79 3d bb 28 c1 4c 24 2c |,p1))-1:y=.(.L$,| 00000200 70 31 2c 70 32 2d 70 31 29 29 0d 01 2c 2c 53 79 |p1,p2-p1))..,,Sy| 00000210 6d 24 3d c1 4c 24 2c 70 32 2c 70 33 2d 70 32 2d |m$=.L$,p2,p3-p2-| 00000220 31 29 3a 4e 6d 24 3d c1 4c 24 2c 70 33 2c 70 34 |1):Nm$=.L$,p3,p4| 00000230 2d 70 33 2d 31 29 0d 01 36 2b 6e 31 3d bb 28 c1 |-p3-1)..6+n1=.(.| 00000240 4c 24 2c 70 34 2c 70 35 2d 70 34 29 29 3a 6e 32 |L$,p4,p5-p4)):n2| 00000250 3d bb 28 c1 4c 24 2c 70 35 2c 70 36 2d 70 35 29 |=.(.L$,p5,p6-p5)| 00000260 29 0d 01 40 0c e7 20 70 31 3e 31 20 8c 0d 01 4a |)..@.. p1>1 ...J| 00000270 38 73 79 6d 24 28 6e 29 3d 53 79 6d 24 3a 6e 61 |8sym$(n)=Sym$:na| 00000280 6d 65 24 28 6e 29 3d 4e 6d 24 3a 61 74 6d 73 25 |me$(n)=Nm$:atms%| 00000290 28 6e 29 3d 6e 31 2a 31 30 3a 61 74 6e 6f 25 28 |(n)=n1*10:atno%(| 000002a0 6e 29 3d 6e 32 0d 01 54 08 6e 2b 3d 31 0d 01 5e |n)=n2..T.n+=1..^| 000002b0 05 cd 0d 01 68 09 fd 20 c5 23 46 0d 01 72 07 d9 |....h.. .#F..r..| 000002c0 23 46 0d 01 7c 05 e1 0d 01 86 04 0d 01 90 16 dd |#F..|...........| 000002d0 20 f2 62 72 65 61 6b 64 6f 77 6e 28 73 2c 57 24 | .breakdown(s,W$| 000002e0 29 0d 01 9a 0d 45 24 3d 22 22 3a 6e 3d 30 0d 01 |)....E$="":n=0..| 000002f0 a4 11 e3 20 63 3d 31 20 b8 20 a9 28 57 24 29 0d |... c=1 . .(W$).| 00000300 01 ae 0f 43 24 3d c1 57 24 2c 63 2c 31 29 0d 01 |...C$=.W$,c,1)..| 00000310 b8 0e e7 20 43 24 3d 22 2b 22 20 8c 0d 01 c2 1d |... C$="+" .....| 00000320 66 6f 72 6d 73 24 28 73 2c 6e 29 3d 45 24 3a 45 |forms$(s,n)=E$:E| 00000330 24 3d 22 22 3a 6e 2b 3d 31 0d 01 cc 05 cc 0d 01 |$="":n+=1.......| 00000340 d6 0c 45 24 3d 45 24 2b 43 24 0d 01 e0 05 cd 0d |..E$=E$+C$......| 00000350 01 ea 28 e7 20 6e 3e 3d 6d 61 78 5f 63 6f 6d 70 |..(. n>=max_comp| 00000360 73 31 20 8c 20 65 72 72 3d 32 3a 65 72 72 31 3d |s1 . err=2:err1=| 00000370 73 3a 63 3d a9 57 24 0d 01 f4 06 ed 63 0d 01 fe |s:c=.W$.....c...| 00000380 24 e7 20 6e 3c 3d 6d 61 78 5f 63 6f 6d 70 73 31 |$. n<=max_comps1| 00000390 20 8c 20 66 6f 72 6d 73 24 28 73 2c 6e 29 3d 45 | . forms$(s,n)=E| 000003a0 24 0d 02 08 05 e1 0d 02 12 04 0d 02 1c 0d dd 20 |$.............. | 000003b0 f2 64 65 63 6f 64 65 0d 02 26 0e f2 63 6c 65 61 |.decode..&..clea| 000003c0 72 76 61 72 73 0d 02 30 15 f2 62 72 65 61 6b 64 |rvars..0..breakd| 000003d0 6f 77 6e 28 30 2c 69 6e 24 29 0d 02 3a 16 f2 62 |own(0,in$)..:..b| 000003e0 72 65 61 6b 64 6f 77 6e 28 31 2c 6f 75 74 24 29 |reakdown(1,out$)| 000003f0 0d 02 44 1a e7 20 65 72 72 3d 30 20 8c 20 f2 61 |..D.. err=0 . .a| 00000400 6e 61 6c 79 73 69 73 28 30 29 0d 02 4e 05 e1 0d |nalysis(0)..N...| 00000410 02 58 04 0d 02 62 16 dd 20 f2 61 6e 61 6c 79 73 |.X...b.. .analys| 00000420 69 73 28 77 68 61 74 25 29 0d 02 6c 26 65 72 72 |is(what%)..l&err| 00000430 3d 30 3a 65 72 72 31 3d 30 3a 65 72 72 32 3d 30 |=0:err1=0:err2=0| 00000440 3a 65 72 72 33 3d 30 3a 65 72 72 24 3d 22 22 0d |:err3=0:err$="".| 00000450 02 76 0d e3 20 73 3d 30 20 b8 20 31 0d 02 80 16 |.v.. s=0 . 1....| 00000460 e3 20 6e 3d 30 20 b8 20 6d 61 78 5f 63 6f 6d 70 |. n=0 . max_comp| 00000470 73 31 0d 02 8a 1e e7 20 77 68 61 74 25 3d 31 20 |s1..... what%=1 | 00000480 8c 20 6e 3d 6d 61 78 5f 63 6f 6d 70 73 31 2b 31 |. n=max_comps1+1| 00000490 0d 02 94 12 57 24 3d 66 6f 72 6d 73 24 28 73 2c |....W$=forms$(s,| 000004a0 6e 29 0d 02 9e 0d e7 20 57 24 3e 22 22 20 8c 0d |n)..... W$>"" ..| 000004b0 02 a8 0f e3 20 63 3d 31 20 b8 20 a9 57 24 0d 02 |.... c=1 . .W$..| 000004c0 b2 0f e7 20 a4 74 79 70 65 3d 34 20 8c 0d 02 bc |... .type=4 ....| 000004d0 08 63 2b 3d 31 0d 02 c6 29 e7 20 a4 74 79 70 65 |.c+=1...). .type| 000004e0 3c 3e 32 20 8c 20 57 24 3d c0 57 24 2c 63 2d 32 |<>2 . W$=.W$,c-2| 000004f0 29 2b c2 57 24 2c a9 57 24 2d 63 2b 31 29 0d 02 |)+.W$,.W$-c+1)..| 00000500 d0 05 cd 0d 02 da 07 ed 20 63 0d 02 e4 07 63 3d |........ c....c=| 00000510 31 0d 02 ee 0f e7 20 a4 74 79 70 65 3d 32 20 8c |1..... .type=2 .| 00000520 0d 02 f8 09 45 24 3d 22 22 0d 03 02 05 f5 0d 03 |....E$="".......| 00000530 0c 08 63 2b 3d 31 0d 03 16 0a 45 24 2b 3d 43 24 |..c+=1....E$+=C$| 00000540 0d 03 20 25 fd 20 a4 74 79 70 65 3c 32 20 84 20 |.. %. .type<2 . | 00000550 a4 74 79 70 65 3d 33 20 84 20 63 3e a9 57 24 20 |.type=3 . c>.W$ | 00000560 84 20 65 72 72 0d 03 2a 0f 6d 25 28 73 2c 6e 29 |. err..*.m%(s,n)| 00000570 3d bb 45 24 0d 03 34 19 e7 20 6d 25 28 73 2c 6e |=.E$..4.. m%(s,n| 00000580 29 3e 39 39 39 20 8c 20 65 72 72 3d 34 0d 03 3e |)>999 . err=4..>| 00000590 05 cd 0d 03 48 33 6e 32 3d 30 3a 62 3d 30 3a 62 |....H3n2=0:b=0:b| 000005a0 72 73 74 3d 30 3a 72 3d 30 3a 6e 6f 6d 75 6c 74 |rst=0:r=0:nomult| 000005b0 3d 30 3a 63 72 79 73 74 3d 30 3a 63 72 79 73 74 |=0:cryst=0:cryst| 000005c0 70 6f 73 3d 30 0d 03 52 05 f5 0d 03 5c 11 45 24 |pos=0..R....\.E$| 000005d0 3d 22 22 3a 6c 61 73 74 63 3d 30 0d 03 66 10 6c |="":lastc=0..f.l| 000005e0 6f 6f 70 63 68 65 63 6b 32 3d 30 0d 03 70 05 f5 |oopcheck2=0..p..| 000005f0 0d 03 7a 20 e7 20 a4 74 79 70 65 3d 33 20 8c 20 |..z . .type=3 . | 00000600 62 3d 31 3a 63 2b 3d 31 3a 62 72 73 74 3d 6e 32 |b=1:c+=1:brst=n2| 00000610 0d 03 84 1b e7 20 a4 74 79 70 65 3c 32 20 8c 20 |..... .type<2 . | 00000620 45 24 2b 3d 43 24 3a 63 2b 3d 31 0d 03 8e 1a e7 |E$+=C$:c+=1.....| 00000630 20 6c 6f 6f 70 63 68 65 63 6b 32 3d 63 20 8c 20 | loopcheck2=c . | 00000640 63 3d 32 35 36 0d 03 98 10 6c 6f 6f 70 63 68 65 |c=256....loopche| 00000650 63 6b 32 3d 63 0d 03 a2 26 fd 20 a4 74 79 70 65 |ck2=c...&. .type| 00000660 3d 2d 31 20 84 20 a4 74 79 70 65 3e 30 20 84 20 |=-1 . .type>0 . | 00000670 63 3e a9 57 24 20 84 20 65 72 72 0d 03 ac 15 69 |c>.W$ . err....i| 00000680 64 3d a4 73 79 6d 5f 74 6f 5f 69 64 28 45 24 29 |d=.sym_to_id(E$)| 00000690 0d 03 b6 0d e7 20 69 64 3d 2d 31 20 8c 0d 03 c0 |..... id=-1 ....| 000006a0 37 e7 20 45 24 3e 22 22 20 8c 20 65 72 72 3d 31 |7. E$>"" . err=1| 000006b0 3a 65 72 72 24 3d 45 24 3a 65 72 72 31 3d 73 3a |:err$=E$:err1=s:| 000006c0 65 72 72 32 3d 6e 3a 65 72 72 33 3d 6e 32 3a 45 |err2=n:err3=n2:E| 000006d0 24 3d 22 22 0d 03 ca 05 cc 0d 03 d4 46 e7 20 6e |$=""........F. n| 000006e0 32 3e 6d 61 78 5f 65 6c 65 6d 65 6e 74 73 20 8c |2>max_elements .| 000006f0 20 65 72 72 3d 35 3a 65 72 72 24 3d 45 24 3a 65 | err=5:err$=E$:e| 00000700 72 72 31 3d 73 20 8b 20 45 24 3d 22 22 3a 72 3d |rr1=s . E$="":r=| 00000710 30 3a 65 25 28 73 2c 6e 2c 6e 32 29 3d 69 64 0d |0:e%(s,n,n2)=id.| 00000720 03 de 05 cd 0d 03 e8 18 6c 6f 6f 70 63 68 65 63 |........loopchec| 00000730 6b 31 3d 30 3a 63 68 65 63 6b 3d 30 0d 03 f2 05 |k1=0:check=0....| 00000740 f5 0d 03 fc 1b e7 20 a4 74 79 70 65 3d 32 20 8c |...... .type=2 .| 00000750 20 45 24 2b 3d 43 24 3a 63 2b 3d 31 0d 04 06 1c | E$+=C$:c+=1....| 00000760 e7 20 62 3d 2d 31 20 8c 20 62 3d 30 3a 72 3d 31 |. b=-1 . b=0:r=1| 00000770 3a 63 68 65 63 6b 3d 31 0d 04 10 26 e7 20 a4 74 |:check=1...&. .t| 00000780 79 70 65 3d 34 20 8c 20 62 3d 2d 31 3a f2 73 74 |ype=4 . b=-1:.st| 00000790 6f 70 64 6f 74 6d 75 6c 74 3a 63 2b 3d 31 0d 04 |opdotmult:c+=1..| 000007a0 1a 1a e7 20 6c 6f 6f 70 63 68 65 63 6b 31 3d 63 |... loopcheck1=c| 000007b0 20 8c 20 63 3d 32 35 36 0d 04 24 10 6c 6f 6f 70 | . c=256..$.loop| 000007c0 63 68 65 63 6b 31 3d 63 0d 04 2e 2c fd 20 a4 74 |check1=c...,. .t| 000007d0 79 70 65 3d 31 20 84 20 63 3e a9 57 24 20 84 20 |ype=1 . c>.W$ . | 000007e0 a4 74 79 70 65 3e 32 20 84 20 62 3d 2d 31 20 84 |.type>2 . b=-1 .| 000007f0 20 65 72 72 0d 04 38 10 f2 73 74 6f 70 64 6f 74 | err..8..stopdot| 00000800 6d 75 6c 74 0d 04 42 15 e7 20 a4 74 79 70 65 3d |mult..B.. .type=| 00000810 2d 31 20 8c 20 63 2b 3d 31 0d 04 4c 18 e7 20 bb |-1 . c+=1..L.. .| 00000820 45 24 3d 30 20 80 20 72 3d 31 20 8c 20 63 2d 3d |E$=0 . r=1 . c-=| 00000830 31 0d 04 56 13 e7 20 72 3d 31 20 80 20 bb 45 24 |1..V.. r=1 . .E$| 00000840 3e 30 20 8c 0d 04 60 07 72 3d 30 0d 04 6a 14 e3 |>0 ...`.r=0..j..| 00000850 20 63 32 3d 62 72 73 74 20 b8 20 6e 32 2d 31 0d | c2=brst . n2-1.| 00000860 04 74 13 6e 73 25 28 73 2c 6e 2c 63 32 29 3d bb |.t.ns%(s,n,c2)=.| 00000870 45 24 0d 04 7e 08 ed 20 63 32 0d 04 88 1a 6e 73 |E$..~.. c2....ns| 00000880 25 28 73 2c 6e 2c 63 32 2d 31 29 3d bb 45 24 2b |%(s,n,c2-1)=.E$+| 00000890 38 38 38 38 0d 04 92 09 6e 32 2d 3d 31 0d 04 9c |8888....n2-=1...| 000008a0 05 cc 0d 04 a6 2f e7 20 6e 32 3c 6d 61 78 5f 65 |...../. n2<max_e| 000008b0 6c 65 6d 65 6e 74 73 20 80 20 bb 45 24 3e 30 20 |lements . .E$>0 | 000008c0 8c 20 65 6d 25 28 73 2c 6e 2c 6e 32 29 3d bb 45 |. em%(s,n,n2)=.E| 000008d0 24 0d 04 b0 05 cd 0d 04 ba 09 6e 32 2b 3d 31 0d |$.........n2+=1.| 000008e0 04 c4 29 e7 20 a4 74 79 70 65 3d 35 20 8c 20 76 |..). .type=5 . v| 000008f0 3d 63 3a f2 73 74 6f 70 64 6f 74 6d 75 6c 74 3a |=c:.stopdotmult:| 00000900 f2 64 6f 74 6d 75 6c 74 0d 04 ce 15 e7 20 63 3d |.dotmult..... c=| 00000910 6c 61 73 74 63 20 8c 20 63 3d 32 35 36 0d 04 d8 |lastc . c=256...| 00000920 0b 6c 61 73 74 63 3d 63 0d 04 e2 29 fd 20 63 3e |.lastc=c...). c>| 00000930 a9 57 24 20 84 20 65 72 72 20 84 20 63 3c 30 20 |.W$ . err . c<0 | 00000940 84 20 6e 32 3e 6d 61 78 5f 65 6c 65 6d 65 6e 74 |. n2>max_element| 00000950 73 0d 04 ec 10 f2 73 74 6f 70 64 6f 74 6d 75 6c |s.....stopdotmul| 00000960 74 0d 04 f6 05 cd 0d 05 00 07 ed 20 6e 0d 05 0a |t.......... n...| 00000970 07 ed 20 73 0d 05 14 05 e1 0d 05 1e 04 0d 05 28 |.. s...........(| 00000980 12 dd 20 f2 73 74 6f 70 64 6f 74 6d 75 6c 74 0d |.. .stopdotmult.| 00000990 05 32 3d e7 20 28 a4 74 79 70 65 3d 35 20 84 20 |.2=. (.type=5 . | 000009a0 a4 74 79 70 65 3d 33 20 84 20 63 3e a9 57 24 20 |.type=3 . c>.W$ | 000009b0 84 20 6e 32 3e 6d 61 78 5f 65 6c 65 6d 65 6e 74 |. n2>max_element| 000009c0 73 29 20 80 20 63 72 79 73 74 20 8c 0d 05 3c 18 |s) . cryst ...<.| 000009d0 e3 20 63 32 3d 63 72 79 73 74 70 6f 73 20 b8 20 |. c2=crystpos . | 000009e0 6e 32 2d 31 0d 05 46 15 6e 73 25 28 73 2c 6e 2c |n2-1..F.ns%(s,n,| 000009f0 63 32 29 3d 63 72 79 73 74 0d 05 50 08 ed 20 63 |c2)=cryst..P.. c| 00000a00 32 0d 05 5a 1a 6e 73 25 28 73 2c 6e 2c 6e 32 29 |2..Z.ns%(s,n,n2)| 00000a10 3d 63 72 79 73 74 2b 38 38 38 38 0d 05 64 0b 63 |=cryst+8888..d.c| 00000a20 72 79 73 74 3d 30 0d 05 6e 0e 63 72 79 73 74 70 |ryst=0..n.crystp| 00000a30 6f 73 3d 30 0d 05 78 05 cd 0d 05 82 05 e1 0d 05 |os=0..x.........| 00000a40 8c 04 0d 05 96 0e dd 20 f2 64 6f 74 6d 75 6c 74 |....... .dotmult| 00000a50 0d 05 a0 0f e7 20 a4 74 79 70 65 3d 35 20 8c 0d |..... .type=5 ..| 00000a60 05 aa 15 63 2b 3d 31 3a 78 3d a4 74 79 70 65 3a |...c+=1:x=.type:| 00000a70 63 2d 3d 31 0d 05 b4 0b e7 20 78 3d 32 20 8c 0d |c-=1..... x=2 ..| 00000a80 05 be 09 45 24 3d 22 22 0d 05 c8 08 63 2b 3d 31 |...E$=""....c+=1| 00000a90 0d 05 d2 05 f5 0d 05 dc 0e 6e 75 6c 6c 3d a4 74 |.........null=.t| 00000aa0 79 70 65 0d 05 e6 0a 45 24 2b 3d 43 24 0d 05 f0 |ype....E$+=C$...| 00000ab0 08 63 2b 3d 31 0d 05 fa 1c fd 20 a4 74 79 70 65 |.c+=1..... .type| 00000ac0 3c 3e 32 20 84 20 63 3e a9 57 24 20 84 20 65 72 |<>2 . c>.W$ . er| 00000ad0 72 0d 06 04 13 63 72 79 73 74 3d bb 45 24 3a 45 |r....cryst=.E$:E| 00000ae0 24 3d 22 22 0d 06 0e 0f 63 72 79 73 74 70 6f 73 |$=""....crystpos| 00000af0 3d 6e 32 0d 06 18 05 cc 0d 06 22 08 63 2b 3d 31 |=n2.......".c+=1| 00000b00 0d 06 2c 05 cd 0d 06 36 05 cd 0d 06 40 05 e1 0d |..,....6....@...| 00000b10 06 4a 04 0d 06 54 0b dd 20 a4 74 79 70 65 0d 06 |.J...T.. .type..| 00000b20 5e 0f 43 24 3d c1 57 24 2c 63 2c 31 29 0d 06 68 |^.C$=.W$,c,1)..h| 00000b30 11 74 74 3d 2d 31 3a 41 3d 97 28 43 24 29 0d 06 |.tt=-1:A=.(C$)..| 00000b40 72 1b e7 20 41 3e 3d 39 37 20 80 20 41 3c 3d 31 |r.. A>=97 . A<=1| 00000b50 32 32 20 8c 20 74 74 3d 30 0d 06 7c 1a e7 20 41 |22 . tt=0..|.. A| 00000b60 3e 3d 36 35 20 80 20 41 3c 3d 39 30 20 8c 20 74 |>=65 . A<=90 . t| 00000b70 74 3d 31 0d 06 86 1a e7 20 41 3e 3d 34 38 20 80 |t=1..... A>=48 .| 00000b80 20 41 3c 3d 35 37 20 8c 20 74 74 3d 32 0d 06 90 | A<=57 . tt=2...| 00000b90 11 e7 20 41 3d 34 30 20 8c 20 74 74 3d 33 0d 06 |.. A=40 . tt=3..| 00000ba0 9a 11 e7 20 41 3d 34 31 20 8c 20 74 74 3d 34 0d |... A=41 . tt=4.| 00000bb0 06 a4 11 e7 20 41 3d 34 36 20 8c 20 74 74 3d 35 |.... A=46 . tt=5| 00000bc0 0d 06 ae 07 3d 74 74 0d 06 b8 04 0d 06 c2 15 dd |....=tt.........| 00000bd0 20 a4 73 79 6d 5f 74 6f 5f 69 64 28 63 68 24 29 | .sym_to_id(ch$)| 00000be0 0d 06 cc 09 66 62 3d 2d 31 0d 06 d6 10 e3 20 66 |....fb=-1..... f| 00000bf0 64 3d 30 20 b8 20 31 30 37 0d 06 e0 2a e7 20 63 |d=0 . 107...*. c| 00000c00 68 24 3d 73 79 6d 24 28 66 64 29 20 80 20 63 68 |h$=sym$(fd) . ch| 00000c10 24 3e 22 22 20 8c 20 66 62 3d 66 64 3a 66 64 3d |$>"" . fb=fd:fd=| 00000c20 31 30 37 0d 06 ea 08 ed 20 66 64 0d 06 f4 14 e7 |107..... fd.....| 00000c30 20 63 68 24 3d 22 22 20 8c 20 66 62 3d 2d 31 0d | ch$="" . fb=-1.| 00000c40 06 fe 07 3d 66 62 0d 07 08 04 0d 07 12 14 dd 20 |...=fb......... | 00000c50 f2 63 6f 6d 70 6f 75 6e 64 69 63 6f 6e 73 0d 07 |.compoundicons..| 00000c60 1c 2a 68 65 69 67 68 74 3d 2d 38 30 3a 70 6f 73 |.*height=-80:pos| 00000c70 3d 30 3a 70 6f 73 32 3d 30 3a 70 6f 73 33 3d 30 |=0:pos2=0:pos3=0| 00000c80 3a 72 61 6d 24 3d 22 22 0d 07 26 0d e3 20 73 3d |:ram$=""..&.. s=| 00000c90 30 20 b8 20 31 0d 07 30 2c e7 20 c2 72 61 6d 24 |0 . 1..0,. .ram$| 00000ca0 2c 33 29 3d 22 20 2b 20 22 20 8c 20 72 61 6d 24 |,3)=" + " . ram$| 00000cb0 3d c0 72 61 6d 24 2c a9 28 72 61 6d 24 29 2d 33 |=.ram$,.(ram$)-3| 00000cc0 29 0d 07 3a 1c e7 20 73 3d 31 20 8c 20 72 61 6d |)..:.. s=1 . ram| 00000cd0 24 2b 3d 22 20 3d 3d 3d 3d 3d 3e 20 22 0d 07 44 |$+=" =====> "..D| 00000ce0 16 e3 20 6e 3d 30 20 b8 20 6d 61 78 5f 63 6f 6d |.. n=0 . max_com| 00000cf0 70 73 31 0d 07 4e 16 e7 20 66 6f 72 6d 73 24 28 |ps1..N.. forms$(| 00000d00 73 2c 6e 29 3e 22 22 20 8c 0d 07 58 18 63 61 6c |s,n)>"" ...X.cal| 00000d10 63 24 3d a4 73 68 6f 77 63 61 6c 63 28 73 2c 6e |c$=.showcalc(s,n| 00000d20 29 0d 07 62 0a 6e 6f 67 6f 3d 30 0d 07 6c 07 ea |)..b.nogo=0..l..| 00000d30 20 85 0d 07 76 1f ee 20 85 20 ea 20 f1 20 22 45 | ...v.. . . . "E| 00000d40 56 41 4c 20 65 72 72 6f 72 22 3a 6e 6f 67 6f 3d |VAL error":nogo=| 00000d50 31 0d 07 80 0e e7 20 6e 6f 67 6f 3d 30 20 8c 0d |1..... nogo=0 ..| 00000d60 07 8a 19 74 6f 74 24 3d c3 28 a0 28 63 61 6c 63 |...tot$=.(.(calc| 00000d70 24 29 29 2b 22 20 67 22 0d 07 94 11 f1 20 66 6f |$))+" g"..... fo| 00000d80 72 6d 73 24 28 73 2c 6e 29 0d 07 9e 16 f1 20 63 |rms$(s,n)..... c| 00000d90 61 6c 63 24 2b 22 20 3d 20 22 2b 74 6f 74 24 0d |alc$+" = "+tot$.| 00000da0 07 a8 18 72 61 6d 24 3d 72 61 6d 24 2b 74 6f 74 |...ram$=ram$+tot| 00000db0 24 2b 22 20 2b 20 22 0d 07 b2 05 cd 0d 07 bc 07 |$+" + ".........| 00000dc0 f7 20 85 0d 07 c6 05 cd 0d 07 d0 07 ed 20 6e 0d |. ........... n.| 00000dd0 07 da 20 e7 20 72 61 6d 24 3d 22 22 20 80 20 73 |.. . ram$="" . s| 00000de0 3d 30 20 8c 20 72 61 6d 24 3d 22 30 20 67 22 0d |=0 . ram$="0 g".| 00000df0 07 e4 07 ed 20 73 0d 07 ee 2c e7 20 c2 72 61 6d |.... s...,. .ram| 00000e00 24 2c 33 29 3d 22 20 2b 20 22 20 8c 20 72 61 6d |$,3)=" + " . ram| 00000e10 24 3d c0 72 61 6d 24 2c a9 28 72 61 6d 24 29 2d |$=.ram$,.(ram$)-| 00000e20 33 29 0d 07 f8 25 e7 20 c2 72 61 6d 24 2c 32 29 |3)...%. .ram$,2)| 00000e30 3d 22 3e 20 22 20 8c 20 72 61 6d 24 3d 72 61 6d |="> " . ram$=ram| 00000e40 24 2b 22 20 30 67 22 0d 08 02 05 e1 0d 08 0c 04 |$+" 0g".........| 00000e50 0d 08 16 16 dd 20 a4 73 68 6f 77 63 61 6c 63 28 |..... .showcalc(| 00000e60 73 31 2c 6e 31 29 0d 08 20 1c 6f 75 74 24 3d 22 |s1,n1).. .out$="| 00000e70 22 3a 63 6d 3d 30 3a 62 73 3d 30 3a 6d 75 6c 74 |":cm=0:bs=0:mult| 00000e80 3d 30 0d 08 2a 18 e3 20 63 3d 30 20 b8 20 6d 61 |=0..*.. c=0 . ma| 00000e90 78 5f 65 6c 65 6d 65 6e 74 73 0d 08 34 11 65 3d |x_elements..4.e=| 00000ea0 65 25 28 73 31 2c 6e 31 2c 63 29 0d 08 3e 09 e7 |e%(s1,n1,c)..>..| 00000eb0 20 65 20 8c 0d 08 48 20 e7 20 63 3d 30 20 8c 20 | e ...H . c=0 . | 00000ec0 70 6c 75 73 24 3d 22 22 20 8b 20 70 6c 75 73 24 |plus$="" . plus$| 00000ed0 3d 22 2b 22 0d 08 52 34 e7 20 63 3d 30 20 80 20 |="+"..R4. c=0 . | 00000ee0 6d 25 28 73 31 2c 6e 31 29 20 8c 20 6f 75 74 24 |m%(s1,n1) . out$| 00000ef0 2b 3d c3 28 6d 25 28 73 31 2c 6e 31 29 29 2b 22 |+=.(m%(s1,n1))+"| 00000f00 2a 28 22 3a 63 6d 3d 31 0d 08 5c 1b e7 20 6e 73 |*(":cm=1..\.. ns| 00000f10 25 28 73 31 2c 6e 31 2c 63 29 20 80 20 62 73 3d |%(s1,n1,c) . bs=| 00000f20 30 20 8c 0d 08 66 21 6f 75 74 24 2b 3d 70 6c 75 |0 ...f!out$+=plu| 00000f30 73 24 2b 22 28 22 3a 62 73 3d 31 3a 70 6c 75 73 |s$+"(":bs=1:plus| 00000f40 24 3d 22 22 0d 08 70 44 e7 20 6e 73 25 28 73 31 |$=""..pD. ns%(s1| 00000f50 2c 6e 31 2c 63 29 3e 38 30 30 30 20 8c 20 6d 75 |,n1,c)>8000 . mu| 00000f60 6c 74 3d 6e 73 25 28 73 31 2c 6e 31 2c 63 29 2d |lt=ns%(s1,n1,c)-| 00000f70 38 38 38 38 20 8b 20 6d 75 6c 74 3d 6e 73 25 28 |8888 . mult=ns%(| 00000f80 73 31 2c 6e 31 2c 63 29 0d 08 7a 05 cd 0d 08 84 |s1,n1,c)..z.....| 00000f90 70 e7 20 65 6d 25 28 73 31 2c 6e 31 2c 63 29 20 |p. em%(s1,n1,c) | 00000fa0 8c 20 6f 75 74 24 2b 3d 70 6c 75 73 24 2b 22 28 |. out$+=plus$+"(| 00000fb0 22 2b c0 c3 28 61 74 6d 73 25 28 65 29 2f 31 30 |"+..(atms%(e)/10| 00000fc0 29 2c 34 29 2b 22 2a 22 2b c3 28 65 6d 25 28 73 |),4)+"*"+.(em%(s| 00000fd0 31 2c 6e 31 2c 63 29 29 2b 22 29 22 20 8b 20 6f |1,n1,c))+")" . o| 00000fe0 75 74 24 2b 3d 70 6c 75 73 24 2b c0 c3 28 61 74 |ut$+=plus$+..(at| 00000ff0 6d 73 25 28 65 29 2f 31 30 29 2c 34 29 0d 08 8e |ms%(e)/10),4)...| 00001000 05 cd 0d 08 98 04 0d 08 a2 33 e7 20 62 73 3d 31 |.........3. bs=1| 00001010 20 80 20 28 6e 73 25 28 73 31 2c 6e 31 2c 63 29 | . (ns%(s1,n1,c)| 00001020 3e 38 30 30 30 20 84 20 6e 73 25 28 73 31 2c 6e |>8000 . ns%(s1,n| 00001030 31 2c 63 29 3d 30 29 20 8c 0d 08 ac 2d e7 20 6d |1,c)=0) ....-. m| 00001040 75 6c 74 3e 30 20 8c 20 6f 75 74 24 2b 3d 22 29 |ult>0 . out$+=")| 00001050 2a 22 2b c3 28 6d 75 6c 74 29 20 8b 20 6f 75 74 |*"+.(mult) . out| 00001060 24 2b 3d 22 29 22 0d 08 b6 0f 62 73 3d 30 3a 6d |$+=")"....bs=0:m| 00001070 75 6c 74 3d 30 0d 08 c0 05 cd 0d 08 ca 07 ed 20 |ult=0.......... | 00001080 63 0d 08 d4 16 e7 20 63 6d 3d 31 20 8c 20 6f 75 |c..... cm=1 . ou| 00001090 74 24 2b 3d 22 29 22 0d 08 de 09 3d 6f 75 74 24 |t$+=")"....=out$| 000010a0 0d ff |..| 000010a2