Home » Personal collection » Acorn DFS disks » dfs_box04_disk09_rgs_robotics_1.scp » TOWER

TOWER

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 DFS disks » dfs_box04_disk09_rgs_robotics_1.scp
Filename: TOWER
Read OK:
File size: 1561 bytes
Load address: FF2400
Exec address: FF8023
Duplicates

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

File contents
   10 REM INTERFACE DRIVER
   15 REM FISCHER COMPUTING <--> ACORN  BBC COMPUTER
   20 REM COPYRIGHT (C) ARTUR FISCHER FORSCHUNG 1984
   30 REM Use the following commands to control your FISCHERTECHNIK model with your Acorn Model B
   35 REM 
   40 REM     * * COMMANDS * *
   45 REM 
   50 REM - CALL M1,CW%
   55 REM   Rotates Motor #1 clockwise
   60 REM - CALL M1,CCW%
   65 REM   Rotates Motor #1 counter-clockwise
   70 REM - CALL M1,GO%
   75 REM   Switches device connected to M1 on
   80 REM - CALL M1,HALT%
   85 REM   Switches device connected to M1 off
   90 REM Instead of "M1" you may also use M2, M3 or M4
   95 REM - FNUSR (E1) 
  100 REM   Returns a '0' or a '1' depending on the current state of the switch
  105 REM Instead of 'E1' you may also use any of the keys 'E2' to 'E8'
  110 REM - FNUSR (EX)
  115 REM   Returns a value depending on the current position of the potentiometer
  120 REM Instead of 'EX' you can also use 'EY' to obtain a value from potentiometer Y
  125 LET drr=&62
  130 LET up=&60
  135 LET til=&68
  140 LET tih=&69
  145 LET tic=&6B
  150 LET avar=&80
  155 LET mask=&81
  160 LET buff=&82 
  165 LET asave=&84
  170 LET xsave=&85
  175 LET ysave=&86
  180 DIM M% 500
  185 FOR Z=0 TO 2 STEP 2
  190 P%=M%
  195[
  200 OPT Z
  205 \ * * OUTPUT DRIVER * *
  210 .init:lda #0:beq stvar:lda #3 :bne bout:lda #12:bne bout:lda #&30:bne bout:lda #&C0
  215 .bout :sta mask:lda avar:ora mask:sta avar:jsr check:jmp ok2
  220 .check :lda &0600:cmp #1:beq ok
  225 .err1:brk:]:PROCequb (&FF):PROCequs ("Use exactly one parameter"):PROCequb (0):[OPT Z
  230 .ok:lda&603: cmp #4:beq ok1  
  235 .err2:brk:]:PROCequb(&FF):PROCequs("Use integer parameters only"):PROCequb(0):[OPT Z
  240 .ok1:lda &601:sta buff:lda &602:sta buff+1:ldy #0:lda (buff),Y
  245 .back:rts 
  250 .ok2:and mask:sta mask: lda avar:eor mask 
  255 .stvar:sta avar: tay
  260 .shout:jsr save:ldy #&3F:ldx #drr:jsr write:jsr load:ldx #8
  265 .loop: lda #&30:asl avar: bcc null:ora #4
  270 .null:jsr save:tay:ldx #up:jsr write:jsr load:ora #8:jsr save:tay:ldx #up
  275 jsr write:jsr load:dex:bne loop:jsr save:ldy #&31:ldx #up:jsr write:jsr load:sty avar:rts
  280 .E1:ldx #1:jmp test
  285 .E2:ldx #2:jmp test
  290 .E3:ldx #4:jmp test
  295 .E4:ldx #8:jmp test
  300 .E5:ldx #16:jmp test
  305 .E6:ldx #32:jmp test
  310 .E7:ldx #64:jmp test
  315 .E8:ldx #128
  320 .test:stx mask:lda #&32:jsr save:ldy asave:ldx #up:jsr write:jsr load:ora #8:jsr save:ldy asave:ldx #up:jsr write:jsr load:ldx #8
  325 .loop2:asl A:jsr save:ldx #up:jsr read:tya:and #&80:beq nul2:jsr load:ora #1:jmp nul3
  330 .nul2:jsr load
  335 .nul3:jsr save:ldy #&30:ldx #up:jsr write:jsr load:ldy #&38:ldx #up:jsr write:jsr load:dex:bne loop2:and mask:beq back1:lda #1 
  340 .back1
  345 rts
  350 .EX:ldx #&A0:jmp poti
  355 .EY:ldx #&90
  360 .poti:sei:jsr save:ldy #&20:ldx #tic:jsr write:ldy #&FF:ldx #til:jsr write:ldy #&FF:ldx #tih:jsr write:ldy xsave
  365 ldx #up:jsr write:ldy #&38:ldx #up:jsr write:jsr load
  370 .tst:jsr save:ldx #til:jsr read:sty ysave:jsr load:tya:ldx #200
  375 .delay:dex:bne delay:jsr save:ldx #til:jsr read:sty ysave:jsr load:sec:sbc ysave:bne tst:jsr save:ldx #til:jsr read:sty ysave:jsr load:sec:lda #&FF:sbc ysave:cli:rts
  380 .write:lda #&97:jsr &FFF4:clc:rts
  385 .read:lda #&96:jsr &FFF4:clc:rts
  390 .save:sta asave:stx xsave:sty ysave:rts 
  395 .load:lda asave:ldx xsave:ldy ysave:rts
  400]
  405 NEXT Z
  410 LET M1=init+4
  415 LET M2=init+8
  420 LET M3=init+12
  425 LET M4=init+16
  430 LET INIT=init
  435 LET CW%=85
  440 LET CCW%=170
  445 LET GO%=85
  450 LET HALT%=255
  455 REM * * * END OF DRIVER * * *
  460 DEF FNUSR(A)=USR(A) AND &FF  
  470 DEFPROCequb(num):?P%=num:P%=P%+1:ENDPROC
  480 DEFPROCequs(text$):$P%=text$:P%=P%+LEN text$:ENDPROC
  500 CALL INIT
  600 REM 
  610 REM FISCHERTECHNIK COMPUTING
  620 REM 
  630 REM TOWER OF HANOI
  640 REM 
  650 REM COPYRIGHT (C) 1984
  660 REM BY ARTUR FISCHER FORSCHUNG
  670 REM 
  690 REM ASSIGNMENTS FOR THE INTERFACE
  700 REM
  710 REM INPUT
  720 REM E1=BOTTOM
  730 REM E2=TOP
  740 REM EY=POSITION OF THE ANGLE
  750 REM 
  760 REM OUTPUT
  770 REM M1=BODY
  780 REM M2=ARM
  790 REM M3=MAGNET
  800 REM 
  810 REM FUNCTION DESCRIPTION :
  820 REM SORTING THE PILE OF DISCS
  830 REM FOLLOWING THE PUZZLE ORIGINATING FROM BUDDHIST TRADITION
  840 REM 
  850 REM 
 1000 DIM X(31),Y(31),Z(31),PILE(3)
 1010 REM POSITON OF PILES (ARBITRARY VALUES)
 1020 PROCsetpile
 1500 MODE6
 1510 PRINT "FISCHERTECHNIK"  
 1520 PRINT "COMPUTING"   
 1530 PRINT
 1540 PRINT "TOWER OF HANOI"
 1550 PRINT
 1600 INPUT "HOW MANY DISCS DOES THE TOWER HAVE ",N
 1610 IF N<1 THEN END
 1620 LET M=0
 1630 LET X(M)=N:LET Y(M)=1:LET Z(M)=3
 1640 GOSUB 1700
 1650 END
 1690 REM PSEUDORECURSIVE ROUTINE
 1700 IF X(M)=0 THEN RETURN
 1710 LET M=M+1
 1720 LET X(M)=X(M-1)-1
 1730 LET Y(M)=Y(M-1)
 1740 LET Z(M)=6-Y(M-1)-Z(M-1)
 1750 GOSUB 1700
 1760 LET M=M-1
 1770 PRINT "DISC ";X(M);"FROM PILE ";Y(M);" TO PILE ";Z(M)  
 1780 GOSUB 2000:REM ROBOT ROUTINE
 1790 LET M=M+1
 1800 LET X(M)=X(M-1)-1
 1810 LET Y(M)=6-Y(M-1)-Z(M-1)
 1820 LET Z(M)=Z(M-1)
 1830 GOSUB 1700
 1840 LET M=M-1
 1850 RETURN
 2000 REM ROBOT ROUTINE
 2010 LET AIM=PILE(Y(M))
 2020 GOSUB 2200:REM TURN BODY
 2030 GOSUB 2310:REM LOWER ARM
 2040 CALL M1,GO%:REM SWITCH MAGNET ON
 2050 GOSUB 2350:REM LIFT ARM
 2060 LET AIM=PILE(Z(M))
 2070 GOSUB 2200:REM TURN BODY
 2080 GOSUB 2310:REM LOWER ARM
 2090 GOSUB 2120:REM MAGNET OFF
 2100 GOSUB 2350:REM LIFT ARM
 2110 RETURN
 2120 REM MAGNET-OFF ROUTINE
 2130 CALL M1,CCW%:REM REVERSE MAGNET CURRENT FOR DEMAGETIZATION 
 2140 CALL M1,HALT%:REM MAGNET OFF 
 2150 RETURN
 2200 REM POSITIONAL CONTROL ROUTINE
 2210 LET D=FNUSR(EY)-AIM 
 2220 IF D>0 THEN CALL M3,CW%  
 2230 IF D<0 THEN CALL M3,CCW% 
 2240 IF D=0 THEN RETURN
 2250 LET D=ABS(D)
 2260 IF D>5 THEN GOTO 2210
 2270 FOR I=0 TO D
 2280 NEXT I
 2290 CALL M3,HALT% 
 2300 GOTO 2210
 2310 CALL M2,CCW%:REM LOWER ARM 
 2320 IF FNUSR(E1)=0 THEN GOTO 2310 
 2330 CALL M2,HALT%
 2340 RETURN
 2350 CALL M2,CW%:REM LIFT ARM  
 2360 IF FNUSR(E2)=0 THEN GOTO 2360 
 2370 CALL M2,HALT%
 2380 RETURN
 2390 DEF PROCsetpile:OK=FALSE
 2395 FOR n=1 TO 3:OK=FALSE
 2400 REPEAT
 2410 IF FNUSR(E4)=1 THEN CALL M3,CW%:OK=TRUE
 2420 IF FNUSR(E5)=1 THEN CALL M3,CCW%:OK=TRUE
 2430 UNTIL OK 
 2440 REPEAT:UNTIL FNUSR(E3)=1
 2450 CALL M3,HALT%
 2460 PILE(n)=FNUSR(EY)
 2470 NEXT n:ENDPROC 

 � INTERFACE DRIVER
