keplemon 1.0.5__cp311-cp311-win_amd64.whl → 1.1.0__cp311-cp311-win_amd64.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.

Potentially problematic release.


This version of keplemon might be problematic. Click here for more details.

Binary file
keplemon/bodies.pyi CHANGED
@@ -1,8 +1,16 @@
1
1
  # flake8: noqa
2
- from keplemon.elements import TLE, CartesianState, Ephemeris, KeplerianState
2
+ from keplemon.elements import (
3
+ TLE,
4
+ CartesianState,
5
+ Ephemeris,
6
+ KeplerianState,
7
+ GeodeticPosition,
8
+ OrbitPlotData,
9
+ TopocentricElements,
10
+ )
3
11
  from keplemon.catalogs import TLECatalog
4
12
  from keplemon.time import Epoch, TimeSpan
5
- from keplemon.events import CloseApproach, CloseApproachReport, HorizonAccessReport
13
+ from keplemon.events import CloseApproach, CloseApproachReport, HorizonAccessReport, FieldOfViewReport
6
14
  from keplemon.propagation import ForceProperties
7
15
 
8
16
  class Earth:
@@ -35,6 +43,9 @@ class Satellite:
35
43
  keplerian_state: KeplerianState | None
36
44
  """Keplerian state of the satellite at the epoch of the TLE, if available"""
37
45
 
46
+ geodetic_position: GeodeticPosition | None
47
+ """Geodetic position of the satellite at the epoch of the TLE, if available"""
48
+
38
49
  def __init__(self) -> None: ...
39
50
  @classmethod
40
51
  def from_tle(cls, tle: TLE) -> Satellite:
@@ -68,6 +79,8 @@ class Satellite:
68
79
  """
69
80
  ...
70
81
 
82
+ def get_plot_data(self, start: Epoch, end: Epoch, step: TimeSpan) -> OrbitPlotData | None: ...
83
+
71
84
  class Constellation:
72
85
 
73
86
  count: int
@@ -77,6 +90,7 @@ class Constellation:
77
90
  """Human-readable name of the constellation"""
78
91
 
79
92
  def __init__(self) -> None: ...
93
+ def get_plot_data(self, start: Epoch, end: Epoch, step: TimeSpan) -> dict[str, OrbitPlotData]: ...
80
94
  @classmethod
81
95
  def from_tle_catalog(cls, tle_catalog: TLECatalog) -> Constellation:
82
96
  """
@@ -255,3 +269,23 @@ class Observatory:
255
269
  Horizon access report for the satellite from the observatory
256
270
  """
257
271
  ...
272
+
273
+ def get_field_of_view_report(
274
+ self,
275
+ epoch: Epoch,
276
+ sensor_direction: TopocentricElements,
277
+ angular_threshold: float,
278
+ sats: Constellation,
279
+ ) -> FieldOfViewReport:
280
+ """
281
+ Calculate field of view report for a sensor at the observatory.
282
+
283
+ Args:
284
+ epoch: UTC epoch of the report
285
+ sensor_direction: Topocentric direction the sensor is pointing
286
+ angular_threshold: Angular threshold in **_degrees_**
287
+ sats: Constellation of satellites to check for being in the field of view
288
+ Returns:
289
+ Field of view report for the sensor at the observatory containing satellites within the field of view
290
+ """
291
+ ...
keplemon/catalogs.pyi CHANGED
@@ -1,5 +1,5 @@
1
1
  # flake8: noqa
2
- from keplemon.elements import TLE
2
+ from keplemon.elements import TLE, OrbitPlotData
3
3
 
4
4
  class TLECatalog:
5
5
  count: int
@@ -14,3 +14,4 @@ class TLECatalog:
14
14
  def get_count(self) -> int: ...
15
15
  def clear(self) -> None: ...
16
16
  def __getitem__(self, satellite_id: str) -> TLE: ...
17
+ def get_plot_data(self) -> OrbitPlotData: ...
keplemon/elements.py CHANGED
@@ -9,6 +9,9 @@ from keplemon._keplemon.elements import ( # type: ignore
9
9
  TopocentricElements,
10
10
  HorizonState,
11
11
  HorizonElements,
12
+ GeodeticPosition,
13
+ OrbitPlotData,
14
+ OrbitPlotState,
12
15
  )
13
16
 
14
17
  __all__ = [
@@ -22,4 +25,7 @@ __all__ = [
22
25
  "TopocentricElements",
23
26
  "HorizonState",
24
27
  "HorizonElements",
28
+ "GeodeticPosition",
29
+ "OrbitPlotData",
30
+ "OrbitPlotState",
25
31
  ]
keplemon/elements.pyi CHANGED
@@ -4,6 +4,39 @@ from keplemon.time import Epoch
4
4
  from keplemon.enums import Classification, KeplerianType, ReferenceFrame
5
5
  from keplemon.events import CloseApproach
6
6
 
7
+ class OrbitPlotData:
8
+ satellite_id: str
9
+ epochs: list[str]
10
+ semi_major_axes: list[float]
11
+ eccentricities: list[float]
12
+ inclinations: list[float]
13
+ raans: list[float]
14
+ radii: list[float]
15
+ apogee_radii: list[float]
16
+ perigee_radii: list[float]
17
+ latitudes: list[float]
18
+ longitudes: list[float]
19
+ altitudes: list[float]
20
+
21
+ class GeodeticPosition:
22
+ """
23
+ Args:
24
+ latitude: Latitude in **_degrees_**
25
+ longitude: Longitude in **_degrees_**
26
+ altitude: Altitude in **_kilometers_**
27
+ """
28
+
29
+ latitude: float
30
+ """Latitude in **_degrees_**"""
31
+
32
+ longitude: float
33
+ """Longitude in **_degrees_**"""
34
+
35
+ altitude: float
36
+ """Altitude in **_kilometers_**"""
37
+
38
+ def __init__(self, latitude: float, longitude: float, altitude: float) -> None: ...
39
+
7
40
  class HorizonElements:
8
41
  """
