From: Eric S. Raymond Date: Mon, 16 Oct 2006 13:41:47 +0000 (+0000) Subject: More trig refactoring. X-Git-Tag: 2.0~63 X-Git-Url: https://jxself.org/git/?p=super-star-trek.git;a=commitdiff_plain;h=d24ab69c78ba2c30ed49fd5a04e0e7a4d452a1fa;hp=11639f15f78cc19cb11d95713ef5d6454c391afc More trig refactoring. --- diff --git a/src/sst.py b/src/sst.py index 87a057d..992b1c9 100644 --- a/src/sst.py +++ b/src/sst.py @@ -1295,14 +1295,11 @@ def torpedo(origin, bearing, dispersion, number, nburst): newcnd(); # we're blown out of dock if game.landed or game.condition=="docked": return hit # Cheat if on a planet - ang = track.angle + 2.5*(randreal()-0.5) - temp = math.fabs(math.sin(ang)) - if math.fabs(math.cos(ang)) > temp: - temp = math.fabs(math.cos(ang)) - xx = -math.sin(ang)/temp - yy = math.cos(ang)/temp - bumpto.i = int(w.i+xx+0.5) - bumpto.j = int(w.j+yy+0.5) + # In the C/FORTRAN version, dispersion was 2.5 radians, which + # is 143 degrees, which is almost exactly 4.8 clockface units + displacement = course(track.bearing+randreal(-2.4,2.4), distance=2**0.5) + displacement.next() + bumpto = displacement.sector() if not bumpto.valid_sector(): return hit if game.quad[bumpto.i][bumpto.j]==IHBLANK: @@ -1343,15 +1340,9 @@ def torpedo(origin, bearing, dispersion, number, nburst): deadkl(w, iquad, w) return None proutn(crmena(True, iquad, "sector", w)) - # If enemy damaged but not destroyed, try to displace - ang = track.angle + 2.5*(randreal()-0.5) - temp = math.fabs(math.sin(ang)) - if math.fabs(math.cos(ang)) > temp: - temp = math.fabs(math.cos(ang)) - xx = -math.sin(ang)/temp - yy = math.cos(ang)/temp - bumpto.i = int(w.i+xx+0.5) - bumpto.j = int(w.j+yy+0.5) + displacement = course(track.bearing+randreal(-2.4,2.4), distance=2**0.5) + displacement.next() + bumpto = displacement.sector() if not bumpto.valid_sector(): prout(_(" damaged but not destroyed.")) return