dos33fsprogs/basic/two-liners/entropy_tiny.s

123 lines
2.2 KiB
ArmAsm
Raw Normal View History

2021-03-04 05:06:51 +00:00
; Entropy
; by Dave McKellar of Toronto
; Two-line BASIC program
; Found on Beagle Brother's Apple Mechanic Disk
; Converted to 6502 Assembly by Deater (Vince Weaver) vince@deater.net
; 24001 ROT=0:FOR I=1 TO 15: READ A,B: POKE A,B: NEXT: DATA
; 232,252,233,29,7676,1,7678,4,7679,0,7680,18,7681,63,
; 7682,36,7683,36,7684,45,7685,45,7686,54,7687,54,7688,63,
; 7689,0
; 24002 FOR I=1 TO 99: HGR2: FOR E=.08 TO .15 STEP .01:
; FOR Y=4 to 189 STEP 6: FOR X=4 to 278 STEP 6:
; SCALE=(RND(1)<E)*RND(1)*E*20+1: XDRAW 1 AT X,Y:
; NEXT: NEXT: NEXT: NEXT
2021-03-04 22:06:46 +00:00
; SCALE=(RND(1)<E)*RND(1)*E*20+1
;
; Equivalent to IF RND(1)<E THEN SCALE=RND(1)*E*20+1
; ELSE SCALE=1
; What this does:
; if EPOS is 8,9 then value is either 1 or 2
; if EPOS is 10,11,12,13,14 then value is either 1, 2, or 3
2021-03-04 05:06:51 +00:00
; Optimization
2021-03-04 22:06:46 +00:00
; 88 bytes -- hack up the entropy code
; 83 bytes -- count down YPOS instead of up
; 73 bytes -- XPOS only up to 256
2021-03-05 01:44:08 +00:00
; 73 bytes -- move to zero page
; 65 bytes -- move XPOS/YPOS into X/Y, use RESTORE
2021-03-04 05:06:51 +00:00
;BLT=BCC, BGE=BCS
; zero page locations
HGR_SHAPE = $1A
2021-03-05 01:44:08 +00:00
A5H = $45
XREG = $46
YREG = $47
2021-03-04 05:06:51 +00:00
HGR_SCALE = $E7
HGR_ROTATION = $F9
2021-03-04 22:06:46 +00:00
FRAME = $FC
2021-03-04 05:06:51 +00:00
XPOS = $FD
YPOS = $FF
; ROM calls
HGR2 = $F3D8
HPOSN = $F411
XDRAW0 = $F65D
2021-03-05 01:44:08 +00:00
RESTORE = $FF3F
2021-03-04 05:06:51 +00:00
2021-03-05 01:44:08 +00:00
.zeropage
2021-03-04 05:06:51 +00:00
entropy:
jsr HGR2 ; Hi-res graphics, no text at bottom
2021-03-04 22:06:46 +00:00
; Y=0, A=0 after this call
2021-03-04 05:06:51 +00:00
eloop:
2021-03-05 01:44:08 +00:00
ldy #180 ; Y=180 down to 0 STEP 6
2021-03-04 05:06:51 +00:00
yloop:
2021-03-04 22:06:46 +00:00
2021-03-05 01:44:08 +00:00
ldx #4 ; FOR X=4 to 278 STEP 6
2021-03-04 05:06:51 +00:00
xloop:
2021-03-05 01:44:08 +00:00
frame_smc:
lda $D000 ; 3 ; also FRAME
and #1 ; 2
sta HGR_SCALE ; 2
inc HGR_SCALE ; 2 = 9
; ldx #1 ; 2
; ldy FRAME ; 2
; lda $D000,y ; 3
; bmi no_add ; 2
; inx ; 1
;no_add: ;
; stx HGR_SCALE ; 2 = 12
stx XREG ; save X
sty YREG ; save Y
; setup X and Y co-ords
tya ; YPOS into A
ldy #0 ; Y always 0
; XPOS already in X
2021-03-04 05:06:51 +00:00
jsr HPOSN ; X= (y,x) Y=(a)
2021-03-05 01:44:08 +00:00
2021-03-04 05:06:51 +00:00
ldx #<shape_table ; point to our shape
lda #0 ; ROT=0
2021-03-05 01:44:08 +00:00
tay ; ldy #>shape_table
2021-03-04 05:06:51 +00:00
jsr XDRAW0 ; XDRAW 1 AT X,Y
; Both A and X are 0 at exit
2021-03-05 01:44:08 +00:00
jsr RESTORE ; restore FLAGS/X/Y/A
2021-03-04 05:06:51 +00:00
nextx: ; NEXT X
2021-03-05 01:44:08 +00:00
inc frame_smc+1
2021-03-04 22:06:46 +00:00
2021-03-05 01:44:08 +00:00
txa
2021-03-04 05:06:51 +00:00
clc ; 1
adc #6 ; x+=6 ; 2
2021-03-05 01:44:08 +00:00
tax
2021-03-04 05:06:51 +00:00
bne xloop ; if so, loop ; 2
2021-03-04 22:06:46 +00:00
nexty:
2021-03-05 01:44:08 +00:00
; carry always set if we get here
; sec
tya
sbc #6 ; y-=6
tay
2021-03-04 22:06:46 +00:00
bne yloop ; if so, loop
beq eloop
2021-03-04 05:06:51 +00:00
shape_table:
.byte 18,63,36,36,45,45,54,54,63,0 ; data