Name | FlowCyPy JSON |
Version |
0.7.0
JSON |
| download |
home_page | None |
Summary | A package for flow-cytometry simulations. |
upload_time | 2025-01-15 14:25:59 |
maintainer | None |
docs_url | None |
author | None |
requires_python | >=3.10 |
license | MIT License Copyright (c) 2020 Martin de Sivry Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
keywords |
refracive index
optics
microbeads
mie scattering
|
VCS |
|
bugtrack_url |
|
requirements |
No requirements were recorded.
|
Travis-CI |
No Travis.
|
coveralls test coverage |
No coveralls.
|
|logo|
FlowCyPy: Flow Cytometer Simulation Tool
========================================
.. list-table::
:widths: 10 25 25 25
:header-rows: 0
* - Meta
- |python|
- |docs|
-
* - Testing
- |ci/cd|
- |coverage|
-
* - PyPi
- |PyPi|
- |PyPi_download|
-
* - Anaconda
- |anaconda|
- |anaconda_download|
- |anaconda_date|
Overview
--------
**FlowCyPy** is a cutting-edge Python library designed to simulate flow cytometer experiments. By generating realistic Forward Scatter (FSC) and Side Scatter (SSC) signals, FlowCyPy enables detailed modeling of flow cytometry setups, making it ideal for researchers and engineers working with extracellular vesicles (EVs) or other scatterers.
Key Features
------------
- **Particle Event Simulation**: Create detailed FSC/SSC signals with customizable particle size and refractive index distributions.
- **Noise and Signal Modeling**: Incorporate realistic noise sources (thermal, shot, dark current) and baseline shifts.
- **Detector Configurations**: Simulate real-world detector behaviors, including saturation and responsivity.
- **Fluorescence Modeling**: Simulate fluorescence signals for labeled particles (e.g., EV surface markers).
- **Visualization Tools**: Generate advanced plots, including density maps and signal traces.
For full documentation and examples, visit the `FlowCyPy Documentation <https://martinpdes.github.io/FlowCyPy/>`_.
Installation
------------
Install FlowCyPy via `pip` or `conda``:
.. code-block:: bash
pip install FlowCyPy
conda install FlowCyPy --channels MartinPdeS
**Requirements**: Python 3.10 or higher with dependencies:
`numpy`, `scipy`, `pint`, `tabulate`, `seaborn`, `MPSPlots`, `PyMieSim`, `pydantic>=2.6.3`
Quick Start
-----------
Simulate a simple flow cytometer experiment:
.. code-block:: python
from FlowCyPy import FlowCytometer, ScattererCollection, FlowCell
from FlowCyPy.units import particle, liter, nanometer, RIU
# Define the flow cell
flow_cell = FlowCell(
flow_speed=1.0, flow_area=10e-6, run_time=0.01
)
# Define scatterer properties
scatterer = ScattererCollection(medium_refractive_index=1.33 * RIU)
scatterer.add_population(
name='EVs',
concentration=1e9 * particle / liter,
size=distribution.Normal(mean=100 * nanometer, std_dev=20 * nanometer),
refractive_index=distribution.Normal(mean=1.45 * RIU, std_dev=0.01 * RIU)
)
flow_cell.initialize(scatterer=scatterer)
# Simulate the cytometer signals
cytometer = FlowCytometer(
flow_cell=flow_cell,
source=source,
detectors=[detector_fsc, detector_ssc]
)
cytometer.simulate_pulse()
cytometer.plot()
Explore more examples in the `FlowCyPy Examples <https://martinpdes.github.io/FlowCyPy/gallery/index.html>`_.
Development and Contribution
-----------------------------
Clone the Repository
~~~~~~~~~~~~~~~~~~~~
.. code-block:: bash
git clone https://github.com/MartinPdeS/FlowCyPy.git
cd FlowCyPy
Install Locally
~~~~~~~~~~~~~~~
Install in editable mode with testing and documentation dependencies:
.. code-block:: bash
pip install -e .[testing,documentation]
Run Tests
~~~~~~~~~
Use `pytest` to validate functionality:
.. code-block:: bash
pytest
Build Documentation
~~~~~~~~~~~~~~~~~~~
Build the documentation locally:
.. code-block:: bash
cd docs
make html
Find the documentation in `docs/_build/html`.
Additional Resources
--------------------
- **Documentation**: Full guide and API reference at `FlowCyPy Documentation <https://martinpdes.github.io/FlowCyPy/>`_
- **Examples**: Explore use cases in the `Examples Section <https://martinpdes.github.io/FlowCyPy/gallery/index.html>`_
Contributions
-------------
Contributions are welcome! If you have suggestions, issues, or would like to collaborate, visit the `GitHub repository <https://github.com/MartinPdeS/FlowCyPy>`_.
Contact
-------
For inquiries or collaboration, contact `Martin Poinsinet de Sivry-Houle <mailto:martin.poinsinet.de.sivry@gmail.com>`_.
.. |logo| image:: https://github.com/MartinPdeS/FlowCyPy/raw/master/docs/images/logo.png
:align: middle
:alt: FlowCyPy Logo
.. |python| image:: https://img.shields.io/pypi/pyversions/flowcypy.svg
:alt: Python
:target: https://www.python.org/
.. |docs| image:: https://github.com/martinpdes/flowcypy/actions/workflows/deploy_documentation.yml/badge.svg
:target: https://martinpdes.github.io/FlowCyPy/
:alt: Documentation Status
.. |PyPi| image:: https://badge.fury.io/py/FlowCyPy.svg
:alt: PyPi version
:target: https://badge.fury.io/py/FlowCyPy
.. |PyPi_download| image:: https://img.shields.io/pypi/dm/FlowCyPy?style=plastic&label=PyPi%20downloads&labelColor=hex&color=hex
:alt: PyPI - Downloads
:target: https://pypistats.org/packages/flowcypy
.. |coverage| image:: https://raw.githubusercontent.com/MartinPdeS/FlowCyPy/python-coverage-comment-action-data/badge.svg
:alt: Unittest coverage
:target: https://htmlpreview.github.io/?https://github.com/MartinPdeS/FlowCyPy/blob/python-coverage-comment-action-data/htmlcov/index.html
.. |ci/cd| image:: https://github.com/martinpdes/flowcypy/actions/workflows/deploy_coverage.yml/badge.svg
:alt: Unittest Status
.. |anaconda| image:: https://anaconda.org/martinpdes/flowcypy/badges/version.svg
:alt: Anaconda version
:target: https://anaconda.org/martinpdes/flowcypy
.. |anaconda_download| image:: https://anaconda.org/martinpdes/flowcypy/badges/downloads.svg
:alt: Anaconda downloads
:target: https://anaconda.org/martinpdes/flowcypy
.. |anaconda_date| image:: https://anaconda.org/martinpdes/flowcypy/badges/latest_release_relative_date.svg
:alt: Latest release date
:target: https://anaconda.org/martinpdes/flowcypy
Raw data
{
"_id": null,
"home_page": null,
"name": "FlowCyPy",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.10",
"maintainer_email": null,
"keywords": "refracive index, optics, microbeads, Mie scattering",
"author": null,
"author_email": "Martin Poinsinet de Sivry-Houle <martin.poinsinet.de.sivry@gmail.com>",
"download_url": "https://files.pythonhosted.org/packages/f2/ac/13763f6ca3a97c415c4fd5783145922fc018483dadce6622b7e7d071df7f/flowcypy-0.7.0.tar.gz",
"platform": null,
"description": "|logo|\n\nFlowCyPy: Flow Cytometer Simulation Tool\n========================================\n\n.. list-table::\n :widths: 10 25 25 25\n :header-rows: 0\n\n * - Meta\n - |python|\n - |docs|\n -\n * - Testing\n - |ci/cd|\n - |coverage|\n -\n * - PyPi\n - |PyPi|\n - |PyPi_download|\n -\n * - Anaconda\n - |anaconda|\n - |anaconda_download|\n - |anaconda_date|\n\nOverview\n--------\n\n**FlowCyPy** is a cutting-edge Python library designed to simulate flow cytometer experiments. By generating realistic Forward Scatter (FSC) and Side Scatter (SSC) signals, FlowCyPy enables detailed modeling of flow cytometry setups, making it ideal for researchers and engineers working with extracellular vesicles (EVs) or other scatterers.\n\nKey Features\n------------\n\n- **Particle Event Simulation**: Create detailed FSC/SSC signals with customizable particle size and refractive index distributions.\n- **Noise and Signal Modeling**: Incorporate realistic noise sources (thermal, shot, dark current) and baseline shifts.\n- **Detector Configurations**: Simulate real-world detector behaviors, including saturation and responsivity.\n- **Fluorescence Modeling**: Simulate fluorescence signals for labeled particles (e.g., EV surface markers).\n- **Visualization Tools**: Generate advanced plots, including density maps and signal traces.\n\nFor full documentation and examples, visit the `FlowCyPy Documentation <https://martinpdes.github.io/FlowCyPy/>`_.\n\nInstallation\n------------\n\nInstall FlowCyPy via `pip` or `conda``:\n\n.. code-block:: bash\n\n pip install FlowCyPy\n conda install FlowCyPy --channels MartinPdeS\n\n**Requirements**: Python 3.10 or higher with dependencies:\n`numpy`, `scipy`, `pint`, `tabulate`, `seaborn`, `MPSPlots`, `PyMieSim`, `pydantic>=2.6.3`\n\nQuick Start\n-----------\n\nSimulate a simple flow cytometer experiment:\n\n.. code-block:: python\n\n from FlowCyPy import FlowCytometer, ScattererCollection, FlowCell\n from FlowCyPy.units import particle, liter, nanometer, RIU\n\n # Define the flow cell\n flow_cell = FlowCell(\n flow_speed=1.0, flow_area=10e-6, run_time=0.01\n )\n\n # Define scatterer properties\n scatterer = ScattererCollection(medium_refractive_index=1.33 * RIU)\n scatterer.add_population(\n name='EVs',\n concentration=1e9 * particle / liter,\n size=distribution.Normal(mean=100 * nanometer, std_dev=20 * nanometer),\n refractive_index=distribution.Normal(mean=1.45 * RIU, std_dev=0.01 * RIU)\n )\n flow_cell.initialize(scatterer=scatterer) \n\n # Simulate the cytometer signals\n cytometer = FlowCytometer(\n flow_cell=flow_cell,\n source=source,\n detectors=[detector_fsc, detector_ssc]\n )\n cytometer.simulate_pulse()\n cytometer.plot()\n\nExplore more examples in the `FlowCyPy Examples <https://martinpdes.github.io/FlowCyPy/gallery/index.html>`_.\n\nDevelopment and Contribution\n-----------------------------\n\nClone the Repository\n~~~~~~~~~~~~~~~~~~~~\n\n.. code-block:: bash\n\n git clone https://github.com/MartinPdeS/FlowCyPy.git\n cd FlowCyPy\n\nInstall Locally\n~~~~~~~~~~~~~~~\n\nInstall in editable mode with testing and documentation dependencies:\n\n.. code-block:: bash\n\n pip install -e .[testing,documentation]\n\nRun Tests\n~~~~~~~~~\n\nUse `pytest` to validate functionality:\n\n.. code-block:: bash\n\n pytest\n\nBuild Documentation\n~~~~~~~~~~~~~~~~~~~\n\nBuild the documentation locally:\n\n.. code-block:: bash\n\n cd docs\n make html\n\nFind the documentation in `docs/_build/html`.\n\nAdditional Resources\n--------------------\n\n- **Documentation**: Full guide and API reference at `FlowCyPy Documentation <https://martinpdes.github.io/FlowCyPy/>`_\n- **Examples**: Explore use cases in the `Examples Section <https://martinpdes.github.io/FlowCyPy/gallery/index.html>`_\n\nContributions\n-------------\n\nContributions are welcome! If you have suggestions, issues, or would like to collaborate, visit the `GitHub repository <https://github.com/MartinPdeS/FlowCyPy>`_.\n\nContact\n-------\n\nFor inquiries or collaboration, contact `Martin Poinsinet de Sivry-Houle <mailto:martin.poinsinet.de.sivry@gmail.com>`_.\n\n.. |logo| image:: https://github.com/MartinPdeS/FlowCyPy/raw/master/docs/images/logo.png\n :align: middle\n :alt: FlowCyPy Logo\n\n.. |python| image:: https://img.shields.io/pypi/pyversions/flowcypy.svg\n :alt: Python\n :target: https://www.python.org/\n\n.. |docs| image:: https://github.com/martinpdes/flowcypy/actions/workflows/deploy_documentation.yml/badge.svg\n :target: https://martinpdes.github.io/FlowCyPy/\n :alt: Documentation Status\n\n.. |PyPi| image:: https://badge.fury.io/py/FlowCyPy.svg\n :alt: PyPi version\n :target: https://badge.fury.io/py/FlowCyPy\n\n.. |PyPi_download| image:: https://img.shields.io/pypi/dm/FlowCyPy?style=plastic&label=PyPi%20downloads&labelColor=hex&color=hex\n :alt: PyPI - Downloads\n :target: https://pypistats.org/packages/flowcypy\n\n.. |coverage| image:: https://raw.githubusercontent.com/MartinPdeS/FlowCyPy/python-coverage-comment-action-data/badge.svg\n :alt: Unittest coverage\n :target: https://htmlpreview.github.io/?https://github.com/MartinPdeS/FlowCyPy/blob/python-coverage-comment-action-data/htmlcov/index.html\n\n.. |ci/cd| image:: https://github.com/martinpdes/flowcypy/actions/workflows/deploy_coverage.yml/badge.svg\n :alt: Unittest Status\n\n.. |anaconda| image:: https://anaconda.org/martinpdes/flowcypy/badges/version.svg\n :alt: Anaconda version\n :target: https://anaconda.org/martinpdes/flowcypy\n\n.. |anaconda_download| image:: https://anaconda.org/martinpdes/flowcypy/badges/downloads.svg\n :alt: Anaconda downloads\n :target: https://anaconda.org/martinpdes/flowcypy\n\n.. |anaconda_date| image:: https://anaconda.org/martinpdes/flowcypy/badges/latest_release_relative_date.svg\n :alt: Latest release date\n :target: https://anaconda.org/martinpdes/flowcypy\n",
"bugtrack_url": null,
"license": "MIT License Copyright (c) 2020 Martin de Sivry Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the \"Software\"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. ",
"summary": "A package for flow-cytometry simulations.",
"version": "0.7.0",
"project_urls": {
"Documentation": "https://martinpdes.github.io/FlowCyPy/",
"Homepage": "https://github.com/MartinPdeS/FlowCyPy",
"Repository": "https://github.com/MartinPdeS/FlowCyPy.git"
},
"split_keywords": [
"refracive index",
" optics",
" microbeads",
" mie scattering"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "0cfe14ce66335f43ffece24491442915c2da18f721cdd0c91c1454954f8516a1",
"md5": "14b6d083b83dc74478fa22e3ae94a5aa",
"sha256": "5d4457940cc5995008304e51d2948450e530bf220364ec8848442486b805d334"
},
"downloads": -1,
"filename": "FlowCyPy-0.7.0-py3-none-any.whl",
"has_sig": false,
"md5_digest": "14b6d083b83dc74478fa22e3ae94a5aa",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.10",
"size": 72015,
"upload_time": "2025-01-15T14:25:56",
"upload_time_iso_8601": "2025-01-15T14:25:56.880886Z",
"url": "https://files.pythonhosted.org/packages/0c/fe/14ce66335f43ffece24491442915c2da18f721cdd0c91c1454954f8516a1/FlowCyPy-0.7.0-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "f2ac13763f6ca3a97c415c4fd5783145922fc018483dadce6622b7e7d071df7f",
"md5": "091934c07805be51600da34acbbc1bd8",
"sha256": "b561640eb6b2f0c993e7b038a8f4e5373d0844d6ba9c6cd4ed13696c804f7be7"
},
"downloads": -1,
"filename": "flowcypy-0.7.0.tar.gz",
"has_sig": false,
"md5_digest": "091934c07805be51600da34acbbc1bd8",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.10",
"size": 2540968,
"upload_time": "2025-01-15T14:25:59",
"upload_time_iso_8601": "2025-01-15T14:25:59.633725Z",
"url": "https://files.pythonhosted.org/packages/f2/ac/13763f6ca3a97c415c4fd5783145922fc018483dadce6622b7e7d071df7f/flowcypy-0.7.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-01-15 14:25:59",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "MartinPdeS",
"github_project": "FlowCyPy",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "flowcypy"
}