Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[namedarray] split .set_dims() into .expand_dims() and broadcast_to() #8380

Merged
merged 71 commits into from
Jan 29, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
71 commits
Select commit Hold shift + click to select a range
1224b54
add `.set_dims()`, `.transpose()` and `.T` to namedarray
andersy005 Oct 26, 2023
409c5de
more typying fixes
andersy005 Oct 26, 2023
43e10d8
more typing fixes
andersy005 Oct 27, 2023
d6c7758
override set_dims for IndexVariable
andersy005 Oct 27, 2023
a920e11
fix dims
andersy005 Oct 27, 2023
e765d7d
split `.set_dims()` into `.expand_dims()` and `broadcast_to()`
andersy005 Oct 27, 2023
00504f4
more typing fixes
andersy005 Oct 27, 2023
5a06dec
update whats-new
andersy005 Oct 27, 2023
ec17489
update tests
andersy005 Oct 27, 2023
a245021
doc fixes
andersy005 Oct 27, 2023
447f226
update whats-new
andersy005 Oct 27, 2023
9ad56a9
keep `.set_dims()` on `Variable()`
andersy005 Oct 27, 2023
a5918c3
update docs
andersy005 Oct 27, 2023
8091265
revert to set_dims
andersy005 Oct 27, 2023
2b93273
revert to .set_dims on Variable
andersy005 Oct 27, 2023
7ea1fb3
Update xarray/namedarray/core.py
andersy005 Oct 27, 2023
456d57c
restore .transpose on variable
andersy005 Oct 27, 2023
3f458c8
revert to set_dims in Variable
andersy005 Oct 28, 2023
c641ee6
Merge branch 'main' into add-set-dims
andersy005 Oct 28, 2023
aae2861
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Oct 28, 2023
d6240de
fix docstring
andersy005 Oct 28, 2023
1364345
update test_namedarray
andersy005 Oct 28, 2023
b793f74
update tests
andersy005 Oct 28, 2023
b15971f
Merge branch 'main' into add-set-dims
andersy005 Nov 9, 2023
cc67b63
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Nov 9, 2023
79119ce
Merge branch 'main' into add-set-dims
andersy005 Nov 20, 2023
f156744
Merge branch 'main' into add-set-dims
andersy005 Nov 28, 2023
ab6262b
Apply suggestions from code review
andersy005 Nov 28, 2023
6fbf90d
Merge branch 'main' into add-set-dims
andersy005 Nov 28, 2023
069c353
fix formatting issue
andersy005 Nov 28, 2023
5e1af7a
fix tests
andersy005 Nov 28, 2023
2499c93
update expand_dims
andersy005 Nov 30, 2023
3e4d8fa
update tests
andersy005 Nov 30, 2023
64b674a
Merge branch 'main' into add-set-dims
andersy005 Nov 30, 2023
ff01bce
update tests
andersy005 Nov 30, 2023
2c4b2b6
remove unnecessary guard conditions
andersy005 Nov 30, 2023
c0aefaa
Update type hints in NamedArray class and test cases
andersy005 Nov 30, 2023
e2cce05
Refactor NamedArray T property to handle non-2D arrays
andersy005 Nov 30, 2023
3633a2e
Reverse the order of dimensions in x.T
andersy005 Nov 30, 2023
326dad4
Refactor broadcasting and dimension expansion in NamedArray
andersy005 Dec 1, 2023
1c562a9
update docstring
andersy005 Dec 1, 2023
a7fd5c7
add todo item
andersy005 Dec 1, 2023
ff1a6fe
Merge branch 'main' into add-set-dims
andersy005 Dec 1, 2023
82e89c0
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Dec 1, 2023
47121ef
Merge branch 'main' into add-set-dims
andersy005 Dec 1, 2023
31acb3b
use comprehension
andersy005 Dec 1, 2023
6fdbad6
use dim
andersy005 Dec 1, 2023
f1feb9f
Merge branch 'main' into add-set-dims
andersy005 Dec 1, 2023
401b6d5
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Dec 1, 2023
c769639
fix imports
andersy005 Dec 1, 2023
dd64dbf
Merge branch 'main' into add-set-dims
andersy005 Dec 1, 2023
06cba49
Merge branch 'main' into add-set-dims
andersy005 Dec 5, 2023
959d97c
formatting only
andersy005 Dec 5, 2023
7be6a2d
Apply suggestions from code review
andersy005 Dec 5, 2023
3dfbce4
Merge branch 'main' into add-set-dims
andersy005 Dec 7, 2023
ea24613
[skip-rtd] fix indentation
andersy005 Dec 7, 2023
3fba906
Merge branch 'main' into add-set-dims
andersy005 Jan 23, 2024
f2a5989
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jan 23, 2024
8f494d3
Merge branch 'main' into add-set-dims
andersy005 Jan 24, 2024
5f7e5c5
refactor expand_dims to simplify API
andersy005 Jan 25, 2024
ce35128
Merge branch 'main' into add-set-dims
andersy005 Jan 25, 2024
0fb4443
fix type hint for `dim` parameter in test.
andersy005 Jan 25, 2024
a831c14
fix typing issues
andersy005 Jan 25, 2024
d880621
Merge branch 'main' into add-set-dims
andersy005 Jan 25, 2024
1524519
fix UnboundLocalError: local variable 'flattened_dims' referenced bef…
andersy005 Jan 26, 2024
e6af928
fix type hint
andersy005 Jan 26, 2024
7c3de30
Merge branch 'main' into add-set-dims
andersy005 Jan 26, 2024
a6ad9b8
ignore typing
andersy005 Jan 26, 2024
fd1c0d3
update whats-new
andersy005 Jan 26, 2024
6ec1170
Merge branch 'main' into add-set-dims
andersy005 Jan 28, 2024
e84abf9
adjust the `broadcast_to` method to prohibit adding new dimensions, a…
andersy005 Jan 28, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
56 changes: 29 additions & 27 deletions doc/api-hidden.rst
Original file line number Diff line number Diff line change
Expand Up @@ -351,33 +351,35 @@
IndexVariable.values