9
42
  Args:
keplemon/events.py CHANGED
@@ -3,6 +3,15 @@ from keplemon._keplemon.events import ( # type: ignore
3
3
  CloseApproachReport,
4
4
  HorizonAccess,
5
5
  HorizonAccessReport,
6
+ FieldOfViewCandidate,
7
+ FieldOfViewReport,
6
8
  )
7
9
 
8
- __all__ = ["CloseApproach", "CloseApproachReport", "HorizonAccess", "HorizonAccessReport"]
10
+ __all__ = [
11
+ "CloseApproach",
12
+ "CloseApproachReport",
13
+ "HorizonAccess",
14
+ "HorizonAccessReport",
15
+ "FieldOfViewCandidate",
16
+ "FieldOfViewReport",
17
+ ]
keplemon/events.pyi CHANGED
@@ -1,6 +1,29 @@
1
1
  # flake8: noqa
2
2
  from keplemon.time import Epoch, TimeSpan
3
- from keplemon.elements import HorizonState
3
+ from keplemon.elements import HorizonState, CartesianVector, TopocentricElements
4
+
5
+ class FieldOfViewCandidate:
6
+ satellite_id: str
7
+ """ID of the candidate satellite"""
8
+
9
+ direction: TopocentricElements
10
+ """Measured direction to the candidate satellite in the sensor's topocentric frame"""
11
+
12
+ class FieldOfViewReport:
13
+ epoch: Epoch
14
+ """UTC epoch of the field of view report"""
15
+
16
+ sensor_position: CartesianVector
17
+ """TEME position of the sensor in the observatory's topocentric frame in **_kilometers_**"""
18
+
19
+ sensor_direction: TopocentricElements
20
+ """Direction of the sensor in the observatory's topocentric frame"""
21
+
22
+ fov_angle: float
23
+ """Field of view angle of the sensor in **_degrees_**"""
24
+
25
+ candidates: list[FieldOfViewCandidate]
26
+ """List of candidate satellites within the field of view"""
4
27
 
5
28
  class CloseApproach:
6
29
  epoch: Epoch
