FlowCytometryTools


NameFlowCytometryTools JSON
Version 0.5.1 PyPI version JSON
download
home_pagehttp://eyurtsev.github.io/FlowCytometryTools/
SummaryA python package for performing flow cytometry analysis
upload_time2021-01-24 23:59:38
maintainer
docs_urlNone
authorJonathan Friedman, Eugene Yurtsev
requires_python
licenseMIT
keywords flow cytometry data analysis cytometry single cell
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            FlowCytometryTools
-------------------

**Authors**: Jonathan Friedman and `Eugene Yurtsev <https://eyurtsev.github.io>`_

.. image:: https://travis-ci.org/eyurtsev/FlowCytometryTools.svg?branch=master
    :target: https://travis-ci.org/eyurtsev/FlowCytometryTools
.. image:: https://zenodo.org/badge/doi/10.5281/zenodo.32991.svg
    :target: https://zenodo.org/record/32991   


FlowCytometryTools is a python package for visualization and analysis of high-throughput flow cytometry data.

* **Intuitive**: provides a simple programmatic interface to work with flow cytometry data
* **Flexible**: can analyze either individual samples or collections of many plates
* **Scalable**: simplifies analysis of high-throughput data using the power of `pandas <https://pandas.pydata.org/>`_ 

Who is this for?
=====================

FlowCytometryTools is for researchers who want to use the python programming language to analyze flow cytometry data.

The package is specifically tailored for high-throughput analysis. It provides an interface that can directly work with collections of flow cytometry measurements (e.g., 96-well plates).

Basic familiarity with the python programming languages is recommended.

You can find a few example scripts that load and plot flow cytometry data in the `gallery <https://eyurtsev.github.io/FlowCytometryTools/gallery.html>`_ page.

If you like what you see, then proceed to the `installation <https://eyurtsev.github.io/FlowCytometryTools/install.html>`_ page and then
to the `tutorial <https://eyurtsev.github.io/FlowCytometryTools/tutorial.html>`_.


And yes, there's a UI to draw basic gates. It's super basic, but it gets the job done.

.. image:: https://github.com/eyurtsev/FlowCytometryTools/blob/master/doc/source/_static/webagg_demo.gif 
  :target: https://github.com/eyurtsev/FlowCytometryTools/blob/master/doc/source/_static/webagg_demo.gif 

.. image:: _static/webagg_demo.gif
  :target: _static/webagg_demo.gif


Features
===================

- **Transformations**: hyperlog (hlog), truncated log (tlog), or anything you can dream of ;)
- **Plotting**: 1D, 2D histograms for both single samples and collections (e.g., 96-well plates).
- **Gating**: threshold, interval, quad, polygon gates
- **Subsampling**: easy to subsample to examine only part of a measurement and randomize event order
- **GUI**: simple graphical user interface to draw gates (`wx` or `webagg`)
- **FCS Formats**: Supports FCS 2.0, 3.0, and 3.1

Resources
===================

- **Documentation:** https://eyurtsev.github.io/FlowCytometryTools/
- **Source Repository:** https://github.com/eyurtsev/FlowCytometryTools
- **Comments or questions:** https://github.com/eyurtsev/FlowCytometryTools/issues

Dependencies
===================

For more information about how to obtain these, please see the `installation
<https://eyurtsev.github.io/FlowCytometryTools/install.html>`_ page.

FlowCytometryTools may work with older versions of some of these dependencies, but if
you run into issues, please update the dependencies.

**Required Dependencies**

#. `python <https://www.python.org/getit/>`_ python 2.7 or python 3
#. `pandas <https://pandas.pydata.org/>`__ (Recommended version: 0.19.0 or higher).
#. `matplotlib <https://matplotlib.org/>`__ (Recommended version: 1.5.3 or higher).
#. `scipy <https://www.scipy.org/>`__ 

**Optional Dependencies**

#. `wx-python <https://wiki.wxpython.org/How%20to%20install%20wxPython>`__ : Used for the FlowCytometryTools GUI.

Alternatives
===================

FlowCytometryTools is not the only open source software for performing data analysis on flow cytometry data.

So if you find that FlowCytometryTools does not suit your needs, take a look at the following software: 

