Home » CEEFAX disks » telesoftware9.adl » 18-09-88/CIRCUIT

18-09-88/CIRCUIT

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 » CEEFAX disks » telesoftware9.adl
Filename: 18-09-88/CIRCUIT
Read OK:
File size: 13CF bytes
Load address: FFFF0E00
Exec address: FFFF802B
Duplicates

There is 1 duplicate copy of this file in the archive:

File contents
   10 ON ERROR GOTO90
   20 REM ********************
   30 REM * Circuit Analyser *
   40 REM * Written Aug.1987 *
   50 REM ********************
   60 
   70 MODE4
   80 PROCset_up
   90 VDU20,19,7;0;0,26
  100 CALLst
  110 VDU5:MOVE1218,30:VDU255,255,4
  120 PROCbox(150,780,1040,940)
  130 PRINT" Circuit Analyser Package"
  140 PRINT'"  (C) 1987 - Version 2.1"
  150 PROCbox(300,150,850,700)
  160 PRINT"-Select Option-"
  170 PRINT''"1 - Editor"
  180 PRINT'"2 - Load Listing"
  190 PRINT"3 - Save Listing"
  200 PRINT"4 - Directory"
  210 PRINT'"5 - Quit"
  220 PRINT'"6 - Clear"
  230 VDU19;7;0;
  240 A%=ASC(GET$)
  250 IFA%<49ORA%>54 THEN240
  260 
  270 IFA%=49 PROCeditor
  280 IFA%=50 PROCload
  290 IFA%=51 PROCsave
  300 IFA%=52 PROCdir
  310 IFA%=53 PROCquit
  320 IFA%=54 RUN
  330 GOTO90
  340 
  350 DEFPROCerror(O%)
  360 PRINT''"Error : ";
  370 IFO%=1 PRINT"Value zero ?"
  380 IFO%=2 PRINT"Nodes same ?"
  390 IFO%=3 PRINT"Frequency zero ?"
  400 ENDPROC
  410 
  420 STOP
  430 DEFPROCbox(a%,b%,c%,d%)
  440 GCOL0,0:MOVEa%,b%
  450 MOVEa%,d%:PLOT85,c%,d%
  460 MOVEc%,b%:PLOT85,a%,b%
  470 GCOL0,1:DRAWa%,d%
  480 DRAWc%,d%:DRAWc%,b%
  490 DRAWa%,b%
  500 a%=a%+32:c%=c%-32
  510 b%=b%+33:d%=d%-33
  520 X1%=a%/32:X2%=c%/32
  530 Y1%=32-(b%/32):Y2%=32-(d%/32)
  540 VDU28,X1%,Y1%,X2%,Y2%,30,14
  550 ENDPROC
  560 
  570 
  580 DEFPROCasm
  590 O=&FFEE:st=&70
  600 FOR PA%=0TO2 STEP2
  610 P%=st:[OPT PA%
  620 LDA#30:JSRO:LDX#6
  630 .s0:LDY#213:.s1:LDA#&FF
  640 JSRO:DEY:BNEs1
  650 DEX:BNEs0:RTS:]
  660 NEXT:ENDPROC
  670 
  680 DEFPROCsolve_matrix
  690 FOR A%=2 TO N%
  700 B%=A%-1
  710 FOR C%=A% TO N%
  720 PV=Y(C%,B%)/Y(B%,B%)
  730 IF PV=0 THEN 780
  740 FOR D%=B% TO N%
  750 Y(C%,D%)=Y(C%,D%)/PV-Y(B%,D%)
  760 NEXT
  770 I(C%)=I(C%)/PV-I(B%)
  780 NEXT:NEXT
  790 FOR A%=1 TO N%
  800 B%=N%+1-A%
  810 C%=B%+1
  820 U=0
  830 IF A%=1 THEN 870
  840 FOR D%=C% TO N%
  850 U=U+Y(B%,D%)*V(D%)
  860 NEXT
  870 V(B%)=(I(B%)-U)/Y(B%,B%)
  880 NEXT:ENDPROC
  890 
  900 DEFPROCset_up
  910 DIM Y(40,40),I(40),V(40),A$(50)
  920 LI%=0:PRT=0
  930 PROCasm:VDU23,255
  940 VDU170,85,170,85,170,85,170,85
  960 ENDPROC
  970 
  980 DEFPROCdir
  990 PROCbox(240,100,900,750)
 1000 PRINT"Hit Shift to Scroll"'
 1010 *CAT
 1020 PRINT'"Hit Space for Menu"
 1030 IFNOT(INKEY(-99))THEN1030
 1040 ENDPROC
 1050 
 1060 DEFPROCload
 1070 PROCbox(200,400,1E3,500)
 1080 INPUT"File : "F$
 1090 IFLEN(F$)>7 VDU7:GOTO1070
 1100 X%=OPENIN(F$)
 1110 INPUT#X%,LI%
 1120 FORT%=1TOLI%
 1130 INPUT#X%,A$(T%)
 1140 NEXT
 1150 CLOSE#X%
 1160 ENDPROC
 1170 
 1180 DEFPROCsave
 1190 PROCbox(200,400,1E3,500)
 1200 INPUT"File : "A$
 1210 IFLEN(A$)>7 VDU7:GOTO1070
 1220 X%=OPENOUT(A$)
 1230 PRINT#X%,LI%
 1240 FORT%=1TOLI%
 1250 PRINT#X%,A$(T%)
 1260 NEXT
 1270 CLOSE#X%
 1280 ENDPROC
 1290 
 1300 DEFPROCphrase(A$,O%)
 1310 IFO% PO%=1
 1320 W$=""
 1330 REPEAT
 1340 X$=MID$(A$,PO%,1)
 1350 W$=W$+X$
 1360 PO%=PO%+1
 1370 UNTILX$="" OR X$=" "
 1380 W=VAL(W$)
 1390 ENDPROC
 1400 
 1410 DEFPROCquit
 1420 PROCbox(200,400,1E3,500)
 1430 PRINT"Are you Sure? Y/N"
 1440 IF(GET$)<>"Y" ENDPROC
 1450 VDU22,4
 1460 PRINT"Ready."':END
 1470 
 1480 DEFPROClist
 1490 PRINT'
 1500 FORT%=1TOLI%
 1510 PRINTA$(T%)
 1520 NEXT
 1530 PRINT'"Ready."'
 1540 ENDPROC
 1550 
 1560 DEFPROCeditor
 1570 PROCbox(100,30,640,100)
 1580 PRINT"Shift - scroll"
 1590 PROCbox(100,140,1100,1000)
 1600 PRINT"Editor 2.1"'
 1610 IFLI%<>0 PROClist
 1620 REPEAT
 1630 INPUT": "L$
 1640 IFL$="LIST" PROClist:GOTO1630
 1650 IFL$="ON" VDU2:PRT=1:GOTO1630
 1660 IFL$="OFF"VDU3:PRT=0:GOTO1630
 1670 IFL$="RUN" PROCrun
 1680 PROCphrase(L$,1):W%=W
 1690 IFW$="" THEN1630
 1700 A$(W%)=L$
 1710 IFW%>LI% LI%=W%
 1720 UNTIL L$="END"
 1730 FORT%=1TO1E3:NEXT
 1740 VDU3:ENDPROC
 1750 
 1760 DEFPROCfreq
 1770 PROCphrase(A$(T%),0)
 1780 PROCval
 1790 AF=W*2*PI
 1800 ENDPROC
 1810 
 1820 DEFPROCvolt
 1830 PROCphrase(A$(T%),0)
 1840 N1%=W
 1850 PROCphrase(A$(T%),0)
 1860 N2%=W
 1870 PROCphrase(A$(T%),0)
 1880 PROCval:VS=W:RS=1E-14:ADM=1/RS
 1890 IFW=0 ER%=1:ENDPROC
 1900 I(N1%)=I(N1%)-(VS/RS)
 1910 I(N2%)=I(N2%)+(VS/RS)
 1920 Y(N1%,N1%)=Y(N1%,N1%)+ADM
 1930 Y(N2%,N2%)=Y(N2%,N2%)+ADM
 1940 Y(N1%,N2%)=Y(N1%,N2%)-ADM
 1950 Y(N2%,N1%)=Y(N2%,N1%)-ADM
 1960 ENDPROC
 1970 
 1980 
 1990 DEFPROCres
 2000 PROCphrase(A$(T%),0)
 2010 N1%=W
 2020 PROCphrase(A$(T%),0)
 2030 N2%=W
 2040 PROCphrase(A$(T%),0)
 2050 PROCval
 2060 IFW=0 ER%=1:ENDPROC
 2070 ADM=1/W
 2080 Y(N1%,N1%)=Y(N1%,N1%)+ADM
 2090 Y(N2%,N2%)=Y(N2%,N2%)+ADM
 2100 Y(N1%,N2%)=Y(N1%,N2%)-ADM
 2110 Y(N2%,N1%)=Y(N2%,N1%)-ADM
 2120 ENDPROC
 2130 
 2140 DEFPROCcap
 2150 PROCphrase(A$(T%),0)
 2160 N1%=W
 2170 PROCphrase(A$(T%),0)
 2180 N2%=W
 2190 PROCphrase(A$(T%),0)
 2200 PROCval:ADM=W*AF
 2210 IF W=0 ER%=1:ENDPROC
 2220 Y(N1%,N1%)=Y(N1%,N1%)+ADM
 2230 Y(N2%,N2%)=Y(N2%,N2%)+ADM
 2240 Y(N1%,N2%)=Y(N1%,N2%)-ADM
 2250 Y(N2%,N1%)=Y(N2%,N1%)-ADM
 2260 ENDPROC
 2270 
 2280 DEFPROCind
 2290 PROCphrase(A$(T%),0)
 2300 N1%=W
 2310 PROCphrase(A$(T%),0)
 2320 N2%=W
 2330 PROCphrase(A$(T%),0)
 2340 PROCval
 2350 IFW=0 ER%=1:ENDPROC
 2360 IFAF=0 ER%=3:ENDPROC
 2370 ADM=1/(W*AF)
 2380 Y(N1%,N1%)=Y(N1%,N1%)+ADM
 2390 Y(N2%,N2%)=Y(N2%,N2%)+ADM
 2400 Y(N1%,N2%)=Y(N1%,N2%)-ADM
 2410 Y(N2%,N1%)=Y(N2%,N1%)-ADM
 2420 ENDPROC
 2430 
 2440 DEFPROCcurr
 2450 PROCphrase(A$(T%),0)
 2460 N1%=W
 2470 PROCphrase(A$(T%),0)
 2480 N2%=W
 2490 PROCphrase(A$(T%),0)
 2500 PROCval
 2510 IFW=0 ER%=1:ENDPROC
 2520 I(N1%)=I(N1%)-W
 2530 I(N2%)=I(N2%)+W
 2540 ENDPROC
 2550 
 2560 
 2570 DEFPROCval
 2580 V$=RIGHT$(W$,1)
 2590 IF V$<":" ENDPROC
 2600 W=VAL(LEFT$(W$,LEN(W$)-1))
 2610 IFV$="p" W=W*1E-12
 2620 IFV$="n" W=W*1E-9
 2630 IFV$="u" W=W*1E-6
 2640 IFV$="m" W=W*1E-3
 2650 IFV$="K" W=W*1E3
 2660 IFV$="M" W=W*1E6
 2670 IFV$="G" W=W*1E9
 2680 ENDPROC
 2690 
 2700 DEFPROCrun
 2710 PRINT'"Circuit Analyser 2.1"'
 2720 N%=0:AF=0:N1%=0
 2730 ER%=0:N2%=0:VDU3
 2740 FORA%=1TO30:FORB%=1TO30
 2750 Y(A%,B%)=0:NEXT
 2760 I(A%)=0:NEXT
 2770 FORT%=1 TO LI%
 2780 PROCphrase(A$(T%),1)
 2790 PRINT"Reading Line :";W
 2800 PROCphrase(A$(T%),0)
 2810 L$=LEFT$(W$,1)
 2820 W=0:VDU11
 2830 IF L$="*" GOTO2950
 2840 IF L$="F" PROCfreq:GOTO2950
 2850 IF L$="R" PROCres
 2860 IF L$="C" PROCcap
 2870 IF L$="L" PROCind
 2880 IF L$="I" PROCcurr
 2890 IF L$="V" PROCvolt
 2900 IF N1%=N2% PROCerror(2):GOTO3020
 2910 IFER%=1 PROCerror(1):GOTO3020
 2920 IFER%=3 PROCerror(3):GOTO3020
 2930 IF N1%>N% N%=N1%
 2940 IF N2%>N% N%=N2%
 2950 NEXT
 2960 PROCsolve_matrix
 2970 IF PRT=1 VDU2
 2980 PRINT''"Voltages are:-"' 
 2990 FORT%=1TON%
 3000 PRINT"V(";T%;") = ";V(T%)
 3010 NEXT
 3020 PRINT'"Ready."'
 3030 ENDPROC

 � � �DZ@
 � ********************
 � * Circuit Analyser *
