Home » Archimedes archive » Acorn User » AU 1996-01.adf » Regulars » StarInfo/Vlietinck/!Roto/!Runimage
StarInfo/Vlietinck/!Roto/!Runimage
This website contains an archive of files for the Acorn Electron, BBC Micro, Acorn Archimedes, Commodore 16 and Commodore 64 computers, which Dominic Ford has rescued from his private collection of floppy disks and cassettes.
Some of these files were originally commercial releases in the 1980s and 1990s, but they are now widely available online. I assume that copyright over them is no longer being asserted. If you own the copyright and would like files to be removed, please contact me.
Tape/disk: | Home » Archimedes archive » Acorn User » AU 1996-01.adf » Regulars |
Filename: | StarInfo/Vlietinck/!Roto/!Runimage |
Read OK: | ✔ |
File size: | 0B46 bytes |
Load address: | 0000 |
Exec address: | 0000 |
File contents
10REM> Roto 20REM> (C) Jan Vlietinck 30REM vlietin@intec.rug.ac.be 40 50MODE13+128:MODE 13:OFF 60ON ERROR:END 70SC=7:DM=2^SC 80DIM IMAGE DM*DM 90PROCASS 100PROCBUILDIMAGE 110PROCMAIN 120END 130 140DEF PROCMAIN 150M%=2 160REPEAT 170R%=2^(36-SC) 180ST=0.5 190H=0 200REPEAT 210H+=ST 220SYS "OS_Byte",&70,M% 230!DXD=COS(RAD(H))*R% 240!DYD=SIN(RAD(H))*R% 250R%=R%/1.02 260CALL set 270CALL scale_rotate 280SYS "OS_Byte",&71,M%:M%=M% EOR3 290UNTIL H>120 300REPEAT 310H-=4*ST 320SYS "OS_Byte",&70,M% 330!DXD=COS(RAD(H))*R% 340!DYD=SIN(RAD(H))*R% 350R%=R%*(1.02)^4 360CALL set 370CALL scale_rotate 380SYS "OS_Byte",&71,M%:M%=M% EOR3 390UNTIL H<0 400UNTIL 0 410ENDPROC 420 430DEF PROCBUILDIMAGE 440*SLOAD <Roto$Dir>.screen 450*SCHOOSE screen 460PLOT &ED,0,-8 470CALL set 480CALL get 490ENDPROC 500 510DEF PROCASS 520DIM Q% 4000 530X=0:Y=1:DX=2:DY=3:C=4:D=5:T=6:SCR=7:BMP=8:XM=9:YM=10:S=11:U=12 540W1=9:W2=10:W3=11:W4=12 550FOR PASS=0 TO 2 STEP 2 560P%=Q% 570[OPT PASS 580.SCREEND EQUD 148:EQUD -1 590.SCREEN EQUD 0 600.DXD EQUD 0 610.DYD EQUD 0 620.XD EQUD DM << (32-SC-1) 630.YD EQUD DM << (32-SC-1) 640.BMPD EQUD IMAGE 650 660.set 670ADR R0,SCREEND 680ADR R1,SCREEN 690SWI "OS_ReadVduVariables" 700MOV PC,R14 710 720.get 730LDR SCR,SCREEN 740ADD SCR,SCR,#320*256 750SUB SCR,SCR,#320 760LDR BMP,BMPD 770MOV D,#DM 780.GLOOPY 790MOV C,#DM 800.GLOOPX 810LDR T,[SCR],#4 820STR T,[BMP],#4 830SUBS C,C,#4 840BNE GLOOPX 850SUB SCR,SCR,#DM 860SUB SCR,SCR,#320 870SUBS D,D,#1 880BNE GLOOPY 890MOV PC,R14 900 910.scale_rotate 920LDR XM,XD 930LDR YM,YD 940LDR SCR,SCREEN 950LDR DX,DXD 960LDR DY,DYD 970LDR BMP,BMPD 980MOV S,#128 990MOV T,#160 1000MOV X,DX,ASR #8 1010MOV Y,DY,ASR #8 1020MUL C,Y,S 1030SUB XM,XM,C,LSL #8 1040MUL C,X,T 1050SUB XM,XM,C,LSL #8 1060MUL C,X,S 1070ADD YM,YM,C,LSL #8 1080MUL C,Y,T 1090SUB YM,YM,C,LSL #8 1100MOV D,#256 1110 1120.LOOPY 1130MOV X,XM 1140MOV Y,YM 1150ADD XM,XM,DY 1160SUB YM,YM,DX 1170STMFD 13!,{XM,YM,DX,DY} 1180 1190BIC DX,DX,#&7F 1200ORR DX,DX,DY,LSR #32-7 1210MOV DY,DY,LSL #7 1220BIC X,X,#&7F 1230ORR X,X,Y,LSR #32-7 1240MOV Y,Y,LSL #7 1250 1260MOV C,#320 1270.LOOPX 1280 1290FNmapbyte(W1) 1300FNmapbyte(T) 1310ADD W1,W1,T,LSL #8 1320FNmapbyte(T) 1330ADD W1,W1,T,LSL #16 1340FNmapbyte(T) 1350ADD W1,W1,T,LSL #24 1360 1370FNmapbyte(W2) 1380FNmapbyte(T) 1390ADD W2,W2,T,LSL #8 1400FNmapbyte(T) 1410ADD W2,W2,T,LSL #16 1420FNmapbyte(T) 1430ADD W2,W2,T,LSL #24 1440 1450FNmapbyte(W3) 1460FNmapbyte(T) 1470ADD W3,W3,T,LSL #8 1480FNmapbyte(T) 1490ADD W3,W3,T,LSL #16 1500FNmapbyte(T) 1510ADD W3,W3,T,LSL #24 1520 1530FNmapbyte(W4) 1540FNmapbyte(T) 1550ADD W4,W4,T,LSL #8 1560FNmapbyte(T) 1570ADD W4,W4,T,LSL #16 1580FNmapbyte(T) 1590ADD W4,W4,T,LSL #24 1600 1630STMIA (SCR)!,{W1,W2,W3,W4} 1640SUBS C,C,#16 1650BNE LOOPX 1660 1670LDMFD 13!,{XM,YM,DX,DY} 1680SUBS D,D,#1 1690BNE LOOPY 1700MOV PC,R14 1710] 1720NEXT 1730ENDPROC 1740 1750 1760DEF FNmapbyte(reg) 1770[OPT PASS 1780; (u, v)+=(du, dv) 1790 ADDS Y,Y,DY 1800 ADC X,X,DX 1810 MOV T,X,ROR #SC 1820; lookup colour at (int(u), int(v)) 1830 LDRB reg,[BMP,T,LSR #32-2*SC] 1840 ] 1850 ="" 1860
�> Roto �> (C) Jan Vlietinck � vlietin@intec.rug.ac.be ( 2�13+128:� 13:� < � �:� FSC=7:DM=2^SC P� IMAGE DM*DM Z�ASS d�BUILDIMAGE n �MAIN x� � �� �MAIN �M%=2 �� �R%=2^(36-SC) � ST=0.5 �H=0 �� � H+=ST �ș "OS_Byte",&70,M% �!DXD=�(�(H))*R% �!DYD=�(�(H))*R% �R%=R%/1.02 � set � scale_rotate ș "OS_Byte",&71,M%:M%=M% �3 "� H>120 ,� 6H-=4*ST @ș "OS_Byte",&70,M% J!DXD=�(�(H))*R% T!DYD=�(�(H))*R% ^R%=R%*(1.02)^4 h � set r� scale_rotate | ș "OS_Byte",&71,M%:M%=M% �3 � � H<0 �� 0 �� � �� �BUILDIMAGE �*SLOAD <Roto$Dir>.screen �*SCHOOSE screen �� &ED,0,-8 � � set � � get �� � � � �ASS � Q% 4000 BX=0:Y=1:DX=2:DY=3:C=4:D=5:T=6:SCR=7:BMP=8:XM=9:YM=10:S=11:U=12 W1=9:W2=10:W3=11:W4=12 &� PASS=0 � 2 � 2 0 P%=Q% : [OPT PASS D.SCREEND EQUD 148:EQUD -1 N.SCREEN EQUD 0 X.DXD EQUD 0 b.DYD EQUD 0 l.XD EQUD DM << (32-SC-1) v.YD EQUD DM << (32-SC-1) �.BMPD EQUD IMAGE � �.set �ADR R0,SCREEND �ADR R1,SCREEN �SWI "OS_ReadVduVariables" �MOV PC,R14 � �.get �LDR SCR,SCREEN �ADD SCR,SCR,#320*256 �SUB SCR,SCR,#320 �LDR BMP,BMPD MOV D,#DM .GLOOPY MOV C,#DM .GLOOPX *LDR T,[SCR],#4 4STR T,[BMP],#4 >SUBS C,C,#4 HBNE GLOOPX RSUB SCR,SCR,#DM \SUB SCR,SCR,#320 fSUBS D,D,#1 pBNE GLOOPY zMOV PC,R14 � �.scale_rotate � LDR XM,XD � LDR YM,YD �LDR SCR,SCREEN �LDR DX,DXD �LDR DY,DYD �LDR BMP,BMPD �MOV S,#128 �MOV T,#160 �MOV X,DX,ASR #8 �MOV Y,DY,ASR #8 � MUL C,Y,S SUB XM,XM,C,LSL #8 MUL C,X,T SUB XM,XM,C,LSL #8 $ MUL C,X,S .ADD YM,YM,C,LSL #8 8 MUL C,Y,T BSUB YM,YM,C,LSL #8 LMOV D,#256 V ` .LOOPY jMOV X,XM tMOV Y,YM ~ADD XM,XM,DY �SUB YM,YM,DX �STMFD 13!,{XM,YM,DX,DY} � �BIC DX,DX,#&7F ��R DX,DX,DY,LSR #32-7 �MOV DY,DY,LSL #7 �BIC X,X,#&7F ��R X,X,Y,LSR #32-7 �MOV Y,Y,LSL #7 � �MOV C,#320 � .LOOPX �mapbyte(W1) �mapbyte(T) ADD W1,W1,T,LSL #8 (�mapbyte(T) 2ADD W1,W1,T,LSL #16 <�mapbyte(T) FADD W1,W1,T,LSL #24 P Z�mapbyte(W2) d�mapbyte(T) nADD W2,W2,T,LSL #8 x�mapbyte(T) �ADD W2,W2,T,LSL #16 ��mapbyte(T) �ADD W2,W2,T,LSL #24 � ��mapbyte(W3) ��mapbyte(T) �ADD W3,W3,T,LSL #8 ��mapbyte(T) �ADD W3,W3,T,LSL #16 ��mapbyte(T) �ADD W3,W3,T,LSL #24 � ��mapbyte(W4) �mapbyte(T) ADD W4,W4,T,LSL #8 �mapbyte(T) "ADD W4,W4,T,LSL #16 ,�mapbyte(T) 6ADD W4,W4,T,LSL #24 @ ^STMIA (SCR)!,{W1,W2,W3,W4} hSUBS C,C,#16 r BNE LOOPX | �LDMFD 13!,{XM,YM,DX,DY} �SUBS D,D,#1 � BNE LOOPY �MOV PC,R14 �] �� �� � � �� �mapbyte(reg) � [OPT PASS �; (u, v)+=(du, dv) � ADDS Y,Y,DY ADC X,X,DX # MOV T,X,ROR #SC '; lookup colour at (int(u), int(v)) &0 LDRB reg,[BMP,T,LSR #32-2*SC] 0 ] : ="" D �
00000000 0d 00 0a 0b f4 3e 20 52 6f 74 6f 0d 00 14 18 f4 |.....> Roto.....| 00000010 3e 20 28 43 29 20 4a 61 6e 20 56 6c 69 65 74 69 |> (C) Jan Vlieti| 00000020 6e 63 6b 0d 00 1e 1d f4 20 76 6c 69 65 74 69 6e |nck..... vlietin| 00000030 40 69 6e 74 65 63 2e 72 75 67 2e 61 63 2e 62 65 |@intec.rug.ac.be| 00000040 0d 00 28 04 0d 00 32 12 eb 31 33 2b 31 32 38 3a |..(...2..13+128:| 00000050 eb 20 31 33 3a 87 0d 00 3c 09 ee 20 85 3a e0 0d |. 13:...<.. .:..| 00000060 00 46 10 53 43 3d 37 3a 44 4d 3d 32 5e 53 43 0d |.F.SC=7:DM=2^SC.| 00000070 00 50 11 de 20 49 4d 41 47 45 20 44 4d 2a 44 4d |.P.. IMAGE DM*DM| 00000080 0d 00 5a 08 f2 41 53 53 0d 00 64 0f f2 42 55 49 |..Z..ASS..d..BUI| 00000090 4c 44 49 4d 41 47 45 0d 00 6e 09 f2 4d 41 49 4e |LDIMAGE..n..MAIN| 000000a0 0d 00 78 05 e0 0d 00 82 04 0d 00 8c 0b dd 20 f2 |..x........... .| 000000b0 4d 41 49 4e 0d 00 96 08 4d 25 3d 32 0d 00 a0 05 |MAIN....M%=2....| 000000c0 f5 0d 00 aa 10 52 25 3d 32 5e 28 33 36 2d 53 43 |.....R%=2^(36-SC| 000000d0 29 0d 00 b4 0a 53 54 3d 30 2e 35 0d 00 be 07 48 |)....ST=0.5....H| 000000e0 3d 30 0d 00 c8 05 f5 0d 00 d2 09 48 2b 3d 53 54 |=0.........H+=ST| 000000f0 0d 00 dc 17 c8 99 20 22 4f 53 5f 42 79 74 65 22 |...... "OS_Byte"| 00000100 2c 26 37 30 2c 4d 25 0d 00 e6 13 21 44 58 44 3d |,&70,M%....!DXD=| 00000110 9b 28 b2 28 48 29 29 2a 52 25 0d 00 f0 13 21 44 |.(.(H))*R%....!D| 00000120 59 44 3d b5 28 b2 28 48 29 29 2a 52 25 0d 00 fa |YD=.(.(H))*R%...| 00000130 0e 52 25 3d 52 25 2f 31 2e 30 32 0d 01 04 09 d6 |.R%=R%/1.02.....| 00000140 20 73 65 74 0d 01 0e 12 d6 20 73 63 61 6c 65 5f | set..... scale_| 00000150 72 6f 74 61 74 65 0d 01 18 20 c8 99 20 22 4f 53 |rotate... .. "OS| 00000160 5f 42 79 74 65 22 2c 26 37 31 2c 4d 25 3a 4d 25 |_Byte",&71,M%:M%| 00000170 3d 4d 25 20 82 33 0d 01 22 0b fd 20 48 3e 31 32 |=M% .3..".. H>12| 00000180 30 0d 01 2c 05 f5 0d 01 36 0b 48 2d 3d 34 2a 53 |0..,....6.H-=4*S| 00000190 54 0d 01 40 17 c8 99 20 22 4f 53 5f 42 79 74 65 |T..@... "OS_Byte| 000001a0 22 2c 26 37 30 2c 4d 25 0d 01 4a 13 21 44 58 44 |",&70,M%..J.!DXD| 000001b0 3d 9b 28 b2 28 48 29 29 2a 52 25 0d 01 54 13 21 |=.(.(H))*R%..T.!| 000001c0 44 59 44 3d b5 28 b2 28 48 29 29 2a 52 25 0d 01 |DYD=.(.(H))*R%..| 000001d0 5e 12 52 25 3d 52 25 2a 28 31 2e 30 32 29 5e 34 |^.R%=R%*(1.02)^4| 000001e0 0d 01 68 09 d6 20 73 65 74 0d 01 72 12 d6 20 73 |..h.. set..r.. s| 000001f0 63 61 6c 65 5f 72 6f 74 61 74 65 0d 01 7c 20 c8 |cale_rotate..| .| 00000200 99 20 22 4f 53 5f 42 79 74 65 22 2c 26 37 31 2c |. "OS_Byte",&71,| 00000210 4d 25 3a 4d 25 3d 4d 25 20 82 33 0d 01 86 09 fd |M%:M%=M% .3.....| 00000220 20 48 3c 30 0d 01 90 07 fd 20 30 0d 01 9a 05 e1 | H<0..... 0.....| 00000230 0d 01 a4 04 0d 01 ae 11 dd 20 f2 42 55 49 4c 44 |......... .BUILD| 00000240 49 4d 41 47 45 0d 01 b8 1c 2a 53 4c 4f 41 44 20 |IMAGE....*SLOAD | 00000250 3c 52 6f 74 6f 24 44 69 72 3e 2e 73 63 72 65 65 |<Roto$Dir>.scree| 00000260 6e 0d 01 c2 13 2a 53 43 48 4f 4f 53 45 20 73 63 |n....*SCHOOSE sc| 00000270 72 65 65 6e 0d 01 cc 0e f0 20 26 45 44 2c 30 2c |reen..... &ED,0,| 00000280 2d 38 0d 01 d6 09 d6 20 73 65 74 0d 01 e0 09 d6 |-8..... set.....| 00000290 20 67 65 74 0d 01 ea 05 e1 0d 01 f4 04 0d 01 fe | get............| 000002a0 0a dd 20 f2 41 53 53 0d 02 08 0d de 20 51 25 20 |.. .ASS..... Q% | 000002b0 34 30 30 30 0d 02 12 42 58 3d 30 3a 59 3d 31 3a |4000...BX=0:Y=1:| 000002c0 44 58 3d 32 3a 44 59 3d 33 3a 43 3d 34 3a 44 3d |DX=2:DY=3:C=4:D=| 000002d0 35 3a 54 3d 36 3a 53 43 52 3d 37 3a 42 4d 50 3d |5:T=6:SCR=7:BMP=| 000002e0 38 3a 58 4d 3d 39 3a 59 4d 3d 31 30 3a 53 3d 31 |8:XM=9:YM=10:S=1| 000002f0 31 3a 55 3d 31 32 0d 02 1c 1a 57 31 3d 39 3a 57 |1:U=12....W1=9:W| 00000300 32 3d 31 30 3a 57 33 3d 31 31 3a 57 34 3d 31 32 |2=10:W3=11:W4=12| 00000310 0d 02 26 14 e3 20 50 41 53 53 3d 30 20 b8 20 32 |..&.. PASS=0 . 2| 00000320 20 88 20 32 0d 02 30 09 50 25 3d 51 25 0d 02 3a | . 2..0.P%=Q%..:| 00000330 0d 5b 4f 50 54 20 50 41 53 53 0d 02 44 1d 2e 53 |.[OPT PASS..D..S| 00000340 43 52 45 45 4e 44 20 45 51 55 44 20 31 34 38 3a |CREEND EQUD 148:| 00000350 45 51 55 44 20 2d 31 0d 02 4e 12 2e 53 43 52 45 |EQUD -1..N..SCRE| 00000360 45 4e 20 45 51 55 44 20 30 0d 02 58 0f 2e 44 58 |EN EQUD 0..X..DX| 00000370 44 20 45 51 55 44 20 30 0d 02 62 0f 2e 44 59 44 |D EQUD 0..b..DYD| 00000380 20 45 51 55 44 20 30 0d 02 6c 1d 2e 58 44 20 45 | EQUD 0..l..XD E| 00000390 51 55 44 20 20 44 4d 20 3c 3c 20 28 33 32 2d 53 |QUD DM << (32-S| 000003a0 43 2d 31 29 0d 02 76 1d 2e 59 44 20 45 51 55 44 |C-1)..v..YD EQUD| 000003b0 20 20 44 4d 20 3c 3c 20 28 33 32 2d 53 43 2d 31 | DM << (32-SC-1| 000003c0 29 0d 02 80 14 2e 42 4d 50 44 20 45 51 55 44 20 |).....BMPD EQUD | 000003d0 49 4d 41 47 45 0d 02 8a 04 0d 02 94 08 2e 73 65 |IMAGE.........se| 000003e0 74 0d 02 9e 12 41 44 52 20 52 30 2c 53 43 52 45 |t....ADR R0,SCRE| 000003f0 45 4e 44 0d 02 a8 11 41 44 52 20 52 31 2c 53 43 |END....ADR R1,SC| 00000400 52 45 45 4e 0d 02 b2 1d 53 57 49 20 22 4f 53 5f |REEN....SWI "OS_| 00000410 52 65 61 64 56 64 75 56 61 72 69 61 62 6c 65 73 |ReadVduVariables| 00000420 22 0d 02 bc 0e 4d 4f 56 20 50 43 2c 52 31 34 0d |"....MOV PC,R14.| 00000430 02 c6 04 0d 02 d0 08 2e 67 65 74 0d 02 da 12 4c |........get....L| 00000440 44 52 20 53 43 52 2c 53 43 52 45 45 4e 0d 02 e4 |DR SCR,SCREEN...| 00000450 18 41 44 44 20 53 43 52 2c 53 43 52 2c 23 33 32 |.ADD SCR,SCR,#32| 00000460 30 2a 32 35 36 0d 02 ee 14 53 55 42 20 53 43 52 |0*256....SUB SCR| 00000470 2c 53 43 52 2c 23 33 32 30 0d 02 f8 10 4c 44 52 |,SCR,#320....LDR| 00000480 20 42 4d 50 2c 42 4d 50 44 0d 03 02 0d 4d 4f 56 | BMP,BMPD....MOV| 00000490 20 44 2c 23 44 4d 0d 03 0c 0b 2e 47 4c 4f 4f 50 | D,#DM.....GLOOP| 000004a0 59 0d 03 16 0d 4d 4f 56 20 43 2c 23 44 4d 0d 03 |Y....MOV C,#DM..| 000004b0 20 0b 2e 47 4c 4f 4f 50 58 0d 03 2a 12 4c 44 52 | ..GLOOPX..*.LDR| 000004c0 20 54 2c 5b 53 43 52 5d 2c 23 34 0d 03 34 12 53 | T,[SCR],#4..4.S| 000004d0 54 52 20 54 2c 5b 42 4d 50 5d 2c 23 34 0d 03 3e |TR T,[BMP],#4..>| 000004e0 0f 53 55 42 53 20 43 2c 43 2c 23 34 0d 03 48 0e |.SUBS C,C,#4..H.| 000004f0 42 4e 45 20 47 4c 4f 4f 50 58 0d 03 52 13 53 55 |BNE GLOOPX..R.SU| 00000500 42 20 53 43 52 2c 53 43 52 2c 23 44 4d 0d 03 5c |B SCR,SCR,#DM..\| 00000510 14 53 55 42 20 53 43 52 2c 53 43 52 2c 23 33 32 |.SUB SCR,SCR,#32| 00000520 30 0d 03 66 0f 53 55 42 53 20 44 2c 44 2c 23 31 |0..f.SUBS D,D,#1| 00000530 0d 03 70 0e 42 4e 45 20 47 4c 4f 4f 50 59 0d 03 |..p.BNE GLOOPY..| 00000540 7a 0e 4d 4f 56 20 50 43 2c 52 31 34 0d 03 84 04 |z.MOV PC,R14....| 00000550 0d 03 8e 11 2e 73 63 61 6c 65 5f 72 6f 74 61 74 |.....scale_rotat| 00000560 65 0d 03 98 0d 4c 44 52 20 58 4d 2c 58 44 0d 03 |e....LDR XM,XD..| 00000570 a2 0d 4c 44 52 20 59 4d 2c 59 44 0d 03 ac 12 4c |..LDR YM,YD....L| 00000580 44 52 20 53 43 52 2c 53 43 52 45 45 4e 0d 03 b6 |DR SCR,SCREEN...| 00000590 0e 4c 44 52 20 44 58 2c 44 58 44 0d 03 c0 0e 4c |.LDR DX,DXD....L| 000005a0 44 52 20 44 59 2c 44 59 44 0d 03 ca 10 4c 44 52 |DR DY,DYD....LDR| 000005b0 20 42 4d 50 2c 42 4d 50 44 0d 03 d4 0e 4d 4f 56 | BMP,BMPD....MOV| 000005c0 20 53 2c 23 31 32 38 0d 03 de 0e 4d 4f 56 20 54 | S,#128....MOV T| 000005d0 2c 23 31 36 30 0d 03 e8 13 4d 4f 56 20 58 2c 44 |,#160....MOV X,D| 000005e0 58 2c 41 53 52 20 23 38 0d 03 f2 13 4d 4f 56 20 |X,ASR #8....MOV | 000005f0 59 2c 44 59 2c 41 53 52 20 23 38 0d 03 fc 0d 4d |Y,DY,ASR #8....M| 00000600 55 4c 20 43 2c 59 2c 53 0d 04 06 16 53 55 42 20 |UL C,Y,S....SUB | 00000610 58 4d 2c 58 4d 2c 43 2c 4c 53 4c 20 23 38 0d 04 |XM,XM,C,LSL #8..| 00000620 10 0d 4d 55 4c 20 43 2c 58 2c 54 0d 04 1a 16 53 |..MUL C,X,T....S| 00000630 55 42 20 58 4d 2c 58 4d 2c 43 2c 4c 53 4c 20 23 |UB XM,XM,C,LSL #| 00000640 38 0d 04 24 0d 4d 55 4c 20 43 2c 58 2c 53 0d 04 |8..$.MUL C,X,S..| 00000650 2e 16 41 44 44 20 59 4d 2c 59 4d 2c 43 2c 4c 53 |..ADD YM,YM,C,LS| 00000660 4c 20 23 38 0d 04 38 0d 4d 55 4c 20 43 2c 59 2c |L #8..8.MUL C,Y,| 00000670 54 0d 04 42 16 53 55 42 20 59 4d 2c 59 4d 2c 43 |T..B.SUB YM,YM,C| 00000680 2c 4c 53 4c 20 23 38 0d 04 4c 0e 4d 4f 56 20 44 |,LSL #8..L.MOV D| 00000690 2c 23 32 35 36 0d 04 56 04 0d 04 60 0a 2e 4c 4f |,#256..V...`..LO| 000006a0 4f 50 59 0d 04 6a 0c 4d 4f 56 20 58 2c 58 4d 0d |OPY..j.MOV X,XM.| 000006b0 04 74 0c 4d 4f 56 20 59 2c 59 4d 0d 04 7e 10 41 |.t.MOV Y,YM..~.A| 000006c0 44 44 20 58 4d 2c 58 4d 2c 44 59 0d 04 88 10 53 |DD XM,XM,DY....S| 000006d0 55 42 20 59 4d 2c 59 4d 2c 44 58 0d 04 92 1b 53 |UB YM,YM,DX....S| 000006e0 54 4d 46 44 20 31 33 21 2c 7b 58 4d 2c 59 4d 2c |TMFD 13!,{XM,YM,| 000006f0 44 58 2c 44 59 7d 0d 04 9c 04 0d 04 a6 13 42 49 |DX,DY}........BI| 00000700 43 20 20 44 58 2c 44 58 2c 23 26 37 46 0d 04 b0 |C DX,DX,#&7F...| 00000710 1a 84 52 20 20 44 58 2c 44 58 2c 44 59 2c 4c 53 |..R DX,DX,DY,LS| 00000720 52 20 23 33 32 2d 37 0d 04 ba 15 4d 4f 56 20 20 |R #32-7....MOV | 00000730 44 59 2c 44 59 2c 4c 53 4c 20 23 37 0d 04 c4 11 |DY,DY,LSL #7....| 00000740 42 49 43 20 20 58 2c 58 2c 23 26 37 46 0d 04 ce |BIC X,X,#&7F...| 00000750 17 84 52 20 20 58 2c 58 2c 59 2c 4c 53 52 20 23 |..R X,X,Y,LSR #| 00000760 33 32 2d 37 0d 04 d8 13 4d 4f 56 20 20 59 2c 59 |32-7....MOV Y,Y| 00000770 2c 4c 53 4c 20 23 37 0d 04 e2 04 0d 04 ec 0e 4d |,LSL #7........M| 00000780 4f 56 20 43 2c 23 33 32 30 0d 04 f6 0a 2e 4c 4f |OV C,#320.....LO| 00000790 4f 50 58 0d 05 00 04 0d 05 0a 10 a4 6d 61 70 62 |OPX.........mapb| 000007a0 79 74 65 28 57 31 29 0d 05 14 0f a4 6d 61 70 62 |yte(W1).....mapb| 000007b0 79 74 65 28 54 29 0d 05 1e 16 41 44 44 20 57 31 |yte(T)....ADD W1| 000007c0 2c 57 31 2c 54 2c 4c 53 4c 20 23 38 0d 05 28 0f |,W1,T,LSL #8..(.| 000007d0 a4 6d 61 70 62 79 74 65 28 54 29 0d 05 32 17 41 |.mapbyte(T)..2.A| 000007e0 44 44 20 57 31 2c 57 31 2c 54 2c 4c 53 4c 20 23 |DD W1,W1,T,LSL #| 000007f0 31 36 0d 05 3c 0f a4 6d 61 70 62 79 74 65 28 54 |16..<..mapbyte(T| 00000800 29 0d 05 46 17 41 44 44 20 57 31 2c 57 31 2c 54 |)..F.ADD W1,W1,T| 00000810 2c 4c 53 4c 20 23 32 34 0d 05 50 04 0d 05 5a 10 |,LSL #24..P...Z.| 00000820 a4 6d 61 70 62 79 74 65 28 57 32 29 0d 05 64 0f |.mapbyte(W2)..d.| 00000830 a4 6d 61 70 62 79 74 65 28 54 29 0d 05 6e 16 41 |.mapbyte(T)..n.A| 00000840 44 44 20 57 32 2c 57 32 2c 54 2c 4c 53 4c 20 23 |DD W2,W2,T,LSL #| 00000850 38 0d 05 78 0f a4 6d 61 70 62 79 74 65 28 54 29 |8..x..mapbyte(T)| 00000860 0d 05 82 17 41 44 44 20 57 32 2c 57 32 2c 54 2c |....ADD W2,W2,T,| 00000870 4c 53 4c 20 23 31 36 0d 05 8c 0f a4 6d 61 70 62 |LSL #16.....mapb| 00000880 79 74 65 28 54 29 0d 05 96 17 41 44 44 20 57 32 |yte(T)....ADD W2| 00000890 2c 57 32 2c 54 2c 4c 53 4c 20 23 32 34 0d 05 a0 |,W2,T,LSL #24...| 000008a0 04 0d 05 aa 10 a4 6d 61 70 62 79 74 65 28 57 33 |......mapbyte(W3| 000008b0 29 0d 05 b4 0f a4 6d 61 70 62 79 74 65 28 54 29 |).....mapbyte(T)| 000008c0 0d 05 be 16 41 44 44 20 57 33 2c 57 33 2c 54 2c |....ADD W3,W3,T,| 000008d0 4c 53 4c 20 23 38 0d 05 c8 0f a4 6d 61 70 62 79 |LSL #8.....mapby| 000008e0 74 65 28 54 29 0d 05 d2 17 41 44 44 20 57 33 2c |te(T)....ADD W3,| 000008f0 57 33 2c 54 2c 4c 53 4c 20 23 31 36 0d 05 dc 0f |W3,T,LSL #16....| 00000900 a4 6d 61 70 62 79 74 65 28 54 29 0d 05 e6 17 41 |.mapbyte(T)....A| 00000910 44 44 20 57 33 2c 57 33 2c 54 2c 4c 53 4c 20 23 |DD W3,W3,T,LSL #| 00000920 32 34 0d 05 f0 04 0d 05 fa 10 a4 6d 61 70 62 79 |24.........mapby| 00000930 74 65 28 57 34 29 0d 06 04 0f a4 6d 61 70 62 79 |te(W4).....mapby| 00000940 74 65 28 54 29 0d 06 0e 16 41 44 44 20 57 34 2c |te(T)....ADD W4,| 00000950 57 34 2c 54 2c 4c 53 4c 20 23 38 0d 06 18 0f a4 |W4,T,LSL #8.....| 00000960 6d 61 70 62 79 74 65 28 54 29 0d 06 22 17 41 44 |mapbyte(T)..".AD| 00000970 44 20 57 34 2c 57 34 2c 54 2c 4c 53 4c 20 23 31 |D W4,W4,T,LSL #1| 00000980 36 0d 06 2c 0f a4 6d 61 70 62 79 74 65 28 54 29 |6..,..mapbyte(T)| 00000990 0d 06 36 17 41 44 44 20 57 34 2c 57 34 2c 54 2c |..6.ADD W4,W4,T,| 000009a0 4c 53 4c 20 23 32 34 0d 06 40 04 0d 06 5e 1e 53 |LSL #24..@...^.S| 000009b0 54 4d 49 41 20 28 53 43 52 29 21 2c 7b 57 31 2c |TMIA (SCR)!,{W1,| 000009c0 57 32 2c 57 33 2c 57 34 7d 0d 06 68 10 53 55 42 |W2,W3,W4}..h.SUB| 000009d0 53 20 43 2c 43 2c 23 31 36 0d 06 72 0d 42 4e 45 |S C,C,#16..r.BNE| 000009e0 20 4c 4f 4f 50 58 0d 06 7c 04 0d 06 86 1b 4c 44 | LOOPX..|.....LD| 000009f0 4d 46 44 20 31 33 21 2c 7b 58 4d 2c 59 4d 2c 44 |MFD 13!,{XM,YM,D| 00000a00 58 2c 44 59 7d 0d 06 90 0f 53 55 42 53 20 44 2c |X,DY}....SUBS D,| 00000a10 44 2c 23 31 0d 06 9a 0d 42 4e 45 20 4c 4f 4f 50 |D,#1....BNE LOOP| 00000a20 59 0d 06 a4 0e 4d 4f 56 20 50 43 2c 52 31 34 0d |Y....MOV PC,R14.| 00000a30 06 ae 05 5d 0d 06 b8 05 ed 0d 06 c2 05 e1 0d 06 |...]............| 00000a40 cc 04 0d 06 d6 04 0d 06 e0 13 dd 20 a4 6d 61 70 |........... .map| 00000a50 62 79 74 65 28 72 65 67 29 0d 06 ea 0d 5b 4f 50 |byte(reg)....[OP| 00000a60 54 20 50 41 53 53 0d 06 f4 16 3b 20 28 75 2c 20 |T PASS....; (u, | 00000a70 76 29 2b 3d 28 64 75 2c 20 64 76 29 0d 06 fe 1e |v)+=(du, dv)....| 00000a80 20 20 20 20 20 20 20 20 20 20 41 44 44 53 20 20 | ADDS | 00000a90 20 20 20 20 59 2c 59 2c 44 59 0d 07 08 1e 20 20 | Y,Y,DY.... | 00000aa0 20 20 20 20 20 20 20 20 41 44 43 20 20 20 20 20 | ADC | 00000ab0 20 20 58 2c 58 2c 44 58 0d 07 12 23 20 20 20 20 | X,X,DX...# | 00000ac0 20 20 20 20 20 20 4d 4f 56 20 20 20 20 20 20 20 | MOV | 00000ad0 54 2c 58 2c 52 4f 52 20 23 53 43 0d 07 1c 27 3b |T,X,ROR #SC...';| 00000ae0 20 6c 6f 6f 6b 75 70 20 63 6f 6c 6f 75 72 20 61 | lookup colour a| 00000af0 74 20 28 69 6e 74 28 75 29 2c 20 69 6e 74 28 76 |t (int(u), int(v| 00000b00 29 29 0d 07 26 30 20 20 20 20 20 20 20 20 20 20 |))..&0 | 00000b10 4c 44 52 42 20 20 20 20 20 20 72 65 67 2c 5b 42 |LDRB reg,[B| 00000b20 4d 50 2c 54 2c 4c 53 52 20 23 33 32 2d 32 2a 53 |MP,T,LSR #32-2*S| 00000b30 43 5d 0d 07 30 06 20 5d 0d 07 3a 08 20 3d 22 22 |C]..0. ]..:. =""| 00000b40 0d 07 44 04 0d ff |..D...| 00000b46