namedarray.core.NamedArray.all
namedarray.core.NamedArray.any
namedarray.core.NamedArray.attrs
namedarray.core.NamedArray.chunks
namedarray.core.NamedArray.chunksizes
namedarray.core.NamedArray.copy
namedarray.core.NamedArray.count
namedarray.core.NamedArray.cumprod
namedarray.core.NamedArray.cumsum
namedarray.core.NamedArray.data
namedarray.core.NamedArray.dims
namedarray.core.NamedArray.dtype
namedarray.core.NamedArray.get_axis_num
namedarray.core.NamedArray.max
namedarray.core.NamedArray.mean
namedarray.core.NamedArray.median
namedarray.core.NamedArray.min
namedarray.core.NamedArray.nbytes
namedarray.core.NamedArray.ndim
namedarray.core.NamedArray.prod
namedarray.core.NamedArray.reduce
namedarray.core.NamedArray.shape
namedarray.core.NamedArray.size
namedarray.core.NamedArray.sizes
namedarray.core.NamedArray.std
namedarray.core.NamedArray.sum
namedarray.core.NamedArray.var
NamedArray.all
NamedArray.any
NamedArray.attrs
NamedArray.broadcast_to
NamedArray.chunks
NamedArray.chunksizes
NamedArray.copy
NamedArray.count
NamedArray.cumprod
NamedArray.cumsum
NamedArray.data
NamedArray.dims
NamedArray.dtype
NamedArray.expand_dims
NamedArray.get_axis_num
NamedArray.max
NamedArray.mean
NamedArray.median
NamedArray.min
NamedArray.nbytes
NamedArray.ndim
NamedArray.prod
NamedArray.reduce
NamedArray.shape
NamedArray.size
NamedArray.sizes
NamedArray.std
NamedArray.sum
NamedArray.var


plot.plot
Expand Down
3 changes: 3 additions & 0 deletions doc/whats-new.rst
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,9 @@ v2024.02.0 (unreleased)
New Features
~~~~~~~~~~~~

- Add :py:meth:`NamedArray.expand_dims`, :py:meth:`NamedArray.permute_dims` and :py:meth:`NamedArray.broadcast_to`
(:pull:`8380`) By `Anderson Banihirwe <https://github.com/andersy005>`_.

- Xarray now defers to flox's `heuristics <https://flox.readthedocs.io/en/latest/implementation.html#heuristics>`_
to set default `method` for groupby problems. This only applies to ``flox>=0.9``.
By `Deepak Cherian <https://github.com/dcherian>`_.
Expand Down
2 changes: 2 additions & 0 deletions xarray/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@
from xarray.core.options import get_options, set_options
from xarray.core.parallel import map_blocks
from xarray.core.variable import IndexVariable, Variable, as_variable
from xarray.namedarray.core import NamedArray
from xarray.util.print_versions import show_versions

