Skip to main content

A plugin for interactive 3D (volumetric or time-lapse) segmentation using Meta's Segment Anything Model 2 (SAM2).

Project description

napari-sam2long

License: CC BY-NC 4.0 PyPI Python Version tests codecov napari hub npe2 Copier

A plugin for interactive 3D (volumetric or time-lapse) segmentation using Meta's Segment Anything Model 2 (SAM2).


Designed for bioimaging researchers working with 3D volumetric or time-lapse images, this plugin supports TIFF files in ZYX or TYX format. Users can provide input and make corrections through point clicks or manually drawn masks.

The tool leverages the SAM2Long model, an optimized version of Meta's SAM 2 with enhancements to the memory module for improved performance on long videos. It was built to support long videos, but it remains effective for shorter videos as well.

This napari plugin was generated with copier using the napari-plugin-template.

Installation

Please see the official SAM 2 repo and the INSTALL.md for notes and FAQs on potential installation issues.

  1. Create a new conda environment with python>=3.10 and install napari:

    conda create -n napari-sam2long python==3.10
    conda activate napari-sam2long
    python -m pip install "napari[all]"
    
  2. Install PyTorch and TorchVision. Select preferences here to find correct installation command.

    Example command can look like this:

    pip3 install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/cu126
    
  3. Install SAM2Long:

    git clone git@github.com:maihanhoang/napari-sam2long.git
    
    cd napari-sam2long/SAM2Long && pip install -e .
    
  4. Install napari-SAM2Long plugin:

    cd .. && pip install e .
    

Usage

Segmenting & tracking first object

  1. Open a 3D tiff in napari, make sure it is in TYX or ZYX format

  2. Select the image in the drop-down menu of Input

  3. Add a new labels layer to the viewer and select it in the drop-down menu of Labels Note: The labels layer should always be added to the viewer after the input image to match the dimensions.

  4. Select the Model

  5. Click Initialize to load the image and initialize the inference state

  6. Select an object on any frame and get an initial mask with

    • the mouse middle click to get the model's mask prediction (mouse middle click to add and Ctrl+mouse middle click to remove areas) and/or
    • napari's labels layers tools (e.g. paintbrush, eraser etc.) to manually draw a mask

    Note: When the model fails to segment the desired object with the point prompts using (Ctrl+) mouse middle click, manually drawing/correcting the mask with napari's labels layer tools can be very useful

  7. Once satisfied with the initial mask, click Propagate from current frame to obtain segmentations for all subsequent frames. The result will be added to the labels layer.

    Note: Propagate from current frame computes the masklets only for the subsequent frames to reduce computation time and does not affect any masklets of the previous frames. Only the mask of the current frame propagation is started from is considered in the prediction, any prompts made in previous and subsequent frames are not regarded.

Making corrections

  1. Re-draw a new mask on any frame by using the (Ctrl+) mouse middle click to (remove) add regions and/or napari's labels layers tools.
  2. Propagate from current frame to re-run the model's predictions with the new mask

Note: When making corrections and "re-defining" the masks, this plugin treats the corrected mask as a new initial mask and disregards any previous prompts on this frame.

Segmenting another object in the same image/video

  1. Save labels layer with the segmentation result of previous object
  2. Click Reset or add another labels layer to the viewer and select the new layer in the Labels-dropdown. Select new object as described in step 6.

Segment new image/video

  1. Reset inference state
  2. Load new image/video and follow instructions from step 1. Initialize is necessary to load the new image/video.

Contributing

Contributions are very welcome. Tests can be run with tox, please ensure the coverage at least stays the same before you submit a pull request.

Bibliography

[1]: Nikhila Ravi, Valentin Gabeur, Yuan-Ting Hu, Ronghang Hu, Chaitanya Ryali, Tengyu Ma, Haitham Khedr, Roman Rädle, Chloe Rolland, Laura Gustafson, Eric Mintun, Junting Pan, Kalyan Vasudev Alwala, Nicolas Carion, Chao-Yuan Wu, Ross Girshick, Piotr Dollár, & Christoph Feichtenhofer. (2024). SAM 2: Segment Anything in Images and Videos.

[2]: Ding, S., Qian, R., Dong, X., Zhang, P., Zang, Y., Cao, Y., Guo, Y., Lin, D., & Wang, J. (2024). SAM2Long: Enhancing SAM 2 for Long Video Segmentation with a Training-Free Memory Tree. arXiv preprint arXiv:2410.16268.

Issues

If you encounter any problems, please file an issue along with a detailed description.

License & Attribution

This project integrates code from:

The following changes were made to SAM2Long:

  • integrated SAM2Long into a napari plugin
  • modified the video predictor to support the progress bar in the plugin

Since this project includes SAM2Long, it inherits the CC-BY-NC 4.0 license, meaning commercial use is not allowed.

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

napari_sam2long-0.1.2.tar.gz (1.6 MB view details)

Uploaded Source

Built Distribution

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

napari_sam2long-0.1.2-py3-none-any.whl (35.6 kB view details)

Uploaded Python 3

File details

Details for the file napari_sam2long-0.1.2.tar.gz.

File metadata

  • Download URL: napari_sam2long-0.1.2.tar.gz
  • Upload date:
  • Size: 1.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.2

File hashes

Hashes for napari_sam2long-0.1.2.tar.gz
Algorithm Hash digest
SHA256 080589d3b042b4023aa7cf950d444ee15f7dc3614ec3ca8a1afb6a9a1ed5ab61
MD5 427ad0c0722ee6e487c57181ad0a847c
BLAKE2b-256 7160b2e865c57be15235d701ccf7ce8ca38dc5ebc8e2c8cdefdd81a763a52e53

See more details on using hashes here.

File details

Details for the file napari_sam2long-0.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for napari_sam2long-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 0d068170fec906f9cb76392fc5c0f686064a3ba6f243ecde53adad424ebf0683
MD5 ea0ae13065fd1ff7215bd11bd9bdbb83
BLAKE2b-256 aa5f8f80946db04238430537d4c4cdf061eb532b4fd7c3ccf94115293bdca28c

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