pydicos


Namepydicos JSON
Version 1.2.8 PyPI version JSON
download
home_pagehttps://github.com/Auxilia-tech/pydicos
SummarypyDICOS is a python package for working with DICOS files.
upload_time2025-01-29 15:01:37
maintainerNone
docs_urlNone
authorLouis Combaldieu
requires_python>=3
licenseMIT
keywords dicos digital imaging communications security
VCS
bugtrack_url
requirements numpy pybind11 cmake wheel build pytest pytest-order
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # 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 [example files](https://github.com/Auxilia-tech/pyDICOS/tree/main/tests) to explore the bound methods.
The Stratovan example files were entirely translated in python.

Here is a quick example 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 developer 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 [example files](https://github.com/Auxilia-tech/pyDICOS/tree/main/tests) to explore the bound methods.\nThe Stratovan example files were entirely translated in python.\n\nHere is a quick example 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 developer 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.8",
    "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": null,
            "digests": {
                "blake2b_256": "05726a0c6eb138ec8b1f9b4de21ffdf6904063cfda57db161960bc2f09b0b293",
                "md5": "451480a38c96036a168698ae838c9282",
                "sha256": "3ef8ae759085b52527ff7826de84a9a357cfbfcf29f5c298d80ccbd71bb3ca19"
            },
            "downloads": -1,
            "filename": "pydicos-1.2.8-cp310-cp310-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl",
            "has_sig": false,
            "md5_digest": "451480a38c96036a168698ae838c9282",
            "packagetype": "bdist_wheel",
            "python_version": "cp310",
            "requires_python": ">=3",
            "size": 5681805,
            "upload_time": "2025-01-29T15:01:37",
            "upload_time_iso_8601": "2025-01-29T15:01:37.097866Z",
            "url": "https://files.pythonhosted.org/packages/05/72/6a0c6eb138ec8b1f9b4de21ffdf6904063cfda57db161960bc2f09b0b293/pydicos-1.2.8-cp310-cp310-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "d048c61db6ff65af91300b7e5d672cb48ed7b77ded449a8cf36bba235bc2d8ef",
                "md5": "45f5a9cedf5e1e984ebdf59c47dff201",
                "sha256": "39d981b0f197946803e62c063ec7a6fc5954ff1438df2de7b84e9d8d1e28ca52"
            },
            "downloads": -1,
            "filename": "pydicos-1.2.8-cp311-cp311-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl",
            "has_sig": false,
            "md5_digest": "45f5a9cedf5e1e984ebdf59c47dff201",
            "packagetype": "bdist_wheel",
            "python_version": "cp311",
            "requires_python": ">=3",
            "size": 5681038,
            "upload_time": "2025-01-29T15:01:40",
            "upload_time_iso_8601": "2025-01-29T15:01:40.015176Z",
            "url": "https://files.pythonhosted.org/packages/d0/48/c61db6ff65af91300b7e5d672cb48ed7b77ded449a8cf36bba235bc2d8ef/pydicos-1.2.8-cp311-cp311-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "3da4ede852089895af90a676c70ba6b61d17e0e578a486488be9e0c814484038",
                "md5": "0121b74ebb0b22691db3669652a67a14",
                "sha256": "4935652d14ffd7020e21144d01d4358be896ced48f5ac87d042d70bb2db61c57"
            },
            "downloads": -1,
            "filename": "pydicos-1.2.8-cp37-cp37m-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl",
            "has_sig": false,
            "md5_digest": "0121b74ebb0b22691db3669652a67a14",
            "packagetype": "bdist_wheel",
            "python_version": "cp37",
            "requires_python": ">=3",
            "size": 5750705,
            "upload_time": "2025-01-29T15:01:42",
            "upload_time_iso_8601": "2025-01-29T15:01:42.001516Z",
            "url": "https://files.pythonhosted.org/packages/3d/a4/ede852089895af90a676c70ba6b61d17e0e578a486488be9e0c814484038/pydicos-1.2.8-cp37-cp37m-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "27648affbb06cc291a5975010e2e08f605c642c2f99bc08b56519025d0c4cf80",
                "md5": "99cefedf6566b7943b536a558bcddf9d",
                "sha256": "2c37f30f8c18a968b0142121cb3295b427387edfb819d5ff35c7b72391ba67ef"
            },
            "downloads": -1,
            "filename": "pydicos-1.2.8-cp38-cp38-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl",
            "has_sig": false,
            "md5_digest": "99cefedf6566b7943b536a558bcddf9d",
            "packagetype": "bdist_wheel",
            "python_version": "cp38",
            "requires_python": ">=3",
            "size": 5680068,
            "upload_time": "2025-01-29T15:01:45",
            "upload_time_iso_8601": "2025-01-29T15:01:45.999910Z",
            "url": "https://files.pythonhosted.org/packages/27/64/8affbb06cc291a5975010e2e08f605c642c2f99bc08b56519025d0c4cf80/pydicos-1.2.8-cp38-cp38-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "3973d60da6c6a90eed1ff497f8fc4f898cf4a9e46511b183cf9eaf22b018e955",
                "md5": "104390ef77f33919c7cd80c2f20384a5",
                "sha256": "b0c322cf80bb6b01cb79a8ab476456e3be715eba442ec1a2a9cfa8e811be4e9f"
            },
            "downloads": -1,
            "filename": "pydicos-1.2.8-cp39-cp39-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl",
            "has_sig": false,
            "md5_digest": "104390ef77f33919c7cd80c2f20384a5",
            "packagetype": "bdist_wheel",
            "python_version": "cp39",
            "requires_python": ">=3",
            "size": 5682019,
            "upload_time": "2025-01-29T15:01:48",
            "upload_time_iso_8601": "2025-01-29T15:01:48.725906Z",
            "url": "https://files.pythonhosted.org/packages/39/73/d60da6c6a90eed1ff497f8fc4f898cf4a9e46511b183cf9eaf22b018e955/pydicos-1.2.8-cp39-cp39-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-01-29 15:01:37",
    "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"
}
        
Elapsed time: 3.62789s