Skip to main content

Quantum Open Source Software for Secure Transmission (QOSST) is a suite of software to implement a CV-QKD system.

Project description

QOSST - Quantum Open Software for Secure Transmissions

QOSST Logo

This repo serves two purposes: the first is to explain how the code quality of QOSST and the second one is to give a general introduction to QOSST.

QOSST was initially developed in the Quantum Information (QI) team of the LIP6 laboratory in Sorbonne Université.

Article

The link to the article will be added soon.

Structure

The QOSST software is separated in 7 submodules:

  • qosst-core for the configuration, control protocol, and common functions to Alice and Bob;
  • qosst-alice for the digital signal processing (DSP), server, and interaction with the hardware for Alice;
  • qosst-bob for the digital signal processing (DSP), client, interaction with the hardware, parameters estimation for Bob.;
  • qosst-hal for hardware abstraction layer;
  • qosst-skr for the secret key rate computations;
  • qosst-sim for the simulations;
  • qosst-pp for the post processing.

To operate Alice, it is only necessary to install the qosst-alice package. The other packages that are required will be automatically installed. The same applies for qosst-bob.

Links and documentation

Name URL Documentation
qosst-core https://github.com/qosst/qosst-core https://qosst-core.readthedocs.io/
qosst-hal https://github.com/qosst/qosst-hal https://qosst-hal.readthedocs.io/
qosst-alice https://github.com/qosst/qosst-alice https://qosst-alice.readthedocs.io/
qosst-bob https://github.com/qosst/qosst-bob https://qosst-bob.readthedocs.io/
qosst-skr https://github.com/qosst/qosst-skr https://qosst-skr.readthedocs.io/
qosst-sim https://github.com/qosst/qosst-sim https://qosst-sim.readthedocs.io/
qosst-pp Not released Not released.

Code quality

The code quality of the QOSST submodules are checked via three tools:

  • pylint for the static linting;
  • mypy for the type hints checking;
  • docstr-coverage for checking the coverage of documentation.

The script code_quality.py automatically applies all the checks to all the submodules.

Additionally, the QOSST submodules are formatted with black.

License

The submodules of QOSST are shipped under the Gnu General Public License v3.

Contributing

Report issues

Reporting issues is the first way to contribute to the software.

You can report global issue with the software on the issues tracker of QOSST at https://github.com/qosst/qosst/issues.

It is however preferable to use the specialized repo for issues that are specific to a module:

Module URL of the issues tracker
qosst-core https://github.com/qosst/qosst-core/issues
qosst-hal https://github.com/qosst/qosst-hal/issues
qosst-alice https://github.com/qosst/qosst-alice/issues
qosst-bob https://github.com/qosst/qosst-bob/issues
qosst-skr https://github.com/qosst/qosst-skr/issues
qosst-sim https://github.com/qosst/qosst-sim/issues

Please include the following information when reporting a bug

  • description of the bug;
  • versions of the QOSST software;
  • configuration file;
  • used hardware, if relevant;
  • logs of the error.

When requesting new feature, please provide a detailed description of what you propose and any reference that could be relevant.

Proposing code

You can propose code, either to solve issues or to propose new features directly.

If you want to solve an issue please comment on the issue on the issue tracker so we can assign the assign to you.

Here are the steps you should do:

  1. Fork the repository on your github account;
  2. Clone your forked repository;
  3. Make the changes and commit;
  4. Push to your forked repository;
  5. Open a Pull Request on the associated repository.

We will then check the changes and merge when it's ready.

Acknowledgments

We first thank the direct contributors of the code:

  • Yoann Piétri
  • Valentina Marulanda Acosta
  • Matteo Schiavon
  • Mayeul Chavanne
  • Ilektra Karakosta - Amarantidou

We also thank all the persons that made comments and discussions that had a direct impact on this software:

  • Luis-Trigo Vidarte
  • Baptiste Gouraud
  • Amine Rhouni
  • Eleni Diamanti
  • Philippe Grangier

And finally we thank the persons that participated in some ways to the development of QOSST:

  • Thomas Liege
  • George Crisan
  • Damien Fruleux
  • Sarah Layani
  • Manon Huguenot

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

qosst-0.10.0.tar.gz (4.2 kB view details)

Uploaded Source

Built Distribution

qosst-0.10.0-py3-none-any.whl (4.7 kB view details)

Uploaded Python 3

File details

Details for the file qosst-0.10.0.tar.gz.

File metadata

  • Download URL: qosst-0.10.0.tar.gz
  • Upload date:
  • Size: 4.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.2 CPython/3.12.3 Linux/6.8.7-arch1-2

File hashes

Hashes for qosst-0.10.0.tar.gz
Algorithm Hash digest
SHA256 2f64ac002a84d27afeea98d6334bbb2085c3ede335f4db07d83b109d54b2f9c9
MD5 526501f7cdc6214e7c1db9e6c2079c0f
BLAKE2b-256 1f3f61de6d52c1d9199df149919b29770633f6baace811367facbe6901757bdd

See more details on using hashes here.

File details

Details for the file qosst-0.10.0-py3-none-any.whl.

File metadata

  • Download URL: qosst-0.10.0-py3-none-any.whl
  • Upload date:
  • Size: 4.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.2 CPython/3.12.3 Linux/6.8.7-arch1-2

File hashes

Hashes for qosst-0.10.0-py3-none-any.whl
Algorithm Hash digest
SHA256 06849c585cc84adc69f5016227a2ebb428583bc298ddece0356d4a4a6cf7355b
MD5 55c86b84276c7fcf49baa33a7c3ed2a4
BLAKE2b-256 73c0730eb5606cc1c28ba9139e025cd5279016928287a934eb4cdf8ba7a4d427

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page