Home » Archimedes archive » Acorn User » AU 1997-03 B.adf » Regulars » StarInfo/circles/Wilson/3D

StarInfo/circles/Wilson/3D

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 1997-03 B.adf » Regulars
Filename: StarInfo/circles/Wilson/3D
Read OK:
File size: 2570 bytes
Load address: 0000
Exec address: 0000
File contents
   10ON ERROR MODE 7:REPORT:PRINT" at line ";ERL:END
   20
   30DIM code 1024*16
   40FOR pass=0 TO 2 STEP 2
   50P%=code:[OPT pass
   60
   70.init
   80STMFD     R13!,{R14}
   90ADR       R0,setmode
  100SWI       "OS_Write0"
  110SWI       "OS_RemoveCursors"
  120ADR       R0,bank
  130MOV       R1,R0
  140SWI       "OS_ReadVduVariables"
  150LDMIA     R1!,{R2,R4}
  160ADD       R2,R2,R4
  170ADD       R3,R2,R4
  180MOV       R1,#2
  190STMIA     R0!,{R1-R3}
  200BL        newpalette
  210LDMFD     R13!,{R15}
  220
  230.setmode  EQUB 22:EQUB 15:EQUB 22:EQUB 13:EQUD 0
  240.bank     EQUD 148:EQUD 7:EQUD -1
  250
  260.swapnum  EQUD 0:EQUD 0
  270.swap
  280STMFD     R13!,{R14}
  290ADR       R10,bank
  300MOV       R0,#19
  310SWI       "OS_Byte"
  320MOV       R0,#112
  330LDR       R1,bank
  340RSB       R1,R1,#3
  350LDR       R12,[R10,R1,LSL #2]
  360STR       R1,bank
  370SWI       "OS_Byte"
  380MOV       R0,#113
  390SWI       "OS_Byte"
  400MOV       R0,#0
  410MOV       R1,R0
  420MOV       R2,R0
  430MOV       R3,R0
  440MOV       R4,R0
  450MOV       R5,R0
  460MOV       R6,R0
  470MOV       R7,R0
  480MOV       R8,R0
  490MOV       R9,R0
  500MOV       R10,R0
  510MOV       R11,R0
  520STR       R13,swapnum
  530MOV       R13,R0
  540MOV       R14,#87
  550.swap2
  560STMDB     R12!,{R0-R11,R13}
  570STMDB     R12!,{R0-R11,R13}
  580STMDB     R12!,{R0-R11,R13}
  590STMDB     R12!,{R0-R11,R13}
  600STMDB     R12!,{R0-R11,R13}
  610STMDB     R12!,{R0-R11,R13}
  620STMDB     R12!,{R0-R11,R13}
  630STMDB     R12!,{R0-R11,R13}
  640STMDB     R12!,{R0-R11,R13}
  650STMDB     R12!,{R0-R11,R13}
  660STMDB     R12!,{R0-R11,R13}
  670STMDB     R12!,{R0-R11,R13}
  680STMDB     R12!,{R0-R11,R13}
  690STMDB     R12!,{R0-R11,R13}
  700STMDB     R12!,{R0-R11,R13}
  710STMDB     R12!,{R0-R11,R13}
  720STMDB     R12!,{R0-R11,R13}
  730STMDB     R12!,{R0-R11,R13}
  740SUBS      R14,R14,#1
  750BGT       swap2
  760STMDB     R12!,{R0-R11,R13}
  770STMDB     R12!,{R0-R11,R13}
  780STMDB     R12!,{R0-R11}
  790STMDB     R12!,{R0-R11}
  800STMDB     R12!,{R0-R11}
  810STMDB     R12!,{R0-R11}
  820STMDB     R12!,{R0-R11}
  830STMDB     R12!,{R0-R11}
  840STMDB     R12!,{R0-R11}
  850STMDB     R12!,{R0-R11}
  860LDR       R13,swapnum
  870ADD       R12,R12,#320*128
  880LDMFD     R13!,{R15}
  890
  900.angle    EQUD 0
  910.speed    EQUD 1
  920.balls    EQUD 0
  930
  940.animation
  950STMFD     R13!,{R14}
  960.animation2
  970LDR       R8,angle
  980LDR       R9,speed
  990SWI       "OS_Mouse"
 1000ANDS      R0,R2,#1
 1010ADDNE     R9,R9,#1
 1020ANDS      R0,R2,#4
 1030SUBNE     R9,R9,#1
 1040CMP       R9,#31
 1050MOVGT     R9,#31
 1060CMN       R9,#30
 1070MVNLT     R9,#30
 1080STR       R9,speed
 1090SUBS      R8,R8,R9
 1100ADDLT     R8,R8,#360
 1110CMP       R8,#360
 1120SUBGT     R8,R8,#360
 1130STR       R8,angle
 1140LDR       R9,balls
 1150CMP       R9,#256
 1160ADDLT     R9,R9,#1
 1170STRLT     R9,balls
 1180BL        calculate
 1190BL        swap
 1200BL        display
 1210BL        plot
 1220BL        keys
 1230SWI       "OS_ReadEscapeState"
 1240BCC       animation2
 1250LDMFD     R13!,{R15}
 1260
 1270.keys
 1280STMFD     R13!,{R14}
 1281MOV       R9,#0
 1290LDR       R10,custom
 1300MOV       R0,#121
 1310MOV       R1,#235
 1320SWI       "OS_Byte"
 1330CMP       R1,#&FF
 1340SUBEQ     R10,R10,#1
 1341MOVEQ     R9,#1
 1350MOV       R1,#250
 1360SWI       "OS_Byte"
 1370CMP       R1,#&FF
 1380ADDEQ     R10,R10,#1
 1381MOVEQ     R9,#1
 1390CMP       R10,#256
 1400MOVGT     R10,#256
 1410CMP       R10,#0
 1420MOVLT     R10,#0
 1430STR       R10,custom
 1440LDR       R10,custom+4
 1450MOV       R0,#121
 1460MOV       R1,#252
 1470SWI       "OS_Byte"
 1480CMP       R1,#&FF
 1490SUBEQ     R10,R10,#1
 1491MOVEQ     R9,#1
 1500MOV       R1,#251
 1510SWI       "OS_Byte"
 1520CMP       R1,#&FF
 1530ADDEQ     R10,R10,#1
 1531MOVEQ     R9,#1
 1540CMP       R10,#256
 1550MOVGT     R10,#256
 1560CMP       R10,#0
 1570MOVLT     R10,#0
 1580STR       R10,custom+4
 1590LDR       R10,custom+8
 1600MOV       R0,#121
 1610MOV       R1,#236
 1620SWI       "OS_Byte"
 1630CMP       R1,#&FF
 1640SUBEQ     R10,R10,#1
 1641MOVEQ     R9,#1
 1650MOV       R1,#154
 1660SWI       "OS_Byte"
 1670CMP       R1,#&FF
 1680ADDEQ     R10,R10,#1
 1681MOVEQ     R9,#1
 1690CMP       R10,#256
 1700MOVGT     R10,#256
 1710CMP       R10,#0
 1720MOVLT     R10,#0
 1730STR       R10,custom+8
 1731MOVS      R9,R9
 1732BLNE      newpalette
 1790LDMFD     R13!,{R15}
 1800
 1810.display
 1820STMFD     R13!,{R12,R14}
 1830MOV       R0,#32
 1840SWI       "OS_WriteC"
 1850LDR       R1,speed
 1860CMP       R1,#0
 1870RSBLT     R1,R1,#0
 1880MOVLT     R0,#45
 1890SWILT     "OS_WriteC"
 1900CMP       R1,#10
 1910BLT       display2
 1920MOV       R0,#3
 1930CMP       R1,#30
 1940MOVLT     R0,#2
 1950CMP       R1,#20
 1960MOVLT     R0,#1
 1970ADD       R2,R0,R0,LSL #2
 1980SUB       R1,R1,R2,LSL #1
 1990ADD       R0,R0,#48
 2000SWI       "OS_WriteC"
 2010.display2
 2020ADD       R0,R1,#48
 2030SWI       "OS_WriteC"
 2040SWI       "OS_NewLine"
 2050MOV       R0,#11
 2060SWI       "OS_WriteC"
 2070MOV       R0,#23
 2080ADD       R0,R0,#99<<16
 2090MOV       R1,#139
 2100ADD       R12,R12,#320*128
 2110FNadr(8,custom)
 2120LDMIA     R8!,{R9-R11}
 2130RSB       R9,R9,#255
 2140RSB       R10,R10,#255
 2150RSB       R11,R11,#255
 2160MOV       R8,#255
 2170.display3
 2180CMP       R8,R11
 2190STRGE     R1,[R12,#-316]
 2200STR       R0,[R12,#-320]!
 2210CMP       R8,R9
 2220BICEQ     R0,R0,#255
 2230CMP       R8,R10
 2240BICEQ     R0,R0,#255<<16
 2250SUBS      R8,R8,#1
 2260BGT       display3
 2270LDMFD     R13!,{R12,R15}
 2280
 2290.calculate
 2300STMFD     R13!,{R14}
 2310FNadr(12,stack)
 2320FNadr(11,sine)
 2330FNadr(10,colour)
 2340.calculate2
 2350ADD       R0,R8,R9,LSL #2
 2360CMP       R0,#720
 2370SUBGE     R0,R0,#720
 2380LDR       R4,[R11,R0,LSL #2]
 2390MUL       R4,R9,R4
 2400ADD       R0,R0,R9,LSL #2
 2410CMP       R0,#720
 2420SUBGE     R0,R0,#720
 2430CMPGE     R0,#720
 2440SUBGE     R0,R0,#720
 2450LDR       R3,[R11,R0,LSL #2]
 2460MUL       R3,R9,R3
 2470ADD       R3,R3,R3,ASL #2
 2480ADD       R0,R0,#720
 2490LDR       R5,[R11,R0,LSL #2]
 2500MUL       R5,R9,R5
 2510MOV       R5,R5,ASR #17
 2520ADD       R5,R5,#128
 2530LDRB      R2,[R10,R5]
 2540MOVS      R2,R2
 2550ADDNE     R5,R5,R5,LSL #8
 2560MULNE     R5,R9,R5
 2570STMNEIA   R12!,{R2-R5}
 2580SUBS      R9,R9,#1
 2590BGT       calculate2
 2600MOV       R0,#0
 2610STR       R0,[R12]
 2620LDMFD     R13!,{R15}
 2630
 2640.plot
 2650STMFD     R13!,{R14}
 2660SUB       R12,R12,#1120
 2670ADD       R12,R12,#6
 2680FNadr(11,palette)
 2690FNadr(10,root)
 2700.plot2
 2710FNadr(9,stack)
 2720LDR       R8,[R11],#4
 2730MOVS      R7,R8
 2740LDMEQFD   R13!,{R15}
 2750.plot3
 2760LDR       R0,[R9],#16
 2770CMP       R0,R8,LSR #24
 2780BEQ       plot4
 2790CMP       R0,#0
 2800BNE       plot3
 2810B         plot2
 2820.plot4
 2830LDMDB     R9,{R0-R2}
 2840MOV       R1,R1,ASR #17
 2850MOVS      R2,R2,ASR #19
 2860BLGT      circle
 2870B         plot3
 2880
 2890.custom   EQUD 256:EQUD 256:EQUD 256
 2900.newpalette
 2910STMFD     R13!,{R14}
 2920MOV       R12,#0
 2930FNadr(11,palette)
 2940MOV       R10,#0
 2950FNadr(9,colour)
 2960FNadr(8,custom)
 2970LDMIA     R8,{R6-R8}
 2980.newpalette2
 2990MUL       R0,R6,R10
 3010MUL       R1,R7,R10
 3020MOV       R1,R1,LSR #8
 3030ADD       R0,R0,R1,LSL #16
 3040MUL       R1,R8,R10
 3050MOV       R1,R1,LSR #8
 3060ADD       R0,R0,R1,LSL #24
 3070REM BIC       R0,R0,#255                          ; Isn't needed for ColourTrans 1.07
 3080SWI       "ColourTrans_ReturnColourNumber"
 3081ADD       R0,R0,R0,LSL #8
 3082ADD       R0,R0,R0,LSL #16
 3090STR       R0,[R9],#4
 3120CMP       R12,R0
 3130MOVNE     R12,R0
 3160STRNE     R0,[R11],#4
 3170ADD       R10,R10,#4
 3180CMP       R10,#255
 3190BLE       newpalette2
 3200MOV       R10,#0
 3210STR       R10,[R11]
 3220LDMFD     R13!,{R15}
 3230
 3240.circle
 3250ADD       R4,R12,R0,ASR #19
 3260ADD       R4,R4,R1,LSL #6
 3270ADD       R4,R4,R1,LSL #8
 3280CMP       R2,#2
 3290STRLEB    R7,[R4]
 3300MOVLE     R15,R14
 3310STMFD     R13!,{R9-R12,R14}
 3320ADD       R11,R4,#320
 3330MOV       R3,R2,LSR #1
 3340ADD       R3,R3,R3,LSL #2
 3350ADD       R12,R4,R3,LSL #6
 3360SUB       R11,R11,R3,LSL #6
 3370MUL       R0,R2,R2
 3380RSB       R0,R0,#0
 3390.circle2
 3400MLA       R1,R2,R2,R0
 3410LDR       R3,[R10,-R1,LSL #2]
 3420ADD       R5,R12,R3,LSR #17
 3430ADD       R6,R11,R3,LSR #17
 3440AND       R4,R5,#3
 3450SUBS      R3,R3,R4,LSL #16
 3460ADDLT     R4,R4,R3,LSR #16
 3470MOVLT     R3,#0
 3480ANDS      R1,R4,#1
 3490STRNEB    R7,[R5,#-1]!
 3500STRNEB    R7,[R6,#-1]!
 3510ANDS      R1,R4,#2
 3520STRNEB    R7,[R5,#-1]!
 3530STRNEB    R7,[R5,#-1]!
 3540STRNEB    R7,[R6,#-1]!
 3550STRNEB    R7,[R6,#-1]!
 3560ANDS      R1,R3,#1<<18
 3570STRNE     R7,[R5,#-4]!
 3580STRNE     R7,[R6,#-4]!
 3590ANDS      R1,R3,#1<<19
 3600STMNEDB   R5!,{R7-R8}
 3610STMNEDB   R6!,{R7-R8}
 3620ANDS      R1,R3,#1<<20
 3630STMNEDB   R5!,{R7-R8}
 3640STMNEDB   R5!,{R7-R8}
 3650STMNEDB   R6!,{R7-R8}
 3660STMNEDB   R6!,{R7-R8}
 3670ANDS      R1,R3,#1<<17
 3680STRNEB    R7,[R5,#-1]!
 3690STRNEB    R7,[R5,#-1]!
 3700STRNEB    R7,[R6,#-1]!
 3710STRNEB    R7,[R6,#-1]!
 3720ANDS      R1,R3,#1<<16
 3730STRNEB    R7,[R5,#-1]!
 3740STRNEB    R7,[R6,#-1]!
 3750SUB       R12,R12,#320
 3760ADD       R11,R11,#320
 3770SUBS      R2,R2,#2
 3780BGT       circle2
 3790LDMFD     R13!,{R9-R12,R15}
 3800
 3810.palette  ]P%+=1024:[OPT pass           ; List of all colours in order
 3820.colour   ]P%+=256:[OPT pass            ; colours in order of brightness
 3830.root     ]P%+=4096:[OPT pass           ; Maximum radius of 32
 3840.sine     ]P%+=720*4:[OPT pass          ; 16-bit fixed point
 3850.cosine   ]P%+=720*4:[OPT pass          ; 16-bit fixed point
 3860.stack    ]P%+=16*128:[OPT pass         ; [colour],[X%],[Y%],[Rad%]
 3870]NEXT
 3880
 3890CALL init
 3900
 3910FOR A%=0 TO 719
 3920 sine!(A%*4)=INT(SINRAD(2*A%)*56500):REM waveform
 3930 cosine!(A%*4)=INT(COSRAD(A%)*65536):REM scaling
 3940NEXT
 3950:
 3960FOR A%=0 TO 1023
 3970 root!(A%*4)=SQR(A%)*65536
 3980NEXT
 3990:
 4000CALL animation
 4010:
 4020END
 4030DEF FNadr(Reg%,Addr%)
 4040IF pass=0 Addr%=P%
 4050IF Addr%<P% THEN
 4060 Addr%=P%-Addr%+8
 4070 [OPT pass:SUB Reg%,R15,#(Addr% AND &FF00):SUB Reg%,Reg%,#(Addr% AND &FF):]
 4080ELSE
 4090 Addr%=Addr%-P%-8
 4100 [OPT pass:ADD Reg%,R15,#(Addr% AND &FF00):ADD Reg%,Reg%,#(Addr% AND &FF):]
 4110ENDIF
 4120=0

� � � 7:�:�" at line ";�:�

� code 1024*16
(� pass=0 � 2 � 2
2P%=code:[OPT pass
<
F	.init
PSTMFD     R13!,{R14}
ZADR       R0,setmode
dSWI       "OS_Write0"
n SWI       "OS_RemoveCursors"
xADR       R0,bank
�MOV       R1,R0
�#SWI       "OS_ReadVduVariables"
�LDMIA     R1!,{R2,R4}
�ADD       R2,R2,R4
�ADD       R3,R2,R4
�MOV       R1,#2
�STMIA     R0!,{R1-R3}
�BL        newpalette
�LDMFD     R13!,{R15}
�
�4.setmode  EQUB 22:EQUB 15:EQUB 22:EQUB 13:EQUD 0
�%.bank     EQUD 148:EQUD 7:EQUD -1
�
.swapnum  EQUD 0:EQUD 0
	.swap
STMFD     R13!,{R14}
"ADR       R10,bank
,MOV       R0,#19
6SWI       "OS_Byte"
@MOV       R0,#112
JLDR       R1,bank
TRSB       R1,R1,#3
^!LDR       R12,[R10,R1,LSL #2]
hSTR       R1,bank
rSWI       "OS_Byte"
|MOV       R0,#113
�SWI       "OS_Byte"
�MOV       R0,#0
�MOV       R1,R0
�MOV       R2,R0
�MOV       R3,R0
�MOV       R4,R0
�MOV       R5,R0
�MOV       R6,R0
�MOV       R7,R0
�MOV       R8,R0
�MOV       R9,R0
�MOV       R10,R0
�MOV       R11,R0
STR       R13,swapnum
MOV       R13,R0
MOV       R14,#87
&
.swap2
0STMDB     R12!,{R0-R11,R13}
:STMDB     R12!,{R0-R11,R13}
DSTMDB     R12!,{R0-R11,R13}
NSTMDB     R12!,{R0-R11,R13}
XSTMDB     R12!,{R0-R11,R13}
bSTMDB     R12!,{R0-R11,R13}
lSTMDB     R12!,{R0-R11,R13}
vSTMDB     R12!,{R0-R11,R13}
�STMDB     R12!,{R0-R11,R13}
�STMDB     R12!,{R0-R11,R13}
�STMDB     R12!,{R0-R11,R13}
�STMDB     R12!,{R0-R11,R13}
�STMDB     R12!,{R0-R11,R13}
�STMDB     R12!,{R0-R11,R13}
�STMDB     R12!,{R0-R11,R13}
�STMDB     R12!,{R0-R11,R13}
�STMDB     R12!,{R0-R11,R13}
�STMDB     R12!,{R0-R11,R13}
�SUBS      R14,R14,#1
�BGT       swap2
�STMDB     R12!,{R0-R11,R13}
STMDB     R12!,{R0-R11,R13}
STMDB     R12!,{R0-R11}
STMDB     R12!,{R0-R11}
 STMDB     R12!,{R0-R11}
*STMDB     R12!,{R0-R11}
4STMDB     R12!,{R0-R11}
>STMDB     R12!,{R0-R11}
HSTMDB     R12!,{R0-R11}
RSTMDB     R12!,{R0-R11}
\LDR       R13,swapnum
fADD       R12,R12,#320*128
pLDMFD     R13!,{R15}
z
�.angle    EQUD 0
�.speed    EQUD 1
�.balls    EQUD 0
�
�.animation
�STMFD     R13!,{R14}
�.animation2
�LDR       R8,angle
�LDR       R9,speed
�SWI       "OS_Mouse"
��S      R0,R2,#1
�ADDNE     R9,R9,#1
��S      R0,R2,#4
SUBNE     R9,R9,#1
CMP       R9,#31
MOVGT     R9,#31
$CMN       R9,#30
.MVNLT     R9,#30
8STR       R9,speed
BSUBS      R8,R8,R9
LADDLT     R8,R8,#360
VCMP       R8,#360
`SUBGT     R8,R8,#360
jSTR       R8,angle
tLDR       R9,balls
~CMP       R9,#256
�ADDLT     R9,R9,#1
�STRLT     R9,balls
�BL        calculate
�BL        swap
�BL        display
�BL        plot
�BL        keys
�"SWI       "OS_ReadEscapeState"
�BCC       animation2
�LDMFD     R13!,{R15}
�
�	.keys
STMFD     R13!,{R14}
MOV       R9,#0

LDR       R10,custom
MOV       R0,#121
MOV       R1,#235
(SWI       "OS_Byte"
2CMP       R1,#&FF
<SUBEQ     R10,R10,#1
=�Q     R9,#1
FMOV       R1,#250
PSWI       "OS_Byte"
ZCMP       R1,#&FF
dADDEQ     R10,R10,#1
e�Q     R9,#1
nCMP       R10,#256
xMOVGT     R10,#256
�CMP       R10,#0
�MOVLT     R10,#0
�STR       R10,custom
�LDR       R10,custom+4
�MOV       R0,#121
�MOV       R1,#252
�SWI       "OS_Byte"
�CMP       R1,#&FF
�SUBEQ     R10,R10,#1
��Q     R9,#1
�MOV       R1,#251
�SWI       "OS_Byte"
�CMP       R1,#&FF
�ADDEQ     R10,R10,#1
��Q     R9,#1
CMP       R10,#256
MOVGT     R10,#256
CMP       R10,#0
"MOVLT     R10,#0
,STR       R10,custom+4
6LDR       R10,custom+8
@MOV       R0,#121
JMOV       R1,#236
TSWI       "OS_Byte"
^CMP       R1,#&FF
hSUBEQ     R10,R10,#1
i�Q     R9,#1
rMOV       R1,#154
|SWI       "OS_Byte"
�CMP       R1,#&FF
�ADDEQ     R10,R10,#1
��Q     R9,#1
�CMP       R10,#256
�MOVGT     R10,#256
�CMP       R10,#0
�MOVLT     R10,#0
�STR       R10,custom+8
�MOVS      R9,R9
�BLNE      newpalette
�LDMFD     R13!,{R15}

.display
STMFD     R13!,{R12,R14}
&MOV       R0,#32
0SWI       "OS_WriteC"
:LDR       R1,speed
DCMP       R1,#0
NRSBLT     R1,R1,#0
XMOVLT     R0,#45
bSWILT     "OS_WriteC"
lCMP       R1,#10
vBLT       display2
�MOV       R0,#3
�CMP       R1,#30
�MOVLT     R0,#2
�CMP       R1,#20
�MOVLT     R0,#1
�ADD       R2,R0,R0,LSL #2
�SUB       R1,R1,R2,LSL #1
�ADD       R0,R0,#48
�SWI       "OS_WriteC"
�
.display2
�ADD       R0,R1,#48
�SWI       "OS_WriteC"
�SWI       "OS_NewLine"
MOV       R0,#11
SWI       "OS_WriteC"
MOV       R0,#23
 ADD       R0,R0,#99<<16
*MOV       R1,#139
4ADD       R12,R12,#320*128
>�adr(8,custom)
HLDMIA     R8!,{R9-R11}
RRSB       R9,R9,#255
\RSB       R10,R10,#255
fRSB       R11,R11,#255
pMOV       R8,#255
z
.display3
�CMP       R8,R11
�STRGE     R1,[R12,#-316]
�STR       R0,[R12,#-320]!
�CMP       R8,R9
�BICEQ     R0,R0,#255
�CMP       R8,R10
�BICEQ     R0,R0,#255<<16
�SUBS      R8,R8,#1
�BGT       display3
�LDMFD     R13!,{R12,R15}
�
�.calculate
�STMFD     R13!,{R14}
	�adr(12,stack)
	�adr(11,sine)
	�adr(10,colour)
	$.calculate2
	.ADD       R0,R8,R9,LSL #2
	8CMP       R0,#720
	BSUBGE     R0,R0,#720
	L LDR       R4,[R11,R0,LSL #2]
	VMUL       R4,R9,R4
	`ADD       R0,R0,R9,LSL #2
	jCMP       R0,#720
	tSUBGE     R0,R0,#720
	~CMPGE     R0,#720
	�SUBGE     R0,R0,#720
	� LDR       R3,[R11,R0,LSL #2]
	�MUL       R3,R9,R3
	�ADD       R3,R3,R3,ASL #2
	�ADD       R0,R0,#720
	� LDR       R5,[R11,R0,LSL #2]
	�MUL       R5,R9,R5
	�MOV       R5,R5,ASR #17
	�ADD       R5,R5,#128
	�LDRB      R2,[R10,R5]
	�MOVS      R2,R2
	�ADDNE     R5,R5,R5,LSL #8
MULNE     R5,R9,R5

STMNEIA   R12!,{R2-R5}
SUBS      R9,R9,#1
BGT       calculate2
(MOV       R0,#0
2STR       R0,[R12]
<LDMFD     R13!,{R15}
F
P	.plot
ZSTMFD     R13!,{R14}
dSUB       R12,R12,#1120
nADD       R12,R12,#6
x�adr(11,palette)
��adr(10,root)
�
.plot2
��adr(9,stack)
�LDR       R8,[R11],#4
�MOVS      R7,R8
�LDMEQFD   R13!,{R15}
�
.plot3
�LDR       R0,[R9],#16
�CMP       R0,R8,LSR #24
�BEQ       plot4
�CMP       R0,#0
�BNE       plot3
�B         plot2

.plot4
LDMDB     R9,{R0-R2}
MOV       R1,R1,ASR #17
"MOVS      R2,R2,ASR #19
,BLGT      circle
6B         plot3
@
J(.custom   EQUD 256:EQUD 256:EQUD 256
T.newpalette
^STMFD     R13!,{R14}
hMOV       R12,#0
r�adr(11,palette)
|MOV       R10,#0
��adr(9,colour)
��adr(8,custom)
�LDMIA     R8,{R6-R8}
�.newpalette2
�MUL       R0,R6,R10
�MUL       R1,R7,R10
�MOV       R1,R1,LSR #8
�ADD       R0,R0,R1,LSL #16
�MUL       R1,R8,R10
�MOV       R1,R1,LSR #8
�ADD       R0,R0,R1,LSL #24
�W� BIC       R0,R0,#255                          ; Isn't needed for ColourTrans 1.07
.SWI       "ColourTrans_ReturnColourNumber"
	ADD       R0,R0,R0,LSL #8

ADD       R0,R0,R0,LSL #16
STR       R0,[R9],#4
0CMP       R12,R0
:MOVNE     R12,R0
XSTRNE     R0,[R11],#4
bADD       R10,R10,#4
lCMP       R10,#255
vBLE       newpalette2
�MOV       R10,#0
�STR       R10,[R11]
�LDMFD     R13!,{R15}
�
�.circle
�ADD       R4,R12,R0,ASR #19
�ADD       R4,R4,R1,LSL #6
�ADD       R4,R4,R1,LSL #8
�CMP       R2,#2
�STRLEB    R7,[R4]
�MOVLE     R15,R14
�STMFD     R13!,{R9-R12,R14}
�ADD       R11,R4,#320

MOV       R3,R2,LSR #1

ADD       R3,R3,R3,LSL #2

ADD       R12,R4,R3,LSL #6

 SUB       R11,R11,R3,LSL #6

*MUL       R0,R2,R2

4RSB       R0,R0,#0

>.circle2

HMLA       R1,R2,R2,R0

R!LDR       R3,[R10,-R1,LSL #2]

\ADD       R5,R12,R3,LSR #17

fADD       R6,R11,R3,LSR #17

p�       R4,R5,#3

zSUBS      R3,R3,R4,LSL #16

�ADDLT     R4,R4,R3,LSR #16

�MOVLT     R3,#0

��S      R1,R4,#1

�STRNEB    R7,[R5,#-1]!

�STRNEB    R7,[R6,#-1]!

��S      R1,R4,#2

�STRNEB    R7,[R5,#-1]!

�STRNEB    R7,[R5,#-1]!

�STRNEB    R7,[R6,#-1]!

�STRNEB    R7,[R6,#-1]!

��S      R1,R3,#1<<18

�STRNE     R7,[R5,#-4]!

�STRNE     R7,[R6,#-4]!
�S      R1,R3,#1<<19
STMNEDB   R5!,{R7-R8}
STMNEDB   R6!,{R7-R8}
$�S      R1,R3,#1<<20
.STMNEDB   R5!,{R7-R8}
8STMNEDB   R5!,{R7-R8}
BSTMNEDB   R6!,{R7-R8}
LSTMNEDB   R6!,{R7-R8}
V�S      R1,R3,#1<<17
`STRNEB    R7,[R5,#-1]!
jSTRNEB    R7,[R5,#-1]!
tSTRNEB    R7,[R6,#-1]!
~STRNEB    R7,[R6,#-1]!
��S      R1,R3,#1<<16
�STRNEB    R7,[R5,#-1]!
�STRNEB    R7,[R6,#-1]!
�SUB       R12,R12,#320
�ADD       R11,R11,#320
�SUBS      R2,R2,#2
�BGT       circle2
�LDMFD     R13!,{R9-R12,R15}
�
�J.palette  ]P%+=1024:[OPT pass           ; List of all colours in order
�L.colour   ]P%+=256:[OPT pass            ; colours in order of brightness
�B.root     ]P%+=4096:[OPT pass           ; Maximum radius of 32
@.sine     ]P%+=720*4:[OPT pass          ; 16-bit fixed point

@.cosine   ]P%+=720*4:[OPT pass          ; 16-bit fixed point
G.stack    ]P%+=16*128:[OPT pass         ; [colour],[X%],[Y%],[Rad%]
]�
(
2
� init
<
F� A%=0 � 719
P- sine!(A%*4)=�(��(2*A%)*56500):� waveform
Z, cosine!(A%*4)=�(��(A%)*65536):� scaling
d�
n:
x� A%=0 � 1023
� root!(A%*4)=�(A%)*65536
��
�:
�� animation
�:
��
�� �adr(Reg%,Addr%)
�� pass=0 Addr%=P%
�� Addr%<P% �
� Addr%=P%-Addr%+8
�K [OPT pass:SUB Reg%,R15,#(Addr% � &FF00):SUB Reg%,Reg%,#(Addr% � &FF):]
��
� Addr%=Addr%-P%-8
K [OPT pass:ADD Reg%,R15,#(Addr% � &FF00):ADD Reg%,Reg%,#(Addr% � &FF):]
�
=0
�
00000000  0d 00 0a 1e ee 20 85 20  eb 20 37 3a f6 3a f1 22  |..... . . 7:.:."|
00000010  20 61 74 20 6c 69 6e 65  20 22 3b 9e 3a e0 0d 00  | at line ";.:...|
00000020  14 04 0d 00 1e 12 de 20  63 6f 64 65 20 31 30 32  |....... code 102|
00000030  34 2a 31 36 0d 00 28 14  e3 20 70 61 73 73 3d 30  |4*16..(.. pass=0|
00000040  20 b8 20 32 20 88 20 32  0d 00 32 15 50 25 3d 63  | . 2 . 2..2.P%=c|
00000050  6f 64 65 3a 5b 4f 50 54  20 70 61 73 73 0d 00 3c  |ode:[OPT pass..<|
00000060  04 0d 00 46 09 2e 69 6e  69 74 0d 00 50 18 53 54  |...F..init..P.ST|
00000070  4d 46 44 20 20 20 20 20  52 31 33 21 2c 7b 52 31  |MFD     R13!,{R1|
00000080  34 7d 0d 00 5a 18 41 44  52 20 20 20 20 20 20 20  |4}..Z.ADR       |
00000090  52 30 2c 73 65 74 6d 6f  64 65 0d 00 64 19 53 57  |R0,setmode..d.SW|
000000a0  49 20 20 20 20 20 20 20  22 4f 53 5f 57 72 69 74  |I       "OS_Writ|
000000b0  65 30 22 0d 00 6e 20 53  57 49 20 20 20 20 20 20  |e0"..n SWI      |
000000c0  20 22 4f 53 5f 52 65 6d  6f 76 65 43 75 72 73 6f  | "OS_RemoveCurso|
000000d0  72 73 22 0d 00 78 15 41  44 52 20 20 20 20 20 20  |rs"..x.ADR      |
000000e0  20 52 30 2c 62 61 6e 6b  0d 00 82 13 4d 4f 56 20  | R0,bank....MOV |
000000f0  20 20 20 20 20 20 52 31  2c 52 30 0d 00 8c 23 53  |      R1,R0...#S|
00000100  57 49 20 20 20 20 20 20  20 22 4f 53 5f 52 65 61  |WI       "OS_Rea|
00000110  64 56 64 75 56 61 72 69  61 62 6c 65 73 22 0d 00  |dVduVariables"..|
00000120  96 19 4c 44 4d 49 41 20  20 20 20 20 52 31 21 2c  |..LDMIA     R1!,|
00000130  7b 52 32 2c 52 34 7d 0d  00 a0 16 41 44 44 20 20  |{R2,R4}....ADD  |
00000140  20 20 20 20 20 52 32 2c  52 32 2c 52 34 0d 00 aa  |     R2,R2,R4...|
00000150  16 41 44 44 20 20 20 20  20 20 20 52 33 2c 52 32  |.ADD       R3,R2|
00000160  2c 52 34 0d 00 b4 13 4d  4f 56 20 20 20 20 20 20  |,R4....MOV      |
00000170  20 52 31 2c 23 32 0d 00  be 19 53 54 4d 49 41 20  | R1,#2....STMIA |
00000180  20 20 20 20 52 30 21 2c  7b 52 31 2d 52 33 7d 0d  |    R0!,{R1-R3}.|
00000190  00 c8 18 42 4c 20 20 20  20 20 20 20 20 6e 65 77  |...BL        new|
000001a0  70 61 6c 65 74 74 65 0d  00 d2 18 4c 44 4d 46 44  |palette....LDMFD|
000001b0  20 20 20 20 20 52 31 33  21 2c 7b 52 31 35 7d 0d  |     R13!,{R15}.|
000001c0  00 dc 04 0d 00 e6 34 2e  73 65 74 6d 6f 64 65 20  |......4.setmode |
000001d0  20 45 51 55 42 20 32 32  3a 45 51 55 42 20 31 35  | EQUB 22:EQUB 15|
000001e0  3a 45 51 55 42 20 32 32  3a 45 51 55 42 20 31 33  |:EQUB 22:EQUB 13|
000001f0  3a 45 51 55 44 20 30 0d  00 f0 25 2e 62 61 6e 6b  |:EQUD 0...%.bank|
00000200  20 20 20 20 20 45 51 55  44 20 31 34 38 3a 45 51  |     EQUD 148:EQ|
00000210  55 44 20 37 3a 45 51 55  44 20 2d 31 0d 00 fa 04  |UD 7:EQUD -1....|
00000220  0d 01 04 1b 2e 73 77 61  70 6e 75 6d 20 20 45 51  |.....swapnum  EQ|
00000230  55 44 20 30 3a 45 51 55  44 20 30 0d 01 0e 09 2e  |UD 0:EQUD 0.....|
00000240  73 77 61 70 0d 01 18 18  53 54 4d 46 44 20 20 20  |swap....STMFD   |
00000250  20 20 52 31 33 21 2c 7b  52 31 34 7d 0d 01 22 16  |  R13!,{R14}..".|
00000260  41 44 52 20 20 20 20 20  20 20 52 31 30 2c 62 61  |ADR       R10,ba|
00000270  6e 6b 0d 01 2c 14 4d 4f  56 20 20 20 20 20 20 20  |nk..,.MOV       |
00000280  52 30 2c 23 31 39 0d 01  36 17 53 57 49 20 20 20  |R0,#19..6.SWI   |
00000290  20 20 20 20 22 4f 53 5f  42 79 74 65 22 0d 01 40  |    "OS_Byte"..@|
000002a0  15 4d 4f 56 20 20 20 20  20 20 20 52 30 2c 23 31  |.MOV       R0,#1|
000002b0  31 32 0d 01 4a 15 4c 44  52 20 20 20 20 20 20 20  |12..J.LDR       |
000002c0  52 31 2c 62 61 6e 6b 0d  01 54 16 52 53 42 20 20  |R1,bank..T.RSB  |
000002d0  20 20 20 20 20 52 31 2c  52 31 2c 23 33 0d 01 5e  |     R1,R1,#3..^|
000002e0  21 4c 44 52 20 20 20 20  20 20 20 52 31 32 2c 5b  |!LDR       R12,[|
000002f0  52 31 30 2c 52 31 2c 4c  53 4c 20 23 32 5d 0d 01  |R10,R1,LSL #2]..|
00000300  68 15 53 54 52 20 20 20  20 20 20 20 52 31 2c 62  |h.STR       R1,b|
00000310  61 6e 6b 0d 01 72 17 53  57 49 20 20 20 20 20 20  |ank..r.SWI      |
00000320  20 22 4f 53 5f 42 79 74  65 22 0d 01 7c 15 4d 4f  | "OS_Byte"..|.MO|
00000330  56 20 20 20 20 20 20 20  52 30 2c 23 31 31 33 0d  |V       R0,#113.|
00000340  01 86 17 53 57 49 20 20  20 20 20 20 20 22 4f 53  |...SWI       "OS|
00000350  5f 42 79 74 65 22 0d 01  90 13 4d 4f 56 20 20 20  |_Byte"....MOV   |
00000360  20 20 20 20 52 30 2c 23  30 0d 01 9a 13 4d 4f 56  |    R0,#0....MOV|
00000370  20 20 20 20 20 20 20 52  31 2c 52 30 0d 01 a4 13  |       R1,R0....|
00000380  4d 4f 56 20 20 20 20 20  20 20 52 32 2c 52 30 0d  |MOV       R2,R0.|
00000390  01 ae 13 4d 4f 56 20 20  20 20 20 20 20 52 33 2c  |...MOV       R3,|
000003a0  52 30 0d 01 b8 13 4d 4f  56 20 20 20 20 20 20 20  |R0....MOV       |
000003b0  52 34 2c 52 30 0d 01 c2  13 4d 4f 56 20 20 20 20  |R4,R0....MOV    |
000003c0  20 20 20 52 35 2c 52 30  0d 01 cc 13 4d 4f 56 20  |   R5,R0....MOV |
000003d0  20 20 20 20 20 20 52 36  2c 52 30 0d 01 d6 13 4d  |      R6,R0....M|
000003e0  4f 56 20 20 20 20 20 20  20 52 37 2c 52 30 0d 01  |OV       R7,R0..|
000003f0  e0 13 4d 4f 56 20 20 20  20 20 20 20 52 38 2c 52  |..MOV       R8,R|
00000400  30 0d 01 ea 13 4d 4f 56  20 20 20 20 20 20 20 52  |0....MOV       R|
00000410  39 2c 52 30 0d 01 f4 14  4d 4f 56 20 20 20 20 20  |9,R0....MOV     |
00000420  20 20 52 31 30 2c 52 30  0d 01 fe 14 4d 4f 56 20  |  R10,R0....MOV |
00000430  20 20 20 20 20 20 52 31  31 2c 52 30 0d 02 08 19  |      R11,R0....|
00000440  53 54 52 20 20 20 20 20  20 20 52 31 33 2c 73 77  |STR       R13,sw|
00000450  61 70 6e 75 6d 0d 02 12  14 4d 4f 56 20 20 20 20  |apnum....MOV    |
00000460  20 20 20 52 31 33 2c 52  30 0d 02 1c 15 4d 4f 56  |   R13,R0....MOV|
00000470  20 20 20 20 20 20 20 52  31 34 2c 23 38 37 0d 02  |       R14,#87..|
00000480  26 0a 2e 73 77 61 70 32  0d 02 30 1f 53 54 4d 44  |&..swap2..0.STMD|
00000490  42 20 20 20 20 20 52 31  32 21 2c 7b 52 30 2d 52  |B     R12!,{R0-R|
000004a0  31 31 2c 52 31 33 7d 0d  02 3a 1f 53 54 4d 44 42  |11,R13}..:.STMDB|
000004b0  20 20 20 20 20 52 31 32  21 2c 7b 52 30 2d 52 31  |     R12!,{R0-R1|
000004c0  31 2c 52 31 33 7d 0d 02  44 1f 53 54 4d 44 42 20  |1,R13}..D.STMDB |
000004d0  20 20 20 20 52 31 32 21  2c 7b 52 30 2d 52 31 31  |    R12!,{R0-R11|
000004e0  2c 52 31 33 7d 0d 02 4e  1f 53 54 4d 44 42 20 20  |,R13}..N.STMDB  |
000004f0  20 20 20 52 31 32 21 2c  7b 52 30 2d 52 31 31 2c  |   R12!,{R0-R11,|
00000500  52 31 33 7d 0d 02 58 1f  53 54 4d 44 42 20 20 20  |R13}..X.STMDB   |
00000510  20 20 52 31 32 21 2c 7b  52 30 2d 52 31 31 2c 52  |  R12!,{R0-R11,R|
00000520  31 33 7d 0d 02 62 1f 53  54 4d 44 42 20 20 20 20  |13}..b.STMDB    |
00000530  20 52 31 32 21 2c 7b 52  30 2d 52 31 31 2c 52 31  | R12!,{R0-R11,R1|
00000540  33 7d 0d 02 6c 1f 53 54  4d 44 42 20 20 20 20 20  |3}..l.STMDB     |
00000550  52 31 32 21 2c 7b 52 30  2d 52 31 31 2c 52 31 33  |R12!,{R0-R11,R13|
00000560  7d 0d 02 76 1f 53 54 4d  44 42 20 20 20 20 20 52  |}..v.STMDB     R|
00000570  31 32 21 2c 7b 52 30 2d  52 31 31 2c 52 31 33 7d  |12!,{R0-R11,R13}|
00000580  0d 02 80 1f 53 54 4d 44  42 20 20 20 20 20 52 31  |....STMDB     R1|
00000590  32 21 2c 7b 52 30 2d 52  31 31 2c 52 31 33 7d 0d  |2!,{R0-R11,R13}.|
000005a0  02 8a 1f 53 54 4d 44 42  20 20 20 20 20 52 31 32  |...STMDB     R12|
000005b0  21 2c 7b 52 30 2d 52 31  31 2c 52 31 33 7d 0d 02  |!,{R0-R11,R13}..|
000005c0  94 1f 53 54 4d 44 42 20  20 20 20 20 52 31 32 21  |..STMDB     R12!|
000005d0  2c 7b 52 30 2d 52 31 31  2c 52 31 33 7d 0d 02 9e  |,{R0-R11,R13}...|
000005e0  1f 53 54 4d 44 42 20 20  20 20 20 52 31 32 21 2c  |.STMDB     R12!,|
000005f0  7b 52 30 2d 52 31 31 2c  52 31 33 7d 0d 02 a8 1f  |{R0-R11,R13}....|
00000600  53 54 4d 44 42 20 20 20  20 20 52 31 32 21 2c 7b  |STMDB     R12!,{|
00000610  52 30 2d 52 31 31 2c 52  31 33 7d 0d 02 b2 1f 53  |R0-R11,R13}....S|
00000620  54 4d 44 42 20 20 20 20  20 52 31 32 21 2c 7b 52  |TMDB     R12!,{R|
00000630  30 2d 52 31 31 2c 52 31  33 7d 0d 02 bc 1f 53 54  |0-R11,R13}....ST|
00000640  4d 44 42 20 20 20 20 20  52 31 32 21 2c 7b 52 30  |MDB     R12!,{R0|
00000650  2d 52 31 31 2c 52 31 33  7d 0d 02 c6 1f 53 54 4d  |-R11,R13}....STM|
00000660  44 42 20 20 20 20 20 52  31 32 21 2c 7b 52 30 2d  |DB     R12!,{R0-|
00000670  52 31 31 2c 52 31 33 7d  0d 02 d0 1f 53 54 4d 44  |R11,R13}....STMD|
00000680  42 20 20 20 20 20 52 31  32 21 2c 7b 52 30 2d 52  |B     R12!,{R0-R|
00000690  31 31 2c 52 31 33 7d 0d  02 da 1f 53 54 4d 44 42  |11,R13}....STMDB|
000006a0  20 20 20 20 20 52 31 32  21 2c 7b 52 30 2d 52 31  |     R12!,{R0-R1|
000006b0  31 2c 52 31 33 7d 0d 02  e4 18 53 55 42 53 20 20  |1,R13}....SUBS  |
000006c0  20 20 20 20 52 31 34 2c  52 31 34 2c 23 31 0d 02  |    R14,R14,#1..|
000006d0  ee 13 42 47 54 20 20 20  20 20 20 20 73 77 61 70  |..BGT       swap|
000006e0  32 0d 02 f8 1f 53 54 4d  44 42 20 20 20 20 20 52  |2....STMDB     R|
000006f0  31 32 21 2c 7b 52 30 2d  52 31 31 2c 52 31 33 7d  |12!,{R0-R11,R13}|
00000700  0d 03 02 1f 53 54 4d 44  42 20 20 20 20 20 52 31  |....STMDB     R1|
00000710  32 21 2c 7b 52 30 2d 52  31 31 2c 52 31 33 7d 0d  |2!,{R0-R11,R13}.|
00000720  03 0c 1b 53 54 4d 44 42  20 20 20 20 20 52 31 32  |...STMDB     R12|
00000730  21 2c 7b 52 30 2d 52 31  31 7d 0d 03 16 1b 53 54  |!,{R0-R11}....ST|
00000740  4d 44 42 20 20 20 20 20  52 31 32 21 2c 7b 52 30  |MDB     R12!,{R0|
00000750  2d 52 31 31 7d 0d 03 20  1b 53 54 4d 44 42 20 20  |-R11}.. .STMDB  |
00000760  20 20 20 52 31 32 21 2c  7b 52 30 2d 52 31 31 7d  |   R12!,{R0-R11}|
00000770  0d 03 2a 1b 53 54 4d 44  42 20 20 20 20 20 52 31  |..*.STMDB     R1|
00000780  32 21 2c 7b 52 30 2d 52  31 31 7d 0d 03 34 1b 53  |2!,{R0-R11}..4.S|
00000790  54 4d 44 42 20 20 20 20  20 52 31 32 21 2c 7b 52  |TMDB     R12!,{R|
000007a0  30 2d 52 31 31 7d 0d 03  3e 1b 53 54 4d 44 42 20  |0-R11}..>.STMDB |
000007b0  20 20 20 20 52 31 32 21  2c 7b 52 30 2d 52 31 31  |    R12!,{R0-R11|
000007c0  7d 0d 03 48 1b 53 54 4d  44 42 20 20 20 20 20 52  |}..H.STMDB     R|
000007d0  31 32 21 2c 7b 52 30 2d  52 31 31 7d 0d 03 52 1b  |12!,{R0-R11}..R.|
000007e0  53 54 4d 44 42 20 20 20  20 20 52 31 32 21 2c 7b  |STMDB     R12!,{|
000007f0  52 30 2d 52 31 31 7d 0d  03 5c 19 4c 44 52 20 20  |R0-R11}..\.LDR  |
00000800  20 20 20 20 20 52 31 33  2c 73 77 61 70 6e 75 6d  |     R13,swapnum|
00000810  0d 03 66 1e 41 44 44 20  20 20 20 20 20 20 52 31  |..f.ADD       R1|
00000820  32 2c 52 31 32 2c 23 33  32 30 2a 31 32 38 0d 03  |2,R12,#320*128..|
00000830  70 18 4c 44 4d 46 44 20  20 20 20 20 52 31 33 21  |p.LDMFD     R13!|
00000840  2c 7b 52 31 35 7d 0d 03  7a 04 0d 03 84 14 2e 61  |,{R15}..z......a|
00000850  6e 67 6c 65 20 20 20 20  45 51 55 44 20 30 0d 03  |ngle    EQUD 0..|
00000860  8e 14 2e 73 70 65 65 64  20 20 20 20 45 51 55 44  |...speed    EQUD|
00000870  20 31 0d 03 98 14 2e 62  61 6c 6c 73 20 20 20 20  | 1.....balls    |
00000880  45 51 55 44 20 30 0d 03  a2 04 0d 03 ac 0e 2e 61  |EQUD 0.........a|
00000890  6e 69 6d 61 74 69 6f 6e  0d 03 b6 18 53 54 4d 46  |nimation....STMF|
000008a0  44 20 20 20 20 20 52 31  33 21 2c 7b 52 31 34 7d  |D     R13!,{R14}|
000008b0  0d 03 c0 0f 2e 61 6e 69  6d 61 74 69 6f 6e 32 0d  |.....animation2.|
000008c0  03 ca 16 4c 44 52 20 20  20 20 20 20 20 52 38 2c  |...LDR       R8,|
000008d0  61 6e 67 6c 65 0d 03 d4  16 4c 44 52 20 20 20 20  |angle....LDR    |
000008e0  20 20 20 52 39 2c 73 70  65 65 64 0d 03 de 18 53  |   R9,speed....S|
000008f0  57 49 20 20 20 20 20 20  20 22 4f 53 5f 4d 6f 75  |WI       "OS_Mou|
00000900  73 65 22 0d 03 e8 14 80  53 20 20 20 20 20 20 52  |se".....S      R|
00000910  30 2c 52 32 2c 23 31 0d  03 f2 16 41 44 44 4e 45  |0,R2,#1....ADDNE|
00000920  20 20 20 20 20 52 39 2c  52 39 2c 23 31 0d 03 fc  |     R9,R9,#1...|
00000930  14 80 53 20 20 20 20 20  20 52 30 2c 52 32 2c 23  |..S      R0,R2,#|
00000940  34 0d 04 06 16 53 55 42  4e 45 20 20 20 20 20 52  |4....SUBNE     R|
00000950  39 2c 52 39 2c 23 31 0d  04 10 14 43 4d 50 20 20  |9,R9,#1....CMP  |
00000960  20 20 20 20 20 52 39 2c  23 33 31 0d 04 1a 14 4d  |     R9,#31....M|
00000970  4f 56 47 54 20 20 20 20  20 52 39 2c 23 33 31 0d  |OVGT     R9,#31.|
00000980  04 24 14 43 4d 4e 20 20  20 20 20 20 20 52 39 2c  |.$.CMN       R9,|
00000990  23 33 30 0d 04 2e 14 4d  56 4e 4c 54 20 20 20 20  |#30....MVNLT    |
000009a0  20 52 39 2c 23 33 30 0d  04 38 16 53 54 52 20 20  | R9,#30..8.STR  |
000009b0  20 20 20 20 20 52 39 2c  73 70 65 65 64 0d 04 42  |     R9,speed..B|
000009c0  16 53 55 42 53 20 20 20  20 20 20 52 38 2c 52 38  |.SUBS      R8,R8|
000009d0  2c 52 39 0d 04 4c 18 41  44 44 4c 54 20 20 20 20  |,R9..L.ADDLT    |
000009e0  20 52 38 2c 52 38 2c 23  33 36 30 0d 04 56 15 43  | R8,R8,#360..V.C|
000009f0  4d 50 20 20 20 20 20 20  20 52 38 2c 23 33 36 30  |MP       R8,#360|
00000a00  0d 04 60 18 53 55 42 47  54 20 20 20 20 20 52 38  |..`.SUBGT     R8|
00000a10  2c 52 38 2c 23 33 36 30  0d 04 6a 16 53 54 52 20  |,R8,#360..j.STR |
00000a20  20 20 20 20 20 20 52 38  2c 61 6e 67 6c 65 0d 04  |      R8,angle..|
00000a30  74 16 4c 44 52 20 20 20  20 20 20 20 52 39 2c 62  |t.LDR       R9,b|
00000a40  61 6c 6c 73 0d 04 7e 15  43 4d 50 20 20 20 20 20  |alls..~.CMP     |
00000a50  20 20 52 39 2c 23 32 35  36 0d 04 88 16 41 44 44  |  R9,#256....ADD|
00000a60  4c 54 20 20 20 20 20 52  39 2c 52 39 2c 23 31 0d  |LT     R9,R9,#1.|
00000a70  04 92 16 53 54 52 4c 54  20 20 20 20 20 52 39 2c  |...STRLT     R9,|
00000a80  62 61 6c 6c 73 0d 04 9c  17 42 4c 20 20 20 20 20  |balls....BL     |
00000a90  20 20 20 63 61 6c 63 75  6c 61 74 65 0d 04 a6 12  |   calculate....|
00000aa0  42 4c 20 20 20 20 20 20  20 20 73 77 61 70 0d 04  |BL        swap..|
00000ab0  b0 15 42 4c 20 20 20 20  20 20 20 20 64 69 73 70  |..BL        disp|
00000ac0  6c 61 79 0d 04 ba 12 42  4c 20 20 20 20 20 20 20  |lay....BL       |
00000ad0  20 70 6c 6f 74 0d 04 c4  12 42 4c 20 20 20 20 20  | plot....BL     |
00000ae0  20 20 20 6b 65 79 73 0d  04 ce 22 53 57 49 20 20  |   keys..."SWI  |
00000af0  20 20 20 20 20 22 4f 53  5f 52 65 61 64 45 73 63  |     "OS_ReadEsc|
00000b00  61 70 65 53 74 61 74 65  22 0d 04 d8 18 42 43 43  |apeState"....BCC|
00000b10  20 20 20 20 20 20 20 61  6e 69 6d 61 74 69 6f 6e  |       animation|
00000b20  32 0d 04 e2 18 4c 44 4d  46 44 20 20 20 20 20 52  |2....LDMFD     R|
00000b30  31 33 21 2c 7b 52 31 35  7d 0d 04 ec 04 0d 04 f6  |13!,{R15}.......|
00000b40  09 2e 6b 65 79 73 0d 05  00 18 53 54 4d 46 44 20  |..keys....STMFD |
00000b50  20 20 20 20 52 31 33 21  2c 7b 52 31 34 7d 0d 05  |    R13!,{R14}..|
00000b60  01 13 4d 4f 56 20 20 20  20 20 20 20 52 39 2c 23  |..MOV       R9,#|
00000b70  30 0d 05 0a 18 4c 44 52  20 20 20 20 20 20 20 52  |0....LDR       R|
00000b80  31 30 2c 63 75 73 74 6f  6d 0d 05 14 15 4d 4f 56  |10,custom....MOV|
00000b90  20 20 20 20 20 20 20 52  30 2c 23 31 32 31 0d 05  |       R0,#121..|
00000ba0  1e 15 4d 4f 56 20 20 20  20 20 20 20 52 31 2c 23  |..MOV       R1,#|
00000bb0  32 33 35 0d 05 28 17 53  57 49 20 20 20 20 20 20  |235..(.SWI      |
00000bc0  20 22 4f 53 5f 42 79 74  65 22 0d 05 32 15 43 4d  | "OS_Byte"..2.CM|
00000bd0  50 20 20 20 20 20 20 20  52 31 2c 23 26 46 46 0d  |P       R1,#&FF.|
00000be0  05 3c 18 53 55 42 45 51  20 20 20 20 20 52 31 30  |.<.SUBEQ     R10|
00000bf0  2c 52 31 30 2c 23 31 0d  05 3d 10 ec 51 20 20 20  |,R10,#1..=..Q   |
00000c00  20 20 52 39 2c 23 31 0d  05 46 15 4d 4f 56 20 20  |  R9,#1..F.MOV  |
00000c10  20 20 20 20 20 52 31 2c  23 32 35 30 0d 05 50 17  |     R1,#250..P.|
00000c20  53 57 49 20 20 20 20 20  20 20 22 4f 53 5f 42 79  |SWI       "OS_By|
00000c30  74 65 22 0d 05 5a 15 43  4d 50 20 20 20 20 20 20  |te"..Z.CMP      |
00000c40  20 52 31 2c 23 26 46 46  0d 05 64 18 41 44 44 45  | R1,#&FF..d.ADDE|
00000c50  51 20 20 20 20 20 52 31  30 2c 52 31 30 2c 23 31  |Q     R10,R10,#1|
00000c60  0d 05 65 10 ec 51 20 20  20 20 20 52 39 2c 23 31  |..e..Q     R9,#1|
00000c70  0d 05 6e 16 43 4d 50 20  20 20 20 20 20 20 52 31  |..n.CMP       R1|
00000c80  30 2c 23 32 35 36 0d 05  78 16 4d 4f 56 47 54 20  |0,#256..x.MOVGT |
00000c90  20 20 20 20 52 31 30 2c  23 32 35 36 0d 05 82 14  |    R10,#256....|
00000ca0  43 4d 50 20 20 20 20 20  20 20 52 31 30 2c 23 30  |CMP       R10,#0|
00000cb0  0d 05 8c 14 4d 4f 56 4c  54 20 20 20 20 20 52 31  |....MOVLT     R1|
00000cc0  30 2c 23 30 0d 05 96 18  53 54 52 20 20 20 20 20  |0,#0....STR     |
00000cd0  20 20 52 31 30 2c 63 75  73 74 6f 6d 0d 05 a0 1a  |  R10,custom....|
00000ce0  4c 44 52 20 20 20 20 20  20 20 52 31 30 2c 63 75  |LDR       R10,cu|
00000cf0  73 74 6f 6d 2b 34 0d 05  aa 15 4d 4f 56 20 20 20  |stom+4....MOV   |
00000d00  20 20 20 20 52 30 2c 23  31 32 31 0d 05 b4 15 4d  |    R0,#121....M|
00000d10  4f 56 20 20 20 20 20 20  20 52 31 2c 23 32 35 32  |OV       R1,#252|
00000d20  0d 05 be 17 53 57 49 20  20 20 20 20 20 20 22 4f  |....SWI       "O|
00000d30  53 5f 42 79 74 65 22 0d  05 c8 15 43 4d 50 20 20  |S_Byte"....CMP  |
00000d40  20 20 20 20 20 52 31 2c  23 26 46 46 0d 05 d2 18  |     R1,#&FF....|
00000d50  53 55 42 45 51 20 20 20  20 20 52 31 30 2c 52 31  |SUBEQ     R10,R1|
00000d60  30 2c 23 31 0d 05 d3 10  ec 51 20 20 20 20 20 52  |0,#1.....Q     R|
00000d70  39 2c 23 31 0d 05 dc 15  4d 4f 56 20 20 20 20 20  |9,#1....MOV     |
00000d80  20 20 52 31 2c 23 32 35  31 0d 05 e6 17 53 57 49  |  R1,#251....SWI|
00000d90  20 20 20 20 20 20 20 22  4f 53 5f 42 79 74 65 22  |       "OS_Byte"|
00000da0  0d 05 f0 15 43 4d 50 20  20 20 20 20 20 20 52 31  |....CMP       R1|
00000db0  2c 23 26 46 46 0d 05 fa  18 41 44 44 45 51 20 20  |,#&FF....ADDEQ  |
00000dc0  20 20 20 52 31 30 2c 52  31 30 2c 23 31 0d 05 fb  |   R10,R10,#1...|
00000dd0  10 ec 51 20 20 20 20 20  52 39 2c 23 31 0d 06 04  |..Q     R9,#1...|
00000de0  16 43 4d 50 20 20 20 20  20 20 20 52 31 30 2c 23  |.CMP       R10,#|
00000df0  32 35 36 0d 06 0e 16 4d  4f 56 47 54 20 20 20 20  |256....MOVGT    |
00000e00  20 52 31 30 2c 23 32 35  36 0d 06 18 14 43 4d 50  | R10,#256....CMP|
00000e10  20 20 20 20 20 20 20 52  31 30 2c 23 30 0d 06 22  |       R10,#0.."|
00000e20  14 4d 4f 56 4c 54 20 20  20 20 20 52 31 30 2c 23  |.MOVLT     R10,#|
00000e30  30 0d 06 2c 1a 53 54 52  20 20 20 20 20 20 20 52  |0..,.STR       R|
00000e40  31 30 2c 63 75 73 74 6f  6d 2b 34 0d 06 36 1a 4c  |10,custom+4..6.L|
00000e50  44 52 20 20 20 20 20 20  20 52 31 30 2c 63 75 73  |DR       R10,cus|
00000e60  74 6f 6d 2b 38 0d 06 40  15 4d 4f 56 20 20 20 20  |tom+8..@.MOV    |
00000e70  20 20 20 52 30 2c 23 31  32 31 0d 06 4a 15 4d 4f  |   R0,#121..J.MO|
00000e80  56 20 20 20 20 20 20 20  52 31 2c 23 32 33 36 0d  |V       R1,#236.|
00000e90  06 54 17 53 57 49 20 20  20 20 20 20 20 22 4f 53  |.T.SWI       "OS|
00000ea0  5f 42 79 74 65 22 0d 06  5e 15 43 4d 50 20 20 20  |_Byte"..^.CMP   |
00000eb0  20 20 20 20 52 31 2c 23  26 46 46 0d 06 68 18 53  |    R1,#&FF..h.S|
00000ec0  55 42 45 51 20 20 20 20  20 52 31 30 2c 52 31 30  |UBEQ     R10,R10|
00000ed0  2c 23 31 0d 06 69 10 ec  51 20 20 20 20 20 52 39  |,#1..i..Q     R9|
00000ee0  2c 23 31 0d 06 72 15 4d  4f 56 20 20 20 20 20 20  |,#1..r.MOV      |
00000ef0  20 52 31 2c 23 31 35 34  0d 06 7c 17 53 57 49 20  | R1,#154..|.SWI |
00000f00  20 20 20 20 20 20 22 4f  53 5f 42 79 74 65 22 0d  |      "OS_Byte".|
00000f10  06 86 15 43 4d 50 20 20  20 20 20 20 20 52 31 2c  |...CMP       R1,|
00000f20  23 26 46 46 0d 06 90 18  41 44 44 45 51 20 20 20  |#&FF....ADDEQ   |
00000f30  20 20 52 31 30 2c 52 31  30 2c 23 31 0d 06 91 10  |  R10,R10,#1....|
00000f40  ec 51 20 20 20 20 20 52  39 2c 23 31 0d 06 9a 16  |.Q     R9,#1....|
00000f50  43 4d 50 20 20 20 20 20  20 20 52 31 30 2c 23 32  |CMP       R10,#2|
00000f60  35 36 0d 06 a4 16 4d 4f  56 47 54 20 20 20 20 20  |56....MOVGT     |
00000f70  52 31 30 2c 23 32 35 36  0d 06 ae 14 43 4d 50 20  |R10,#256....CMP |
00000f80  20 20 20 20 20 20 52 31  30 2c 23 30 0d 06 b8 14  |      R10,#0....|
00000f90  4d 4f 56 4c 54 20 20 20  20 20 52 31 30 2c 23 30  |MOVLT     R10,#0|
00000fa0  0d 06 c2 1a 53 54 52 20  20 20 20 20 20 20 52 31  |....STR       R1|
00000fb0  30 2c 63 75 73 74 6f 6d  2b 38 0d 06 c3 13 4d 4f  |0,custom+8....MO|
00000fc0  56 53 20 20 20 20 20 20  52 39 2c 52 39 0d 06 c4  |VS      R9,R9...|
00000fd0  18 42 4c 4e 45 20 20 20  20 20 20 6e 65 77 70 61  |.BLNE      newpa|
00000fe0  6c 65 74 74 65 0d 06 fe  18 4c 44 4d 46 44 20 20  |lette....LDMFD  |
00000ff0  20 20 20 52 31 33 21 2c  7b 52 31 35 7d 0d 07 08  |   R13!,{R15}...|
00001000  04 0d 07 12 0c 2e 64 69  73 70 6c 61 79 0d 07 1c  |......display...|
00001010  1c 53 54 4d 46 44 20 20  20 20 20 52 31 33 21 2c  |.STMFD     R13!,|
00001020  7b 52 31 32 2c 52 31 34  7d 0d 07 26 14 4d 4f 56  |{R12,R14}..&.MOV|
00001030  20 20 20 20 20 20 20 52  30 2c 23 33 32 0d 07 30  |       R0,#32..0|
00001040  19 53 57 49 20 20 20 20  20 20 20 22 4f 53 5f 57  |.SWI       "OS_W|
00001050  72 69 74 65 43 22 0d 07  3a 16 4c 44 52 20 20 20  |riteC"..:.LDR   |
00001060  20 20 20 20 52 31 2c 73  70 65 65 64 0d 07 44 13  |    R1,speed..D.|
00001070  43 4d 50 20 20 20 20 20  20 20 52 31 2c 23 30 0d  |CMP       R1,#0.|
00001080  07 4e 16 52 53 42 4c 54  20 20 20 20 20 52 31 2c  |.N.RSBLT     R1,|
00001090  52 31 2c 23 30 0d 07 58  14 4d 4f 56 4c 54 20 20  |R1,#0..X.MOVLT  |
000010a0  20 20 20 52 30 2c 23 34  35 0d 07 62 19 53 57 49  |   R0,#45..b.SWI|
000010b0  4c 54 20 20 20 20 20 22  4f 53 5f 57 72 69 74 65  |LT     "OS_Write|
000010c0  43 22 0d 07 6c 14 43 4d  50 20 20 20 20 20 20 20  |C"..l.CMP       |
000010d0  52 31 2c 23 31 30 0d 07  76 16 42 4c 54 20 20 20  |R1,#10..v.BLT   |
000010e0  20 20 20 20 64 69 73 70  6c 61 79 32 0d 07 80 13  |    display2....|
000010f0  4d 4f 56 20 20 20 20 20  20 20 52 30 2c 23 33 0d  |MOV       R0,#3.|
00001100  07 8a 14 43 4d 50 20 20  20 20 20 20 20 52 31 2c  |...CMP       R1,|
00001110  23 33 30 0d 07 94 13 4d  4f 56 4c 54 20 20 20 20  |#30....MOVLT    |
00001120  20 52 30 2c 23 32 0d 07  9e 14 43 4d 50 20 20 20  | R0,#2....CMP   |
00001130  20 20 20 20 52 31 2c 23  32 30 0d 07 a8 13 4d 4f  |    R1,#20....MO|
00001140  56 4c 54 20 20 20 20 20  52 30 2c 23 31 0d 07 b2  |VLT     R0,#1...|
00001150  1d 41 44 44 20 20 20 20  20 20 20 52 32 2c 52 30  |.ADD       R2,R0|
00001160  2c 52 30 2c 4c 53 4c 20  23 32 0d 07 bc 1d 53 55  |,R0,LSL #2....SU|
00001170  42 20 20 20 20 20 20 20  52 31 2c 52 31 2c 52 32  |B       R1,R1,R2|
00001180  2c 4c 53 4c 20 23 31 0d  07 c6 17 41 44 44 20 20  |,LSL #1....ADD  |
00001190  20 20 20 20 20 52 30 2c  52 30 2c 23 34 38 0d 07  |     R0,R0,#48..|
000011a0  d0 19 53 57 49 20 20 20  20 20 20 20 22 4f 53 5f  |..SWI       "OS_|
000011b0  57 72 69 74 65 43 22 0d  07 da 0d 2e 64 69 73 70  |WriteC".....disp|
000011c0  6c 61 79 32 0d 07 e4 17  41 44 44 20 20 20 20 20  |lay2....ADD     |
000011d0  20 20 52 30 2c 52 31 2c  23 34 38 0d 07 ee 19 53  |  R0,R1,#48....S|
000011e0  57 49 20 20 20 20 20 20  20 22 4f 53 5f 57 72 69  |WI       "OS_Wri|
000011f0  74 65 43 22 0d 07 f8 1a  53 57 49 20 20 20 20 20  |teC"....SWI     |
00001200  20 20 22 4f 53 5f 4e 65  77 4c 69 6e 65 22 0d 08  |  "OS_NewLine"..|
00001210  02 14 4d 4f 56 20 20 20  20 20 20 20 52 30 2c 23  |..MOV       R0,#|
00001220  31 31 0d 08 0c 19 53 57  49 20 20 20 20 20 20 20  |11....SWI       |
00001230  22 4f 53 5f 57 72 69 74  65 43 22 0d 08 16 14 4d  |"OS_WriteC"....M|
00001240  4f 56 20 20 20 20 20 20  20 52 30 2c 23 32 33 0d  |OV       R0,#23.|
00001250  08 20 1b 41 44 44 20 20  20 20 20 20 20 52 30 2c  |. .ADD       R0,|
00001260  52 30 2c 23 39 39 3c 3c  31 36 0d 08 2a 15 4d 4f  |R0,#99<<16..*.MO|
00001270  56 20 20 20 20 20 20 20  52 31 2c 23 31 33 39 0d  |V       R1,#139.|
00001280  08 34 1e 41 44 44 20 20  20 20 20 20 20 52 31 32  |.4.ADD       R12|
00001290  2c 52 31 32 2c 23 33 32  30 2a 31 32 38 0d 08 3e  |,R12,#320*128..>|
000012a0  12 a4 61 64 72 28 38 2c  63 75 73 74 6f 6d 29 0d  |..adr(8,custom).|
000012b0  08 48 1a 4c 44 4d 49 41  20 20 20 20 20 52 38 21  |.H.LDMIA     R8!|
000012c0  2c 7b 52 39 2d 52 31 31  7d 0d 08 52 18 52 53 42  |,{R9-R11}..R.RSB|
000012d0  20 20 20 20 20 20 20 52  39 2c 52 39 2c 23 32 35  |       R9,R9,#25|
000012e0  35 0d 08 5c 1a 52 53 42  20 20 20 20 20 20 20 52  |5..\.RSB       R|
000012f0  31 30 2c 52 31 30 2c 23  32 35 35 0d 08 66 1a 52  |10,R10,#255..f.R|
00001300  53 42 20 20 20 20 20 20  20 52 31 31 2c 52 31 31  |SB       R11,R11|
00001310  2c 23 32 35 35 0d 08 70  15 4d 4f 56 20 20 20 20  |,#255..p.MOV    |
00001320  20 20 20 52 38 2c 23 32  35 35 0d 08 7a 0d 2e 64  |   R8,#255..z..d|
00001330  69 73 70 6c 61 79 33 0d  08 84 14 43 4d 50 20 20  |isplay3....CMP  |
00001340  20 20 20 20 20 52 38 2c  52 31 31 0d 08 8e 1c 53  |     R8,R11....S|
00001350  54 52 47 45 20 20 20 20  20 52 31 2c 5b 52 31 32  |TRGE     R1,[R12|
00001360  2c 23 2d 33 31 36 5d 0d  08 98 1d 53 54 52 20 20  |,#-316]....STR  |
00001370  20 20 20 20 20 52 30 2c  5b 52 31 32 2c 23 2d 33  |     R0,[R12,#-3|
00001380  32 30 5d 21 0d 08 a2 13  43 4d 50 20 20 20 20 20  |20]!....CMP     |
00001390  20 20 52 38 2c 52 39 0d  08 ac 18 42 49 43 45 51  |  R8,R9....BICEQ|
000013a0  20 20 20 20 20 52 30 2c  52 30 2c 23 32 35 35 0d  |     R0,R0,#255.|
000013b0  08 b6 14 43 4d 50 20 20  20 20 20 20 20 52 38 2c  |...CMP       R8,|
000013c0  52 31 30 0d 08 c0 1c 42  49 43 45 51 20 20 20 20  |R10....BICEQ    |
000013d0  20 52 30 2c 52 30 2c 23  32 35 35 3c 3c 31 36 0d  | R0,R0,#255<<16.|
000013e0  08 ca 16 53 55 42 53 20  20 20 20 20 20 52 38 2c  |...SUBS      R8,|
000013f0  52 38 2c 23 31 0d 08 d4  16 42 47 54 20 20 20 20  |R8,#1....BGT    |
00001400  20 20 20 64 69 73 70 6c  61 79 33 0d 08 de 1c 4c  |   display3....L|
00001410  44 4d 46 44 20 20 20 20  20 52 31 33 21 2c 7b 52  |DMFD     R13!,{R|
00001420  31 32 2c 52 31 35 7d 0d  08 e8 04 0d 08 f2 0e 2e  |12,R15}.........|
00001430  63 61 6c 63 75 6c 61 74  65 0d 08 fc 18 53 54 4d  |calculate....STM|
00001440  46 44 20 20 20 20 20 52  31 33 21 2c 7b 52 31 34  |FD     R13!,{R14|
00001450  7d 0d 09 06 12 a4 61 64  72 28 31 32 2c 73 74 61  |}.....adr(12,sta|
00001460  63 6b 29 0d 09 10 11 a4  61 64 72 28 31 31 2c 73  |ck).....adr(11,s|
00001470  69 6e 65 29 0d 09 1a 13  a4 61 64 72 28 31 30 2c  |ine).....adr(10,|
00001480  63 6f 6c 6f 75 72 29 0d  09 24 0f 2e 63 61 6c 63  |colour)..$..calc|
00001490  75 6c 61 74 65 32 0d 09  2e 1d 41 44 44 20 20 20  |ulate2....ADD   |
000014a0  20 20 20 20 52 30 2c 52  38 2c 52 39 2c 4c 53 4c  |    R0,R8,R9,LSL|
000014b0  20 23 32 0d 09 38 15 43  4d 50 20 20 20 20 20 20  | #2..8.CMP      |
000014c0  20 52 30 2c 23 37 32 30  0d 09 42 18 53 55 42 47  | R0,#720..B.SUBG|
000014d0  45 20 20 20 20 20 52 30  2c 52 30 2c 23 37 32 30  |E     R0,R0,#720|
000014e0  0d 09 4c 20 4c 44 52 20  20 20 20 20 20 20 52 34  |..L LDR       R4|
000014f0  2c 5b 52 31 31 2c 52 30  2c 4c 53 4c 20 23 32 5d  |,[R11,R0,LSL #2]|
00001500  0d 09 56 16 4d 55 4c 20  20 20 20 20 20 20 52 34  |..V.MUL       R4|
00001510  2c 52 39 2c 52 34 0d 09  60 1d 41 44 44 20 20 20  |,R9,R4..`.ADD   |
00001520  20 20 20 20 52 30 2c 52  30 2c 52 39 2c 4c 53 4c  |    R0,R0,R9,LSL|
00001530  20 23 32 0d 09 6a 15 43  4d 50 20 20 20 20 20 20  | #2..j.CMP      |
00001540  20 52 30 2c 23 37 32 30  0d 09 74 18 53 55 42 47  | R0,#720..t.SUBG|
00001550  45 20 20 20 20 20 52 30  2c 52 30 2c 23 37 32 30  |E     R0,R0,#720|
00001560  0d 09 7e 15 43 4d 50 47  45 20 20 20 20 20 52 30  |..~.CMPGE     R0|
00001570  2c 23 37 32 30 0d 09 88  18 53 55 42 47 45 20 20  |,#720....SUBGE  |
00001580  20 20 20 52 30 2c 52 30  2c 23 37 32 30 0d 09 92  |   R0,R0,#720...|
00001590  20 4c 44 52 20 20 20 20  20 20 20 52 33 2c 5b 52  | LDR       R3,[R|
000015a0  31 31 2c 52 30 2c 4c 53  4c 20 23 32 5d 0d 09 9c  |11,R0,LSL #2]...|
000015b0  16 4d 55 4c 20 20 20 20  20 20 20 52 33 2c 52 39  |.MUL       R3,R9|
000015c0  2c 52 33 0d 09 a6 1d 41  44 44 20 20 20 20 20 20  |,R3....ADD      |
000015d0  20 52 33 2c 52 33 2c 52  33 2c 41 53 4c 20 23 32  | R3,R3,R3,ASL #2|
000015e0  0d 09 b0 18 41 44 44 20  20 20 20 20 20 20 52 30  |....ADD       R0|
000015f0  2c 52 30 2c 23 37 32 30  0d 09 ba 20 4c 44 52 20  |,R0,#720... LDR |
00001600  20 20 20 20 20 20 52 35  2c 5b 52 31 31 2c 52 30  |      R5,[R11,R0|
00001610  2c 4c 53 4c 20 23 32 5d  0d 09 c4 16 4d 55 4c 20  |,LSL #2]....MUL |
00001620  20 20 20 20 20 20 52 35  2c 52 39 2c 52 35 0d 09  |      R5,R9,R5..|
00001630  ce 1b 4d 4f 56 20 20 20  20 20 20 20 52 35 2c 52  |..MOV       R5,R|
00001640  35 2c 41 53 52 20 23 31  37 0d 09 d8 18 41 44 44  |5,ASR #17....ADD|
00001650  20 20 20 20 20 20 20 52  35 2c 52 35 2c 23 31 32  |       R5,R5,#12|
00001660  38 0d 09 e2 19 4c 44 52  42 20 20 20 20 20 20 52  |8....LDRB      R|
00001670  32 2c 5b 52 31 30 2c 52  35 5d 0d 09 ec 13 4d 4f  |2,[R10,R5]....MO|
00001680  56 53 20 20 20 20 20 20  52 32 2c 52 32 0d 09 f6  |VS      R2,R2...|
00001690  1d 41 44 44 4e 45 20 20  20 20 20 52 35 2c 52 35  |.ADDNE     R5,R5|
000016a0  2c 52 35 2c 4c 53 4c 20  23 38 0d 0a 00 16 4d 55  |,R5,LSL #8....MU|
000016b0  4c 4e 45 20 20 20 20 20  52 35 2c 52 39 2c 52 35  |LNE     R5,R9,R5|
000016c0  0d 0a 0a 1a 53 54 4d 4e  45 49 41 20 20 20 52 31  |....STMNEIA   R1|
000016d0  32 21 2c 7b 52 32 2d 52  35 7d 0d 0a 14 16 53 55  |2!,{R2-R5}....SU|
000016e0  42 53 20 20 20 20 20 20  52 39 2c 52 39 2c 23 31  |BS      R9,R9,#1|
000016f0  0d 0a 1e 18 42 47 54 20  20 20 20 20 20 20 63 61  |....BGT       ca|
00001700  6c 63 75 6c 61 74 65 32  0d 0a 28 13 4d 4f 56 20  |lculate2..(.MOV |
00001710  20 20 20 20 20 20 52 30  2c 23 30 0d 0a 32 16 53  |      R0,#0..2.S|
00001720  54 52 20 20 20 20 20 20  20 52 30 2c 5b 52 31 32  |TR       R0,[R12|
00001730  5d 0d 0a 3c 18 4c 44 4d  46 44 20 20 20 20 20 52  |]..<.LDMFD     R|
00001740  31 33 21 2c 7b 52 31 35  7d 0d 0a 46 04 0d 0a 50  |13!,{R15}..F...P|
00001750  09 2e 70 6c 6f 74 0d 0a  5a 18 53 54 4d 46 44 20  |..plot..Z.STMFD |
00001760  20 20 20 20 52 31 33 21  2c 7b 52 31 34 7d 0d 0a  |    R13!,{R14}..|
00001770  64 1b 53 55 42 20 20 20  20 20 20 20 52 31 32 2c  |d.SUB       R12,|
00001780  52 31 32 2c 23 31 31 32  30 0d 0a 6e 18 41 44 44  |R12,#1120..n.ADD|
00001790  20 20 20 20 20 20 20 52  31 32 2c 52 31 32 2c 23  |       R12,R12,#|
000017a0  36 0d 0a 78 14 a4 61 64  72 28 31 31 2c 70 61 6c  |6..x..adr(11,pal|
000017b0  65 74 74 65 29 0d 0a 82  11 a4 61 64 72 28 31 30  |ette).....adr(10|
000017c0  2c 72 6f 6f 74 29 0d 0a  8c 0a 2e 70 6c 6f 74 32  |,root).....plot2|
000017d0  0d 0a 96 11 a4 61 64 72  28 39 2c 73 74 61 63 6b  |.....adr(9,stack|
000017e0  29 0d 0a a0 19 4c 44 52  20 20 20 20 20 20 20 52  |)....LDR       R|
000017f0  38 2c 5b 52 31 31 5d 2c  23 34 0d 0a aa 13 4d 4f  |8,[R11],#4....MO|
00001800  56 53 20 20 20 20 20 20  52 37 2c 52 38 0d 0a b4  |VS      R7,R8...|
00001810  18 4c 44 4d 45 51 46 44  20 20 20 52 31 33 21 2c  |.LDMEQFD   R13!,|
00001820  7b 52 31 35 7d 0d 0a be  0a 2e 70 6c 6f 74 33 0d  |{R15}.....plot3.|
00001830  0a c8 19 4c 44 52 20 20  20 20 20 20 20 52 30 2c  |...LDR       R0,|
00001840  5b 52 39 5d 2c 23 31 36  0d 0a d2 1b 43 4d 50 20  |[R9],#16....CMP |
00001850  20 20 20 20 20 20 52 30  2c 52 38 2c 4c 53 52 20  |      R0,R8,LSR |
00001860  23 32 34 0d 0a dc 13 42  45 51 20 20 20 20 20 20  |#24....BEQ      |
00001870  20 70 6c 6f 74 34 0d 0a  e6 13 43 4d 50 20 20 20  | plot4....CMP   |
00001880  20 20 20 20 52 30 2c 23  30 0d 0a f0 13 42 4e 45  |    R0,#0....BNE|
00001890  20 20 20 20 20 20 20 70  6c 6f 74 33 0d 0a fa 13  |       plot3....|
000018a0  42 20 20 20 20 20 20 20  20 20 70 6c 6f 74 32 0d  |B         plot2.|
000018b0  0b 04 0a 2e 70 6c 6f 74  34 0d 0b 0e 18 4c 44 4d  |....plot4....LDM|
000018c0  44 42 20 20 20 20 20 52  39 2c 7b 52 30 2d 52 32  |DB     R9,{R0-R2|
000018d0  7d 0d 0b 18 1b 4d 4f 56  20 20 20 20 20 20 20 52  |}....MOV       R|
000018e0  31 2c 52 31 2c 41 53 52  20 23 31 37 0d 0b 22 1b  |1,R1,ASR #17..".|
000018f0  4d 4f 56 53 20 20 20 20  20 20 52 32 2c 52 32 2c  |MOVS      R2,R2,|
00001900  41 53 52 20 23 31 39 0d  0b 2c 14 42 4c 47 54 20  |ASR #19..,.BLGT |
00001910  20 20 20 20 20 63 69 72  63 6c 65 0d 0b 36 13 42  |     circle..6.B|
00001920  20 20 20 20 20 20 20 20  20 70 6c 6f 74 33 0d 0b  |         plot3..|
00001930  40 04 0d 0b 4a 28 2e 63  75 73 74 6f 6d 20 20 20  |@...J(.custom   |
00001940  45 51 55 44 20 32 35 36  3a 45 51 55 44 20 32 35  |EQUD 256:EQUD 25|
00001950  36 3a 45 51 55 44 20 32  35 36 0d 0b 54 0f 2e 6e  |6:EQUD 256..T..n|
00001960  65 77 70 61 6c 65 74 74  65 0d 0b 5e 18 53 54 4d  |ewpalette..^.STM|
00001970  46 44 20 20 20 20 20 52  31 33 21 2c 7b 52 31 34  |FD     R13!,{R14|
00001980  7d 0d 0b 68 14 4d 4f 56  20 20 20 20 20 20 20 52  |}..h.MOV       R|
00001990  31 32 2c 23 30 0d 0b 72  14 a4 61 64 72 28 31 31  |12,#0..r..adr(11|
000019a0  2c 70 61 6c 65 74 74 65  29 0d 0b 7c 14 4d 4f 56  |,palette)..|.MOV|
000019b0  20 20 20 20 20 20 20 52  31 30 2c 23 30 0d 0b 86  |       R10,#0...|
000019c0  12 a4 61 64 72 28 39 2c  63 6f 6c 6f 75 72 29 0d  |..adr(9,colour).|
000019d0  0b 90 12 a4 61 64 72 28  38 2c 63 75 73 74 6f 6d  |....adr(8,custom|
000019e0  29 0d 0b 9a 18 4c 44 4d  49 41 20 20 20 20 20 52  |)....LDMIA     R|
000019f0  38 2c 7b 52 36 2d 52 38  7d 0d 0b a4 10 2e 6e 65  |8,{R6-R8}.....ne|
00001a00  77 70 61 6c 65 74 74 65  32 0d 0b ae 17 4d 55 4c  |wpalette2....MUL|
00001a10  20 20 20 20 20 20 20 52  30 2c 52 36 2c 52 31 30  |       R0,R6,R10|
00001a20  0d 0b c2 17 4d 55 4c 20  20 20 20 20 20 20 52 31  |....MUL       R1|
00001a30  2c 52 37 2c 52 31 30 0d  0b cc 1a 4d 4f 56 20 20  |,R7,R10....MOV  |
00001a40  20 20 20 20 20 52 31 2c  52 31 2c 4c 53 52 20 23  |     R1,R1,LSR #|
00001a50  38 0d 0b d6 1e 41 44 44  20 20 20 20 20 20 20 52  |8....ADD       R|
00001a60  30 2c 52 30 2c 52 31 2c  4c 53 4c 20 23 31 36 0d  |0,R0,R1,LSL #16.|
00001a70  0b e0 17 4d 55 4c 20 20  20 20 20 20 20 52 31 2c  |...MUL       R1,|
00001a80  52 38 2c 52 31 30 0d 0b  ea 1a 4d 4f 56 20 20 20  |R8,R10....MOV   |
00001a90  20 20 20 20 52 31 2c 52  31 2c 4c 53 52 20 23 38  |    R1,R1,LSR #8|
00001aa0  0d 0b f4 1e 41 44 44 20  20 20 20 20 20 20 52 30  |....ADD       R0|
00001ab0  2c 52 30 2c 52 31 2c 4c  53 4c 20 23 32 34 0d 0b  |,R0,R1,LSL #24..|
00001ac0  fe 57 f4 20 42 49 43 20  20 20 20 20 20 20 52 30  |.W. BIC       R0|
00001ad0  2c 52 30 2c 23 32 35 35  20 20 20 20 20 20 20 20  |,R0,#255        |
00001ae0  20 20 20 20 20 20 20 20  20 20 20 20 20 20 20 20  |                |
00001af0  20 20 3b 20 49 73 6e 27  74 20 6e 65 65 64 65 64  |  ; Isn't needed|
00001b00  20 66 6f 72 20 43 6f 6c  6f 75 72 54 72 61 6e 73  | for ColourTrans|
00001b10  20 31 2e 30 37 0d 0c 08  2e 53 57 49 20 20 20 20  | 1.07....SWI    |
00001b20  20 20 20 22 43 6f 6c 6f  75 72 54 72 61 6e 73 5f  |   "ColourTrans_|
00001b30  52 65 74 75 72 6e 43 6f  6c 6f 75 72 4e 75 6d 62  |ReturnColourNumb|
00001b40  65 72 22 0d 0c 09 1d 41  44 44 20 20 20 20 20 20  |er"....ADD      |
00001b50  20 52 30 2c 52 30 2c 52  30 2c 4c 53 4c 20 23 38  | R0,R0,R0,LSL #8|
00001b60  0d 0c 0a 1e 41 44 44 20  20 20 20 20 20 20 52 30  |....ADD       R0|
00001b70  2c 52 30 2c 52 30 2c 4c  53 4c 20 23 31 36 0d 0c  |,R0,R0,LSL #16..|
00001b80  12 18 53 54 52 20 20 20  20 20 20 20 52 30 2c 5b  |..STR       R0,[|
00001b90  52 39 5d 2c 23 34 0d 0c  30 14 43 4d 50 20 20 20  |R9],#4..0.CMP   |
00001ba0  20 20 20 20 52 31 32 2c  52 30 0d 0c 3a 14 4d 4f  |    R12,R0..:.MO|
00001bb0  56 4e 45 20 20 20 20 20  52 31 32 2c 52 30 0d 0c  |VNE     R12,R0..|
00001bc0  58 19 53 54 52 4e 45 20  20 20 20 20 52 30 2c 5b  |X.STRNE     R0,[|
00001bd0  52 31 31 5d 2c 23 34 0d  0c 62 18 41 44 44 20 20  |R11],#4..b.ADD  |
00001be0  20 20 20 20 20 52 31 30  2c 52 31 30 2c 23 34 0d  |     R10,R10,#4.|
00001bf0  0c 6c 16 43 4d 50 20 20  20 20 20 20 20 52 31 30  |.l.CMP       R10|
00001c00  2c 23 32 35 35 0d 0c 76  19 42 4c 45 20 20 20 20  |,#255..v.BLE    |
00001c10  20 20 20 6e 65 77 70 61  6c 65 74 74 65 32 0d 0c  |   newpalette2..|
00001c20  80 14 4d 4f 56 20 20 20  20 20 20 20 52 31 30 2c  |..MOV       R10,|
00001c30  23 30 0d 0c 8a 17 53 54  52 20 20 20 20 20 20 20  |#0....STR       |
00001c40  52 31 30 2c 5b 52 31 31  5d 0d 0c 94 18 4c 44 4d  |R10,[R11]....LDM|
00001c50  46 44 20 20 20 20 20 52  31 33 21 2c 7b 52 31 35  |FD     R13!,{R15|
00001c60  7d 0d 0c 9e 04 0d 0c a8  0b 2e 63 69 72 63 6c 65  |}.........circle|
00001c70  0d 0c b2 1f 41 44 44 20  20 20 20 20 20 20 52 34  |....ADD       R4|
00001c80  2c 52 31 32 2c 52 30 2c  41 53 52 20 23 31 39 0d  |,R12,R0,ASR #19.|
00001c90  0c bc 1d 41 44 44 20 20  20 20 20 20 20 52 34 2c  |...ADD       R4,|
00001ca0  52 34 2c 52 31 2c 4c 53  4c 20 23 36 0d 0c c6 1d  |R4,R1,LSL #6....|
00001cb0  41 44 44 20 20 20 20 20  20 20 52 34 2c 52 34 2c  |ADD       R4,R4,|
00001cc0  52 31 2c 4c 53 4c 20 23  38 0d 0c d0 13 43 4d 50  |R1,LSL #8....CMP|
00001cd0  20 20 20 20 20 20 20 52  32 2c 23 32 0d 0c da 15  |       R2,#2....|
00001ce0  53 54 52 4c 45 42 20 20  20 20 52 37 2c 5b 52 34  |STRLEB    R7,[R4|
00001cf0  5d 0d 0c e4 15 4d 4f 56  4c 45 20 20 20 20 20 52  |]....MOVLE     R|
00001d00  31 35 2c 52 31 34 0d 0c  ee 1f 53 54 4d 46 44 20  |15,R14....STMFD |
00001d10  20 20 20 20 52 31 33 21  2c 7b 52 39 2d 52 31 32  |    R13!,{R9-R12|
00001d20  2c 52 31 34 7d 0d 0c f8  19 41 44 44 20 20 20 20  |,R14}....ADD    |
00001d30  20 20 20 52 31 31 2c 52  34 2c 23 33 32 30 0d 0d  |   R11,R4,#320..|
00001d40  02 1a 4d 4f 56 20 20 20  20 20 20 20 52 33 2c 52  |..MOV       R3,R|
00001d50  32 2c 4c 53 52 20 23 31  0d 0d 0c 1d 41 44 44 20  |2,LSR #1....ADD |
00001d60  20 20 20 20 20 20 52 33  2c 52 33 2c 52 33 2c 4c  |      R3,R3,R3,L|
00001d70  53 4c 20 23 32 0d 0d 16  1e 41 44 44 20 20 20 20  |SL #2....ADD    |
00001d80  20 20 20 52 31 32 2c 52  34 2c 52 33 2c 4c 53 4c  |   R12,R4,R3,LSL|
00001d90  20 23 36 0d 0d 20 1f 53  55 42 20 20 20 20 20 20  | #6.. .SUB      |
00001da0  20 52 31 31 2c 52 31 31  2c 52 33 2c 4c 53 4c 20  | R11,R11,R3,LSL |
00001db0  23 36 0d 0d 2a 16 4d 55  4c 20 20 20 20 20 20 20  |#6..*.MUL       |
00001dc0  52 30 2c 52 32 2c 52 32  0d 0d 34 16 52 53 42 20  |R0,R2,R2..4.RSB |
00001dd0  20 20 20 20 20 20 52 30  2c 52 30 2c 23 30 0d 0d  |      R0,R0,#0..|
00001de0  3e 0c 2e 63 69 72 63 6c  65 32 0d 0d 48 19 4d 4c  |>..circle2..H.ML|
00001df0  41 20 20 20 20 20 20 20  52 31 2c 52 32 2c 52 32  |A       R1,R2,R2|
00001e00  2c 52 30 0d 0d 52 21 4c  44 52 20 20 20 20 20 20  |,R0..R!LDR      |
00001e10  20 52 33 2c 5b 52 31 30  2c 2d 52 31 2c 4c 53 4c  | R3,[R10,-R1,LSL|
00001e20  20 23 32 5d 0d 0d 5c 1f  41 44 44 20 20 20 20 20  | #2]..\.ADD     |
00001e30  20 20 52 35 2c 52 31 32  2c 52 33 2c 4c 53 52 20  |  R5,R12,R3,LSR |
00001e40  23 31 37 0d 0d 66 1f 41  44 44 20 20 20 20 20 20  |#17..f.ADD      |
00001e50  20 52 36 2c 52 31 31 2c  52 33 2c 4c 53 52 20 23  | R6,R11,R3,LSR #|
00001e60  31 37 0d 0d 70 14 80 20  20 20 20 20 20 20 52 34  |17..p..       R4|
00001e70  2c 52 35 2c 23 33 0d 0d  7a 1e 53 55 42 53 20 20  |,R5,#3..z.SUBS  |
00001e80  20 20 20 20 52 33 2c 52  33 2c 52 34 2c 4c 53 4c  |    R3,R3,R4,LSL|
00001e90  20 23 31 36 0d 0d 84 1e  41 44 44 4c 54 20 20 20  | #16....ADDLT   |
00001ea0  20 20 52 34 2c 52 34 2c  52 33 2c 4c 53 52 20 23  |  R4,R4,R3,LSR #|
00001eb0  31 36 0d 0d 8e 13 4d 4f  56 4c 54 20 20 20 20 20  |16....MOVLT     |
00001ec0  52 33 2c 23 30 0d 0d 98  14 80 53 20 20 20 20 20  |R3,#0.....S     |
00001ed0  20 52 31 2c 52 34 2c 23  31 0d 0d a2 1a 53 54 52  | R1,R4,#1....STR|
00001ee0  4e 45 42 20 20 20 20 52  37 2c 5b 52 35 2c 23 2d  |NEB    R7,[R5,#-|
00001ef0  31 5d 21 0d 0d ac 1a 53  54 52 4e 45 42 20 20 20  |1]!....STRNEB   |
00001f00  20 52 37 2c 5b 52 36 2c  23 2d 31 5d 21 0d 0d b6  | R7,[R6,#-1]!...|
00001f10  14 80 53 20 20 20 20 20  20 52 31 2c 52 34 2c 23  |..S      R1,R4,#|
00001f20  32 0d 0d c0 1a 53 54 52  4e 45 42 20 20 20 20 52  |2....STRNEB    R|
00001f30  37 2c 5b 52 35 2c 23 2d  31 5d 21 0d 0d ca 1a 53  |7,[R5,#-1]!....S|
00001f40  54 52 4e 45 42 20 20 20  20 52 37 2c 5b 52 35 2c  |TRNEB    R7,[R5,|
00001f50  23 2d 31 5d 21 0d 0d d4  1a 53 54 52 4e 45 42 20  |#-1]!....STRNEB |
00001f60  20 20 20 52 37 2c 5b 52  36 2c 23 2d 31 5d 21 0d  |   R7,[R6,#-1]!.|
00001f70  0d de 1a 53 54 52 4e 45  42 20 20 20 20 52 37 2c  |...STRNEB    R7,|
00001f80  5b 52 36 2c 23 2d 31 5d  21 0d 0d e8 18 80 53 20  |[R6,#-1]!.....S |
00001f90  20 20 20 20 20 52 31 2c  52 33 2c 23 31 3c 3c 31  |     R1,R3,#1<<1|
00001fa0  38 0d 0d f2 1a 53 54 52  4e 45 20 20 20 20 20 52  |8....STRNE     R|
00001fb0  37 2c 5b 52 35 2c 23 2d  34 5d 21 0d 0d fc 1a 53  |7,[R5,#-4]!....S|
00001fc0  54 52 4e 45 20 20 20 20  20 52 37 2c 5b 52 36 2c  |TRNE     R7,[R6,|
00001fd0  23 2d 34 5d 21 0d 0e 06  18 80 53 20 20 20 20 20  |#-4]!.....S     |
00001fe0  20 52 31 2c 52 33 2c 23  31 3c 3c 31 39 0d 0e 10  | R1,R3,#1<<19...|
00001ff0  19 53 54 4d 4e 45 44 42  20 20 20 52 35 21 2c 7b  |.STMNEDB   R5!,{|
00002000  52 37 2d 52 38 7d 0d 0e  1a 19 53 54 4d 4e 45 44  |R7-R8}....STMNED|
00002010  42 20 20 20 52 36 21 2c  7b 52 37 2d 52 38 7d 0d  |B   R6!,{R7-R8}.|
00002020  0e 24 18 80 53 20 20 20  20 20 20 52 31 2c 52 33  |.$..S      R1,R3|
00002030  2c 23 31 3c 3c 32 30 0d  0e 2e 19 53 54 4d 4e 45  |,#1<<20....STMNE|
00002040  44 42 20 20 20 52 35 21  2c 7b 52 37 2d 52 38 7d  |DB   R5!,{R7-R8}|
00002050  0d 0e 38 19 53 54 4d 4e  45 44 42 20 20 20 52 35  |..8.STMNEDB   R5|
00002060  21 2c 7b 52 37 2d 52 38  7d 0d 0e 42 19 53 54 4d  |!,{R7-R8}..B.STM|
00002070  4e 45 44 42 20 20 20 52  36 21 2c 7b 52 37 2d 52  |NEDB   R6!,{R7-R|
00002080  38 7d 0d 0e 4c 19 53 54  4d 4e 45 44 42 20 20 20  |8}..L.STMNEDB   |
00002090  52 36 21 2c 7b 52 37 2d  52 38 7d 0d 0e 56 18 80  |R6!,{R7-R8}..V..|
000020a0  53 20 20 20 20 20 20 52  31 2c 52 33 2c 23 31 3c  |S      R1,R3,#1<|
000020b0  3c 31 37 0d 0e 60 1a 53  54 52 4e 45 42 20 20 20  |<17..`.STRNEB   |
000020c0  20 52 37 2c 5b 52 35 2c  23 2d 31 5d 21 0d 0e 6a  | R7,[R5,#-1]!..j|
000020d0  1a 53 54 52 4e 45 42 20  20 20 20 52 37 2c 5b 52  |.STRNEB    R7,[R|
000020e0  35 2c 23 2d 31 5d 21 0d  0e 74 1a 53 54 52 4e 45  |5,#-1]!..t.STRNE|
000020f0  42 20 20 20 20 52 37 2c  5b 52 36 2c 23 2d 31 5d  |B    R7,[R6,#-1]|
00002100  21 0d 0e 7e 1a 53 54 52  4e 45 42 20 20 20 20 52  |!..~.STRNEB    R|
00002110  37 2c 5b 52 36 2c 23 2d  31 5d 21 0d 0e 88 18 80  |7,[R6,#-1]!.....|
00002120  53 20 20 20 20 20 20 52  31 2c 52 33 2c 23 31 3c  |S      R1,R3,#1<|
00002130  3c 31 36 0d 0e 92 1a 53  54 52 4e 45 42 20 20 20  |<16....STRNEB   |
00002140  20 52 37 2c 5b 52 35 2c  23 2d 31 5d 21 0d 0e 9c  | R7,[R5,#-1]!...|
00002150  1a 53 54 52 4e 45 42 20  20 20 20 52 37 2c 5b 52  |.STRNEB    R7,[R|
00002160  36 2c 23 2d 31 5d 21 0d  0e a6 1a 53 55 42 20 20  |6,#-1]!....SUB  |
00002170  20 20 20 20 20 52 31 32  2c 52 31 32 2c 23 33 32  |     R12,R12,#32|
00002180  30 0d 0e b0 1a 41 44 44  20 20 20 20 20 20 20 52  |0....ADD       R|
00002190  31 31 2c 52 31 31 2c 23  33 32 30 0d 0e ba 16 53  |11,R11,#320....S|
000021a0  55 42 53 20 20 20 20 20  20 52 32 2c 52 32 2c 23  |UBS      R2,R2,#|
000021b0  32 0d 0e c4 15 42 47 54  20 20 20 20 20 20 20 63  |2....BGT       c|
000021c0  69 72 63 6c 65 32 0d 0e  ce 1f 4c 44 4d 46 44 20  |ircle2....LDMFD |
000021d0  20 20 20 20 52 31 33 21  2c 7b 52 39 2d 52 31 32  |    R13!,{R9-R12|
000021e0  2c 52 31 35 7d 0d 0e d8  04 0d 0e e2 4a 2e 70 61  |,R15}.......J.pa|
000021f0  6c 65 74 74 65 20 20 5d  50 25 2b 3d 31 30 32 34  |lette  ]P%+=1024|
00002200  3a 5b 4f 50 54 20 70 61  73 73 20 20 20 20 20 20  |:[OPT pass      |
00002210  20 20 20 20 20 3b 20 4c  69 73 74 20 6f 66 20 61  |     ; List of a|
00002220  6c 6c 20 63 6f 6c 6f 75  72 73 20 69 6e 20 6f 72  |ll colours in or|
00002230  64 65 72 0d 0e ec 4c 2e  63 6f 6c 6f 75 72 20 20  |der...L.colour  |
00002240  20 5d 50 25 2b 3d 32 35  36 3a 5b 4f 50 54 20 70  | ]P%+=256:[OPT p|
00002250  61 73 73 20 20 20 20 20  20 20 20 20 20 20 20 3b  |ass            ;|
00002260  20 63 6f 6c 6f 75 72 73  20 69 6e 20 6f 72 64 65  | colours in orde|
00002270  72 20 6f 66 20 62 72 69  67 68 74 6e 65 73 73 0d  |r of brightness.|
00002280  0e f6 42 2e 72 6f 6f 74  20 20 20 20 20 5d 50 25  |..B.root     ]P%|
00002290  2b 3d 34 30 39 36 3a 5b  4f 50 54 20 70 61 73 73  |+=4096:[OPT pass|
000022a0  20 20 20 20 20 20 20 20  20 20 20 3b 20 4d 61 78  |           ; Max|
000022b0  69 6d 75 6d 20 72 61 64  69 75 73 20 6f 66 20 33  |imum radius of 3|
000022c0  32 0d 0f 00 40 2e 73 69  6e 65 20 20 20 20 20 5d  |2...@.sine     ]|
000022d0  50 25 2b 3d 37 32 30 2a  34 3a 5b 4f 50 54 20 70  |P%+=720*4:[OPT p|
000022e0  61 73 73 20 20 20 20 20  20 20 20 20 20 3b 20 31  |ass          ; 1|
000022f0  36 2d 62 69 74 20 66 69  78 65 64 20 70 6f 69 6e  |6-bit fixed poin|
00002300  74 0d 0f 0a 40 2e 63 6f  73 69 6e 65 20 20 20 5d  |t...@.cosine   ]|
00002310  50 25 2b 3d 37 32 30 2a  34 3a 5b 4f 50 54 20 70  |P%+=720*4:[OPT p|
00002320  61 73 73 20 20 20 20 20  20 20 20 20 20 3b 20 31  |ass          ; 1|
00002330  36 2d 62 69 74 20 66 69  78 65 64 20 70 6f 69 6e  |6-bit fixed poin|
00002340  74 0d 0f 14 47 2e 73 74  61 63 6b 20 20 20 20 5d  |t...G.stack    ]|
00002350  50 25 2b 3d 31 36 2a 31  32 38 3a 5b 4f 50 54 20  |P%+=16*128:[OPT |
00002360  70 61 73 73 20 20 20 20  20 20 20 20 20 3b 20 5b  |pass         ; [|
00002370  63 6f 6c 6f 75 72 5d 2c  5b 58 25 5d 2c 5b 59 25  |colour],[X%],[Y%|
00002380  5d 2c 5b 52 61 64 25 5d  0d 0f 1e 06 5d ed 0d 0f  |],[Rad%]....]...|
00002390  28 04 0d 0f 32 0a d6 20  69 6e 69 74 0d 0f 3c 04  |(...2.. init..<.|
000023a0  0d 0f 46 10 e3 20 41 25  3d 30 20 b8 20 37 31 39  |..F.. A%=0 . 719|
000023b0  0d 0f 50 2d 20 73 69 6e  65 21 28 41 25 2a 34 29  |..P- sine!(A%*4)|
000023c0  3d a8 28 b5 b2 28 32 2a  41 25 29 2a 35 36 35 30  |=.(..(2*A%)*5650|
000023d0  30 29 3a f4 20 77 61 76  65 66 6f 72 6d 0d 0f 5a  |0):. waveform..Z|
000023e0  2c 20 63 6f 73 69 6e 65  21 28 41 25 2a 34 29 3d  |, cosine!(A%*4)=|
000023f0  a8 28 9b b2 28 41 25 29  2a 36 35 35 33 36 29 3a  |.(..(A%)*65536):|
00002400  f4 20 73 63 61 6c 69 6e  67 0d 0f 64 05 ed 0d 0f  |. scaling..d....|
00002410  6e 05 3a 0d 0f 78 11 e3  20 41 25 3d 30 20 b8 20  |n.:..x.. A%=0 . |
00002420  31 30 32 33 0d 0f 82 1c  20 72 6f 6f 74 21 28 41  |1023.... root!(A|
00002430  25 2a 34 29 3d b6 28 41  25 29 2a 36 35 35 33 36  |%*4)=.(A%)*65536|
00002440  0d 0f 8c 05 ed 0d 0f 96  05 3a 0d 0f a0 0f d6 20  |.........:..... |
00002450  61 6e 69 6d 61 74 69 6f  6e 0d 0f aa 05 3a 0d 0f  |animation....:..|
00002460  b4 05 e0 0d 0f be 16 dd  20 a4 61 64 72 28 52 65  |........ .adr(Re|
00002470  67 25 2c 41 64 64 72 25  29 0d 0f c8 15 e7 20 70  |g%,Addr%)..... p|
00002480  61 73 73 3d 30 20 41 64  64 72 25 3d 50 25 0d 0f  |ass=0 Addr%=P%..|
00002490  d2 10 e7 20 41 64 64 72  25 3c 50 25 20 8c 0d 0f  |... Addr%<P% ...|
000024a0  dc 15 20 41 64 64 72 25  3d 50 25 2d 41 64 64 72  |.. Addr%=P%-Addr|
000024b0  25 2b 38 0d 0f e6 4b 20  5b 4f 50 54 20 70 61 73  |%+8...K [OPT pas|
000024c0  73 3a 53 55 42 20 52 65  67 25 2c 52 31 35 2c 23  |s:SUB Reg%,R15,#|
000024d0  28 41 64 64 72 25 20 80  20 26 46 46 30 30 29 3a  |(Addr% . &FF00):|
000024e0  53 55 42 20 52 65 67 25  2c 52 65 67 25 2c 23 28  |SUB Reg%,Reg%,#(|
000024f0  41 64 64 72 25 20 80 20  26 46 46 29 3a 5d 0d 0f  |Addr% . &FF):]..|
00002500  f0 05 cc 0d 0f fa 15 20  41 64 64 72 25 3d 41 64  |....... Addr%=Ad|
00002510  64 72 25 2d 50 25 2d 38  0d 10 04 4b 20 5b 4f 50  |dr%-P%-8...K [OP|
00002520  54 20 70 61 73 73 3a 41  44 44 20 52 65 67 25 2c  |T pass:ADD Reg%,|
00002530  52 31 35 2c 23 28 41 64  64 72 25 20 80 20 26 46  |R15,#(Addr% . &F|
00002540  46 30 30 29 3a 41 44 44  20 52 65 67 25 2c 52 65  |F00):ADD Reg%,Re|
00002550  67 25 2c 23 28 41 64 64  72 25 20 80 20 26 46 46  |g%,#(Addr% . &FF|
00002560  29 3a 5d 0d 10 0e 05 cd  0d 10 18 06 3d 30 0d ff  |):].........=0..|
00002570