Orbital
bsk_rl.utils.orbital
:Utilities for computing orbital events.
- random_orbit(i: float | None = 45.0, alt: float = 500, r_body: float = 6371, e: float = 0, Omega: float | None = None, omega: float | None = 0, f: float | None = None) <MagicMock name='mock.ClassicElements' id='140604236725984'> [source]
Create a set of orbit elements.
Parameters are fixed if specified and randomized if
None
. Defaults to a random circular orbit at 500 km altitude and 45 deg inclination.- Parameters:
i (float | None) – [deg] Inclination, randomized in
[-pi, pi]
.alt (float) – [km] Altitude above r_body.
r_body (float) – [km] Body radius.
e (float) – Eccentricity.
Omega (float | None) – [deg] LAN, randomized in
[0, 2pi]
.omega (float | None) – [deg] Argument of periapsis, randomized in
[0, 2pi]
.f (float | None) – [deg] True anomaly, randomized in
[0, 2pi]
.
- Returns:
orbital elements
- Return type:
ClassicElements
- random_epoch(start: int = 2000, end: int = 2022)[source]
Generate a random epoch in a year range.
Date will always be in the first 28 days of the month.
- Parameters:
start (int) – Initial year.
end (int) – Final year.
- Returns:
Epoch in
YYYY MMM DD HH:MM:SS.SSS (UTC)
format
- lla2ecef(lat: float, long: float, radius: float)[source]
Project LLA to Earth Centered, Earth Fixed location.
- Parameters:
lat (float) – [deg]
long (float) – [deg]
radius (float) – [any]
- elevation(r_sat: ndarray, r_target: ndarray) ndarray [source]
Find the elevation angle from a target to a satellite.
- Parameters:
r_sat (ndarray) – Satellite position(s).
r_target (ndarray) – Target position.
- Returns:
Elevation angle(s)
- Return type:
ndarray
- walker_delta(n_spacecraft: int, n_planes: int, rel_phasing: float, altitude: float, inc: float, clustersize: int = 1, clusterspacing: float = 0) list[<MagicMock name='mock.orbitalMotion.ClassicElements' id='140604236709952'>] [source]
Compute the initial orbit conditions of a Walker-delta constellation.
- Parameters:
n_spacecraft (int) – Number of spacecraft.
n_planes (int) – Number of orbital planes.
rel_phasing (float) – [deg] Relative phasing between planes.
altitude (float) – [m] Altitude above Earth’s surface.
inc (float) – [deg] Inclination.
clustersize (int) – Number of spacecraft in each cluster.
clusterspacing (float) – [deg] Spacing between spacecraft in a cluster.
- Returns:
List of orbital elements
- Return type:
list
- walker_delta_args(n_planes: int, rel_phasing: float = 0.0, altitude: float = 500, inc: float = 45.0, randomize_true_anomaly=True, randomize_lan=True, **walker_delta_kwargs)[source]
Generate a function to generate a randomly phased Walker-delta constellation.
The output of this function should be used to set the
sat_arg_randomizer
of the environment.- Parameters:
n_planes (int) – Number of constellation planes.
rel_phasing (float) – [deg] Relative phasing between planes. Defaults to 0.0.
altitude (float) – [km] Orbit altitude above Earth’s surface.
inc (float) – [deg] Orbit inclination
randomize_true_anomaly – Add a random true anomaly phase shift that is the same for all constellation members on each call.
randomize_lan – Add a random LAN phase shift that is the same for all constellation members on each call.
walker_delta_kwargs – Additional arguments to pass to
walker_delta
.
- rv2HN(r_N: ndarray, v_N: ndarray)[source]
Find the Hill frame rotation matrix from position and velocity.
- Parameters:
r_N (ndarray) – Position vector in the inertial frame
v_N (ndarray) – Velocity vector in the inertial frame
- Returns:
Hill frame rotation matrix HN
- rv2omega(r_N: ndarray, v_N: ndarray)[source]
Find the Hill frame rotation rate from position and velocity.
- Parameters:
r_N (ndarray) – Position vector in the inertial frame
v_N (ndarray) – Velocity vector in the inertial frame
- Returns:
Angular velocity of the Hill frame in the inertial frame
- Return type:
omega_HN_N