( � * Written Aug.1987 *
2 � ********************
< 
F �4
P �set_up
Z �20,19,7;0;0,26
d �st
n �5:�1218,30:�255,255,4
x �box(150,780,1040,940)
�! �" Circuit Analyser Package"
�! �'"  (C) 1987 - Version 2.1"
� �box(300,150,850,700)
� �"-Select Option-"
� �''"1 - Editor"
� �'"2 - Load Listing"
� �"3 - Save Listing"
� �"4 - Directory"
� �'"5 - Quit"
� �'"6 - Clear"
�
 �19;7;0;
� A%=�(�)
� �A%<49�A%>54 ��dp@
 
 �A%=49 �editor
 �A%=50 �load
" �A%=51 �save
, �A%=52 �dir
6 �A%=53 �quit
@
 �A%=54 �
J
 �DZ@
T 
^ ��error(O%)
h �''"Error : ";
r �O%=1 �"Value zero ?"
| �O%=2 �"Nodes same ?"
� �O%=3 �"Frequency zero ?"
� �
� 
� �
� ��box(a%,b%,c%,d%)
� �0,0:�a%,b%
� �a%,d%:�85,c%,d%
� �c%,b%:�85,a%,b%
� �0,1:�a%,d%
� �c%,d%:�c%,b%
� �a%,b%
� a%=a%+32:c%=c%-32
� b%=b%+33:d%=d%-33
 X1%=a%/32:X2%=c%/32
" Y1%=32-(b%/32):Y2%=32-(d%/32)
 �28,X1%,Y1%,X2%,Y2%,30,14
& �
0 
: 
D
 ��asm
N O=&FFEE:st=&70
X � PA%=0�2 �2
b P%=st:[OPT PA%
l LDA#30:JSRO:LDX#6
v .s0:LDY#213:.s1:LDA#&FF
� JSRO:DEY:BNEs1
� DEX:BNEs0:RTS:]
� �:�
� 
� ��solve_matrix
� � A%=2 � N%
� B%=A%-1
� � C%=A% � N%
� PV=Y(C%,B%)/Y(B%,B%)
� � PV=0 � �TLC
� � D%=B% � N%
�" Y(C%,D%)=Y(C%,D%)/PV-Y(B%,D%)
� �
 I(C%)=I(C%)/PV-I(B%)
 �:�
 � A%=1 � N%
  B%=N%+1-A%
* C%=B%+1
4 U=0
> � A%=1 � �DfC
H � D%=C% � N%
R U=U+Y(B%,D%)*V(D%)
\ �
f V(B%)=(I(B%)-U)/Y(B%,B%)
p �:�
z 
�
 ��set_up
�" � Y(40,40),I(40),V(40),A$(50)
� LI%=0:PRT=0
� �asm:�23,255
�! �170,85,170,85,170,85,170,85
� �
� 
�
 ��dir
� �box(240,100,900,750)
� �"Hit Shift to Scroll"'
�	 *CAT
� �'"Hit Space for Menu"
 �(�(-99))��TFD
 �
 
$ ��load
. �box(200,400,1E3,500)
8 �"File : "F$
B �(F$)>7 �7:�TnD
L
 X%=�(F$)
V
 �#X%,LI%
` �T%=1�LI%
j �#X%,A$(T%)
t �
~	 �#X%
� �
� 
� ��save
� �box(200,400,1E3,500)
� �"File : "A$
� �(A$)>7 �7:�TnD
�
 X%=�(A$)
�
 �#X%,LI%
� �T%=1�LI%
� �#X%,A$(T%)
� �
�	 �#X%
 �

 
 ��phrase(A$,O%)
 �O% PO%=1
(
 W$=""
2 �
< X$=�A$,PO%,1)
F
 W$=W$+X$
P PO%=PO%+1
Z �X$="" � X$=" "
d W=�(W$)
n �
x 
� ��quit
� �box(200,400,1E3,500)
� �"Are you Sure? Y/N"
� �(�)<>"Y" �
�
 �22,4
� �"Ready."':�
� 
� ��list
� �'
� �T%=1�LI%
� �A$(T%)
� �
� �'"Ready."'
 �
 

 ��editor
" �box(100,30,640,100)
, �"Shift - scroll"
6 �box(100,140,1100,1000)
@ �"Editor 2.1"'
J �LI%<>0 �list
T �
^ �": "L$
h �L$="LIST" �list:�D^F
r �L$="ON" �2:PRT=1:�D^F
| �L$="OFF"�3:PRT=0:�D^F
� �L$="RUN" �run
� �phrase(L$,1):W%=W
� �W$="" ��D^F
� A$(W%)=L$
� �W%>LI% LI%=W%
� � L$="END"
� �T%=1�1E3:�
�	 �3:�
� 
� ��freq
� �phrase(A$(T%),0)
�	 �val
�
 AF=W*2*�
 �
 
 ��volt
& �phrase(A$(T%),0)
0
 N1%=W
: �phrase(A$(T%),0)
D
 N2%=W
N �phrase(A$(T%),0)
X  �val:VS=W:RS=1E-14:ADM=1/RS
b �W=0 ER%=1:�
l I(N1%)=I(N1%)-(VS/RS)
v I(N2%)=I(N2%)+(VS/RS)
� Y(N1%,N1%)=Y(N1%,N1%)+ADM
� Y(N2%,N2%)=Y(N2%,N2%)+ADM
� Y(N1%,N2%)=Y(N1%,N2%)-ADM
� Y(N2%,N1%)=Y(N2%,N1%)-ADM
� �
� 
� 
�
 ��res
� �phrase(A$(T%),0)
�
 N1%=W
� �phrase(A$(T%),0)
�
 N2%=W
� �phrase(A$(T%),0)
	 �val
 �W=0 ER%=1:�
 ADM=1/W
  Y(N1%,N1%)=Y(N1%,N1%)+ADM
* Y(N2%,N2%)=Y(N2%,N2%)+ADM
4 Y(N1%,N2%)=Y(N1%,N2%)-ADM
> Y(N2%,N1%)=Y(N2%,N1%)-ADM
H �
R 
\
 ��cap
f �phrase(A$(T%),0)
p
 N1%=W
z �phrase(A$(T%),0)
�
 N2%=W
� �phrase(A$(T%),0)
� �val:ADM=W*AF
� � W=0 ER%=1:�
� Y(N1%,N1%)=Y(N1%,N1%)+ADM
� Y(N2%,N2%)=Y(N2%,N2%)+ADM
� Y(N1%,N2%)=Y(N1%,N2%)-ADM
� Y(N2%,N1%)=Y(N2%,N1%)-ADM
� �
� 
�
 ��ind
� �phrase(A$(T%),0)
�
 N1%=W
	 �phrase(A$(T%),0)
	
 N2%=W
	 �phrase(A$(T%),0)
	$	 �val
	. �W=0 ER%=1:�
	8 �AF=0 ER%=3:�
	B ADM=1/(W*AF)
	L Y(N1%,N1%)=Y(N1%,N1%)+ADM
	V Y(N2%,N2%)=Y(N2%,N2%)+ADM
	` Y(N1%,N2%)=Y(N1%,N2%)-ADM
	j Y(N2%,N1%)=Y(N2%,N1%)-ADM
	t �
	~ 
	� ��curr
	� �phrase(A$(T%),0)
	�
 N1%=W
	� �phrase(A$(T%),0)
	�
 N2%=W
	� �phrase(A$(T%),0)
	�	 �val
	� �W=0 ER%=1:�
	� I(N1%)=I(N1%)-W
	� I(N2%)=I(N2%)+W
	� �
	� 
 


 ��val
 V$=�W$,1)
 � V$<":" �
