# OQuPy: Open Quantum Systems in Python
**A Python package to efficiently simulate non-Markovian open quantum systems
with process tensors.**
[![Binder](https://mybinder.org/badge_logo.svg)](https://mybinder.org/v2/gh/tempoCollaboration/OQuPy/main?filepath=tutorials%2Fquickstart.ipynb)
[![Tests status](https://github.com/tempoCollaboration/OQuPy/actions/workflows/python-package-tests.yml/badge.svg)](https://github.com/tempoCollaboration/OQuPy/actions/workflows/python-package-tests.yml)
[![Codecov](https://codecov.io/gh/tempoCollaboration/OQuPy/branch/main/graph/badge.svg)](https://codecov.io/gh/tempoCollaboration/OQuPy)
[![Documentation Status](https://readthedocs.org/projects/oqupy/badge/?version=latest)](https://oqupy.readthedocs.io/en/latest/?badge=latest)
[![Contributor Covenant](https://img.shields.io/badge/Contributor%20Covenant-v2.0%20adopted-ff69b4.svg)](https://github.com/tempoCollaboration/OQuPy/blob/main/CODE_OF_CONDUCT.md)
[![DOI](https://www.zenodo.org/badge/244404030.svg)](https://www.zenodo.org/badge/latestdoi/244404030)
[![Unitary Fund](https://img.shields.io/badge/Supported%20By-UNITARY%20FUND-brightgreen.svg?style=for-the-badge)](http://unitary.fund)
This open source project aims to facilitate versatile numerical tools to efficiently compute the dynamics of quantum systems that are possibly strongly coupled to structured environments. It facilitates the convenient application of several numerical methods that combine the conceptional advantages of the process tensor framework [1], with the numerical efficiency of tensor networks.
OQuPy includes numerically exact methods (i.e. employing only numerically well controlled approximations) for the non-Markovian dynamics and multi-time correlations of ...
- quantum systems coupled to a single environment [2-4],
- quantum systems coupled to multiple environments [5],
- interacting chains of non-Markovian open quantum systems [6], and
- ensembles of open many-body systems with many-to-one coupling [7].
Furthermore, OQuPy implements methods to ...
- optimize control protocols for non-Markovian open quantum systems [8,9],
- compute the dynamics of an non-Markovian environment [10], and
- obtain the thermal state of a strongly couled quantum system [11].
![OQuPy - overview](docs/graphics/overview.png)
- **[1]** Pollock et al., [Phys. Rev. A 97, 012127](https://doi.org/10.1103/PhysRevA.97.012127) (2018).
- **[2]** Strathearn et al., [New J. Phys. 19(9), p.093009](https://doi.org/10.1088/1367-2630/aa8744) (2017).
- **[3]** Strathearn et al., [Nat. Commun. 9, 3322](https://doi.org/10.1038/s41467-018-05617-3)
(2018).
- **[4]** Jørgensen and Pollock, [Phys. Rev. Lett. 123, 240602](https://doi.org/10.1103/PhysRevLett.123.240602) (2019).
- **[5]** Gribben et al., [PRX Quantum 3, 10321](https://doi.org/10.1103/PRXQuantum.3.010321) (2022).
- **[6]** Fux et al., [Phys. Rev. Research 5, 033078 ](https://doi.org/10.1103/PhysRevResearch.5.033078}) (2023).
- **[7]** Fowler-Wright et al., [Phys. Rev. Lett. 129, 173001](https://doi.org/10.1103/PhysRevLett.129.173001) (2022).
- **[8]** Fux et al., [Phys. Rev. Lett. 126, 200401](https://doi.org/10.1103/PhysRevLett.126.200401) (2021).
- **[9]** Butler et al., [Phys. Rev. Lett. 132, 060401 ](https://doi.org/10.1103/PhysRevLett.132.060401}) (2024).
- **[10]** Gribben et al., [Quantum, 6, 847](https://doi.org/10.22331/q-2022-10-25-847) (2022).
- **[11]** Chiu et al., [Phys. Rev. A 106, 012204](https://doi.org/10.1103/PhysRevA.106.012204}) (2022).
-------------------------------------------------------------------------------
## Links
* Github: <https://github.com/tempoCollaboration/OQupy>
* Documentation: <https://oqupy.readthedocs.io>
* PyPI: <https://pypi.org/project/oqupy/>
* Tutorial: [![Binder](https://mybinder.org/badge_logo.svg)](https://mybinder.org/v2/gh/tempoCollaboration/OQuPy/main?filepath=tutorials%2Fquickstart.ipynb)
## Installation
You can install OQuPy using pip like this:
```
$ python3 -m pip install oqupy
```
See the
[documentation](https://oqupy.readthedocs.io/en/latest/pages/install.html)
for more information.
## Quickstart Tutorial
[![Binder](https://mybinder.org/badge_logo.svg)](https://mybinder.org/v2/gh/tempoCollaboration/OQuPy/main?filepath=tutorials%2Fquickstart.ipynb)
Click the `launch binder` button above to start a tutorial in a browser based jupyter notebook (no installation required) or checkout the [tutorial in the documentation](https://oqupy.readthedocs.io/en/latest/pages/tutorials/quickstart.html).
## Contributing
Contributions of all kinds are welcome! Get in touch if you ...
<ul style="list-style: none;">
<li>... found a bug.</li>
<li> ... have a question on how to use the code.</li>
<li> ... have a suggestion, on how to improve the code or documentation.</li>
<li> ... would like to get involved in writing code or documentation.</li>
<li> ... have some other thoughts or suggestions.</li>
</ul>
Please, feel free to file an issue in the [Issues](https://github.com/tempoCollaboration/OQuPy/issues) section on GitHub for this. Also, have a look at [`CONTRIBUTING.md`](https://github.com/tempoCollaboration/OQuPy/blob/main/CONTRIBUTING.md) if you want to get involved in the development.
## Citing, Authors and Bibliography
See the files [`HOW_TO_CITE.md`](https://github.com/tempoCollaboration/OQuPy/blob/main/HOW_TO_CITE.md), [`AUTHORS.md`](https://github.com/tempoCollaboration/OQuPy/blob/main/AUTHORS.md) and [`BIBLIOGRAPHY.md`](https://github.com/tempoCollaboration/OQuPy/blob/main/BIBLIOGRAPHY.md).
#### Consider sharing this project:
<p align="center">
<img src="docs/graphics/oqupy-github-qr.png" alt="OQuPy - GitHub QR Code" width="200"/>
</p>
Raw data
{
"_id": null,
"home_page": "http://github.com/tempoCollaboration/OQuPy",
"name": "oqupy-gefux",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.10.0",
"maintainer_email": null,
"keywords": "physics, computational-physics, quantum-physics, quantum-information, open-quantum-systems",
"author": "TEMPO Collaboration",
"author_email": "tempo.collaboration@gmail.com",
"download_url": "https://files.pythonhosted.org/packages/5a/81/2eed1879fb6d0843e5a9c7e8cfdd081290592aff08e5712374ca36f9fce9/oqupy_gefux-0.5.0.tar.gz",
"platform": null,
"description": "\n# OQuPy: Open Quantum Systems in Python\n\n**A Python package to efficiently simulate non-Markovian open quantum systems\nwith process tensors.**\n\n[![Binder](https://mybinder.org/badge_logo.svg)](https://mybinder.org/v2/gh/tempoCollaboration/OQuPy/main?filepath=tutorials%2Fquickstart.ipynb)\n[![Tests status](https://github.com/tempoCollaboration/OQuPy/actions/workflows/python-package-tests.yml/badge.svg)](https://github.com/tempoCollaboration/OQuPy/actions/workflows/python-package-tests.yml)\n[![Codecov](https://codecov.io/gh/tempoCollaboration/OQuPy/branch/main/graph/badge.svg)](https://codecov.io/gh/tempoCollaboration/OQuPy)\n[![Documentation Status](https://readthedocs.org/projects/oqupy/badge/?version=latest)](https://oqupy.readthedocs.io/en/latest/?badge=latest)\n[![Contributor Covenant](https://img.shields.io/badge/Contributor%20Covenant-v2.0%20adopted-ff69b4.svg)](https://github.com/tempoCollaboration/OQuPy/blob/main/CODE_OF_CONDUCT.md)\n[![DOI](https://www.zenodo.org/badge/244404030.svg)](https://www.zenodo.org/badge/latestdoi/244404030)\n\n[![Unitary Fund](https://img.shields.io/badge/Supported%20By-UNITARY%20FUND-brightgreen.svg?style=for-the-badge)](http://unitary.fund)\n\nThis open source project aims to facilitate versatile numerical tools to efficiently compute the dynamics of quantum systems that are possibly strongly coupled to structured environments. It facilitates the convenient application of several numerical methods that combine the conceptional advantages of the process tensor framework [1], with the numerical efficiency of tensor networks.\n\nOQuPy includes numerically exact methods (i.e. employing only numerically well controlled approximations) for the non-Markovian dynamics and multi-time correlations of ...\n- quantum systems coupled to a single environment [2-4],\n- quantum systems coupled to multiple environments [5],\n- interacting chains of non-Markovian open quantum systems [6], and\n- ensembles of open many-body systems with many-to-one coupling [7].\n\nFurthermore, OQuPy implements methods to ...\n- optimize control protocols for non-Markovian open quantum systems [8,9],\n- compute the dynamics of an non-Markovian environment [10], and\n- obtain the thermal state of a strongly couled quantum system [11].\n\n![OQuPy - overview](docs/graphics/overview.png)\n\n- **[1]** Pollock et al., [Phys. Rev. A 97, 012127](https://doi.org/10.1103/PhysRevA.97.012127) (2018).\n- **[2]** Strathearn et al., [New J. Phys. 19(9), p.093009](https://doi.org/10.1088/1367-2630/aa8744) (2017).\n- **[3]** Strathearn et al., [Nat. Commun. 9, 3322](https://doi.org/10.1038/s41467-018-05617-3)\n (2018).\n- **[4]** J\u00f8rgensen and Pollock, [Phys. Rev. Lett. 123, 240602](https://doi.org/10.1103/PhysRevLett.123.240602) (2019).\n- **[5]** Gribben et al., [PRX Quantum 3, 10321](https://doi.org/10.1103/PRXQuantum.3.010321) (2022).\n- **[6]** Fux et al., [Phys. Rev. Research 5, 033078 ](https://doi.org/10.1103/PhysRevResearch.5.033078}) (2023).\n- **[7]** Fowler-Wright et al., [Phys. Rev. Lett. 129, 173001](https://doi.org/10.1103/PhysRevLett.129.173001) (2022).\n- **[8]** Fux et al., [Phys. Rev. Lett. 126, 200401](https://doi.org/10.1103/PhysRevLett.126.200401) (2021).\n- **[9]** Butler et al., [Phys. Rev. Lett. 132, 060401 ](https://doi.org/10.1103/PhysRevLett.132.060401}) (2024).\n- **[10]** Gribben et al., [Quantum, 6, 847](https://doi.org/10.22331/q-2022-10-25-847) (2022).\n- **[11]** Chiu et al., [Phys. Rev. A 106, 012204](https://doi.org/10.1103/PhysRevA.106.012204}) (2022).\n\n\n-------------------------------------------------------------------------------\n\n## Links\n\n* Github: <https://github.com/tempoCollaboration/OQupy>\n* Documentation: <https://oqupy.readthedocs.io>\n* PyPI: <https://pypi.org/project/oqupy/>\n* Tutorial: [![Binder](https://mybinder.org/badge_logo.svg)](https://mybinder.org/v2/gh/tempoCollaboration/OQuPy/main?filepath=tutorials%2Fquickstart.ipynb)\n\n## Installation\nYou can install OQuPy using pip like this:\n```\n$ python3 -m pip install oqupy\n```\n\nSee the\n[documentation](https://oqupy.readthedocs.io/en/latest/pages/install.html)\nfor more information.\n\n\n## Quickstart Tutorial\n[![Binder](https://mybinder.org/badge_logo.svg)](https://mybinder.org/v2/gh/tempoCollaboration/OQuPy/main?filepath=tutorials%2Fquickstart.ipynb)\n\nClick the `launch binder` button above to start a tutorial in a browser based jupyter notebook (no installation required) or checkout the [tutorial in the documentation](https://oqupy.readthedocs.io/en/latest/pages/tutorials/quickstart.html).\n\n\n## Contributing\nContributions of all kinds are welcome! Get in touch if you ...\n<ul style=\"list-style: none;\">\n <li>... found a bug.</li>\n <li> ... have a question on how to use the code.</li>\n <li> ... have a suggestion, on how to improve the code or documentation.</li>\n <li> ... would like to get involved in writing code or documentation.</li>\n <li> ... have some other thoughts or suggestions.</li>\n</ul>\n\nPlease, feel free to file an issue in the [Issues](https://github.com/tempoCollaboration/OQuPy/issues) section on GitHub for this. Also, have a look at [`CONTRIBUTING.md`](https://github.com/tempoCollaboration/OQuPy/blob/main/CONTRIBUTING.md) if you want to get involved in the development.\n\n## Citing, Authors and Bibliography\nSee the files [`HOW_TO_CITE.md`](https://github.com/tempoCollaboration/OQuPy/blob/main/HOW_TO_CITE.md), [`AUTHORS.md`](https://github.com/tempoCollaboration/OQuPy/blob/main/AUTHORS.md) and [`BIBLIOGRAPHY.md`](https://github.com/tempoCollaboration/OQuPy/blob/main/BIBLIOGRAPHY.md).\n\n#### Consider sharing this project:\n<p align=\"center\">\n<img src=\"docs/graphics/oqupy-github-qr.png\" alt=\"OQuPy - GitHub QR Code\" width=\"200\"/>\n</p>\n",
"bugtrack_url": null,
"license": "Apache 2.0",
"summary": "A Python 3 package to efficiently compute non-Markovian open quantum systems.",
"version": "0.5.0",
"project_urls": {
"Homepage": "http://github.com/tempoCollaboration/OQuPy"
},
"split_keywords": [
"physics",
" computational-physics",
" quantum-physics",
" quantum-information",
" open-quantum-systems"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "b68dd5db2a471caee00488e055b2e5884ea7e357d09a13d87069eaf08b82e466",
"md5": "ed823eb830f62eedc5361aed374610cf",
"sha256": "d2e7a657eeaee59007ae4dc4b30becf4bcd56228d7678f925a0f6b09f9c52080"
},
"downloads": -1,
"filename": "oqupy_gefux-0.5.0-py3-none-any.whl",
"has_sig": false,
"md5_digest": "ed823eb830f62eedc5361aed374610cf",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.10.0",
"size": 104984,
"upload_time": "2024-06-24T12:20:23",
"upload_time_iso_8601": "2024-06-24T12:20:23.093894Z",
"url": "https://files.pythonhosted.org/packages/b6/8d/d5db2a471caee00488e055b2e5884ea7e357d09a13d87069eaf08b82e466/oqupy_gefux-0.5.0-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "5a812eed1879fb6d0843e5a9c7e8cfdd081290592aff08e5712374ca36f9fce9",
"md5": "f2c50d28159238e2b3834901032b3fea",
"sha256": "24172975fd21723b60c0dbc2b4a8b6e81df779bbe22e5c9e9d89ff2810772a52"
},
"downloads": -1,
"filename": "oqupy_gefux-0.5.0.tar.gz",
"has_sig": false,
"md5_digest": "f2c50d28159238e2b3834901032b3fea",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.10.0",
"size": 127045,
"upload_time": "2024-06-24T12:20:25",
"upload_time_iso_8601": "2024-06-24T12:20:25.304680Z",
"url": "https://files.pythonhosted.org/packages/5a/81/2eed1879fb6d0843e5a9c7e8cfdd081290592aff08e5712374ca36f9fce9/oqupy_gefux-0.5.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-06-24 12:20:25",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "tempoCollaboration",
"github_project": "OQuPy",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"requirements": [
{
"name": "numpy",
"specs": [
[
"<",
"2.0"
],
[
">=",
"1.18"
]
]
},
{
"name": "scipy",
"specs": [
[
">=",
"1.4.0"
]
]
},
{
"name": "tensornetwork",
"specs": [
[
"==",
"0.4.3"
]
]
},
{
"name": "matplotlib",
"specs": [
[
">=",
"3.0.0"
]
]
},
{
"name": "h5py",
"specs": [
[
">=",
"3.1.0"
]
]
},
{
"name": "numdifftools",
"specs": [
[
">=",
"0.9.41"
]
]
}
],
"tox": true,
"lcname": "oqupy-gefux"
}