Lasso

3D lasso tool to select large 3D areas

  • Lorenz Lamm

License BSD-3 PyPI Python Version tests codecov napari hub

3D lasso tool to select large 3D areas


This napari plugin was generated with Cookiecutter using @napari's cookiecutter-napari-plugin template.

Lasso tool

This repository allows to draw 3D lassos, generate masks from these, and then mask out the image. For instructions on how to use the plugin, please refer to the Usage instructions.

lasso_gif

How it works: A polygon is drawn and a mask is generated via:

Mask via rotation

Steps:

  1. Rotate and project polygon to 2D and create a pixel mask
  2. Create a 3D mask by stacking the pixel mask along z
  3. Rotate 3D mask s.t. it is aligned with the original polygon

This performed more efficiently than the other methods:

Mask via projection

Steps:

  1. Project all points onto the hyperplane defined by the polygon
  2. Rotate all points and the polygon s.t. they are in a horizontal plane and remove z component
  3. Create a binary pixel mask of the polygon
  4. Check which point projections are within the polygon mask
  5. reshape mask to original tomogram size

Mask via mesh voxelization

Steps:

  1. Move polygon along its normal in both directions until end of tomogram shape --> front & back polygons
  2. Define a surface by combining front & back polygons into a triangular mesh
  3. Voxelize the surface, giving the outline of the cone
  4. Fill holes to receive a filled cone

Mask via attaching slices

Steps:

  1. Rotate and project polygon to 2D and generate a pixel mask (2D)
  2. Get indices of pixel mask and rotate them back to 3D space
  3. Do that for many pixel mask, varying the z-component --> will be moved into tomogram along the polygon normal
  4. Binary closing to get rid of holes from integer conversion

Installation

pip install .

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.

License

Distributed under the terms of the BSD-3 license, "lasso-3d" is free and open source software

Issues

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

Version:

  • 0.0.1

Last updated:

  • 2025-01-09

First released:

  • 2025-01-09

License:

  • Copyright (c) 2024, Lorenz Lam...

Supported data:

  • Information not submitted

Plugin type:

Open extension:

Save extension:

Python versions supported:

Operating system:

  • Information not submitted

Requirements:

  • magicgui
  • membrain-seg
  • napari-mrcfile-reader
  • numpy
  • pyqt5
  • qtpy
  • scipy
  • scikit-image
  • tox; extra == "testing"
  • pytest; extra == "testing"
  • pytest-cov; extra == "testing"
  • pytest-qt; extra == "testing"
  • napari; extra == "testing"
  • pyqt5; extra == "testing"
Website by the napari team, original design by CZI. Go to napari main website.