Home » Personal collection » Acorn DFS disks » dfs_box04_disk09_rgs_robotics_1.scp » SOLAR
SOLAR
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: | SOLAR |
Read OK: | ✔ |
File size: | 1E87 bytes |
Load address: | FF1900 |
Exec address: | FF8023 |
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 510 REM 520 REM FISCHERTECHNIK COMPUTING 530 REM 540 REM SOLAR CELL TRACKING 550 REM 560 REM COPYRIGHT (C) 1984 570 REM BY ARTUR FISCHER TORSCHUNG 580 REM 620 REM ASSIGNMENTS FOR THE INTERFACE 630 REM 640 REM INPUT 650 REM E3=MANUAL CONTROL UP/RIGHT 660 REM E4=MANUAL CONTROL DOWN/LEFT 670 REM E5=MOTOR-SELECT 680 REM E6=ACCEPT KEY 690 REM EX=ELEVATION 700 REM EY=AZIMUTH 710 REM 720 REM OUTPUT 730 REM M1=AZIMUTHAL DRIVE MOTOR 740 REM M2=ELEVATION DRIVE MOTOR 750 REM FUNKTION 760 REM THE FOLLOWING PROGRAM CALCULATES THE POSITION OF THE SUN AND CONTROLS THE SOLAR CELL TRACKING 770 REM INPUT PARAMETERS ARE: 780 REM THE YEAR,THE DAY IN THE YEAR,STARTING WITH 1 ON JANUARY 1ST WITH THE EXCEPTION OF LEAP_YEARS, 790 REM WHERE COUNTING STARTS WITH 0. 800 REM HOUR,MINUTES AND SECONDS OF YOUR LOCAL TIME ZONE 810 REM THE TIME ZONE RELATIVE TO GREENWICH UNIVERSAL TIME.COUNTING IS POSITIVE TO THE WEST AND NEGATIVE TO THE EAST. 820 REM THE LOCAL LATITUDE(POSITIVE TO NORTH) 830 REM THE LOCAL LONGITUDE WEST OF GREENWICH 840 REM THE FORMULAE ARE TAKEN FROM: 850 REM R.WALRAVEN IN SOLAR ENERGY,VOL.20(1978),P.393_397 920 REM CONSTANTS 2*PI AND PI/180 930 TWOPI=2*PI:RD=PI/180 950 LET AL=20:REM MIN.VALUE OF EY 960 LET AR=200:REM MAX.VALUE OF EY 970 LET EM=20:REM MIN.VALUE OF EX 980 LET ER=200:REM MAX.VALUE OF EX 990 LET EA=EM 1000 LET AA=AL 1030 LET GA=5:REM BRAKE PERIOD FOR AZIMUTH MOTOR 1040 MODE6 1050 PRINT "FISCHERTECHNIK" 1060 PRINT "COMPUTING" 1070 PRINT 1080 PRINT " SOLAR CELL TRACKING" 1090 PRINT 1100 INPUT "YEAR : ",YEAR 1110 INPUT "DAY OF YEAR : ",DAY 1130 INPUT "TIME ZONE",TZ 1140 INPUT "DEGREE OF LATITUDE",LAT 1150 INPUT "DEGREE OF LONGITUDE",LONG 1160 REM CALIBRATION 1170 PRINT "PLEASE CALIBRATE SOLAR CELL" 1180 LET A$="MOVE SOLAR CELL EXACTLY" 1190 PRINT A$;" EAST" 1200 PRINT "FACING THE HORIZON" 1210 GOSUB 2000 1220 LET Y0=Y 1230 LET E0=X 1240 PRINT A$;" WEST" 1250 PRINT "FACING STRAIGHT UPWARDS" 1260 GOSUB 2000 1270 LET A0=(Y+Y0)/2 1280 LET FA=(Y0-Y)/180 1290 LET FE=(X-E0)/90 1300 PRINT "INPUT TIME" 1310 INPUT "HOUR :",H$ 1320 INPUT "MINUTE : ",M$ 1330 INPUT "SECOND : ",S$ 1340 TI=((VAL(H$)*60+VAL(M$))*60+VAL(S$))*100 1345 TIME=TI :REM SET REAL TIME CLOCK 1380 LET ZR=0 1390 IF TI=0 THEN LET ZR=1 1450 LET DF=YEAR-1980 1460 LET LEAPYEAR=INT(DF/4) 1470 LET HOUR=VAL(H$) 1480 LET MIN=VAL(M$) 1490 LET SK=VAL(S$) 1500 LET TTIM=HOUR+(MIN+SK/60)/60+TZ 1510 LET TIM=DF*365+LEAPYEAR+DAY-1+TTIM/24 1520 IF DF=4*LEAPYEAR THEN LET TIM=TIM-1 1530 IF (DF<0) AND (DF<>4*LEAPYEAR) THEN LET TIM=TIM-1 1540 LET THETA=(TWOPI*TIM/365.25) 1550 LET G=-0.031271-(4.53963E-7)*TIM+THETA 1560 LET EL=4.900968+(3.67474E-7)*TIM 1570 LET EL=EL+(0.033434-(2.3E-9)*TIM)*SIN(G) 1580 LET EL=EL+(3.49E-4)*SIN(2*G)+THETA 1590 REM LENGTH OF THE SUN 1600 LET SEL=SIN(EL) 1610 LET EPS=0.40914-(6.2149E-9)*TIM 1620 REM ECLIPTIC APPROX. 23.5 DEGREES 1630 LET RA=ATN(SEL*COS(EPS)/COS(EL)) 1640 IF RA<0 THEN LET RA=RA+TWOPI/2 1650 LET DEKL=ASN(SEL*SIN(EPS)) 1660 REM DECLINATION 1670 LET SID=1.759335+TWOPI*(TIM/365.25-DF)+(3.694E-7)*TIM 1680 IF SID>=TWOPI THEN LET SID=SID-TWOPI 1690 REM SIDEREAL TIME 1700 LET S=SID+(TTIM*15-LONG)*RD 1710 IF S>=TWOPI THEN LET S=S-TWOPI 1720 REM LOCAL SUN-TIME 1730 LET H=RA-S 1740 REM HOUR ANGLE 1750 LET PHI=LAT*RD 1760 LET E=ASN(SIN(PHI)*SIN(DEKL)+COS(PHI)*COS(DEKL)*COS(H)) 1770 LET A=ASN(COS(DEKL)*SIN(H)/COS(E))/RD 1780 IF SIN(E)>=SIN(DEKL)/SIN(PHI) THEN GOTO 1810 1790 IF A<0 THEN A=A+360 1800 LET A=180-A 1810 LET E=E/RD 1820 PRINT H$;":";M$;":";S$ 1830 PRINT "A=";A;" DEG E=";E;" DEG" 1840 GOSUB 3000:REM CONTROL ROUTINE 1850 LET MIN=MIN+10 1860 IF MIN<60 THEN GOTO 1890 1870 LET MIN=0 1880 LET HOUR=HOUR+1 1890 IF HOUR<24 THEN GOTO 1920 1900 LET HOUR=0 1910 LET DAY=DAY+1 1920 LET M$=STR$(MIN) 1930 LET H$=STR$(HOUR) 1940 IF ZR=1 THEN GOTO 1500 1950 LET T=((HOUR*60+MIN)*60+SK)*100 1960 IF TIME<T THEN GOTO 1960 1970 GOTO 1500 2000 REM ACCEPT CALIBRATED VALUES 2010 PRINT "IF DIRECTION IS OK" 2020 PRINT "PRESS KEY E6" 2030 M=M1 2040 IF FNUSR(E5)=1 THEN M=M2 2050 IF FNUSR(E3)=0 THEN GOTO 2080 2060 CALL M,CW%: REM UP/RIGHT 2070 GOTO 2050 2080 CALL M1,HALT% 2090 CALL M2,HALT% 2100 IF FNUSR(E4)=0 THEN GOTO 2130 2110 CALL M,CCW%: REM DOWN/LEFT 2120 GOTO 2100 2130 CALL M1,HALT% 2140 CALL M2,HALT% 2150 IF FNUSR(E6)=0 THEN GOTO 2030 2160 LET X=FNUSR(EX): REM ELEVATION 2170 LET Y=FNUSR(EY): REM AZIMUTH 2180 IF FNUSR(E6)=1 THEN GOTO 2180 2190 RETURN 3000 REM MOVEMENT ROUTINE 3005 IF E<0 THEN RETURN 3010 LET AS=INT(A*FA+A0+0.5) 3020 LET ES=INT(E*FE+E0+0.5) 3030 IF AS<AL THEN LET AS=AL 3040 IF AS>AR THEN LET AS=AR 3050 IF ES<EM THEN LET ES=EM 3060 IF ES>ER THEN LET ES=ER 3070 IF ES=EA THEN GOTO 3160 3080 REM CONTROL OF ELEVATION 3090 LET D=FNUSR(EX)-ES 3100 IF D>0 THEN CALL M2,CW% 3120 IF D<0 THEN CALL M2,CCW% 3140 IF D=0 THEN GOTO 3160 3142 FOR I=0TO5 3143 NEXT I 3145 CALL M2,HALT% 3150 GOTO 3090 3160 LET EA=ES 3170 IF AS=AA THEN GOTO 3270 3180 REM CONTROL OF AZIMUTH 3190 LET D=FNUSR(EY)-AS 3200 IF D>0 THEN CALL M1,CW% 3210 IF D<0 THEN CALL M1,CCW% 3220 IF D=0 THEN GOTO 3270 3230 LET D=ABS(D) 3240 IF D>GA THEN GOTO 3190 3250 CALL M1,HALT% 3260 GOTO 3190 3270 LET AA=AS 3280 RETURN
� 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 � � � FISCHERTECHNIK COMPUTING � � SOLAR CELL TRACKING & � 0 � COPYRIGHT (C) 1984 :! � BY ARTUR FISCHER TORSCHUNG D � l$ � ASSIGNMENTS FOR THE INTERFACE v � � � INPUT �! � E3=MANUAL CONTROL UP/RIGHT �" � E4=MANUAL CONTROL DOWN/LEFT � � E5=MOTOR-SELECT � � E6=ACCEPT KEY � � EX=ELEVATION � � EY=AZIMUTH � � � � OUTPUT � � M1=AZIMUTHAL DRIVE MOTOR � � M2=ELEVATION DRIVE MOTOR � � FUNKTION �d � THE FOLLOWING PROGRAM CALCULATES THE POSITION OF THE SUN AND CONTROLS THE SOLAR CELL TRACKING � INPUT PARAMETERS ARE: d � THE YEAR,THE DAY IN THE YEAR,STARTING WITH 1 ON JANUARY 1ST WITH THE EXCEPTION OF LEAP_YEARS, $ � WHERE COUNTING STARTS WITH 0. 7 � HOUR,MINUTES AND SECONDS OF YOUR LOCAL TIME ZONE *u � THE TIME ZONE RELATIVE TO GREENWICH UNIVERSAL TIME.COUNTING IS POSITIVE TO THE WEST AND NEGATIVE TO THE EAST. 4, � THE LOCAL LATITUDE(POSITIVE TO NORTH) >, � THE LOCAL LONGITUDE WEST OF GREENWICH H# � THE FORMULAE ARE TAKEN FROM: R8 � R.WALRAVEN IN SOLAR ENERGY,VOL.20(1978),P.393_397 � � CONSTANTS 2*PI AND PI/180 � TWOPI=2*�:RD=�/180 � � AL=20:� MIN.VALUE OF EY � � AR=200:� MAX.VALUE OF EY � � EM=20:� MIN.VALUE OF EX � � ER=200:� MAX.VALUE OF EX � � EA=EM � � AA=AL , � GA=5:� BRAKE PERIOD FOR AZIMUTH MOTOR �6 � "FISCHERTECHNIK" $ � "COMPUTING" . � 8 � " SOLAR CELL TRACKING" B � L � "YEAR : ",YEAR V � "DAY OF YEAR : ",DAY j � "TIME ZONE",TZ t � "DEGREE OF LATITUDE",LAT ~! � "DEGREE OF LONGITUDE",LONG � � CALIBRATION �$ � "PLEASE CALIBRATE SOLAR CELL" �# � A$="MOVE SOLAR CELL EXACTLY" � � A$;" EAST" � � "FACING THE HORIZON" � � �dPG � � Y0=Y � � E0=X � � A$;" WEST" � � "FACING STRAIGHT UPWARDS" � � �dPG � � A0=(Y+Y0)/2 � FA=(Y0-Y)/180 � FE=(X-E0)/90 � "INPUT TIME" � "HOUR :",H$ ( � "MINUTE : ",M$ 2 � "SECOND : ",S$ <( TI=((�(H$)*60+�(M$))*60+�(S$))*100 A �=TI :� SET REAL TIME CLOCK d � ZR=0 n � TI=0 � � ZR=1 � � DF=YEAR-1980 � � LEAPYEAR=�(DF/4) � � HOUR=�(H$) � � MIN=�(M$) � � SK=�(S$) �" � TTIM=HOUR+(MIN+SK/60)/60+TZ �( � TIM=DF*365+LEAPYEAR+DAY-1+TTIM/24 �" � DF=4*LEAPYEAR � � TIM=TIM-1 �/ � (DF<0) � (DF<>4*LEAPYEAR) � � TIM=TIM-1 � THETA=(TWOPI*TIM/365.25) ) � G=-0.031271-(4.53963E-7)*TIM+THETA # � EL=4.900968+(3.67474E-7)*TIM ") � EL=EL+(0.033434-(2.3E-9)*TIM)*�(G) ,# � EL=EL+(3.49E-4)*�(2*G)+THETA 6 � LENGTH OF THE SUN @ � SEL=�(EL) J" � EPS=0.40914-(6.2149E-9)*TIM T$ � ECLIPTIC APPROX. 23.5 DEGREES ^ � RA=�(SEL*�(EPS)/�(EL)) h � RA<0 � � RA=RA+TWOPI/2 r � DEKL=�(SEL*�(EPS)) | � DECLINATION �8 � SID=1.759335+TWOPI*(TIM/365.25-DF)+(3.694E-7)*TIM �$ � SID>=TWOPI � � SID=SID-TWOPI � � SIDEREAL TIME � � S=SID+(TTIM*15-LONG)*RD � � S>=TWOPI � � S=S-TWOPI � � LOCAL SUN-TIME � � H=RA-S � � HOUR ANGLE � � PHI=LAT*RD �. � E=�(�(PHI)*�(DEKL)+�(PHI)*�(DEKL)*�(H)) � � A=�(�(DEKL)*�(H)/�(E))/RD �$ � �(E)>=�(DEKL)/�(PHI) � � �TRG � � A<0 � A=A+360 � A=180-A � E=E/RD � H$;":";M$;":";S$ &" � "A=";A;" DEG E=";E;" DEG" 0 � �txK:� CONTROL ROUTINE : � MIN=MIN+10 D � MIN<60 � � �DbG N � MIN=0 X � HOUR=HOUR+1 b � HOUR<24 � � �t@G l � HOUR=0 v � DAY=DAY+1 � � M$=�(MIN) � � H$=�(HOUR) � � ZR=1 � � �d\E �" � T=((HOUR*60+MIN)*60+SK)*100 � � �<T � � �thG � � �d\E � � ACCEPT CALIBRATED VALUES � � "IF DIRECTION IS OK" � � "PRESS KEY E6" � M=M1 � � �USR(E5)=1 � M=M2 � �USR(E3)=0 � � �T`H � M,CW%: � UP/RIGHT � �TBH � M1,HALT% * � M2,HALT% 4 � �USR(E4)=0 � � �DRH > � M,CCW%: � DOWN/LEFT H � �TtH R � M1,HALT% \ � M2,HALT% f � �USR(E6)=0 � � �dnG p � X=�USR(EX): � ELEVATION z! � Y=�USR(EY): � AZIMUTH � � �USR(E6)=1 � � �tDH � � � � MOVEMENT ROUTINE � � E<0 � � � � AS=�(A*FA+A0+0.5) � � ES=�(E*FE+E0+0.5) � � AS<AL � � AS=AL � � AS>AR � � AS=AR � � ES<EM � � ES=EM � � ES>ER � � ES=ER � � ES=EA � � �DXL � CONTROL OF ELEVATION � D=�USR(EX)-ES � D>0 � � M2,CW% 0 � D<0 � � M2,CCW% D � D=0 � � �DXL F � I=0�5 G � I I � M2,HALT% N � �TRL X � EA=ES b � AS=AA � � �dFL l � CONTROL OF AZIMUTH v � D=�USR(EY)-AS � � D>0 � � M1,CW% � � D<0 � � M1,CCW% � � D=0 � � �dFL � � D=�(D) � � D>GA � � �DvL � � M1,HALT% � � �DvL � � AA=AS � � �
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 01 |$:..... . INIT..| 00000d90 fe 06 20 f4 0d 02 08 1f 20 f4 20 46 49 53 43 48 |.. ..... . FISCH| 00000da0 45 52 54 45 43 48 4e 49 4b 20 43 4f 4d 50 55 54 |ERTECHNIK COMPUT| 00000db0 49 4e 47 0d 02 12 07 20 f4 20 0d 02 1c 1a 20 f4 |ING.... . .... .| 00000dc0 20 53 4f 4c 41 52 20 43 45 4c 4c 20 54 52 41 43 | SOLAR CELL TRAC| 00000dd0 4b 49 4e 47 0d 02 26 07 20 f4 20 0d 02 30 19 20 |KING..&. . ..0. | 00000de0 f4 20 43 4f 50 59 52 49 47 48 54 20 28 43 29 20 |. COPYRIGHT (C) | 00000df0 31 39 38 34 0d 02 3a 21 20 f4 20 42 59 20 41 52 |1984..:! . BY AR| 00000e00 54 55 52 20 46 49 53 43 48 45 52 20 54 4f 52 53 |TUR FISCHER TORS| 00000e10 43 48 55 4e 47 0d 02 44 07 20 f4 20 0d 02 6c 24 |CHUNG..D. . ..l$| 00000e20 20 f4 20 41 53 53 49 47 4e 4d 45 4e 54 53 20 46 | . ASSIGNMENTS F| 00000e30 4f 52 20 54 48 45 20 49 4e 54 45 52 46 41 43 45 |OR THE INTERFACE| 00000e40 0d 02 76 07 20 f4 20 0d 02 80 0c 20 f4 20 49 4e |..v. . .... . IN| 00000e50 50 55 54 0d 02 8a 21 20 f4 20 45 33 3d 4d 41 4e |PUT...! . E3=MAN| 00000e60 55 41 4c 20 43 4f 4e 54 52 4f 4c 20 55 50 2f 52 |UAL CONTROL UP/R| 00000e70 49 47 48 54 0d 02 94 22 20 f4 20 45 34 3d 4d 41 |IGHT..." . E4=MA| 00000e80 4e 55 41 4c 20 43 4f 4e 54 52 4f 4c 20 44 4f 57 |NUAL CONTROL DOW| 00000e90 4e 2f 4c 45 46 54 0d 02 9e 16 20 f4 20 45 35 3d |N/LEFT.... . E5=| 00000ea0 4d 4f 54 4f 52 2d 53 45 4c 45 43 54 0d 02 a8 14 |MOTOR-SELECT....| 00000eb0 20 f4 20 45 36 3d 41 43 43 45 50 54 20 4b 45 59 | . E6=ACCEPT KEY| 00000ec0 0d 02 b2 13 20 f4 20 45 58 3d 45 4c 45 56 41 54 |.... . EX=ELEVAT| 00000ed0 49 4f 4e 0d 02 bc 11 20 f4 20 45 59 3d 41 5a 49 |ION.... . EY=AZI| 00000ee0 4d 55 54 48 0d 02 c6 07 20 f4 20 0d 02 d0 0d 20 |MUTH.... . .... | 00000ef0 f4 20 4f 55 54 50 55 54 0d 02 da 1f 20 f4 20 4d |. OUTPUT.... . M| 00000f00 31 3d 41 5a 49 4d 55 54 48 41 4c 20 44 52 49 56 |1=AZIMUTHAL DRIV| 00000f10 45 20 4d 4f 54 4f 52 0d 02 e4 1f 20 f4 20 4d 32 |E MOTOR.... . M2| 00000f20 3d 45 4c 45 56 41 54 49 4f 4e 20 44 52 49 56 45 |=ELEVATION DRIVE| 00000f30 20 4d 4f 54 4f 52 0d 02 ee 0f 20 f4 20 46 55 4e | MOTOR.... . FUN| 00000f40 4b 54 49 4f 4e 0d 02 f8 64 20 f4 20 54 48 45 20 |KTION...d . THE | 00000f50 46 4f 4c 4c 4f 57 49 4e 47 20 50 52 4f 47 52 41 |FOLLOWING PROGRA| 00000f60 4d 20 43 41 4c 43 55 4c 41 54 45 53 20 54 48 45 |M CALCULATES THE| 00000f70 20 50 4f 53 49 54 49 4f 4e 20 4f 46 20 54 48 45 | POSITION OF THE| 00000f80 20 53 55 4e 20 41 4e 44 20 43 4f 4e 54 52 4f 4c | SUN AND CONTROL| 00000f90 53 20 54 48 45 20 53 4f 4c 41 52 20 43 45 4c 4c |S THE SOLAR CELL| 00000fa0 20 54 52 41 43 4b 49 4e 47 0d 03 02 1c 20 f4 20 | TRACKING.... . | 00000fb0 49 4e 50 55 54 20 50 41 52 41 4d 45 54 45 52 53 |INPUT PARAMETERS| 00000fc0 20 41 52 45 3a 0d 03 0c 64 20 f4 20 54 48 45 20 | ARE:...d . THE | 00000fd0 59 45 41 52 2c 54 48 45 20 44 41 59 20 49 4e 20 |YEAR,THE DAY IN | 00000fe0 54 48 45 20 59 45 41 52 2c 53 54 41 52 54 49 4e |THE YEAR,STARTIN| 00000ff0 47 20 57 49 54 48 20 31 20 4f 4e 20 4a 41 4e 55 |G WITH 1 ON JANU| 00001000 41 52 59 20 31 53 54 20 57 49 54 48 20 54 48 45 |ARY 1ST WITH THE| 00001010 20 45 58 43 45 50 54 49 4f 4e 20 4f 46 20 4c 45 | EXCEPTION OF LE| 00001020 41 50 5f 59 45 41 52 53 2c 0d 03 16 24 20 f4 20 |AP_YEARS,...$ . | 00001030 57 48 45 52 45 20 43 4f 55 4e 54 49 4e 47 20 53 |WHERE COUNTING S| 00001040 54 41 52 54 53 20 57 49 54 48 20 30 2e 0d 03 20 |TARTS WITH 0... | 00001050 37 20 f4 20 48 4f 55 52 2c 4d 49 4e 55 54 45 53 |7 . HOUR,MINUTES| 00001060 20 41 4e 44 20 53 45 43 4f 4e 44 53 20 4f 46 20 | AND SECONDS OF | 00001070 59 4f 55 52 20 4c 4f 43 41 4c 20 54 49 4d 45 20 |YOUR LOCAL TIME | 00001080 5a 4f 4e 45 0d 03 2a 75 20 f4 20 54 48 45 20 54 |ZONE..*u . THE T| 00001090 49 4d 45 20 5a 4f 4e 45 20 52 45 4c 41 54 49 56 |IME ZONE RELATIV| 000010a0 45 20 54 4f 20 47 52 45 45 4e 57 49 43 48 20 55 |E TO GREENWICH U| 000010b0 4e 49 56 45 52 53 41 4c 20 54 49 4d 45 2e 43 4f |NIVERSAL TIME.CO| 000010c0 55 4e 54 49 4e 47 20 49 53 20 50 4f 53 49 54 49 |UNTING IS POSITI| 000010d0 56 45 20 54 4f 20 54 48 45 20 57 45 53 54 20 41 |VE TO THE WEST A| 000010e0 4e 44 20 4e 45 47 41 54 49 56 45 20 20 54 4f 20 |ND NEGATIVE TO | 000010f0 54 48 45 20 45 41 53 54 2e 0d 03 34 2c 20 f4 20 |THE EAST...4, . | 00001100 54 48 45 20 4c 4f 43 41 4c 20 4c 41 54 49 54 55 |THE LOCAL LATITU| 00001110 44 45 28 50 4f 53 49 54 49 56 45 20 54 4f 20 4e |DE(POSITIVE TO N| 00001120 4f 52 54 48 29 0d 03 3e 2c 20 f4 20 54 48 45 20 |ORTH)..>, . THE | 00001130 4c 4f 43 41 4c 20 4c 4f 4e 47 49 54 55 44 45 20 |LOCAL LONGITUDE | 00001140 57 45 53 54 20 4f 46 20 47 52 45 45 4e 57 49 43 |WEST OF GREENWIC| 00001150 48 0d 03 48 23 20 f4 20 54 48 45 20 46 4f 52 4d |H..H# . THE FORM| 00001160 55 4c 41 45 20 41 52 45 20 54 41 4b 45 4e 20 46 |ULAE ARE TAKEN F| 00001170 52 4f 4d 3a 0d 03 52 38 20 f4 20 52 2e 57 41 4c |ROM:..R8 . R.WAL| 00001180 52 41 56 45 4e 20 49 4e 20 53 4f 4c 41 52 20 45 |RAVEN IN SOLAR E| 00001190 4e 45 52 47 59 2c 56 4f 4c 2e 32 30 28 31 39 37 |NERGY,VOL.20(197| 000011a0 38 29 2c 50 2e 33 39 33 5f 33 39 37 0d 03 98 20 |8),P.393_397... | 000011b0 20 f4 20 43 4f 4e 53 54 41 4e 54 53 20 32 2a 50 | . CONSTANTS 2*P| 000011c0 49 20 41 4e 44 20 50 49 2f 31 38 30 0d 03 a2 17 |I AND PI/180....| 000011d0 20 54 57 4f 50 49 3d 32 2a af 3a 52 44 3d af 2f | TWOPI=2*.:RD=./| 000011e0 31 38 30 0d 03 b6 1e 20 e9 20 41 4c 3d 32 30 3a |180.... . AL=20:| 000011f0 f4 20 4d 49 4e 2e 56 41 4c 55 45 20 4f 46 20 45 |. MIN.VALUE OF E| 00001200 59 0d 03 c0 1f 20 e9 20 41 52 3d 32 30 30 3a f4 |Y.... . AR=200:.| 00001210 20 4d 41 58 2e 56 41 4c 55 45 20 4f 46 20 45 59 | MAX.VALUE OF EY| 00001220 0d 03 ca 1e 20 e9 20 45 4d 3d 32 30 3a f4 20 4d |.... . EM=20:. M| 00001230 49 4e 2e 56 41 4c 55 45 20 4f 46 20 45 58 0d 03 |IN.VALUE OF EX..| 00001240 d4 1f 20 e9 20 45 52 3d 32 30 30 3a f4 20 4d 41 |.. . ER=200:. MA| 00001250 58 2e 56 41 4c 55 45 20 4f 46 20 45 58 0d 03 de |X.VALUE OF EX...| 00001260 0c 20 e9 20 45 41 3d 45 4d 0d 03 e8 0c 20 e9 20 |. . EA=EM.... . | 00001270 41 41 3d 41 4c 0d 04 06 2c 20 e9 20 47 41 3d 35 |AA=AL..., . GA=5| 00001280 3a f4 20 42 52 41 4b 45 20 50 45 52 49 4f 44 20 |:. BRAKE PERIOD | 00001290 46 4f 52 20 41 5a 49 4d 55 54 48 20 4d 4f 54 4f |FOR AZIMUTH MOTO| 000012a0 52 0d 04 10 07 20 eb 36 0d 04 1a 17 20 f1 20 22 |R.... .6.... . "| 000012b0 46 49 53 43 48 45 52 54 45 43 48 4e 49 4b 22 0d |FISCHERTECHNIK".| 000012c0 04 24 14 20 f1 20 22 43 4f 4d 50 55 54 49 4e 47 |.$. . "COMPUTING| 000012d0 22 20 20 0d 04 2e 06 20 f1 0d 04 38 1d 20 f1 20 |" .... ...8. . | 000012e0 22 20 53 4f 4c 41 52 20 43 45 4c 4c 20 54 52 41 |" SOLAR CELL TRA| 000012f0 43 4b 49 4e 47 22 0d 04 42 06 20 f1 0d 04 4c 15 |CKING"..B. ...L.| 00001300 20 e8 20 22 59 45 41 52 20 3a 20 22 2c 59 45 41 | . "YEAR : ",YEA| 00001310 52 0d 04 56 1b 20 e8 20 22 44 41 59 20 4f 46 20 |R..V. . "DAY OF | 00001320 59 45 41 52 20 3a 20 22 2c 44 41 59 0d 04 6a 15 |YEAR : ",DAY..j.| 00001330 20 e8 20 22 54 49 4d 45 20 5a 4f 4e 45 22 2c 54 | . "TIME ZONE",T| 00001340 5a 0d 04 74 1f 20 e8 20 22 44 45 47 52 45 45 20 |Z..t. . "DEGREE | 00001350 4f 46 20 4c 41 54 49 54 55 44 45 22 2c 4c 41 54 |OF LATITUDE",LAT| 00001360 0d 04 7e 21 20 e8 20 22 44 45 47 52 45 45 20 4f |..~! . "DEGREE O| 00001370 46 20 4c 4f 4e 47 49 54 55 44 45 22 2c 4c 4f 4e |F LONGITUDE",LON| 00001380 47 0d 04 88 12 20 f4 20 43 41 4c 49 42 52 41 54 |G.... . CALIBRAT| 00001390 49 4f 4e 0d 04 92 24 20 f1 20 22 50 4c 45 41 53 |ION...$ . "PLEAS| 000013a0 45 20 43 41 4c 49 42 52 41 54 45 20 53 4f 4c 41 |E CALIBRATE SOLA| 000013b0 52 20 43 45 4c 4c 22 0d 04 9c 23 20 e9 20 41 24 |R CELL"...# . A$| 000013c0 3d 22 4d 4f 56 45 20 53 4f 4c 41 52 20 43 45 4c |="MOVE SOLAR CEL| 000013d0 4c 20 45 58 41 43 54 4c 59 22 0d 04 a6 11 20 f1 |L EXACTLY".... .| 000013e0 20 41 24 3b 22 20 45 41 53 54 22 0d 04 b0 1c 20 | A$;" EAST".... | 000013f0 f1 20 22 46 41 43 49 4e 47 20 54 48 45 20 48 4f |. "FACING THE HO| 00001400 52 49 5a 4f 4e 22 20 0d 04 ba 0b 20 e4 20 8d 64 |RIZON" .... . .d| 00001410 50 47 0d 04 c4 0b 20 e9 20 59 30 3d 59 0d 04 ce |PG.... . Y0=Y...| 00001420 0b 20 e9 20 45 30 3d 58 0d 04 d8 11 20 f1 20 41 |. . E0=X.... . A| 00001430 24 3b 22 20 57 45 53 54 22 0d 04 e2 20 20 f1 20 |$;" WEST"... . | 00001440 22 46 41 43 49 4e 47 20 53 54 52 41 49 47 48 54 |"FACING STRAIGHT| 00001450 20 55 50 57 41 52 44 53 22 0d 04 ec 0b 20 e4 20 | UPWARDS".... . | 00001460 8d 64 50 47 0d 04 f6 12 20 e9 20 41 30 3d 28 59 |.dPG.... . A0=(Y| 00001470 2b 59 30 29 2f 32 0d 05 00 14 20 e9 20 46 41 3d |+Y0)/2.... . FA=| 00001480 28 59 30 2d 59 29 2f 31 38 30 0d 05 0a 14 20 e9 |(Y0-Y)/180.... .| 00001490 20 46 45 3d 28 58 2d 45 30 29 2f 39 30 20 0d 05 | FE=(X-E0)/90 ..| 000014a0 14 13 20 f1 20 22 49 4e 50 55 54 20 54 49 4d 45 |.. . "INPUT TIME| 000014b0 22 0d 05 1e 12 20 e8 20 22 48 4f 55 52 20 3a 22 |".... . "HOUR :"| 000014c0 2c 48 24 0d 05 28 15 20 e8 20 22 4d 49 4e 55 54 |,H$..(. . "MINUT| 000014d0 45 20 3a 20 22 2c 4d 24 0d 05 32 15 20 e8 20 22 |E : ",M$..2. . "| 000014e0 53 45 43 4f 4e 44 20 3a 20 22 2c 53 24 0d 05 3c |SECOND : ",S$..<| 000014f0 28 20 54 49 3d 28 28 bb 28 48 24 29 2a 36 30 2b |( TI=((.(H$)*60+| 00001500 bb 28 4d 24 29 29 2a 36 30 2b bb 28 53 24 29 29 |.(M$))*60+.(S$))| 00001510 2a 31 30 30 20 0d 05 41 20 20 d1 3d 54 49 20 3a |*100 ..A .=TI :| 00001520 f4 20 53 45 54 20 52 45 41 4c 20 54 49 4d 45 20 |. SET REAL TIME | 00001530 43 4c 4f 43 4b 0d 05 64 0b 20 e9 20 5a 52 3d 30 |CLOCK..d. . ZR=0| 00001540 0d 05 6e 14 20 e7 20 54 49 3d 30 20 8c 20 e9 20 |..n. . TI=0 . . | 00001550 5a 52 3d 31 0d 05 aa 13 20 e9 20 44 46 3d 59 45 |ZR=1.... . DF=YE| 00001560 41 52 2d 31 39 38 30 0d 05 b4 17 20 e9 20 4c 45 |AR-1980.... . LE| 00001570 41 50 59 45 41 52 3d a8 28 44 46 2f 34 29 0d 05 |APYEAR=.(DF/4)..| 00001580 be 11 20 e9 20 48 4f 55 52 3d bb 28 48 24 29 0d |.. . HOUR=.(H$).| 00001590 05 c8 10 20 e9 20 4d 49 4e 3d bb 28 4d 24 29 0d |... . MIN=.(M$).| 000015a0 05 d2 11 20 e9 20 53 4b 3d bb 28 53 24 29 20 20 |... . SK=.(S$) | 000015b0 0d 05 dc 22 20 e9 20 54 54 49 4d 3d 48 4f 55 52 |..." . TTIM=HOUR| 000015c0 2b 28 4d 49 4e 2b 53 4b 2f 36 30 29 2f 36 30 2b |+(MIN+SK/60)/60+| 000015d0 54 5a 0d 05 e6 28 20 e9 20 54 49 4d 3d 44 46 2a |TZ...( . TIM=DF*| 000015e0 33 36 35 2b 4c 45 41 50 59 45 41 52 2b 44 41 59 |365+LEAPYEAR+DAY| 000015f0 2d 31 2b 54 54 49 4d 2f 32 34 0d 05 f0 22 20 e7 |-1+TTIM/24..." .| 00001600 20 44 46 3d 34 2a 4c 45 41 50 59 45 41 52 20 8c | DF=4*LEAPYEAR .| 00001610 20 e9 20 54 49 4d 3d 54 49 4d 2d 31 0d 05 fa 2f | . TIM=TIM-1.../| 00001620 20 20 e7 20 28 44 46 3c 30 29 20 80 20 28 44 46 | . (DF<0) . (DF| 00001630 3c 3e 34 2a 4c 45 41 50 59 45 41 52 29 20 8c 20 |<>4*LEAPYEAR) . | 00001640 e9 20 54 49 4d 3d 54 49 4d 2d 31 0d 06 04 1f 20 |. TIM=TIM-1.... | 00001650 e9 20 54 48 45 54 41 3d 28 54 57 4f 50 49 2a 54 |. THETA=(TWOPI*T| 00001660 49 4d 2f 33 36 35 2e 32 35 29 0d 06 0e 29 20 e9 |IM/365.25)...) .| 00001670 20 47 3d 2d 30 2e 30 33 31 32 37 31 2d 28 34 2e | G=-0.031271-(4.| 00001680 35 33 39 36 33 45 2d 37 29 2a 54 49 4d 2b 54 48 |53963E-7)*TIM+TH| 00001690 45 54 41 0d 06 18 23 20 e9 20 45 4c 3d 34 2e 39 |ETA...# . EL=4.9| 000016a0 30 30 39 36 38 2b 28 33 2e 36 37 34 37 34 45 2d |00968+(3.67474E-| 000016b0 37 29 2a 54 49 4d 0d 06 22 29 20 e9 20 45 4c 3d |7)*TIM..") . EL=| 000016c0 45 4c 2b 28 30 2e 30 33 33 34 33 34 2d 28 32 2e |EL+(0.033434-(2.| 000016d0 33 45 2d 39 29 2a 54 49 4d 29 2a b5 28 47 29 0d |3E-9)*TIM)*.(G).| 000016e0 06 2c 23 20 e9 20 45 4c 3d 45 4c 2b 28 33 2e 34 |.,# . EL=EL+(3.4| 000016f0 39 45 2d 34 29 2a b5 28 32 2a 47 29 2b 54 48 45 |9E-4)*.(2*G)+THE| 00001700 54 41 0d 06 36 18 20 f4 20 4c 45 4e 47 54 48 20 |TA..6. . LENGTH | 00001710 4f 46 20 54 48 45 20 53 55 4e 0d 06 40 10 20 e9 |OF THE SUN..@. .| 00001720 20 53 45 4c 3d b5 28 45 4c 29 0d 06 4a 22 20 e9 | SEL=.(EL)..J" .| 00001730 20 45 50 53 3d 30 2e 34 30 39 31 34 2d 28 36 2e | EPS=0.40914-(6.| 00001740 32 31 34 39 45 2d 39 29 2a 54 49 4d 0d 06 54 24 |2149E-9)*TIM..T$| 00001750 20 f4 20 45 43 4c 49 50 54 49 43 20 41 50 50 52 | . ECLIPTIC APPR| 00001760 4f 58 2e 20 32 33 2e 35 20 44 45 47 52 45 45 53 |OX. 23.5 DEGREES| 00001770 0d 06 5e 1d 20 e9 20 52 41 3d 99 28 53 45 4c 2a |..^. . RA=.(SEL*| 00001780 9b 28 45 50 53 29 2f 9b 28 45 4c 29 29 0d 06 68 |.(EPS)/.(EL))..h| 00001790 1d 20 e7 20 52 41 3c 30 20 8c 20 e9 20 52 41 3d |. . RA<0 . . RA=| 000017a0 52 41 2b 54 57 4f 50 49 2f 32 0d 06 72 19 20 e9 |RA+TWOPI/2..r. .| 000017b0 20 44 45 4b 4c 3d 98 28 53 45 4c 2a b5 28 45 50 | DEKL=.(SEL*.(EP| 000017c0 53 29 29 0d 06 7c 13 20 f4 20 44 45 43 4c 49 4e |S))..|. . DECLIN| 000017d0 41 54 49 4f 4e 20 0d 06 86 38 20 e9 20 53 49 44 |ATION ...8 . SID| 000017e0 3d 31 2e 37 35 39 33 33 35 2b 54 57 4f 50 49 2a |=1.759335+TWOPI*| 000017f0 28 54 49 4d 2f 33 36 35 2e 32 35 2d 44 46 29 2b |(TIM/365.25-DF)+| 00001800 28 33 2e 36 39 34 45 2d 37 29 2a 54 49 4d 0d 06 |(3.694E-7)*TIM..| 00001810 90 24 20 e7 20 53 49 44 3e 3d 54 57 4f 50 49 20 |.$ . SID>=TWOPI | 00001820 8c 20 e9 20 53 49 44 3d 53 49 44 2d 54 57 4f 50 |. . SID=SID-TWOP| 00001830 49 20 0d 06 9a 14 20 f4 20 53 49 44 45 52 45 41 |I .... . SIDEREA| 00001840 4c 20 54 49 4d 45 0d 06 a4 1e 20 e9 20 53 3d 53 |L TIME.... . S=S| 00001850 49 44 2b 28 54 54 49 4d 2a 31 35 2d 4c 4f 4e 47 |ID+(TTIM*15-LONG| 00001860 29 2a 52 44 0d 06 ae 1d 20 e7 20 53 3e 3d 54 57 |)*RD.... . S>=TW| 00001870 4f 50 49 20 8c 20 e9 20 53 3d 53 2d 54 57 4f 50 |OPI . . S=S-TWOP| 00001880 49 0d 06 b8 15 20 f4 20 4c 4f 43 41 4c 20 53 55 |I.... . LOCAL SU| 00001890 4e 2d 54 49 4d 45 0d 06 c2 0d 20 e9 20 48 3d 52 |N-TIME.... . H=R| 000018a0 41 2d 53 0d 06 cc 11 20 f4 20 48 4f 55 52 20 41 |A-S.... . HOUR A| 000018b0 4e 47 4c 45 0d 06 d6 11 20 e9 20 50 48 49 3d 4c |NGLE.... . PHI=L| 000018c0 41 54 2a 52 44 0d 06 e0 2e 20 e9 20 45 3d 98 28 |AT*RD.... . E=.(| 000018d0 b5 28 50 48 49 29 2a b5 28 44 45 4b 4c 29 2b 9b |.(PHI)*.(DEKL)+.| 000018e0 28 50 48 49 29 2a 9b 28 44 45 4b 4c 29 2a 9b 28 |(PHI)*.(DEKL)*.(| 000018f0 48 29 29 0d 06 ea 20 20 e9 20 41 3d 98 28 9b 28 |H))... . A=.(.(| 00001900 44 45 4b 4c 29 2a b5 28 48 29 2f 9b 28 45 29 29 |DEKL)*.(H)/.(E))| 00001910 2f 52 44 0d 06 f4 24 20 e7 20 b5 28 45 29 3e 3d |/RD...$ . .(E)>=| 00001920 b5 28 44 45 4b 4c 29 2f b5 28 50 48 49 29 20 8c |.(DEKL)/.(PHI) .| 00001930 20 e5 20 8d 54 52 47 0d 06 fe 14 20 e7 20 41 3c | . .TRG.... . A<| 00001940 30 20 8c 20 41 3d 41 2b 33 36 30 0d 07 08 0e 20 |0 . A=A+360.... | 00001950 e9 20 41 3d 31 38 30 2d 41 0d 07 12 0d 20 e9 20 |. A=180-A.... . | 00001960 45 3d 45 2f 52 44 0d 07 1c 17 20 f1 20 48 24 3b |E=E/RD.... . H$;| 00001970 22 3a 22 3b 4d 24 3b 22 3a 22 3b 53 24 0d 07 26 |":";M$;":";S$..&| 00001980 22 20 f1 20 22 41 3d 22 3b 41 3b 22 20 44 45 47 |" . "A=";A;" DEG| 00001990 20 20 20 45 3d 22 3b 45 3b 22 20 44 45 47 22 0d | E=";E;" DEG".| 000019a0 07 30 1d 20 e4 20 8d 74 78 4b 3a f4 20 43 4f 4e |.0. . .txK:. CON| 000019b0 54 52 4f 4c 20 52 4f 55 54 49 4e 45 0d 07 3a 11 |TROL ROUTINE..:.| 000019c0 20 e9 20 4d 49 4e 3d 4d 49 4e 2b 31 30 0d 07 44 | . MIN=MIN+10..D| 000019d0 16 20 e7 20 4d 49 4e 3c 36 30 20 8c 20 e5 20 8d |. . MIN<60 . . .| 000019e0 44 62 47 0d 07 4e 0c 20 e9 20 4d 49 4e 3d 30 0d |DbG..N. . MIN=0.| 000019f0 07 58 12 20 e9 20 48 4f 55 52 3d 48 4f 55 52 2b |.X. . HOUR=HOUR+| 00001a00 31 0d 07 62 17 20 e7 20 48 4f 55 52 3c 32 34 20 |1..b. . HOUR<24 | 00001a10 8c 20 e5 20 8d 74 40 47 0d 07 6c 0d 20 e9 20 48 |. . .t@G..l. . H| 00001a20 4f 55 52 3d 30 0d 07 76 10 20 e9 20 44 41 59 3d |OUR=0..v. . DAY=| 00001a30 44 41 59 2b 31 0d 07 80 10 20 e9 20 4d 24 3d c3 |DAY+1.... . M$=.| 00001a40 28 4d 49 4e 29 0d 07 8a 11 20 e9 20 48 24 3d c3 |(MIN).... . H$=.| 00001a50 28 48 4f 55 52 29 0d 07 94 14 20 e7 20 5a 52 3d |(HOUR).... . ZR=| 00001a60 31 20 8c 20 e5 20 8d 64 5c 45 0d 07 9e 22 20 e9 |1 . . .d\E..." .| 00001a70 20 54 3d 28 28 48 4f 55 52 2a 36 30 2b 4d 49 4e | T=((HOUR*60+MIN| 00001a80 29 2a 36 30 2b 53 4b 29 2a 31 30 30 0d 07 a8 13 |)*60+SK)*100....| 00001a90 20 e7 20 91 3c 54 20 8c 20 e5 20 8d 74 68 47 0d | . .<T . . .thG.| 00001aa0 07 b2 0b 20 e5 20 8d 64 5c 45 0d 07 d0 1f 20 f4 |... . .d\E.... .| 00001ab0 20 41 43 43 45 50 54 20 43 41 4c 49 42 52 41 54 | ACCEPT CALIBRAT| 00001ac0 45 44 20 56 41 4c 55 45 53 0d 07 da 1b 20 f1 20 |ED VALUES.... . | 00001ad0 22 49 46 20 44 49 52 45 43 54 49 4f 4e 20 49 53 |"IF DIRECTION IS| 00001ae0 20 4f 4b 22 0d 07 e4 15 20 f1 20 22 50 52 45 53 | OK".... . "PRES| 00001af0 53 20 4b 45 59 20 45 36 22 0d 07 ee 09 20 4d 3d |S KEY E6".... M=| 00001b00 4d 31 0d 07 f8 18 20 e7 20 a4 55 53 52 28 45 35 |M1.... . .USR(E5| 00001b10 29 3d 31 20 8c 20 4d 3d 4d 32 0d 08 02 1a 20 e7 |)=1 . M=M2.... .| 00001b20 20 a4 55 53 52 28 45 33 29 3d 30 20 8c 20 e5 20 | .USR(E3)=0 . . | 00001b30 8d 54 60 48 0d 08 0c 18 20 d6 20 4d 2c 43 57 25 |.T`H.... . M,CW%| 00001b40 3a 20 f4 20 55 50 2f 52 49 47 48 54 0d 08 16 0b |: . UP/RIGHT....| 00001b50 20 e5 20 8d 54 42 48 0d 08 20 0f 20 d6 20 4d 31 | . .TBH.. . . M1| 00001b60 2c 48 41 4c 54 25 0d 08 2a 0f 20 d6 20 4d 32 2c |,HALT%..*. . M2,| 00001b70 48 41 4c 54 25 0d 08 34 1a 20 e7 20 a4 55 53 52 |HALT%..4. . .USR| 00001b80 28 45 34 29 3d 30 20 8c 20 e5 20 8d 44 52 48 0d |(E4)=0 . . .DRH.| 00001b90 08 3e 1a 20 d6 20 4d 2c 43 43 57 25 3a 20 f4 20 |.>. . M,CCW%: . | 00001ba0 44 4f 57 4e 2f 4c 45 46 54 0d 08 48 0b 20 e5 20 |DOWN/LEFT..H. . | 00001bb0 8d 54 74 48 0d 08 52 0f 20 d6 20 4d 31 2c 48 41 |.TtH..R. . M1,HA| 00001bc0 4c 54 25 0d 08 5c 0f 20 d6 20 4d 32 2c 48 41 4c |LT%..\. . M2,HAL| 00001bd0 54 25 0d 08 66 1b 20 e7 20 a4 55 53 52 28 45 36 |T%..f. . .USR(E6| 00001be0 29 3d 30 20 8c 20 e5 20 8d 64 6e 47 20 0d 08 70 |)=0 . . .dnG ..p| 00001bf0 1e 20 e9 20 58 3d a4 55 53 52 28 45 58 29 3a 20 |. . X=.USR(EX): | 00001c00 f4 20 45 4c 45 56 41 54 49 4f 4e 0d 08 7a 21 20 |. ELEVATION..z! | 00001c10 e9 20 59 3d a4 55 53 52 28 45 59 29 3a 20 f4 20 |. Y=.USR(EY): . | 00001c20 41 5a 49 4d 55 54 48 20 20 20 20 20 0d 08 84 1a |AZIMUTH ....| 00001c30 20 e7 20 a4 55 53 52 28 45 36 29 3d 31 20 8c 20 | . .USR(E6)=1 . | 00001c40 e5 20 8d 74 44 48 0d 08 8e 06 20 f8 0d 0b b8 17 |. .tDH.... .....| 00001c50 20 f4 20 4d 4f 56 45 4d 45 4e 54 20 52 4f 55 54 | . MOVEMENT ROUT| 00001c60 49 4e 45 0d 0b bd 0e 20 e7 20 45 3c 30 20 8c 20 |INE.... . E<0 . | 00001c70 f8 0d 0b c2 19 20 e9 20 41 53 3d a8 28 41 2a 46 |..... . AS=.(A*F| 00001c80 41 2b 41 30 2b 30 2e 35 29 20 0d 0b cc 18 20 e9 |A+A0+0.5) .... .| 00001c90 20 45 53 3d a8 28 45 2a 46 45 2b 45 30 2b 30 2e | ES=.(E*FE+E0+0.| 00001ca0 35 29 0d 0b d6 16 20 e7 20 41 53 3c 41 4c 20 8c |5).... . AS<AL .| 00001cb0 20 e9 20 41 53 3d 41 4c 0d 0b e0 16 20 e7 20 41 | . AS=AL.... . A| 00001cc0 53 3e 41 52 20 8c 20 e9 20 41 53 3d 41 52 0d 0b |S>AR . . AS=AR..| 00001cd0 ea 16 20 e7 20 45 53 3c 45 4d 20 8c 20 e9 20 45 |.. . ES<EM . . E| 00001ce0 53 3d 45 4d 0d 0b f4 18 20 e7 20 45 53 3e 45 52 |S=EM.... . ES>ER| 00001cf0 20 8c 20 e9 20 45 53 3d 45 52 20 20 0d 0b fe 15 | . . ES=ER ....| 00001d00 20 e7 20 45 53 3d 45 41 20 8c 20 e5 20 8d 44 58 | . ES=EA . . .DX| 00001d10 4c 0d 0c 08 1b 20 f4 20 43 4f 4e 54 52 4f 4c 20 |L.... . CONTROL | 00001d20 4f 46 20 45 4c 45 56 41 54 49 4f 4e 0d 0c 12 14 |OF ELEVATION....| 00001d30 20 e9 20 44 3d a4 55 53 52 28 45 58 29 2d 45 53 | . D=.USR(EX)-ES| 00001d40 0d 0c 1c 15 20 e7 20 44 3e 30 20 8c 20 d6 20 4d |.... . D>0 . . M| 00001d50 32 2c 43 57 25 0d 0c 30 16 20 e7 20 44 3c 30 20 |2,CW%..0. . D<0 | 00001d60 8c 20 d6 20 4d 32 2c 43 43 57 25 0d 0c 44 13 20 |. . M2,CCW%..D. | 00001d70 e7 20 44 3d 30 20 8c 20 e5 20 8d 44 58 4c 0d 0c |. D=0 . . .DXL..| 00001d80 46 0c 20 e3 20 49 3d 30 b8 35 0d 0c 47 08 20 ed |F. . I=0.5..G. .| 00001d90 20 49 0d 0c 49 0f 20 d6 20 4d 32 2c 48 41 4c 54 | I..I. . M2,HALT| 00001da0 25 0d 0c 4e 0b 20 e5 20 8d 54 52 4c 0d 0c 58 0c |%..N. . .TRL..X.| 00001db0 20 e9 20 45 41 3d 45 53 0d 0c 62 15 20 e7 20 41 | . EA=ES..b. . A| 00001dc0 53 3d 41 41 20 8c 20 e5 20 8d 64 46 4c 0d 0c 6c |S=AA . . .dFL..l| 00001dd0 19 20 f4 20 43 4f 4e 54 52 4f 4c 20 4f 46 20 41 |. . CONTROL OF A| 00001de0 5a 49 4d 55 54 48 0d 0c 76 14 20 e9 20 44 3d a4 |ZIMUTH..v. . D=.| 00001df0 55 53 52 28 45 59 29 2d 41 53 0d 0c 80 15 20 e7 |USR(EY)-AS.... .| 00001e00 20 44 3e 30 20 8c 20 d6 20 4d 31 2c 43 57 25 0d | D>0 . . M1,CW%.| 00001e10 0c 8a 16 20 e7 20 44 3c 30 20 8c 20 d6 20 4d 31 |... . D<0 . . M1| 00001e20 2c 43 43 57 25 0d 0c 94 13 20 e7 20 44 3d 30 20 |,CCW%.... . D=0 | 00001e30 8c 20 e5 20 8d 64 46 4c 0d 0c 9e 0d 20 e9 20 44 |. . .dFL.... . D| 00001e40 3d 94 28 44 29 0d 0c a8 14 20 e7 20 44 3e 47 41 |=.(D).... . D>GA| 00001e50 20 8c 20 e5 20 8d 44 76 4c 0d 0c b2 0f 20 d6 20 | . . .DvL.... . | 00001e60 4d 31 2c 48 41 4c 54 25 0d 0c bc 0b 20 e5 20 8d |M1,HALT%.... . .| 00001e70 44 76 4c 0d 0c c6 0c 20 e9 20 41 41 3d 41 53 0d |DvL.... . AA=AS.| 00001e80 0c d0 06 20 f8 0d ff |... ...| 00001e87