The napari hub is transitioning to a community-run implementation due to launch in June 2025.
Since October 1, 2024, this version is no longer actively maintained and will not be updated. New plugins and plugin updates will continue to be listed.

Lasso

lasso-3d

3D lasso tool to select large 3D areas

Workflow step:
Image annotation
Image segmentation

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:

  • 09 January 2025

First released:

  • 09 January 2025

License:

  • Copyright (c) 2024, Lorenz Lamm All rights reserved. Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: * Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. * Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. * Neither the name of copyright holder nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission. THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

Supported data:

  • Information not submitted

Plugin type:

GitHub activity:

  • Stars: 0
  • Forks: 0
  • Issues + PRs: 0

Python versions supported:

Operating system:

Requirements:

  • magicgui
  • membrain-seg
  • napari-mrcfile-reader
  • numpy
  • pyqt5
  • qtpy
  • scipy
  • scikit-image