1 � FISCHER COMPUTING <--> ACORN  BBC COMPUTER
1 � COPYRIGHT (C) ARTUR FISCHER FORSCHUNG 1984
^ � Use the following commands to control your FISCHERTECHNIK model with your Acorn Model B
# � 
( �     * * COMMANDS * *
- � 
2 � - CALL M1,CW%
7# �   Rotates Motor #1 clockwise
< � - CALL M1,CCW%
A+ �   Rotates Motor #1 counter-clockwise
F � - CALL M1,GO%
K+ �   Switches device connected to M1 on
P � - CALL M1,HALT%
U, �   Switches device connected to M1 off
Z4 � Instead of "M1" you may also use M2, M3 or M4
_ � - FNUSR (E1) 
dL �   Returns a '0' or a '1' depending on the current state of the switch
iD � Instead of 'E1' you may also use any of the keys 'E2' to 'E8'
n � - FNUSR (EX)
sO �   Returns a value depending on the current position of the potentiometer
xS � Instead of 'EX' you can also use 'EY' to obtain a value from potentiometer Y
} � drr=&62
�
 � up=&60
� � til=&68
� � tih=&69
� � tic=&6B
� � avar=&80
� � mask=&81
� � buff=&82 
� � asave=&84
� � xsave=&85
� � ysave=&86
�
 � M% 500
� � Z=0 � 2 � 2
�
 P%=M%
�[
�
 OPT Z
� \ * * OUTPUT DRIVER * *
�X .init:lda #0:beq stvar:lda #3 :bne bout:lda #12:bne bout:lda #&30:bne bout:lda #&C0
�A .bout :sta mask:lda avar:ora mask:sta avar:jsr check:jmp ok2
�$ .check :lda &0600:cmp #1:beq ok
�Q .err1:brk:]:�equb (&FF):�equs ("Use exactly one parameter"):�equb (0):[OPT Z
�" .ok:lda&603: cmp #4:beq ok1  
�P .err2:brk:]:�equb(&FF):�equs("Use integer parameters only"):�equb(0):[OPT Z
�C .ok1:lda &601:sta buff:lda &602:sta buff+1:ldy #0:lda (buff),Y
� .back:rts 
�/ .ok2:and mask:sta mask: lda avar:eor mask 
� .stvar:sta avar: tay
@ .shout:jsr save:ldy #&3F:ldx #drr:jsr write:jsr load:ldx #8
	. .loop: lda #&30:asl avar: bcc null:ora #4
N .null:jsr save:tay:ldx #up:jsr write:jsr load:ora #8:jsr save:tay:ldx #up
^ jsr write:jsr load:dex:bne loop:jsr save:ldy #&31:ldx #up:jsr write:jsr load:sty avar:rts
 .E1:ldx #1:jmp test
 .E2:ldx #2:jmp test
" .E3:ldx #4:jmp test
' .E4:ldx #8:jmp test
, .E5:ldx #16:jmp test
1 .E6:ldx #32:jmp test
6 .E7:ldx #64:jmp test
; .E8:ldx #128
@� .test:stx mask:lda #&32:jsr save:ldy asave:ldx #up:jsr write:jsr load:ora #8:jsr save:ldy asave:ldx #up:jsr write:jsr load:ldx #8
EZ .loop2:asl A:jsr save:ldx #up:jsr read:tya:and #&80:beq nul2:jsr load:ora #1:jmp nul3
J .nul2:jsr load
O� .nul3:jsr save:ldy #&30:ldx #up:jsr write:jsr load:ldy #&38:ldx #up:jsr write:jsr load:dex:bne loop2:and mask:beq back1:lda #1 
T .back1
Y rts
^ .EX:ldx #&A0:jmp poti
c .EY:ldx #&90
hu .poti:sei:jsr save:ldy #&20:ldx #tic:jsr write:ldy #&FF:ldx #til:jsr write:ldy #&FF:ldx #tih:jsr write:ldy xsave
m: ldx #up:jsr write:ldy #&38:ldx #up:jsr write:jsr load
rD .tst:jsr save:ldx #til:jsr read:sty ysave:jsr load:tya:ldx #200
w� .delay:dex:bne delay:jsr save:ldx #til:jsr read:sty ysave:jsr load:sec:sbc ysave:bne tst:jsr save:ldx #til:jsr read:sty ysave:jsr load:sec:lda #&FF:sbc ysave:cli:rts
|& .write:lda #&97:jsr &FFF4:clc:rts
�% .read:lda #&96:jsr &FFF4:clc:rts
�- .save:sta asave:stx xsave:sty ysave:rts 
�, .load:lda asave:ldx xsave:ldy ysave:rts
�]
� � Z
� � M1=init+4
� � M2=init+8
� � M3=init+12
� � M4=init+16
� � INIT=init
�
 � CW%=85
� � CCW%=170
�
 � GO%=85
� � HALT%=255
�  � * * * END OF DRIVER * * *
� � �USR(A)=�(A) � &FF  
�" ��equb(num):?P%=num:P%=P%+1:�
�, ��equs(text$):$P%=text$:P%=P%+� text$:�
� � INIT
X � 
b � FISCHERTECHNIK COMPUTING
l � 
v � TOWER OF HANOI
� � 
� � COPYRIGHT (C) 1984
�! � BY ARTUR FISCHER FORSCHUNG
� � 
�$ � ASSIGNMENTS FOR THE INTERFACE
� �
� � INPUT
� � E1=BOTTOM
�
 � E2=TOP
� � EY=POSITION OF THE ANGLE
� � 
�
 � OUTPUT
 � M1=BODY

 � M2=ARM
 � M3=MAGNET
  � 
