From b4d0261e996dc49123ebee87e61caae30d0b1fac Mon Sep 17 00:00:00 2001 From: Tony Wong Date: Fri, 19 Aug 2022 07:11:27 +0800 Subject: [PATCH 1/2] Fix use of subtree parameter in plot_tree and get_mask --- astrodendro/plot.py | 2 +- astrodendro/structure.py | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/astrodendro/plot.py b/astrodendro/plot.py index f675d44..b7b020a 100644 --- a/astrodendro/plot.py +++ b/astrodendro/plot.py @@ -100,7 +100,7 @@ def plot_tree(self, ax, structure=None, subtree=True, autoscale=True, **kwargs): """ # Get the lines for the dendrogram - lines = self.get_lines(structures=structure, **kwargs) + lines = self.get_lines(structures=structure, subtree=subtree, **kwargs) # Add the lines to the axes ax.add_collection(lines) diff --git a/astrodendro/structure.py b/astrodendro/structure.py index 7bd855f..d21c870 100644 --- a/astrodendro/structure.py +++ b/astrodendro/structure.py @@ -477,7 +477,7 @@ def get_mask(self, shape=None, subtree=True): """ if shape is None: shape = self._dendrogram.data.shape - indices = self.indices(subtree=True) if subtree else self.indices + indices = self.indices(subtree=True) if subtree else self.indices() mask = np.zeros(shape, dtype=bool) mask[indices] = True return mask From 5e7d914714b9df1ea212f7b2a104acd777d07434 Mon Sep 17 00:00:00 2001 From: Tony Wong Date: Fri, 28 Jul 2023 20:42:53 -0500 Subject: [PATCH 2/2] Fix for astropy 5.3 (conversion of astropy.units.Quantity to bool that was deprecated since astropy 3.0 now raises a ValueError) --- astrodendro/analysis.py | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/astrodendro/analysis.py b/astrodendro/analysis.py index 2993d2e..350505f 100644 --- a/astrodendro/analysis.py +++ b/astrodendro/analysis.py @@ -322,7 +322,7 @@ def major_sigma(self): computed from the intensity weighted second moment in direction of greatest elongation in the PP plane. """ - dx = self.spatial_scale or u.pixel + dx = self.spatial_scale if self.spatial_scale is not None else u.pixel a, b = self._sky_paxes() # We need to multiply the second moment by two to get the major axis # rather than the half-major axis. @@ -335,7 +335,7 @@ def minor_sigma(self): computed from the intensity weighted second moment perpendicular to the major axis in the PP plane. """ - dx = self.spatial_scale or u.pixel + dx = self.spatial_scale if self.spatial_scale is not None else u.pixel a, b = self._sky_paxes() # We need to multiply the second moment by two to get the minor axis # rather than the half-minor axis. @@ -462,7 +462,7 @@ def v_rms(self): 0 following the Numpy convention - the third axis in the FITS convention). """ - dv = self.velocity_scale or u.pixel + dv = self.velocity_scale if self.velocity_scale is not None else u.pixel ax = [0, 0, 0] ax[self.vaxis] = 1 return dv * np.sqrt(self.stat.mom2_along(tuple(ax))) @@ -484,7 +484,7 @@ def area_exact(self): """ The exact area of the structure on the sky. """ - dx = self.spatial_scale or u.pixel + dx = self.spatial_scale if self.spatial_scale is not None else u.pixel indices = zip(*tuple(self.stat.indices[i] for i in range(3) if i != self.vaxis)) return len(set(indices)) * dx ** 2 @@ -562,7 +562,7 @@ def area_exact(self): """ The exact area of the structure on the sky. """ - dx = self.spatial_scale or u.pixel + dx = self.spatial_scale if self.spatial_scale is not None else u.pixel return self.stat.count() * dx ** 2