import sys
from typing import TypeVar, Union, Iterable, overload
from numpy import ndarray, _OrderKACF
from numpy.typing import ArrayLike, DTypeLike
if sys.version_info >= (3, 8):
from typing import Literal
else:
from typing_extensions import Literal
_ArrayType = TypeVar("_ArrayType", bound=ndarray)
# TODO: The following functions are now defined in C, so should be defined
# in a (not yet existing) `multiarray.pyi`.
# (with the exception of `require`)
def asarray(
a: object,
dtype: DTypeLike = ...,
order: _OrderKACF = ...,
*,
like: ArrayLike = ...
) -> ndarray: ...
@overload
def asanyarray(
a: _ArrayType,
dtype: None = ...,
order: _OrderKACF = ...,
*,
like: ArrayLike = ...
) -> _ArrayType: ...
@overload
def asanyarray(
a: object,
dtype: DTypeLike = ...,
order: _OrderKACF = ...,
*,
like: ArrayLike = ...
) -> ndarray: ...
def ascontiguousarray(
a: object, dtype: DTypeLike = ..., *, like: ArrayLike = ...
) -> ndarray: ...
def asfortranarray(
a: object, dtype: DTypeLike = ..., *, like: ArrayLike = ...
) -> ndarray: ...
_Requirements = Literal[
"C", "C_CONTIGUOUS", "CONTIGUOUS",
"F", "F_CONTIGUOUS", "FORTRAN",
"A", "ALIGNED",
"W", "WRITEABLE",
"O", "OWNDATA"
]
_E = Literal["E", "ENSUREARRAY"]
_RequirementsWithE = Union[_Requirements, _E]
@overload
def require(
a: _ArrayType,
dtype: None = ...,
requirements: Union[None, _Requirements, Iterable[_Requirements]] = ...,
*,
like: ArrayLike = ...
) -> _ArrayType: ...
@overload
def require(
a: object,
dtype: DTypeLike = ...,
requirements: Union[_E, Iterable[_RequirementsWithE]] = ...,
*,
like: ArrayLike = ...
) -> ndarray: ...
@overload
def require(
a: object,
dtype: DTypeLike = ...,
requirements: Union[None, _Requirements, Iterable[_Requirements]] = ...,
*,
like: ArrayLike = ...
) -> ndarray: ...