Home » Personal collection » Acorn ADFS disks » Greaseweazled » dos34_s2312.016_compaq_user_programs.adf » BioBot/NumPat/Num4

BioBot/NumPat/Num4

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 » Personal collection » Acorn ADFS disks » Greaseweazled » dos34_s2312.016_compaq_user_programs.adf
Filename: BioBot/NumPat/Num4
Read OK:
File size: 125C bytes
Load address: FFFFFB47
Exec address: FD9B678A
Duplicates

There are 2 duplicate copies of this file in the archive:

File contents
   10 REM Intellegent number pattern matching
   20 REM by Dominic Ford 1997
   30 :
   40 MODE0:PRINT"BIOBOT INTELLIGENT NUMERICAL PATTERN MATCHING"'"(C) Dominic Ford 1997":FORR=0TO79:PRINT"_";:NEXT:VDU28,0,31,79,3:T=TIME
   50 DIMn(4):PROCsetupbb
   60 FORd=0TO4:INPUTn(d):NEXT
   70 REPEAT
   80 Na=FNai(0):PROCaddbonds(FNscorebonds(Na,n(0)))
   90 Nb=FNai(1):PROCaddbonds(FNscorebonds(Nb,n(1)))
  100 Nc=FNai(2):PROCaddbonds(FNscorebonds(Nc,n(2)))
  110 Nd=FNai(3):PROCaddbonds(FNscorebonds(Nd,n(3)))
  120 Ne=FNai(4):PROCaddbonds(FNscorebonds(Ne,n(4)))
  130 PRINTbbno,Na,Nb,Nc,Nd,Ne,FNscr
  140 idle=TRUE:Z=FNai(0)
  150 UNTIL score=100
  160 :
  170 REM General maintainence and refereeing
  180 :
  190 DEFPROCreferee
  200 ENDPROC
  210 DEFPROCrestart
  220 ENDPROC
  230 :
  240 REM Give ballbot a score at the end of a run
  250 :
  260 DEFFNscorebonds(x,y)
  270 thisscr=(-2.5*((x AND1)=(y AND1))-2.5*((x AND2)=(y AND2))-2.5*((x AND4)=(y AND4))-2.5*((x AND8)=(y AND8)))^2
  280 scorebu=scorebu+thisscr
  290 IF scorebu<0 THEN scorbu=0
  300 goes=goes+1
  310 =thisscr
  320 :
  330 REM BioBot Evolutionary Learning Routine
  340 :
  350 REM Main AI system
  360 :
  370 DEFFNai(A1)
  380 REM Artificial intelligence routines (ie. What Next??)
  390 counter=counter+1:IF counter=1000 OR idle=TRUE THEN PROCnext(FNscr):=0
  400 :
  410 n%(1)=(A1 AND 1)
  420 n%(2)=(A1 AND 2)
  430 n%(3)=(A1 AND 4)
  440 n%(4)=(A1 AND 8)
  450 FORl=0TOlinks-1:bond%(l)=0:NEXT
  460 FORl=0TO1:FORma=0TOlinks-1
  470 IFm%(bbno,ma,0)=1 AND n%(m%(bbno,ma,1))<>0 AND n%(m%(bbno,ma,2))<>0 THEN n%(m%(bbno,ma,3))=1:bond%(ma)=1
  480 IFm%(bbno,ma,0)=2 AND (n%(m%(bbno,ma,1))<>0 OR n%(m%(bbno,ma,2))<>0) THEN n%(m%(bbno,ma,3))=1:bond%(ma)=1
  490 IFm%(bbno,ma,0)=3 AND n%(m%(bbno,ma,1))=0 THEN n%(m%(bbno,ma,3))=1 ELSE n%(m%(bbno,ma,3))=0
  500 IFm%(bbno,ma,0)=3 AND n%(m%(bbno,ma,1))=0 THEN bond%(ma)=1
  510 IFm%(bbno,ma,0)=4 AND (n%(m%(bbno,ma,1))<>0 EOR n%(m%(bbno,ma,2))<>0) THEN n%(m%(bbno,ma,3))=1:bond%(ma)=1
  520 IFm%(bbno,ma,0)=5 AND n%(m%(bbno,ma,1))<>0 THEN n%(m%(bbno,ma,3))=1 ELSE n%(m%(bbno,ma,3))=0
  530 IFm%(bbno,ma,0)=5 AND n%(m%(bbno,ma,1))<>0 THEN bond%(ma)=1
  540 NEXT,
  550 REM Calculate outputs
  560 o1=A1:PROCreferee
  570 R%=0:FORz=1TOtotalout:R%=2*R%-(n%(no%-totalout+z)<>0):NEXT
  580 REM R%=ABS(INKEY(-71)+2*INKEY(-102)+4*INKEY(-98)+8*INKEY(-67))
  590 =R%
  600 :
  610 REM Next attempt by this biobot (each has ten)
  620 :
  630 DEFPROCnext(score)
  640 PROCuser:PROCrestart
  650 s%(bbno)=s%(bbno)+score/attempts:counter=0:idle=FALSE
  660 FORc=0TOno%:n%(c)=0:NEXT:tns%=1:scorebu=0:goes=0
  670 tryno=tryno+1:IF tryno<attempts THEN ENDPROC
  680 tryno=0:bbno=bbno+1:IF bbno=10 THEN PROCgeneration
  690 PROCnewbb
  700 ENDPROC
  710 :
  720 REM Test next biobot
  730 :
  740 DEFPROCnewbb
  750 o1=0:o2=0:o3=0:tns%=1
  760 idle=FALSE:scr=0:tryno=0
  770 PROCrestart:counter=0
  780 ENDPROC
  790 :
  800 REM Setup BioBot system (for the first time)
  810 :
  820 DEFPROCsetupbb
  830 scorebu=0:goes=0
  840 bbno=0:gen=0:PROCnewbb
  850 totalin=4:analogues=1:switches=0:totalout=4:mem=2:attempts=1
  860 no%=totalin+totalout+mem:links=12
  870 DIMm%(10,links-1,3):DIMn%(no%):DIMs%(9):DIMbond%(links-1):DIMcsb(9,links-1):DIMbs%(links-1)
  880 s%(1)=1:m%(1,1,0)=3:m%(1,1,1)=1:m%(1,1,3)=no%:m%(1,2,0)=5:m%(1,2,1)=1:m%(1,2,3)=no%-1:PROCgeneration
  890 ENDPROC
  900 :
  910 REM Select best biobot of generation
  920 :
  930 DEFPROCgeneration
  940 winner=0:score=s%(0)
  950 FORs=0TO9:IF s%(s)>score THEN score=s%(s):winner=s
  960 NEXT
  970 scowin=score
  980 :
  990 REM Breed more biobots from best one
 1000 :
 1010 FORx=0TOlinks-1:FORy=0TO3:m%(10,x,y)=m%(winner,x,y):NEXT,
 1020 FORz=0TO9:FORx=0TOlinks-1:FORy=0TO3:m%(z,x,y)=m%(10,x,y):NEXT,,
 1030 :
 1040 REM Add a bit of variation (with help from csb)
 1050 :
 1060 PRINT"Sorting...";:FORp=0TOlinks-1:scrlnk=-5:FORlnk=0TOlinks-1
 1070 IF csb(winner,lnk)>scrlnk THEN scrlnk=csb(winner,lnk):bbno=lnk
 1080 NEXT:bs%(p)=bbno:csb(winner,bbno)=-1
 1090 NEXT:PRINT" Done."
 1100 :
 1110 alts=(1/(score+1))*2500:IF alts<9 THEN alts=9
 1120 IF score=100 THEN PROCdisp:PRINT''"Generation:";gen'(TIME-T)/6000;" minutes":ENDPROC
 1130 FORn=0TOalts
 1140 z=INT(SQR(RND((links-1)^2))):zx=z:x=bs%(z):z=RND(9)-1
 1150 PRINT"[";zx;",";z;",";x;"]",;
 1160 m%(z,x,0)=RND(6)-1:m%(z,x,1)=RND(no%-totalout):m%(z,x,2)=RND(no%-totalout):m%(z,x,3)=totalin+RND(no%-totalin)
 1170 NEXT
 1180 :
 1190 REM Initialise ready for generation test
 1200 bbno=0:gen=gen+1
 1210 FORs=0TO9:s%(s)=0:FORl=0TOlinks-1:csb(s,l)=0:NEXT,
 1220 PRINT'"Generation ";gen'
 1230 ENDPROC
 1240:
 1250 REM User interface for BioBot system
 1260 :
 1270 DEFPROCuser
 1280 f$=INKEY$(0)
 1290 IF f$="D" THEN PROCdisp
 1300 IF f$="S" THEN PROCsave
 1310 ENDPROC
 1320 REM Display best biobot's genetic information
 1330 DEFPROCdisp
 1340 CLS:FORz=0TOlinks-2:PRINTz+1,m%(10,z,0),m%(10,z,1),m%(10,z,2),m%(10,z,3):NEXT
 1350 PRINTlinks,m%(10,links-1,0),m%(10,links-1,1),m%(10,links-1,2),m%(10,links-1,3);
 1360 PRINT''"Scored: ";scowin
 1370 IF score=100 THEN ENDPROC
 1380 VDU 7:REPEAT UNTIL INKEY$(0)=""
 1390 REPEAT UNTIL INKEY$(0)<>""
 1400 ENDPROC
 1410 REM Save best biobot to disc
 1420 DEFPROCsave
 1430 file=OPENOUT"BBF"
 1440 FORz=0TOlinks-1:PRINT#file,z+1,m%(10,z,0),m%(10,z,1),m%(10,z,2),m%(10,z,3):NEXT
 1450 CLOSE#file
 1460 ENDPROC
 1470 :
 1480 REM Give biobot a score from successive goes
 1490 DEFFNscr=scorebu/goes
 1500 :
 1510 REM Add scores to bonds from this BioBot
 1520 DEFPROCaddbonds(score)
 1530 FORl=0TOlinks-1
 1540 csb(bbno,l)=csb(bbno,l)/goes*(goes-1)+(score*bond%(l))/goes
 1550 NEXT
 1560 ENDPROC