try:
Expand Down Expand Up @@ -104,6 +105,7 @@
"IndexSelResult",
"IndexVariable",
"Variable",
"NamedArray",
andersy005 marked this conversation as resolved.
Show resolved Hide resolved
# Exceptions
"MergeError",
"SerializationWarning",
Expand Down
3 changes: 2 additions & 1 deletion xarray/core/dataarray.py
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,7 @@
as_compatible_data,
as_variable,
)
from xarray.namedarray.utils import infix_dims
from xarray.plot.accessor import DataArrayPlotAccessor
from xarray.plot.utils import _get_units_from_attrs
from xarray.util.deprecation_helpers import _deprecate_positional_args, deprecate_dims
Expand Down Expand Up @@ -3017,7 +3018,7 @@ def transpose(
Dataset.transpose
"""
if dims:
dims = tuple(utils.infix_dims(dims, self.dims, missing_dims))
dims = tuple(infix_dims(dims, self.dims, missing_dims))
variable = self.variable.transpose(*dims)
if transpose_coords:
coords: dict[Hashable, Variable] = {}
Expand Down
3 changes: 1 addition & 2 deletions xarray/core/dataset.py
Original file line number Diff line number Diff line change
Expand Up @@ -114,8 +114,6 @@
drop_dims_from_indexers,
either_dict_or_kwargs,
emit_user_level_warning,
infix_dims,
is_dict_like,
is_scalar,
maybe_wrap_array,
)
Expand All @@ -126,6 +124,7 @@
broadcast_variables,
calculate_dimensions,
)
from xarray.namedarray.utils import infix_dims, is_dict_like
from xarray.plot.accessor import DatasetPlotAccessor
from xarray.util.deprecation_helpers import _deprecate_positional_args

Expand Down
9 changes: 1 addition & 8 deletions xarray/core/groupby.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,14 +5,7 @@
from abc import ABC, abstractmethod
from collections.abc import Hashable, Iterator, Mapping, Sequence
from dataclasses import dataclass, field
from typing import (
TYPE_CHECKING,
Any,
Callable,
Generic,
Literal,
Union,
)
from typing import TYPE_CHECKING, Any, Callable, Generic, Literal, Union

import numpy as np
import pandas as pd
Expand Down
30 changes: 0 additions & 30 deletions xarray/core/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -846,36 +846,6 @@ def __len__(self) -> int:
return len(self._data) - num_hidden


def infix_dims(
dims_supplied: Collection,
dims_all: Collection,
missing_dims: ErrorOptionsWithWarn = "raise",
) -> Iterator:
"""
Resolves a supplied list containing an ellipsis representing other items, to
a generator with the 'realized' list of all items
"""
if ... in dims_supplied:
if len(set(dims_all)) != len(dims_all):
raise ValueError("Cannot use ellipsis with repeated dims")
if list(dims_supplied).count(...) > 1:
raise ValueError("More than one ellipsis supplied")
other_dims = [d for d in dims_all if d not in dims_supplied]
existing_dims = drop_missing_dims(dims_supplied, dims_all, missing_dims)
for d in existing_dims:
if d is ...:
yield from other_dims
else:
yield d
else:
existing_dims = drop_missing_dims(dims_supplied, dims_all, missing_dims)
if set(existing_dims) ^ set(dims_all):
raise ValueError(
f"{dims_supplied} must be a permuted list of {dims_all}, unless `...` is included"
)
yield from existing_dims


def get_temp_dimname(dims: Container[Hashable], new_dim: Hashable) -> Hashable:
"""Get an new dimension name based on new_dim, that is not used in dims.
If the same name exists, we add an underscore(s) in the head.
Expand Down
2 changes: 1 addition & 1 deletion xarray/core/variable.py
Original file line number Diff line number Diff line change
Expand Up @@ -42,11 +42,11 @@
drop_dims_from_indexers,
either_dict_or_kwargs,
ensure_us_time_resolution,
infix_dims,
is_duck_array,
maybe_coerce_to_str,
)
from xarray.namedarray.core import NamedArray, _raise_if_any_duplicate_dimensions
from xarray.namedarray.utils import infix_dims

NON_NUMPY_SUPPORTED_ARRAY_TYPES = (
indexing.ExplicitlyIndexed,
Expand Down
30 changes: 30 additions & 0 deletions xarray/namedarray/_array_api.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@
from xarray.namedarray._typing import (
Default,
_arrayapi,
_Axes,
_Axis,
_default,
_Dim,
Expand Down Expand Up @@ -196,3 +197,32 @@ def expand_dims(
d.insert(axis, dim)
out = x._new(dims=tuple(d), data=xp.expand_dims(x._data, axis=axis))
return out


def permute_dims(x: NamedArray[Any, _DType], axes: _Axes) -> NamedArray[Any, _DType]:
"""
Permutes the dimensions of an array.

Parameters
----------
x :
Array to permute.
axes :
Permutation of the dimensions of x.

Returns
-------
out :
An array with permuted dimensions. The returned array must have the same
data type as x.

"""

dims = x.dims
new_dims = tuple(dims[i] for i in axes)
if isinstance(x._data, _arrayapi):
xp = _get_data_namespace(x)
out = x._new(dims=new_dims, data=xp.permute_dims(x._data, axes))
else:
out = x._new(dims=new_dims, data=x._data.transpose(axes)) # type: ignore[attr-defined]
return out
5 changes: 4 additions & 1 deletion xarray/namedarray/_typing.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
Any,
Callable,
Final,
Literal,
Protocol,
SupportsIndex,
TypeVar,
Expand Down Expand Up @@ -311,8 +312,10 @@ def todense(self) -> np.ndarray[Any, _DType_co]:

# NamedArray can most likely use both __array_function__ and __array_namespace__:
_sparsearrayfunction_or_api = (_sparsearrayfunction, _sparsearrayapi)

sparseduckarray = Union[
_sparsearrayfunction[_ShapeType_co, _DType_co],
_sparsearrayapi[_ShapeType_co, _DType_co],
]

ErrorOptions = Literal["raise", "ignore"]
ErrorOptionsWithWarn = Literal["raise", "warn", "ignore"]
Loading
Loading