From bf102ad70af42b5aa778a37f35a0a234b62f3161 Mon Sep 17 00:00:00 2001 From: Alessandro Felder Date: Tue, 19 Mar 2024 09:13:16 +0000 Subject: [PATCH] remove load_labelled_volume (#257) * remove load_labelled_volume * remove dependency on brainglobe-utils * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * do not package atlas-scripts --------- Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com> --- MANIFEST.in | 1 + .../atlas_generation/volume_utils.py | 60 ------------------- pyproject.toml | 4 +- 3 files changed, 2 insertions(+), 63 deletions(-) diff --git a/MANIFEST.in b/MANIFEST.in index 4e46edeb..5ba9d7b1 100644 --- a/MANIFEST.in +++ b/MANIFEST.in @@ -10,3 +10,4 @@ graft brainglobe_atlasapi *.py prune tests prune tutorials +prune brainglobe_atlasapi/atlas_generation/atlas_scripts/* diff --git a/brainglobe_atlasapi/atlas_generation/volume_utils.py b/brainglobe_atlasapi/atlas_generation/volume_utils.py index 3ca40085..8624542d 100644 --- a/brainglobe_atlasapi/atlas_generation/volume_utils.py +++ b/brainglobe_atlasapi/atlas_generation/volume_utils.py @@ -4,17 +4,6 @@ extracting surfaces from volumetric data .... """ -try: - from vedo import Volume -except ModuleNotFoundError: - raise ModuleNotFoundError( - "Mesh generation with these utils requires vedo\n" - + ' please install with "pip install vedo -U"' - ) - -import os - -import brainglobe_utils.image_io as image_io import numpy as np @@ -57,52 +46,3 @@ def create_masked_array(volume, label, greater_than=False): else: arr[volume > label] = 1 return arr - - -# ----------------------------- vedo utils ----------------------------- # -# This stuff is outdated, use the functions in mesh_utils.py -# to extract meshes from volumes - - -def load_labelled_volume(data, vmin=0, alpha=1, **kwargs): - """ - Load volume image from .nrrd file. - - Assume that voxels with value = 0 are empty while voxels with values > 0 - are labels. - (EG to indicate the location of a brain region in a reference atlas) - - :param data: str, path to file with volume data or 3d numpy array. - :param vmin: float, values below this number will be assigned an alpha=0 - and not be visualized. - :param **kwargs: kwargs to pass to the Volume class from vedo. - :param alpha: float in [0,1], - transparency [for the part of volume with value > vmin]. - """ - # Load/check volumetric data - if isinstance(data, str): # load from file - if not os.path.isfile(data): - raise FileNotFoundError(f"Volume data file {data} not found") - - try: - data = image_io.load_any(data) - except Exception as e: - raise ValueError( - f"Could not load volume data from file: {data} - {e}" - ) - - elif not isinstance(data, np.ndarray): - raise ValueError( - f"Data should be a filepath or np array, not: {data.__type__}" - ) - - # Create volume and set transparency range - vol = Volume(data, alpha=alpha, **kwargs) - - otf = vol.GetProperty().GetScalarOpacity() - otf.RemoveAllPoints() - otf.AddPoint(vmin, 0) # set to transparent - otf.AddPoint(vmin + 0.1, alpha) # set to opaque - otf.AddPoint(data.max(), alpha) - - return vol diff --git a/pyproject.toml b/pyproject.toml index 74d10179..35b2cf78 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -38,9 +38,7 @@ dependencies = [ "vedo", "xmltodict", "scikit-image", - "brainio", - "brainglobe-utils", - + "brainio" ] dynamic = ["version"]