open-space-toolkit-astrodynamics 17.2.0__py312-none-manylinux2014_x86_64.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- open_space_toolkit_astrodynamics-17.2.0.dist-info/METADATA +30 -0
- open_space_toolkit_astrodynamics-17.2.0.dist-info/RECORD +151 -0
- open_space_toolkit_astrodynamics-17.2.0.dist-info/WHEEL +5 -0
- open_space_toolkit_astrodynamics-17.2.0.dist-info/top_level.txt +1 -0
- open_space_toolkit_astrodynamics-17.2.0.dist-info/zip-safe +1 -0
- ostk/__init__.py +1 -0
- ostk/astrodynamics/OpenSpaceToolkitAstrodynamicsPy.cpython-312-x86_64-linux-gnu.so +0 -0
- ostk/astrodynamics/__init__.py +11 -0
- ostk/astrodynamics/__init__.pyi +720 -0
- ostk/astrodynamics/access.pyi +577 -0
- ostk/astrodynamics/conjunction/__init__.pyi +121 -0
- ostk/astrodynamics/conjunction/close_approach.pyi +89 -0
- ostk/astrodynamics/conjunction/message/__init__.pyi +3 -0
- ostk/astrodynamics/conjunction/message/ccsds.pyi +705 -0
- ostk/astrodynamics/converters.py +130 -0
- ostk/astrodynamics/converters.pyi +58 -0
- ostk/astrodynamics/data/__init__.pyi +3 -0
- ostk/astrodynamics/data/provider.pyi +22 -0
- ostk/astrodynamics/dataframe.py +597 -0
- ostk/astrodynamics/display.py +281 -0
- ostk/astrodynamics/dynamics.pyi +311 -0
- ostk/astrodynamics/eclipse.pyi +70 -0
- ostk/astrodynamics/estimator.pyi +268 -0
- ostk/astrodynamics/event_condition.pyi +910 -0
- ostk/astrodynamics/flight/__init__.pyi +626 -0
- ostk/astrodynamics/flight/profile/__init__.pyi +99 -0
- ostk/astrodynamics/flight/profile/model.pyi +179 -0
- ostk/astrodynamics/flight/system.pyi +268 -0
- ostk/astrodynamics/guidance_law.pyi +416 -0
- ostk/astrodynamics/libopen-space-toolkit-astrodynamics.so.17 +0 -0
- ostk/astrodynamics/pytrajectory/__init__.py +1 -0
- ostk/astrodynamics/pytrajectory/__init__.pyi +3 -0
- ostk/astrodynamics/pytrajectory/pystate.py +263 -0
- ostk/astrodynamics/pytrajectory/pystate.pyi +66 -0
- ostk/astrodynamics/solver.pyi +432 -0
- ostk/astrodynamics/test/__init__.py +1 -0
- ostk/astrodynamics/test/access/__init__.py +1 -0
- ostk/astrodynamics/test/access/test_generator.py +319 -0
- ostk/astrodynamics/test/access/test_visibility_criterion.py +201 -0
- ostk/astrodynamics/test/conftest.py +119 -0
- ostk/astrodynamics/test/conjunction/close_approach/__init__.py +0 -0
- ostk/astrodynamics/test/conjunction/close_approach/test_generator.py +228 -0
- ostk/astrodynamics/test/conjunction/message/ccsds/__init__.py +1 -0
- ostk/astrodynamics/test/conjunction/message/ccsds/conftest.py +325 -0
- ostk/astrodynamics/test/conjunction/message/ccsds/data/cdm.json +303 -0
- ostk/astrodynamics/test/conjunction/message/ccsds/test_cdm.py +416 -0
- ostk/astrodynamics/test/conjunction/test_close_approach.py +244 -0
- ostk/astrodynamics/test/data/provider/test_off_nadir.py +58 -0
- ostk/astrodynamics/test/dynamics/__init__.py +1 -0
- ostk/astrodynamics/test/dynamics/data/Tabulated_Earth_Gravity.csv +565 -0
- ostk/astrodynamics/test/dynamics/data/Tabulated_Earth_Gravity_Truth.csv +100 -0
- ostk/astrodynamics/test/dynamics/test_atmospheric_drag.py +128 -0
- ostk/astrodynamics/test/dynamics/test_central_body_gravity.py +58 -0
- ostk/astrodynamics/test/dynamics/test_dynamics.py +50 -0
- ostk/astrodynamics/test/dynamics/test_position_derivative.py +51 -0
- ostk/astrodynamics/test/dynamics/test_tabulated.py +138 -0
- ostk/astrodynamics/test/dynamics/test_third_body_gravity.py +67 -0
- ostk/astrodynamics/test/dynamics/test_thruster.py +157 -0
- ostk/astrodynamics/test/eclipse/__init__.py +1 -0
- ostk/astrodynamics/test/eclipse/test_generator.py +138 -0
- ostk/astrodynamics/test/estimator/test_orbit_determination_solver.py +261 -0
- ostk/astrodynamics/test/estimator/test_tle_solver.py +216 -0
- ostk/astrodynamics/test/event_condition/test_angular_condition.py +113 -0
- ostk/astrodynamics/test/event_condition/test_boolean_condition.py +55 -0
- ostk/astrodynamics/test/event_condition/test_brouwer_lyddane_mean_long_condition.py +135 -0
- ostk/astrodynamics/test/event_condition/test_coe_condition.py +135 -0
- ostk/astrodynamics/test/event_condition/test_instant_condition.py +48 -0
- ostk/astrodynamics/test/event_condition/test_logical_condition.py +120 -0
- ostk/astrodynamics/test/event_condition/test_real_condition.py +50 -0
- ostk/astrodynamics/test/flight/__init__.py +1 -0
- ostk/astrodynamics/test/flight/profile/model/test_tabulated_profile.py +115 -0
- ostk/astrodynamics/test/flight/system/__init__.py +1 -0
- ostk/astrodynamics/test/flight/system/test_propulsion_system.py +64 -0
- ostk/astrodynamics/test/flight/system/test_satellite_system.py +83 -0
- ostk/astrodynamics/test/flight/system/test_satellite_system_builder.py +71 -0
- ostk/astrodynamics/test/flight/test_maneuver.py +231 -0
- ostk/astrodynamics/test/flight/test_profile.py +293 -0
- ostk/astrodynamics/test/flight/test_system.py +45 -0
- ostk/astrodynamics/test/guidance_law/test_constant_thrust.py +177 -0
- ostk/astrodynamics/test/guidance_law/test_guidance_law.py +60 -0
- ostk/astrodynamics/test/guidance_law/test_heterogeneous_guidance_law.py +164 -0
- ostk/astrodynamics/test/guidance_law/test_qlaw.py +209 -0
- ostk/astrodynamics/test/solvers/__init__.py +1 -0
- ostk/astrodynamics/test/solvers/test_finite_difference_solver.py +196 -0
- ostk/astrodynamics/test/solvers/test_least_squares_solver.py +334 -0
- ostk/astrodynamics/test/solvers/test_temporal_condition_solver.py +161 -0
- ostk/astrodynamics/test/test_access.py +128 -0
- ostk/astrodynamics/test/test_converters.py +290 -0
- ostk/astrodynamics/test/test_dataframe.py +1355 -0
- ostk/astrodynamics/test/test_display.py +184 -0
- ostk/astrodynamics/test/test_event_condition.py +80 -0
- ostk/astrodynamics/test/test_import.py +26 -0
- ostk/astrodynamics/test/test_root_solver.py +70 -0
- ostk/astrodynamics/test/test_trajectory.py +126 -0
- ostk/astrodynamics/test/test_utilities.py +338 -0
- ostk/astrodynamics/test/test_viewer.py +318 -0
- ostk/astrodynamics/test/trajectory/__init__.py +1 -0
- ostk/astrodynamics/test/trajectory/model/test_nadir_trajectory.py +87 -0
- ostk/astrodynamics/test/trajectory/model/test_tabulated_trajectory.py +303 -0
- ostk/astrodynamics/test/trajectory/model/test_target_scan_trajectory.py +126 -0
- ostk/astrodynamics/test/trajectory/orbit/__init__.py +1 -0
- ostk/astrodynamics/test/trajectory/orbit/message/__init__.py +1 -0
- ostk/astrodynamics/test/trajectory/orbit/message/spacex/__init__.py +1 -0
- ostk/astrodynamics/test/trajectory/orbit/message/spacex/conftest.py +18 -0
- ostk/astrodynamics/test/trajectory/orbit/message/spacex/data/opm_1.yaml +44 -0
- ostk/astrodynamics/test/trajectory/orbit/message/spacex/test_opm.py +108 -0
- ostk/astrodynamics/test/trajectory/orbit/models/__init__.py +1 -0
- ostk/astrodynamics/test/trajectory/orbit/models/kepler/__init__.py +1 -0
- ostk/astrodynamics/test/trajectory/orbit/models/kepler/test_brouwer_lyddane_mean.py +65 -0
- ostk/astrodynamics/test/trajectory/orbit/models/kepler/test_brouwer_lyddane_mean_long.py +102 -0
- ostk/astrodynamics/test/trajectory/orbit/models/kepler/test_brouwer_lyddane_mean_short.py +102 -0
- ostk/astrodynamics/test/trajectory/orbit/models/kepler/test_coe.py +305 -0
- ostk/astrodynamics/test/trajectory/orbit/models/sgp4/__init__.py +1 -0
- ostk/astrodynamics/test/trajectory/orbit/models/sgp4/test_tle.py +337 -0
- ostk/astrodynamics/test/trajectory/orbit/models/test_kepler.py +130 -0
- ostk/astrodynamics/test/trajectory/orbit/models/test_modified_equinoctial.py +142 -0
- ostk/astrodynamics/test/trajectory/orbit/models/test_propagated.py +234 -0
- ostk/astrodynamics/test/trajectory/orbit/models/test_sgp4.py +1 -0
- ostk/astrodynamics/test/trajectory/orbit/models/test_tabulated.py +380 -0
- ostk/astrodynamics/test/trajectory/orbit/test_model.py +1 -0
- ostk/astrodynamics/test/trajectory/orbit/test_pass.py +75 -0
- ostk/astrodynamics/test/trajectory/state/coordinate_subset/test_angular_velocity.py +30 -0
- ostk/astrodynamics/test/trajectory/state/coordinate_subset/test_attitude_quaternion.py +18 -0
- ostk/astrodynamics/test/trajectory/state/coordinate_subset/test_cartesian_acceleration.py +136 -0
- ostk/astrodynamics/test/trajectory/state/coordinate_subset/test_cartesian_position.py +107 -0
- ostk/astrodynamics/test/trajectory/state/coordinate_subset/test_cartesian_velocity.py +115 -0
- ostk/astrodynamics/test/trajectory/state/test_coordinate_broker.py +84 -0
- ostk/astrodynamics/test/trajectory/state/test_coordinate_subset.py +58 -0
- ostk/astrodynamics/test/trajectory/state/test_numerical_solver.py +316 -0
- ostk/astrodynamics/test/trajectory/test_local_orbital_frame_direction.py +81 -0
- ostk/astrodynamics/test/trajectory/test_local_orbital_frame_factory.py +119 -0
- ostk/astrodynamics/test/trajectory/test_model.py +1 -0
- ostk/astrodynamics/test/trajectory/test_orbit.py +212 -0
- ostk/astrodynamics/test/trajectory/test_propagator.py +452 -0
- ostk/astrodynamics/test/trajectory/test_segment.py +694 -0
- ostk/astrodynamics/test/trajectory/test_sequence.py +550 -0
- ostk/astrodynamics/test/trajectory/test_state.py +629 -0
- ostk/astrodynamics/test/trajectory/test_state_builder.py +172 -0
- ostk/astrodynamics/trajectory/__init__.pyi +1982 -0
- ostk/astrodynamics/trajectory/model.pyi +259 -0
- ostk/astrodynamics/trajectory/orbit/__init__.pyi +349 -0
- ostk/astrodynamics/trajectory/orbit/message/__init__.pyi +3 -0
- ostk/astrodynamics/trajectory/orbit/message/spacex.pyi +264 -0
- ostk/astrodynamics/trajectory/orbit/model/__init__.pyi +648 -0
- ostk/astrodynamics/trajectory/orbit/model/brouwerLyddaneMean.pyi +121 -0
- ostk/astrodynamics/trajectory/orbit/model/kepler.pyi +709 -0
- ostk/astrodynamics/trajectory/orbit/model/sgp4.pyi +330 -0
- ostk/astrodynamics/trajectory/state/__init__.pyi +402 -0
- ostk/astrodynamics/trajectory/state/coordinate_subset.pyi +208 -0
- ostk/astrodynamics/utilities.py +396 -0
- ostk/astrodynamics/viewer.py +851 -0
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
# Apache License 2.0
|
|
2
|
+
|
|
3
|
+
import pytest
|
|
4
|
+
|
|
5
|
+
import numpy as np
|
|
6
|
+
|
|
7
|
+
from ostk.physics.time import Instant
|
|
8
|
+
from ostk.physics.time import DateTime
|
|
9
|
+
from ostk.physics.time import Scale
|
|
10
|
+
from ostk.physics.coordinate import Frame
|
|
11
|
+
|
|
12
|
+
from ostk.astrodynamics.trajectory import (
|
|
13
|
+
State,
|
|
14
|
+
StateBuilder,
|
|
15
|
+
)
|
|
16
|
+
from ostk.astrodynamics.trajectory.state import (
|
|
17
|
+
CoordinateBroker,
|
|
18
|
+
CoordinateSubset,
|
|
19
|
+
)
|
|
20
|
+
from ostk.astrodynamics.trajectory.state.coordinate_subset import (
|
|
21
|
+
CartesianPosition,
|
|
22
|
+
CartesianVelocity,
|
|
23
|
+
)
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
@pytest.fixture()
|
|
27
|
+
def instant() -> Instant:
|
|
28
|
+
return Instant.date_time(DateTime(2018, 1, 1, 0, 0, 0), Scale.UTC)
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
@pytest.fixture
|
|
32
|
+
def frame() -> Frame:
|
|
33
|
+
return Frame.GCRF()
|
|
34
|
+
|
|
35
|
+
|
|
36
|
+
@pytest.fixture
|
|
37
|
+
def coordinate_subsets() -> list[CoordinateSubset]:
|
|
38
|
+
return [CartesianPosition.default(), CartesianVelocity.default()]
|
|
39
|
+
|
|
40
|
+
|
|
41
|
+
@pytest.fixture
|
|
42
|
+
def coordinates() -> list[float]:
|
|
43
|
+
return [1.0, 2.0, 3.0, 4.0, 5.0, 6.0]
|
|
44
|
+
|
|
45
|
+
|
|
46
|
+
@pytest.fixture
|
|
47
|
+
def coordinate_broker(
|
|
48
|
+
coordinate_subsets: list[CoordinateSubset],
|
|
49
|
+
) -> CoordinateBroker:
|
|
50
|
+
return CoordinateBroker(coordinate_subsets)
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
@pytest.fixture
|
|
54
|
+
def state(
|
|
55
|
+
instant: Instant,
|
|
56
|
+
coordinates: list[float],
|
|
57
|
+
frame: Frame,
|
|
58
|
+
coordinate_broker: CoordinateBroker,
|
|
59
|
+
) -> State:
|
|
60
|
+
return State(instant, coordinates, frame, coordinate_broker)
|
|
61
|
+
|
|
62
|
+
|
|
63
|
+
@pytest.fixture
|
|
64
|
+
def state_builder(frame: Frame, coordinate_broker: CoordinateBroker) -> State:
|
|
65
|
+
return StateBuilder(frame, coordinate_broker)
|
|
66
|
+
|
|
67
|
+
|
|
68
|
+
class TestStateBuilder:
|
|
69
|
+
def test_broker_constructor(
|
|
70
|
+
self,
|
|
71
|
+
frame: Frame,
|
|
72
|
+
coordinate_broker: CoordinateBroker,
|
|
73
|
+
):
|
|
74
|
+
builder = StateBuilder(frame, coordinate_broker)
|
|
75
|
+
assert builder is not None
|
|
76
|
+
assert isinstance(builder, StateBuilder)
|
|
77
|
+
assert builder.is_defined()
|
|
78
|
+
|
|
79
|
+
def test_subsets_constructor(
|
|
80
|
+
self,
|
|
81
|
+
frame: Frame,
|
|
82
|
+
coordinate_subsets: list[CoordinateSubset],
|
|
83
|
+
):
|
|
84
|
+
builder = StateBuilder(frame, coordinate_subsets)
|
|
85
|
+
assert builder is not None
|
|
86
|
+
assert isinstance(builder, StateBuilder)
|
|
87
|
+
assert builder.is_defined()
|
|
88
|
+
|
|
89
|
+
def test_state_constructor(
|
|
90
|
+
self,
|
|
91
|
+
state: State,
|
|
92
|
+
):
|
|
93
|
+
builder = StateBuilder(state)
|
|
94
|
+
assert builder is not None
|
|
95
|
+
assert isinstance(builder, StateBuilder)
|
|
96
|
+
assert builder.is_defined()
|
|
97
|
+
|
|
98
|
+
def test_comparators(self, state_builder: StateBuilder):
|
|
99
|
+
assert (state_builder == state_builder) is True
|
|
100
|
+
assert (state_builder != state_builder) is False
|
|
101
|
+
|
|
102
|
+
def test_operators(
|
|
103
|
+
self,
|
|
104
|
+
state_builder: StateBuilder,
|
|
105
|
+
):
|
|
106
|
+
added_builder: StateBuilder = state_builder + CoordinateSubset.mass()
|
|
107
|
+
assert isinstance(added_builder, StateBuilder)
|
|
108
|
+
assert state_builder != added_builder
|
|
109
|
+
|
|
110
|
+
subtracted_builder: StateBuilder = state_builder - CartesianPosition.default()
|
|
111
|
+
assert isinstance(subtracted_builder, StateBuilder)
|
|
112
|
+
assert state_builder != subtracted_builder
|
|
113
|
+
|
|
114
|
+
def test_build(
|
|
115
|
+
self,
|
|
116
|
+
instant: Instant,
|
|
117
|
+
state_builder: StateBuilder,
|
|
118
|
+
):
|
|
119
|
+
coordinates = [1, 2, 3, 1, 2, 3]
|
|
120
|
+
state: State = state_builder.build(instant, coordinates)
|
|
121
|
+
|
|
122
|
+
assert state is not None
|
|
123
|
+
assert isinstance(state, State)
|
|
124
|
+
assert state.is_defined()
|
|
125
|
+
assert state.get_instant() == instant
|
|
126
|
+
assert (state.get_coordinates() == coordinates).all()
|
|
127
|
+
assert state.get_frame() == state_builder.get_frame()
|
|
128
|
+
assert state.get_coordinate_subsets() == state_builder.get_coordinate_subsets()
|
|
129
|
+
|
|
130
|
+
def test_reduce(
|
|
131
|
+
self,
|
|
132
|
+
state: State,
|
|
133
|
+
):
|
|
134
|
+
builder = StateBuilder(state.get_frame(), [CartesianPosition.default()])
|
|
135
|
+
reduced_state: State = builder.reduce(state)
|
|
136
|
+
|
|
137
|
+
assert isinstance(reduced_state, State)
|
|
138
|
+
assert state != reduced_state
|
|
139
|
+
|
|
140
|
+
def test_expand(
|
|
141
|
+
self,
|
|
142
|
+
state: State,
|
|
143
|
+
):
|
|
144
|
+
builder = StateBuilder(
|
|
145
|
+
state.get_frame(),
|
|
146
|
+
[
|
|
147
|
+
CartesianPosition.default(),
|
|
148
|
+
CartesianVelocity.default(),
|
|
149
|
+
CoordinateSubset.mass(),
|
|
150
|
+
],
|
|
151
|
+
)
|
|
152
|
+
default_state: State = State(
|
|
153
|
+
state.get_instant(),
|
|
154
|
+
[100],
|
|
155
|
+
state.get_frame(),
|
|
156
|
+
CoordinateBroker([CoordinateSubset.mass()]),
|
|
157
|
+
)
|
|
158
|
+
expanded_state: State = builder.expand(state, default_state)
|
|
159
|
+
|
|
160
|
+
assert isinstance(expanded_state, State)
|
|
161
|
+
assert state != expanded_state
|
|
162
|
+
assert default_state != expanded_state
|
|
163
|
+
|
|
164
|
+
def test_getters(
|
|
165
|
+
self,
|
|
166
|
+
state_builder: StateBuilder,
|
|
167
|
+
frame: Frame,
|
|
168
|
+
coordinate_broker: CoordinateBroker,
|
|
169
|
+
):
|
|
170
|
+
assert state_builder.get_frame() == frame
|
|
171
|
+
assert state_builder.get_coordinate_subsets() == coordinate_broker.get_subsets()
|
|
172
|
+
assert state_builder.get_size() == coordinate_broker.get_number_of_coordinates()
|