* `cytoflow <https://github.com/bpteague/cytoflow>`_: API for python with a GUI
* `fcm <https://pythonhosted.org/fcm/basic.html>`_ : API for python
* `Bioconductor <http://master.bioconductor.org/>`_ : API for the R programming language
* `FlowPy <http://flowpy.wikidot.com/>`_ : GUI
* `cyflogic <http://www.cyflogic.com/>`_ : GUI
* `Flowing Software <http://www.flowingsoftware.com/>`_ : GUI

Changes
=====================

v0.4.6, 2017-03-26

+ FIX: edge case for inferring x-range for spline interpolation when doing log transforms and with data the contains values in the interval. 
+ FIX: fix linear transform (kwargs weren't being passed correctly).
+ FIX: interval gate was raising exceptions for certain numpy versions (fix by alonyan)

v0.4.5, 2015-10-31

+ Sample fcs files now included with installation
+ Mostly maintenance (tests, configuration files, etc.)

v0.4.4, 2015-09-06

** Repository moved to github **

Enhancements:

+ added an experimental web-based backend for drawing gates. Use FCMeasurement.view_inteactively(backend='webagg').
+ col first enumerator for forming an ordered fcs file collection (Yoav Ram)

Bug fixes:

+ FCPlate.from_dir ID_kwargs match against full path, not just filename (Nick Bolten)
+ fcs parser can read larger fcs files and handles blank headers (Ben Roth)

v0.4.3, 2014-12-05

+ ENHC: Automatically determine bin location when plotting plates. 
+ Fix for Accuri V6 FCS (Ben Roth)
+ Fix for xlim/ylim when plotting 2d histograms

v0.4.2, 2014-10-08

+ FCS parser can handle more formats
+ Updated documentation

v0.4.1, 2014-09-13

+ Bug fixes for GUI
+ Now works with matplotlib 1.4.0
+ Added documentation and examples to gallery

v0.4.0, 2014-06-05

+ Updates in documentation
+ Added experimental view() function
+ Renamed old view() function into -> view_interactively()
+ Added queueing to help when dealing with large quantities of data.
+ Histogram plots should work with pandas (0.14.0) & matplotlib (1.3.1).

v0.3.6, 2014-02-11

+ Mostly updates in documentation

v0.3.5, 2014-01-19

+ Boost in speed for transformations on collections of measurements (like 96-well plates).
+ Much of the documentation has been updated and improved.
+ Improved GUI.

v0.3.0, 2013-10-27 Initial Release

LICENSE
===================

The MIT License (MIT)

Copyright (c) 2013-2015 Eugene Yurtsev and Jonathan Friedman

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.



            

Raw data

            {
    "_id": null,
    "home_page": "http://eyurtsev.github.io/FlowCytometryTools/",
    "name": "FlowCytometryTools",
    "maintainer": "",
    "docs_url": null,
    "requires_python": "",
    "maintainer_email": "",
    "keywords": "flow cytometry,data analysis,cytometry,single cell",
    "author": "Jonathan Friedman, Eugene Yurtsev",
    "author_email": "eyurtsev@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/e4/51/aaeef2bf0f333e278442096afeb608642d4f6ff16a1595d846777ad8bc5f/FlowCytometryTools-0.5.1.tar.gz",
    "platform": "",
    "description": "FlowCytometryTools\n-------------------\n\n**Authors**: Jonathan Friedman and `Eugene Yurtsev <https://eyurtsev.github.io>`_\n\n.. image:: https://travis-ci.org/eyurtsev/FlowCytometryTools.svg?branch=master\n    :target: https://travis-ci.org/eyurtsev/FlowCytometryTools\n.. image:: https://zenodo.org/badge/doi/10.5281/zenodo.32991.svg\n    :target: https://zenodo.org/record/32991   \n\n\nFlowCytometryTools is a python package for visualization and analysis of high-throughput flow cytometry data.\n\n* **Intuitive**: provides a simple programmatic interface to work with flow cytometry data\n* **Flexible**: can analyze either individual samples or collections of many plates\n* **Scalable**: simplifies analysis of high-throughput data using the power of `pandas <https://pandas.pydata.org/>`_ \n\nWho is this for?\n=====================\n\nFlowCytometryTools is for researchers who want to use the python programming language to analyze flow cytometry data.\n\nThe package is specifically tailored for high-throughput analysis. It provides an interface that can directly work with collections of flow cytometry measurements (e.g., 96-well plates).\n\nBasic familiarity with the python programming languages is recommended.\n\nYou can find a few example scripts that load and plot flow cytometry data in the `gallery <https://eyurtsev.github.io/FlowCytometryTools/gallery.html>`_ page.\n\nIf you like what you see, then proceed to the `installation <https://eyurtsev.github.io/FlowCytometryTools/install.html>`_ page and then\nto the `tutorial <https://eyurtsev.github.io/FlowCytometryTools/tutorial.html>`_.\n\n\nAnd yes, there's a UI to draw basic gates. It's super basic, but it gets the job done.\n\n.. image:: https://github.com/eyurtsev/FlowCytometryTools/blob/master/doc/source/_static/webagg_demo.gif \n  :target: https://github.com/eyurtsev/FlowCytometryTools/blob/master/doc/source/_static/webagg_demo.gif \n\n.. image:: _static/webagg_demo.gif\n  :target: _static/webagg_demo.gif\n\n\nFeatures\n===================\n\n- **Transformations**: hyperlog (hlog), truncated log (tlog), or anything you can dream of ;)\n- **Plotting**: 1D, 2D histograms for both single samples and collections (e.g., 96-well plates).\n- **Gating**: threshold, interval, quad, polygon gates\n- **Subsampling**: easy to subsample to examine only part of a measurement and randomize event order\n- **GUI**: simple graphical user interface to draw gates (`wx` or `webagg`)\n- **FCS Formats**: Supports FCS 2.0, 3.0, and 3.1\n\nResources\n===================\n\n- **Documentation:** https://eyurtsev.github.io/FlowCytometryTools/\n- **Source Repository:** https://github.com/eyurtsev/FlowCytometryTools\n- **Comments or questions:** https://github.com/eyurtsev/FlowCytometryTools/issues\n\nDependencies\n===================\n\nFor more information about how to obtain these, please see the `installation\n<https://eyurtsev.github.io/FlowCytometryTools/install.html>`_ page.\n\nFlowCytometryTools may work with older versions of some of these dependencies, but if\nyou run into issues, please update the dependencies.\n\n**Required Dependencies**\n\n#. `python <https://www.python.org/getit/>`_ python 2.7 or python 3\n#. `pandas <https://pandas.pydata.org/>`__ (Recommended version: 0.19.0 or higher).\n#. `matplotlib <https://matplotlib.org/>`__ (Recommended version: 1.5.3 or higher).\n#. `scipy <https://www.scipy.org/>`__ \n\n**Optional Dependencies**\n\n#. `wx-python <https://wiki.wxpython.org/How%20to%20install%20wxPython>`__ : Used for the FlowCytometryTools GUI.\n\nAlternatives\n===================\n\nFlowCytometryTools is not the only open source software for performing data analysis on flow cytometry data.\n\nSo if you find that FlowCytometryTools does not suit your needs, take a look at the following software: \n\n* `cytoflow <https://github.com/bpteague/cytoflow>`_: API for python with a GUI\n* `fcm <https://pythonhosted.org/fcm/basic.html>`_ : API for python\n* `Bioconductor <http://master.bioconductor.org/>`_ : API for the R programming language\n* `FlowPy <http://flowpy.wikidot.com/>`_ : GUI\n* `cyflogic <http://www.cyflogic.com/>`_ : GUI\n* `Flowing Software <http://www.flowingsoftware.com/>`_ : GUI\n\nChanges\n=====================\n\nv0.4.6, 2017-03-26\n\n+ FIX: edge case for inferring x-range for spline interpolation when doing log transforms and with data the contains values in the interval. \n+ FIX: fix linear transform (kwargs weren't being passed correctly).\n+ FIX: interval gate was raising exceptions for certain numpy versions (fix by alonyan)\n\nv0.4.5, 2015-10-31\n\n+ Sample fcs files now included with installation\n+ Mostly maintenance (tests, configuration files, etc.)\n\nv0.4.4, 2015-09-06\n\n** Repository moved to github **\n\nEnhancements:\n\n+ added an experimental web-based backend for drawing gates. Use FCMeasurement.view_inteactively(backend='webagg').\n+ col first enumerator for forming an ordered fcs file collection (Yoav Ram)\n\nBug fixes:\n\n+ FCPlate.from_dir ID_kwargs match against full path, not just filename (Nick Bolten)\n+ fcs parser can read larger fcs files and handles blank headers (Ben Roth)\n\nv0.4.3, 2014-12-05\n\n+ ENHC: Automatically determine bin location when plotting plates. \n+ Fix for Accuri V6 FCS (Ben Roth)\n+ Fix for xlim/ylim when plotting 2d histograms\n\nv0.4.2, 2014-10-08\n\n+ FCS parser can handle more formats\n+ Updated documentation\n\nv0.4.1, 2014-09-13\n\n+ Bug fixes for GUI\n+ Now works with matplotlib 1.4.0\n+ Added documentation and examples to gallery\n\nv0.4.0, 2014-06-05\n\n+ Updates in documentation\n+ Added experimental view() function\n+ Renamed old view() function into -> view_interactively()\n+ Added queueing to help when dealing with large quantities of data.\n+ Histogram plots should work with pandas (0.14.0) & matplotlib (1.3.1).\n\nv0.3.6, 2014-02-11\n\n+ Mostly updates in documentation\n\nv0.3.5, 2014-01-19\n\n+ Boost in speed for transformations on collections of measurements (like 96-well plates).\n+ Much of the documentation has been updated and improved.\n+ Improved GUI.\n\nv0.3.0, 2013-10-27 Initial Release\n\nLICENSE\n===================\n\nThe MIT License (MIT)\n\nCopyright (c) 2013-2015 Eugene Yurtsev and Jonathan Friedman\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE.\n\n\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "A python package for performing flow cytometry analysis",
    "version": "0.5.1",
    "project_urls": {
        "Download": "https://github.com/eyurtsev/FlowCytometryTools/archive/v0.5.1.zip",
        "Homepage": "http://eyurtsev.github.io/FlowCytometryTools/"
    },
    "split_keywords": [
        "flow cytometry",
        "data analysis",
        "cytometry",
        "single cell"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "5433b9db6698488857879c71f741399e6b2ffc93bf388f70b943537e0b995db4",
                "md5": "19b95fcc04028f7cd234e195f12b285a",
                "sha256": "9380ffb968469e3f0a97113add1c10e82cab6131462cf47b6826d36d1679e354"
            },
            "downloads": -1,
            "filename": "FlowCytometryTools-0.5.1-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "19b95fcc04028f7cd234e195f12b285a",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": null,
            "size": 7055122,
            "upload_time": "2021-01-24T23:59:34",
            "upload_time_iso_8601": "2021-01-24T23:59:34.230081Z",
            "url": "https://files.pythonhosted.org/packages/54/33/b9db6698488857879c71f741399e6b2ffc93bf388f70b943537e0b995db4/FlowCytometryTools-0.5.1-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "e451aaeef2bf0f333e278442096afeb608642d4f6ff16a1595d846777ad8bc5f",
                "md5": "d983fd37189df41dd3dec7f0b108783b",
                "sha256": "2a2a151f6d0bc53318848c7bb2d5dfa61412e7c81fc5efcbb4643aee471e5393"
            },
            "downloads": -1,
            "filename": "FlowCytometryTools-0.5.1.tar.gz",
            "has_sig": false,
            "md5_digest": "d983fd37189df41dd3dec7f0b108783b",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 7043942,
            "upload_time": "2021-01-24T23:59:38",
            "upload_time_iso_8601": "2021-01-24T23:59:38.483341Z",
            "url": "https://files.pythonhosted.org/packages/e4/51/aaeef2bf0f333e278442096afeb608642d4f6ff16a1595d846777ad8bc5f/FlowCytometryTools-0.5.1.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2021-01-24 23:59:38",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "eyurtsev",
    "github_project": "FlowCytometryTools",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "requirements": [],
    "lcname": "flowcytometrytools"
}
        
Elapsed time: 0.69599s