Skip to content

Latest commit

 

History

History
181 lines (131 loc) · 13.5 KB

README.md

File metadata and controls

181 lines (131 loc) · 13.5 KB

Caiman

A Python toolbox for large-scale Calcium Imaging Analysis.

Caiman implements a set of essential methods required to analyze calcium and voltage imaging data. It provides fast and scalable algorithms for motion correction, source extraction, spike deconvolution, and registering neurons across multiple sessions. It is suitable for both two-photon and one-photon fluorescence microscopy data, and can be run in both offline and online modes. Documentation is here.

Installation

There are two primary ways to install Caiman.

Route A

The easiest route is to install the miniforge distribution of Anaconda, and use that to install the rest using prebuilt packages. Most users should take this path.

Route B

The alternative route is to make sure you have a working compiler, create a python virtualenv, grab the caiman sources, and use pip to populate the virtualenv and build Caiman. This route is not as tested and is not presently documented; it is a standard pip-based install.

Quick start (Route A)

Follow these three steps to get started quickly, from installation to working through a demo notebook. If you do not already have conda installed, you can find it here. The miniforge distribution of conda is preferred; it will require fewer steps and likely encounter fewer issues. If you are using a different distro of conda, you will likely need to add -c conda-forge to the commands you use to make your environment.

Windows users will temporarily need to use an alternative install path.

Step 1: Install Caiman

The following is all done in your anaconda prompt, starting in your base environment:

mamba create -n caiman caiman # build a caiman environment
conda activate caiman  # activate the environment

Step 1: Install Caiman (alternative for Windows users)

Windows users will need to follow an alternative set of steps because tensorflow does not have good packaging for Windows with conda (packaging changes are underway to solve this but are not available as of this writing).

First, you will need to install Visual Studio 2019 or possibly a later version, with the C++ compiler and commandline utilities. Then you will clone this repo to your windows system, and enter the checkout directory.

Next, you will build and activate a mostly-empty conda environment:

mamba create -n caiman python=3.11 pip vs2019_win-64
conda activate caiman

Finally, you will use pip to install Caiman's prerequisites and Caiman itself: pip install .

This step may fail if the compiler is not correctly installed and is the most fragile part of this install route; reach out if you encounter issues.

After this, assuming you succeed, leave the source directory. Later steps will not function correctly when run in the source/checkout directory.

Step 2: Download code samples and data sets

Create a working directory called caiman_data that includes code samples and related data. Run the following command from the same conda environment that you created in Step 1:

caimanmanager install

Step 3: Try out a demo notebook

Go into the working directory you created in Step 2, and open a Jupyter notebook:

cd <your home>/caiman_data/
jupyter lab

Jupyter will open. Navigate to demos/notebooks/ and click on demo_pipeline.ipynb to get started with a demo.

<your home> in the first line is your home directory, its location depdnding on your OS/computer. On Linux/Mac it is ~ while on Windows it will be something like C:\Users\your_user_name\

For installation help

Caiman should install easily on Linux, Mac, and Windows. If you run into problems, we have a dedicated installation page. If you don't find what you need there, create an issue on GitHub.

Demo notebooks

Caiman provides demo notebooks to showcase each of our main features, from motion correction to online CNMF. We recommend starting with the CNMF notebook (demo_pipeline.ipynb), which contains more explanation and details than the other notebooks: it covers many concepts that will be used without explanation in the other notebooks. The CNMFE notebook (demo_pipeline_cnmfE.ipynb), is also more detailed. Once you've gotten things set up and worked through those "anchor" notebooks, the best way to get started is to work through the demo notebook that most closely matches your use case; you should be able to adapt it for your particular needs.

The main use cases and notebooks are listed in the following table:

Use case Demo notebook Paper
CNMF for 2p or low-noise 1p data demo_pipeline.ipynb Pnevmatikakis et al., 2016
CNMFE for 1p data demo_pipeline_cnmfE.ipynb Zhou et al., 2018
Volpy for voltage data demo_pipeline_voltage_imaging.ipynb Cai et al., 2021
Volumetric (3D) CNMF demo_caiman_cnmf_3D.ipynb Mentioned in Giovannucci et al., 2019
CNMF for dendrites demo_dendritic.ipynb Pnevmatikakis et al., 2016
Online CNMF (OnACID) demo_OnACID_mesoscope.ipynb Giovannucci et al., 2017
Online volumetric CNMF demo_online_3D.ipynb Developed by Johannes Friedrich
Online CNMFE (OnACID-E) demo_realtime_cnmfE.ipynb Friedrich et al. 2020
Motion correction demo_motion_correction.ipynb Pnevmatikakis et al., 2017
Seed CNMF with external masks demo_seeded_CNMF.ipynb Mentioned in Giovannucci et al., 2019
Register cells across sessions demo_multisession_registration.ipynb Pnevmatikakis et al., 2016