( W=�(�W$,�(W$)-1))
2 �V$="p" W=W*1E-12
< �V$="n" W=W*1E-9
F �V$="u" W=W*1E-6
P �V$="m" W=W*1E-3
Z �V$="K" W=W*1E3
d �V$="M" W=W*1E6
n �V$="G" W=W*1E9
x �
� 
�
 ��run
� �'"Circuit Analyser 2.1"'
� N%=0:AF=0:N1%=0
� ER%=0:N2%=0:�3
� �A%=1�30:�B%=1�30
� Y(A%,B%)=0:�
� I(A%)=0:�
� �T%=1 � LI%
� �phrase(A$(T%),1)
� �"Reading Line :";W
� �phrase(A$(T%),0)
� L$=�W$,1)
 W=0:�11
 � L$="*" �tFK
 � L$="F" �freq:�tFK
" � L$="R" �res
, � L$="C" �cap
6 � L$="L" �ind
@ � L$="I" �curr
J � L$="V" �volt
T � N1%=N2% �error(2):�dLK
^ �ER%=1 �error(1):�dLK
h �ER%=3 �error(3):�dLK
r � N1%>N% N%=N1%
| � N2%>N% N%=N2%
� �
� �solve_matrix
� � PRT=1 �2
� �''"Voltages are:-"' 
�
 �T%=1�N%
