2022-01-25 14:16:08 -05:00
|
|
|
; approx sine
|
|
|
|
|
|
|
|
; uses two parabolas to approximate sine
|
2022-01-25 15:44:27 -05:00
|
|
|
; based on https://codebase64.org/doku.php?id=base:generating_approximate_sines_in_assembly
|
2022-01-25 14:16:08 -05:00
|
|
|
|
|
|
|
VALUE_L = $F0
|
|
|
|
VALUE_H = $F1
|
|
|
|
DELTA_L = $F2
|
|
|
|
DELTA_H = $F3
|
|
|
|
|
|
|
|
approx_sine:
|
|
|
|
|
|
|
|
|
|
|
|
initSineTable:
|
|
|
|
|
|
|
|
ldy #$3f
|
|
|
|
ldx #$00
|
|
|
|
stx VALUE_L
|
|
|
|
stx VALUE_H
|
|
|
|
stx DELTA_L
|
|
|
|
stx DELTA_H
|
|
|
|
|
|
|
|
|
|
|
|
; Accumulate the delta (normal 16-bit addition)
|
|
|
|
|
|
|
|
outer_loop:
|
|
|
|
lda VALUE_L
|
|
|
|
clc
|
|
|
|
adc DELTA_L
|
|
|
|
sta VALUE_L
|
|
|
|
lda VALUE_H
|
|
|
|
adc DELTA_H
|
|
|
|
sta VALUE_H
|
|
|
|
|
2022-01-25 15:44:27 -05:00
|
|
|
|
2022-01-25 14:16:08 -05:00
|
|
|
; Reflect the value around for a sine wave
|
2022-01-25 15:44:27 -05:00
|
|
|
sec
|
|
|
|
sbc #$20
|
2022-01-25 14:16:08 -05:00
|
|
|
|
|
|
|
sta sinetable+$c0,X
|
|
|
|
sta sinetable+$80,Y
|
2022-01-25 15:44:27 -05:00
|
|
|
|
2022-01-25 14:16:08 -05:00
|
|
|
eor #$ff
|
|
|
|
sta sinetable+$40,X
|
|
|
|
sta sinetable+$00,Y
|
|
|
|
|
|
|
|
; Increase the delta, which creates the "acceleration" for a parabola
|
|
|
|
lda DELTA_L
|
2022-01-25 15:44:27 -05:00
|
|
|
adc #$4 ; this value adds up to the proper amplitude
|
2022-01-25 14:16:08 -05:00
|
|
|
sta DELTA_L
|
|
|
|
bcc skip_oflo
|
|
|
|
inc DELTA_H
|
|
|
|
skip_oflo:
|
|
|
|
; Loop
|
|
|
|
inx
|
|
|
|
dey
|
|
|
|
bpl outer_loop
|
|
|
|
|
|
|
|
end:
|
|
|
|
jmp end
|
|
|
|
|
|
|
|
sinetable=$6000
|