Skip to main content

Live-cell microscopy image analysis and single-molecule measurements

Project description

MicroLive Micro Logo

Authors: Luis U. Aguilera, William S. Raymond, Rhiannon M. Sears, Nathan L. Nowling, Brian Munsky, Ning Zhao

PyPI version Documentation Tutorial API Reference License: GPL v3 Python 3.10+ PyQt5

About

MicroLive is a Python-based GUI application for live-cell microscopy image analysis and single-molecule measurements. It provides an end-to-end workflow from image loading through particle tracking, colocalization analysis, and statistical analysis.

MicroLive Demo

Features

  • Image I/O: Load .lif, .tif, .ome.tif with metadata extraction and dimension mapping
  • Registration: Drift correction via phase correlation
  • Segmentation: Cellpose (GPU), watershed, manual ROI, or external mask import
  • Photobleaching correction: Exponential decay modeling
  • Particle tracking: 2D (TrackPy) and 3D (Big-FISH) detection with multi-channel support
  • Automated threshold detection: Hybrid Big-FISH/TrueSpot method
  • Trajectory linking: Nearest-neighbor with memory and cluster analysis
  • Intensity quantification: Background subtraction, PSF fitting, SNR calculation
  • Colocalization: CNN-based, distance-based, and manual verification
  • MSD analysis: Per-cell diffusion coefficient calculation
  • Correlation: Auto- and cross-correlation with exponential/linear fitting
  • Export: PNG, TIFF, CSV, MP4/GIF with full metadata logging

Documentation

  • User Guide — Complete guide to using MicroLive
  • Tutorial — Step-by-step tutorials for all workflows
  • API Reference — Technical documentation for developers

Installation

Quick Install (Recommended)

# Create and activate conda environment
conda create -n microlive python=3.10 -y
conda activate microlive

# Install MicroLive
pip install microlive

# Launch the GUI
microlive

That's it! MicroLive will launch with GPU acceleration automatically enabled:

  • macOS (Apple Silicon): MPS GPU acceleration works automatically
  • Linux/Windows (CPU): Works out of the box

GPU Acceleration for NVIDIA (Windows/Linux)

For NVIDIA GPU acceleration, install PyTorch with CUDA support before installing MicroLive:

# Create environment
conda create -n microlive python=3.10 -y
conda activate microlive

# Install PyTorch with CUDA 12.4 (adjust version as needed)
pip install torch torchvision --index-url https://download.pytorch.org/whl/cu124

# Then install MicroLive
pip install microlive

# Launch
microlive

Using Conda Environment Files

Pre-configured environment files are available:

# macOS / CPU
conda env create -f installation/microlive.yml
conda activate microlive

# Windows/Linux with NVIDIA GPU
conda env create -f installation/microlive_cuda.yml
conda activate microlive

Verify GPU Support

from microlive.utils.device import check_gpu_status
check_gpu_status()

Expected output:

PyTorch version: 2.x.x
✅ CUDA available: NVIDIA GeForce RTX ...
   Memory: 8.0 GB

Or for Apple Silicon:

PyTorch version: 2.x.x
✅ MPS available: Apple Silicon GPU (MPS)

Development Installation

For developers who want to modify the source code:

# Clone the repository
git clone --depth 1 https://github.com/ningzhaoAnschutz/microlive.git
cd microlive

# Create environment
conda create -n microlive python=3.10 -y
conda activate microlive

# Install in editable mode
pip install -e .

# Launch
microlive

Usage

GUI Application

conda activate microlive
microlive

Programmatic API

import microlive.microscopy as mi

# Load images from a Leica .lif file
reader = mi.ReadLif("experiment.lif")
images = reader.get_images()

# Access image data
image = reader.list_images[0]
print(f"Image shape: {image.shape}")  # (T, Z, Y, X, C)

# Run Cellpose segmentation
cellpose = mi.Cellpose(image_for_segmentation=image[0, 0, :, :, 0])
masks = cellpose.calculate_masks()

# Spot detection
spots = mi.SpotDetection(
    image=image,
    spot_size_yx=5,
    threshold=100
)
detected = spots.detect_spots()

Project Structure

microlive/
├── microlive/                    # Core package (pip installable)
│   ├── microscopy.py             # Main analysis classes
│   ├── imports.py                # Central import management
│   ├── ml_spot_detection.py      # ML-based spot detection
│   ├── gui/                      # GUI application
│   │   ├── app.py                # Main GUI window
│   │   └── main.py               # CLI entry point
│   ├── utils/                    # Utility modules
│   │   ├── device.py             # GPU detection
│   │   └── resources.py          # Resource paths
│   └── pipelines/                # Analysis pipeline modules
├── docs/                         # Documentation
│   ├── user_guide.md             # User manual
│   ├── tutorial.md               # Step-by-step tutorials
│   └── api_reference.md          # API documentation
├── modeling/                     # Research/development (not in pip package)
├── notebooks/                    # Example Jupyter notebooks
├── installation/                 # Environment files
│   ├── microlive.yml             # Conda env (macOS / CPU)
│   └── microlive_cuda.yml        # Conda env (NVIDIA GPU)
├── tests/                        # Test suite
├── pyproject.toml                # Package configuration
└── LICENSE                       # GPL v3 License

License

This project is licensed under the GNU General Public License v3 (GPLv3). See LICENSE for details.


Citation

If you use MicroLive in your research, please cite:

Aguilera LU, Raymond WS, Sears RM, Nowling NL, Munsky B, Zhao N. MicroLive: An Image Processing Toolkit for Quantifying Live-cell Single-Molecule Microscopy. bioRxiv, 2025.
DOI: 10.1101/2025.09.25.678587

@article{aguilera2025microlive,
  title={MicroLive: An Image Processing Toolkit for Quantifying Live-cell Single-Molecule Microscopy},
  author={Aguilera, Luis U and Raymond, William S and Sears, Rhiannon M and Nowling, Nathan L and Munsky, Brian and Zhao, Ning},
  journal={bioRxiv},
  pages={2025--09},
  year={2025},
  publisher={Cold Spring Harbor Laboratory},
  doi={10.1101/2025.09.25.678587}
}

Support

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

microlive-1.0.3.tar.gz (661.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

microlive-1.0.3-py2.py3-none-any.whl (673.7 kB view details)

Uploaded Python 2Python 3

File details

Details for the file microlive-1.0.3.tar.gz.

File metadata

  • Download URL: microlive-1.0.3.tar.gz
  • Upload date:
  • Size: 661.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.19

File hashes

Hashes for microlive-1.0.3.tar.gz
Algorithm Hash digest
SHA256 d435fafed26e4a1e4b8c42ea5af2cb992439907f698327d1475dfc6855beaa11
MD5 ed6187e4e25476676afe8744e80633f1
BLAKE2b-256 0a4b91d514afa3ca5e177f50c0909b7b58a9677b0566004a5f7fc3c91b3c4b48

See more details on using hashes here.

File details

Details for the file microlive-1.0.3-py2.py3-none-any.whl.

File metadata

  • Download URL: microlive-1.0.3-py2.py3-none-any.whl
  • Upload date:
  • Size: 673.7 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.19

File hashes

Hashes for microlive-1.0.3-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 78c511677b96ed1e3dccca189294c95eb85d0d107f294e4b3ea104cbe0a07fc0
MD5 5f594ea9f585b951bb67dc4d30624fe0
BLAKE2b-256 b6e639830363c7a3fb5259c4c1a911a8f65c51ab0d36b009888c14e5507df997

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page