A comprehensive list of references, where you can find detailed discussion of the methods and their development, can be found here.

CLI demos

Caiman also provides commandline demos, similar to the notebooks, demonstrating how to work with the codebase outside of Jupyter. They take their configuration primarily from json files (which you will want to modify to work with your data and its specifics) and should be reasonably easy to modify if they don't already do what you want them to do (in particular, saving things; a standard output format for Caiman is something intended for future releases). To run them, activate your environment, and find the demos in demos/general under your caiman data directory; you can run them like you would any other python application, or edit them with your code editor. Each demo comes with a json configuration file that you can customise. There is a README in the demos directory that covers some of this.

How to get help

  • Online documentation contains a lot of general information about Caiman, the parameters, how to interpret its outputs, and more.
  • GitHub Discussions is our preferred venue for users to ask for help.
  • The Gitter forum is our old forum: we sometimes will ask people to join us there when something can best be solved in real time (e.g., installation problems).
  • If you have found a bug, we recommend searching the issues at github and opening a new issue if you can't find the solution there.
  • If there is a feature you would like to see implemented, feel free to come chat at the above forums or open an issue at Github.

How to contribute

Caiman is an open-source project and improves because of contributions from users all over the world. If there is something about Caiman that you would like to work on, then please reach out. We are always looking for more contributors, so please come read the contributors page for more details about how.

Videos

There are multiple online videos by Andrea Giovannucci from past Caiman workshops/events that are an excellent start for newcomers.

The following talk provides a good high-level introduction to Caiman:
https://www.youtube.com/watch?v=5APzPRbzUIA

The following talks are more in depth:

Related repositories

There are many repositories that use Caiman, or help make using Caiman easier.

  • use_cases repo: additional code (unmaintained) demonstrating how to reproduce results in some Caiman-related papers, and how to use/extend Caiman.
  • jnormcorre: JAX implementation of NoRMCorre for motion correction using JAX acceleration
  • funimag: matrix decomposition for denoising and compression
  • mesmerize-core: parameter optimization, data organization and visualizations with Caiman
  • improv: a platform for creating online analysis workflows that lets you use Caiman in real time (e.g., for all-optical experiments)

If you have questions about these related packages please reach out to their maintainers directly. If you would like your software to be in this list, please contact one of the developers or open an issue.

Citing Caiman and related papers

If you publish a paper that relied on Caiman, we kindly ask that you cite Giovannucci et al., 2019:

@article{giovannucci2019caiman,
  title={CaImAn: An open source tool for scalable Calcium Imaging data Analysis},
  author={Giovannucci, Andrea and Friedrich, Johannes and Gunn, Pat and Kalfon, Jeremie and Brown, Brandon L and Koay, Sue Ann and Taxidis, Jiannis and Najafi, Farzaneh and Gauthier, Jeffrey L and Zhou, Pengcheng and Khakh, Baljit S and Tank, David W and Chklovskii, Dmitri B and Pnevmatikakis, Eftychios A},
  journal={eLife},
  volume={8},
  pages={e38173},
  year={2019},
  publisher={eLife Sciences Publications Limited}
}

If possible, we'd also ask that you cite the papers where the original algorithms you use (such as CNMF) were developed. A list of such references can be found here.

Main developers

  • (emeritus) Eftychios A. Pnevmatikakis, Flatiron Institute, Simons Foundation
  • (emeritus) Andrea Giovannucci, University of North Carolina, Chapel Hill
  • (emeritus) Johannes Friedrich, Allen Institute, Seattle Washington
  • (emeritus) Changjia Cai, University of North Carolina, Chapel Hill
  • Kushal Kolar, Flatiron Institute, Simons Foundation
  • Pat Gunn, Flatiron Institute, Simons Foundation

A complete list of contributors can be found here.

Acknowledgements

Special thanks to the following people for letting us use their datasets in demo files:

  • Weijian Yang, Darcy Peterka, Rafael Yuste, Columbia University
  • Bernardo Sabatini, Harvard University
  • Sue Ann Koay, David Tank, Princeton University
  • Manolis Froudarakis, Jake Reimers, Andreas Tolias, Baylor College of Medicine
  • Clay Lacefield, Randy Bruno, Columbia University
  • Daniel Aharoni, Peyman Golshani, UCLA
  • Darcy Peterka, Columbia

Also a special thanks to:

  • Eric Thompson, for various strong contributions to code and demos, both before and during his employment at the Flatiron Institute.
  • Cai Changjia, for Volpy
  • Ethan Blackwood, for several contributions in various areas

License

This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program. If not, see http://www.gnu.org/licenses/.