piscat


Namepiscat JSON
Version 1.1.3 PyPI version JSON
download
home_page
SummaryA high-performance library for interferometric scattering microscopy.
upload_time2023-08-12 14:17:28
maintainer
docs_urlNone
authorHouman Mirzaalian Dastjerdi, Marco Heisig, Matthias Baer, Reza Gholami, Mohammad Hossein Sheikhsaraf
requires_python>=3.8
license
keywords microscopy iscat
VCS
bugtrack_url
requirements GitPython PyQt6 PyQtWebEngine Pyside6 astropy flifile h5py imageio-ffmpeg ipywidgets joblib matplotlib networkx notebook numba numpy opencv-python pandas psutil pyqtgraph requests scikit-image scikit_learn scipy subprocess.run tensorflow tifffile tqdm trackpy wget
Travis-CI No Travis.
coveralls test coverage
            <a href="https://zenodo.org/badge/latestdoi/360498327"><img src="https://zenodo.org/badge/360498327.svg" alt="DOI"></a>

<a style="border-width:0" href="https://doi.org/10.21105/joss.04024"><img src="https://joss.theoj.org/papers/10.21105/joss.04024/status.svg" alt="DOI badge" ></a>

![](https://github.com/SandoghdarLab/PiSCAT/blob/28eafb06ea4f6b468dde70e33fa970d1699974cf/docs/Fig/PiSCAT_logo_bg.png)

# PiSCAT: An open source package in Python for interferometric Scattering Microscopy ([Homepage](https://piscat.readthedocs.io))

iSCAT microscopy was introduced about two decades ago ([1](https://link.aps.org/doi/10.1103/PhysRevLett.93.037401)) and demonstrated to be the method of choice for label-free imaging and tracking of matter at nanometric scale ([2](https://doi.org/10.1021/acs.nanolett.9b01822)), with a wide range of applications such as detection of gold nanoparticles, single dye molecules, viruses, and small proteins ([3](https://en.wikipedia.org/wiki/Interferometric_scattering_microscopy)).
The image of a nanoparticle in iSCAT microscopy is formed via the interference between the light scattered from the particle and a reference field which is a part of the incident laser light. The photostable scattering signal from nanoparticles allows for very long measurements at high speeds, all the way up to megahertz, limited only by the available technology, e.g. of cameras or scanners. Recording fast and long videos however, produces a large volume of data which needs to undergo several stages of computationally demanding analysis. We introduce **PiSCAT** as a python-based package for the analysis of variuos iSCAT measurements and related experiments. PiSCAT aims to facilitate high-performance quantitative analysis of big data and provide a generally open-access platform to enable and speed up the research in iSCAT and related communities. To facilitate the use of PiSCAT, we offer tutorials with live-code features in which we present state-of-the-art algorithms for iSCAT microscopy. These cover important educative materials in [jupyter notebooks](https://jupyter.org/), supported with a web-based [documentation page](https://piscat.readthedocs.io).

In this first release, we provide analysis tools for the sensitive detection of single unlabelled proteins via wide-field iSCAT microscopy. Proteins are only a few nanometers in size with a molecular weight of a few to several hundred kDa. They were detected via iSCAT already in 2014 for small proteins down to the Bovines Serumalbumin (BSA) protein with a mass of 65 kDa ([4](https://doi.org/10.1038/ncomms5495)). iSCAT microscopy is since employed in several more advanced applications such as real-time investigation of cellular secretion ([5](https://doi.org/10.3791/58486),[6](https://doi.org/10.1021/acs.nanolett.7b04494)) and quantitative mass spectrometry of single proteins ([7](https://doi.org/10.1126/science.aar5839)).

## Documentation

The documentation webpage of PiSCAT modules can be found
[here](https://piscat.readthedocs.io).

The outputs from most of the PiSCAT localization and tracking methods are of [Panda data frame type](https://pandas.pydata.org/pandas-docs/stable/reference/frame.html). This data structure has the ability to be easily appended/extended with more information based on different levels of analysis. The data structures containing the results of localization and tracking routines can be saved as csv, mat and HDF5 files. This helps users to work with the analyzed information using different softwares namely, MATLAB and Microsoft Excel. HDF5 is a well-known format that is readable in different programming languages and supports large, complex, heterogeneous data. HDF5 uses a "file directory" like structure that allows users to organize data within the file in structured ways and to embed metadata as well, making it self-describing.


## Installation

### From PyPi

To install PiSCAT using PyPi, enter the following command in the console:

```
pip install piscat
```

### Local installation of PiSCAT

Clone/download this repository and unzip it. In the project directory enter the following command

```
pip install -e .
```

## Running PiSCAT GUI

Once the installation is done and the python environment is activated, enter the following command in the console:

```
python -m piscat
```

## Running PiSCAT Tutorials

Once the installation is done and the python environment is activated, enter the following command in the console:

```
python -m piscat.Tutorials
```

## Citing PiSCAT
<a style="border-width:0" href="https://doi.org/10.21105/joss.04024"><img src="https://joss.theoj.org/papers/10.21105/joss.04024/status.svg" alt="DOI badge" ></a>

If you use PiSCAT in a scientific publication or for its API or design, we would appreciate citations to the
following paper:

[1] Mirzaalian Dastjerdi, Houman, et al. "PiSCAT: A Python Package for Interferometric Scattering Microscopy." The Journal of Open Source Software 7.71 (2022). ([Journal](https://doi.org/10.21105/joss.04024))

Bibtex entry:

    @article{Dastjerdi2022,
      doi = {10.21105/joss.04024},
      url = {https://doi.org/10.21105/joss.04024},
      year = {2022},
      publisher = {The Open Journal},
      volume = {7},
      number = {71},
      pages = {4024},
      author = {Houman Mirzaalian Dastjerdi and Reza Gholami Mahmoodabadi and Matthias Bär and Vahid Sandoghdar and Harald Köstler},
      title = {PiSCAT: A Python Package for Interferometric Scattering Microscopy},
      journal = {Journal of Open Source Software}
    }

## Testing

To run the tests, please activate the PiSCAT virtual environment. In the project directory, in the console, enter the following command:

```
python setup.py test
```

## Installation of PiSCAT virtual environment in the PyCharm IDE:

1.	Follow the hyper links and the install [ Python 3.9](https://www.python.org/downloads/) and [PyCharm](https://www.jetbrains.com/pycharm/download/#section=windows).
2.	Create a virtual environment based on the instructions provided [here](https://www.jetbrains.com/help/pycharm/creating-virtual-environment.html).
3.  Follow [this link](https://www.jetbrains.com/help/pycharm/creating-and-running-setup-py.html) to select PiSCAT venv as the interpreter, to install the setup.py file and then to run a setup.py task.

# Contributing

Contributions to PiSCAT are always welcome, and they are greatly appreciated! Our contribution policy can be found [here](https://github.com/SandoghdarLab/PiSCAT/blob/main/CONTRIBUTING.md).

            

Raw data

            {
    "_id": null,
    "home_page": "",
    "name": "piscat",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">=3.8",
    "maintainer_email": "",
    "keywords": "Microscopy,iSCAT",
    "author": "Houman Mirzaalian Dastjerdi, Marco Heisig, Matthias Baer, Reza Gholami, Mohammad Hossein Sheikhsaraf",
    "author_email": "The PiSCAT Developers <piscat@mpl.mpg.de>",
    "download_url": "https://files.pythonhosted.org/packages/41/1f/7006244d2ec3df41b53d6645e1beca69de6d77019d5a74c8a95e0adb1d58/piscat-1.1.3.tar.gz",
    "platform": null,
    "description": "<a href=\"https://zenodo.org/badge/latestdoi/360498327\"><img src=\"https://zenodo.org/badge/360498327.svg\" alt=\"DOI\"></a>\n\n<a style=\"border-width:0\" href=\"https://doi.org/10.21105/joss.04024\"><img src=\"https://joss.theoj.org/papers/10.21105/joss.04024/status.svg\" alt=\"DOI badge\" ></a>\n\n![](https://github.com/SandoghdarLab/PiSCAT/blob/28eafb06ea4f6b468dde70e33fa970d1699974cf/docs/Fig/PiSCAT_logo_bg.png)\n\n# PiSCAT: An open source package in Python for interferometric Scattering Microscopy ([Homepage](https://piscat.readthedocs.io))\n\niSCAT microscopy was introduced about two decades ago ([1](https://link.aps.org/doi/10.1103/PhysRevLett.93.037401)) and demonstrated to be the method of choice for label-free imaging and tracking of matter at nanometric scale ([2](https://doi.org/10.1021/acs.nanolett.9b01822)), with a wide range of applications such as detection of gold nanoparticles, single dye molecules, viruses, and small proteins ([3](https://en.wikipedia.org/wiki/Interferometric_scattering_microscopy)).\nThe image of a nanoparticle in iSCAT microscopy is formed via the interference between the light scattered from the particle and a reference field which is a part of the incident laser light. The photostable scattering signal from nanoparticles allows for very long measurements at high speeds, all the way up to megahertz, limited only by the available technology, e.g. of cameras or scanners. Recording fast and long videos however, produces a large volume of data which needs to undergo several stages of computationally demanding analysis. We introduce **PiSCAT** as a python-based package for the analysis of variuos iSCAT measurements and related experiments. PiSCAT aims to facilitate high-performance quantitative analysis of big data and provide a generally open-access platform to enable and speed up the research in iSCAT and related communities. To facilitate the use of PiSCAT, we offer tutorials with live-code features in which we present state-of-the-art algorithms for iSCAT microscopy. These cover important educative materials in [jupyter notebooks](https://jupyter.org/), supported with a web-based [documentation page](https://piscat.readthedocs.io).\n\nIn this first release, we provide analysis tools for the sensitive detection of single unlabelled proteins via wide-field iSCAT microscopy. Proteins are only a few nanometers in size with a molecular weight of a few to several hundred kDa. They were detected via iSCAT already in 2014 for small proteins down to the Bovines Serumalbumin (BSA) protein with a mass of 65 kDa ([4](https://doi.org/10.1038/ncomms5495)). iSCAT microscopy is since employed in several more advanced applications such as real-time investigation of cellular secretion ([5](https://doi.org/10.3791/58486),[6](https://doi.org/10.1021/acs.nanolett.7b04494)) and quantitative mass spectrometry of single proteins ([7](https://doi.org/10.1126/science.aar5839)).\n\n## Documentation\n\nThe documentation webpage of PiSCAT modules can be found\n[here](https://piscat.readthedocs.io).\n\nThe outputs from most of the PiSCAT localization and tracking methods are of [Panda data frame type](https://pandas.pydata.org/pandas-docs/stable/reference/frame.html). This data structure has the ability to be easily appended/extended with more information based on different levels of analysis. The data structures containing the results of localization and tracking routines can be saved as csv, mat and HDF5 files. This helps users to work with the analyzed information using different softwares namely, MATLAB and Microsoft Excel. HDF5 is a well-known format that is readable in different programming languages and supports large, complex, heterogeneous data. HDF5 uses a \"file directory\" like structure that allows users to organize data within the file in structured ways and to embed metadata as well, making it self-describing.\n\n\n## Installation\n\n### From PyPi\n\nTo install PiSCAT using PyPi, enter the following command in the console:\n\n```\npip install piscat\n```\n\n### Local installation of PiSCAT\n\nClone/download this repository and unzip it. In the project directory enter the following command\n\n```\npip install -e .\n```\n\n## Running PiSCAT GUI\n\nOnce the installation is done and the python environment is activated, enter the following command in the console:\n\n```\npython -m piscat\n```\n\n## Running PiSCAT Tutorials\n\nOnce the installation is done and the python environment is activated, enter the following command in the console:\n\n```\npython -m piscat.Tutorials\n```\n\n## Citing PiSCAT\n<a style=\"border-width:0\" href=\"https://doi.org/10.21105/joss.04024\"><img src=\"https://joss.theoj.org/papers/10.21105/joss.04024/status.svg\" alt=\"DOI badge\" ></a>\n\nIf you use PiSCAT in a scientific publication or for its API or design, we would appreciate citations to the\nfollowing paper:\n\n[1] Mirzaalian Dastjerdi, Houman, et al. \"PiSCAT: A Python Package for Interferometric Scattering Microscopy.\" The Journal of Open Source Software 7.71 (2022). ([Journal](https://doi.org/10.21105/joss.04024))\n\nBibtex entry:\n\n    @article{Dastjerdi2022,\n      doi = {10.21105/joss.04024},\n      url = {https://doi.org/10.21105/joss.04024},\n      year = {2022},\n      publisher = {The Open Journal},\n      volume = {7},\n      number = {71},\n      pages = {4024},\n      author = {Houman Mirzaalian Dastjerdi and Reza Gholami Mahmoodabadi and Matthias B\u00e4r and Vahid Sandoghdar and Harald K\u00f6stler},\n      title = {PiSCAT: A Python Package for Interferometric Scattering Microscopy},\n      journal = {Journal of Open Source Software}\n    }\n\n## Testing\n\nTo run the tests, please activate the PiSCAT virtual environment. In the project directory, in the console, enter the following command:\n\n```\npython setup.py test\n```\n\n## Installation of PiSCAT virtual environment in the PyCharm IDE:\n\n1.\tFollow the hyper links and the install [ Python 3.9](https://www.python.org/downloads/) and [PyCharm](https://www.jetbrains.com/pycharm/download/#section=windows).\n2.\tCreate a virtual environment based on the instructions provided [here](https://www.jetbrains.com/help/pycharm/creating-virtual-environment.html).\n3.  Follow [this link](https://www.jetbrains.com/help/pycharm/creating-and-running-setup-py.html) to select PiSCAT venv as the interpreter, to install the setup.py file and then to run a setup.py task.\n\n# Contributing\n\nContributions to PiSCAT are always welcome, and they are greatly appreciated! Our contribution policy can be found [here](https://github.com/SandoghdarLab/PiSCAT/blob/main/CONTRIBUTING.md).\n",
    "bugtrack_url": null,
    "license": "",
    "summary": "A high-performance library for interferometric scattering microscopy.",
    "version": "1.1.3",
    "project_urls": {
        "documentation": "https://piscat.readthedocs.io/",
        "source": "https://github.com/SandoghdarLab/PiSCAT/",
        "tracker": "https://github.com/SandoghdarLab/PiSCAT/issues"
    },
    "split_keywords": [
        "microscopy",
        "iscat"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "da0bc9664486e0f4050652e35fb3f71194cb14648734438c45c7684b0044a1eb",
                "md5": "eed389134cfad4338d290e0754ec9567",
                "sha256": "b2ab2f4e4d4a7b7f8f785a87a85252f9e0b4db7487afe6917d1a616d353a001e"
            },
            "downloads": -1,
            "filename": "piscat-1.1.3-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "eed389134cfad4338d290e0754ec9567",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.8",
            "size": 4553336,
            "upload_time": "2023-08-12T14:17:23",
            "upload_time_iso_8601": "2023-08-12T14:17:23.404978Z",
            "url": "https://files.pythonhosted.org/packages/da/0b/c9664486e0f4050652e35fb3f71194cb14648734438c45c7684b0044a1eb/piscat-1.1.3-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "411f7006244d2ec3df41b53d6645e1beca69de6d77019d5a74c8a95e0adb1d58",
                "md5": "0b3ee103e4795473163f1493121ad80f",
                "sha256": "a1d5cfbe23c3275c7e745bdc71b597d730388fea96153b9a05df6d22246cbdf6"
            },
            "downloads": -1,
            "filename": "piscat-1.1.3.tar.gz",
            "has_sig": false,
            "md5_digest": "0b3ee103e4795473163f1493121ad80f",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.8",
            "size": 4498392,
            "upload_time": "2023-08-12T14:17:28",
            "upload_time_iso_8601": "2023-08-12T14:17:28.825269Z",
            "url": "https://files.pythonhosted.org/packages/41/1f/7006244d2ec3df41b53d6645e1beca69de6d77019d5a74c8a95e0adb1d58/piscat-1.1.3.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-08-12 14:17:28",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "SandoghdarLab",
    "github_project": "PiSCAT",
    "travis_ci": false,
    "coveralls": true,
    "github_actions": true,
    "requirements": [
        {
            "name": "GitPython",
            "specs": []
        },
        {
            "name": "PyQt6",
            "specs": [
                [
                    "==",
                    "6.2.3"
                ]
            ]
        },
        {
            "name": "PyQtWebEngine",
            "specs": []
        },
        {
            "name": "Pyside6",
            "specs": [
                [
                    "==",
                    "6.2.3"
                ]
            ]
        },
        {
            "name": "astropy",
            "specs": []
        },
        {
            "name": "flifile",
            "specs": []
        },
        {
            "name": "h5py",
            "specs": []
        },
        {
            "name": "imageio-ffmpeg",
            "specs": [
                [
                    "==",
                    "0.4.5"
                ]
            ]
        },
        {
            "name": "ipywidgets",
            "specs": []
        },
        {
            "name": "joblib",
            "specs": []
        },
        {
            "name": "matplotlib",
            "specs": []
        },
        {
            "name": "networkx",
            "specs": []
        },
        {
            "name": "notebook",
            "specs": []
        },
        {
            "name": "numba",
            "specs": []
        },
        {
            "name": "numpy",
            "specs": []
        },
        {
            "name": "opencv-python",
            "specs": []
        },
        {
            "name": "pandas",
            "specs": [
                [
                    "<",
                    "2.0"
                ]
            ]
        },
        {
            "name": "psutil",
            "specs": []
        },
        {
            "name": "pyqtgraph",
            "specs": [
                [
                    "==",
                    "0.12"
                ]
            ]
        },
        {
            "name": "requests",
            "specs": []
        },
        {
            "name": "scikit-image",
            "specs": []
        },
        {
            "name": "scikit_learn",
            "specs": []
        },
        {
            "name": "scipy",
            "specs": [
                [
                    ">=",
                    "0.14.0"
                ]
            ]
        },
        {
            "name": "subprocess.run",
            "specs": []
        },
        {
            "name": "tensorflow",
            "specs": []
        },
        {
            "name": "tifffile",
            "specs": []
        },
        {
            "name": "tqdm",
            "specs": []
        },
        {
            "name": "trackpy",
            "specs": []
        },
        {
            "name": "wget",
            "specs": []
        }
    ],
    "lcname": "piscat"
}
        
Elapsed time: 0.11245s