2018-01-16 17:59:05 -05:00
|
|
|
NUM_SQUARE_ROOTS EQU 255
|
|
|
|
|
2018-06-24 16:09:41 +02:00
|
|
|
GetSquareRoot:
|
2017-12-15 20:10:54 -05:00
|
|
|
; Return the square root of de in b.
|
|
|
|
|
|
|
|
; Rather than calculating the result, we take the index of the
|
|
|
|
; first value in a table of squares that isn't lower than de.
|
|
|
|
|
2017-12-24 19:35:35 -05:00
|
|
|
ld hl, .Squares
|
2017-12-15 20:10:54 -05:00
|
|
|
ld b, 0
|
|
|
|
.loop
|
|
|
|
; Make sure we don't go past the end of the table.
|
|
|
|
inc b
|
|
|
|
ld a, b
|
2018-01-16 17:59:05 -05:00
|
|
|
cp NUM_SQUARE_ROOTS
|
2017-12-15 20:10:54 -05:00
|
|
|
ret z
|
|
|
|
|
|
|
|
; Iterate over the table until b**2 >= de.
|
|
|
|
ld a, [hli]
|
|
|
|
sub e
|
|
|
|
ld a, [hli]
|
|
|
|
sbc d
|
|
|
|
|
|
|
|
jr c, .loop
|
|
|
|
ret
|
|
|
|
|
2018-06-24 16:09:41 +02:00
|
|
|
.Squares:
|
2018-01-16 17:59:05 -05:00
|
|
|
x = 1
|
|
|
|
rept NUM_SQUARE_ROOTS
|
|
|
|
dw x * x
|
|
|
|
x = x + 1
|
|
|
|
endr
|