A plugin for interactive 3D (volumetric or time-lapse) segmentation using Meta's Segment Anything Model 2 (SAM2).
Project description
napari-sam2long
A plugin for interactive 3D (volumetric or time-lapse) segmentation using Meta's Segment Anything Model 2 (SAM2).
https://github.com/user-attachments/assets/6c753c65-ff8c-4dff-a9c9-5b445f5cad13
https://github.com/user-attachments/assets/04396517-cc20-42f4-93f3-81cc2a0f4560
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.
-
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]"
-
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
-
Install SAM2Long:
git clone git@github.com:maihanhoang/napari-sam2long.git cd napari-sam2long/SAM2Long && pip install -e .
-
Install napari-SAM2Long plugin:
cd .. && pip install e .
Usage
Segmenting & tracking first object
-
Open a 3D tiff in napari, make sure it is in TYX or ZYX format
-
Select the image in the drop-down menu of Input
-
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.
-
Select the Model
-
Click Initialize to load the image and initialize the inference state
-
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
-
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
- 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.
- 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
- Save labels layer with the segmentation result of previous object
- 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
- Reset inference state
- 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.
Issues
If you encounter any problems, please file an issue along with a detailed description.
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.
License & Attribution
This project integrates code from:
- SAM2Long by Shuangrui Ding et al. (
CC-BY-NC 4.0 License) - napari-samv2 by Krishnan Venkataraman (
BSD-3 License)
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file napari_sam2long-0.1.3.tar.gz.
File metadata
- Download URL: napari_sam2long-0.1.3.tar.gz
- Upload date:
- Size: 1.6 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b54851b9671e2da36137e1f49a27d64655957115f19927c6a8d0649a9183043a
|
|
| MD5 |
33db3a3d26b44719032ea1a1de14fed7
|
|
| BLAKE2b-256 |
1b74d1bf8a26092ab1777c28dba9c7807e815d1c13d66d05219d763807467f6a
|
File details
Details for the file napari_sam2long-0.1.3-py3-none-any.whl.
File metadata
- Download URL: napari_sam2long-0.1.3-py3-none-any.whl
- Upload date:
- Size: 35.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
34e821391b520b223436a4e7b54a3868b25038f258f76df19d5d391104db115b
|
|
| MD5 |
2a368994e9010bf58f910abf46d2b9e0
|
|
| BLAKE2b-256 |
49a7db25730403f72d531cd0a1278222310d12c5888431a31280604d00daa8ad
|