Maneuver Detection Data Generation
Project description
MaDDG (Maneuver Detection Data Generation)
A library for simulating high-fidelity observations of satellite trajectories with configurable maneuvers and custom sensor networks.
MaDDG provides a simple interface for modeling complex observation scenarios. It allows you to create a satellite in any geocentric orbit, propagate its motion with a robust physical model, and track its position through optical sensors with customizable locations, observing limits, and noise parameters.
Through its use of hydra-zen and the submitit plugin, MaDDG can easily configure an array of simulation scenarios and distribute them in a SLURM cluster, empowering users to create large-scale, realistic datasets for training reliable maneuver detection and characterization models.
Installation
MaDDG is available on PyPI:
pip install MaDDG
To install from source, clone this repository and run the following command from its top-level directory:
pip install -e .
If you want to modify the orbit propagation physics behind MaDDG, you will likely need to edit the AstroForge library, as well. AstroForge is an open-source astrodynamics library and a key requirement of MaDDG. See the AstroForge documentation for installation instructions.
Usage
For details on how to use the various features of MaDDG, we recommend following the Jupyter notebooks in the examples/ directory.
Citation
Please use this DOI number reference, published on Zenodo, when citing the software:
Post Processing Scripts
Weather Event (Cloud Dropout)
Use dropout.py to apply pseudo weather-based data dropout to dataset .csv files created with hz_launcher.py.
$ python scripts/dropout.py --help
usage: dropout.py [-h] --path PATH [--cloud_prob CLOUD_PROB] [--cloud_duration_mean CLOUD_DURATION_MEAN] [--cloud_duration_std CLOUD_DURATION_STD] [--num_runs NUM_RUNS]
[--save_copy_of_original] [--save_plots] [--submitit]
Script description
options:
-h, --help show this help message and exit
--path PATH The path to the input data file (.csv) (default: None)
--cloud_prob CLOUD_PROB
Probability of a cloud event blocking the sky during
any nighttime observable window for each sensor (default: 0.5)
--cloud_duration_mean CLOUD_DURATION_MEAN
Mean duration of a cloud event (seconds) (default: 10800.0)
--cloud_duration_std CLOUD_DURATION_STD
Standard deviation of a cloud event (seconds) (default: 3600.0)
--num_runs NUM_RUNS Number of dropout datasets to generate (default: 1)
--save_copy_of_original
Raise this flag to save copy of the original input data along
side of the modified dataset with dropouts (default: False)
--save_plots Raise this flag to generate and save plots (default: False)
--submitit Raise this flag to use submitit to launch jobs across multiple
nodes in parallel (default: False)
Example vscode launch.json entry:
{
"name": "Launch Dropout",
"type": "python",
"request": "launch",
"program": "scripts/dropout.py",
"console": "integratedTerminal",
"cwd": "/path/to/MaDDG",
"args": [
"--path=/path/to/complete.csv",
"--cloud_prob=1.0",
"--cloud_duration_mean=0,3600,7200,10800,14400,18000,21600,25200,28800,32400,36000,39600,43200,46800,50400,54000,57600",
"--cloud_duration_std=0.0",
"--num_runs=10",
"--save_copy_of_original",
"--submitit",
]
}
Disclaimer
DISTRIBUTION STATEMENT A. Approved for public release. Distribution is unlimited.
Research was sponsored by the United States Air Force Research Laboratory and the United States Air Force Artificial Intelligence Accelerator and was accomplished under Cooperative Agreement Number FA8750-19-2-1000. The views and conclusions contained in this document are those of the authors and should not be interpreted as representing the official policies, eitherexpressed or implied, of the United States Air Force or the U.S. Government. The U.S.Government is authorized to reproduce and distribute reprints for Government purposes notwithstanding any copyright notation herein.
© 2024 Massachusetts Institute of Technology.
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 maddg-0.1.4.tar.gz.
File metadata
- Download URL: maddg-0.1.4.tar.gz
- Upload date:
- Size: 1.5 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d2c583ca22f2f851e7102b11567cd6cf6a56577823e093772487db909e45cf67
|
|
| MD5 |
349ae84bdee137990f1d3ae39bd911e8
|
|
| BLAKE2b-256 |
8d369f8760c22cab91ddca7856cd00a6396d517429f51c755a2adeaa06430a7b
|
File details
Details for the file maddg-0.1.4-py3-none-any.whl.
File metadata
- Download URL: maddg-0.1.4-py3-none-any.whl
- Upload date:
- Size: 28.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fa9244c884867e5b45584f2b59fd2290ca2e65a5c81c743ffe9d81da3cffa33d
|
|
| MD5 |
2194a3a058a31084394bc50d9e0c9c79
|
|
| BLAKE2b-256 |
35f86c741236207acab8cb3c34d1b861ac8c81d35d4d6cbb8ef1202767a69036
|