[Git][debian-gis-team/trollimage][upstream] New upstream version 1.24.0
Antonio Valentino (@antonio.valentino)
gitlab at salsa.debian.org
Sun Jun 23 17:41:44 BST 2024
Antonio Valentino pushed to branch upstream at Debian GIS Project / trollimage
Commits:
ed00c289 by Antonio Valentino at 2024-06-23T16:19:01+00:00
New upstream version 1.24.0
- - - - -
8 changed files:
- .github/workflows/ci.yaml
- .github/workflows/deploy.yaml
- CHANGELOG.md
- pyproject.toml
- trollimage/colormap.py
- trollimage/tests/test_colormap.py
- trollimage/version.py
- trollimage/xrimage.py
Changes:
=====================================
.github/workflows/ci.yaml
=====================================
@@ -59,7 +59,6 @@ jobs:
git+https://github.com/dask/distributed \
git+https://github.com/rasterio/rasterio \
git+https://github.com/pydata/bottleneck \
- git+https://github.com/zarr-developers/zarr \
git+https://github.com/pydata/xarray;
python -m pip install -e . --no-deps --no-build-isolation;
=====================================
.github/workflows/deploy.yaml
=====================================
@@ -59,7 +59,7 @@ jobs:
platforms: all
- name: Build wheels
- uses: pypa/cibuildwheel at v2.17.0
+ uses: pypa/cibuildwheel at v2.18.1
env:
CIBW_SKIP: "cp36-* cp37-* cp38-* pp* *-manylinux_i686 *-musllinux_i686 *-musllinux_aarch64 *-win32"
CIBW_ARCHS: "${{ matrix.cibw_archs }}"
=====================================
CHANGELOG.md
=====================================
@@ -1,3 +1,19 @@
+## Version 1.24.0 (2024/06/20)
+
+
+### Pull Requests Merged
+
+#### Bugs fixed
+
+* [PR 171](https://github.com/pytroll/trollimage/pull/171) - Fix various numpy 2 and new xarray casting issues
+
+#### Features added
+
+* [PR 170](https://github.com/pytroll/trollimage/pull/170) - Implement set_alpha_channel in Colorbar
+
+In this release 2 pull requests were closed.
+
+
## Version 1.23.2 (2024/04/15)
### Pull Requests Merged
=====================================
pyproject.toml
=====================================
@@ -20,6 +20,8 @@ xfail_strict = true
filterwarnings = [
"error",
"ignore::rasterio.errors.NotGeoreferencedWarning",
+ # remove when fixed by xarray
+ "ignore:__array_wrap__ must accept context and return_scalar arguments:DeprecationWarning:numpy",
# dateutil needs a new release
# https://github.com/dateutil/dateutil/issues/1314
'ignore:datetime.datetime.utcfromtimestamp\(\) is deprecated and scheduled for removal:DeprecationWarning:dateutil',
=====================================
trollimage/colormap.py
=====================================
@@ -365,6 +365,41 @@ class Colormap(object):
cmap.values = values
return cmap
+ def set_alpha_range(self, min_alpha, max_alpha, inplace=True):
+ """Set the colormap alpha channel between two values in linear steps.
+
+ If the input colormap does not have an alpha channel,
+ it will be added to it. If an alpha channel is already existing,
+ the values will be overwritten.
+
+ The min and max values shall be between 0 (completely transparent)
+ and 1 (completely opaque).
+
+ Args:
+ min_alpha (float): Start value of the alpha channel [0-1]
+ max_alpha (float): End value of the alpha channel [0-1]
+ inplace (bool): If True (default), modify the values inplace.
+ If False, return a new Colormap instance.
+
+ """
+ if inplace:
+ cmap = self
+ else:
+ cmap = Colormap(
+ values=self.values.copy(),
+ colors=self.colors.copy())
+
+ alpha = np.linspace(min_alpha,
+ max_alpha,
+ self.colors.shape[0])
+
+ if cmap.colors.shape[1] == 4:
+ cmap.colors[:, 3] = alpha
+ else:
+ cmap.colors = np.column_stack((cmap.colors, alpha))
+
+ return cmap
+
def to_rio(self):
"""Convert the colormap to a rasterio colormap.
@@ -687,7 +722,7 @@ class Colormap(object):
# remove the last value because monkeys don't like water sprays
# on a more serious note, I don't know why we are removing the last
# value here, but this behaviour was copied from ancient satpy code
- values = np.arange(squeezed_palette.shape[0]-remove_last)
+ values = np.arange(squeezed_palette.shape[0] - remove_last)
if remove_last:
squeezed_palette = squeezed_palette[:-remove_last, :]
=====================================
trollimage/tests/test_colormap.py
=====================================
@@ -30,7 +30,6 @@ import xarray
import pytest
-
COLORS_RGB1 = np.array([
[0.0, 0.0, 0.0],
[0.2, 0.2, 0.0],
@@ -340,6 +339,32 @@ class TestColormap:
_assert_values_changed(cmap, new_cmap, inplace, orig_values)
_assert_unchanged_colors(cmap, new_cmap, orig_colors)
+ @pytest.mark.parametrize(
+ 'new_range',
+ [
+ (0.0, 1.0),
+ (1.0, 0.0),
+ (0.2, 0.5),
+ (0.8, 0.3),
+ ])
+ @pytest.mark.parametrize('colors_already_with_alpha', [False, True])
+ @pytest.mark.parametrize('inplace', [False, True])
+ def test_set_alpha_range(self, new_range, inplace, colors_already_with_alpha):
+ """Test 'set_alpha_range' method."""
+ values = np.linspace(0, 1, 11)
+ colors_col_n = 4 if colors_already_with_alpha else 3
+ colors = np.repeat(np.linspace(0, 1, 11)[:, np.newaxis], colors_col_n, 1)
+ orig_values = values.copy()
+
+ cmap = colormap.Colormap(values=values, colors=colors)
+ new_cmap = cmap.set_alpha_range(*new_range, inplace)
+
+ np.testing.assert_equal(new_cmap.colors[0, 3], new_range[0])
+ np.testing.assert_equal(new_cmap.colors[-1, 3], new_range[1])
+
+ _assert_inplace_worked(cmap, new_cmap, inplace)
+ _assert_unchanged_values(cmap, new_cmap, inplace, orig_values)
+
@pytest.mark.parametrize(
("input_cmap_func", "expected_result"),
[
@@ -690,7 +715,7 @@ def test_cmap_from_sequence_of_colors():
colors = [[0, 1, 2], [3, 4, 5], [6, 7, 8], [9, 10, 11]]
cmap = colormap.Colormap.from_sequence_of_colors(colors, color_scale=2)
np.testing.assert_allclose(cmap.values, [0, 0.33333333, 0.66666667, 1])
- np.testing.assert_array_equal(cmap.colors*2, colors)
+ np.testing.assert_array_equal(cmap.colors * 2, colors)
vals = [0, 5, 10, 15]
cmap = colormap.Colormap.from_sequence_of_colors(colors, values=vals, color_scale=2)
@@ -706,7 +731,7 @@ def test_build_colormap_with_int_data_and_without_meanings():
# test that values are respected even if valid_range is passed
# see https://github.com/pytroll/satpy/issues/2376
cmap = colormap.Colormap.from_array_with_metadata(
- palette, np.uint8, valid_range=[0, 100])
+ palette, np.uint8, valid_range=[0, 100])
np.testing.assert_array_equal(cmap.values, [0, 1])
@@ -716,23 +741,23 @@ def test_build_colormap_with_float_data():
palette = np.array([[0, 0, 0], [127, 127, 127], [255, 255, 255]])
with pytest.raises(AttributeError):
- colormap.Colormap.from_array_with_metadata(palette/100, np.float32)
+ colormap.Colormap.from_array_with_metadata(palette / 100, np.float32)
cmap = colormap.Colormap.from_array_with_metadata(
- palette,
- np.float32,
- valid_range=[0, 100],
- scale_factor=2,
- remove_last=True)
+ palette,
+ np.float32,
+ valid_range=[0, 100],
+ scale_factor=2,
+ remove_last=True)
np.testing.assert_array_equal(cmap.values, [0, 200])
cmap = colormap.Colormap.from_array_with_metadata(
- palette,
- np.float32,
- valid_range=[0, 100],
- scale_factor=2,
- remove_last=False)
+ palette,
+ np.float32,
+ valid_range=[0, 100],
+ scale_factor=2,
+ remove_last=False)
np.testing.assert_array_equal(cmap.values, [0, 100, 200])
=====================================
trollimage/version.py
=====================================
@@ -26,9 +26,9 @@ def get_keywords():
# setup.py/versioneer.py will grep for the variable names, so they must
# each be defined on a line of their own. _version.py will just call
# get_keywords().
- git_refnames = " (HEAD -> main, tag: v1.23.2)"
- git_full = "78c093c210159c7eea5e932e550952b3dabab5f2"
- git_date = "2024-04-15 14:06:06 -0500"
+ git_refnames = " (HEAD -> main, tag: v1.24.0)"
+ git_full = "5de5037532e3433a2122c57a173c984e76c8a1fb"
+ git_date = "2024-06-20 10:24:19 +0200"
keywords = {"refnames": git_refnames, "full": git_full, "date": git_date}
return keywords
=====================================
trollimage/xrimage.py
=====================================
@@ -673,6 +673,9 @@ class XRImage:
"""
attrs = data.attrs.copy()
if np.issubdtype(dtype, np.integer):
+ if np.issubdtype(data, np.bool_):
+ # convert boolean masks to floats so they can be scaled to the output integer dtype
+ data = data.astype(np.float64)
if np.issubdtype(data, np.integer):
# preserve integer data type
data = data.clip(np.iinfo(dtype).min, np.iinfo(dtype).max)
@@ -1109,6 +1112,10 @@ class XRImage:
attrs = self.data.attrs
offset = -min_stretch * scale_factor
+ try:
+ offset = offset.astype(scale_factor.dtype)
+ except AttributeError:
+ offset = scale_factor.dtype.type(offset)
self.data = np.multiply(self.data, scale_factor, dtype=scale_factor.dtype) + offset
self.data.attrs = attrs
@@ -1225,7 +1232,7 @@ class XRImage:
log_func = np.log if base == "e" else getattr(np, "log" + base)
min_stretch, max_stretch = self._convert_log_minmax_stretch(min_stretch, max_stretch)
- b__ = float(crange[1] - crange[0]) / log_func(factor)
+ b__ = float(crange[1] - crange[0]) / self.data.dtype.type(log_func(factor))
c__ = float(crange[0])
def _band_log(arr, min_input, max_input):
View it on GitLab: https://salsa.debian.org/debian-gis-team/trollimage/-/commit/ed00c289fd37c07ff6000f7a874ece5515c7a40d
--
This project does not include diff previews in email notifications.
View it on GitLab: https://salsa.debian.org/debian-gis-team/trollimage/-/commit/ed00c289fd37c07ff6000f7a874ece5515c7a40d
You're receiving this email because of your account on salsa.debian.org.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://alioth-lists.debian.net/pipermail/pkg-grass-devel/attachments/20240623/ae14c68a/attachment-0001.htm>
More information about the Pkg-grass-devel
mailing list