* � Intellegent number pattern matching
 � by Dominic Ford 1997
 :
(r �0:�"BIOBOT INTELLIGENT NUMERICAL PATTERN MATCHING"'"(C) Dominic Ford 1997":�R=0�79:�"_";:�:�28,0,31,79,3:T=�
2 �n(4):�setupbb
< �d=0�4:�n(d):�
F �
P. Na=�ai(0):�addbonds(�scorebonds(Na,n(0)))
Z. Nb=�ai(1):�addbonds(�scorebonds(Nb,n(1)))
d. Nc=�ai(2):�addbonds(�scorebonds(Nc,n(2)))
n. Nd=�ai(3):�addbonds(�scorebonds(Nd,n(3)))
x. Ne=�ai(4):�addbonds(�scorebonds(Ne,n(4)))
� �bbno,Na,Nb,Nc,Nd,Ne,�scr
� idle=�:Z=�ai(0)
� � score=100
� :
�* � General maintainence and refereeing
� :
� ��referee
� �
� ��restart
� �
� :
�/ � Give ballbot a score at the end of a run
� :
 ݤscorebonds(x,y)
a thisscr=(-2.5*((x �1)=(y �1))-2.5*((x �2)=(y �2))-2.5*((x �4)=(y �4))-2.5*((x �8)=(y �8)))^2
 scorebu=scorebu+thisscr
" � scorebu<0 � scorbu=0
, goes=goes+1
6
 =thisscr
@ :
J+ � BioBot Evolutionary Learning Routine
T :
^ � Main AI system
h :
r
 ݤai(A1)
|9 � Artificial intelligence routines (ie. What Next??)
�? counter=counter+1:� counter=1000 � idle=� � �next(�scr):=0
� :
� n%(1)=(A1 � 1)
� n%(2)=(A1 � 2)
� n%(3)=(A1 � 4)
� n%(4)=(A1 � 8)
� �l=0�links-1:bond%(l)=0:�
� �l=0�1:�ma=0�links-1
�e �m%(bbno,ma,0)=1 � n%(m%(bbno,ma,1))<>0 � n%(m%(bbno,ma,2))<>0 � n%(m%(bbno,ma,3))=1:bond%(ma)=1
�g �m%(bbno,ma,0)=2 � (n%(m%(bbno,ma,1))<>0 � n%(m%(bbno,ma,2))<>0) � n%(m%(bbno,ma,3))=1:bond%(ma)=1
�W �m%(bbno,ma,0)=3 � n%(m%(bbno,ma,1))=0 � n%(m%(bbno,ma,3))=1 � n%(m%(bbno,ma,3))=0
�9 �m%(bbno,ma,0)=3 � n%(m%(bbno,ma,1))=0 � bond%(ma)=1
�g �m%(bbno,ma,0)=4 � (n%(m%(bbno,ma,1))<>0 � n%(m%(bbno,ma,2))<>0) � n%(m%(bbno,ma,3))=1:bond%(ma)=1
X �m%(bbno,ma,0)=5 � n%(m%(bbno,ma,1))<>0 � n%(m%(bbno,ma,3))=1 � n%(m%(bbno,ma,3))=0
: �m%(bbno,ma,0)=5 � n%(m%(bbno,ma,1))<>0 � bond%(ma)=1
 �,
& � Calculate outputs
0 o1=A1:�referee
:9 R%=0:�z=1�totalout:R%=2*R%-(n%(no%-totalout+z)<>0):�
DA � R%=ABS(INKEY(-71)+2*INKEY(-102)+4*INKEY(-98)+8*INKEY(-67))
N =R%
X :
b1 � Next attempt by this biobot (each has ten)
l :
v ��next(score)
� �user:�restart
�6 s%(bbno)=s%(bbno)+score/attempts:counter=0:idle=�
�/ �c=0�no%:n%(c)=0:�:tns%=1:scorebu=0:goes=0
�' tryno=tryno+1:� tryno<attempts � �
�0 tryno=0:bbno=bbno+1:� bbno=10 � �generation
� �newbb
� �
� :
� � Test next biobot
� :
� ��newbb
� o1=0:o2=0:o3=0:tns%=1
� idle=�:scr=0:tryno=0
 �restart:counter=0
 �
 :
 / � Setup BioBot system (for the first time)
* :
4 ��setupbb
> scorebu=0:goes=0
H bbno=0:gen=0:�newbb
RA totalin=4:analogues=1:switches=0:totalout=4:mem=2:attempts=1
\& no%=totalin+totalout+mem:links=12
fT �m%(10,links-1,3):�n%(no%):�s%(9):�bond%(links-1):�csb(9,links-1):�bs%(links-1)
pf s%(1)=1:m%(1,1,0)=3:m%(1,1,1)=1:m%(1,1,3)=no%:m%(1,2,0)=5:m%(1,2,1)=1:m%(1,2,3)=no%-1:�generation
z �
� :
�' � Select best biobot of generation
� :
� ��generation
� winner=0:score=s%(0)
�0 �s=0�9:� s%(s)>score � score=s%(s):winner=s
� �
� scowin=score
� :
�' � Breed more biobots from best one
� :
�5 �x=0�links-1:�y=0�3:m%(10,x,y)=m%(winner,x,y):�,
�8 �z=0�9:�x=0�links-1:�y=0�3:m%(z,x,y)=m%(10,x,y):�,,
 :
2 � Add a bit of variation (with help from csb)
 :
$9 �"Sorting...";:�p=0�links-1:scrlnk=-5:�lnk=0�links-1
.? � csb(winner,lnk)>scrlnk � scrlnk=csb(winner,lnk):bbno=lnk
8& �:bs%(p)=bbno:csb(winner,bbno)=-1
B �:�" Done."
L :
V. alts=(1/(score+1))*2500:� alts<9 � alts=9
`E � score=100 � �disp:�''"Generation:";gen'(�-T)/6000;" minutes":�
j �n=0�alts
t2 z=�(�(�((links-1)^2))):zx=z:x=bs%(z):z=�(9)-1
~ �"[";zx;",";z;",";x;"]",;
�j m%(z,x,0)=�(6)-1:m%(z,x,1)=�(no%-totalout):m%(z,x,2)=�(no%-totalout):m%(z,x,3)=totalin+�(no%-totalin)
� �
� :
�+ � Initialise ready for generation test
� bbno=0:gen=gen+1
�. �s=0�9:s%(s)=0:�l=0�links-1:csb(s,l)=0:�,
� �'"Generation ";gen'
� �
�:
�' � User interface for BioBot system
� :
� ��user
 f$=�(0)

 � f$="D" � �disp
 � f$="S" � �save
 �
(0 � Display best biobot's genetic information
2 ��disp
<F �:�z=0�links-2:�z+1,m%(10,z,0),m%(10,z,1),m%(10,z,2),m%(10,z,3):�
FP �links,m%(10,links-1,0),m%(10,links-1,1),m%(10,links-1,2),m%(10,links-1,3);
P �''"Scored: ";scowin
Z � score=100 � �
d � 7:� � �(0)=""
n � � �(0)<>""
x �
� � Save best biobot to disc
� ��save
� file=�"BBF"
�J �z=0�links-1:�#file,z+1,m%(10,z,0),m%(10,z,1),m%(10,z,2),m%(10,z,3):�
� �#file
� �
� :
�/ � Give biobot a score from successive goes
� ݤscr=scorebu/goes
� :
�+ � Add scores to bonds from this BioBot
� ��addbonds(score)
� �l=0�links-1
@ csb(bbno,l)=csb(bbno,l)/goes*(goes-1)+(score*bond%(l))/goes
 �
 �
�
00000000  0d 00 0a 2a 20 f4 20 49  6e 74 65 6c 6c 65 67 65  |...* . Intellege|
00000010  6e 74 20 6e 75 6d 62 65  72 20 70 61 74 74 65 72  |nt number patter|
00000020  6e 20 6d 61 74 63 68 69  6e 67 0d 00 14 1b 20 f4  |n matching.... .|
00000030  20 62 79 20 44 6f 6d 69  6e 69 63 20 46 6f 72 64  | by Dominic Ford|
00000040  20 31 39 39 37 0d 00 1e  06 20 3a 0d 00 28 72 20  | 1997.... :..(r |
00000050  eb 30 3a f1 22 42 49 4f  42 4f 54 20 49 4e 54 45  |.0:."BIOBOT INTE|
00000060  4c 4c 49 47 45 4e 54 20  4e 55 4d 45 52 49 43 41  |LLIGENT NUMERICA|
00000070  4c 20 50 41 54 54 45 52  4e 20 4d 41 54 43 48 49  |L PATTERN MATCHI|
00000080  4e 47 22 27 22 28 43 29  20 44 6f 6d 69 6e 69 63  |NG"'"(C) Dominic|
00000090  20 46 6f 72 64 20 31 39  39 37 22 3a e3 52 3d 30  | Ford 1997":.R=0|
000000a0  b8 37 39 3a f1 22 5f 22  3b 3a ed 3a ef 32 38 2c  |.79:."_";:.:.28,|
000000b0  30 2c 33 31 2c 37 39 2c  33 3a 54 3d 91 0d 00 32  |0,31,79,3:T=...2|
000000c0  13 20 de 6e 28 34 29 3a  f2 73 65 74 75 70 62 62  |. .n(4):.setupbb|
000000d0  0d 00 3c 13 20 e3 64 3d  30 b8 34 3a e8 6e 28 64  |..<. .d=0.4:.n(d|
000000e0  29 3a ed 0d 00 46 06 20  f5 0d 00 50 2e 20 4e 61  |):...F. ...P. Na|
000000f0  3d a4 61 69 28 30 29 3a  f2 61 64 64 62 6f 6e 64  |=.ai(0):.addbond|
00000100  73 28 a4 73 63 6f 72 65  62 6f 6e 64 73 28 4e 61  |s(.scorebonds(Na|
00000110  2c 6e 28 30 29 29 29 0d  00 5a 2e 20 4e 62 3d a4  |,n(0)))..Z. Nb=.|
00000120  61 69 28 31 29 3a f2 61  64 64 62 6f 6e 64 73 28  |ai(1):.addbonds(|
00000130  a4 73 63 6f 72 65 62 6f  6e 64 73 28 4e 62 2c 6e  |.scorebonds(Nb,n|
00000140  28 31 29 29 29 0d 00 64  2e 20 4e 63 3d a4 61 69  |(1)))..d. Nc=.ai|
00000150  28 32 29 3a f2 61 64 64  62 6f 6e 64 73 28 a4 73  |(2):.addbonds(.s|
00000160  63 6f 72 65 62 6f 6e 64  73 28 4e 63 2c 6e 28 32  |corebonds(Nc,n(2|
00000170  29 29 29 0d 00 6e 2e 20  4e 64 3d a4 61 69 28 33  |)))..n. Nd=.ai(3|
00000180  29 3a f2 61 64 64 62 6f  6e 64 73 28 a4 73 63 6f  |):.addbonds(.sco|
00000190  72 65 62 6f 6e 64 73 28  4e 64 2c 6e 28 33 29 29  |rebonds(Nd,n(3))|
000001a0  29 0d 00 78 2e 20 4e 65  3d a4 61 69 28 34 29 3a  |)..x. Ne=.ai(4):|
000001b0  f2 61 64 64 62 6f 6e 64  73 28 a4 73 63 6f 72 65  |.addbonds(.score|
000001c0  62 6f 6e 64 73 28 4e 65  2c 6e 28 34 29 29 29 0d  |bonds(Ne,n(4))).|
000001d0  00 82 1e 20 f1 62 62 6e  6f 2c 4e 61 2c 4e 62 2c  |... .bbno,Na,Nb,|
000001e0  4e 63 2c 4e 64 2c 4e 65  2c a4 73 63 72 0d 00 8c  |Nc,Nd,Ne,.scr...|
000001f0  14 20 69 64 6c 65 3d b9  3a 5a 3d a4 61 69 28 30  |. idle=.:Z=.ai(0|
00000200  29 0d 00 96 10 20 fd 20  73 63 6f 72 65 3d 31 30  |).... . score=10|
00000210  30 0d 00 a0 06 20 3a 0d  00 aa 2a 20 f4 20 47 65  |0.... :...* . Ge|
00000220  6e 65 72 61 6c 20 6d 61  69 6e 74 61 69 6e 65 6e  |neral maintainen|
00000230  63 65 20 61 6e 64 20 72  65 66 65 72 65 65 69 6e  |ce and refereein|
00000240  67 0d 00 b4 06 20 3a 0d  00 be 0e 20 dd f2 72 65  |g.... :.... ..re|
00000250  66 65 72 65 65 0d 00 c8  06 20 e1 0d 00 d2 0e 20  |feree.... ..... |
00000260  dd f2 72 65 73 74 61 72  74 0d 00 dc 06 20 e1 0d  |..restart.... ..|
00000270  00 e6 06 20 3a 0d 00 f0  2f 20 f4 20 47 69 76 65  |... :.../ . Give|
00000280  20 62 61 6c 6c 62 6f 74  20 61 20 73 63 6f 72 65  | ballbot a score|
00000290  20 61 74 20 74 68 65 20  65 6e 64 20 6f 66 20 61  | at the end of a|
000002a0  20 72 75 6e 0d 00 fa 06  20 3a 0d 01 04 16 20 dd  | run.... :.... .|
000002b0  a4 73 63 6f 72 65 62 6f  6e 64 73 28 78 2c 79 29  |.scorebonds(x,y)|
000002c0  0d 01 0e 61 20 74 68 69  73 73 63 72 3d 28 2d 32  |...a thisscr=(-2|
000002d0  2e 35 2a 28 28 78 20 80  31 29 3d 28 79 20 80 31  |.5*((x .1)=(y .1|
000002e0  29 29 2d 32 2e 35 2a 28  28 78 20 80 32 29 3d 28  |))-2.5*((x .2)=(|
000002f0  79 20 80 32 29 29 2d 32  2e 35 2a 28 28 78 20 80  |y .2))-2.5*((x .|
00000300  34 29 3d 28 79 20 80 34  29 29 2d 32 2e 35 2a 28  |4)=(y .4))-2.5*(|
00000310  28 78 20 80 38 29 3d 28  79 20 80 38 29 29 29 5e  |(x .8)=(y .8)))^|
00000320  32 0d 01 18 1c 20 73 63  6f 72 65 62 75 3d 73 63  |2.... scorebu=sc|
00000330  6f 72 65 62 75 2b 74 68  69 73 73 63 72 0d 01 22  |orebu+thisscr.."|
00000340  1b 20 e7 20 73 63 6f 72  65 62 75 3c 30 20 8c 20  |. . scorebu<0 . |
00000350  73 63 6f 72 62 75 3d 30  0d 01 2c 10 20 67 6f 65  |scorbu=0..,. goe|
00000360  73 3d 67 6f 65 73 2b 31  0d 01 36 0d 20 3d 74 68  |s=goes+1..6. =th|
00000370  69 73 73 63 72 0d 01 40  06 20 3a 0d 01 4a 2b 20  |isscr..@. :..J+ |
00000380  f4 20 42 69 6f 42 6f 74  20 45 76 6f 6c 75 74 69  |. BioBot Evoluti|
00000390  6f 6e 61 72 79 20 4c 65  61 72 6e 69 6e 67 20 52  |onary Learning R|
000003a0  6f 75 74 69 6e 65 0d 01  54 06 20 3a 0d 01 5e 15  |outine..T. :..^.|
000003b0  20 f4 20 4d 61 69 6e 20  41 49 20 73 79 73 74 65  | . Main AI syste|
000003c0  6d 0d 01 68 06 20 3a 0d  01 72 0d 20 dd a4 61 69  |m..h. :..r. ..ai|
000003d0  28 41 31 29 0d 01 7c 39  20 f4 20 41 72 74 69 66  |(A1)..|9 . Artif|
000003e0  69 63 69 61 6c 20 69 6e  74 65 6c 6c 69 67 65 6e  |icial intelligen|
000003f0  63 65 20 72 6f 75 74 69  6e 65 73 20 28 69 65 2e  |ce routines (ie.|
00000400  20 57 68 61 74 20 4e 65  78 74 3f 3f 29 0d 01 86  | What Next??)...|
00000410  3f 20 63 6f 75 6e 74 65  72 3d 63 6f 75 6e 74 65  |? counter=counte|
00000420  72 2b 31 3a e7 20 63 6f  75 6e 74 65 72 3d 31 30  |r+1:. counter=10|
00000430  30 30 20 84 20 69 64 6c  65 3d b9 20 8c 20 f2 6e  |00 . idle=. . .n|
00000440  65 78 74 28 a4 73 63 72  29 3a 3d 30 0d 01 90 06  |ext(.scr):=0....|
00000450  20 3a 0d 01 9a 13 20 6e  25 28 31 29 3d 28 41 31  | :.... n%(1)=(A1|
00000460  20 80 20 31 29 0d 01 a4  13 20 6e 25 28 32 29 3d  | . 1).... n%(2)=|
00000470  28 41 31 20 80 20 32 29  0d 01 ae 13 20 6e 25 28  |(A1 . 2).... n%(|
00000480  33 29 3d 28 41 31 20 80  20 34 29 0d 01 b8 13 20  |3)=(A1 . 4).... |
00000490  6e 25 28 34 29 3d 28 41  31 20 80 20 38 29 0d 01  |n%(4)=(A1 . 8)..|
000004a0  c2 1e 20 e3 6c 3d 30 b8  6c 69 6e 6b 73 2d 31 3a  |.. .l=0.links-1:|
000004b0  62 6f 6e 64 25 28 6c 29  3d 30 3a ed 0d 01 cc 19  |bond%(l)=0:.....|
000004c0  20 e3 6c 3d 30 b8 31 3a  e3 6d 61 3d 30 b8 6c 69  | .l=0.1:.ma=0.li|
000004d0  6e 6b 73 2d 31 0d 01 d6  65 20 e7 6d 25 28 62 62  |nks-1...e .m%(bb|
000004e0  6e 6f 2c 6d 61 2c 30 29  3d 31 20 80 20 6e 25 28  |no,ma,0)=1 . n%(|
000004f0  6d 25 28 62 62 6e 6f 2c  6d 61 2c 31 29 29 3c 3e  |m%(bbno,ma,1))<>|
00000500  30 20 80 20 6e 25 28 6d  25 28 62 62 6e 6f 2c 6d  |0 . n%(m%(bbno,m|
00000510  61 2c 32 29 29 3c 3e 30  20 8c 20 6e 25 28 6d 25  |a,2))<>0 . n%(m%|
00000520  28 62 62 6e 6f 2c 6d 61  2c 33 29 29 3d 31 3a 62  |(bbno,ma,3))=1:b|
00000530  6f 6e 64 25 28 6d 61 29  3d 31 0d 01 e0 67 20 e7  |ond%(ma)=1...g .|
00000540  6d 25 28 62 62 6e 6f 2c  6d 61 2c 30 29 3d 32 20  |m%(bbno,ma,0)=2 |
00000550  80 20 28 6e 25 28 6d 25  28 62 62 6e 6f 2c 6d 61  |. (n%(m%(bbno,ma|
00000560  2c 31 29 29 3c 3e 30 20  84 20 6e 25 28 6d 25 28  |,1))<>0 . n%(m%(|
00000570  62 62 6e 6f 2c 6d 61 2c  32 29 29 3c 3e 30 29 20  |bbno,ma,2))<>0) |
00000580  8c 20 6e 25 28 6d 25 28  62 62 6e 6f 2c 6d 61 2c  |. n%(m%(bbno,ma,|
00000590  33 29 29 3d 31 3a 62 6f  6e 64 25 28 6d 61 29 3d  |3))=1:bond%(ma)=|
000005a0  31 0d 01 ea 57 20 e7 6d  25 28 62 62 6e 6f 2c 6d  |1...W .m%(bbno,m|
000005b0  61 2c 30 29 3d 33 20 80  20 6e 25 28 6d 25 28 62  |a,0)=3 . n%(m%(b|
000005c0  62 6e 6f 2c 6d 61 2c 31  29 29 3d 30 20 8c 20 6e  |bno,ma,1))=0 . n|
000005d0  25 28 6d 25 28 62 62 6e  6f 2c 6d 61 2c 33 29 29  |%(m%(bbno,ma,3))|
000005e0  3d 31 20 8b 20 6e 25 28  6d 25 28 62 62 6e 6f 2c  |=1 . n%(m%(bbno,|
000005f0  6d 61 2c 33 29 29 3d 30  0d 01 f4 39 20 e7 6d 25  |ma,3))=0...9 .m%|
00000600  28 62 62 6e 6f 2c 6d 61  2c 30 29 3d 33 20 80 20  |(bbno,ma,0)=3 . |
00000610  6e 25 28 6d 25 28 62 62  6e 6f 2c 6d 61 2c 31 29  |n%(m%(bbno,ma,1)|
00000620  29 3d 30 20 8c 20 62 6f  6e 64 25 28 6d 61 29 3d  |)=0 . bond%(ma)=|
00000630  31 0d 01 fe 67 20 e7 6d  25 28 62 62 6e 6f 2c 6d  |1...g .m%(bbno,m|
00000640  61 2c 30 29 3d 34 20 80  20 28 6e 25 28 6d 25 28  |a,0)=4 . (n%(m%(|
00000650  62 62 6e 6f 2c 6d 61 2c  31 29 29 3c 3e 30 20 82  |bbno,ma,1))<>0 .|
00000660  20 6e 25 28 6d 25 28 62  62 6e 6f 2c 6d 61 2c 32  | n%(m%(bbno,ma,2|
00000670  29 29 3c 3e 30 29 20 8c  20 6e 25 28 6d 25 28 62  |))<>0) . n%(m%(b|
00000680  62 6e 6f 2c 6d 61 2c 33  29 29 3d 31 3a 62 6f 6e  |bno,ma,3))=1:bon|
00000690  64 25 28 6d 61 29 3d 31  0d 02 08 58 20 e7 6d 25  |d%(ma)=1...X .m%|
000006a0  28 62 62 6e 6f 2c 6d 61  2c 30 29 3d 35 20 80 20  |(bbno,ma,0)=5 . |
000006b0  6e 25 28 6d 25 28 62 62  6e 6f 2c 6d 61 2c 31 29  |n%(m%(bbno,ma,1)|
000006c0  29 3c 3e 30 20 8c 20 6e  25 28 6d 25 28 62 62 6e  |)<>0 . n%(m%(bbn|
000006d0  6f 2c 6d 61 2c 33 29 29  3d 31 20 8b 20 6e 25 28  |o,ma,3))=1 . n%(|
000006e0  6d 25 28 62 62 6e 6f 2c  6d 61 2c 33 29 29 3d 30  |m%(bbno,ma,3))=0|
000006f0  0d 02 12 3a 20 e7 6d 25  28 62 62 6e 6f 2c 6d 61  |...: .m%(bbno,ma|
00000700  2c 30 29 3d 35 20 80 20  6e 25 28 6d 25 28 62 62  |,0)=5 . n%(m%(bb|
00000710  6e 6f 2c 6d 61 2c 31 29  29 3c 3e 30 20 8c 20 62  |no,ma,1))<>0 . b|
00000720  6f 6e 64 25 28 6d 61 29  3d 31 0d 02 1c 07 20 ed  |ond%(ma)=1.... .|
00000730  2c 0d 02 26 18 20 f4 20  43 61 6c 63 75 6c 61 74  |,..&. . Calculat|
00000740  65 20 6f 75 74 70 75 74  73 0d 02 30 13 20 6f 31  |e outputs..0. o1|
00000750  3d 41 31 3a f2 72 65 66  65 72 65 65 0d 02 3a 39  |=A1:.referee..:9|
00000760  20 52 25 3d 30 3a e3 7a  3d 31 b8 74 6f 74 61 6c  | R%=0:.z=1.total|
00000770  6f 75 74 3a 52 25 3d 32  2a 52 25 2d 28 6e 25 28  |out:R%=2*R%-(n%(|
00000780  6e 6f 25 2d 74 6f 74 61  6c 6f 75 74 2b 7a 29 3c  |no%-totalout+z)<|
00000790  3e 30 29 3a ed 0d 02 44  41 20 f4 20 52 25 3d 41  |>0):...DA . R%=A|
000007a0  42 53 28 49 4e 4b 45 59  28 2d 37 31 29 2b 32 2a  |BS(INKEY(-71)+2*|
000007b0  49 4e 4b 45 59 28 2d 31  30 32 29 2b 34 2a 49 4e  |INKEY(-102)+4*IN|
000007c0  4b 45 59 28 2d 39 38 29  2b 38 2a 49 4e 4b 45 59  |KEY(-98)+8*INKEY|
000007d0  28 2d 36 37 29 29 0d 02  4e 08 20 3d 52 25 0d 02  |(-67))..N. =R%..|
000007e0  58 06 20 3a 0d 02 62 31  20 f4 20 4e 65 78 74 20  |X. :..b1 . Next |
000007f0  61 74 74 65 6d 70 74 20  62 79 20 74 68 69 73 20  |attempt by this |
00000800  62 69 6f 62 6f 74 20 28  65 61 63 68 20 68 61 73  |biobot (each has|
00000810  20 74 65 6e 29 0d 02 6c  06 20 3a 0d 02 76 12 20  | ten)..l. :..v. |
00000820  dd f2 6e 65 78 74 28 73  63 6f 72 65 29 0d 02 80  |..next(score)...|
00000830  13 20 f2 75 73 65 72 3a  f2 72 65 73 74 61 72 74  |. .user:.restart|
00000840  0d 02 8a 36 20 73 25 28  62 62 6e 6f 29 3d 73 25  |...6 s%(bbno)=s%|
00000850  28 62 62 6e 6f 29 2b 73  63 6f 72 65 2f 61 74 74  |(bbno)+score/att|
00000860  65 6d 70 74 73 3a 63 6f  75 6e 74 65 72 3d 30 3a  |empts:counter=0:|
00000870  69 64 6c 65 3d a3 0d 02  94 2f 20 e3 63 3d 30 b8  |idle=..../ .c=0.|
00000880  6e 6f 25 3a 6e 25 28 63  29 3d 30 3a ed 3a 74 6e  |no%:n%(c)=0:.:tn|
00000890  73 25 3d 31 3a 73 63 6f  72 65 62 75 3d 30 3a 67  |s%=1:scorebu=0:g|
000008a0  6f 65 73 3d 30 0d 02 9e  27 20 74 72 79 6e 6f 3d  |oes=0...' tryno=|
000008b0  74 72 79 6e 6f 2b 31 3a  e7 20 74 72 79 6e 6f 3c  |tryno+1:. tryno<|
000008c0  61 74 74 65 6d 70 74 73  20 8c 20 e1 0d 02 a8 30  |attempts . ....0|
000008d0  20 74 72 79 6e 6f 3d 30  3a 62 62 6e 6f 3d 62 62  | tryno=0:bbno=bb|
000008e0  6e 6f 2b 31 3a e7 20 62  62 6e 6f 3d 31 30 20 8c  |no+1:. bbno=10 .|
000008f0  20 f2 67 65 6e 65 72 61  74 69 6f 6e 0d 02 b2 0b  | .generation....|
00000900  20 f2 6e 65 77 62 62 0d  02 bc 06 20 e1 0d 02 c6  | .newbb.... ....|
00000910  06 20 3a 0d 02 d0 17 20  f4 20 54 65 73 74 20 6e  |. :.... . Test n|
00000920  65 78 74 20 62 69 6f 62  6f 74 0d 02 da 06 20 3a  |ext biobot.... :|
00000930  0d 02 e4 0c 20 dd f2 6e  65 77 62 62 0d 02 ee 1a  |.... ..newbb....|
00000940  20 6f 31 3d 30 3a 6f 32  3d 30 3a 6f 33 3d 30 3a  | o1=0:o2=0:o3=0:|
00000950  74 6e 73 25 3d 31 0d 02  f8 19 20 69 64 6c 65 3d  |tns%=1.... idle=|
00000960  a3 3a 73 63 72 3d 30 3a  74 72 79 6e 6f 3d 30 0d  |.:scr=0:tryno=0.|
00000970  03 02 17 20 f2 72 65 73  74 61 72 74 3a 63 6f 75  |... .restart:cou|
00000980  6e 74 65 72 3d 30 0d 03  0c 06 20 e1 0d 03 16 06  |nter=0.... .....|
00000990  20 3a 0d 03 20 2f 20 f4  20 53 65 74 75 70 20 42  | :.. / . Setup B|
000009a0  69 6f 42 6f 74 20 73 79  73 74 65 6d 20 28 66 6f  |ioBot system (fo|
000009b0  72 20 74 68 65 20 66 69  72 73 74 20 74 69 6d 65  |r the first time|
000009c0  29 0d 03 2a 06 20 3a 0d  03 34 0e 20 dd f2 73 65  |)..*. :..4. ..se|
000009d0  74 75 70 62 62 0d 03 3e  15 20 73 63 6f 72 65 62  |tupbb..>. scoreb|
000009e0  75 3d 30 3a 67 6f 65 73  3d 30 0d 03 48 18 20 62  |u=0:goes=0..H. b|
000009f0  62 6e 6f 3d 30 3a 67 65  6e 3d 30 3a f2 6e 65 77  |bno=0:gen=0:.new|
00000a00  62 62 0d 03 52 41 20 74  6f 74 61 6c 69 6e 3d 34  |bb..RA totalin=4|
00000a10  3a 61 6e 61 6c 6f 67 75  65 73 3d 31 3a 73 77 69  |:analogues=1:swi|
00000a20  74 63 68 65 73 3d 30 3a  74 6f 74 61 6c 6f 75 74  |tches=0:totalout|
00000a30  3d 34 3a 6d 65 6d 3d 32  3a 61 74 74 65 6d 70 74  |=4:mem=2:attempt|
00000a40  73 3d 31 0d 03 5c 26 20  6e 6f 25 3d 74 6f 74 61  |s=1..\& no%=tota|
00000a50  6c 69 6e 2b 74 6f 74 61  6c 6f 75 74 2b 6d 65 6d  |lin+totalout+mem|
00000a60  3a 6c 69 6e 6b 73 3d 31  32 0d 03 66 54 20 de 6d  |:links=12..fT .m|
00000a70  25 28 31 30 2c 6c 69 6e  6b 73 2d 31 2c 33 29 3a  |%(10,links-1,3):|
00000a80  de 6e 25 28 6e 6f 25 29  3a de 73 25 28 39 29 3a  |.n%(no%):.s%(9):|
00000a90  de 62 6f 6e 64 25 28 6c  69 6e 6b 73 2d 31 29 3a  |.bond%(links-1):|
00000aa0  de 63 73 62 28 39 2c 6c  69 6e 6b 73 2d 31 29 3a  |.csb(9,links-1):|
00000ab0  de 62 73 25 28 6c 69 6e  6b 73 2d 31 29 0d 03 70  |.bs%(links-1)..p|
00000ac0  66 20 73 25 28 31 29 3d  31 3a 6d 25 28 31 2c 31  |f s%(1)=1:m%(1,1|
00000ad0  2c 30 29 3d 33 3a 6d 25  28 31 2c 31 2c 31 29 3d  |,0)=3:m%(1,1,1)=|
00000ae0  31 3a 6d 25 28 31 2c 31  2c 33 29 3d 6e 6f 25 3a  |1:m%(1,1,3)=no%:|
00000af0  6d 25 28 31 2c 32 2c 30  29 3d 35 3a 6d 25 28 31  |m%(1,2,0)=5:m%(1|
00000b00  2c 32 2c 31 29 3d 31 3a  6d 25 28 31 2c 32 2c 33  |,2,1)=1:m%(1,2,3|
00000b10  29 3d 6e 6f 25 2d 31 3a  f2 67 65 6e 65 72 61 74  |)=no%-1:.generat|
00000b20  69 6f 6e 0d 03 7a 06 20  e1 0d 03 84 06 20 3a 0d  |ion..z. ..... :.|
00000b30  03 8e 27 20 f4 20 53 65  6c 65 63 74 20 62 65 73  |..' . Select bes|
00000b40  74 20 62 69 6f 62 6f 74  20 6f 66 20 67 65 6e 65  |t biobot of gene|
00000b50  72 61 74 69 6f 6e 0d 03  98 06 20 3a 0d 03 a2 11  |ration.... :....|
00000b60  20 dd f2 67 65 6e 65 72  61 74 69 6f 6e 0d 03 ac  | ..generation...|
00000b70  19 20 77 69 6e 6e 65 72  3d 30 3a 73 63 6f 72 65  |. winner=0:score|
00000b80  3d 73 25 28 30 29 0d 03  b6 30 20 e3 73 3d 30 b8  |=s%(0)...0 .s=0.|
00000b90  39 3a e7 20 73 25 28 73  29 3e 73 63 6f 72 65 20  |9:. s%(s)>score |
00000ba0  8c 20 73 63 6f 72 65 3d  73 25 28 73 29 3a 77 69  |. score=s%(s):wi|
00000bb0  6e 6e 65 72 3d 73 0d 03  c0 06 20 ed 0d 03 ca 11  |nner=s.... .....|
00000bc0  20 73 63 6f 77 69 6e 3d  73 63 6f 72 65 0d 03 d4  | scowin=score...|
00000bd0  06 20 3a 0d 03 de 27 20  f4 20 42 72 65 65 64 20  |. :...' . Breed |
00000be0  6d 6f 72 65 20 62 69 6f  62 6f 74 73 20 66 72 6f  |more biobots fro|
00000bf0  6d 20 62 65 73 74 20 6f  6e 65 0d 03 e8 06 20 3a  |m best one.... :|
00000c00  0d 03 f2 35 20 e3 78 3d  30 b8 6c 69 6e 6b 73 2d  |...5 .x=0.links-|
00000c10  31 3a e3 79 3d 30 b8 33  3a 6d 25 28 31 30 2c 78  |1:.y=0.3:m%(10,x|
00000c20  2c 79 29 3d 6d 25 28 77  69 6e 6e 65 72 2c 78 2c  |,y)=m%(winner,x,|
00000c30  79 29 3a ed 2c 0d 03 fc  38 20 e3 7a 3d 30 b8 39  |y):.,...8 .z=0.9|
00000c40  3a e3 78 3d 30 b8 6c 69  6e 6b 73 2d 31 3a e3 79  |:.x=0.links-1:.y|
00000c50  3d 30 b8 33 3a 6d 25 28  7a 2c 78 2c 79 29 3d 6d  |=0.3:m%(z,x,y)=m|
00000c60  25 28 31 30 2c 78 2c 79  29 3a ed 2c 2c 0d 04 06  |%(10,x,y):.,,...|
00000c70  06 20 3a 0d 04 10 32 20  f4 20 41 64 64 20 61 20  |. :...2 . Add a |
00000c80  62 69 74 20 6f 66 20 76  61 72 69 61 74 69 6f 6e  |bit of variation|
00000c90  20 28 77 69 74 68 20 68  65 6c 70 20 66 72 6f 6d  | (with help from|
00000ca0  20 63 73 62 29 0d 04 1a  06 20 3a 0d 04 24 39 20  | csb).... :..$9 |
00000cb0  f1 22 53 6f 72 74 69 6e  67 2e 2e 2e 22 3b 3a e3  |."Sorting...";:.|
00000cc0  70 3d 30 b8 6c 69 6e 6b  73 2d 31 3a 73 63 72 6c  |p=0.links-1:scrl|
00000cd0  6e 6b 3d 2d 35 3a e3 6c  6e 6b 3d 30 b8 6c 69 6e  |nk=-5:.lnk=0.lin|
00000ce0  6b 73 2d 31 0d 04 2e 3f  20 e7 20 63 73 62 28 77  |ks-1...? . csb(w|
00000cf0  69 6e 6e 65 72 2c 6c 6e  6b 29 3e 73 63 72 6c 6e  |inner,lnk)>scrln|
00000d00  6b 20 8c 20 73 63 72 6c  6e 6b 3d 63 73 62 28 77  |k . scrlnk=csb(w|
00000d10  69 6e 6e 65 72 2c 6c 6e  6b 29 3a 62 62 6e 6f 3d  |inner,lnk):bbno=|
00000d20  6c 6e 6b 0d 04 38 26 20  ed 3a 62 73 25 28 70 29  |lnk..8& .:bs%(p)|
00000d30  3d 62 62 6e 6f 3a 63 73  62 28 77 69 6e 6e 65 72  |=bbno:csb(winner|
00000d40  2c 62 62 6e 6f 29 3d 2d  31 0d 04 42 10 20 ed 3a  |,bbno)=-1..B. .:|
00000d50  f1 22 20 44 6f 6e 65 2e  22 0d 04 4c 06 20 3a 0d  |." Done."..L. :.|
00000d60  04 56 2e 20 61 6c 74 73  3d 28 31 2f 28 73 63 6f  |.V. alts=(1/(sco|
00000d70  72 65 2b 31 29 29 2a 32  35 30 30 3a e7 20 61 6c  |re+1))*2500:. al|
00000d80  74 73 3c 39 20 8c 20 61  6c 74 73 3d 39 0d 04 60  |ts<9 . alts=9..`|
00000d90  45 20 e7 20 73 63 6f 72  65 3d 31 30 30 20 8c 20  |E . score=100 . |
00000da0  f2 64 69 73 70 3a f1 27  27 22 47 65 6e 65 72 61  |.disp:.''"Genera|
00000db0  74 69 6f 6e 3a 22 3b 67  65 6e 27 28 91 2d 54 29  |tion:";gen'(.-T)|
00000dc0  2f 36 30 30 30 3b 22 20  6d 69 6e 75 74 65 73 22  |/6000;" minutes"|
00000dd0  3a e1 0d 04 6a 0e 20 e3  6e 3d 30 b8 61 6c 74 73  |:...j. .n=0.alts|
00000de0  0d 04 74 32 20 7a 3d a8  28 b6 28 b3 28 28 6c 69  |..t2 z=.(.(.((li|
00000df0  6e 6b 73 2d 31 29 5e 32  29 29 29 3a 7a 78 3d 7a  |nks-1)^2))):zx=z|
00000e00  3a 78 3d 62 73 25 28 7a  29 3a 7a 3d b3 28 39 29  |:x=bs%(z):z=.(9)|
00000e10  2d 31 0d 04 7e 1e 20 f1  22 5b 22 3b 7a 78 3b 22  |-1..~. ."[";zx;"|
00000e20  2c 22 3b 7a 3b 22 2c 22  3b 78 3b 22 5d 22 2c 3b  |,";z;",";x;"]",;|
00000e30  0d 04 88 6a 20 6d 25 28  7a 2c 78 2c 30 29 3d b3  |...j m%(z,x,0)=.|
00000e40  28 36 29 2d 31 3a 6d 25  28 7a 2c 78 2c 31 29 3d  |(6)-1:m%(z,x,1)=|
00000e50  b3 28 6e 6f 25 2d 74 6f  74 61 6c 6f 75 74 29 3a  |.(no%-totalout):|
00000e60  6d 25 28 7a 2c 78 2c 32  29 3d b3 28 6e 6f 25 2d  |m%(z,x,2)=.(no%-|
00000e70  74 6f 74 61 6c 6f 75 74  29 3a 6d 25 28 7a 2c 78  |totalout):m%(z,x|
00000e80  2c 33 29 3d 74 6f 74 61  6c 69 6e 2b b3 28 6e 6f  |,3)=totalin+.(no|
00000e90  25 2d 74 6f 74 61 6c 69  6e 29 0d 04 92 06 20 ed  |%-totalin).... .|
00000ea0  0d 04 9c 06 20 3a 0d 04  a6 2b 20 f4 20 49 6e 69  |.... :...+ . Ini|
00000eb0  74 69 61 6c 69 73 65 20  72 65 61 64 79 20 66 6f  |tialise ready fo|
00000ec0  72 20 67 65 6e 65 72 61  74 69 6f 6e 20 74 65 73  |r generation tes|
00000ed0  74 0d 04 b0 15 20 62 62  6e 6f 3d 30 3a 67 65 6e  |t.... bbno=0:gen|
00000ee0  3d 67 65 6e 2b 31 0d 04  ba 2e 20 e3 73 3d 30 b8  |=gen+1.... .s=0.|
00000ef0  39 3a 73 25 28 73 29 3d  30 3a e3 6c 3d 30 b8 6c  |9:s%(s)=0:.l=0.l|
00000f00  69 6e 6b 73 2d 31 3a 63  73 62 28 73 2c 6c 29 3d  |inks-1:csb(s,l)=|
00000f10  30 3a ed 2c 0d 04 c4 19  20 f1 27 22 47 65 6e 65  |0:.,.... .'"Gene|
00000f20  72 61 74 69 6f 6e 20 22  3b 67 65 6e 27 0d 04 ce  |ration ";gen'...|
00000f30  06 20 e1 0d 04 d8 05 3a  0d 04 e2 27 20 f4 20 55  |. .....:...' . U|
00000f40  73 65 72 20 69 6e 74 65  72 66 61 63 65 20 66 6f  |ser interface fo|
00000f50  72 20 42 69 6f 42 6f 74  20 73 79 73 74 65 6d 0d  |r BioBot system.|
00000f60  04 ec 06 20 3a 0d 04 f6  0b 20 dd f2 75 73 65 72  |... :.... ..user|
00000f70  0d 05 00 0c 20 66 24 3d  bf 28 30 29 0d 05 0a 15  |.... f$=.(0)....|
00000f80  20 e7 20 66 24 3d 22 44  22 20 8c 20 f2 64 69 73  | . f$="D" . .dis|
00000f90  70 0d 05 14 15 20 e7 20  66 24 3d 22 53 22 20 8c  |p.... . f$="S" .|
00000fa0  20 f2 73 61 76 65 0d 05  1e 06 20 e1 0d 05 28 30  | .save.... ...(0|
00000fb0  20 f4 20 44 69 73 70 6c  61 79 20 62 65 73 74 20  | . Display best |
00000fc0  62 69 6f 62 6f 74 27 73  20 67 65 6e 65 74 69 63  |biobot's genetic|
00000fd0  20 69 6e 66 6f 72 6d 61  74 69 6f 6e 0d 05 32 0b  | information..2.|
00000fe0  20 dd f2 64 69 73 70 0d  05 3c 46 20 db 3a e3 7a  | ..disp..<F .:.z|
00000ff0  3d 30 b8 6c 69 6e 6b 73  2d 32 3a f1 7a 2b 31 2c  |=0.links-2:.z+1,|
00001000  6d 25 28 31 30 2c 7a 2c  30 29 2c 6d 25 28 31 30  |m%(10,z,0),m%(10|
00001010  2c 7a 2c 31 29 2c 6d 25  28 31 30 2c 7a 2c 32 29  |,z,1),m%(10,z,2)|
00001020  2c 6d 25 28 31 30 2c 7a  2c 33 29 3a ed 0d 05 46  |,m%(10,z,3):...F|
00001030  50 20 f1 6c 69 6e 6b 73  2c 6d 25 28 31 30 2c 6c  |P .links,m%(10,l|
00001040  69 6e 6b 73 2d 31 2c 30  29 2c 6d 25 28 31 30 2c  |inks-1,0),m%(10,|
00001050  6c 69 6e 6b 73 2d 31 2c  31 29 2c 6d 25 28 31 30  |links-1,1),m%(10|
00001060  2c 6c 69 6e 6b 73 2d 31  2c 32 29 2c 6d 25 28 31  |,links-1,2),m%(1|
00001070  30 2c 6c 69 6e 6b 73 2d  31 2c 33 29 3b 0d 05 50  |0,links-1,3);..P|
00001080  19 20 f1 27 27 22 53 63  6f 72 65 64 3a 20 22 3b  |. .''"Scored: ";|
00001090  73 63 6f 77 69 6e 0d 05  5a 14 20 e7 20 73 63 6f  |scowin..Z. . sco|
000010a0  72 65 3d 31 30 30 20 8c  20 e1 0d 05 64 14 20 ef  |re=100 . ...d. .|
000010b0  20 37 3a f5 20 fd 20 bf  28 30 29 3d 22 22 0d 05  | 7:. . .(0)=""..|
000010c0  6e 11 20 f5 20 fd 20 bf  28 30 29 3c 3e 22 22 0d  |n. . . .(0)<>"".|
000010d0  05 78 06 20 e1 0d 05 82  1f 20 f4 20 53 61 76 65  |.x. ..... . Save|
000010e0  20 62 65 73 74 20 62 69  6f 62 6f 74 20 74 6f 20  | best biobot to |
000010f0  64 69 73 63 0d 05 8c 0b  20 dd f2 73 61 76 65 0d  |disc.... ..save.|
00001100  05 96 10 20 66 69 6c 65  3d ae 22 42 42 46 22 0d  |... file=."BBF".|
00001110  05 a0 4a 20 e3 7a 3d 30  b8 6c 69 6e 6b 73 2d 31  |..J .z=0.links-1|
00001120  3a f1 23 66 69 6c 65 2c  7a 2b 31 2c 6d 25 28 31  |:.#file,z+1,m%(1|
00001130  30 2c 7a 2c 30 29 2c 6d  25 28 31 30 2c 7a 2c 31  |0,z,0),m%(10,z,1|
00001140  29 2c 6d 25 28 31 30 2c  7a 2c 32 29 2c 6d 25 28  |),m%(10,z,2),m%(|
00001150  31 30 2c 7a 2c 33 29 3a  ed 0d 05 aa 0b 20 d9 23  |10,z,3):..... .#|
00001160  66 69 6c 65 0d 05 b4 06  20 e1 0d 05 be 06 20 3a  |file.... ..... :|
00001170  0d 05 c8 2f 20 f4 20 47  69 76 65 20 62 69 6f 62  |.../ . Give biob|
00001180  6f 74 20 61 20 73 63 6f  72 65 20 66 72 6f 6d 20  |ot a score from |
00001190  73 75 63 63 65 73 73 69  76 65 20 67 6f 65 73 0d  |successive goes.|
000011a0  05 d2 17 20 dd a4 73 63  72 3d 73 63 6f 72 65 62  |... ..scr=scoreb|
000011b0  75 2f 67 6f 65 73 0d 05  dc 06 20 3a 0d 05 e6 2b  |u/goes.... :...+|
000011c0  20 f4 20 41 64 64 20 73  63 6f 72 65 73 20 74 6f  | . Add scores to|
000011d0  20 62 6f 6e 64 73 20 66  72 6f 6d 20 74 68 69 73  | bonds from this|
000011e0  20 42 69 6f 42 6f 74 0d  05 f0 16 20 dd f2 61 64  | BioBot.... ..ad|
000011f0  64 62 6f 6e 64 73 28 73  63 6f 72 65 29 0d 05 fa  |dbonds(score)...|
00001200  11 20 e3 6c 3d 30 b8 6c  69 6e 6b 73 2d 31 0d 06  |. .l=0.links-1..|
00001210  04 40 20 63 73 62 28 62  62 6e 6f 2c 6c 29 3d 63  |.@ csb(bbno,l)=c|
00001220  73 62 28 62 62 6e 6f 2c  6c 29 2f 67 6f 65 73 2a  |sb(bbno,l)/goes*|
00001230  28 67 6f 65 73 2d 31 29  2b 28 73 63 6f 72 65 2a  |(goes-1)+(score*|
00001240  62 6f 6e 64 25 28 6c 29  29 2f 67 6f 65 73 0d 06  |bond%(l))/goes..|
00001250  0e 06 20 ed 0d 06 18 06  20 e1 0d ff              |.. ..... ...|
0000125c
BioBot/NumPat/Num4.m0
BioBot/NumPat/Num4.m1
BioBot/NumPat/Num4.m2
BioBot/NumPat/Num4.m4
BioBot/NumPat/Num4.m5