-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathnight_time.py
executable file
·58 lines (47 loc) · 1.86 KB
/
night_time.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
#!/usr/bin/env python
import sys
import math
import spyce.load
from spyce.human import to_human_time, to_si_prefix
from spyce.analysis import newton_raphson
def main():
# parse orbited body
if len(sys.argv) <= 1:
print(
'Usage: %s BODY [ALTITUDE]\n'
'Compute the time spent in the dark by a satellite\n'
'If ALTITUDE is not given, the best one is computed\n'
% sys.argv[0], file=sys.stderr)
sys.exit(1)
primary = spyce.load.from_name(sys.argv[1])
R = primary.radius
mu = primary.gravitational_parameter
def f(a):
# note: a for semi-major axis
return 2 * math.asin(R / a) * math.sqrt(a*a*a / mu)
# f''(a) / f'(a)
def ratio(a):
r = R/a
x = 1 - r*r
s = math.asin(r)/r * math.sqrt(x)
return a * (1.5*s - 1) / (.75*s - 2 + 1/x)
if len(sys.argv) > 2:
altitude = float(sys.argv[2])
semi_major_axis = primary.radius + altitude
altitude = to_si_prefix(altitude, 'm')
night_time = to_human_time(f(semi_major_axis))
print('Consider a satellite in a circular orbit around %s' % primary)
print('Time in the dark at altitude %s: %s' % (altitude, night_time))
print('This ignores possible eclipses from natural satellites')
sys.exit(0)
# find a root of f'
# i.e. a local extremum of f
semi_major_axis = newton_raphson(primary.radius+1e-6, ratio=ratio)
night_time = to_human_time(f(semi_major_axis))
altitude = to_si_prefix(semi_major_axis - primary.radius, 'm')
print('Consider a satellite in a circular orbit around %s' % primary)
print('The time spent in the dark is at least %s' % night_time)
print('This is achieved at altitude %s' % altitude)
print('Note that this ignores possible eclipses from natural satellites')
if __name__ == '__main__':
main()