No project description provided
Project description
GeoSim (Geometric Simulation)
A Python library for geometric simulation of geolocation scenarios. GeoSim models platforms (satellites, ground stations, aircraft) with attached sensors that observe emitters and generate measurements (AOA, TDOA, FDOA) for testing geolocation algorithms. Requires Python 3.14+.
Mathematical Background
The sensor models compute measurements from geometry:
AOA (Angle of Arrival). Direction cosines (u, v) from the collector-to-emitter unit vector projected into the sensor's local coordinate frame. For ENU-based sensors, u = east component, v = north component of the unit direction.
TDOA (Time Difference of Arrival). The difference in propagation time between two collectors:
dt = (||x - c1|| - ||x - c2||) / c
where x is the emitter position, c1 and c2 are collector positions, and c is the speed of light. The iso-surface is a hyperboloid with foci at the two collectors.
FDOA (Frequency Difference of Arrival). The differential Doppler shift observed between two collectors:
df = (f / c) * (v1 . r1_hat - v2 . r2_hat)
where f is the carrier frequency, v1, v2 are collector velocities, and r1_hat, r2_hat are unit vectors from each collector to the emitter.
References: Torrieri (1984), "Statistical Theory of Passive Location Systems"; Ho & Chan (1997), "Geolocation of a Known Altitude Object from TDOA and FDOA Measurements."
Key Features
- Platform modeling: Stationary, TLE (SGP4), Keplerian orbit, and waypoint trajectories
- Sensor types: AOA (Angle of Arrival), TDOA (Time Difference of Arrival), FDOA (Frequency Difference of Arrival)
- FOV constraints: Elevation masks, conical FOV, Earth occlusion
- Observation generation: Self-contained measurements with embedded collector state
- Geolocation pipeline: Observation -> Ell (ellipsoid) conversion and fusion
- Monte Carlo support: Statistical analysis via multiple simulation iterations
- Atmospheric corrections: Integration with gri-tropo/gri-iono for delay modeling
Core Classes
| Class | Purpose |
|---|---|
Scenario |
Orchestrates simulation timeline and all participants |
Platform |
Moving or stationary observer (satellite, ground station, aircraft) |
Emitter |
Target being observed (stationary or moving) |
AoaSensor |
Angle of Arrival measurements (azimuth/elevation or direction cosines) |
TdoaSensor |
Time Difference of Arrival measurements (paired platforms) |
FdoaSensor |
Frequency Difference of Arrival measurements (Doppler-based) |
LocatorResult |
Geolocation solution with position, covariance, and chi-squared |
Installation
# Basic installation
pip install gri-geosim
# With geolocation support (gri-ell for ellipsoids)
pip install gri-geosim[all]
# With atmospheric corrections
pip install gri-geosim[atmosphere]
Quick Start
from gri_geosim import Scenario, Platform, Emitter, filter_aoa
from gri_geosim.sensors import AoaSensor
from gri_pos import Pos
from gri_nsepoch import Time
# Create a ground-based emitter (target)
emitter = Emitter(Pos.LLA(39.0, -76.5, 0.0), frequency_hz=1.5e9, name="TARGET")
# Create sensor platform
ground = Platform(Pos.LLA(38.0, -77.0, 100.0), name="GROUND_STATION")
ground.add_sensor(AoaSensor("aoa", azimuth_std_rad=0.001, elevation_std_rad=0.001))
# Run single-instant simulation
scenario = Scenario.for_instant(platforms=[ground], emitters=[emitter])
observations = scenario.simulate_at(Time.from_str("2024-01-15T12:00:00Z"))
# Access observations
for obs in filter_aoa(observations):
print(f"Azimuth: {obs.azimuth:.4f} rad, Elevation: {obs.elevation:.4f} rad")
Trajectories
| Trajectory | Description |
|---|---|
StationaryTrajectory |
Fixed position, zero velocity |
Sgp4Trajectory |
SGP4/SDP4 TLE propagation (python-sgp4 backend) |
KeplerianTrajectory |
Two-body orbital mechanics (gri-utils backend) |
WaypointTrajectory |
Interpolated path through waypoints (cubic/linear) |
FOV Constraints
Sensors support pluggable field-of-view constraints:
| Constraint | Description |
|---|---|
NoFov |
No restriction (always visible) |
ConeFov |
Conical field of view with half-angle |
ElevationMaskFov |
Elevation angle constraints (auto-detects ground reference) |
EarthOcclusionFov |
Earth line-of-sight blockage check |
from gri_geosim.sensors import AoaSensor, ElevationMaskFov
# Ground station with 10-degree elevation mask
sensor = AoaSensor(
"ground_aoa",
azimuth_std_rad=0.001,
fov=ElevationMaskFov(min_elev_deg=10.0),
)
Geolocation Pipeline
Convert observations to position estimates with covariance:
from gri_geosim import locate
from gri_convolve import smart_convolve
# Generate observations
observations = scenario.simulate_at(observation_time)
# Convert to position estimate with covariance ellipsoid
ell = locate(observations)
print(f"Position: {ell.lla}")
print(f"95% horizontal error: {ell.cep95_m:.1f} m")
# Combine multiple ellipsoids (with outlier rejection)
combined, used, discarded = smart_convolve([ell1, ell2, ell3])
Dependencies
This is a Layer 3 application package in the GRI FOSS ecosystem:
Required:
gri-utils: Coordinate conversions, orbit propagation, observable calculationsgri-pos: Position objects (Pos class) with LLA/XYZ supportgri-nsepoch: Nanosecond-accurate timestamps (Time, Delta classes)numpy,scipy: Numerical computingsgp4: TLE orbit propagation
Optional (installed with [all]):
gri-ell: Covariance ellipsoid objects forlocate()gri-convolve: Ellipsoid combination (smart_convolve,convolve,cluster_convolve)
Optional (installed with [atmosphere]):
gri-tropo: Tropospheric delay modeling (ITU-R 2019)gri-iono: Ionospheric delay modeling (Bent, IRI, NeQuick)
Examples
See examples/README.md for detailed examples:
basic_scenario.py- Multi-platform AOA with ground/aircraft/satellite sensorstdoa_scenario.py- TDOA sensor pairs with paired platformsmonte_carlo.py- Statistical analysis via multiple simulation runslocate_and_fuse.py- Full geolocation pipeline with ellipsoid fusionatmosphere_effects.py- Tropospheric and ionospheric delay demonstrationmulti_platform_geo.py- Complex hybrid AOA/TDOA/FDOA scenario
Other Projects
Current list of other GRI FOSS Projects we are building and maintaining.
License
MIT License. See LICENSE for details.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file gri_geosim-0.2.0.post1.tar.gz.
File metadata
- Download URL: gri_geosim-0.2.0.post1.tar.gz
- Upload date:
- Size: 151.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.10.4 {"installer":{"name":"uv","version":"0.10.4","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
557485f726de3cc80be209804dc080a2d8804ab086cda064e1335789903b5dd4
|
|
| MD5 |
70120f8eddb81bff7afef6899b68450a
|
|
| BLAKE2b-256 |
a76226c150d9a3c10191ab844dc5c5070229b82e09a505ff20ce850f8d5b037b
|
File details
Details for the file gri_geosim-0.2.0.post1-py3-none-any.whl.
File metadata
- Download URL: gri_geosim-0.2.0.post1-py3-none-any.whl
- Upload date:
- Size: 88.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.10.4 {"installer":{"name":"uv","version":"0.10.4","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2ece16c9f4445ac7b2392007f68876733953636992fd77f09d9e4f2a37324bac
|
|
| MD5 |
7e3ed8663ab8285395f4ea07e1a9b2e3
|
|
| BLAKE2b-256 |
3637e6ec38785d4528b23622daa4d6d8dcf33dc400539b7d443515c1a4bb0de1
|