# pyDICOS
[![License](https://img.shields.io/badge/license-MIT-blue)](https://opensource.org/licenses/MIT)
[![run-tests](https://github.com/Auxilia-tech/pyDICOS/actions/workflows/tests.yml/badge.svg)](https://github.com/Auxilia-tech/pyDICOS/actions/workflows/tests.yml)
[![codecov](https://codecov.io/gh/Auxilia-tech/pyDICOS/graph/badge.svg?token=BJ9INN7187)](https://codecov.io/gh/Auxilia-tech/pyDICOS)
[![PyPI](https://img.shields.io/pypi/v/pydicos)](https://pypi.org/project/pydicos/)
[![PyPI - Downloads](https://img.shields.io/pypi/dm/pydicos?label=pypi%20downloads)](https://pypi.org/project/pydicos/)
## Motivations
This project was initiated to enable the usage of DICOS data in machine learning workflows.
PyDICOS is intended to be a simple python wrapper of Stratovan's C++ [DICOS library](https://www.stratovan.com/products/dicos-toolkit).
Note that this is **NOT** an open source implementation of the DICOS standard.
PyDICOS relies on [pybind11](https://github.com/pybind/pybind11) to wrap DICOS user-level API to python.
It depends on numpy to load data in python and can easily be installed _via_ `pip`.
PyDICOS is unrelated to [pydicom](https://github.com/pydicom/pydicom) in its implementation and contributors,
while being similar in its core spirit (enabling python data manipulations).
## Open Architecture
We firmly believe that by releasing this library, we will encourage and support the [Open Architecture framework](https://www.aci-europe.org/downloads/resources/TSA-230504-7_4.1%20Attachment%201%20OA%20for%20Airport%20Security%20Systems%202nd%20Edition%20%20FINAL.pdf). We welcome all actors of airport security to review and use this library.
## Scope
- Provide a pythonized API for the DICOS toolkit
- [x] First release : read/write functions for CT, DX and TDR, user-level API
- [x] First releases : DICOS protocol, client/server functions
- [x] Future release : more pure python functions to shave off heavy cpp signatures (`dcsread`, `dcswrite`, `get_data`, `set_data` and `CT::generate_tdr`)
- [x] Future release : library indexed in Pypi
- [ ] Out of scope for now : Windows release
- [ ] Out of scope for now : AIT2D, AIT3D, QR
- [ ] Out of scope for now : Module and Tag level APIs
- Stay up to date with Stratovan latest releases
- Currently tested and supported DICOS version : `v3`
## Install
⚠️ pyDICOS is currently only available for linux on x86 platform.
### ✨ NEW ✨ Using Pypi index (recommended)
Using [pip](https://pip.pypa.io/en/stable/) directly from Pypi index :
```bash
pip install pydicos
```
### Building from source (dev mode)
To setup the build environment, clone the repository, create your virtual environment and install required dependencies
```bash
git clone https://github.com/Auxilia-tech/pyDICOS
cd pyDICOS
python3 -m venv venv
source venv/bin/activate
pip install -r requirements.txt
```
Install the [Stratovan toolkit](https://www.stratovan.com/products/dicos-toolkit) in the `opt` folder. If the library is already installed in another folder, skip this step and change the SDICOS path variable in `setup.sh`.
```bash
chmod +x ./sdicos_lin_ubuntu-20-{version}.run
./sdicos_lin_ubuntu-20-{version}.run --unattendedmodeui none --mode unattended --prefix /opt/stratovan/sdicos
chmod 755 -R /opt/stratovan/sdicos
```
To generate a python wheel :
```bash
chmod +x setup.sh
./setup.sh
```
The lib wheel should be produced in the `dist` folder and can be installed _via_ `pip` in any local virtual environment.
## Usage
### Concept diagram
<div align="center">
<img width="850" src="assets/DICOS.svg">
</div>
### Script usage
Refer to our [exemple files](https://github.com/Auxilia-tech/pyDICOS/tests) to explore the binded methods.
The stratovan exemple files were entirely translated in python.
Here is a quick exemple for a script that reads and rewrites a CT and DX scan, and a TDR.
```python
from pydicos import dcsread, dcswrite
ct = dcsread("SimpleCT/SimpleCT.dcs")
data = ct.get_data() # list of 3-dimentionnal numpy arrays
dcswrite(ct, "SimpleCT/SimpleCT_2.dcs")
dx = dcsread("DXFiles/SimpleDX.dcs")
data = dx.get_data() # 2-dimentionnal numpy array
dcswrite(dx, "DXFiles/SimpleDX_2.dcs")
tdr = dcsread("SimpleTDR/SimpleTDR.dcs")
data = tdr.get_data() # dictionnay of metadata
dcswrite(tdr, "SimpleTDR/SimpleTDR_2.dcs")
```
✨ NEW ✨ : refer to [our notebook](notebooks/tutorial.ipynb) tutorial for instructions and examples to change an object main attribute.
### Advanced usage
More complex operations can be addressed by using the C++ functions directly.
They can be invoked using the `pyDICOS` modules. For example, the previous
script would look like this :
```python
from pyDICOS import CT, DX, TDR, ErrorLog, Filename
ct, err, file = CT(), ErrorLog(), Filename("SimpleCT/SimpleCT.dcs")
if not ct.Read(file, err, None):
raise RuntimeError(f"Failed to read DICOS file: {file.Get()}\n{err.GetErrorLog().Get()}")
data = ... # This is very long, refer to pydicos._loaders::CTLoader.get_data for full script
if not ct.Write(Filename("SimpleCT/SimpleCT_2.dcs"), err):
raise RuntimeError(f"Failed to write DICOS file: SimpleCT/SimpleCT_2.dcs\n{err.GetErrorLog().Get()}")
dx, err, file = DX(), ErrorLog(), Filename("SimpleDX/SimpleDX.dcs")
if not dx.Read(file, err, None):
raise RuntimeError(f"Failed to read DICOS file: {file.Get()}\n{err.GetErrorLog().Get()}")
data = np.array(dx.GetXRayData().GetUnsigned16(), copy=False)
if not dx.Write(Filename("SimpleDX/SimpleDX_2.dcs"), err):
raise RuntimeError(f"Failed to write DICOS file: SimpleDX/SimpleDX_2.dcs\n{err.GetErrorLog().Get()}")
tdr, err, file = TDR(), ErrorLog(), Filename("SimpleTDR/SimpleTDR.dcs")
if not tdr.Read(file, err, None):
raise RuntimeError(f"Failed to read DICOS file: {filename}\n{err.GetErrorLog().Get()}")
data = ... # This is very long, refer to pydicos._loaders::TDRLoader.get_data for full script
if not tdr.Write(Filename("SimpleTDR/SimpleTDR_2.dcs"), err):
raise RuntimeError(f"Failed to write DICOS file: SimpleTDR/SimpleTDR_2.dcs\n{err.GetErrorLog().Get()}")
```
As you can see, `pyDICOS` is the direct translation of the C++ classes and in-place method signatures.
The objects of the `pydicos` library inherit the methods available in `pyDICOS`.
More details in [architecture](pydicos/README.md).
### Testing
The library can be tested via `pytest`
```bash
pytest tests/
```
## Contributing
As our resources are limited, we very much value your contributions, be it bug fixes, new core features, or documentation improvements.
For more information, please read our [contribution guide](CONTRIBUTING.md).
### Contributors acknowledgement
Many thanks to our main contributors :
- [Ahmad Audi](https://github.com/AAUDI) is a freelance developper specialized in C++ and python. He is available for similar work on [upwork](https://www.upwork.com/freelancers/~01a066bd29ed6d1a64). [LinkedIn](https://www.linkedin.com/in/ahmadaudi/)
- [Louis Combaldieu](https://github.com/lcombaldieu) is the cofounder and CTO of Auxilia. He specializes in deep learning and computer vision. Get in touch with him through our [contact form](https://www.auxilia-tech.com/contact) to learn more about pyDICOS and Auxilia's line of products.
## License
This software is released under the [MIT license](https://opensource.org/licenses/MIT).
### Stratovan inherited disclaimer
##############################################################################
### Stratovan Corporation Copyright and Disclaimer Notice:
###
### Copyright (c) 2014 Stratovan Corporation. All Rights Reserved.
###
### Permission to use, copy, modify, and distribute this software and its
### documentation without a signed licensing agreement, is hereby granted,
### provided that this copyright notice, this paragraph and the following two
### paragraphs appear in all copies, modifications, and distributions.
###
### IN NO EVENT SHALL STRATOVAN BE LIABLE TO ANY PARTY FOR DIRECT, INDIRECT,
### SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, INCLUDING LOST PROFITS,
### ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF
### STRATOVAN HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
###
### STRATOVAN SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING, BUT NOT LIMITED
### TO, THE IMPLIED WARRANTIES OF USE AND FITNESS FOR A PARTICULAR PURPOSE. THE
### SOFTWARE AND ACCOMPANYING DOCUMENTATION, IF ANY, PROVIDED HEREUNDER IS
### PROVIDED "AS IS". STRATOVAN HAS NO OBLIGATION TO PROVIDE MAINTENANCE,
### SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS UNLESS DIRECTED BY THE
### U.S. GOVERNMENT'S TRANSPORTATION SECURITY ADMINISTRATION (TSA).
###
##############################################################################
Raw data
{
"_id": null,
"home_page": "https://github.com/Auxilia-tech/pydicos",
"name": "pydicos",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3",
"maintainer_email": null,
"keywords": "DICOS, Digital, Imaging, Communications, Security",
"author": "Louis Combaldieu",
"author_email": "louis.combaldieu@auxilia-tech.com",
"download_url": "https://github.com/Auxilia-tech/pydicos/",
"platform": null,
"description": "# pyDICOS\n\n[![License](https://img.shields.io/badge/license-MIT-blue)](https://opensource.org/licenses/MIT)\n[![run-tests](https://github.com/Auxilia-tech/pyDICOS/actions/workflows/tests.yml/badge.svg)](https://github.com/Auxilia-tech/pyDICOS/actions/workflows/tests.yml)\n[![codecov](https://codecov.io/gh/Auxilia-tech/pyDICOS/graph/badge.svg?token=BJ9INN7187)](https://codecov.io/gh/Auxilia-tech/pyDICOS)\n[![PyPI](https://img.shields.io/pypi/v/pydicos)](https://pypi.org/project/pydicos/)\n[![PyPI - Downloads](https://img.shields.io/pypi/dm/pydicos?label=pypi%20downloads)](https://pypi.org/project/pydicos/)\n\n## Motivations\n\nThis project was initiated to enable the usage of DICOS data in machine learning workflows. \nPyDICOS is intended to be a simple python wrapper of Stratovan's C++ [DICOS library](https://www.stratovan.com/products/dicos-toolkit).\nNote that this is **NOT** an open source implementation of the DICOS standard.\n\nPyDICOS relies on [pybind11](https://github.com/pybind/pybind11) to wrap DICOS user-level API to python.\nIt depends on numpy to load data in python and can easily be installed _via_ `pip`.\n\nPyDICOS is unrelated to [pydicom](https://github.com/pydicom/pydicom) in its implementation and contributors, \nwhile being similar in its core spirit (enabling python data manipulations).\n\n## Open Architecture\n\nWe firmly believe that by releasing this library, we will encourage and support the [Open Architecture framework](https://www.aci-europe.org/downloads/resources/TSA-230504-7_4.1%20Attachment%201%20OA%20for%20Airport%20Security%20Systems%202nd%20Edition%20%20FINAL.pdf). We welcome all actors of airport security to review and use this library.\n\n## Scope\n\n - Provide a pythonized API for the DICOS toolkit\n - [x] First release : read/write functions for CT, DX and TDR, user-level API\n - [x] First releases : DICOS protocol, client/server functions\n - [x] Future release : more pure python functions to shave off heavy cpp signatures (`dcsread`, `dcswrite`, `get_data`, `set_data` and `CT::generate_tdr`)\n - [x] Future release : library indexed in Pypi \n - [ ] Out of scope for now : Windows release\n - [ ] Out of scope for now : AIT2D, AIT3D, QR\n - [ ] Out of scope for now : Module and Tag level APIs\n - Stay up to date with Stratovan latest releases\n - Currently tested and supported DICOS version : `v3`\n\n## Install\n\n\u26a0\ufe0f pyDICOS is currently only available for linux on x86 platform.\n\n### \u2728 NEW \u2728 Using Pypi index (recommended)\n\nUsing [pip](https://pip.pypa.io/en/stable/) directly from Pypi index :\n```bash\npip install pydicos\n```\n\n### Building from source (dev mode)\n\nTo setup the build environment, clone the repository, create your virtual environment and install required dependencies\n\n```bash\ngit clone https://github.com/Auxilia-tech/pyDICOS\ncd pyDICOS\npython3 -m venv venv\nsource venv/bin/activate\npip install -r requirements.txt\n```\n\nInstall the [Stratovan toolkit](https://www.stratovan.com/products/dicos-toolkit) in the `opt` folder. If the library is already installed in another folder, skip this step and change the SDICOS path variable in `setup.sh`.\n```bash\nchmod +x ./sdicos_lin_ubuntu-20-{version}.run\n./sdicos_lin_ubuntu-20-{version}.run --unattendedmodeui none --mode unattended --prefix /opt/stratovan/sdicos\nchmod 755 -R /opt/stratovan/sdicos\n```\n\nTo generate a python wheel :\n\n```bash\nchmod +x setup.sh\n./setup.sh\n```\n\nThe lib wheel should be produced in the `dist` folder and can be installed _via_ `pip` in any local virtual environment.\n\n## Usage\n\n### Concept diagram\n\n<div align=\"center\">\n<img width=\"850\" src=\"assets/DICOS.svg\">\n</div>\n\n### Script usage\n\nRefer to our [exemple files](https://github.com/Auxilia-tech/pyDICOS/tests) to explore the binded methods.\nThe stratovan exemple files were entirely translated in python.\n\nHere is a quick exemple for a script that reads and rewrites a CT and DX scan, and a TDR.\n\n```python\nfrom pydicos import dcsread, dcswrite\n\nct = dcsread(\"SimpleCT/SimpleCT.dcs\")\ndata = ct.get_data() # list of 3-dimentionnal numpy arrays\ndcswrite(ct, \"SimpleCT/SimpleCT_2.dcs\")\n\ndx = dcsread(\"DXFiles/SimpleDX.dcs\")\ndata = dx.get_data() # 2-dimentionnal numpy array\ndcswrite(dx, \"DXFiles/SimpleDX_2.dcs\")\n\ntdr = dcsread(\"SimpleTDR/SimpleTDR.dcs\")\ndata = tdr.get_data() # dictionnay of metadata\ndcswrite(tdr, \"SimpleTDR/SimpleTDR_2.dcs\")\n```\n\n\u2728 NEW \u2728 : refer to [our notebook](notebooks/tutorial.ipynb) tutorial for instructions and examples to change an object main attribute.\n\n### Advanced usage\n\nMore complex operations can be addressed by using the C++ functions directly. \nThey can be invoked using the `pyDICOS` modules. For example, the previous \nscript would look like this :\n\n```python\nfrom pyDICOS import CT, DX, TDR, ErrorLog, Filename\n \nct, err, file = CT(), ErrorLog(), Filename(\"SimpleCT/SimpleCT.dcs\")\nif not ct.Read(file, err, None):\n raise RuntimeError(f\"Failed to read DICOS file: {file.Get()}\\n{err.GetErrorLog().Get()}\")\ndata = ... # This is very long, refer to pydicos._loaders::CTLoader.get_data for full script\nif not ct.Write(Filename(\"SimpleCT/SimpleCT_2.dcs\"), err):\n raise RuntimeError(f\"Failed to write DICOS file: SimpleCT/SimpleCT_2.dcs\\n{err.GetErrorLog().Get()}\")\n\ndx, err, file = DX(), ErrorLog(), Filename(\"SimpleDX/SimpleDX.dcs\")\nif not dx.Read(file, err, None):\n raise RuntimeError(f\"Failed to read DICOS file: {file.Get()}\\n{err.GetErrorLog().Get()}\")\ndata = np.array(dx.GetXRayData().GetUnsigned16(), copy=False)\nif not dx.Write(Filename(\"SimpleDX/SimpleDX_2.dcs\"), err):\n raise RuntimeError(f\"Failed to write DICOS file: SimpleDX/SimpleDX_2.dcs\\n{err.GetErrorLog().Get()}\")\n\ntdr, err, file = TDR(), ErrorLog(), Filename(\"SimpleTDR/SimpleTDR.dcs\")\nif not tdr.Read(file, err, None):\n raise RuntimeError(f\"Failed to read DICOS file: {filename}\\n{err.GetErrorLog().Get()}\")\ndata = ... # This is very long, refer to pydicos._loaders::TDRLoader.get_data for full script\nif not tdr.Write(Filename(\"SimpleTDR/SimpleTDR_2.dcs\"), err):\n raise RuntimeError(f\"Failed to write DICOS file: SimpleTDR/SimpleTDR_2.dcs\\n{err.GetErrorLog().Get()}\")\n```\nAs you can see, `pyDICOS` is the direct translation of the C++ classes and in-place method signatures. \nThe objects of the `pydicos` library inherit the methods available in `pyDICOS`. \nMore details in [architecture](pydicos/README.md).\n\n### Testing\n\nThe library can be tested via `pytest`\n```bash\npytest tests/\n```\n\n## Contributing\n\nAs our resources are limited, we very much value your contributions, be it bug fixes, new core features, or documentation improvements.\nFor more information, please read our [contribution guide](CONTRIBUTING.md).\n\n### Contributors acknowledgement\n\nMany thanks to our main contributors :\n\n - [Ahmad Audi](https://github.com/AAUDI) is a freelance developper specialized in C++ and python. He is available for similar work on [upwork](https://www.upwork.com/freelancers/~01a066bd29ed6d1a64). [LinkedIn](https://www.linkedin.com/in/ahmadaudi/)\n - [Louis Combaldieu](https://github.com/lcombaldieu) is the cofounder and CTO of Auxilia. He specializes in deep learning and computer vision. Get in touch with him through our [contact form](https://www.auxilia-tech.com/contact) to learn more about pyDICOS and Auxilia's line of products.\n\n## License\n\nThis software is released under the [MIT license](https://opensource.org/licenses/MIT).\n\n### Stratovan inherited disclaimer\n\n ##############################################################################\n ### Stratovan Corporation Copyright and Disclaimer Notice:\n ###\n ### Copyright (c) 2014 Stratovan Corporation. All Rights Reserved.\n ###\n ### Permission to use, copy, modify, and distribute this software and its\n ### documentation without a signed licensing agreement, is hereby granted,\n ### provided that this copyright notice, this paragraph and the following two\n ### paragraphs appear in all copies, modifications, and distributions.\n ###\n ### IN NO EVENT SHALL STRATOVAN BE LIABLE TO ANY PARTY FOR DIRECT, INDIRECT,\n ### SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, INCLUDING LOST PROFITS,\n ### ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF\n ### STRATOVAN HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n ###\n ### STRATOVAN SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING, BUT NOT LIMITED\n ### TO, THE IMPLIED WARRANTIES OF USE AND FITNESS FOR A PARTICULAR PURPOSE. THE\n ### SOFTWARE AND ACCOMPANYING DOCUMENTATION, IF ANY, PROVIDED HEREUNDER IS\n ### PROVIDED \"AS IS\". STRATOVAN HAS NO OBLIGATION TO PROVIDE MAINTENANCE,\n ### SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS UNLESS DIRECTED BY THE\n ### U.S. GOVERNMENT'S TRANSPORTATION SECURITY ADMINISTRATION (TSA).\n ###\n ##############################################################################\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "pyDICOS is a python package for working with DICOS files.",
"version": "1.2.4",
"project_urls": {
"Download": "https://github.com/Auxilia-tech/pydicos/",
"Homepage": "https://github.com/Auxilia-tech/pydicos"
},
"split_keywords": [
"dicos",
" digital",
" imaging",
" communications",
" security"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "1380a022945ca8854c17b97e34525cb1251b862981bce900d06ce20a568b4c6c",
"md5": "5fbaaf5bbc9f6106ec7d3200fa83e7d8",
"sha256": "19896cf5a26113df97215f7bd89cd331cc0157ee24b8f5497317d8d8e2a0971d"
},
"downloads": -1,
"filename": "pydicos-1.2.4-cp310-cp310-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl",
"has_sig": false,
"md5_digest": "5fbaaf5bbc9f6106ec7d3200fa83e7d8",
"packagetype": "bdist_wheel",
"python_version": "cp310",
"requires_python": ">=3",
"size": 5677674,
"upload_time": "2024-10-29T12:34:58",
"upload_time_iso_8601": "2024-10-29T12:34:58.874902Z",
"url": "https://files.pythonhosted.org/packages/13/80/a022945ca8854c17b97e34525cb1251b862981bce900d06ce20a568b4c6c/pydicos-1.2.4-cp310-cp310-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "061c7c7aa2ef625f99afdbd93c338101609399105b1cda99b080b2b10eecb798",
"md5": "f0d8999f491b525b5f8bfe81e6f291f4",
"sha256": "9d3bb7379b63c08819e0405218d9f31ffa3832efc54c3fdae735a2d92d377d7e"
},
"downloads": -1,
"filename": "pydicos-1.2.4-cp311-cp311-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl",
"has_sig": false,
"md5_digest": "f0d8999f491b525b5f8bfe81e6f291f4",
"packagetype": "bdist_wheel",
"python_version": "cp311",
"requires_python": ">=3",
"size": 5679455,
"upload_time": "2024-10-29T12:35:00",
"upload_time_iso_8601": "2024-10-29T12:35:00.887296Z",
"url": "https://files.pythonhosted.org/packages/06/1c/7c7aa2ef625f99afdbd93c338101609399105b1cda99b080b2b10eecb798/pydicos-1.2.4-cp311-cp311-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "3eb2b4aa7eb671e62249646038f1935b52e9f7eb463f42d6337079cddc23dd75",
"md5": "47962d251d1bd8639f0f031aa9fda5e4",
"sha256": "8201e1cf5f04c456ba82777883b898ca83b9ba0960dc0f89d22328a1f6f4ad9a"
},
"downloads": -1,
"filename": "pydicos-1.2.4-cp37-cp37m-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl",
"has_sig": false,
"md5_digest": "47962d251d1bd8639f0f031aa9fda5e4",
"packagetype": "bdist_wheel",
"python_version": "cp37",
"requires_python": ">=3",
"size": 5747343,
"upload_time": "2024-10-29T12:35:03",
"upload_time_iso_8601": "2024-10-29T12:35:03.047378Z",
"url": "https://files.pythonhosted.org/packages/3e/b2/b4aa7eb671e62249646038f1935b52e9f7eb463f42d6337079cddc23dd75/pydicos-1.2.4-cp37-cp37m-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "93d61ef8ec74d4f823197decd516fb261bff992d7b4b9e1010d3166dfa00c96c",
"md5": "e50f0ae05a3338b524d6ce321f9d4a6a",
"sha256": "28ba37202d16e6f3881d6fe0d39ebd4d07ca3a94f0ab635a3bebf45292a25af7"
},
"downloads": -1,
"filename": "pydicos-1.2.4-cp38-cp38-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl",
"has_sig": false,
"md5_digest": "e50f0ae05a3338b524d6ce321f9d4a6a",
"packagetype": "bdist_wheel",
"python_version": "cp38",
"requires_python": ">=3",
"size": 5677906,
"upload_time": "2024-10-29T12:35:04",
"upload_time_iso_8601": "2024-10-29T12:35:04.440177Z",
"url": "https://files.pythonhosted.org/packages/93/d6/1ef8ec74d4f823197decd516fb261bff992d7b4b9e1010d3166dfa00c96c/pydicos-1.2.4-cp38-cp38-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "2861a3b119d91b6eda121d71634b6a8933b21fc6654c3320aa5ccd42fd988264",
"md5": "8c32b7bf32c4d744b995acb0892f1d72",
"sha256": "10d6f83bcbff979b792ae377457bcf19a59bf930d6b22ff5f1b7d94e766af557"
},
"downloads": -1,
"filename": "pydicos-1.2.4-cp39-cp39-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl",
"has_sig": false,
"md5_digest": "8c32b7bf32c4d744b995acb0892f1d72",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": ">=3",
"size": 5680169,
"upload_time": "2024-10-29T12:35:06",
"upload_time_iso_8601": "2024-10-29T12:35:06.340961Z",
"url": "https://files.pythonhosted.org/packages/28/61/a3b119d91b6eda121d71634b6a8933b21fc6654c3320aa5ccd42fd988264/pydicos-1.2.4-cp39-cp39-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-10-29 12:34:58",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "Auxilia-tech",
"github_project": "pydicos",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"requirements": [
{
"name": "numpy",
"specs": []
},
{
"name": "pybind11",
"specs": []
},
{
"name": "cmake",
"specs": []
},
{
"name": "wheel",
"specs": []
},
{
"name": "build",
"specs": []
},
{
"name": "pytest",
"specs": []
},
{
"name": "pytest-order",
"specs": []
}
],
"lcname": "pydicos"
}