* � FUNCTION DESCRIPTION :
4  � SORTING THE PILE OF DISCS
>? � FOLLOWING THE PUZZLE ORIGINATING FROM BUDDHIST TRADITION
H � 
R � 
�  � X(31),Y(31),Z(31),PILE(3)
�* � POSITON OF PILES (ARBITRARY VALUES)
�
 �setpile
� �6
� � "FISCHERTECHNIK"  
� � "COMPUTING"   
� �
 � "TOWER OF HANOI"
 �
@. � "HOW MANY DISCS DOES THE TOWER HAVE ",N
J � N<1 � �
T
 � M=0
^ � X(M)=N:� Y(M)=1:� Z(M)=3
h � �tdF
r �
� � PSEUDORECURSIVE ROUTINE
� � X(M)=0 � �
� � M=M+1
� � X(M)=X(M-1)-1
� � Y(M)=Y(M-1)
� � Z(M)=6-Y(M-1)-Z(M-1)
� � �tdF
� � M=M-1
�8 � "DISC ";X(M);"FROM PILE ";Y(M);" TO PILE ";Z(M)  
� � �dPG:� ROBOT ROUTINE
� � M=M+1
 � X(M)=X(M-1)-1
 � Y(M)=6-Y(M-1)-Z(M-1)
 � Z(M)=Z(M-1)
& � �tdF
0 � M=M-1
: �
� � ROBOT ROUTINE
� � AIM=PILE(Y(M))
� � �tXH:� TURN BODY
� � �TFI:� LOWER ARM
�  � M1,GO%:� SWITCH MAGNET ON
 � �TnI:� LIFT ARM
 � AIM=PILE(Z(M))
 � �tXH:� TURN BODY
  � �TFI:� LOWER ARM
* � �DHH:� MAGNET OFF
4 � �TnI:� LIFT ARM
> �
H � MAGNET-OFF ROUTINE
R; � M1,CCW%:� REVERSE MAGNET CURRENT FOR DEMAGETIZATION 
\ � M1,HALT%:� MAGNET OFF 
f �
�! � POSITIONAL CONTROL ROUTINE
� � D=�USR(EY)-AIM 
� � D>0 � � M3,CW%  
� � D<0 � � M3,CCW% 
� � D=0 � �
�
 � D=�(D)
