You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
82 lines
1.9 KiB
82 lines
1.9 KiB
2 years ago
|
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: ...
|