| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379 |
- from typing import (
- Any,
- Generic,
- Literal as L,
- NamedTuple,
- overload,
- SupportsIndex,
- TypeVar,
- )
- from typing_extensions import deprecated
- import numpy as np
- from numpy import generic, number, int8, intp, timedelta64, object_
- from numpy._typing import (
- ArrayLike,
- NDArray,
- _ArrayLike,
- _ArrayLikeBool_co,
- _ArrayLikeDT64_co,
- _ArrayLikeTD64_co,
- _ArrayLikeObject_co,
- _ArrayLikeNumber_co,
- )
- __all__ = [
- "ediff1d",
- "in1d",
- "intersect1d",
- "isin",
- "setdiff1d",
- "setxor1d",
- "union1d",
- "unique",
- "unique_all",
- "unique_counts",
- "unique_inverse",
- "unique_values",
- ]
- _SCT = TypeVar("_SCT", bound=generic)
- _NumberType = TypeVar("_NumberType", bound=number[Any])
- # Explicitly set all allowed values to prevent accidental castings to
- # abstract dtypes (their common super-type).
- #
- # Only relevant if two or more arguments are parametrized, (e.g. `setdiff1d`)
- # which could result in, for example, `int64` and `float64`producing a
- # `number[_64Bit]` array
- _EitherSCT = TypeVar(
- "_EitherSCT",
- np.bool,
- np.int8, np.int16, np.int32, np.int64, np.intp,
- np.uint8, np.uint16, np.uint32, np.uint64, np.uintp,
- np.float16, np.float32, np.float64, np.longdouble,
- np.complex64, np.complex128, np.clongdouble,
- np.timedelta64, np.datetime64,
- np.bytes_, np.str_, np.void, np.object_,
- np.integer, np.floating, np.complexfloating, np.character,
- ) # fmt: skip
- class UniqueAllResult(NamedTuple, Generic[_SCT]):
- values: NDArray[_SCT]
- indices: NDArray[intp]
- inverse_indices: NDArray[intp]
- counts: NDArray[intp]
- class UniqueCountsResult(NamedTuple, Generic[_SCT]):
- values: NDArray[_SCT]
- counts: NDArray[intp]
- class UniqueInverseResult(NamedTuple, Generic[_SCT]):
- values: NDArray[_SCT]
- inverse_indices: NDArray[intp]
- @overload
- def ediff1d(
- ary: _ArrayLikeBool_co,
- to_end: None | ArrayLike = ...,
- to_begin: None | ArrayLike = ...,
- ) -> NDArray[int8]: ...
- @overload
- def ediff1d(
- ary: _ArrayLike[_NumberType],
- to_end: None | ArrayLike = ...,
- to_begin: None | ArrayLike = ...,
- ) -> NDArray[_NumberType]: ...
- @overload
- def ediff1d(
- ary: _ArrayLikeNumber_co,
- to_end: None | ArrayLike = ...,
- to_begin: None | ArrayLike = ...,
- ) -> NDArray[Any]: ...
- @overload
- def ediff1d(
- ary: _ArrayLikeDT64_co | _ArrayLikeTD64_co,
- to_end: None | ArrayLike = ...,
- to_begin: None | ArrayLike = ...,
- ) -> NDArray[timedelta64]: ...
- @overload
- def ediff1d(
- ary: _ArrayLikeObject_co,
- to_end: None | ArrayLike = ...,
- to_begin: None | ArrayLike = ...,
- ) -> NDArray[object_]: ...
- @overload
- def unique(
- ar: _ArrayLike[_SCT],
- return_index: L[False] = ...,
- return_inverse: L[False] = ...,
- return_counts: L[False] = ...,
- axis: None | SupportsIndex = ...,
- *,
- equal_nan: bool = ...,
- ) -> NDArray[_SCT]: ...
- @overload
- def unique(
- ar: ArrayLike,
- return_index: L[False] = ...,
- return_inverse: L[False] = ...,
- return_counts: L[False] = ...,
- axis: None | SupportsIndex = ...,
- *,
- equal_nan: bool = ...,
- ) -> NDArray[Any]: ...
- @overload
- def unique(
- ar: _ArrayLike[_SCT],
- return_index: L[True] = ...,
- return_inverse: L[False] = ...,
- return_counts: L[False] = ...,
- axis: None | SupportsIndex = ...,
- *,
- equal_nan: bool = ...,
- ) -> tuple[NDArray[_SCT], NDArray[intp]]: ...
- @overload
- def unique(
- ar: ArrayLike,
- return_index: L[True] = ...,
- return_inverse: L[False] = ...,
- return_counts: L[False] = ...,
- axis: None | SupportsIndex = ...,
- *,
- equal_nan: bool = ...,
- ) -> tuple[NDArray[Any], NDArray[intp]]: ...
- @overload
- def unique(
- ar: _ArrayLike[_SCT],
- return_index: L[False] = ...,
- return_inverse: L[True] = ...,
- return_counts: L[False] = ...,
- axis: None | SupportsIndex = ...,
- *,
- equal_nan: bool = ...,
- ) -> tuple[NDArray[_SCT], NDArray[intp]]: ...
- @overload
- def unique(
- ar: ArrayLike,
- return_index: L[False] = ...,
- return_inverse: L[True] = ...,
- return_counts: L[False] = ...,
- axis: None | SupportsIndex = ...,
- *,
- equal_nan: bool = ...,
- ) -> tuple[NDArray[Any], NDArray[intp]]: ...
- @overload
- def unique(
- ar: _ArrayLike[_SCT],
- return_index: L[False] = ...,
- return_inverse: L[False] = ...,
- return_counts: L[True] = ...,
- axis: None | SupportsIndex = ...,
- *,
- equal_nan: bool = ...,
- ) -> tuple[NDArray[_SCT], NDArray[intp]]: ...
- @overload
- def unique(
- ar: ArrayLike,
- return_index: L[False] = ...,
- return_inverse: L[False] = ...,
- return_counts: L[True] = ...,
- axis: None | SupportsIndex = ...,
- *,
- equal_nan: bool = ...,
- ) -> tuple[NDArray[Any], NDArray[intp]]: ...
- @overload
- def unique(
- ar: _ArrayLike[_SCT],
- return_index: L[True] = ...,
- return_inverse: L[True] = ...,
- return_counts: L[False] = ...,
- axis: None | SupportsIndex = ...,
- *,
- equal_nan: bool = ...,
- ) -> tuple[NDArray[_SCT], NDArray[intp], NDArray[intp]]: ...
- @overload
- def unique(
- ar: ArrayLike,
- return_index: L[True] = ...,
- return_inverse: L[True] = ...,
- return_counts: L[False] = ...,
- axis: None | SupportsIndex = ...,
- *,
- equal_nan: bool = ...,
- ) -> tuple[NDArray[Any], NDArray[intp], NDArray[intp]]: ...
- @overload
- def unique(
- ar: _ArrayLike[_SCT],
- return_index: L[True] = ...,
- return_inverse: L[False] = ...,
- return_counts: L[True] = ...,
- axis: None | SupportsIndex = ...,
- *,
- equal_nan: bool = ...,
- ) -> tuple[NDArray[_SCT], NDArray[intp], NDArray[intp]]: ...
- @overload
- def unique(
- ar: ArrayLike,
- return_index: L[True] = ...,
- return_inverse: L[False] = ...,
- return_counts: L[True] = ...,
- axis: None | SupportsIndex = ...,
- *,
- equal_nan: bool = ...,
- ) -> tuple[NDArray[Any], NDArray[intp], NDArray[intp]]: ...
- @overload
- def unique(
- ar: _ArrayLike[_SCT],
- return_index: L[False] = ...,
- return_inverse: L[True] = ...,
- return_counts: L[True] = ...,
- axis: None | SupportsIndex = ...,
- *,
- equal_nan: bool = ...,
- ) -> tuple[NDArray[_SCT], NDArray[intp], NDArray[intp]]: ...
- @overload
- def unique(
- ar: ArrayLike,
- return_index: L[False] = ...,
- return_inverse: L[True] = ...,
- return_counts: L[True] = ...,
- axis: None | SupportsIndex = ...,
- *,
- equal_nan: bool = ...,
- ) -> tuple[NDArray[Any], NDArray[intp], NDArray[intp]]: ...
- @overload
- def unique(
- ar: _ArrayLike[_SCT],
- return_index: L[True] = ...,
- return_inverse: L[True] = ...,
- return_counts: L[True] = ...,
- axis: None | SupportsIndex = ...,
- *,
- equal_nan: bool = ...,
- ) -> tuple[NDArray[_SCT], NDArray[intp], NDArray[intp], NDArray[intp]]: ...
- @overload
- def unique(
- ar: ArrayLike,
- return_index: L[True] = ...,
- return_inverse: L[True] = ...,
- return_counts: L[True] = ...,
- axis: None | SupportsIndex = ...,
- *,
- equal_nan: bool = ...,
- ) -> tuple[NDArray[Any], NDArray[intp], NDArray[intp], NDArray[intp]]: ...
- @overload
- def unique_all(
- x: _ArrayLike[_SCT], /
- ) -> UniqueAllResult[_SCT]: ...
- @overload
- def unique_all(
- x: ArrayLike, /
- ) -> UniqueAllResult[Any]: ...
- @overload
- def unique_counts(
- x: _ArrayLike[_SCT], /
- ) -> UniqueCountsResult[_SCT]: ...
- @overload
- def unique_counts(
- x: ArrayLike, /
- ) -> UniqueCountsResult[Any]: ...
- @overload
- def unique_inverse(x: _ArrayLike[_SCT], /) -> UniqueInverseResult[_SCT]: ...
- @overload
- def unique_inverse(x: ArrayLike, /) -> UniqueInverseResult[Any]: ...
- @overload
- def unique_values(x: _ArrayLike[_SCT], /) -> NDArray[_SCT]: ...
- @overload
- def unique_values(x: ArrayLike, /) -> NDArray[Any]: ...
- @overload
- def intersect1d(
- ar1: _ArrayLike[_EitherSCT],
- ar2: _ArrayLike[_EitherSCT],
- assume_unique: bool = ...,
- return_indices: L[False] = ...,
- ) -> NDArray[_EitherSCT]: ...
- @overload
- def intersect1d(
- ar1: ArrayLike,
- ar2: ArrayLike,
- assume_unique: bool = ...,
- return_indices: L[False] = ...,
- ) -> NDArray[Any]: ...
- @overload
- def intersect1d(
- ar1: _ArrayLike[_EitherSCT],
- ar2: _ArrayLike[_EitherSCT],
- assume_unique: bool = ...,
- return_indices: L[True] = ...,
- ) -> tuple[NDArray[_EitherSCT], NDArray[intp], NDArray[intp]]: ...
- @overload
- def intersect1d(
- ar1: ArrayLike,
- ar2: ArrayLike,
- assume_unique: bool = ...,
- return_indices: L[True] = ...,
- ) -> tuple[NDArray[Any], NDArray[intp], NDArray[intp]]: ...
- @overload
- def setxor1d(
- ar1: _ArrayLike[_EitherSCT],
- ar2: _ArrayLike[_EitherSCT],
- assume_unique: bool = ...,
- ) -> NDArray[_EitherSCT]: ...
- @overload
- def setxor1d(
- ar1: ArrayLike,
- ar2: ArrayLike,
- assume_unique: bool = ...,
- ) -> NDArray[Any]: ...
- def isin(
- element: ArrayLike,
- test_elements: ArrayLike,
- assume_unique: bool = ...,
- invert: bool = ...,
- *,
- kind: None | str = ...,
- ) -> NDArray[np.bool]: ...
- @deprecated("Use 'isin' instead")
- def in1d(
- element: ArrayLike,
- test_elements: ArrayLike,
- assume_unique: bool = ...,
- invert: bool = ...,
- *,
- kind: None | str = ...,
- ) -> NDArray[np.bool]: ...
- @overload
- def union1d(
- ar1: _ArrayLike[_EitherSCT],
- ar2: _ArrayLike[_EitherSCT],
- ) -> NDArray[_EitherSCT]: ...
- @overload
- def union1d(
- ar1: ArrayLike,
- ar2: ArrayLike,
- ) -> NDArray[Any]: ...
- @overload
- def setdiff1d(
- ar1: _ArrayLike[_EitherSCT],
- ar2: _ArrayLike[_EitherSCT],
- assume_unique: bool = ...,
- ) -> NDArray[_EitherSCT]: ...
- @overload
- def setdiff1d(
- ar1: ArrayLike,
- ar2: ArrayLike,
- assume_unique: bool = ...,
- ) -> NDArray[Any]: ...
|