� � D>5 � � �tbH
� � I=0 � D
� � I
� � M3,HALT% 
� � �tbH
	 � M2,CCW%:� LOWER ARM 
	 � �USR(E1)=0 � � �TFI 
	 � M2,HALT%
	$ �
	. � M2,CW%:� LIFT ARM  
	8 � �USR(E2)=0 � � �TxI 
	B � M2,HALT%
	L �
	V � �setpile:OK=�
	[ � n=1 � 3:OK=�
	` �
	j! � �USR(E4)=1 � � M3,CW%:OK=�
	t" � �USR(E5)=1 � � M3,CCW%:OK=�
	~
 � OK 
	� �:� �USR(E3)=1
	� � M3,HALT%
	� PILE(n)=�USR(EY)
	� � n:� 
�
00000000  0d 00 0a 17 20 f4 20 49  4e 54 45 52 46 41 43 45  |.... . INTERFACE|
00000010  20 44 52 49 56 45 52 0d  00 0f 31 20 f4 20 46 49  | DRIVER...1 . FI|
00000020  53 43 48 45 52 20 43 4f  4d 50 55 54 49 4e 47 20  |SCHER COMPUTING |
00000030  3c 2d 2d 3e 20 41 43 4f  52 4e 20 20 42 42 43 20  |<--> ACORN  BBC |
00000040  43 4f 4d 50 55 54 45 52  0d 00 14 31 20 f4 20 43  |COMPUTER...1 . C|
00000050  4f 50 59 52 49 47 48 54  20 28 43 29 20 41 52 54  |OPYRIGHT (C) ART|
00000060  55 52 20 46 49 53 43 48  45 52 20 46 4f 52 53 43  |UR FISCHER FORSC|
00000070  48 55 4e 47 20 31 39 38  34 0d 00 1e 5e 20 f4 20  |HUNG 1984...^ . |
00000080  55 73 65 20 74 68 65 20  66 6f 6c 6c 6f 77 69 6e  |Use the followin|
00000090  67 20 63 6f 6d 6d 61 6e  64 73 20 74 6f 20 63 6f  |g commands to co|
000000a0  6e 74 72 6f 6c 20 79 6f  75 72 20 46 49 53 43 48  |ntrol your FISCH|
000000b0  45 52 54 45 43 48 4e 49  4b 20 6d 6f 64 65 6c 20  |ERTECHNIK model |
000000c0  77 69 74 68 20 79 6f 75  72 20 41 63 6f 72 6e 20  |with your Acorn |
000000d0  4d 6f 64 65 6c 20 42 0d  00 23 07 20 f4 20 0d 00  |Model B..#. . ..|
000000e0  28 1b 20 f4 20 20 20 20  20 2a 20 2a 20 43 4f 4d  |(. .     * * COM|
000000f0  4d 41 4e 44 53 20 2a 20  2a 0d 00 2d 07 20 f4 20  |MANDS * *..-. . |
00000100  0d 00 32 14 20 f4 20 2d  20 43 41 4c 4c 20 4d 31  |..2. . - CALL M1|
00000110  2c 43 57 25 0d 00 37 23  20 f4 20 20 20 52 6f 74  |,CW%..7# .   Rot|
00000120  61 74 65 73 20 4d 6f 74  6f 72 20 23 31 20 63 6c  |ates Motor #1 cl|
00000130  6f 63 6b 77 69 73 65 0d  00 3c 15 20 f4 20 2d 20  |ockwise..<. . - |
00000140  43 41 4c 4c 20 4d 31 2c  43 43 57 25 0d 00 41 2b  |CALL M1,CCW%..A+|
00000150  20 f4 20 20 20 52 6f 74  61 74 65 73 20 4d 6f 74  | .   Rotates Mot|
00000160  6f 72 20 23 31 20 63 6f  75 6e 74 65 72 2d 63 6c  |or #1 counter-cl|
00000170  6f 63 6b 77 69 73 65 0d  00 46 14 20 f4 20 2d 20  |ockwise..F. . - |
00000180  43 41 4c 4c 20 4d 31 2c  47 4f 25 0d 00 4b 2b 20  |CALL M1,GO%..K+ |
00000190  f4 20 20 20 53 77 69 74  63 68 65 73 20 64 65 76  |.   Switches dev|
000001a0  69 63 65 20 63 6f 6e 6e  65 63 74 65 64 20 74 6f  |ice connected to|
000001b0  20 4d 31 20 6f 6e 0d 00  50 16 20 f4 20 2d 20 43  | M1 on..P. . - C|
000001c0  41 4c 4c 20 4d 31 2c 48  41 4c 54 25 0d 00 55 2c  |ALL M1,HALT%..U,|
000001d0  20 f4 20 20 20 53 77 69  74 63 68 65 73 20 64 65  | .   Switches de|
000001e0  76 69 63 65 20 63 6f 6e  6e 65 63 74 65 64 20 74  |vice connected t|
000001f0  6f 20 4d 31 20 6f 66 66  0d 00 5a 34 20 f4 20 49  |o M1 off..Z4 . I|
00000200  6e 73 74 65 61 64 20 6f  66 20 22 4d 31 22 20 79  |nstead of "M1" y|
00000210  6f 75 20 6d 61 79 20 61  6c 73 6f 20 75 73 65 20  |ou may also use |
00000220  4d 32 2c 20 4d 33 20 6f  72 20 4d 34 0d 00 5f 14  |M2, M3 or M4.._.|
00000230  20 f4 20 2d 20 46 4e 55  53 52 20 28 45 31 29 20  | . - FNUSR (E1) |
00000240  0d 00 64 4c 20 f4 20 20  20 52 65 74 75 72 6e 73  |..dL .   Returns|
00000250  20 61 20 27 30 27 20 6f  72 20 61 20 27 31 27 20  | a '0' or a '1' |
00000260  64 65 70 65 6e 64 69 6e  67 20 6f 6e 20 74 68 65  |depending on the|
00000270  20 63 75 72 72 65 6e 74  20 73 74 61 74 65 20 6f  | current state o|
00000280  66 20 74 68 65 20 73 77  69 74 63 68 0d 00 69 44  |f the switch..iD|
00000290  20 f4 20 49 6e 73 74 65  61 64 20 6f 66 20 27 45  | . Instead of 'E|
000002a0  31 27 20 79 6f 75 20 6d  61 79 20 61 6c 73 6f 20  |1' you may also |
000002b0  75 73 65 20 61 6e 79 20  6f 66 20 74 68 65 20 6b  |use any of the k|
000002c0  65 79 73 20 27 45 32 27  20 74 6f 20 27 45 38 27  |eys 'E2' to 'E8'|
000002d0  0d 00 6e 13 20 f4 20 2d  20 46 4e 55 53 52 20 28  |..n. . - FNUSR (|
000002e0  45 58 29 0d 00 73 4f 20  f4 20 20 20 52 65 74 75  |EX)..sO .   Retu|
000002f0  72 6e 73 20 61 20 76 61  6c 75 65 20 64 65 70 65  |rns a value depe|
00000300  6e 64 69 6e 67 20 6f 6e  20 74 68 65 20 63 75 72  |nding on the cur|
00000310  72 65 6e 74 20 70 6f 73  69 74 69 6f 6e 20 6f 66  |rent position of|
00000320  20 74 68 65 20 70 6f 74  65 6e 74 69 6f 6d 65 74  | the potentiomet|
00000330  65 72 0d 00 78 53 20 f4  20 49 6e 73 74 65 61 64  |er..xS . Instead|
00000340  20 6f 66 20 27 45 58 27  20 79 6f 75 20 63 61 6e  | of 'EX' you can|
00000350  20 61 6c 73 6f 20 75 73  65 20 27 45 59 27 20 74  | also use 'EY' t|
00000360  6f 20 6f 62 74 61 69 6e  20 61 20 76 61 6c 75 65  |o obtain a value|
00000370  20 66 72 6f 6d 20 70 6f  74 65 6e 74 69 6f 6d 65  | from potentiome|
00000380  74 65 72 20 59 0d 00 7d  0e 20 e9 20 64 72 72 3d  |ter Y..}. . drr=|
00000390  26 36 32 0d 00 82 0d 20  e9 20 75 70 3d 26 36 30  |&62.... . up=&60|
000003a0  0d 00 87 0e 20 e9 20 74  69 6c 3d 26 36 38 0d 00  |.... . til=&68..|
000003b0  8c 0e 20 e9 20 74 69 68  3d 26 36 39 0d 00 91 0e  |.. . tih=&69....|
000003c0  20 e9 20 74 69 63 3d 26  36 42 0d 00 96 0f 20 e9  | . tic=&6B.... .|
000003d0  20 61 76 61 72 3d 26 38  30 0d 00 9b 0f 20 e9 20  | avar=&80.... . |
000003e0  6d 61 73 6b 3d 26 38 31  0d 00 a0 10 20 e9 20 62  |mask=&81.... . b|
000003f0  75 66 66 3d 26 38 32 20  0d 00 a5 10 20 e9 20 61  |uff=&82 .... . a|
00000400  73 61 76 65 3d 26 38 34  0d 00 aa 10 20 e9 20 78  |save=&84.... . x|
00000410  73 61 76 65 3d 26 38 35  0d 00 af 10 20 e9 20 79  |save=&85.... . y|
00000420  73 61 76 65 3d 26 38 36  0d 00 b4 0d 20 de 20 4d  |save=&86.... . M|
00000430  25 20 35 30 30 0d 00 b9  12 20 e3 20 5a 3d 30 20  |% 500.... . Z=0 |
00000440  b8 20 32 20 88 20 32 0d  00 be 0a 20 50 25 3d 4d  |. 2 . 2.... P%=M|
00000450  25 0d 00 c3 05 5b 0d 00  c8 0a 20 4f 50 54 20 5a  |%....[.... OPT Z|
00000460  0d 00 cd 1c 20 5c 20 2a  20 2a 20 4f 55 54 50 55  |.... \ * * OUTPU|
00000470  54 20 44 52 49 56 45 52  20 2a 20 2a 0d 00 d2 58  |T DRIVER * *...X|
00000480  20 2e 69 6e 69 74 3a 6c  64 61 20 23 30 3a 62 65  | .init:lda #0:be|
00000490  71 20 73 74 76 61 72 3a  6c 64 61 20 23 33 20 3a  |q stvar:lda #3 :|
000004a0  62 6e 65 20 62 6f 75 74  3a 6c 64 61 20 23 31 32  |bne bout:lda #12|
000004b0  3a 62 6e 65 20 62 6f 75  74 3a 6c 64 61 20 23 26  |:bne bout:lda #&|
000004c0  33 30 3a 62 6e 65 20 62  6f 75 74 3a 6c 64 61 20  |30:bne bout:lda |
000004d0  23 26 43 30 0d 00 d7 41  20 2e 62 6f 75 74 20 3a  |#&C0...A .bout :|
000004e0  73 74 61 20 6d 61 73 6b  3a 6c 64 61 20 61 76 61  |sta mask:lda ava|
000004f0  72 3a 6f 72 61 20 6d 61  73 6b 3a 73 74 61 20 61  |r:ora mask:sta a|
00000500  76 61 72 3a 6a 73 72 20  63 68 65 63 6b 3a 6a 6d  |var:jsr check:jm|
00000510  70 20 6f 6b 32 0d 00 dc  24 20 2e 63 68 65 63 6b  |p ok2...$ .check|
00000520  20 3a 6c 64 61 20 26 30  36 30 30 3a 63 6d 70 20  | :lda &0600:cmp |
00000530  23 31 3a 62 65 71 20 6f  6b 0d 00 e1 51 20 2e 65  |#1:beq ok...Q .e|
00000540  72 72 31 3a 62 72 6b 3a  5d 3a f2 65 71 75 62 20  |rr1:brk:]:.equb |
00000550  28 26 46 46 29 3a f2 65  71 75 73 20 28 22 55 73  |(&FF):.equs ("Us|
00000560  65 20 65 78 61 63 74 6c  79 20 6f 6e 65 20 70 61  |e exactly one pa|
00000570  72 61 6d 65 74 65 72 22  29 3a f2 65 71 75 62 20  |rameter"):.equb |
00000580  28 30 29 3a 5b 4f 50 54  20 5a 0d 00 e6 22 20 2e  |(0):[OPT Z..." .|
00000590  6f 6b 3a 6c 64 61 26 36  30 33 3a 20 63 6d 70 20  |ok:lda&603: cmp |
000005a0  23 34 3a 62 65 71 20 6f  6b 31 20 20 0d 00 eb 50  |#4:beq ok1  ...P|
000005b0  20 2e 65 72 72 32 3a 62  72 6b 3a 5d 3a f2 65 71  | .err2:brk:]:.eq|
000005c0  75 62 28 26 46 46 29 3a  f2 65 71 75 73 28 22 55  |ub(&FF):.equs("U|
000005d0  73 65 20 69 6e 74 65 67  65 72 20 70 61 72 61 6d  |se integer param|
000005e0  65 74 65 72 73 20 6f 6e  6c 79 22 29 3a f2 65 71  |eters only"):.eq|
000005f0  75 62 28 30 29 3a 5b 4f  50 54 20 5a 0d 00 f0 43  |ub(0):[OPT Z...C|
00000600  20 2e 6f 6b 31 3a 6c 64  61 20 26 36 30 31 3a 73  | .ok1:lda &601:s|
00000610  74 61 20 62 75 66 66 3a  6c 64 61 20 26 36 30 32  |ta buff:lda &602|
00000620  3a 73 74 61 20 62 75 66  66 2b 31 3a 6c 64 79 20  |:sta buff+1:ldy |
00000630  23 30 3a 6c 64 61 20 28  62 75 66 66 29 2c 59 0d  |#0:lda (buff),Y.|
00000640  00 f5 0f 20 2e 62 61 63  6b 3a 72 74 73 20 0d 00  |... .back:rts ..|
00000650  fa 2f 20 2e 6f 6b 32 3a  61 6e 64 20 6d 61 73 6b  |./ .ok2:and mask|
00000660  3a 73 74 61 20 6d 61 73  6b 3a 20 6c 64 61 20 61  |:sta mask: lda a|
00000670  76 61 72 3a 65 6f 72 20  6d 61 73 6b 20 0d 00 ff  |var:eor mask ...|
00000680  19 20 2e 73 74 76 61 72  3a 73 74 61 20 61 76 61  |. .stvar:sta ava|
00000690  72 3a 20 74 61 79 0d 01  04 40 20 2e 73 68 6f 75  |r: tay...@ .shou|
000006a0  74 3a 6a 73 72 20 73 61  76 65 3a 6c 64 79 20 23  |t:jsr save:ldy #|
000006b0  26 33 46 3a 6c 64 78 20  23 64 72 72 3a 6a 73 72  |&3F:ldx #drr:jsr|
000006c0  20 77 72 69 74 65 3a 6a  73 72 20 6c 6f 61 64 3a  | write:jsr load:|
000006d0  6c 64 78 20 23 38 0d 01  09 2e 20 2e 6c 6f 6f 70  |ldx #8.... .loop|
000006e0  3a 20 6c 64 61 20 23 26  33 30 3a 61 73 6c 20 61  |: lda #&30:asl a|
000006f0  76 61 72 3a 20 62 63 63  20 6e 75 6c 6c 3a 6f 72  |var: bcc null:or|
00000700  61 20 23 34 0d 01 0e 4e  20 2e 6e 75 6c 6c 3a 6a  |a #4...N .null:j|
00000710  73 72 20 73 61 76 65 3a  74 61 79 3a 6c 64 78 20  |sr save:tay:ldx |
00000720  23 75 70 3a 6a 73 72 20  77 72 69 74 65 3a 6a 73  |#up:jsr write:js|
00000730  72 20 6c 6f 61 64 3a 6f  72 61 20 23 38 3a 6a 73  |r load:ora #8:js|
00000740  72 20 73 61 76 65 3a 74  61 79 3a 6c 64 78 20 23  |r save:tay:ldx #|
00000750  75 70 0d 01 13 5e 20 6a  73 72 20 77 72 69 74 65  |up...^ jsr write|
00000760  3a 6a 73 72 20 6c 6f 61  64 3a 64 65 78 3a 62 6e  |:jsr load:dex:bn|
00000770  65 20 6c 6f 6f 70 3a 6a  73 72 20 73 61 76 65 3a  |e loop:jsr save:|
00000780  6c 64 79 20 23 26 33 31  3a 6c 64 78 20 23 75 70  |ldy #&31:ldx #up|
00000790  3a 6a 73 72 20 77 72 69  74 65 3a 6a 73 72 20 6c  |:jsr write:jsr l|
000007a0  6f 61 64 3a 73 74 79 20  61 76 61 72 3a 72 74 73  |oad:sty avar:rts|
000007b0  0d 01 18 18 20 2e 45 31  3a 6c 64 78 20 23 31 3a  |.... .E1:ldx #1:|
000007c0  6a 6d 70 20 74 65 73 74  0d 01 1d 18 20 2e 45 32  |jmp test.... .E2|
000007d0  3a 6c 64 78 20 23 32 3a  6a 6d 70 20 74 65 73 74  |:ldx #2:jmp test|
000007e0  0d 01 22 18 20 2e 45 33  3a 6c 64 78 20 23 34 3a  |..". .E3:ldx #4:|
000007f0  6a 6d 70 20 74 65 73 74  0d 01 27 18 20 2e 45 34  |jmp test..'. .E4|
00000800  3a 6c 64 78 20 23 38 3a  6a 6d 70 20 74 65 73 74  |:ldx #8:jmp test|
00000810  0d 01 2c 19 20 2e 45 35  3a 6c 64 78 20 23 31 36  |..,. .E5:ldx #16|
00000820  3a 6a 6d 70 20 74 65 73  74 0d 01 31 19 20 2e 45  |:jmp test..1. .E|
00000830  36 3a 6c 64 78 20 23 33  32 3a 6a 6d 70 20 74 65  |6:ldx #32:jmp te|
00000840  73 74 0d 01 36 19 20 2e  45 37 3a 6c 64 78 20 23  |st..6. .E7:ldx #|
00000850  36 34 3a 6a 6d 70 20 74  65 73 74 0d 01 3b 11 20  |64:jmp test..;. |
00000860  2e 45 38 3a 6c 64 78 20  23 31 32 38 0d 01 40 86  |.E8:ldx #128..@.|
00000870  20 2e 74 65 73 74 3a 73  74 78 20 6d 61 73 6b 3a  | .test:stx mask:|
00000880  6c 64 61 20 23 26 33 32  3a 6a 73 72 20 73 61 76  |lda #&32:jsr sav|
00000890  65 3a 6c 64 79 20 61 73  61 76 65 3a 6c 64 78 20  |e:ldy asave:ldx |
000008a0  23 75 70 3a 6a 73 72 20  77 72 69 74 65 3a 6a 73  |#up:jsr write:js|
000008b0  72 20 6c 6f 61 64 3a 6f  72 61 20 23 38 3a 6a 73  |r load:ora #8:js|
000008c0  72 20 73 61 76 65 3a 6c  64 79 20 61 73 61 76 65  |r save:ldy asave|
000008d0  3a 6c 64 78 20 23 75 70  3a 6a 73 72 20 77 72 69  |:ldx #up:jsr wri|
000008e0  74 65 3a 6a 73 72 20 6c  6f 61 64 3a 6c 64 78 20  |te:jsr load:ldx |
000008f0  23 38 0d 01 45 5a 20 2e  6c 6f 6f 70 32 3a 61 73  |#8..EZ .loop2:as|
00000900  6c 20 41 3a 6a 73 72 20  73 61 76 65 3a 6c 64 78  |l A:jsr save:ldx|
00000910  20 23 75 70 3a 6a 73 72  20 72 65 61 64 3a 74 79  | #up:jsr read:ty|
00000920  61 3a 61 6e 64 20 23 26  38 30 3a 62 65 71 20 6e  |a:and #&80:beq n|
00000930  75 6c 32 3a 6a 73 72 20  6c 6f 61 64 3a 6f 72 61  |ul2:jsr load:ora|
00000940  20 23 31 3a 6a 6d 70 20  6e 75 6c 33 0d 01 4a 13  | #1:jmp nul3..J.|
00000950  20 2e 6e 75 6c 32 3a 6a  73 72 20 6c 6f 61 64 0d  | .nul2:jsr load.|
00000960  01 4f 84 20 2e 6e 75 6c  33 3a 6a 73 72 20 73 61  |.O. .nul3:jsr sa|
00000970  76 65 3a 6c 64 79 20 23  26 33 30 3a 6c 64 78 20  |ve:ldy #&30:ldx |
00000980  23 75 70 3a 6a 73 72 20  77 72 69 74 65 3a 6a 73  |#up:jsr write:js|
00000990  72 20 6c 6f 61 64 3a 6c  64 79 20 23 26 33 38 3a  |r load:ldy #&38:|
000009a0  6c 64 78 20 23 75 70 3a  6a 73 72 20 77 72 69 74  |ldx #up:jsr writ|
000009b0  65 3a 6a 73 72 20 6c 6f  61 64 3a 64 65 78 3a 62  |e:jsr load:dex:b|
000009c0  6e 65 20 6c 6f 6f 70 32  3a 61 6e 64 20 6d 61 73  |ne loop2:and mas|
000009d0  6b 3a 62 65 71 20 62 61  63 6b 31 3a 6c 64 61 20  |k:beq back1:lda |
000009e0  23 31 20 0d 01 54 0b 20  2e 62 61 63 6b 31 0d 01  |#1 ..T. .back1..|
000009f0  59 08 20 72 74 73 0d 01  5e 1a 20 2e 45 58 3a 6c  |Y. rts..^. .EX:l|
00000a00  64 78 20 23 26 41 30 3a  6a 6d 70 20 70 6f 74 69  |dx #&A0:jmp poti|
00000a10  0d 01 63 11 20 2e 45 59  3a 6c 64 78 20 23 26 39  |..c. .EY:ldx #&9|
00000a20  30 0d 01 68 75 20 2e 70  6f 74 69 3a 73 65 69 3a  |0..hu .poti:sei:|
00000a30  6a 73 72 20 73 61 76 65  3a 6c 64 79 20 23 26 32  |jsr save:ldy #&2|
00000a40  30 3a 6c 64 78 20 23 74  69 63 3a 6a 73 72 20 77  |0:ldx #tic:jsr w|
00000a50  72 69 74 65 3a 6c 64 79  20 23 26 46 46 3a 6c 64  |rite:ldy #&FF:ld|
00000a60  78 20 23 74 69 6c 3a 6a  73 72 20 77 72 69 74 65  |x #til:jsr write|
00000a70  3a 6c 64 79 20 23 26 46  46 3a 6c 64 78 20 23 74  |:ldy #&FF:ldx #t|
00000a80  69 68 3a 6a 73 72 20 77  72 69 74 65 3a 6c 64 79  |ih:jsr write:ldy|
00000a90  20 78 73 61 76 65 0d 01  6d 3a 20 6c 64 78 20 23  | xsave..m: ldx #|
00000aa0  75 70 3a 6a 73 72 20 77  72 69 74 65 3a 6c 64 79  |up:jsr write:ldy|
00000ab0  20 23 26 33 38 3a 6c 64  78 20 23 75 70 3a 6a 73  | #&38:ldx #up:js|
00000ac0  72 20 77 72 69 74 65 3a  6a 73 72 20 6c 6f 61 64  |r write:jsr load|
00000ad0  0d 01 72 44 20 2e 74 73  74 3a 6a 73 72 20 73 61  |..rD .tst:jsr sa|
00000ae0  76 65 3a 6c 64 78 20 23  74 69 6c 3a 6a 73 72 20  |ve:ldx #til:jsr |
00000af0  72 65 61 64 3a 73 74 79  20 79 73 61 76 65 3a 6a  |read:sty ysave:j|
00000b00  73 72 20 6c 6f 61 64 3a  74 79 61 3a 6c 64 78 20  |sr load:tya:ldx |
00000b10  23 32 30 30 0d 01 77 aa  20 2e 64 65 6c 61 79 3a  |#200..w. .delay:|
00000b20  64 65 78 3a 62 6e 65 20  64 65 6c 61 79 3a 6a 73  |dex:bne delay:js|
00000b30  72 20 73 61 76 65 3a 6c  64 78 20 23 74 69 6c 3a  |r save:ldx #til:|
00000b40  6a 73 72 20 72 65 61 64  3a 73 74 79 20 79 73 61  |jsr read:sty ysa|
00000b50  76 65 3a 6a 73 72 20 6c  6f 61 64 3a 73 65 63 3a  |ve:jsr load:sec:|
00000b60  73 62 63 20 79 73 61 76  65 3a 62 6e 65 20 74 73  |sbc ysave:bne ts|
00000b70  74 3a 6a 73 72 20 73 61  76 65 3a 6c 64 78 20 23  |t:jsr save:ldx #|
00000b80  74 69 6c 3a 6a 73 72 20  72 65 61 64 3a 73 74 79  |til:jsr read:sty|
00000b90  20 79 73 61 76 65 3a 6a  73 72 20 6c 6f 61 64 3a  | ysave:jsr load:|
00000ba0  73 65 63 3a 6c 64 61 20  23 26 46 46 3a 73 62 63  |sec:lda #&FF:sbc|
00000bb0  20 79 73 61 76 65 3a 63  6c 69 3a 72 74 73 0d 01  | ysave:cli:rts..|
00000bc0  7c 26 20 2e 77 72 69 74  65 3a 6c 64 61 20 23 26  ||& .write:lda #&|
00000bd0  39 37 3a 6a 73 72 20 26  46 46 46 34 3a 63 6c 63  |97:jsr &FFF4:clc|
00000be0  3a 72 74 73 0d 01 81 25  20 2e 72 65 61 64 3a 6c  |:rts...% .read:l|
00000bf0  64 61 20 23 26 39 36 3a  6a 73 72 20 26 46 46 46  |da #&96:jsr &FFF|
00000c00  34 3a 63 6c 63 3a 72 74  73 0d 01 86 2d 20 2e 73  |4:clc:rts...- .s|
00000c10  61 76 65 3a 73 74 61 20  61 73 61 76 65 3a 73 74  |ave:sta asave:st|
00000c20  78 20 78 73 61 76 65 3a  73 74 79 20 79 73 61 76  |x xsave:sty ysav|
00000c30  65 3a 72 74 73 20 0d 01  8b 2c 20 2e 6c 6f 61 64  |e:rts ..., .load|
00000c40  3a 6c 64 61 20 61 73 61  76 65 3a 6c 64 78 20 78  |:lda asave:ldx x|
00000c50  73 61 76 65 3a 6c 64 79  20 79 73 61 76 65 3a 72  |save:ldy ysave:r|
00000c60  74 73 0d 01 90 05 5d 0d  01 95 08 20 ed 20 5a 0d  |ts....].... . Z.|
00000c70  01 9a 10 20 e9 20 4d 31  3d 69 6e 69 74 2b 34 0d  |... . M1=init+4.|
00000c80  01 9f 10 20 e9 20 4d 32  3d 69 6e 69 74 2b 38 0d  |... . M2=init+8.|
00000c90  01 a4 11 20 e9 20 4d 33  3d 69 6e 69 74 2b 31 32  |... . M3=init+12|
00000ca0  0d 01 a9 11 20 e9 20 4d  34 3d 69 6e 69 74 2b 31  |.... . M4=init+1|
00000cb0  36 0d 01 ae 10 20 e9 20  49 4e 49 54 3d 69 6e 69  |6.... . INIT=ini|
00000cc0  74 0d 01 b3 0d 20 e9 20  43 57 25 3d 38 35 0d 01  |t.... . CW%=85..|
00000cd0  b8 0f 20 e9 20 43 43 57  25 3d 31 37 30 0d 01 bd  |.. . CCW%=170...|
00000ce0  0d 20 e9 20 47 4f 25 3d  38 35 0d 01 c2 10 20 e9  |. . GO%=85.... .|
00000cf0  20 48 41 4c 54 25 3d 32  35 35 0d 01 c7 20 20 f4  | HALT%=255...  .|
00000d00  20 2a 20 2a 20 2a 20 45  4e 44 20 4f 46 20 44 52  | * * * END OF DR|
00000d10  49 56 45 52 20 2a 20 2a  20 2a 0d 01 cc 1b 20 dd  |IVER * * *.... .|
00000d20  20 a4 55 53 52 28 41 29  3d ba 28 41 29 20 80 20  | .USR(A)=.(A) . |
00000d30  26 46 46 20 20 0d 01 d6  22 20 dd f2 65 71 75 62  |&FF  ..." ..equb|
00000d40  28 6e 75 6d 29 3a 3f 50  25 3d 6e 75 6d 3a 50 25  |(num):?P%=num:P%|
00000d50  3d 50 25 2b 31 3a e1 0d  01 e0 2c 20 dd f2 65 71  |=P%+1:...., ..eq|
00000d60  75 73 28 74 65 78 74 24  29 3a 24 50 25 3d 74 65  |us(text$):$P%=te|
00000d70  78 74 24 3a 50 25 3d 50  25 2b a9 20 74 65 78 74  |xt$:P%=P%+. text|
00000d80  24 3a e1 0d 01 f4 0b 20  d6 20 49 4e 49 54 0d 02  |$:..... . INIT..|
00000d90  58 07 20 f4 20 0d 02 62  1f 20 f4 20 46 49 53 43  |X. . ..b. . FISC|
00000da0  48 45 52 54 45 43 48 4e  49 4b 20 43 4f 4d 50 55  |HERTECHNIK COMPU|
00000db0  54 49 4e 47 0d 02 6c 07  20 f4 20 0d 02 76 15 20  |TING..l. . ..v. |
00000dc0  f4 20 54 4f 57 45 52 20  4f 46 20 48 41 4e 4f 49  |. TOWER OF HANOI|
00000dd0  0d 02 80 07 20 f4 20 0d  02 8a 19 20 f4 20 43 4f  |.... . .... . CO|
00000de0  50 59 52 49 47 48 54 20  28 43 29 20 31 39 38 34  |PYRIGHT (C) 1984|
00000df0  0d 02 94 21 20 f4 20 42  59 20 41 52 54 55 52 20  |...! . BY ARTUR |
00000e00  46 49 53 43 48 45 52 20  46 4f 52 53 43 48 55 4e  |FISCHER FORSCHUN|
00000e10  47 0d 02 9e 07 20 f4 20  0d 02 b2 24 20 f4 20 41  |G.... . ...$ . A|
00000e20  53 53 49 47 4e 4d 45 4e  54 53 20 46 4f 52 20 54  |SSIGNMENTS FOR T|
00000e30  48 45 20 49 4e 54 45 52  46 41 43 45 0d 02 bc 06  |HE INTERFACE....|
00000e40  20 f4 0d 02 c6 0c 20 f4  20 49 4e 50 55 54 0d 02  | ..... . INPUT..|
00000e50  d0 10 20 f4 20 45 31 3d  42 4f 54 54 4f 4d 0d 02  |.. . E1=BOTTOM..|
00000e60  da 0d 20 f4 20 45 32 3d  54 4f 50 0d 02 e4 1f 20  |.. . E2=TOP.... |
00000e70  f4 20 45 59 3d 50 4f 53  49 54 49 4f 4e 20 4f 46  |. EY=POSITION OF|
00000e80  20 54 48 45 20 41 4e 47  4c 45 0d 02 ee 07 20 f4  | THE ANGLE.... .|
00000e90  20 0d 02 f8 0d 20 f4 20  4f 55 54 50 55 54 0d 03  | .... . OUTPUT..|
00000ea0  02 0e 20 f4 20 4d 31 3d  42 4f 44 59 0d 03 0c 0d  |.. . M1=BODY....|
00000eb0  20 f4 20 4d 32 3d 41 52  4d 0d 03 16 10 20 f4 20  | . M2=ARM.... . |
00000ec0  4d 33 3d 4d 41 47 4e 45  54 0d 03 20 07 20 f4 20  |M3=MAGNET.. . . |
00000ed0  0d 03 2a 1d 20 f4 20 46  55 4e 43 54 49 4f 4e 20  |..*. . FUNCTION |
00000ee0  44 45 53 43 52 49 50 54  49 4f 4e 20 3a 0d 03 34  |DESCRIPTION :..4|
00000ef0  20 20 f4 20 53 4f 52 54  49 4e 47 20 54 48 45 20  |  . SORTING THE |
00000f00  50 49 4c 45 20 4f 46 20  44 49 53 43 53 0d 03 3e  |PILE OF DISCS..>|
00000f10  3f 20 f4 20 46 4f 4c 4c  4f 57 49 4e 47 20 54 48  |? . FOLLOWING TH|
00000f20  45 20 50 55 5a 5a 4c 45  20 4f 52 49 47 49 4e 41  |E PUZZLE ORIGINA|
00000f30  54 49 4e 47 20 46 52 4f  4d 20 42 55 44 44 48 49  |TING FROM BUDDHI|
00000f40  53 54 20 54 52 41 44 49  54 49 4f 4e 0d 03 48 07  |ST TRADITION..H.|
00000f50  20 f4 20 0d 03 52 07 20  f4 20 0d 03 e8 20 20 de  | . ..R. . ...  .|
00000f60  20 58 28 33 31 29 2c 59  28 33 31 29 2c 5a 28 33  | X(31),Y(31),Z(3|
00000f70  31 29 2c 50 49 4c 45 28  33 29 0d 03 f2 2a 20 f4  |1),PILE(3)...* .|
00000f80  20 50 4f 53 49 54 4f 4e  20 4f 46 20 50 49 4c 45  | POSITON OF PILE|
00000f90  53 20 28 41 52 42 49 54  52 41 52 59 20 56 41 4c  |S (ARBITRARY VAL|
00000fa0  55 45 53 29 0d 03 fc 0d  20 f2 73 65 74 70 69 6c  |UES).... .setpil|
00000fb0  65 0d 05 dc 07 20 eb 36  0d 05 e6 19 20 f1 20 22  |e.... .6.... . "|
00000fc0  46 49 53 43 48 45 52 54  45 43 48 4e 49 4b 22 20  |FISCHERTECHNIK" |
00000fd0  20 0d 05 f0 15 20 f1 20  22 43 4f 4d 50 55 54 49  | .... . "COMPUTI|
00000fe0  4e 47 22 20 20 20 0d 05  fa 06 20 f1 0d 06 04 17  |NG"   .... .....|
00000ff0  20 f1 20 22 54 4f 57 45  52 20 4f 46 20 48 41 4e  | . "TOWER OF HAN|
00001000  4f 49 22 0d 06 0e 06 20  f1 0d 06 40 2e 20 e8 20  |OI".... ...@. . |
00001010  22 48 4f 57 20 4d 41 4e  59 20 44 49 53 43 53 20  |"HOW MANY DISCS |
00001020  44 4f 45 53 20 54 48 45  20 54 4f 57 45 52 20 48  |DOES THE TOWER H|
00001030  41 56 45 20 22 2c 4e 0d  06 4a 0e 20 e7 20 4e 3c  |AVE ",N..J. . N<|
00001040  31 20 8c 20 e0 0d 06 54  0a 20 e9 20 4d 3d 30 0d  |1 . ...T. . M=0.|
00001050  06 5e 1f 20 e9 20 58 28  4d 29 3d 4e 3a e9 20 59  |.^. . X(M)=N:. Y|
00001060  28 4d 29 3d 31 3a e9 20  5a 28 4d 29 3d 33 0d 06  |(M)=1:. Z(M)=3..|
00001070  68 0b 20 e4 20 8d 74 64  46 0d 06 72 06 20 e0 0d  |h. . .tdF..r. ..|
00001080  06 9a 1e 20 f4 20 50 53  45 55 44 4f 52 45 43 55  |... . PSEUDORECU|
00001090  52 53 49 56 45 20 52 4f  55 54 49 4e 45 0d 06 a4  |RSIVE ROUTINE...|
000010a0  11 20 e7 20 58 28 4d 29  3d 30 20 8c 20 f8 0d 06  |. . X(M)=0 . ...|
000010b0  ae 0c 20 e9 20 4d 3d 4d  2b 31 0d 06 b8 14 20 e9  |.. . M=M+1.... .|
000010c0  20 58 28 4d 29 3d 58 28  4d 2d 31 29 2d 31 0d 06  | X(M)=X(M-1)-1..|
000010d0  c2 12 20 e9 20 59 28 4d  29 3d 59 28 4d 2d 31 29  |.. . Y(M)=Y(M-1)|
000010e0  0d 06 cc 1b 20 e9 20 5a  28 4d 29 3d 36 2d 59 28  |.... . Z(M)=6-Y(|
000010f0  4d 2d 31 29 2d 5a 28 4d  2d 31 29 0d 06 d6 0b 20  |M-1)-Z(M-1).... |
00001100  e4 20 8d 74 64 46 0d 06  e0 0c 20 e9 20 4d 3d 4d  |. .tdF.... . M=M|
00001110  2d 31 0d 06 ea 38 20 f1  20 22 44 49 53 43 20 22  |-1...8 . "DISC "|
00001120  3b 58 28 4d 29 3b 22 46  52 4f 4d 20 50 49 4c 45  |;X(M);"FROM PILE|
00001130  20 22 3b 59 28 4d 29 3b  22 20 54 4f 20 50 49 4c  | ";Y(M);" TO PIL|
00001140  45 20 22 3b 5a 28 4d 29  20 20 0d 06 f4 1b 20 e4  |E ";Z(M)  .... .|
00001150  20 8d 64 50 47 3a f4 20  52 4f 42 4f 54 20 52 4f  | .dPG:. ROBOT RO|
00001160  55 54 49 4e 45 0d 06 fe  0c 20 e9 20 4d 3d 4d 2b  |UTINE.... . M=M+|
00001170  31 0d 07 08 14 20 e9 20  58 28 4d 29 3d 58 28 4d  |1.... . X(M)=X(M|
00001180  2d 31 29 2d 31 0d 07 12  1b 20 e9 20 59 28 4d 29  |-1)-1.... . Y(M)|
00001190  3d 36 2d 59 28 4d 2d 31  29 2d 5a 28 4d 2d 31 29  |=6-Y(M-1)-Z(M-1)|
000011a0  0d 07 1c 12 20 e9 20 5a  28 4d 29 3d 5a 28 4d 2d  |.... . Z(M)=Z(M-|
000011b0  31 29 0d 07 26 0b 20 e4  20 8d 74 64 46 0d 07 30  |1)..&. . .tdF..0|
000011c0  0c 20 e9 20 4d 3d 4d 2d  31 0d 07 3a 06 20 f8 0d  |. . M=M-1..:. ..|
000011d0  07 d0 14 20 f4 20 52 4f  42 4f 54 20 52 4f 55 54  |... . ROBOT ROUT|
000011e0  49 4e 45 0d 07 da 15 20  e9 20 41 49 4d 3d 50 49  |INE.... . AIM=PI|
000011f0  4c 45 28 59 28 4d 29 29  0d 07 e4 17 20 e4 20 8d  |LE(Y(M)).... . .|
00001200  74 58 48 3a f4 20 54 55  52 4e 20 42 4f 44 59 0d  |tXH:. TURN BODY.|
00001210  07 ee 17 20 e4 20 8d 54  46 49 3a f4 20 4c 4f 57  |... . .TFI:. LOW|
00001220  45 52 20 41 52 4d 0d 07  f8 20 20 d6 20 4d 31 2c  |ER ARM...  . M1,|
00001230  47 4f 25 3a f4 20 53 57  49 54 43 48 20 4d 41 47  |GO%:. SWITCH MAG|
00001240  4e 45 54 20 4f 4e 0d 08  02 16 20 e4 20 8d 54 6e  |NET ON.... . .Tn|
00001250  49 3a f4 20 4c 49 46 54  20 41 52 4d 0d 08 0c 15  |I:. LIFT ARM....|
00001260  20 e9 20 41 49 4d 3d 50  49 4c 45 28 5a 28 4d 29  | . AIM=PILE(Z(M)|
00001270  29 0d 08 16 17 20 e4 20  8d 74 58 48 3a f4 20 54  |).... . .tXH:. T|
00001280  55 52 4e 20 42 4f 44 59  0d 08 20 17 20 e4 20 8d  |URN BODY.. . . .|
00001290  54 46 49 3a f4 20 4c 4f  57 45 52 20 41 52 4d 0d  |TFI:. LOWER ARM.|
000012a0  08 2a 18 20 e4 20 8d 44  48 48 3a f4 20 4d 41 47  |.*. . .DHH:. MAG|
000012b0  4e 45 54 20 4f 46 46 0d  08 34 16 20 e4 20 8d 54  |NET OFF..4. . .T|
000012c0  6e 49 3a f4 20 4c 49 46  54 20 41 52 4d 0d 08 3e  |nI:. LIFT ARM..>|
000012d0  06 20 f8 0d 08 48 19 20  f4 20 4d 41 47 4e 45 54  |. ...H. . MAGNET|
000012e0  2d 4f 46 46 20 52 4f 55  54 49 4e 45 0d 08 52 3b  |-OFF ROUTINE..R;|
000012f0  20 d6 20 4d 31 2c 43 43  57 25 3a f4 20 52 45 56  | . M1,CCW%:. REV|
00001300  45 52 53 45 20 4d 41 47  4e 45 54 20 43 55 52 52  |ERSE MAGNET CURR|
00001310  45 4e 54 20 46 4f 52 20  44 45 4d 41 47 45 54 49  |ENT FOR DEMAGETI|
00001320  5a 41 54 49 4f 4e 20 0d  08 5c 1d 20 d6 20 4d 31  |ZATION ..\. . M1|
00001330  2c 48 41 4c 54 25 3a f4  20 4d 41 47 4e 45 54 20  |,HALT%:. MAGNET |
00001340  4f 46 46 20 0d 08 66 06  20 f8 0d 08 98 21 20 f4  |OFF ..f. ....! .|
00001350  20 50 4f 53 49 54 49 4f  4e 41 4c 20 43 4f 4e 54  | POSITIONAL CONT|
00001360  52 4f 4c 20 52 4f 55 54  49 4e 45 0d 08 a2 16 20  |ROL ROUTINE.... |
00001370  e9 20 44 3d a4 55 53 52  28 45 59 29 2d 41 49 4d  |. D=.USR(EY)-AIM|
00001380  20 0d 08 ac 17 20 e7 20  44 3e 30 20 8c 20 d6 20  | .... . D>0 . . |
00001390  4d 33 2c 43 57 25 20 20  0d 08 b6 17 20 e7 20 44  |M3,CW%  .... . D|
000013a0  3c 30 20 8c 20 d6 20 4d  33 2c 43 43 57 25 20 0d  |<0 . . M3,CCW% .|
000013b0  08 c0 0e 20 e7 20 44 3d  30 20 8c 20 f8 0d 08 ca  |... . D=0 . ....|
000013c0  0d 20 e9 20 44 3d 94 28  44 29 0d 08 d4 13 20 e7  |. . D=.(D).... .|
000013d0  20 44 3e 35 20 8c 20 e5  20 8d 74 62 48 0d 08 de  | D>5 . . .tbH...|
000013e0  0e 20 e3 20 49 3d 30 20  b8 20 44 0d 08 e8 08 20  |. . I=0 . D.... |
000013f0  ed 20 49 0d 08 f2 10 20  d6 20 4d 33 2c 48 41 4c  |. I.... . M3,HAL|
00001400  54 25 20 0d 08 fc 0b 20  e5 20 8d 74 62 48 0d 09  |T% .... . .tbH..|
00001410  06 1b 20 d6 20 4d 32 2c  43 43 57 25 3a f4 20 4c  |.. . M2,CCW%:. L|
00001420  4f 57 45 52 20 41 52 4d  20 0d 09 10 1b 20 e7 20  |OWER ARM .... . |
00001430  a4 55 53 52 28 45 31 29  3d 30 20 8c 20 e5 20 8d  |.USR(E1)=0 . . .|
00001440  54 46 49 20 0d 09 1a 0f  20 d6 20 4d 32 2c 48 41  |TFI .... . M2,HA|
00001450  4c 54 25 0d 09 24 06 20  f8 0d 09 2e 1a 20 d6 20  |LT%..$. ..... . |
00001460  4d 32 2c 43 57 25 3a f4  20 4c 49 46 54 20 41 52  |M2,CW%:. LIFT AR|
00001470  4d 20 20 0d 09 38 1b 20  e7 20 a4 55 53 52 28 45  |M  ..8. . .USR(E|
00001480  32 29 3d 30 20 8c 20 e5  20 8d 54 78 49 20 0d 09  |2)=0 . . .TxI ..|
00001490  42 0f 20 d6 20 4d 32 2c  48 41 4c 54 25 0d 09 4c  |B. . M2,HALT%..L|
000014a0  06 20 f8 0d 09 56 14 20  dd 20 f2 73 65 74 70 69  |. ...V. . .setpi|
000014b0  6c 65 3a 4f 4b 3d a3 0d  09 5b 13 20 e3 20 6e 3d  |le:OK=...[. . n=|
000014c0  31 20 b8 20 33 3a 4f 4b  3d a3 0d 09 60 06 20 f5  |1 . 3:OK=...`. .|
000014d0  0d 09 6a 21 20 e7 20 a4  55 53 52 28 45 34 29 3d  |..j! . .USR(E4)=|
000014e0  31 20 8c 20 d6 20 4d 33  2c 43 57 25 3a 4f 4b 3d  |1 . . M3,CW%:OK=|
000014f0  b9 0d 09 74 22 20 e7 20  a4 55 53 52 28 45 35 29  |...t" . .USR(E5)|
00001500  3d 31 20 8c 20 d6 20 4d  33 2c 43 43 57 25 3a 4f  |=1 . . M3,CCW%:O|
00001510  4b 3d b9 0d 09 7e 0a 20  fd 20 4f 4b 20 0d 09 88  |K=...~. . OK ...|
00001520  13 20 f5 3a fd 20 a4 55  53 52 28 45 33 29 3d 31  |. .:. .USR(E3)=1|
00001530  0d 09 92 0f 20 d6 20 4d  33 2c 48 41 4c 54 25 0d  |.... . M3,HALT%.|
00001540  09 9c 15 20 50 49 4c 45  28 6e 29 3d a4 55 53 52  |... PILE(n)=.USR|
00001550  28 45 59 29 0d 09 a6 0b  20 ed 20 6e 3a e1 20 0d  |(EY).... . n:. .|
00001560  ff                                                |.|
00001561
TOWER.m0
TOWER.m1
TOWER.m2
TOWER.m4
TOWER.m5