2017-12-15 20:10:54 -05:00
|
|
|
GetSquareRoot: ; 13b87
|
|
|
|
; 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
|
|
|
|
cp $ff
|
|
|
|
ret z
|
|
|
|
|
|
|
|
; Iterate over the table until b**2 >= de.
|
|
|
|
ld a, [hli]
|
|
|
|
sub e
|
|
|
|
ld a, [hli]
|
|
|
|
sbc d
|
|
|
|
|
|
|
|
jr c, .loop
|
|
|
|
ret
|
|
|
|
|
2017-12-24 19:35:35 -05:00
|
|
|
.Squares: ; 13b98
|
2017-12-29 18:53:21 +01:00
|
|
|
root = 1
|
2017-12-15 20:10:54 -05:00
|
|
|
rept $ff
|
2017-12-29 18:53:21 +01:00
|
|
|
dw root * root
|
|
|
|
root = root + 1
|
2017-12-15 20:10:54 -05:00
|
|
|
endr
|