Skip to main content

sidereon_core/
lib.rs

1//! # sidereon-core
2//!
3//! The complete Sidereon engine in one crate. It folds the numerical
4//! astrodynamics core (orbit propagation, force models, frames, time, SGP4)
5//! together with the GNSS domain layer (SP3, broadcast ephemeris, multi-GNSS
6//! positioning, RTK/PPP, ionosphere/troposphere, DOP).
7//!
8//! - The propagation/astro layer is always present under the [`astro`] module.
9//! - The GNSS layer lives behind the default-on `gnss` cargo feature, so a
10//!   propagation-only consumer can build with `--no-default-features` (plus
11//!   any astro features it wants) and never compile the IONEX/SP3 parsers.
12//!
13//! The GNSS façade is organized by user-facing tasks:
14//!
15//! - [`ephemeris`] - precise SP3 and broadcast ephemeris products,
16//! - [`rinex`] - RINEX navigation/observation parsing and CRINEX decoding,
17//! - [`antex`] - ANTEX receiver and satellite antenna calibration parsing,
18//! - [`combinations`] - observable linear combinations such as ionosphere-free,
19//! - [`observables`] - forward range, Doppler, and azimuth/elevation prediction,
20//! - [`velocity`] - receiver velocity and clock-drift solve from range-rate data,
21//! - [`positioning`] - single-point positioning and DOP diagnostics,
22//! - [`dgnss`] - code-differential pseudorange correction and rover pairing,
23//! - [`quality`] - pseudorange weighting, RAIM, and FDE integrity checks,
24//! - [`observation_qc`] - RINEX observation completeness and signal rollups,
25//! - [`signal`] - GPS C/A code generation, correlation, and acquisition,
26//! - [`ppp_corrections`] - static-arc PPP correction precomputation,
27//! - [`atmosphere`] - ionosphere and troposphere corrections,
28//! - [`orbit`] - compact reduced-orbit fitting/evaluation.
29//!
30//! Implementation modules (`sp3`, `rinex_nav`, `spp`, etc.) are crate-private.
31//! This is a clean public surface rather than a compatibility shim around the
32//! original implementation-shaped module layout.
33//!
34//! ## Units policy (internal representation)
35//!
36//! All quantities are stored and computed in **SI base units**, with the frame
37//! and datum encoded in the type name (per the spec's frames-in-the-type-system
38//! rule), never hidden behind a bare `position_m`:
39//!
40//! - **Length / position:** meters (`_m`). SP3 positions are ITRF/IGS-frame
41//!   ECEF meters; SPP receiver positions are WGS84/ITRF-compatible ECEF meters.
42//!   (The [`astro`] state layer works in kilometers; conversions happen
43//!   explicitly at the boundary, never implicitly.)
44//! - **Time / clock:** seconds (`_s`). Epochs are represented by the [`astro`]
45//!   time family (`Instant`/`TimeScale`), always scale-tagged; there is no bare
46//!   ambiguous epoch.
47//! - **Velocity:** meters per second (`_m_s`).
48//! - **Angles:** radians (`_rad`) internally. Degrees appear only at I/O edges
49//!   and are named `_deg`.
50//! - **Frequency:** hertz (`_hz`).
51//!
52//! Field and parameter names carry the unit suffix so the unit is visible at
53//! every call site. Matrix/vector linear algebra uses `nalgebra`
54//! (`DMatrix`/`DVector`) per the spec.
55
56extern crate self as sidereon_core;
57
58// ---------------------------------------------------------------------------
59// Astro / propagation layer. Always present. The GNSS layer below depends on
60// it via `crate::astro::*`.
61// ---------------------------------------------------------------------------
62
63mod validate;
64
65#[cfg(all(test, sidereon_repo_tests))]
66mod test_parity;
67
68pub mod astro;
69pub(crate) mod format;
70
71// ---------------------------------------------------------------------------
72// GNSS domain layer. Behind the default-on `gnss` feature so a propagation-only
73// consumer can opt out. Additional product modules are added as each lands.
74// ---------------------------------------------------------------------------
75
76mod ambiguity; // shared RTK/PPP cycle-slip policy + wide-lane/narrow-lane prep
77mod antenna; // shared ANTEX PCV/PCO zenith/azimuth interpolation kernels
78pub mod antex; // ANTEX receiver/satellite antenna parser + PCO/PCV lookup
79pub mod araim; // advanced RAIM multi-hypothesis protection levels
80pub mod bias; // Bias-SINEX and DCB bias products
81mod broadcast; // broadcast-ephemeris (GPS LNAV / Galileo I/NAV) orbit + clock
82pub mod broadcast_comparison; // broadcast-vs-precise (SISRE orbit/clock) accuracy
83pub mod carrier_phase; // carrier-phase combinations, cycle-slip detection, Hatch smoothing
84pub mod clock_stability; // Allan-family receiver clock stability estimators
85pub mod constants; // shared physical/time constants (used by astro + gnss)
86pub mod constellation; // GNSS constellation identity catalog (CelesTrak/NAVCEN)
87mod crinex; // Hatanaka (CRINEX) observation-file decoder
88pub mod data; // sans-IO GNSS product filename and archive URL catalog
89pub mod dop; // dilution-of-precision geometry (GDOP/PDOP/HDOP/VDOP/TDOP)
90pub mod error_metrics; // covariance-derived CEP, radial, and ellipse metrics
91pub mod frequencies; // canonical GNSS carrier-frequency table
92mod glonass; // GLONASS PZ-90.11 state-vector RK4 propagation
93mod ionex; // Klobuchar broadcast model + IONEX ionospheric maps
94pub mod navigation; // navigation-message bit-level codecs (GPS LNAV)
95pub mod nmea; // NMEA 0183 sentence parsing, stream grouping, and GGA writing
96pub mod ntrip; // NTRIP client sans-I/O request, response, and stream handling
97pub mod observables; // forward GNSS observable prediction
98pub mod ppp_corrections; // static-arc PPP correction tables
99pub mod precise_positioning; // static multi-epoch PPP float solve
100mod reduced_orbit; // compact mean-element orbit approximation (fitted)
101mod rinex_clock; // RINEX clock satellite-bias parsing and interpolation
102mod rinex_common; // shared RINEX header concepts (time-system label mapping)
103mod rinex_nav; // RINEX 3 navigation-message parsing (GPS/Galileo broadcast)
104mod rinex_obs; // RINEX 3 observation parsing + single-frequency pseudoranges
105mod rinex_qc; // RINEX observation/navigation lint and mechanical repair
106pub mod rtcm; // RTCM 3 differential-GNSS stream decode/encode (MSM, station, ephemeris)
107pub mod rtk; // RTK double-difference construction
108pub mod sbas;
109pub mod sbas_pl; // SBAS single-hypothesis protection levels
110pub mod sidereal; // repeating-geometry residual filtering and period diagnostics
111pub mod signal; // GPS C/A code, coherent correlation, and acquisition
112pub mod source_localization; // ToA/TDOA source localization from arrival times
113mod sp3; // SP3-c / SP3-d parser + arbitrary-epoch interpolation
114mod spp; // single-point positioning (least-squares PVT)
115pub mod ssr; // SSR correction store and corrected broadcast ephemeris source
116pub mod staleness; // product-staleness graceful degradation for time-varying products
117mod tropo; // Saastamoinen zenith + Niell (NMF) mapping troposphere
118pub mod velocity; // receiver velocity / clock-drift least-squares solve
119
120mod error;
121pub mod frame;
122pub mod frame_catalog;
123mod id;
124
125pub mod atmosphere;
126pub mod combinations;
127pub mod dgnss;
128pub mod ephemeris;
129pub mod estimation; // Phase-2 estimation substrate: named operation-order recipes
130pub mod geodesic; // WGS84 geodesic direct and inverse solvers
131pub mod geodetic_time_series; // robust station velocity, trajectory, steps, and fields
132pub mod geoid; // geoid undulation grid + bilinear interpolation (orthometric heights)
133pub mod geometry;
134pub mod geometry_quality;
135pub mod ils; // integer least squares ambiguity-resolution kernels
136pub mod inertial; // ECEF strapdown INS frames, mechanization, and IMU error model
137pub mod integrity; // shared protection and covariance primitives
138pub mod observation_qc; // RINEX observation completeness and signal rollups
139pub mod qc_obs {
140    //! RINEX observation quality-control rollups.
141    pub use crate::observation_qc::*;
142}
143pub mod orbit;
144pub mod orbit_determination;
145pub mod positioning;
146pub mod prelude;
147pub mod quality; // measurement weighting, RAIM, and FDE integrity checks
148pub mod rinex;
149pub mod rtk_filter; // sequential RTK baseline filter - serializable state ABI (kernel migration)
150pub mod terrain;
151pub mod terrain_store;
152pub mod tides;
153pub mod tolerances;
154
155pub mod fusion; // GNSS/INS error-state prediction and EKF correction over the inertial surface
156
157pub use crate::astro::frames::{
158    EarthOrientation, EarthOrientationProvider, TdbEarthOrientationProvider,
159};
160pub use crate::error_metrics::{
161    error_ellipse_from_enu_m2, horizontal_radius_at, metrics_from_ecef_covariance_m2,
162    metrics_from_enu_covariance_m2, metrics_from_kinematic_solution,
163    metrics_from_position_covariance, spherical_radius_at, vertical_radius_at, ErrorEllipse,
164    ErrorMetricsError, PercentileRadius, PositionErrorMetrics,
165};
166pub use crate::estimation::{
167    alpha_beta_apply_measurement, alpha_beta_filter_step, alpha_beta_predict,
168    alpha_beta_steady_state_gains, cfar_ca_false_alarm_probability, cfar_ca_multiplier_from_pfa,
169    cfar_ca_pfa_from_multiplier, cfar_ca_threshold, ewma_update, ewma_update_power_of_two,
170    kalman_cv_steady_state_gains, mad_spread, nis_expected_value, nis_gate_test,
171    nis_gate_threshold, nis_statistic, normalized_innovation, AlphaBetaGains, AlphaBetaState,
172    AlphaBetaStep, PrimitiveError, ScalarKalmanGains, MAD_GAUSSIAN_CONSISTENCY,
173};
174pub use crate::quality::{
175    reliability_araim, reliability_design, wtest_noncentrality, wtest_noncentrality_components,
176    ObservationReliability, RangeReliabilityRow, ReliabilityOptions, ReliabilityReport,
177    ReliabilitySummary, WtestNoncentralityComponents,
178};
179pub use araim::ProtectionModel;
180pub use error::{Error, Result};
181pub use frame::{
182    geodetic_to_itrf, itrf_to_geodetic, FrameValueError, ItrfPositionM, ItrfVelocityMS,
183    Wgs84Geodetic,
184};
185pub use frame_catalog::{
186    catalog, catalog_entry, propagate_position, transform, transform_from_epoch, FrameCatalogError,
187    HelmertParameters, HelmertRates, HelmertTransform, TerrestrialFrame, TerrestrialPositionM,
188    TerrestrialState, TerrestrialVelocityMPerYear, TERRESTRIAL_FRAME_CATALOG,
189};
190pub use fusion::{
191    loose_coupling_correction, validate_time_sync_gnss_order, validate_time_sync_imu_order,
192    FusionUpdate, GnssFixMeasurement, InertialFilter, InertialFilterConfig, LooseCouplingConfig,
193    TimeSyncHistoryConfig, TimeSyncHistoryStatus, TimeSyncUpdate,
194    DEFAULT_TIME_SYNC_CHECKPOINT_CAPACITY, DEFAULT_TIME_SYNC_IMU_CAPACITY,
195};
196pub use geodesic::{geodesic_direct, geodesic_inverse, GeodesicError};
197pub use geoid::{
198    egm96_undulations_deg, egm96_undulations_rad, ellipsoidal_height_m, geoid_undulation,
199    geoid_undulations_deg, geoid_undulations_rad, orthometric_height_m, Egm2008GridSpacing,
200    Egm2008RasterWindow, GeoidError, GeoidGrid,
201};
202pub use id::{GnssSatelliteId, GnssSystem, SatelliteIdError};
203pub use inertial::{
204    gauss_markov_bias_decay, gauss_markov_bias_variance_increment, gravity_ecef_mps2,
205    mechanize_ecef, normal_gravity_mps2, rodrigues_delta_dcm, simulate_imu_samples,
206    simulate_imu_samples_from_increments, true_imu_increment_between, AttitudeQuaternion,
207    ConingCorrection, CorrectedImuIncrement, ImuBias, ImuCalibration, ImuErrorModel, ImuGrade,
208    ImuRateRandomWalk, ImuSample, ImuSampleKind, ImuSimulationOptions, ImuSimulationOutput,
209    ImuSimulator, ImuSpec, InertialError, MechanizationConfig, NavState, SimulatedImuSequence,
210    StrapdownMechanizer, DEFAULT_IMU_SIM_SEED, WGS84_NORMAL_GRAVITY_EQUATOR_MPS2,
211    WGS84_NORMAL_GRAVITY_POLE_MPS2, WGS84_SOMIGLIANA_K,
212};
213pub use observables::{
214    observable_media_corrections, predict_batch_with_media, predict_batch_with_media_parallel,
215    predict_ranges_with_media, predict_with_media, AppliedMediaCorrections, MediaPredictOptions,
216    MediaPredictedObservables, MediaRangePrediction, ObservableIonosphereCorrection,
217    ObservableMediaOptions, ObservableTroposphereCorrection,
218};
219pub use sbas_pl::{
220    sbas_protection_levels, AirborneModel, DegradationParams, ProtectionGeometry, ProtectionRow,
221    SbasErrorModel, SbasKMultipliers, SbasPlError, SbasProtection, SbasSisError,
222};
223pub use sidereal::{
224    orbit_repeat_lag, periodicity_strength, periodicity_strength_with_sample_interval,
225    repeat_period, sidereal_filter, solar_day_period, SiderealFilterError, SiderealFilterOptions,
226    SiderealFilterOutput, SiderealTemplateMethod, SIDEREAL_DAY_NANOS, SIDEREAL_DAY_SECONDS,
227};