Skip to content

Commit ed33843

Browse files
committed
✨ HasNDim
Signed-off-by: nstarman <[email protected]>
1 parent b0b88cf commit ed33843

File tree

4 files changed

+27
-0
lines changed

4 files changed

+27
-0
lines changed

src/array_api_typing/__init__.py

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -6,6 +6,7 @@
66
"HasDType",
77
"HasDevice",
88
"HasMatrixTranspose",
9+
"HasNDim",
910
"__version__",
1011
"__version_tuple__",
1112
)
@@ -16,5 +17,6 @@
1617
HasDevice,
1718
HasDType,
1819
HasMatrixTranspose,
20+
HasNDim,
1921
)
2022
from ._version import version as __version__, version_tuple as __version_tuple__

src/array_api_typing/_array.py

Lines changed: 16 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -4,6 +4,7 @@
44
"HasDType",
55
"HasDevice",
66
"HasMatrixTranspose",
7+
"HasNDim",
78
)
89

910
from types import ModuleType
@@ -100,11 +101,26 @@ def mT(self) -> Self: # noqa: N802
100101
...
101102

102103

104+
class HasNDim(Protocol):
105+
"""Protocol for array classes that have a number of dimensions attribute."""
106+
107+
@property
108+
def ndim(self) -> int:
109+
"""Number of array dimensions (axes).
110+
111+
Returns:
112+
int: number of array dimensions (axes).
113+
114+
"""
115+
...
116+
117+
103118
class Array(
104119
# ------ Attributes -------
105120
HasDType[DTypeT_co],
106121
HasDevice,
107122
HasMatrixTranspose,
123+
HasNDim,
108124
# ------- Methods ---------
109125
HasArrayNamespace[NamespaceT_co],
110126
# -------------------------

tests/integration/test_numpy1p0.pyi

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -63,3 +63,7 @@ _: object = x_i32.device
6363
# Check Attribute `.mT`
6464
_: xpt.Array[dtype[Any]] = x_f32.mT
6565
_: xpt.Array[dtype[Any]] = x_i32.mT
66+
67+
# Check Attribute `.ndim`
68+
_: int = x_f32.ndim
69+
_: int = x_i32.ndim

tests/integration/test_numpy2p0.pyi

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -71,3 +71,8 @@ _: object = x_b.device
7171
_: xpt.Array[np.dtype[F32]] = x_f32.mT
7272
_: xpt.Array[np.dtype[I32]] = x_i32.mT
7373
_: xpt.Array[np.dtype[B]] = x_b.mT
74+
75+
# Check Attribute `.ndim`
76+
_: int = x_f32.ndim
77+
_: int = x_i32.ndim
78+
_: int = x_b.ndim

0 commit comments

Comments
 (0)