Source code for topostats.tracing.skeletonize
"""Skeletonize molecules."""
import logging
from collections.abc import Callable
import numpy.typing as npt
from skimage.morphology import skeletonize, thin
from topostats.logs.logs import LOGGER_NAME
LOGGER = logging.getLogger(LOGGER_NAME)
[docs]
def get_skeleton(image: npt.NDArray, method: str) -> npt.NDArray:
    """
    Skeletonizing masked molecules.
    Parameters
    ----------
    image : npt.NDArray
        Image of molecule to be skeletonized.
    method : str
        Method to use, default is 'zhang' other options are 'lee', and 'thin'.
    Returns
    -------
    npt.NDArray
        Skeletonised version of the image.all($0).
    Notes
    -----
    This is a thin wrapper to the methods provided
    by the `skimage.morphology
    <https://scikit-image.org/docs/stable/api/skimage.morphology.html?highlight=skeletonize>`_
    module. See also the `examples
    <https://scikit-image.org/docs/stable/auto_examples/edges/plot_skeleton.html>_
    """
    skeletonizer = _get_skeletonize(method)
    return skeletonizer(image) 
[docs]
def _get_skeletonize(method: str = "zhang") -> Callable:
    """
    Creator component which determines which skeletonize method to use.
    Parameters
    ----------
    method : str
        Method to use for skeletonizing, methods are 'zhang' (default), 'lee', and 'thin'.
    Returns
    -------
    Callable
        Returns the function appropriate for the required skeletonizing method.
    """
    if method == "zhang":
        return _skeletonize_zhang
    if method == "lee":
        return _skeletonize_lee
    if method == "thin":
        return _skeletonize_thin
    raise ValueError(method) 
[docs]
def _skeletonize_zhang(image: npt.NDArray) -> npt.NDArray:
    """
    Skeletonize using Zhang method.
    Parameters
    ----------
    image : npt.NDArray
        Numpy array to be skeletonized.
    Returns
    -------
    npt.NDArray
        Skeletonized Numpy array.
    """
    return skeletonize(image, method="zhang") 
[docs]
def _skeletonize_lee(image: npt.NDArray) -> npt.NDArray:
    """
    Skeletonize using Lee method.
    Parameters
    ----------
    image : npt.NDArray
        Numpy array to be skeletonized.
    Returns
    -------
    npt.NDArray
        Skeletonized Numpy array.
    """
    return skeletonize(image, method="lee") 
[docs]
def _skeletonize_thin(image: npt.NDArray) -> npt.NDArray:
    """
    Skeletonize using thinning method.
    Parameters
    ----------
    image : npt.NDArray
        Numpy array to be skeletonized.
    Returns
    -------
    npt.NDArray
        Skeletonized Numpy array.
    """
    return thin(image)