� �"V(";T%;") = ";V(T%)
� �
� �'"Ready."'
� �
�
00000000  0d 00 0a 0e 20 ee 20 85  20 e5 8d 44 5a 40 0d 00  |.... . . ..DZ@..|
00000010  14 1b 20 f4 20 2a 2a 2a  2a 2a 2a 2a 2a 2a 2a 2a  |.. . ***********|
00000020  2a 2a 2a 2a 2a 2a 2a 2a  2a 0d 00 1e 1b 20 f4 20  |*********.... . |
00000030  2a 20 43 69 72 63 75 69  74 20 41 6e 61 6c 79 73  |* Circuit Analys|
00000040  65 72 20 2a 0d 00 28 1b  20 f4 20 2a 20 57 72 69  |er *..(. . * Wri|
00000050  74 74 65 6e 20 41 75 67  2e 31 39 38 37 20 2a 0d  |tten Aug.1987 *.|
00000060  00 32 1b 20 f4 20 2a 2a  2a 2a 2a 2a 2a 2a 2a 2a  |.2. . **********|
00000070  2a 2a 2a 2a 2a 2a 2a 2a  2a 2a 0d 00 3c 05 20 0d  |**********..<. .|
00000080  00 46 07 20 eb 34 0d 00  50 0c 20 f2 73 65 74 5f  |.F. .4..P. .set_|
00000090  75 70 0d 00 5a 14 20 ef  32 30 2c 31 39 2c 37 3b  |up..Z. .20,19,7;|
000000a0  30 3b 30 2c 32 36 0d 00  64 08 20 d6 73 74 0d 00  |0;0,26..d. .st..|
000000b0  6e 1b 20 ef 35 3a ec 31  32 31 38 2c 33 30 3a ef  |n. .5:.1218,30:.|
000000c0  32 35 35 2c 32 35 35 2c  34 0d 00 78 1b 20 f2 62  |255,255,4..x. .b|
000000d0  6f 78 28 31 35 30 2c 37  38 30 2c 31 30 34 30 2c  |ox(150,780,1040,|
000000e0  39 34 30 29 0d 00 82 21  20 f1 22 20 43 69 72 63  |940)...! ." Circ|
000000f0  75 69 74 20 41 6e 61 6c  79 73 65 72 20 50 61 63  |uit Analyser Pac|
00000100  6b 61 67 65 22 0d 00 8c  21 20 f1 27 22 20 20 28  |kage"...! .'"  (|
00000110  43 29 20 31 39 38 37 20  2d 20 56 65 72 73 69 6f  |C) 1987 - Versio|
00000120  6e 20 32 2e 31 22 0d 00  96 1a 20 f2 62 6f 78 28  |n 2.1".... .box(|
00000130  33 30 30 2c 31 35 30 2c  38 35 30 2c 37 30 30 29  |300,150,850,700)|
00000140  0d 00 a0 17 20 f1 22 2d  53 65 6c 65 63 74 20 4f  |.... ."-Select O|
00000150  70 74 69 6f 6e 2d 22 0d  00 aa 14 20 f1 27 27 22  |ption-".... .''"|
00000160  31 20 2d 20 45 64 69 74  6f 72 22 0d 00 b4 19 20  |1 - Editor".... |
00000170  f1 27 22 32 20 2d 20 4c  6f 61 64 20 4c 69 73 74  |.'"2 - Load List|
00000180  69 6e 67 22 0d 00 be 18  20 f1 22 33 20 2d 20 53  |ing".... ."3 - S|
00000190  61 76 65 20 4c 69 73 74  69 6e 67 22 0d 00 c8 15  |ave Listing"....|
000001a0  20 f1 22 34 20 2d 20 44  69 72 65 63 74 6f 72 79  | ."4 - Directory|
000001b0  22 0d 00 d2 11 20 f1 27  22 35 20 2d 20 51 75 69  |".... .'"5 - Qui|
000001c0  74 22 0d 00 dc 12 20 f1  27 22 36 20 2d 20 43 6c  |t".... .'"6 - Cl|
000001d0  65 61 72 22 0d 00 e6 0d  20 ef 31 39 3b 37 3b 30  |ear".... .19;7;0|
000001e0  3b 0d 00 f0 0c 20 41 25  3d 97 28 be 29 0d 00 fa  |;.... A%=.(.)...|
000001f0  17 20 e7 41 25 3c 34 39  84 41 25 3e 35 34 20 8c  |. .A%<49.A%>54 .|
00000200  8d 64 70 40 0d 01 04 05  20 0d 01 0e 13 20 e7 41  |.dp@.... .... .A|
00000210  25 3d 34 39 20 f2 65 64  69 74 6f 72 0d 01 18 11  |%=49 .editor....|
00000220  20 e7 41 25 3d 35 30 20  f2 6c 6f 61 64 0d 01 22  | .A%=50 .load.."|
00000230  11 20 e7 41 25 3d 35 31  20 f2 73 61 76 65 0d 01  |. .A%=51 .save..|
00000240  2c 10 20 e7 41 25 3d 35  32 20 f2 64 69 72 0d 01  |,. .A%=52 .dir..|
00000250  36 11 20 e7 41 25 3d 35  33 20 f2 71 75 69 74 0d  |6. .A%=53 .quit.|
00000260  01 40 0d 20 e7 41 25 3d  35 34 20 f9 0d 01 4a 0a  |.@. .A%=54 ...J.|
00000270  20 e5 8d 44 5a 40 0d 01  54 05 20 0d 01 5e 10 20  | ..DZ@..T. ..^. |
00000280  dd f2 65 72 72 6f 72 28  4f 25 29 0d 01 68 13 20  |..error(O%)..h. |
00000290  f1 27 27 22 45 72 72 6f  72 20 3a 20 22 3b 0d 01  |.''"Error : ";..|
000002a0  72 1a 20 e7 4f 25 3d 31  20 f1 22 56 61 6c 75 65  |r. .O%=1 ."Value|
000002b0  20 7a 65 72 6f 20 3f 22  0d 01 7c 1a 20 e7 4f 25  | zero ?"..|. .O%|
000002c0  3d 32 20 f1 22 4e 6f 64  65 73 20 73 61 6d 65 20  |=2 ."Nodes same |
000002d0  3f 22 0d 01 86 1e 20 e7  4f 25 3d 33 20 f1 22 46  |?".... .O%=3 ."F|
000002e0  72 65 71 75 65 6e 63 79  20 7a 65 72 6f 20 3f 22  |requency zero ?"|
000002f0  0d 01 90 06 20 e1 0d 01  9a 05 20 0d 01 a4 06 20  |.... ..... .... |
00000300  fa 0d 01 ae 17 20 dd f2  62 6f 78 28 61 25 2c 62  |..... ..box(a%,b|
00000310  25 2c 63 25 2c 64 25 29  0d 01 b8 10 20 e6 30 2c  |%,c%,d%).... .0,|
00000320  30 3a ec 61 25 2c 62 25  0d 01 c2 15 20 ec 61 25  |0:.a%,b%.... .a%|
00000330  2c 64 25 3a f0 38 35 2c  63 25 2c 64 25 0d 01 cc  |,d%:.85,c%,d%...|
00000340  15 20 ec 63 25 2c 62 25  3a f0 38 35 2c 61 25 2c  |. .c%,b%:.85,a%,|
00000350  62 25 0d 01 d6 10 20 e6  30 2c 31 3a df 61 25 2c  |b%.... .0,1:.a%,|
00000360  64 25 0d 01 e0 12 20 df  63 25 2c 64 25 3a df 63  |d%.... .c%,d%:.c|
00000370  25 2c 62 25 0d 01 ea 0b  20 df 61 25 2c 62 25 0d  |%,b%.... .a%,b%.|
00000380  01 f4 16 20 61 25 3d 61  25 2b 33 32 3a 63 25 3d  |... a%=a%+32:c%=|
00000390  63 25 2d 33 32 0d 01 fe  16 20 62 25 3d 62 25 2b  |c%-32.... b%=b%+|
000003a0  33 33 3a 64 25 3d 64 25  2d 33 33 0d 02 08 18 20  |33:d%=d%-33.... |
000003b0  58 31 25 3d 61 25 2f 33  32 3a 58 32 25 3d 63 25  |X1%=a%/32:X2%=c%|
000003c0  2f 33 32 0d 02 12 22 20  59 31 25 3d 33 32 2d 28  |/32..." Y1%=32-(|
000003d0  62 25 2f 33 32 29 3a 59  32 25 3d 33 32 2d 28 64  |b%/32):Y2%=32-(d|
000003e0  25 2f 33 32 29 0d 02 1c  1e 20 ef 32 38 2c 58 31  |%/32).... .28,X1|
000003f0  25 2c 59 31 25 2c 58 32  25 2c 59 32 25 2c 33 30  |%,Y1%,X2%,Y2%,30|
00000400  2c 31 34 0d 02 26 06 20  e1 0d 02 30 05 20 0d 02  |,14..&. ...0. ..|
00000410  3a 05 20 0d 02 44 0a 20  dd f2 61 73 6d 0d 02 4e  |:. ..D. ..asm..N|
00000420  13 20 4f 3d 26 46 46 45  45 3a 73 74 3d 26 37 30  |. O=&FFEE:st=&70|
00000430  0d 02 58 11 20 e3 20 50  41 25 3d 30 b8 32 20 88  |..X. . PA%=0.2 .|
00000440  32 0d 02 62 13 20 50 25  3d 73 74 3a 5b 4f 50 54  |2..b. P%=st:[OPT|
00000450  20 50 41 25 0d 02 6c 16  20 4c 44 41 23 33 30 3a  | PA%..l. LDA#30:|
00000460  4a 53 52 4f 3a 4c 44 58  23 36 0d 02 76 1c 20 2e  |JSRO:LDX#6..v. .|
00000470  73 30 3a 4c 44 59 23 32  31 33 3a 2e 73 31 3a 4c  |s0:LDY#213:.s1:L|
00000480  44 41 23 26 46 46 0d 02  80 13 20 4a 53 52 4f 3a  |DA#&FF.... JSRO:|
00000490  44 45 59 3a 42 4e 45 73  31 0d 02 8a 14 20 44 45  |DEY:BNEs1.... DE|
000004a0  58 3a 42 4e 45 73 30 3a  52 54 53 3a 5d 0d 02 94  |X:BNEs0:RTS:]...|
000004b0  08 20 ed 3a e1 0d 02 9e  05 20 0d 02 a8 13 20 dd  |. .:..... .... .|
000004c0  f2 73 6f 6c 76 65 5f 6d  61 74 72 69 78 0d 02 b2  |.solve_matrix...|
000004d0  10 20 e3 20 41 25 3d 32  20 b8 20 4e 25 0d 02 bc  |. . A%=2 . N%...|
000004e0  0c 20 42 25 3d 41 25 2d  31 0d 02 c6 11 20 e3 20  |. B%=A%-1.... . |
000004f0  43 25 3d 41 25 20 b8 20  4e 25 0d 02 d0 19 20 50  |C%=A% . N%.... P|
00000500  56 3d 59 28 43 25 2c 42  25 29 2f 59 28 42 25 2c  |V=Y(C%,B%)/Y(B%,|
00000510  42 25 29 0d 02 da 12 20  e7 20 50 56 3d 30 20 8c  |B%).... . PV=0 .|
00000520  20 8d 54 4c 43 0d 02 e4  11 20 e3 20 44 25 3d 42  | .TLC.... . D%=B|
00000530  25 20 b8 20 4e 25 0d 02  ee 22 20 59 28 43 25 2c  |% . N%..." Y(C%,|
00000540  44 25 29 3d 59 28 43 25  2c 44 25 29 2f 50 56 2d  |D%)=Y(C%,D%)/PV-|
00000550  59 28 42 25 2c 44 25 29  0d 02 f8 06 20 ed 0d 03  |Y(B%,D%).... ...|
00000560  02 19 20 49 28 43 25 29  3d 49 28 43 25 29 2f 50  |.. I(C%)=I(C%)/P|
00000570  56 2d 49 28 42 25 29 0d  03 0c 08 20 ed 3a ed 0d  |V-I(B%).... .:..|
00000580  03 16 10 20 e3 20 41 25  3d 31 20 b8 20 4e 25 0d  |... . A%=1 . N%.|
00000590  03 20 0f 20 42 25 3d 4e  25 2b 31 2d 41 25 0d 03  |. . B%=N%+1-A%..|
000005a0  2a 0c 20 43 25 3d 42 25  2b 31 0d 03 34 08 20 55  |*. C%=B%+1..4. U|
000005b0  3d 30 0d 03 3e 12 20 e7  20 41 25 3d 31 20 8c 20  |=0..>. . A%=1 . |
000005c0  8d 44 66 43 0d 03 48 11  20 e3 20 44 25 3d 43 25  |.DfC..H. . D%=C%|
000005d0  20 b8 20 4e 25 0d 03 52  17 20 55 3d 55 2b 59 28  | . N%..R. U=U+Y(|
000005e0  42 25 2c 44 25 29 2a 56  28 44 25 29 0d 03 5c 06  |B%,D%)*V(D%)..\.|
000005f0  20 ed 0d 03 66 1d 20 56  28 42 25 29 3d 28 49 28  | ...f. V(B%)=(I(|
00000600  42 25 29 2d 55 29 2f 59  28 42 25 2c 42 25 29 0d  |B%)-U)/Y(B%,B%).|
00000610  03 70 08 20 ed 3a e1 0d  03 7a 05 20 0d 03 84 0d  |.p. .:...z. ....|
00000620  20 dd f2 73 65 74 5f 75  70 0d 03 8e 22 20 de 20  | ..set_up..." . |
00000630  59 28 34 30 2c 34 30 29  2c 49 28 34 30 29 2c 56  |Y(40,40),I(40),V|
00000640  28 34 30 29 2c 41 24 28  35 30 29 0d 03 98 10 20  |(40),A$(50).... |
00000650  4c 49 25 3d 30 3a 50 52  54 3d 30 0d 03 a2 11 20  |LI%=0:PRT=0.... |
00000660  f2 61 73 6d 3a ef 32 33  2c 32 35 35 0d 03 ac 21  |.asm:.23,255...!|
00000670  20 ef 31 37 30 2c 38 35  2c 31 37 30 2c 38 35 2c  | .170,85,170,85,|
00000680  31 37 30 2c 38 35 2c 31  37 30 2c 38 35 0d 03 c0  |170,85,170,85...|
00000690  06 20 e1 0d 03 ca 05 20  0d 03 d4 0a 20 dd f2 64  |. ..... .... ..d|
000006a0  69 72 0d 03 de 1a 20 f2  62 6f 78 28 32 34 30 2c  |ir.... .box(240,|
000006b0  31 30 30 2c 39 30 30 2c  37 35 30 29 0d 03 e8 1c  |100,900,750)....|
000006c0  20 f1 22 48 69 74 20 53  68 69 66 74 20 74 6f 20  | ."Hit Shift to |
000006d0  53 63 72 6f 6c 6c 22 27  0d 03 f2 09 20 2a 43 41  |Scroll"'.... *CA|
000006e0  54 0d 03 fc 1b 20 f1 27  22 48 69 74 20 53 70 61  |T.... .'"Hit Spa|
000006f0  63 65 20 66 6f 72 20 4d  65 6e 75 22 0d 04 06 14  |ce for Menu"....|
00000700  20 e7 ac 28 a6 28 2d 39  39 29 29 8c 8d 54 46 44  | ..(.(-99))..TFD|
00000710  0d 04 10 06 20 e1 0d 04  1a 05 20 0d 04 24 0b 20  |.... ..... ..$. |
00000720  dd f2 6c 6f 61 64 0d 04  2e 1a 20 f2 62 6f 78 28  |..load.... .box(|
00000730  32 30 30 2c 34 30 30 2c  31 45 33 2c 35 30 30 29  |200,400,1E3,500)|
00000740  0d 04 38 11 20 e8 22 46  69 6c 65 20 3a 20 22 46  |..8. ."File : "F|
00000750  24 0d 04 42 16 20 e7 a9  28 46 24 29 3e 37 20 ef  |$..B. ..(F$)>7 .|
00000760  37 3a e5 8d 54 6e 44 0d  04 4c 0d 20 58 25 3d 8e  |7:..TnD..L. X%=.|
00000770  28 46 24 29 0d 04 56 0d  20 e8 23 58 25 2c 4c 49  |(F$)..V. .#X%,LI|
00000780  25 0d 04 60 0e 20 e3 54  25 3d 31 b8 4c 49 25 0d  |%..`. .T%=1.LI%.|
00000790  04 6a 10 20 e8 23 58 25  2c 41 24 28 54 25 29 0d  |.j. .#X%,A$(T%).|
000007a0  04 74 06 20 ed 0d 04 7e  09 20 d9 23 58 25 0d 04  |.t. ...~. .#X%..|
000007b0  88 06 20 e1 0d 04 92 05  20 0d 04 9c 0b 20 dd f2  |.. ..... .... ..|
000007c0  73 61 76 65 0d 04 a6 1a  20 f2 62 6f 78 28 32 30  |save.... .box(20|
000007d0  30 2c 34 30 30 2c 31 45  33 2c 35 30 30 29 0d 04  |0,400,1E3,500)..|
000007e0  b0 11 20 e8 22 46 69 6c  65 20 3a 20 22 41 24 0d  |.. ."File : "A$.|
000007f0  04 ba 16 20 e7 a9 28 41  24 29 3e 37 20 ef 37 3a  |... ..(A$)>7 .7:|
00000800  e5 8d 54 6e 44 0d 04 c4  0d 20 58 25 3d ae 28 41  |..TnD.... X%=.(A|
00000810  24 29 0d 04 ce 0d 20 f1  23 58 25 2c 4c 49 25 0d  |$).... .#X%,LI%.|
00000820  04 d8 0e 20 e3 54 25 3d  31 b8 4c 49 25 0d 04 e2  |... .T%=1.LI%...|
00000830  10 20 f1 23 58 25 2c 41  24 28 54 25 29 0d 04 ec  |. .#X%,A$(T%)...|
00000840  06 20 ed 0d 04 f6 09 20  d9 23 58 25 0d 05 00 06  |. ..... .#X%....|
00000850  20 e1 0d 05 0a 05 20 0d  05 14 14 20 dd f2 70 68  | ..... .... ..ph|
00000860  72 61 73 65 28 41 24 2c  4f 25 29 0d 05 1e 0e 20  |rase(A$,O%).... |
00000870  e7 4f 25 20 50 4f 25 3d  31 0d 05 28 0a 20 57 24  |.O% PO%=1..(. W$|
00000880  3d 22 22 0d 05 32 06 20  f5 0d 05 3c 12 20 58 24  |=""..2. ...<. X$|
00000890  3d c1 41 24 2c 50 4f 25  2c 31 29 0d 05 46 0d 20  |=.A$,PO%,1)..F. |
000008a0  57 24 3d 57 24 2b 58 24  0d 05 50 0e 20 50 4f 25  |W$=W$+X$..P. PO%|
000008b0  3d 50 4f 25 2b 31 0d 05  5a 14 20 fd 58 24 3d 22  |=PO%+1..Z. .X$="|
000008c0  22 20 84 20 58 24 3d 22  20 22 0d 05 64 0c 20 57  |" . X$=" "..d. W|
000008d0  3d bb 28 57 24 29 0d 05  6e 06 20 e1 0d 05 78 05  |=.(W$)..n. ...x.|
000008e0  20 0d 05 82 0b 20 dd f2  71 75 69 74 0d 05 8c 1a  | .... ..quit....|
000008f0  20 f2 62 6f 78 28 32 30  30 2c 34 30 30 2c 31 45  | .box(200,400,1E|
00000900  33 2c 35 30 30 29 0d 05  96 19 20 f1 22 41 72 65  |3,500).... ."Are|
00000910  20 79 6f 75 20 53 75 72  65 3f 20 59 2f 4e 22 0d  | you Sure? Y/N".|
00000920  05 a0 10 20 e7 28 be 29  3c 3e 22 59 22 20 e1 0d  |... .(.)<>"Y" ..|
00000930  05 aa 0a 20 ef 32 32 2c  34 0d 05 b4 11 20 f1 22  |... .22,4.... ."|
00000940  52 65 61 64 79 2e 22 27  3a e0 0d 05 be 05 20 0d  |Ready."':..... .|
00000950  05 c8 0b 20 dd f2 6c 69  73 74 0d 05 d2 07 20 f1  |... ..list.... .|
00000960  27 0d 05 dc 0e 20 e3 54  25 3d 31 b8 4c 49 25 0d  |'.... .T%=1.LI%.|
00000970  05 e6 0c 20 f1 41 24 28  54 25 29 0d 05 f0 06 20  |... .A$(T%).... |
00000980  ed 0d 05 fa 10 20 f1 27  22 52 65 61 64 79 2e 22  |..... .'"Ready."|
00000990  27 0d 06 04 06 20 e1 0d  06 0e 05 20 0d 06 18 0d  |'.... ..... ....|
000009a0  20 dd f2 65 64 69 74 6f  72 0d 06 22 19 20 f2 62  | ..editor..". .b|
000009b0  6f 78 28 31 30 30 2c 33  30 2c 36 34 30 2c 31 30  |ox(100,30,640,10|
000009c0  30 29 0d 06 2c 16 20 f1  22 53 68 69 66 74 20 2d  |0)..,. ."Shift -|
000009d0  20 73 63 72 6f 6c 6c 22  0d 06 36 1c 20 f2 62 6f  | scroll"..6. .bo|
000009e0  78 28 31 30 30 2c 31 34  30 2c 31 31 30 30 2c 31  |x(100,140,1100,1|
000009f0  30 30 30 29 0d 06 40 13  20 f1 22 45 64 69 74 6f  |000)..@. ."Edito|
00000a00  72 20 32 2e 31 22 27 0d  06 4a 12 20 e7 4c 49 25  |r 2.1"'..J. .LI%|
00000a10  3c 3e 30 20 f2 6c 69 73  74 0d 06 54 06 20 f5 0d  |<>0 .list..T. ..|
00000a20  06 5e 0c 20 e8 22 3a 20  22 4c 24 0d 06 68 1b 20  |.^. .": "L$..h. |
00000a30  e7 4c 24 3d 22 4c 49 53  54 22 20 f2 6c 69 73 74  |.L$="LIST" .list|
00000a40  3a e5 8d 44 5e 46 0d 06  72 1c 20 e7 4c 24 3d 22  |:..D^F..r. .L$="|
00000a50  4f 4e 22 20 ef 32 3a 50  52 54 3d 31 3a e5 8d 44  |ON" .2:PRT=1:..D|
00000a60  5e 46 0d 06 7c 1c 20 e7  4c 24 3d 22 4f 46 46 22  |^F..|. .L$="OFF"|
00000a70  ef 33 3a 50 52 54 3d 30  3a e5 8d 44 5e 46 0d 06  |.3:PRT=0:..D^F..|
00000a80  86 13 20 e7 4c 24 3d 22  52 55 4e 22 20 f2 72 75  |.. .L$="RUN" .ru|
00000a90  6e 0d 06 90 17 20 f2 70  68 72 61 73 65 28 4c 24  |n.... .phrase(L$|
00000aa0  2c 31 29 3a 57 25 3d 57  0d 06 9a 11 20 e7 57 24  |,1):W%=W.... .W$|
00000ab0  3d 22 22 20 8c 8d 44 5e  46 0d 06 a4 0e 20 41 24  |="" ..D^F.... A$|
00000ac0  28 57 25 29 3d 4c 24 0d  06 ae 13 20 e7 57 25 3e  |(W%)=L$.... .W%>|
00000ad0  4c 49 25 20 4c 49 25 3d  57 25 0d 06 b8 0f 20 fd  |LI% LI%=W%.... .|
00000ae0  20 4c 24 3d 22 45 4e 44  22 0d 06 c2 10 20 e3 54  | L$="END".... .T|
00000af0  25 3d 31 b8 31 45 33 3a  ed 0d 06 cc 09 20 ef 33  |%=1.1E3:..... .3|
00000b00  3a e1 0d 06 d6 05 20 0d  06 e0 0b 20 dd f2 66 72  |:..... .... ..fr|
00000b10  65 71 0d 06 ea 16 20 f2  70 68 72 61 73 65 28 41  |eq.... .phrase(A|
00000b20  24 28 54 25 29 2c 30 29  0d 06 f4 09 20 f2 76 61  |$(T%),0).... .va|
00000b30  6c 0d 06 fe 0d 20 41 46  3d 57 2a 32 2a af 0d 07  |l.... AF=W*2*...|
00000b40  08 06 20 e1 0d 07 12 05  20 0d 07 1c 0b 20 dd f2  |.. ..... .... ..|
00000b50  76 6f 6c 74 0d 07 26 16  20 f2 70 68 72 61 73 65  |volt..&. .phrase|
00000b60  28 41 24 28 54 25 29 2c  30 29 0d 07 30 0a 20 4e  |(A$(T%),0)..0. N|
00000b70  31 25 3d 57 0d 07 3a 16  20 f2 70 68 72 61 73 65  |1%=W..:. .phrase|
00000b80  28 41 24 28 54 25 29 2c  30 29 0d 07 44 0a 20 4e  |(A$(T%),0)..D. N|
00000b90  32 25 3d 57 0d 07 4e 16  20 f2 70 68 72 61 73 65  |2%=W..N. .phrase|
00000ba0  28 41 24 28 54 25 29 2c  30 29 0d 07 58 20 20 f2  |(A$(T%),0)..X  .|
00000bb0  76 61 6c 3a 56 53 3d 57  3a 52 53 3d 31 45 2d 31  |val:VS=W:RS=1E-1|
00000bc0  34 3a 41 44 4d 3d 31 2f  52 53 0d 07 62 11 20 e7  |4:ADM=1/RS..b. .|
00000bd0  57 3d 30 20 45 52 25 3d  31 3a e1 0d 07 6c 1a 20  |W=0 ER%=1:...l. |
00000be0  49 28 4e 31 25 29 3d 49  28 4e 31 25 29 2d 28 56  |I(N1%)=I(N1%)-(V|
00000bf0  53 2f 52 53 29 0d 07 76  1a 20 49 28 4e 32 25 29  |S/RS)..v. I(N2%)|
00000c00  3d 49 28 4e 32 25 29 2b  28 56 53 2f 52 53 29 0d  |=I(N2%)+(VS/RS).|
00000c10  07 80 1e 20 59 28 4e 31  25 2c 4e 31 25 29 3d 59  |... Y(N1%,N1%)=Y|
00000c20  28 4e 31 25 2c 4e 31 25  29 2b 41 44 4d 0d 07 8a  |(N1%,N1%)+ADM...|
00000c30  1e 20 59 28 4e 32 25 2c  4e 32 25 29 3d 59 28 4e  |. Y(N2%,N2%)=Y(N|
00000c40  32 25 2c 4e 32 25 29 2b  41 44 4d 0d 07 94 1e 20  |2%,N2%)+ADM.... |
00000c50  59 28 4e 31 25 2c 4e 32  25 29 3d 59 28 4e 31 25  |Y(N1%,N2%)=Y(N1%|
00000c60  2c 4e 32 25 29 2d 41 44  4d 0d 07 9e 1e 20 59 28  |,N2%)-ADM.... Y(|
00000c70  4e 32 25 2c 4e 31 25 29  3d 59 28 4e 32 25 2c 4e  |N2%,N1%)=Y(N2%,N|
00000c80  31 25 29 2d 41 44 4d 0d  07 a8 06 20 e1 0d 07 b2  |1%)-ADM.... ....|
00000c90  05 20 0d 07 bc 05 20 0d  07 c6 0a 20 dd f2 72 65  |. .... .... ..re|
00000ca0  73 0d 07 d0 16 20 f2 70  68 72 61 73 65 28 41 24  |s.... .phrase(A$|
00000cb0  28 54 25 29 2c 30 29 0d  07 da 0a 20 4e 31 25 3d  |(T%),0).... N1%=|
00000cc0  57 0d 07 e4 16 20 f2 70  68 72 61 73 65 28 41 24  |W.... .phrase(A$|
00000cd0  28 54 25 29 2c 30 29 0d  07 ee 0a 20 4e 32 25 3d  |(T%),0).... N2%=|
00000ce0  57 0d 07 f8 16 20 f2 70  68 72 61 73 65 28 41 24  |W.... .phrase(A$|
00000cf0  28 54 25 29 2c 30 29 0d  08 02 09 20 f2 76 61 6c  |(T%),0).... .val|
00000d00  0d 08 0c 11 20 e7 57 3d  30 20 45 52 25 3d 31 3a  |.... .W=0 ER%=1:|
00000d10  e1 0d 08 16 0c 20 41 44  4d 3d 31 2f 57 0d 08 20  |..... ADM=1/W.. |
00000d20  1e 20 59 28 4e 31 25 2c  4e 31 25 29 3d 59 28 4e  |. Y(N1%,N1%)=Y(N|
00000d30  31 25 2c 4e 31 25 29 2b  41 44 4d 0d 08 2a 1e 20  |1%,N1%)+ADM..*. |
00000d40  59 28 4e 32 25 2c 4e 32  25 29 3d 59 28 4e 32 25  |Y(N2%,N2%)=Y(N2%|
00000d50  2c 4e 32 25 29 2b 41 44  4d 0d 08 34 1e 20 59 28  |,N2%)+ADM..4. Y(|
00000d60  4e 31 25 2c 4e 32 25 29  3d 59 28 4e 31 25 2c 4e  |N1%,N2%)=Y(N1%,N|
00000d70  32 25 29 2d 41 44 4d 0d  08 3e 1e 20 59 28 4e 32  |2%)-ADM..>. Y(N2|
00000d80  25 2c 4e 31 25 29 3d 59  28 4e 32 25 2c 4e 31 25  |%,N1%)=Y(N2%,N1%|
00000d90  29 2d 41 44 4d 0d 08 48  06 20 e1 0d 08 52 05 20  |)-ADM..H. ...R. |
00000da0  0d 08 5c 0a 20 dd f2 63  61 70 0d 08 66 16 20 f2  |..\. ..cap..f. .|
00000db0  70 68 72 61 73 65 28 41  24 28 54 25 29 2c 30 29  |phrase(A$(T%),0)|
00000dc0  0d 08 70 0a 20 4e 31 25  3d 57 0d 08 7a 16 20 f2  |..p. N1%=W..z. .|
00000dd0  70 68 72 61 73 65 28 41  24 28 54 25 29 2c 30 29  |phrase(A$(T%),0)|
00000de0  0d 08 84 0a 20 4e 32 25  3d 57 0d 08 8e 16 20 f2  |.... N2%=W.... .|
00000df0  70 68 72 61 73 65 28 41  24 28 54 25 29 2c 30 29  |phrase(A$(T%),0)|
00000e00  0d 08 98 12 20 f2 76 61  6c 3a 41 44 4d 3d 57 2a  |.... .val:ADM=W*|
00000e10  41 46 0d 08 a2 12 20 e7  20 57 3d 30 20 45 52 25  |AF.... . W=0 ER%|
00000e20  3d 31 3a e1 0d 08 ac 1e  20 59 28 4e 31 25 2c 4e  |=1:..... Y(N1%,N|
00000e30  31 25 29 3d 59 28 4e 31  25 2c 4e 31 25 29 2b 41  |1%)=Y(N1%,N1%)+A|
00000e40  44 4d 0d 08 b6 1e 20 59  28 4e 32 25 2c 4e 32 25  |DM.... Y(N2%,N2%|
00000e50  29 3d 59 28 4e 32 25 2c  4e 32 25 29 2b 41 44 4d  |)=Y(N2%,N2%)+ADM|
00000e60  0d 08 c0 1e 20 59 28 4e  31 25 2c 4e 32 25 29 3d  |.... Y(N1%,N2%)=|
00000e70  59 28 4e 31 25 2c 4e 32  25 29 2d 41 44 4d 0d 08  |Y(N1%,N2%)-ADM..|
00000e80  ca 1e 20 59 28 4e 32 25  2c 4e 31 25 29 3d 59 28  |.. Y(N2%,N1%)=Y(|
00000e90  4e 32 25 2c 4e 31 25 29  2d 41 44 4d 0d 08 d4 06  |N2%,N1%)-ADM....|
00000ea0  20 e1 0d 08 de 05 20 0d  08 e8 0a 20 dd f2 69 6e  | ..... .... ..in|
00000eb0  64 0d 08 f2 16 20 f2 70  68 72 61 73 65 28 41 24  |d.... .phrase(A$|
00000ec0  28 54 25 29 2c 30 29 0d  08 fc 0a 20 4e 31 25 3d  |(T%),0).... N1%=|
00000ed0  57 0d 09 06 16 20 f2 70  68 72 61 73 65 28 41 24  |W.... .phrase(A$|
00000ee0  28 54 25 29 2c 30 29 0d  09 10 0a 20 4e 32 25 3d  |(T%),0).... N2%=|
00000ef0  57 0d 09 1a 16 20 f2 70  68 72 61 73 65 28 41 24  |W.... .phrase(A$|
00000f00  28 54 25 29 2c 30 29 0d  09 24 09 20 f2 76 61 6c  |(T%),0)..$. .val|
00000f10  0d 09 2e 11 20 e7 57 3d  30 20 45 52 25 3d 31 3a  |.... .W=0 ER%=1:|
00000f20  e1 0d 09 38 12 20 e7 41  46 3d 30 20 45 52 25 3d  |...8. .AF=0 ER%=|
00000f30  33 3a e1 0d 09 42 11 20  41 44 4d 3d 31 2f 28 57  |3:...B. ADM=1/(W|
00000f40  2a 41 46 29 0d 09 4c 1e  20 59 28 4e 31 25 2c 4e  |*AF)..L. Y(N1%,N|
00000f50  31 25 29 3d 59 28 4e 31  25 2c 4e 31 25 29 2b 41  |1%)=Y(N1%,N1%)+A|
00000f60  44 4d 0d 09 56 1e 20 59  28 4e 32 25 2c 4e 32 25  |DM..V. Y(N2%,N2%|
00000f70  29 3d 59 28 4e 32 25 2c  4e 32 25 29 2b 41 44 4d  |)=Y(N2%,N2%)+ADM|
00000f80  0d 09 60 1e 20 59 28 4e  31 25 2c 4e 32 25 29 3d  |..`. Y(N1%,N2%)=|
00000f90  59 28 4e 31 25 2c 4e 32  25 29 2d 41 44 4d 0d 09  |Y(N1%,N2%)-ADM..|
00000fa0  6a 1e 20 59 28 4e 32 25  2c 4e 31 25 29 3d 59 28  |j. Y(N2%,N1%)=Y(|
00000fb0  4e 32 25 2c 4e 31 25 29  2d 41 44 4d 0d 09 74 06  |N2%,N1%)-ADM..t.|
00000fc0  20 e1 0d 09 7e 05 20 0d  09 88 0b 20 dd f2 63 75  | ...~. .... ..cu|
00000fd0  72 72 0d 09 92 16 20 f2  70 68 72 61 73 65 28 41  |rr.... .phrase(A|
00000fe0  24 28 54 25 29 2c 30 29  0d 09 9c 0a 20 4e 31 25  |$(T%),0).... N1%|
00000ff0  3d 57 0d 09 a6 16 20 f2  70 68 72 61 73 65 28 41  |=W.... .phrase(A|
00001000  24 28 54 25 29 2c 30 29  0d 09 b0 0a 20 4e 32 25  |$(T%),0).... N2%|
00001010  3d 57 0d 09 ba 16 20 f2  70 68 72 61 73 65 28 41  |=W.... .phrase(A|
00001020  24 28 54 25 29 2c 30 29  0d 09 c4 09 20 f2 76 61  |$(T%),0).... .va|
00001030  6c 0d 09 ce 11 20 e7 57  3d 30 20 45 52 25 3d 31  |l.... .W=0 ER%=1|
00001040  3a e1 0d 09 d8 14 20 49  28 4e 31 25 29 3d 49 28  |:..... I(N1%)=I(|
00001050  4e 31 25 29 2d 57 0d 09  e2 14 20 49 28 4e 32 25  |N1%)-W.... I(N2%|
00001060  29 3d 49 28 4e 32 25 29  2b 57 0d 09 ec 06 20 e1  |)=I(N2%)+W.... .|
00001070  0d 09 f6 05 20 0d 0a 00  05 20 0d 0a 0a 0a 20 dd  |.... .... .... .|
00001080  f2 76 61 6c 0d 0a 14 0e  20 56 24 3d c2 57 24 2c  |.val.... V$=.W$,|
00001090  31 29 0d 0a 1e 0f 20 e7  20 56 24 3c 22 3a 22 20  |1).... . V$<":" |
000010a0  e1 0d 0a 28 16 20 57 3d  bb 28 c0 57 24 2c a9 28  |...(. W=.(.W$,.(|
000010b0  57 24 29 2d 31 29 29 0d  0a 32 16 20 e7 56 24 3d  |W$)-1))..2. .V$=|
000010c0  22 70 22 20 57 3d 57 2a  31 45 2d 31 32 0d 0a 3c  |"p" W=W*1E-12..<|
000010d0  15 20 e7 56 24 3d 22 6e  22 20 57 3d 57 2a 31 45  |. .V$="n" W=W*1E|
000010e0  2d 39 0d 0a 46 15 20 e7  56 24 3d 22 75 22 20 57  |-9..F. .V$="u" W|
000010f0  3d 57 2a 31 45 2d 36 0d  0a 50 15 20 e7 56 24 3d  |=W*1E-6..P. .V$=|
00001100  22 6d 22 20 57 3d 57 2a  31 45 2d 33 0d 0a 5a 14  |"m" W=W*1E-3..Z.|
00001110  20 e7 56 24 3d 22 4b 22  20 57 3d 57 2a 31 45 33  | .V$="K" W=W*1E3|
00001120  0d 0a 64 14 20 e7 56 24  3d 22 4d 22 20 57 3d 57  |..d. .V$="M" W=W|
00001130  2a 31 45 36 0d 0a 6e 14  20 e7 56 24 3d 22 47 22  |*1E6..n. .V$="G"|
00001140  20 57 3d 57 2a 31 45 39  0d 0a 78 06 20 e1 0d 0a  | W=W*1E9..x. ...|
00001150  82 05 20 0d 0a 8c 0a 20  dd f2 72 75 6e 0d 0a 96  |.. .... ..run...|
00001160  1e 20 f1 27 22 43 69 72  63 75 69 74 20 41 6e 61  |. .'"Circuit Ana|
00001170  6c 79 73 65 72 20 32 2e  31 22 27 0d 0a a0 14 20  |lyser 2.1"'.... |
00001180  4e 25 3d 30 3a 41 46 3d  30 3a 4e 31 25 3d 30 0d  |N%=0:AF=0:N1%=0.|
00001190  0a aa 13 20 45 52 25 3d  30 3a 4e 32 25 3d 30 3a  |... ER%=0:N2%=0:|
000011a0  ef 33 0d 0a b4 16 20 e3  41 25 3d 31 b8 33 30 3a  |.3.... .A%=1.30:|
000011b0  e3 42 25 3d 31 b8 33 30  0d 0a be 11 20 59 28 41  |.B%=1.30.... Y(A|
000011c0  25 2c 42 25 29 3d 30 3a  ed 0d 0a c8 0e 20 49 28  |%,B%)=0:..... I(|
000011d0  41 25 29 3d 30 3a ed 0d  0a d2 10 20 e3 54 25 3d  |A%)=0:..... .T%=|
000011e0  31 20 b8 20 4c 49 25 0d  0a dc 16 20 f2 70 68 72  |1 . LI%.... .phr|
000011f0  61 73 65 28 41 24 28 54  25 29 2c 31 29 0d 0a e6  |ase(A$(T%),1)...|
00001200  18 20 f1 22 52 65 61 64  69 6e 67 20 4c 69 6e 65  |. ."Reading Line|
00001210  20 3a 22 3b 57 0d 0a f0  16 20 f2 70 68 72 61 73  | :";W.... .phras|
00001220  65 28 41 24 28 54 25 29  2c 30 29 0d 0a fa 0e 20  |e(A$(T%),0).... |
00001230  4c 24 3d c0 57 24 2c 31  29 0d 0b 04 0c 20 57 3d  |L$=.W$,1).... W=|
00001240  30 3a ef 31 31 0d 0b 0e  13 20 e7 20 4c 24 3d 22  |0:.11.... . L$="|
00001250  2a 22 20 e5 8d 74 46 4b  0d 0b 18 19 20 e7 20 4c  |*" ..tFK.... . L|
00001260  24 3d 22 46 22 20 f2 66  72 65 71 3a e5 8d 74 46  |$="F" .freq:..tF|
00001270  4b 0d 0b 22 12 20 e7 20  4c 24 3d 22 52 22 20 f2  |K..". . L$="R" .|
00001280  72 65 73 0d 0b 2c 12 20  e7 20 4c 24 3d 22 43 22  |res..,. . L$="C"|
00001290  20 f2 63 61 70 0d 0b 36  12 20 e7 20 4c 24 3d 22  | .cap..6. . L$="|
000012a0  4c 22 20 f2 69 6e 64 0d  0b 40 13 20 e7 20 4c 24  |L" .ind..@. . L$|
000012b0  3d 22 49 22 20 f2 63 75  72 72 0d 0b 4a 13 20 e7  |="I" .curr..J. .|
000012c0  20 4c 24 3d 22 56 22 20  f2 76 6f 6c 74 0d 0b 54  | L$="V" .volt..T|
000012d0  1e 20 e7 20 4e 31 25 3d  4e 32 25 20 f2 65 72 72  |. . N1%=N2% .err|
000012e0  6f 72 28 32 29 3a e5 8d  64 4c 4b 0d 0b 5e 1b 20  |or(2):..dLK..^. |
000012f0  e7 45 52 25 3d 31 20 f2  65 72 72 6f 72 28 31 29  |.ER%=1 .error(1)|
00001300  3a e5 8d 64 4c 4b 0d 0b  68 1b 20 e7 45 52 25 3d  |:..dLK..h. .ER%=|
00001310  33 20 f2 65 72 72 6f 72  28 33 29 3a e5 8d 64 4c  |3 .error(3):..dL|
00001320  4b 0d 0b 72 14 20 e7 20  4e 31 25 3e 4e 25 20 4e  |K..r. . N1%>N% N|
00001330  25 3d 4e 31 25 0d 0b 7c  14 20 e7 20 4e 32 25 3e  |%=N1%..|. . N2%>|
00001340  4e 25 20 4e 25 3d 4e 32  25 0d 0b 86 06 20 ed 0d  |N% N%=N2%.... ..|
00001350  0b 90 12 20 f2 73 6f 6c  76 65 5f 6d 61 74 72 69  |... .solve_matri|
00001360  78 0d 0b 9a 0f 20 e7 20  50 52 54 3d 31 20 ef 32  |x.... . PRT=1 .2|
00001370  0d 0b a4 1a 20 f1 27 27  22 56 6f 6c 74 61 67 65  |.... .''"Voltage|
00001380  73 20 61 72 65 3a 2d 22  27 20 0d 0b ae 0d 20 e3  |s are:-"' .... .|
00001390  54 25 3d 31 b8 4e 25 0d  0b b8 1a 20 f1 22 56 28  |T%=1.N%.... ."V(|
000013a0  22 3b 54 25 3b 22 29 20  3d 20 22 3b 56 28 54 25  |";T%;") = ";V(T%|
000013b0  29 0d 0b c2 06 20 ed 0d  0b cc 10 20 f1 27 22 52  |).... ..... .'"R|
000013c0  65 61 64 79 2e 22 27 0d  0b d6 06 20 e1 0d ff     |eady."'.... ...|
000013cf
18-09-88/CIRCUIT.m0
18-09-88/CIRCUIT.m1
18-09-88/CIRCUIT.m2
18-09-88/CIRCUIT.m4
18-09-88/CIRCUIT.m5