@@ -3,6 +3,7 @@ from keplemon._keplemon.saal.astro_func_interface import ( # type: ignore
3
3
  ra_dec_to_az_el_time,
4
4
  ra_dec_to_az_el,
5
5
  mean_motion_to_sma,
6
+ topo_date_to_equinox,
6
7
  XA_TOPO_RA,
7
8
  XA_TOPO_DEC,
8
9
  XA_TOPO_AZ,
@@ -14,6 +15,8 @@ from keplemon._keplemon.saal.astro_func_interface import ( # type: ignore
14
15
  XA_TOPO_ELDOT,
15
16
  XA_TOPO_RANGEDOT,
16
17
  XA_TOPO_SIZE,
18
+ YROFEQNX_2000,
19
+ YROFEQNX_CURR,
17
20
  )
18
21
 
19
22
  __all__ = [
@@ -32,4 +35,7 @@ __all__ = [
32
35
  "XA_TOPO_RANGEDOT",
33
36
  "XA_TOPO_SIZE",
34
37
  "mean_motion_to_sma",
38
+ "topo_date_to_equinox",
39
+ "YROFEQNX_2000",
40
+ "YROFEQNX_CURR",
35
41
  ]
@@ -78,6 +78,21 @@ def teme_to_topo(
78
78
  """
79
79
  ...
80
80
 
81
+ def topo_date_to_equinox(yr_of_equinox: int, ds50utc: float, ra: float, dec: float) -> tuple[float, float]:
82
+ """
83
+ Convert topocentric right ascension and declination to equinox coordinates for a given year of equinox.
84
+
85
+ Args:
86
+ yr_of_equinox: Year of the equinox (e.g., 2000 for J2000).
87
+ ds50utc: Epoch in DS50 UTC format.
88
+ ra: Topocentric right ascension in degrees.
89
+ dec: Topocentric declination in degrees.
90
+
91
+ Returns:
92
+ A tuple containing the equinox right ascension and declination in degrees.
93
+ """
94
+ ...
95
+
81
96
  XA_TOPO_AZ: int
82
97
  """Index for topocentric azimuth in degrees."""
83
98
 
@@ -110,3 +125,9 @@ XA_TOPO_DEC: int
110
125
 
111
126
  XA_TOPO_SIZE: int
112
127
  """Size of XA_TOPO_ array"""
128
+
129
+ YROFEQNX_2000: int
130
+ """Year of equinox 2000 constant"""
131
+
132
+ YROFEQNX_CURR: int
133
+ """Year of current equinox constant"""
@@ -0,0 +1,7 @@
1
+ from keplemon._keplemon.saal.sgp4_prop_interface import ( # type: ignore
2
+ reepoch_tle,
3
+ )
4
+
5
+ __all__ = [
6
+ "reepoch_tle",
7
+ ]
@@ -0,0 +1,9 @@
1
+ def reepoch_tle(tle_key: int, new_ds50_epoch: float) -> None:
2
+ """
3
+ Re-epoch a TLE in the SGP4 propagator.
4
+
5
+ Args:
6
+ tle_key: Key of the TLE to re-epoch.
7
+ new_ds50_epoch: New epoch in DS50 format.
8
+ """
9
+ ...
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: keplemon
3
- Version: 1.0.5
3
+ Version: 1.1.0
4
4
  Requires-Dist: requests
5
5
  Requires-Dist: click
6
6
  Requires-Dist: maturin>=1.0,<2.0 ; extra == 'dev'
@@ -1,6 +1,6 @@
1
- keplemon-1.0.5.dist-info/METADATA,sha256=l0b2cTyJbCUpNiCbm8PHD1dSWuq1kEpseFXtf80GMIw,863
2
- keplemon-1.0.5.dist-info/WHEEL,sha256=Ncll1xfKuKRSH9zs2vSEuHQoNZLcJWpzadJbiEni0qk,96
3
- keplemon-1.0.5.dist-info/entry_points.txt,sha256=eYbCkvQvWfRDQ0LzaCELov1xeLAxQEHlfdgNq-LXyb0,49
1
+ keplemon-1.1.0.dist-info/METADATA,sha256=8Ob7y_2GYYtVzAUssxxuo4Mj4HH7eR-sPjzOvE7eaWU,863
2
+ keplemon-1.1.0.dist-info/WHEEL,sha256=YCZ9Vxhf2aXNyfoR2QH-PPqnUr48Igr9zjgnGhp3xTc,96
3
+ keplemon-1.1.0.dist-info/entry_points.txt,sha256=eYbCkvQvWfRDQ0LzaCELov1xeLAxQEHlfdgNq-LXyb0,49
4
4
  keplemon/AstroFunc.dll,sha256=RwDLeYGuSd3MxQ3O_Ljb0maS5KoDL8HZLpAvcQhDmnQ,357376
5
5
  keplemon/AstroFunc.lib,sha256=q0Ob5NGUgbywJg6XqH48QLNmFv8T5p8NVLSx2kKkL4A,56480
6
6
  keplemon/DllMain.dll,sha256=vYgOfGAUHn2z1MrVu9wV-k_LRdtuF8RuWrbuu2xk7jk,121344
@@ -30,7 +30,7 @@ keplemon/Vcm.lib,sha256=q2FPbH_DJXjIzNIzli2f1uV2faHHBjLbffZrL3Nagpw,19404
30
30
  keplemon/__init__.py,sha256=JymfGXbJ9UJDdwRW0CXS7j5j_LPk1_P_ViKbjoTdCFU,861
31
31
  keplemon/__init__.pyi,sha256=PgtL8CNupZCJibx07RLmFf56gMkCFx7voUIxBpeADO8,1349
32
32
  keplemon/__main__.py,sha256=Bbbzny3eE3NOikVCEVFAGJiSRGooAkLzPwoSz-rpaxc,689
33
- keplemon/_keplemon.cp311-win_amd64.pyd,sha256=mbBWFV0i9Ki1_D6uusZg5osCWdeJy4XIUZt68lwTkgU,1480192
33
+ keplemon/_keplemon.cp311-win_amd64.pyd,sha256=tbeza-XTjhaOfOYI25kzlCzruzo7ojTWzfUqKUHwv8s,1626112
34
34
  keplemon/assets/EGM-2008.GEO,sha256=K2nG8HGLATIHZYMfw3GSClYOTCuZ7rq4RdCeUNgCw5A,148770
35
35
  keplemon/assets/EGM-96.GEO,sha256=VBkILuvEMwAPuWmUHy2PeyEfULOwJ4PEJLNf5hr84mU,148770
36
36
  keplemon/assets/GEM_5-22.GEO,sha256=stemYLn1ChXa-VdLGHYfa15AXZa_xxGZQ65p4c3gffI,6852
@@ -43,17 +43,17 @@ keplemon/assets/SGP4_Open_License.txt,sha256=ThQ87DpbbXt-9K0-0U13tcZqsndte_UkaG3
43
43
  keplemon/assets/WGS84-70.GEO,sha256=ARjEC_5s2SVd0Kh9udbTy1ztBwTeuBYPOhUVJgIqit8,148510
44
44
  keplemon/assets/time_constants.dat,sha256=3nsYjFgq0QnTUHPxuQPdtMG-AqxShVbvmG2zPcZfdcA,1246208
45
45
  keplemon/bodies.py,sha256=MjdAGL25eF5pA3KHo5ipjz0DDql5EEEbBqR735M254g,217
46
- keplemon/bodies.pyi,sha256=Cw-Bs_UG96VN-8TZOqmr9QoB-gwfA9q6NBvLeLJiawA,7526
46
+ keplemon/bodies.pyi,sha256=ANgociClcS9hhzvA-g57HHDQfExED3z0QvOxBWWWCiM,8733
47
47
  keplemon/catalogs.py,sha256=AKONH7zWBOnUZI0ty0lYiYZtrdILfKivoUgk1nU3PZ8,107
48
- keplemon/catalogs.pyi,sha256=0xKUNjmioF_cd5atqiGbRxaZuTUIBr2hbEJ0J0A4c-s,540
49
- keplemon/elements.py,sha256=AzE0xyBNDynGtBcIkpQaV7qHW-xNdA9bFkIcr5CC1oY,506
50
- keplemon/elements.pyi,sha256=qbUm5uQ9FNjQP5b99K8NxeaC6xnDSSaaY8NnofoAJIg,9811
48
+ keplemon/catalogs.pyi,sha256=UxwRVMfuySXNYOQ7KuCXtwHcu3zL3Fgo1sBP77qUKaU,606
49
+ keplemon/elements.py,sha256=Z0zzwjbOnqi4lXO4Iw5Nio2eZcdrlObzAJ2oLRDzyJY,640
50
+ keplemon/elements.pyi,sha256=EQEqEduwsMqhKjLPbbVS3eyGxNRQitLfzM8KhuxPDLs,10647
51
51
  keplemon/enums.py,sha256=5MejXeSwXPtfpIYeNuFQH3LSIRf4aTFZTK2Q1AYyaEg,325
52
52
  keplemon/enums.pyi,sha256=OSS71WesYTgzWGUSjpxaYtzj6XmoyLBXq_Zd13IBwyQ,2418
53
53
  keplemon/estimation.py,sha256=Of0rHiapW4s1wRipBCZrp4oOiIzs794w1nhqM7AVrGs,236
54
54
  keplemon/estimation.pyi,sha256=kH-erT5qhxKVpHm9NehHsZbHbe96FP3aDX6GgwdntAs,5693
55
- keplemon/events.py,sha256=MNf_CCxbTr-MoUoFAbB78rSqKNAT0_EmRjhWFvaGGKI,246
56
- keplemon/events.pyi,sha256=bncrIlvZbPFEZZf0HIPkDvRqOLIViU0W4_UJdh-pcTo,2098
55
+ keplemon/events.py,sha256=gl2eqYWkTtMxLPstZziIbNbeVHJzEiMPyhrFaC-gcmA,376
56
+ keplemon/events.pyi,sha256=o24TRnO4pZ2gh0aeJvxFsLj_SrBV3s3SvPrAdx0TmxU,2909
57
57
  keplemon/exceptions.py,sha256=kdFwToNBHfbpzj311wHfTDztdgwRg2-OM3sHYhmd3AI,107
58
58
  keplemon/libifcoremd.dll,sha256=x8iFLCgtUCJjWdfdmQycUx9BlXcNCW-Q3MeGpcIN12k,1885224
59
59
  keplemon/libiomp5md.dll,sha256=C2O3Lj2yJYPGTyH0Z1c4FSrflnSzxHARp6y0dE3H2ZI,2030632
@@ -63,12 +63,14 @@ keplemon/propagation.pyi,sha256=BjBIlp_8fdEb5gii5OsvLtXfIzV_Mo2pLlX75bZ1SDo,715
63
63
  keplemon/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
64
64
  keplemon/saal/__init__.py,sha256=JS-tjVFqN1B3ZjIG2g7v1GrmUPi9eIv0_Le1reYuQ2o,126
65
65
  keplemon/saal/__init__.pyi,sha256=7wosTC1KhEJis-zp2LlZmW7hlr8BzFO4gx0TJ9c3J80,148
66
- keplemon/saal/astro_func_interface.py,sha256=6Y26Qtpg-vf4K5pya2DRzPyv4_4vnp9vmnribbpqYyw,737
67
- keplemon/saal/astro_func_interface.pyi,sha256=b0QKQhoeBWZ1ouuux9ZoojHpNNnHlNz_bi8kalBgSA0,2808
66
+ keplemon/saal/astro_func_interface.py,sha256=ZiGQm-ysZbH0ocLFzYHgLVGWuNabO5obLMVuv6nSTPQ,877
67
+ keplemon/saal/astro_func_interface.pyi,sha256=cwsPQlowxLr3tj8EKP1wJhd_qOLpk4yRef-PyGCnAxU,3504
68
68
  keplemon/saal/obs_interface.py,sha256=ax8T4Y61pWh3VnQ4K2bCDNdrK-H6WKWr14pEDAY8WxE,257
69
69
  keplemon/saal/obs_interface.pyi,sha256=Y9PE1t2Kdz1Sne1t_M-ctOp9G4hWGKgMMkuES6v1U6Q,235
70
+ keplemon/saal/sgp4_prop_interface.py,sha256=biuhXWIsauR4BO8chsWILfb8-E8OdRNWT5cSL3OYsVQ,134
71
+ keplemon/saal/sgp4_prop_interface.pyi,sha256=9NpOUhf03VQYVEyq1Kutqp6J6bZ3x0NCFSBlVY-Nb9s,244
70
72
  keplemon/saal/time_func_interface.py,sha256=C18Q_PIMUFBcB0pHN6wlVj35Vrt83VQNKOEmHDHvZSA,438
71
73
  keplemon/saal/time_func_interface.pyi,sha256=3QKtsuxMoTgG--bDvbVNcJyD8vfcAUlw2n69g1m0kNM,1578
72
74
  keplemon/time.py,sha256=fa6AKPPU18lX44emrAy5ZZ5TRam-Vhm8ecsauvQ_wdg,2888
73
75
  keplemon/time.pyi,sha256=bS5UrY2loeT2mzONRFl2LTG5ZLaC3EnCXKB8fZRks4Q,6529
74
- keplemon-1.0.5.dist-info/RECORD,,
76
+ keplemon-1.1.0.dist-info/RECORD,,
@@ -1,4 +1,4 @@
1
1
  Wheel-Version: 1.0
2
- Generator: maturin (1.9.3)
2
+ Generator: maturin (1.9.4)
3
3
  Root-Is-Purelib: false
4
4
  Tag: cp311-cp311-win_amd64