An event-based network simulator optimized for federated and deep-space satellite networks.
Project description
DSNS: The Deep Space Network Simulator
The Deep Space Network Simulator (DSNS) is an event-based network simulator designed for efficient simulation of satellite networks and interplanetary communication, to facilitate protocol testing and development. The paper introducing it can be found on arXiv here.
When using DSNS, please cite the following paper: "DSNS: The Deep Space Network Simulator". The BibTeX entry is given below:
@inproceedings{smailesDSNS2025,
author = {Smailes, Joshua and Futera, Filip and K{\"o}hler, Sebastian and Birnbach, Simon and Strohmeier, Martin and Martinovic, Ivan},
title = {{DSNS}: {The Deep Space Network Simulator}},
booktitle={2025 Security for Space Systems (3S)},
year={2025},
organization={IEEE}
}
Papers and projects which have used DSNS:
- "KeySpace: Enhancing Public Key Infrastructure for Interplanetary Networks" (2025): https://arxiv.org/abs/2408.10963
- "Secure and Scalable Rerouting in LEO Satellite Networks" (2025): https://arxiv.org/abs/2509.10173
[!NOTE] To add your project to this list, or to merge your contributions with DSNS, feel free to submit a pull request.
Documentation
Further documentation can be found here: https://ssloxford.github.io/DSNS/
Installation
DSNS is distributed on PyPI, and can be installed using pip:
pip3 install dsns
However, many use cases will require modifications to the source code.
For this reason, we recommend installation from source, using the --editable flag to ensure the code can be updated without requiring reinstallation.
This can be done as follows:
git clone https://github.com/ssloxford/dsns.git
cd dsns
pip3 install --editable .
Dependencies are listed in pyproject.toml, at the root of the repository.
We recommend the use of a virtual environment to reduce the likelihood of dependency conflicts.
Usage
We recommend looking in the examples directory for usage examples, or at the documentation for further instruction.
[!NOTE] The examples in
examples/paperrequire simulation logs that are not bundled with this repository due to their size, and are provided for reference only. The logs can be obtained by runningexamples/ccsds_reference.pyandexamples/custom_reference.pywith the arguments shown at the bottom of the respective file, or by contacting the authors.
Contributing
We welcome any contributions to DSNS, including but not limited to improved documentation, refactoring, new features, examples, and reference scenarios. To make a contribution, please add an issue to the tracker or create a pull request, and we will aim to merge any changes shortly. Please note that any code changes must come with corresponding changes to the documentation.
License
This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program. If not, see https://www.gnu.org/licenses/.
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 dsns-1.0.0.tar.gz.
File metadata
- Download URL: dsns-1.0.0.tar.gz
- Upload date:
- Size: 72.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fd3ec491a1503f4c60203fd974ce63222286235f59e7e4f8cae1f666011033c0
|
|
| MD5 |
7e9b56690edf1d99b5d41d8403075665
|
|
| BLAKE2b-256 |
85d43df63dce5d328e3a955e9134c5f66be6ac4a630bf843a8a88fd7fd2249c2
|
Provenance
The following attestation bundles were made for dsns-1.0.0.tar.gz:
Publisher:
release.yml on ssloxford/DSNS
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
dsns-1.0.0.tar.gz -
Subject digest:
fd3ec491a1503f4c60203fd974ce63222286235f59e7e4f8cae1f666011033c0 - Sigstore transparency entry: 529656217
- Sigstore integration time:
-
Permalink:
ssloxford/DSNS@83c01ab46f780e9559bb3af382c8b4b9c049508c -
Branch / Tag:
refs/tags/v1.0.0 - Owner: https://github.com/ssloxford
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@83c01ab46f780e9559bb3af382c8b4b9c049508c -
Trigger Event:
push
-
Statement type:
File details
Details for the file dsns-1.0.0-py3-none-any.whl.
File metadata
- Download URL: dsns-1.0.0-py3-none-any.whl
- Upload date:
- Size: 75.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
57c48231903b8a29f0501f85f71e3f3581647ea72f2140736f3e81535da49107
|
|
| MD5 |
312ec019f565e5de5464e0afb8d99f95
|
|
| BLAKE2b-256 |
bb13b0b50ef7daaec8837cb9785a0e34a2814d5b9aeb64e95e1800ad4e44d793
|
Provenance
The following attestation bundles were made for dsns-1.0.0-py3-none-any.whl:
Publisher:
release.yml on ssloxford/DSNS
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
dsns-1.0.0-py3-none-any.whl -
Subject digest:
57c48231903b8a29f0501f85f71e3f3581647ea72f2140736f3e81535da49107 - Sigstore transparency entry: 529656237
- Sigstore integration time:
-
Permalink:
ssloxford/DSNS@83c01ab46f780e9559bb3af382c8b4b9c049508c -
Branch / Tag:
refs/tags/v1.0.0 - Owner: https://github.com/ssloxford
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@83c01ab46f780e9559bb3af382c8b4b9c049508c -
Trigger Event:
push
-
Statement type: