aboutsummaryrefslogtreecommitdiff
# mypy: disable-error-code=misc
"""Generated from the `scripts/chaining_type_generator.py` script."""

import re
import typing as t

from _typeshed import (
    SupportsAdd,
    SupportsDunderGE,
    SupportsDunderGT,
    SupportsDunderLE,
    SupportsDunderLT,
    SupportsRichComparison,
    SupportsRichComparisonT,
    SupportsSub,
)
from typing_extensions import Concatenate, Literal, ParamSpec, Type

import pydash as pyd
from pydash.chaining.chaining import Chain
from pydash.functions import (
    After,
    Ary,
    Before,
    CurryFive,
    CurryFour,
    CurryOne,
    CurryRightFive,
    CurryRightFour,
    CurryRightOne,
    CurryRightThree,
    CurryRightTwo,
    CurryThree,
    CurryTwo,
    Debounce,
    Disjoin,
    Flow,
    Iterated,
    Juxtapose,
    Negate,
    Once,
    Partial,
    Rearg,
    Spread,
    Throttle,
)
from pydash.helpers import UNSET, Unset
from pydash.types import *
from pydash.utilities import MemoizedFunc

ValueT_co = t.TypeVar("ValueT_co", covariant=True)
T = t.TypeVar("T")
T1 = t.TypeVar("T1")
T2 = t.TypeVar("T2")
T3 = t.TypeVar("T3")
T4 = t.TypeVar("T4")
T5 = t.TypeVar("T5")
NumT = t.TypeVar("NumT", int, float, "Decimal")
NumT2 = t.TypeVar("NumT2", int, float, "Decimal")
NumT3 = t.TypeVar("NumT3", int, float, "Decimal")
CallableT = t.TypeVar("CallableT", bound=t.Callable[..., t.Any])
SequenceT = t.TypeVar("SequenceT", bound=t.Sequence[t.Any])
MutableSequenceT = t.TypeVar("MutableSequenceT", bound=t.MutableSequence[t.Any])
P = ParamSpec("P")

class AllFuncs:
    def chunk(self: "Chain[t.Sequence[T]]", size: int = 1) -> "Chain[t.List[t.Sequence[T]]]":
        return self._wrap(pyd.chunk)(size)

    def compact(self: "Chain[t.Iterable[t.Union[T, None]]]") -> "Chain[t.List[T]]":
        return self._wrap(pyd.compact)()

    def concat(self: "Chain[t.Iterable[T]]", *arrays: t.Iterable[T]) -> "Chain[t.List[T]]":
        return self._wrap(pyd.concat)(*arrays)

    def difference(self: "Chain[t.Iterable[T]]", *others: t.Iterable[T]) -> "Chain[t.List[T]]":
        return self._wrap(pyd.difference)(*others)

    @t.overload
    def difference_by(
        self: "Chain[t.Iterable[T]]",
        *others: t.Iterable[T],
        iteratee: t.Union[IterateeObjT, t.Callable[[T], t.Any], None],
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def difference_by(
        self: "Chain[t.Iterable[T]]",
        *others: t.Union[IterateeObjT, t.Iterable[T], t.Callable[[T], t.Any]],
    ) -> "Chain[t.List[T]]": ...
    def difference_by(self, *others, **kwargs):
        return self._wrap(pyd.difference_by)(*others, **kwargs)

    @t.overload
    def difference_with(
        self: "Chain[t.Iterable[T]]",
        *others: t.Iterable[T2],
        comparator: t.Union[t.Callable[[T, T2], t.Any], None],
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def difference_with(
        self: "Chain[t.Iterable[T]]", *others: t.Union[t.Iterable[T2], t.Callable[[T, T2], t.Any]]
    ) -> "Chain[t.List[T]]": ...
    def difference_with(self, *others, **kwargs):
        return self._wrap(pyd.difference_with)(*others, **kwargs)

    def drop(self: "Chain[t.Sequence[T]]", n: int = 1) -> "Chain[t.List[T]]":
        return self._wrap(pyd.drop)(n)

    def drop_right(self: "Chain[t.Sequence[T]]", n: int = 1) -> "Chain[t.List[T]]":
        return self._wrap(pyd.drop_right)(n)

    @t.overload
    def drop_right_while(
        self: "Chain[t.Sequence[T]]", predicate: t.Callable[[T, int, t.List[T]], t.Any]
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def drop_right_while(
        self: "Chain[t.Sequence[T]]", predicate: t.Callable[[T, int], t.Any]
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def drop_right_while(
        self: "Chain[t.Sequence[T]]", predicate: t.Callable[[T], t.Any]
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def drop_right_while(
        self: "Chain[t.Sequence[T]]", predicate: None = None
    ) -> "Chain[t.List[T]]": ...
    def drop_right_while(self, predicate=None):
        return self._wrap(pyd.drop_right_while)(predicate)

    @t.overload
    def drop_while(
        self: "Chain[t.Sequence[T]]", predicate: t.Callable[[T, int, t.List[T]], t.Any]
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def drop_while(
        self: "Chain[t.Sequence[T]]", predicate: t.Callable[[T, int], t.Any]
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def drop_while(
        self: "Chain[t.Sequence[T]]", predicate: t.Callable[[T], t.Any]
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def drop_while(self: "Chain[t.Sequence[T]]", predicate: None = None) -> "Chain[t.List[T]]": ...
    def drop_while(self, predicate=None):
        return self._wrap(pyd.drop_while)(predicate)

    def duplicates(
        self: "Chain[t.Sequence[T]]",
        iteratee: t.Union[t.Callable[[T], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.List[T]]":
        return self._wrap(pyd.duplicates)(iteratee)

    def fill(
        self: "Chain[t.Sequence[T]]", value: T2, start: int = 0, end: t.Union[int, None] = None
    ) -> "Chain[t.List[t.Union[T, T2]]]":
        return self._wrap(pyd.fill)(value, start, end)

    @t.overload
    def find_index(
        self: "Chain[t.Iterable[T]]", predicate: t.Callable[[T, int, t.List[T]], t.Any]
    ) -> "Chain[int]": ...
    @t.overload
    def find_index(
        self: "Chain[t.Iterable[T]]", predicate: t.Callable[[T, int], t.Any]
    ) -> "Chain[int]": ...
    @t.overload
    def find_index(
        self: "Chain[t.Iterable[T]]", predicate: t.Callable[[T], t.Any]
    ) -> "Chain[int]": ...
    @t.overload
    def find_index(self: "Chain[t.Iterable[t.Any]]", predicate: IterateeObjT) -> "Chain[int]": ...
    @t.overload
    def find_index(self: "Chain[t.Iterable[t.Any]]", predicate: None = None) -> "Chain[int]": ...
    def find_index(self, predicate=None):
        return self._wrap(pyd.find_index)(predicate)

    @t.overload
    def find_last_index(
        self: "Chain[t.Iterable[T]]", predicate: t.Callable[[T, int, t.List[T]], t.Any]
    ) -> "Chain[int]": ...
    @t.overload
    def find_last_index(
        self: "Chain[t.Iterable[T]]", predicate: t.Callable[[T, int], t.Any]
    ) -> "Chain[int]": ...
    @t.overload
    def find_last_index(
        self: "Chain[t.Iterable[T]]", predicate: t.Callable[[T], t.Any]
    ) -> "Chain[int]": ...
    @t.overload
    def find_last_index(
        self: "Chain[t.Iterable[t.Any]]", predicate: IterateeObjT
    ) -> "Chain[int]": ...
    @t.overload
    def find_last_index(
        self: "Chain[t.Iterable[t.Any]]", predicate: None = None
    ) -> "Chain[int]": ...
    def find_last_index(self, predicate=None):
        return self._wrap(pyd.find_last_index)(predicate)

    @t.overload
    def flatten(self: "Chain[t.Iterable[t.Iterable[T]]]") -> "Chain[t.List[T]]": ...
    @t.overload
    def flatten(self: "Chain[t.Iterable[T]]") -> "Chain[t.List[T]]": ...
    def flatten(self):
        return self._wrap(pyd.flatten)()

    def flatten_deep(self: "Chain[t.Iterable[t.Any]]") -> "Chain[t.List[t.Any]]":
        return self._wrap(pyd.flatten_deep)()

    def flatten_depth(self: "Chain[t.Iterable[t.Any]]", depth: int = 1) -> "Chain[t.List[t.Any]]":
        return self._wrap(pyd.flatten_depth)(depth)

    @t.overload
    def from_pairs(self: "Chain[t.Iterable[t.Tuple[T, T2]]]") -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def from_pairs(
        self: "Chain[t.Iterable[t.List[t.Union[T, T2]]]]",
    ) -> "Chain[t.Dict[t.Union[T, T2], t.Union[T, T2]]]": ...
    def from_pairs(self):
        return self._wrap(pyd.from_pairs)()

    def head(self: "Chain[t.Sequence[T]]") -> "Chain[t.Union[T, None]]":
        return self._wrap(pyd.head)()

    def index_of(self: "Chain[t.Sequence[T]]", value: T, from_index: int = 0) -> "Chain[int]":
        return self._wrap(pyd.index_of)(value, from_index)

    def initial(self: "Chain[t.Sequence[T]]") -> "Chain[t.Sequence[T]]":
        return self._wrap(pyd.initial)()

    @t.overload
    def intercalate(
        self: "Chain[t.Iterable[t.Iterable[T]]]", separator: T2
    ) -> "Chain[t.List[t.Union[T, T2]]]": ...
    @t.overload
    def intercalate(
        self: "Chain[t.Iterable[T]]", separator: T2
    ) -> "Chain[t.List[t.Union[T, T2]]]": ...
    def intercalate(self, separator):
        return self._wrap(pyd.intercalate)(separator)

    def interleave(self: "Chain[t.Iterable[T]]", *arrays: t.Iterable[T]) -> "Chain[t.List[T]]":
        return self._wrap(pyd.interleave)(*arrays)

    def intersection(
        self: "Chain[t.Sequence[T]]", *others: t.Iterable[t.Any]
    ) -> "Chain[t.List[T]]":
        return self._wrap(pyd.intersection)(*others)

    @t.overload
    def intersection_by(
        self: "Chain[t.Sequence[T]]",
        *others: t.Iterable[t.Any],
        iteratee: t.Union[t.Callable[[T], t.Any], IterateeObjT],
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def intersection_by(
        self: "Chain[t.Sequence[T]]",
        *others: t.Union[t.Iterable[t.Any], t.Callable[[T], t.Any], IterateeObjT],
    ) -> "Chain[t.List[T]]": ...
    def intersection_by(self, *others, **kwargs):
        return self._wrap(pyd.intersection_by)(*others, **kwargs)

    @t.overload
    def intersection_with(
        self: "Chain[t.Sequence[T]]",
        *others: t.Iterable[T2],
        comparator: t.Callable[[T, T2], t.Any],
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def intersection_with(
        self: "Chain[t.Sequence[T]]", *others: t.Union[t.Iterable[T2], t.Callable[[T, T2], t.Any]]
    ) -> "Chain[t.List[T]]": ...
    def intersection_with(self, *others, **kwargs):
        return self._wrap(pyd.intersection_with)(*others, **kwargs)

    def intersperse(self: "Chain[t.Iterable[T]]", separator: T2) -> "Chain[t.List[t.Union[T, T2]]]":
        return self._wrap(pyd.intersperse)(separator)

    def last(self: "Chain[t.Sequence[T]]") -> "Chain[t.Union[T, None]]":
        return self._wrap(pyd.last)()

    def last_index_of(
        self: "Chain[t.Sequence[t.Any]]", value: t.Any, from_index: t.Union[int, None] = None
    ) -> "Chain[int]":
        return self._wrap(pyd.last_index_of)(value, from_index)

    @t.overload
    def mapcat(
        self: "Chain[t.Iterable[T]]",
        iteratee: t.Callable[[T, int, t.List[T]], t.Union[t.List[T2], t.List[t.List[T2]]]],
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def mapcat(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, int, t.List[T]], T2]
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def mapcat(
        self: "Chain[t.Iterable[T]]",
        iteratee: t.Callable[[T, int], t.Union[t.List[T2], t.List[t.List[T2]]]],
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def mapcat(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, int], T2]
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def mapcat(
        self: "Chain[t.Iterable[T]]",
        iteratee: t.Callable[[T], t.Union[t.List[T2], t.List[t.List[T2]]]],
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def mapcat(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T], T2]
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def mapcat(
        self: "Chain[t.Iterable[t.Union[t.List[T], t.List[t.List[T]]]]]", iteratee: None = None
    ) -> "Chain[t.List[t.Union[T, t.List[T]]]]": ...
    def mapcat(self, iteratee=None):
        return self._wrap(pyd.mapcat)(iteratee)

    def nth(self: "Chain[t.Iterable[T]]", pos: int = 0) -> "Chain[t.Union[T, None]]":
        return self._wrap(pyd.nth)(pos)

    def pop(self: "Chain[t.List[T]]", index: int = -1) -> "Chain[T]":
        return self._wrap(pyd.pop)(index)

    def pull(self: "Chain[t.List[T]]", *values: T) -> "Chain[t.List[T]]":
        return self._wrap(pyd.pull)(*values)

    def pull_all(self: "Chain[t.List[T]]", values: t.Iterable[T]) -> "Chain[t.List[T]]":
        return self._wrap(pyd.pull_all)(values)

    def pull_all_by(
        self: "Chain[t.List[T]]",
        values: t.Iterable[T],
        iteratee: t.Union[IterateeObjT, t.Callable[[T], t.Any], None] = None,
    ) -> "Chain[t.List[T]]":
        return self._wrap(pyd.pull_all_by)(values, iteratee)

    def pull_all_with(
        self: "Chain[t.List[T]]",
        values: t.Iterable[T],
        comparator: t.Union[t.Callable[[T, T], t.Any], None] = None,
    ) -> "Chain[t.List[T]]":
        return self._wrap(pyd.pull_all_with)(values, comparator)

    def pull_at(self: "Chain[t.List[T]]", *indexes: int) -> "Chain[t.List[T]]":
        return self._wrap(pyd.pull_at)(*indexes)

    def push(self: "Chain[t.List[T]]", *items: T2) -> "Chain[t.List[t.Union[T, T2]]]":
        return self._wrap(pyd.push)(*items)

    def remove(
        self: "Chain[t.List[T]]",
        predicate: t.Union[
            t.Callable[[T, int, t.List[T]], t.Any],
            t.Callable[[T, int], t.Any],
            t.Callable[[T], t.Any],
            None,
        ] = None,
    ) -> "Chain[t.List[T]]":
        return self._wrap(pyd.remove)(predicate)

    def reverse(self: "Chain[SequenceT]") -> "Chain[SequenceT]":
        return self._wrap(pyd.reverse)()

    def shift(self: "Chain[t.List[T]]") -> "Chain[T]":
        return self._wrap(pyd.shift)()

    def slice_(
        self: "Chain[SequenceT]", start: int = 0, end: t.Union[int, None] = None
    ) -> "Chain[SequenceT]":
        return self._wrap(pyd.slice_)(start, end)

    slice = slice_

    @t.overload
    def sort(
        self: "Chain[t.List['SupportsRichComparisonT']]",
        comparator: None = None,
        key: None = None,
        reverse: bool = False,
    ) -> "Chain[t.List['SupportsRichComparisonT']]": ...
    @t.overload
    def sort(
        self: "Chain[t.List[T]]", comparator: t.Callable[[T, T], int], *, reverse: bool = False
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def sort(
        self: "Chain[t.List[T]]",
        *,
        key: t.Callable[[T], "SupportsRichComparisonT"],
        reverse: bool = False,
    ) -> "Chain[t.List[T]]": ...
    def sort(self, comparator=None, key=None, reverse=False):
        return self._wrap(pyd.sort)(comparator, key, reverse)

    def sorted_index(
        self: "Chain[t.Sequence['SupportsRichComparisonT']]", value: "SupportsRichComparisonT"
    ) -> "Chain[int]":
        return self._wrap(pyd.sorted_index)(value)

    @t.overload
    def sorted_index_by(
        self: "Chain[t.Sequence[T]]",
        value: T,
        iteratee: t.Union[IterateeObjT, t.Callable[[T], "SupportsRichComparisonT"]],
    ) -> "Chain[int]": ...
    @t.overload
    def sorted_index_by(
        self: "Chain[t.Sequence['SupportsRichComparisonT']]",
        value: "SupportsRichComparisonT",
        iteratee: None = None,
    ) -> "Chain[int]": ...
    def sorted_index_by(self, value, iteratee=None):
        return self._wrap(pyd.sorted_index_by)(value, iteratee)

    def sorted_index_of(
        self: "Chain[t.Sequence['SupportsRichComparisonT']]", value: "SupportsRichComparisonT"
    ) -> "Chain[int]":
        return self._wrap(pyd.sorted_index_of)(value)

    def sorted_last_index(
        self: "Chain[t.Sequence['SupportsRichComparisonT']]", value: "SupportsRichComparisonT"
    ) -> "Chain[int]":
        return self._wrap(pyd.sorted_last_index)(value)

    @t.overload
    def sorted_last_index_by(
        self: "Chain[t.Sequence[T]]",
        value: T,
        iteratee: t.Union[IterateeObjT, t.Callable[[T], "SupportsRichComparisonT"]],
    ) -> "Chain[int]": ...
    @t.overload
    def sorted_last_index_by(
        self: "Chain[t.Sequence['SupportsRichComparisonT']]",
        value: "SupportsRichComparisonT",
        iteratee: None = None,
    ) -> "Chain[int]": ...
    def sorted_last_index_by(self, value, iteratee=None):
        return self._wrap(pyd.sorted_last_index_by)(value, iteratee)

    def sorted_last_index_of(
        self: "Chain[t.Sequence['SupportsRichComparisonT']]", value: "SupportsRichComparisonT"
    ) -> "Chain[int]":
        return self._wrap(pyd.sorted_last_index_of)(value)

    def sorted_uniq(
        self: "Chain[t.Iterable['SupportsRichComparisonT']]",
    ) -> "Chain[t.List['SupportsRichComparisonT']]":
        return self._wrap(pyd.sorted_uniq)()

    def sorted_uniq_by(
        self: "Chain[t.Iterable['SupportsRichComparisonT']]",
        iteratee: t.Union[
            t.Callable[["SupportsRichComparisonT"], "SupportsRichComparisonT"], None
        ] = None,
    ) -> "Chain[t.List['SupportsRichComparisonT']]":
        return self._wrap(pyd.sorted_uniq_by)(iteratee)

    def splice(
        self: "Chain[MutableSequenceT]", start: int, count: t.Union[int, None] = None, *items: t.Any
    ) -> "Chain[MutableSequenceT]":
        return self._wrap(pyd.splice)(start, count, *items)

    def split_at(self: "Chain[t.Sequence[T]]", index: int) -> "Chain[t.List[t.Sequence[T]]]":
        return self._wrap(pyd.split_at)(index)

    def tail(self: "Chain[t.Sequence[T]]") -> "Chain[t.Sequence[T]]":
        return self._wrap(pyd.tail)()

    def take(self: "Chain[t.Sequence[T]]", n: int = 1) -> "Chain[t.Sequence[T]]":
        return self._wrap(pyd.take)(n)

    def take_right(self: "Chain[t.Sequence[T]]", n: int = 1) -> "Chain[t.Sequence[T]]":
        return self._wrap(pyd.take_right)(n)

    @t.overload
    def take_right_while(
        self: "Chain[t.Sequence[T]]", predicate: t.Callable[[T, int, t.List[T]], t.Any]
    ) -> "Chain[t.Sequence[T]]": ...
    @t.overload
    def take_right_while(
        self: "Chain[t.Sequence[T]]", predicate: t.Callable[[T, int], t.Any]
    ) -> "Chain[t.Sequence[T]]": ...
    @t.overload
    def take_right_while(
        self: "Chain[t.Sequence[T]]", predicate: t.Callable[[T], t.Any]
    ) -> "Chain[t.Sequence[T]]": ...
    @t.overload
    def take_right_while(
        self: "Chain[t.Sequence[T]]", predicate: None = None
    ) -> "Chain[t.Sequence[T]]": ...
    def take_right_while(self, predicate=None):
        return self._wrap(pyd.take_right_while)(predicate)

    @t.overload
    def take_while(
        self: "Chain[t.Sequence[T]]", predicate: t.Callable[[T, int, t.List[T]], t.Any]
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def take_while(
        self: "Chain[t.Sequence[T]]", predicate: t.Callable[[T, int], t.Any]
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def take_while(
        self: "Chain[t.Sequence[T]]", predicate: t.Callable[[T], t.Any]
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def take_while(self: "Chain[t.Sequence[T]]", predicate: None = None) -> "Chain[t.List[T]]": ...
    def take_while(self, predicate=None):
        return self._wrap(pyd.take_while)(predicate)

    @t.overload
    def union(self: "Chain[t.Sequence[T]]") -> "Chain[t.List[T]]": ...
    @t.overload
    def union(
        self: "Chain[t.Sequence[T]]", *others: t.Sequence[T2]
    ) -> "Chain[t.List[t.Union[T, T2]]]": ...
    def union(self, *others):
        return self._wrap(pyd.union)(*others)

    @t.overload
    def union_by(
        self: "Chain[t.Sequence[T]]", *others: t.Iterable[T], iteratee: t.Callable[[T], t.Any]
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def union_by(
        self: "Chain[t.Sequence[T]]", *others: t.Union[t.Iterable[T], t.Callable[[T], t.Any]]
    ) -> "Chain[t.List[T]]": ...
    def union_by(self, *others, **kwargs):
        return self._wrap(pyd.union_by)(*others, **kwargs)

    @t.overload
    def union_with(
        self: "Chain[t.Sequence[T]]",
        *others: t.Iterable[T2],
        comparator: t.Callable[[T, T2], t.Any],
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def union_with(
        self: "Chain[t.Sequence[T]]", *others: t.Union[t.Iterable[T2], t.Callable[[T, T2], t.Any]]
    ) -> "Chain[t.List[T]]": ...
    def union_with(self, *others, **kwargs):
        return self._wrap(pyd.union_with)(*others, **kwargs)

    def uniq(self: "Chain[t.Iterable[T]]") -> "Chain[t.List[T]]":
        return self._wrap(pyd.uniq)()

    def uniq_by(
        self: "Chain[t.Iterable[T]]", iteratee: t.Union[t.Callable[[T], t.Any], None] = None
    ) -> "Chain[t.List[T]]":
        return self._wrap(pyd.uniq_by)(iteratee)

    def uniq_with(
        self: "Chain[t.Sequence[T]]", comparator: t.Union[t.Callable[[T, T], t.Any], None] = None
    ) -> "Chain[t.List[T]]":
        return self._wrap(pyd.uniq_with)(comparator)

    def unshift(self: "Chain[t.List[T]]", *items: T2) -> "Chain[t.List[t.Union[T, T2]]]":
        return self._wrap(pyd.unshift)(*items)

    @t.overload
    def unzip(self: "Chain[t.Iterable[t.Tuple[T, T2]]]") -> "Chain[t.List[t.Tuple[T, T2]]]": ...
    @t.overload
    def unzip(
        self: "Chain[t.Iterable[t.Tuple[T, T2, T3]]]",
    ) -> "Chain[t.List[t.Tuple[T, T2, T3]]]": ...
    @t.overload
    def unzip(
        self: "Chain[t.Iterable[t.Tuple[T, T2, T3, T4]]]",
    ) -> "Chain[t.List[t.Tuple[T, T2, T3, T4]]]": ...
    @t.overload
    def unzip(
        self: "Chain[t.Iterable[t.Tuple[T, T2, T3, T4, T5]]]",
    ) -> "Chain[t.List[t.Tuple[T, T2, T3, T4, T5]]]": ...
    @t.overload
    def unzip(
        self: "Chain[t.Iterable[t.Iterable[t.Any]]]",
    ) -> "Chain[t.List[t.Tuple[t.Any, ...]]]": ...
    def unzip(self):
        return self._wrap(pyd.unzip)()

    @t.overload
    def unzip_with(
        self: "Chain[t.Iterable[t.Tuple[T, T2]]]",
        iteratee: t.Union[
            t.Callable[[t.Union[T, T2, T3], t.Union[T, T2], int], T3],
            t.Callable[[t.Union[T, T2, T3], t.Union[T, T2]], T3],
            t.Callable[[t.Union[T, T2, T3]], T3],
        ],
    ) -> "Chain[t.List[T3]]": ...
    @t.overload
    def unzip_with(
        self: "Chain[t.Iterable[t.Iterable[t.Any]]]",
        iteratee: t.Union[
            t.Callable[[t.Any, t.Any, int], T3],
            t.Callable[[t.Any, t.Any], T3],
            t.Callable[[t.Any], T3],
        ],
    ) -> "Chain[t.List[T3]]": ...
    @t.overload
    def unzip_with(
        self: "Chain[t.Iterable[t.Iterable[T]]]", iteratee: None = None
    ) -> "Chain[t.List[t.Tuple[T]]]": ...
    def unzip_with(self, iteratee=None):
        return self._wrap(pyd.unzip_with)(iteratee)

    def without(self: "Chain[t.Iterable[T]]", *values: T) -> "Chain[t.List[T]]":
        return self._wrap(pyd.without)(*values)

    def xor(self: "Chain[t.Iterable[T]]", *lists: t.Iterable[T]) -> "Chain[t.List[T]]":
        return self._wrap(pyd.xor)(*lists)

    @t.overload
    def xor_by(
        self: "Chain[t.Iterable[T]]",
        *lists: t.Iterable[T],
        iteratee: t.Union[t.Callable[[T], t.Any], IterateeObjT],
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def xor_by(
        self: "Chain[t.Iterable[T]]", *lists: t.Union[t.Iterable[T], t.Callable[[T], t.Any]]
    ) -> "Chain[t.List[T]]": ...
    def xor_by(self, *lists, **kwargs):
        return self._wrap(pyd.xor_by)(*lists, **kwargs)

    @t.overload
    def xor_with(
        self: "Chain[t.Sequence[T]]", *lists: t.Iterable[T2], comparator: t.Callable[[T, T2], t.Any]
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def xor_with(
        self: "Chain[t.Sequence[T]]", *lists: t.Union[t.Iterable[T2], t.Callable[[T, T2], t.Any]]
    ) -> "Chain[t.List[T]]": ...
    def xor_with(self, *lists, **kwargs):
        return self._wrap(pyd.xor_with)(*lists, **kwargs)

    @t.overload
    def zip_(
        self: "Chain[t.Iterable[t.Any]]", *arrays: t.Iterable[t.Any]
    ) -> "Chain[t.List[t.Tuple[t.Any, ...]]]": ...
    def zip_(self, *arrays):
        return self._wrap(pyd.zip_)(*arrays)

    zip = zip_

    @t.overload
    def zip_object(
        self: "Chain[t.Iterable[t.Tuple[T, T2]]]", values: None = None
    ) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def zip_object(
        self: "Chain[t.Iterable[t.List[t.Union[T, T2]]]]", values: None = None
    ) -> "Chain[t.Dict[t.Union[T, T2], t.Union[T, T2]]]": ...
    @t.overload
    def zip_object(self: "Chain[t.Iterable[T]]", values: t.List[T2]) -> "Chain[t.Dict[T, T2]]": ...
    def zip_object(self, values=None):
        return self._wrap(pyd.zip_object)(values)

    def zip_object_deep(
        self: "Chain[t.Iterable[t.Any]]", values: t.Union[t.List[t.Any], None] = None
    ) -> "Chain[t.Dict[t.Any, t.Any]]":
        return self._wrap(pyd.zip_object_deep)(values)

    @t.overload
    def zip_with(
        self: "Chain[t.Iterable[T]]",
        array2: t.Iterable[T2],
        *,
        iteratee: t.Union[
            t.Callable[[T, T2, int], T3], t.Callable[[T, T2], T3], t.Callable[[T], T3]
        ],
    ) -> "Chain[t.List[T3]]": ...
    @t.overload
    def zip_with(
        self: "Chain[t.Iterable[t.Any]]",
        *arrays: t.Iterable[t.Any],
        iteratee: t.Union[
            t.Callable[[t.Any, t.Any, int], T2],
            t.Callable[[t.Any, t.Any], T2],
            t.Callable[[t.Any], T2],
        ],
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def zip_with(
        self: "Chain[t.Union[t.Iterable[t.Any], t.Callable[[t.Any, t.Any, int], T2], t.Callable[[t.Any, t.Any], T2], t.Callable[[t.Any], T2]]]",
        *arrays: t.Union[
            t.Iterable[t.Any],
            t.Callable[[t.Any, t.Any, int], T2],
            t.Callable[[t.Any, t.Any], T2],
            t.Callable[[t.Any], T2],
        ],
    ) -> "Chain[t.List[T2]]": ...
    def zip_with(self, *arrays, **kwargs):
        return self._wrap(pyd.zip_with)(*arrays, **kwargs)

    def tap(self: "Chain[T]", interceptor: t.Callable[[T], t.Any]) -> "Chain[T]":
        return self._wrap(pyd.tap)(interceptor)

    @t.overload
    def at(self: "Chain[t.Mapping[T, T2]]", *paths: T) -> "Chain[t.List[t.Union[T2, None]]]": ...
    @t.overload
    def at(
        self: "Chain[t.Mapping[T, t.Any]]", *paths: t.Union[T, t.Iterable[T]]
    ) -> "Chain[t.List[t.Any]]": ...
    @t.overload
    def at(self: "Chain[t.Iterable[T]]", *paths: int) -> "Chain[t.List[t.Union[T, None]]]": ...
    @t.overload
    def at(
        self: "Chain[t.Iterable[t.Any]]", *paths: t.Union[int, t.Iterable[int]]
    ) -> "Chain[t.List[t.Any]]": ...
    def at(self, *paths):
        return self._wrap(pyd.at)(*paths)

    @t.overload
    def count_by(
        self: "Chain[t.Mapping[t.Any, T2]]", iteratee: None = None
    ) -> "Chain[t.Dict[T2, int]]": ...
    @t.overload
    def count_by(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2, T, t.Dict[T, T2]], T3]
    ) -> "Chain[t.Dict[T3, int]]": ...
    @t.overload
    def count_by(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2, T], T3]
    ) -> "Chain[t.Dict[T3, int]]": ...
    @t.overload
    def count_by(
        self: "Chain[t.Mapping[t.Any, T2]]", iteratee: t.Callable[[T2], T3]
    ) -> "Chain[t.Dict[T3, int]]": ...
    @t.overload
    def count_by(
        self: "Chain[t.Iterable[T]]", iteratee: None = None
    ) -> "Chain[t.Dict[T, int]]": ...
    @t.overload
    def count_by(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, int, t.List[T]], T2]
    ) -> "Chain[t.Dict[T2, int]]": ...
    @t.overload
    def count_by(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, int], T2]
    ) -> "Chain[t.Dict[T2, int]]": ...
    @t.overload
    def count_by(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T], T2]
    ) -> "Chain[t.Dict[T2, int]]": ...
    def count_by(self, iteratee=None):
        return self._wrap(pyd.count_by)(iteratee)

    def every(
        self: "Chain[t.Iterable[T]]",
        predicate: t.Union[t.Callable[[T], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[bool]":
        return self._wrap(pyd.every)(predicate)

    @t.overload
    def filter_(
        self: "Chain[t.Mapping[T, T2]]",
        predicate: t.Union[t.Callable[[T2, T, t.Dict[T, T2]], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def filter_(
        self: "Chain[t.Mapping[T, T2]]",
        predicate: t.Union[t.Callable[[T2, T], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def filter_(
        self: "Chain[t.Mapping[t.Any, T2]]",
        predicate: t.Union[t.Callable[[T2], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def filter_(
        self: "Chain[t.Iterable[T]]",
        predicate: t.Union[t.Callable[[T, int, t.List[T]], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def filter_(
        self: "Chain[t.Iterable[T]]",
        predicate: t.Union[t.Callable[[T, int], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def filter_(
        self: "Chain[t.Iterable[T]]",
        predicate: t.Union[t.Callable[[T], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.List[T]]": ...
    def filter_(self, predicate=None):
        return self._wrap(pyd.filter_)(predicate)

    filter = filter_

    @t.overload
    def find(
        self: "Chain[t.Dict[T, T2]]",
        predicate: t.Union[t.Callable[[T2, T, t.Dict[T, T2]], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.Union[T2, None]]": ...
    @t.overload
    def find(
        self: "Chain[t.Dict[T, T2]]",
        predicate: t.Union[t.Callable[[T2, T], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.Union[T2, None]]": ...
    @t.overload
    def find(
        self: "Chain[t.Dict[T, T2]]",
        predicate: t.Union[t.Callable[[T2], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.Union[T2, None]]": ...
    @t.overload
    def find(
        self: "Chain[t.List[T]]",
        predicate: t.Union[t.Callable[[T, int, t.List[T]], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.Union[T, None]]": ...
    @t.overload
    def find(
        self: "Chain[t.List[T]]",
        predicate: t.Union[t.Callable[[T, int], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.Union[T, None]]": ...
    @t.overload
    def find(
        self: "Chain[t.List[T]]",
        predicate: t.Union[t.Callable[[T], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.Union[T, None]]": ...
    def find(self, predicate=None):
        return self._wrap(pyd.find)(predicate)

    @t.overload
    def find_last(
        self: "Chain[t.Dict[T, T2]]",
        predicate: t.Union[t.Callable[[T2, T, t.Dict[T, T2]], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.Union[T2, None]]": ...
    @t.overload
    def find_last(
        self: "Chain[t.Dict[T, T2]]",
        predicate: t.Union[t.Callable[[T2, T], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.Union[T2, None]]": ...
    @t.overload
    def find_last(
        self: "Chain[t.Dict[t.Any, T2]]",
        predicate: t.Union[t.Callable[[T2], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.Union[T2, None]]": ...
    @t.overload
    def find_last(
        self: "Chain[t.List[T]]",
        predicate: t.Union[t.Callable[[T, int, t.List[T]], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.Union[T, None]]": ...
    @t.overload
    def find_last(
        self: "Chain[t.List[T]]",
        predicate: t.Union[t.Callable[[T, int], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.Union[T, None]]": ...
    @t.overload
    def find_last(
        self: "Chain[t.List[T]]",
        predicate: t.Union[t.Callable[[T], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.Union[T, None]]": ...
    def find_last(self, predicate=None):
        return self._wrap(pyd.find_last)(predicate)

    @t.overload
    def flat_map(
        self: "Chain[t.Mapping[T, T2]]",
        iteratee: t.Callable[[T2, T, t.Dict[T, T2]], t.Iterable[T3]],
    ) -> "Chain[t.List[T3]]": ...
    @t.overload
    def flat_map(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2, T], t.Iterable[T3]]
    ) -> "Chain[t.List[T3]]": ...
    @t.overload
    def flat_map(
        self: "Chain[t.Mapping[t.Any, T2]]", iteratee: t.Callable[[T2], t.Iterable[T3]]
    ) -> "Chain[t.List[T3]]": ...
    @t.overload
    def flat_map(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2, T, t.Dict[T, T2]], T3]
    ) -> "Chain[t.List[T3]]": ...
    @t.overload
    def flat_map(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2, T], T3]
    ) -> "Chain[t.List[T3]]": ...
    @t.overload
    def flat_map(
        self: "Chain[t.Mapping[t.Any, T2]]", iteratee: t.Callable[[T2], T3]
    ) -> "Chain[t.List[T3]]": ...
    @t.overload
    def flat_map(
        self: "Chain[t.Mapping[t.Any, t.Iterable[T2]]]", iteratee: None = None
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def flat_map(
        self: "Chain[t.Mapping[t.Any, T2]]", iteratee: None = None
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def flat_map(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, int, t.List[T]], t.Iterable[T2]]
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def flat_map(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, int], t.Iterable[T2]]
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def flat_map(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T], t.Iterable[T2]]
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def flat_map(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, int, t.List[T]], T2]
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def flat_map(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, int], T2]
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def flat_map(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T], T2]
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def flat_map(
        self: "Chain[t.Iterable[t.Iterable[T]]]", iteratee: None = None
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def flat_map(self: "Chain[t.Iterable[T]]", iteratee: None = None) -> "Chain[t.List[T]]": ...
    def flat_map(self, iteratee=None):
        return self._wrap(pyd.flat_map)(iteratee)

    @t.overload
    def flat_map_deep(
        self: "Chain[t.Mapping[T, T2]]",
        iteratee: t.Union[t.Callable[[T2, T, t.Dict[T, T2]], t.Any], None] = None,
    ) -> "Chain[t.List[t.Any]]": ...
    @t.overload
    def flat_map_deep(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Union[t.Callable[[T2, T], t.Any], None] = None
    ) -> "Chain[t.List[t.Any]]": ...
    @t.overload
    def flat_map_deep(
        self: "Chain[t.Mapping[t.Any, T2]]", iteratee: t.Union[t.Callable[[T2], t.Any], None] = None
    ) -> "Chain[t.List[t.Any]]": ...
    @t.overload
    def flat_map_deep(
        self: "Chain[t.Iterable[T]]",
        iteratee: t.Union[t.Callable[[T, int, t.List[T]], t.Any], None] = None,
    ) -> "Chain[t.List[t.Any]]": ...
    @t.overload
    def flat_map_deep(
        self: "Chain[t.Iterable[T]]", iteratee: t.Union[t.Callable[[T, int], t.Any], None] = None
    ) -> "Chain[t.List[t.Any]]": ...
    @t.overload
    def flat_map_deep(
        self: "Chain[t.Iterable[T]]", iteratee: t.Union[t.Callable[[T], t.Any], None] = None
    ) -> "Chain[t.List[t.Any]]": ...
    def flat_map_deep(self, iteratee=None):
        return self._wrap(pyd.flat_map_deep)(iteratee)

    @t.overload
    def flat_map_depth(
        self: "Chain[t.Mapping[T, T2]]",
        iteratee: t.Union[t.Callable[[T2, T, t.Dict[T, T2]], t.Any], None] = None,
        depth: int = 1,
    ) -> "Chain[t.List[t.Any]]": ...
    @t.overload
    def flat_map_depth(
        self: "Chain[t.Mapping[T, T2]]",
        iteratee: t.Union[t.Callable[[T2, T], t.Any], None] = None,
        depth: int = 1,
    ) -> "Chain[t.List[t.Any]]": ...
    @t.overload
    def flat_map_depth(
        self: "Chain[t.Mapping[t.Any, T2]]",
        iteratee: t.Union[t.Callable[[T2], t.Any], None] = None,
        depth: int = 1,
    ) -> "Chain[t.List[t.Any]]": ...
    @t.overload
    def flat_map_depth(
        self: "Chain[t.Iterable[T]]",
        iteratee: t.Union[t.Callable[[T, int, t.List[T]], t.Any], None] = None,
        depth: int = 1,
    ) -> "Chain[t.List[t.Any]]": ...
    @t.overload
    def flat_map_depth(
        self: "Chain[t.Iterable[T]]",
        iteratee: t.Union[t.Callable[[T, int], t.Any], None] = None,
        depth: int = 1,
    ) -> "Chain[t.List[t.Any]]": ...
    @t.overload
    def flat_map_depth(
        self: "Chain[t.Iterable[T]]",
        iteratee: t.Union[t.Callable[[T], t.Any], None] = None,
        depth: int = 1,
    ) -> "Chain[t.List[t.Any]]": ...
    def flat_map_depth(self, iteratee=None, depth=1):
        return self._wrap(pyd.flat_map_depth)(iteratee, depth)

    @t.overload
    def for_each(
        self: "Chain[t.Dict[T, T2]]",
        iteratee: t.Union[t.Callable[[T2, T, t.Dict[T, T2]], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def for_each(
        self: "Chain[t.Dict[T, T2]]",
        iteratee: t.Union[t.Callable[[T2, T], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def for_each(
        self: "Chain[t.Dict[T, T2]]",
        iteratee: t.Union[t.Callable[[T2], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def for_each(
        self: "Chain[t.List[T]]",
        iteratee: t.Union[t.Callable[[T, int, t.List[T]], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def for_each(
        self: "Chain[t.List[T]]",
        iteratee: t.Union[t.Callable[[T, int], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def for_each(
        self: "Chain[t.List[T]]",
        iteratee: t.Union[t.Callable[[T], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.List[T]]": ...
    def for_each(self, iteratee=None):
        return self._wrap(pyd.for_each)(iteratee)

    @t.overload
    def for_each_right(
        self: "Chain[t.Dict[T, T2]]",
        iteratee: t.Union[t.Callable[[T2, T, t.Dict[T, T2]], t.Any], IterateeObjT],
    ) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def for_each_right(
        self: "Chain[t.Dict[T, T2]]", iteratee: t.Union[t.Callable[[T2, T], t.Any], IterateeObjT]
    ) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def for_each_right(
        self: "Chain[t.Dict[T, T2]]", iteratee: t.Union[t.Callable[[T2], t.Any], IterateeObjT]
    ) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def for_each_right(
        self: "Chain[t.List[T]]",
        iteratee: t.Union[t.Callable[[T, int, t.List[T]], t.Any], IterateeObjT],
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def for_each_right(
        self: "Chain[t.List[T]]", iteratee: t.Union[t.Callable[[T, int], t.Any], IterateeObjT]
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def for_each_right(
        self: "Chain[t.List[T]]", iteratee: t.Union[t.Callable[[T], t.Any], IterateeObjT]
    ) -> "Chain[t.List[T]]": ...
    def for_each_right(self, iteratee):
        return self._wrap(pyd.for_each_right)(iteratee)

    @t.overload
    def group_by(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T], T2]
    ) -> "Chain[t.Dict[T2, t.List[T]]]": ...
    @t.overload
    def group_by(
        self: "Chain[t.Iterable[T]]", iteratee: t.Union[IterateeObjT, None] = None
    ) -> "Chain[t.Dict[t.Any, t.List[T]]]": ...
    def group_by(self, iteratee=None):
        return self._wrap(pyd.group_by)(iteratee)

    def includes(
        self: "Chain[t.Union[t.Sequence[t.Any], t.Dict[t.Any, t.Any]]]",
        target: t.Any,
        from_index: int = 0,
    ) -> "Chain[bool]":
        return self._wrap(pyd.includes)(target, from_index)

    def invoke_map(
        self: "Chain[t.Iterable[t.Any]]", path: PathT, *args: t.Any, **kwargs: t.Any
    ) -> "Chain[t.List[t.Any]]":
        return self._wrap(pyd.invoke_map)(path, *args, **kwargs)

    @t.overload
    def key_by(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T], T2]
    ) -> "Chain[t.Dict[T2, T]]": ...
    @t.overload
    def key_by(
        self: "Chain[t.Iterable[t.Any]]", iteratee: t.Union[IterateeObjT, None] = None
    ) -> "Chain[t.Dict[t.Any, t.Any]]": ...
    def key_by(self, iteratee=None):
        return self._wrap(pyd.key_by)(iteratee)

    @t.overload
    def map_(
        self: "Chain[t.Mapping[t.Any, T2]]", iteratee: t.Callable[[T2], T3]
    ) -> "Chain[t.List[T3]]": ...
    @t.overload
    def map_(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2, T], T3]
    ) -> "Chain[t.List[T3]]": ...
    @t.overload
    def map_(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2, T, t.Dict[T, T2]], T3]
    ) -> "Chain[t.List[T3]]": ...
    @t.overload
    def map_(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T], T2]
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def map_(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, int], T2]
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def map_(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, int, t.List[T]], T2]
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def map_(
        self: "Chain[t.Iterable[t.Any]]", iteratee: t.Union[IterateeObjT, None] = None
    ) -> "Chain[t.List[t.Any]]": ...
    def map_(self, iteratee=None):
        return self._wrap(pyd.map_)(iteratee)

    map = map_

    def nest(self: "Chain[t.Iterable[t.Any]]", *properties: t.Any) -> "Chain[t.Any]":
        return self._wrap(pyd.nest)(*properties)

    @t.overload
    def order_by(
        self: "Chain[t.Mapping[t.Any, T2]]",
        keys: t.Iterable[t.Union[str, int]],
        orders: t.Union[t.Iterable[bool], bool],
        reverse: bool = False,
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def order_by(
        self: "Chain[t.Mapping[t.Any, T2]]",
        keys: t.Iterable[str],
        orders: None = None,
        reverse: bool = False,
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def order_by(
        self: "Chain[t.Iterable[T]]",
        keys: t.Iterable[t.Union[str, int]],
        orders: t.Union[t.Iterable[bool], bool],
        reverse: bool = False,
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def order_by(
        self: "Chain[t.Iterable[T]]",
        keys: t.Iterable[str],
        orders: None = None,
        reverse: bool = False,
    ) -> "Chain[t.List[T]]": ...
    def order_by(self, keys, orders=None, reverse=False):
        return self._wrap(pyd.order_by)(keys, orders, reverse)

    @t.overload
    def partition(
        self: "Chain[t.Mapping[T, T2]]", predicate: t.Callable[[T2, T, t.Dict[T, T2]], t.Any]
    ) -> "Chain[t.List[t.List[T2]]]": ...
    @t.overload
    def partition(
        self: "Chain[t.Mapping[T, T2]]", predicate: t.Callable[[T2, T], t.Any]
    ) -> "Chain[t.List[t.List[T2]]]": ...
    @t.overload
    def partition(
        self: "Chain[t.Mapping[t.Any, T2]]", predicate: t.Callable[[T2], t.Any]
    ) -> "Chain[t.List[t.List[T2]]]": ...
    @t.overload
    def partition(
        self: "Chain[t.Mapping[t.Any, T2]]", predicate: t.Union[IterateeObjT, None] = None
    ) -> "Chain[t.List[t.List[T2]]]": ...
    @t.overload
    def partition(
        self: "Chain[t.Iterable[T]]", predicate: t.Callable[[T, int, t.List[T]], t.Any]
    ) -> "Chain[t.List[t.List[T]]]": ...
    @t.overload
    def partition(
        self: "Chain[t.Iterable[T]]", predicate: t.Callable[[T, int], t.Any]
    ) -> "Chain[t.List[t.List[T]]]": ...
    @t.overload
    def partition(
        self: "Chain[t.Iterable[T]]", predicate: t.Callable[[T], t.Any]
    ) -> "Chain[t.List[t.List[T]]]": ...
    @t.overload
    def partition(
        self: "Chain[t.Iterable[T]]", predicate: t.Union[IterateeObjT, None] = None
    ) -> "Chain[t.List[t.List[T]]]": ...
    def partition(self, predicate=None):
        return self._wrap(pyd.partition)(predicate)

    def pluck(self: "Chain[t.Iterable[t.Any]]", path: PathT) -> "Chain[t.List[t.Any]]":
        return self._wrap(pyd.pluck)(path)

    @t.overload
    def reduce_(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T3, T2, T], T3], accumulator: T3
    ) -> "Chain[T3]": ...
    @t.overload
    def reduce_(
        self: "Chain[t.Mapping[t.Any, T2]]", iteratee: t.Callable[[T3, T2], T3], accumulator: T3
    ) -> "Chain[T3]": ...
    @t.overload
    def reduce_(
        self: "Chain[t.Mapping[t.Any, t.Any]]", iteratee: t.Callable[[T3], T3], accumulator: T3
    ) -> "Chain[T3]": ...
    @t.overload
    def reduce_(
        self: "Chain[t.Mapping[T, T2]]",
        iteratee: t.Callable[[T2, T2, T], T2],
        accumulator: None = None,
    ) -> "Chain[T2]": ...
    @t.overload
    def reduce_(
        self: "Chain[t.Mapping[t.Any, T2]]",
        iteratee: t.Callable[[T2, T2], T2],
        accumulator: None = None,
    ) -> "Chain[T2]": ...
    @t.overload
    def reduce_(
        self: "Chain[t.Mapping[t.Any, t.Any]]",
        iteratee: t.Callable[[T], T],
        accumulator: None = None,
    ) -> "Chain[T]": ...
    @t.overload
    def reduce_(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T2, T, int], T2], accumulator: T2
    ) -> "Chain[T2]": ...
    @t.overload
    def reduce_(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T2, T], T2], accumulator: T2
    ) -> "Chain[T2]": ...
    @t.overload
    def reduce_(
        self: "Chain[t.Iterable[t.Any]]", iteratee: t.Callable[[T2], T2], accumulator: T2
    ) -> "Chain[T2]": ...
    @t.overload
    def reduce_(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, T, int], T], accumulator: None = None
    ) -> "Chain[T]": ...
    @t.overload
    def reduce_(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, T], T], accumulator: None = None
    ) -> "Chain[T]": ...
    @t.overload
    def reduce_(
        self: "Chain[t.Iterable[t.Any]]", iteratee: t.Callable[[T], T], accumulator: None = None
    ) -> "Chain[T]": ...
    @t.overload
    def reduce_(
        self: "Chain[t.Iterable[T]]", iteratee: None = None, accumulator: t.Union[T, None] = None
    ) -> "Chain[T]": ...
    def reduce_(self, iteratee=None, accumulator=None):
        return self._wrap(pyd.reduce_)(iteratee, accumulator)

    reduce = reduce_

    @t.overload
    def reduce_right(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T3, T2, T], T3], accumulator: T3
    ) -> "Chain[T3]": ...
    @t.overload
    def reduce_right(
        self: "Chain[t.Mapping[t.Any, T2]]", iteratee: t.Callable[[T3, T2], T3], accumulator: T3
    ) -> "Chain[T3]": ...
    @t.overload
    def reduce_right(
        self: "Chain[t.Mapping[t.Any, t.Any]]", iteratee: t.Callable[[T3], T3], accumulator: T3
    ) -> "Chain[T3]": ...
    @t.overload
    def reduce_right(
        self: "Chain[t.Mapping[T, T2]]",
        iteratee: t.Callable[[T2, T2, T], T2],
        accumulator: None = None,
    ) -> "Chain[T2]": ...
    @t.overload
    def reduce_right(
        self: "Chain[t.Mapping[t.Any, T2]]",
        iteratee: t.Callable[[T2, T2], T2],
        accumulator: None = None,
    ) -> "Chain[T2]": ...
    @t.overload
    def reduce_right(
        self: "Chain[t.Mapping[t.Any, t.Any]]",
        iteratee: t.Callable[[T], T],
        accumulator: None = None,
    ) -> "Chain[T]": ...
    @t.overload
    def reduce_right(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T2, T, int], T2], accumulator: T2
    ) -> "Chain[T2]": ...
    @t.overload
    def reduce_right(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T2, T], T2], accumulator: T2
    ) -> "Chain[T2]": ...
    @t.overload
    def reduce_right(
        self: "Chain[t.Iterable[t.Any]]", iteratee: t.Callable[[T2], T2], accumulator: T2
    ) -> "Chain[T2]": ...
    @t.overload
    def reduce_right(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, T, int], T], accumulator: None = None
    ) -> "Chain[T]": ...
    @t.overload
    def reduce_right(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, T], T], accumulator: None = None
    ) -> "Chain[T]": ...
    @t.overload
    def reduce_right(
        self: "Chain[t.Iterable[t.Any]]", iteratee: t.Callable[[T], T], accumulator: None = None
    ) -> "Chain[T]": ...
    @t.overload
    def reduce_right(
        self: "Chain[t.Iterable[T]]", iteratee: None = None, accumulator: t.Union[T, None] = None
    ) -> "Chain[T]": ...
    def reduce_right(self, iteratee=None, accumulator=None):
        return self._wrap(pyd.reduce_right)(iteratee, accumulator)

    @t.overload
    def reductions(
        self: "Chain[t.Mapping[T, T2]]",
        iteratee: t.Callable[[T3, T2, T], T3],
        accumulator: T3,
        from_right: bool = False,
    ) -> "Chain[t.List[T3]]": ...
    @t.overload
    def reductions(
        self: "Chain[t.Mapping[t.Any, T2]]",
        iteratee: t.Callable[[T3, T2], T3],
        accumulator: T3,
        from_right: bool = False,
    ) -> "Chain[t.List[T3]]": ...
    @t.overload
    def reductions(
        self: "Chain[t.Mapping[t.Any, t.Any]]",
        iteratee: t.Callable[[T3], T3],
        accumulator: T3,
        from_right: bool = False,
    ) -> "Chain[t.List[T3]]": ...
    @t.overload
    def reductions(
        self: "Chain[t.Mapping[T, T2]]",
        iteratee: t.Callable[[T2, T2, T], T2],
        accumulator: None = None,
        from_right: bool = False,
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def reductions(
        self: "Chain[t.Mapping[t.Any, T2]]",
        iteratee: t.Callable[[T2, T2], T2],
        accumulator: None = None,
        from_right: bool = False,
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def reductions(
        self: "Chain[t.Mapping[t.Any, t.Any]]",
        iteratee: t.Callable[[T], T],
        accumulator: None = None,
        from_right: bool = False,
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def reductions(
        self: "Chain[t.Iterable[T]]",
        iteratee: t.Callable[[T2, T, int], T2],
        accumulator: T2,
        from_right: bool = False,
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def reductions(
        self: "Chain[t.Iterable[T]]",
        iteratee: t.Callable[[T2, T], T2],
        accumulator: T2,
        from_right: bool = False,
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def reductions(
        self: "Chain[t.Iterable[t.Any]]",
        iteratee: t.Callable[[T2], T2],
        accumulator: T2,
        from_right: bool = False,
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def reductions(
        self: "Chain[t.Iterable[T]]",
        iteratee: t.Callable[[T, T, int], T],
        accumulator: None = None,
        from_right: bool = False,
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def reductions(
        self: "Chain[t.Iterable[T]]",
        iteratee: t.Callable[[T, T], T],
        accumulator: None = None,
        from_right: bool = False,
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def reductions(
        self: "Chain[t.Iterable[t.Any]]",
        iteratee: t.Callable[[T], T],
        accumulator: None = None,
        from_right: bool = False,
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def reductions(
        self: "Chain[t.Iterable[T]]",
        iteratee: None = None,
        accumulator: t.Union[T, None] = None,
        from_right: bool = False,
    ) -> "Chain[t.List[T]]": ...
    def reductions(self, iteratee=None, accumulator=None, from_right=False):
        return self._wrap(pyd.reductions)(iteratee, accumulator, from_right)

    @t.overload
    def reductions_right(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T3, T2, T], T3], accumulator: T3
    ) -> "Chain[t.List[T3]]": ...
    @t.overload
    def reductions_right(
        self: "Chain[t.Mapping[t.Any, T2]]", iteratee: t.Callable[[T3, T2], T3], accumulator: T3
    ) -> "Chain[t.List[T3]]": ...
    @t.overload
    def reductions_right(
        self: "Chain[t.Mapping[t.Any, t.Any]]", iteratee: t.Callable[[T3], T3], accumulator: T3
    ) -> "Chain[t.List[T3]]": ...
    @t.overload
    def reductions_right(
        self: "Chain[t.Mapping[T, T2]]",
        iteratee: t.Callable[[T2, T2, T], T2],
        accumulator: None = None,
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def reductions_right(
        self: "Chain[t.Mapping[t.Any, T2]]",
        iteratee: t.Callable[[T2, T2], T2],
        accumulator: None = None,
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def reductions_right(
        self: "Chain[t.Mapping[t.Any, t.Any]]",
        iteratee: t.Callable[[T], T],
        accumulator: None = None,
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def reductions_right(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T2, T, int], T2], accumulator: T2
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def reductions_right(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T2, T], T2], accumulator: T2
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def reductions_right(
        self: "Chain[t.Iterable[t.Any]]", iteratee: t.Callable[[T2], T2], accumulator: T2
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def reductions_right(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, T, int], T], accumulator: None = None
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def reductions_right(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, T], T], accumulator: None = None
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def reductions_right(
        self: "Chain[t.Iterable[t.Any]]", iteratee: t.Callable[[T], T], accumulator: None = None
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def reductions_right(
        self: "Chain[t.Iterable[T]]", iteratee: None = None, accumulator: t.Union[T, None] = None
    ) -> "Chain[t.List[T]]": ...
    def reductions_right(self, iteratee=None, accumulator=None):
        return self._wrap(pyd.reductions_right)(iteratee, accumulator)

    @t.overload
    def reject(
        self: "Chain[t.Mapping[T, T2]]",
        predicate: t.Union[t.Callable[[T2, T, t.Dict[T, T2]], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def reject(
        self: "Chain[t.Mapping[T, T2]]",
        predicate: t.Union[t.Callable[[T2, T], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def reject(
        self: "Chain[t.Mapping[t.Any, T2]]",
        predicate: t.Union[t.Callable[[T2], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def reject(
        self: "Chain[t.Iterable[T]]",
        predicate: t.Union[t.Callable[[T, int, t.List[T]], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def reject(
        self: "Chain[t.Iterable[T]]",
        predicate: t.Union[t.Callable[[T, int], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def reject(
        self: "Chain[t.Iterable[T]]",
        predicate: t.Union[t.Callable[[T], t.Any], IterateeObjT, None] = None,
    ) -> "Chain[t.List[T]]": ...
    def reject(self, predicate=None):
        return self._wrap(pyd.reject)(predicate)

    def sample(self: "Chain[t.Sequence[T]]") -> "Chain[T]":
        return self._wrap(pyd.sample)()

    def sample_size(
        self: "Chain[t.Sequence[T]]", n: t.Union[int, None] = None
    ) -> "Chain[t.List[T]]":
        return self._wrap(pyd.sample_size)(n)

    @t.overload
    def shuffle(self: "Chain[t.Mapping[t.Any, T]]") -> "Chain[t.List[T]]": ...
    @t.overload
    def shuffle(self: "Chain[t.Iterable[T]]") -> "Chain[t.List[T]]": ...
    def shuffle(self):
        return self._wrap(pyd.shuffle)()

    def size(self: "Chain[t.Sized]") -> "Chain[int]":
        return self._wrap(pyd.size)()

    def some(
        self: "Chain[t.Iterable[T]]", predicate: t.Union[t.Callable[[T], t.Any], None] = None
    ) -> "Chain[bool]":
        return self._wrap(pyd.some)(predicate)

    @t.overload
    def sort_by(
        self: "Chain[t.Mapping[t.Any, T2]]",
        iteratee: t.Union[t.Callable[[T2], t.Any], IterateeObjT, None] = None,
        reverse: bool = False,
    ) -> "Chain[t.List[T2]]": ...
    @t.overload
    def sort_by(
        self: "Chain[t.Iterable[T]]",
        iteratee: t.Union[t.Callable[[T], t.Any], IterateeObjT, None] = None,
        reverse: bool = False,
    ) -> "Chain[t.List[T]]": ...
    def sort_by(self, iteratee=None, reverse=False):
        return self._wrap(pyd.sort_by)(iteratee, reverse)

    def after(self: "Chain[t.Callable[P, T]]", n: t.SupportsInt) -> "Chain[After[P, T]]":
        return self._wrap(pyd.after)(n)

    def ary(self: "Chain[t.Callable[..., T]]", n: t.Union[t.SupportsInt, None]) -> "Chain[Ary[T]]":
        return self._wrap(pyd.ary)(n)

    def before(self: "Chain[t.Callable[P, T]]", n: t.SupportsInt) -> "Chain[Before[P, T]]":
        return self._wrap(pyd.before)(n)

    def conjoin(
        self: "Chain[t.Callable[[T], t.Any]]", *funcs: t.Callable[[T], t.Any]
    ) -> "Chain[t.Callable[[t.Iterable[T]], bool]]":
        return self._wrap(pyd.conjoin)(*funcs)

    @t.overload
    def curry(
        self: "Chain[t.Callable[[T1], T]]", arity: t.Union[int, None] = None
    ) -> "Chain[CurryOne[T1, T]]": ...
    @t.overload
    def curry(
        self: "Chain[t.Callable[[T1, T2], T]]", arity: t.Union[int, None] = None
    ) -> "Chain[CurryTwo[T1, T2, T]]": ...
    @t.overload
    def curry(
        self: "Chain[t.Callable[[T1, T2, T3], T]]", arity: t.Union[int, None] = None
    ) -> "Chain[CurryThree[T1, T2, T3, T]]": ...
    @t.overload
    def curry(
        self: "Chain[t.Callable[[T1, T2, T3, T4], T]]", arity: t.Union[int, None] = None
    ) -> "Chain[CurryFour[T1, T2, T3, T4, T]]": ...
    @t.overload
    def curry(
        self: "Chain[t.Callable[[T1, T2, T3, T4, T5], T]]", arity: t.Union[int, None] = None
    ) -> "Chain[CurryFive[T1, T2, T3, T4, T5, T]]": ...
    def curry(self, arity=None):
        return self._wrap(pyd.curry)(arity)

    @t.overload
    def curry_right(
        self: "Chain[t.Callable[[T1], T]]", arity: t.Union[int, None] = None
    ) -> "Chain[CurryRightOne[T1, T]]": ...
    @t.overload
    def curry_right(
        self: "Chain[t.Callable[[T1, T2], T]]", arity: t.Union[int, None] = None
    ) -> "Chain[CurryRightTwo[T2, T1, T]]": ...
    @t.overload
    def curry_right(
        self: "Chain[t.Callable[[T1, T2, T3], T]]", arity: t.Union[int, None] = None
    ) -> "Chain[CurryRightThree[T3, T2, T1, T]]": ...
    @t.overload
    def curry_right(
        self: "Chain[t.Callable[[T1, T2, T3, T4], T]]", arity: t.Union[int, None] = None
    ) -> "Chain[CurryRightFour[T4, T3, T2, T1, T]]": ...
    @t.overload
    def curry_right(
        self: "Chain[t.Callable[[T1, T2, T3, T4, T5], T]]",
    ) -> "Chain[CurryRightFive[T5, T4, T3, T2, T1, T]]": ...
    def curry_right(self, arity=None):
        return self._wrap(pyd.curry_right)(arity)

    def debounce(
        self: "Chain[t.Callable[P, T]]", wait: int, max_wait: t.Union[int, Literal[False]] = False
    ) -> "Chain[Debounce[P, T]]":
        return self._wrap(pyd.debounce)(wait, max_wait)

    def delay(
        self: "Chain[t.Callable[P, T]]", wait: int, *args: "P.args", **kwargs: "P.kwargs"
    ) -> "Chain[T]":
        return self._wrap(pyd.delay)(wait, *args, **kwargs)

    def disjoin(
        self: "Chain[t.Callable[[T], t.Any]]", *funcs: t.Callable[[T], t.Any]
    ) -> "Chain[Disjoin[T]]":
        return self._wrap(pyd.disjoin)(*funcs)

    @t.overload
    def flip(
        self: "Chain[t.Callable[[T1, T2, T3, T4, T5], T]]",
    ) -> "Chain[t.Callable[[T5, T4, T3, T2, T1], T]]": ...
    @t.overload
    def flip(
        self: "Chain[t.Callable[[T1, T2, T3, T4], T]]",
    ) -> "Chain[t.Callable[[T4, T3, T2, T1], T]]": ...
    @t.overload
    def flip(
        self: "Chain[t.Callable[[T1, T2, T3], T]]",
    ) -> "Chain[t.Callable[[T3, T2, T1], T]]": ...
    @t.overload
    def flip(self: "Chain[t.Callable[[T1, T2], T]]") -> "Chain[t.Callable[[T2, T1], T]]": ...
    @t.overload
    def flip(self: "Chain[t.Callable[[T1], T]]") -> "Chain[t.Callable[[T1], T]]": ...
    def flip(self: "Chain[t.Callable[..., t.Any]]") -> "Chain[t.Callable[..., t.Any]]":
        return self._wrap(pyd.flip)()

    @t.overload
    def flow(
        self: "Chain[t.Callable[P, T2]]",
        func2: t.Callable[[T2], T3],
        func3: t.Callable[[T3], T4],
        func4: t.Callable[[T4], T5],
        func5: t.Callable[[T5], T],
    ) -> "Chain[Flow[P, T]]": ...
    @t.overload
    def flow(
        self: "Chain[t.Callable[P, T2]]",
        func2: t.Callable[[T2], T3],
        func3: t.Callable[[T3], T4],
        func4: t.Callable[[T4], T],
    ) -> "Chain[Flow[P, T]]": ...
    @t.overload
    def flow(
        self: "Chain[t.Callable[P, T2]]", func2: t.Callable[[T2], T3], func3: t.Callable[[T3], T]
    ) -> "Chain[Flow[P, T]]": ...
    @t.overload
    def flow(
        self: "Chain[t.Callable[P, T2]]", func2: t.Callable[[T2], T]
    ) -> "Chain[Flow[P, T]]": ...
    @t.overload
    def flow(self: "Chain[t.Callable[P, T]]") -> "Chain[Flow[P, T]]": ...
    def flow(self, *funcs):
        return self._wrap(pyd.flow)(*funcs)

    @t.overload
    def flow_right(
        self: "Chain[t.Callable[[T4], T]]",
        func4: t.Callable[[T3], T4],
        func3: t.Callable[[T2], T3],
        func2: t.Callable[[T1], T2],
        func1: t.Callable[P, T1],
    ) -> "Chain[Flow[P, T]]": ...
    @t.overload
    def flow_right(
        self: "Chain[t.Callable[[T3], T]]",
        func3: t.Callable[[T2], T3],
        func2: t.Callable[[T1], T2],
        func1: t.Callable[P, T1],
    ) -> "Chain[Flow[P, T]]": ...
    @t.overload
    def flow_right(
        self: "Chain[t.Callable[[T2], T]]", func2: t.Callable[[T1], T2], func1: t.Callable[P, T1]
    ) -> "Chain[Flow[P, T]]": ...
    @t.overload
    def flow_right(
        self: "Chain[t.Callable[[T1], T]]", func1: t.Callable[P, T1]
    ) -> "Chain[Flow[P, T]]": ...
    @t.overload
    def flow_right(self: "Chain[t.Callable[P, T]]") -> "Chain[Flow[P, T]]": ...
    def flow_right(self, *funcs):
        return self._wrap(pyd.flow_right)(*funcs)

    def iterated(self: "Chain[t.Callable[[T], T]]") -> "Chain[Iterated[T]]":
        return self._wrap(pyd.iterated)()

    def juxtapose(
        self: "Chain[t.Callable[P, T]]", *funcs: t.Callable[P, T]
    ) -> "Chain[Juxtapose[P, T]]":
        return self._wrap(pyd.juxtapose)(*funcs)

    def negate(self: "Chain[t.Callable[P, t.Any]]") -> "Chain[Negate[P]]":
        return self._wrap(pyd.negate)()

    def once(self: "Chain[t.Callable[P, T]]") -> "Chain[Once[P, T]]":
        return self._wrap(pyd.once)()

    @t.overload
    def over_args(
        self: "Chain[t.Callable[[T1, T2, T3, T4, T5], T]]",
        transform_one: t.Callable[[T1], T1],
        transform_two: t.Callable[[T2], T2],
        transform_three: t.Callable[[T3], T3],
        transform_four: t.Callable[[T4], T4],
        transform_five: t.Callable[[T5], T5],
    ) -> "Chain[t.Callable[[T1, T2, T3, T4, T5], T]]": ...
    @t.overload
    def over_args(
        self: "Chain[t.Callable[[T1, T2, T3, T4], T]]",
        transform_one: t.Callable[[T1], T1],
        transform_two: t.Callable[[T2], T2],
        transform_three: t.Callable[[T3], T3],
        transform_four: t.Callable[[T4], T4],
    ) -> "Chain[t.Callable[[T1, T2, T3, T4], T]]": ...
    @t.overload
    def over_args(
        self: "Chain[t.Callable[[T1, T2, T3], T]]",
        transform_one: t.Callable[[T1], T1],
        transform_two: t.Callable[[T2], T2],
        transform_three: t.Callable[[T3], T3],
    ) -> "Chain[t.Callable[[T1, T2, T3], T]]": ...
    @t.overload
    def over_args(
        self: "Chain[t.Callable[[T1, T2], T]]",
        transform_one: t.Callable[[T1], T1],
        transform_two: t.Callable[[T2], T2],
    ) -> "Chain[t.Callable[[T1, T2], T]]": ...
    @t.overload
    def over_args(
        self: "Chain[t.Callable[[T1], T]]", transform_one: t.Callable[[T1], T1]
    ) -> "Chain[t.Callable[[T1], T]]": ...
    def over_args(self, *transforms):
        return self._wrap(pyd.over_args)(*transforms)

    def partial(
        self: "Chain[t.Callable[..., T]]", *args: t.Any, **kwargs: t.Any
    ) -> "Chain[Partial[T]]":
        return self._wrap(pyd.partial)(*args, **kwargs)

    def partial_right(
        self: "Chain[t.Callable[..., T]]", *args: t.Any, **kwargs: t.Any
    ) -> "Chain[Partial[T]]":
        return self._wrap(pyd.partial_right)(*args, **kwargs)

    def rearg(self: "Chain[t.Callable[P, T]]", *indexes: int) -> "Chain[Rearg[P, T]]":
        return self._wrap(pyd.rearg)(*indexes)

    def spread(self: "Chain[t.Callable[..., T]]") -> "Chain[Spread[T]]":
        return self._wrap(pyd.spread)()

    def throttle(self: "Chain[t.Callable[P, T]]", wait: int) -> "Chain[Throttle[P, T]]":
        return self._wrap(pyd.throttle)(wait)

    def unary(self: "Chain[t.Callable[..., T]]") -> "Chain[Ary[T]]":
        return self._wrap(pyd.unary)()

    def wrap(self: "Chain[T1]", func: t.Callable[Concatenate[T1, P], T]) -> "Chain[Partial[T]]":
        return self._wrap(pyd.wrap)(func)

    @t.overload
    def add(self: "Chain['SupportsAdd[T, T2]']", b: T) -> "Chain[T2]": ...
    @t.overload
    def add(self: "Chain[T]", b: "SupportsAdd[T, T2]") -> "Chain[T2]": ...
    def add(self, b):
        return self._wrap(pyd.add)(b)

    @t.overload
    def sum_(self: "Chain[t.Mapping[t.Any, 'SupportsAdd[int, T]']]") -> "Chain[T]": ...
    @t.overload
    def sum_(self: "Chain[t.Iterable['SupportsAdd[int, T]']]") -> "Chain[T]": ...
    def sum_(self):
        return self._wrap(pyd.sum_)()

    sum = sum_

    @t.overload
    def sum_by(
        self: "Chain[t.Mapping[T, T2]]",
        iteratee: t.Callable[[T2, T, t.Dict[T, T2]], "SupportsAdd[int, T3]"],
    ) -> "Chain[T3]": ...
    @t.overload
    def sum_by(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2, T], "SupportsAdd[int, T3]"]
    ) -> "Chain[T3]": ...
    @t.overload
    def sum_by(
        self: "Chain[t.Mapping[t.Any, T2]]", iteratee: t.Callable[[T2], "SupportsAdd[int, T3]"]
    ) -> "Chain[T3]": ...
    @t.overload
    def sum_by(
        self: "Chain[t.Iterable[T]]",
        iteratee: t.Callable[[T, int, t.List[T]], "SupportsAdd[int, T2]"],
    ) -> "Chain[T2]": ...
    @t.overload
    def sum_by(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, int], "SupportsAdd[int, T2]"]
    ) -> "Chain[T2]": ...
    @t.overload
    def sum_by(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T], "SupportsAdd[int, T2]"]
    ) -> "Chain[T2]": ...
    @t.overload
    def sum_by(
        self: "Chain[t.Mapping[t.Any, 'SupportsAdd[int, T]']]", iteratee: None = None
    ) -> "Chain[T]": ...
    @t.overload
    def sum_by(
        self: "Chain[t.Iterable['SupportsAdd[int, T]']]", iteratee: None = None
    ) -> "Chain[T]": ...
    def sum_by(self, iteratee=None):
        return self._wrap(pyd.sum_by)(iteratee)

    @t.overload
    def mean(self: "Chain[t.Mapping[t.Any, 'SupportsAdd[int, t.Any]']]") -> "Chain[float]": ...
    @t.overload
    def mean(self: "Chain[t.Iterable['SupportsAdd[int, t.Any]']]") -> "Chain[float]": ...
    def mean(self):
        return self._wrap(pyd.mean)()

    @t.overload
    def mean_by(
        self: "Chain[t.Mapping[T, T2]]",
        iteratee: t.Callable[[T2, T, t.Dict[T, T2]], "SupportsAdd[int, t.Any]"],
    ) -> "Chain[float]": ...
    @t.overload
    def mean_by(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2, T], "SupportsAdd[int, t.Any]"]
    ) -> "Chain[float]": ...
    @t.overload
    def mean_by(
        self: "Chain[t.Mapping[t.Any, T2]]", iteratee: t.Callable[[T2], "SupportsAdd[int, t.Any]"]
    ) -> "Chain[float]": ...
    @t.overload
    def mean_by(
        self: "Chain[t.Iterable[T]]",
        iteratee: t.Callable[[T, int, t.List[T]], "SupportsAdd[int, t.Any]"],
    ) -> "Chain[float]": ...
    @t.overload
    def mean_by(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, int], "SupportsAdd[int, t.Any]"]
    ) -> "Chain[float]": ...
    @t.overload
    def mean_by(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T], "SupportsAdd[int, t.Any]"]
    ) -> "Chain[float]": ...
    @t.overload
    def mean_by(
        self: "Chain[t.Mapping[t.Any, 'SupportsAdd[int, t.Any]']]", iteratee: None = None
    ) -> "Chain[float]": ...
    @t.overload
    def mean_by(
        self: "Chain[t.Iterable['SupportsAdd[int, t.Any]']]", iteratee: None = None
    ) -> "Chain[float]": ...
    def mean_by(self, iteratee=None):
        return self._wrap(pyd.mean_by)(iteratee)

    def ceil(self: "Chain[NumberT]", precision: int = 0) -> "Chain[float]":
        return self._wrap(pyd.ceil)(precision)

    def clamp(
        self: "Chain[NumT]", lower: NumT2, upper: t.Union[NumT3, None] = None
    ) -> "Chain[t.Union[NumT, NumT2, NumT3]]":
        return self._wrap(pyd.clamp)(lower, upper)

    def divide(
        self: "Chain[t.Union[NumberT, None]]", divisor: t.Union[NumberT, None]
    ) -> "Chain[float]":
        return self._wrap(pyd.divide)(divisor)

    def floor(self: "Chain[NumberT]", precision: int = 0) -> "Chain[float]":
        return self._wrap(pyd.floor)(precision)

    @t.overload
    def max_(
        self: "Chain[t.Mapping[t.Any, 'SupportsRichComparisonT']]", default: Unset = UNSET
    ) -> "Chain['SupportsRichComparisonT']": ...
    @t.overload
    def max_(
        self: "Chain[t.Mapping[t.Any, 'SupportsRichComparisonT']]", default: T
    ) -> "Chain[t.Union['SupportsRichComparisonT', T]]": ...
    @t.overload
    def max_(
        self: "Chain[t.Iterable['SupportsRichComparisonT']]", default: Unset = UNSET
    ) -> "Chain['SupportsRichComparisonT']": ...
    @t.overload
    def max_(
        self: "Chain[t.Iterable['SupportsRichComparisonT']]", default: T
    ) -> "Chain[t.Union['SupportsRichComparisonT', T]]": ...
    def max_(self, default=UNSET):
        return self._wrap(pyd.max_)(default)

    max = max_

    @t.overload
    def max_by(
        self: "Chain[t.Mapping[t.Any, 'SupportsRichComparisonT']]",
        iteratee: None = None,
        default: Unset = UNSET,
    ) -> "Chain['SupportsRichComparisonT']": ...
    @t.overload
    def max_by(
        self: "Chain[t.Mapping[t.Any, T2]]",
        iteratee: t.Callable[[T2], "SupportsRichComparisonT"],
        default: Unset = UNSET,
    ) -> "Chain[T2]": ...
    @t.overload
    def max_by(
        self: "Chain[t.Mapping[t.Any, T2]]",
        iteratee: t.Callable[[T2], "SupportsRichComparisonT"],
        *,
        default: T,
    ) -> "Chain[t.Union[T2, T]]": ...
    @t.overload
    def max_by(
        self: "Chain[t.Mapping[t.Any, 'SupportsRichComparisonT']]",
        iteratee: None = None,
        *,
        default: T,
    ) -> "Chain[t.Union['SupportsRichComparisonT', T]]": ...
    @t.overload
    def max_by(
        self: "Chain[t.Iterable['SupportsRichComparisonT']]",
        iteratee: None = None,
        default: Unset = UNSET,
    ) -> "Chain['SupportsRichComparisonT']": ...
    @t.overload
    def max_by(
        self: "Chain[t.Iterable[T2]]",
        iteratee: t.Callable[[T2], "SupportsRichComparisonT"],
        default: Unset = UNSET,
    ) -> "Chain[T2]": ...
    @t.overload
    def max_by(
        self: "Chain[t.Iterable[T2]]",
        iteratee: t.Callable[[T2], "SupportsRichComparisonT"],
        *,
        default: T,
    ) -> "Chain[t.Union[T2, T]]": ...
    @t.overload
    def max_by(
        self: "Chain[t.Iterable['SupportsRichComparisonT']]", iteratee: None = None, *, default: T
    ) -> "Chain[t.Union['SupportsRichComparisonT', T]]": ...
    @t.overload
    def max_by(
        self: "Chain[t.Iterable[T]]", iteratee: IterateeObjT, default: Unset = UNSET
    ) -> "Chain[T]": ...
    @t.overload
    def max_by(
        self: "Chain[t.Iterable[T]]", iteratee: IterateeObjT, default: T2
    ) -> "Chain[t.Union[T, T2]]": ...
    def max_by(self, iteratee=None, default=UNSET):
        return self._wrap(pyd.max_by)(iteratee, default)

    @t.overload
    def median(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2, T, t.Dict[T, T2]], NumberT]
    ) -> "Chain[t.Union[float, int]]": ...
    @t.overload
    def median(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2, T], NumberT]
    ) -> "Chain[t.Union[float, int]]": ...
    @t.overload
    def median(
        self: "Chain[t.Mapping[t.Any, T2]]", iteratee: t.Callable[[T2], NumberT]
    ) -> "Chain[t.Union[float, int]]": ...
    @t.overload
    def median(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, int, t.List[T]], NumberT]
    ) -> "Chain[t.Union[float, int]]": ...
    @t.overload
    def median(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, int], NumberT]
    ) -> "Chain[t.Union[float, int]]": ...
    @t.overload
    def median(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T], NumberT]
    ) -> "Chain[t.Union[float, int]]": ...
    @t.overload
    def median(
        self: "Chain[t.Iterable[NumberT]]", iteratee: None = None
    ) -> "Chain[t.Union[float, int]]": ...
    def median(self, iteratee=None):
        return self._wrap(pyd.median)(iteratee)

    @t.overload
    def min_(
        self: "Chain[t.Mapping[t.Any, 'SupportsRichComparisonT']]", default: Unset = UNSET
    ) -> "Chain['SupportsRichComparisonT']": ...
    @t.overload
    def min_(
        self: "Chain[t.Mapping[t.Any, 'SupportsRichComparisonT']]", default: T
    ) -> "Chain[t.Union['SupportsRichComparisonT', T]]": ...
    @t.overload
    def min_(
        self: "Chain[t.Iterable['SupportsRichComparisonT']]", default: Unset = UNSET
    ) -> "Chain['SupportsRichComparisonT']": ...
    @t.overload
    def min_(
        self: "Chain[t.Iterable['SupportsRichComparisonT']]", default: T
    ) -> "Chain[t.Union['SupportsRichComparisonT', T]]": ...
    def min_(self, default=UNSET):
        return self._wrap(pyd.min_)(default)

    min = min_

    @t.overload
    def min_by(
        self: "Chain[t.Mapping[t.Any, 'SupportsRichComparisonT']]",
        iteratee: None = None,
        default: Unset = UNSET,
    ) -> "Chain['SupportsRichComparisonT']": ...
    @t.overload
    def min_by(
        self: "Chain[t.Mapping[t.Any, T2]]",
        iteratee: t.Callable[[T2], "SupportsRichComparisonT"],
        default: Unset = UNSET,
    ) -> "Chain[T2]": ...
    @t.overload
    def min_by(
        self: "Chain[t.Mapping[t.Any, T2]]",
        iteratee: t.Callable[[T2], "SupportsRichComparisonT"],
        *,
        default: T,
    ) -> "Chain[t.Union[T2, T]]": ...
    @t.overload
    def min_by(
        self: "Chain[t.Mapping[t.Any, 'SupportsRichComparisonT']]",
        iteratee: None = None,
        *,
        default: T,
    ) -> "Chain[t.Union['SupportsRichComparisonT', T]]": ...
    @t.overload
    def min_by(
        self: "Chain[t.Iterable['SupportsRichComparisonT']]",
        iteratee: None = None,
        default: Unset = UNSET,
    ) -> "Chain['SupportsRichComparisonT']": ...
    @t.overload
    def min_by(
        self: "Chain[t.Iterable[T2]]",
        iteratee: t.Callable[[T2], "SupportsRichComparisonT"],
        default: Unset = UNSET,
    ) -> "Chain[T2]": ...
    @t.overload
    def min_by(
        self: "Chain[t.Iterable[T2]]",
        iteratee: t.Callable[[T2], "SupportsRichComparisonT"],
        *,
        default: T,
    ) -> "Chain[t.Union[T2, T]]": ...
    @t.overload
    def min_by(
        self: "Chain[t.Iterable['SupportsRichComparisonT']]", iteratee: None = None, *, default: T
    ) -> "Chain[t.Union['SupportsRichComparisonT', T]]": ...
    @t.overload
    def min_by(
        self: "Chain[t.Iterable[T]]", iteratee: IterateeObjT, default: Unset = UNSET
    ) -> "Chain[T]": ...
    @t.overload
    def min_by(
        self: "Chain[t.Iterable[T]]", iteratee: IterateeObjT, default: T2
    ) -> "Chain[t.Union[T, T2]]": ...
    def min_by(self, iteratee=None, default=UNSET):
        return self._wrap(pyd.min_by)(iteratee, default)

    def moving_mean(
        self: "Chain[t.Sequence['SupportsAdd[int, t.Any]']]", size: t.SupportsInt
    ) -> "Chain[t.List[float]]":
        return self._wrap(pyd.moving_mean)(size)

    @t.overload
    def multiply(self: "Chain[SupportsMul[int, T2]]", multiplicand: None) -> "Chain[T2]": ...
    @t.overload
    def multiply(self: "Chain[None]", multiplicand: SupportsMul[int, T2]) -> "Chain[T2]": ...
    @t.overload
    def multiply(self: "Chain[None]", multiplicand: None) -> "Chain[int]": ...
    @t.overload
    def multiply(self: "Chain[SupportsMul[T, T2]]", multiplicand: T) -> "Chain[T2]": ...
    @t.overload
    def multiply(self: "Chain[T]", multiplicand: SupportsMul[T, T2]) -> "Chain[T2]": ...
    def multiply(self, multiplicand):
        return self._wrap(pyd.multiply)(multiplicand)

    @t.overload
    def power(self: "Chain[int]", n: int) -> "Chain[t.Union[int, float]]": ...
    @t.overload
    def power(self: "Chain[float]", n: t.Union[int, float]) -> "Chain[float]": ...
    @t.overload
    def power(self: "Chain[t.List[int]]", n: int) -> "Chain[t.List[t.Union[int, float]]]": ...
    @t.overload
    def power(
        self: "Chain[t.List[float]]", n: t.List[t.Union[int, float]]
    ) -> "Chain[t.List[float]]": ...
    def power(self, n):
        return self._wrap(pyd.power)(n)

    @t.overload
    def round_(
        self: "Chain[t.List[SupportsRound[NumberT]]]", precision: int = 0
    ) -> "Chain[t.List[float]]": ...
    @t.overload
    def round_(self: "Chain[SupportsRound[NumberT]]", precision: int = 0) -> "Chain[float]": ...
    def round_(self, precision=0):
        return self._wrap(pyd.round_)(precision)

    round = round_

    @t.overload
    def scale(
        self: "Chain[t.Iterable['Decimal']]", maximum: "Decimal"
    ) -> "Chain[t.List['Decimal']]": ...
    @t.overload
    def scale(
        self: "Chain[t.Iterable[NumberNoDecimalT]]", maximum: NumberNoDecimalT
    ) -> "Chain[t.List[float]]": ...
    @t.overload
    def scale(self: "Chain[t.Iterable[NumberT]]", maximum: int = 1) -> "Chain[t.List[float]]": ...
    def scale(self, maximum: NumberT = 1):
        return self._wrap(pyd.scale)(maximum)

    @t.overload
    def slope(
        self: "Chain[t.Union[t.Tuple['Decimal', 'Decimal'], t.List['Decimal']]]",
        point2: t.Union[t.Tuple["Decimal", "Decimal"], t.List["Decimal"]],
    ) -> "Chain['Decimal']": ...
    @t.overload
    def slope(
        self: "Chain[t.Union[t.Tuple[NumberNoDecimalT, NumberNoDecimalT], t.List[NumberNoDecimalT]]]",
        point2: t.Union[t.Tuple[NumberNoDecimalT, NumberNoDecimalT], t.List[NumberNoDecimalT]],
    ) -> "Chain[float]": ...
    def slope(self, point2):
        return self._wrap(pyd.slope)(point2)

    def std_deviation(self: "Chain[t.List[NumberT]]") -> "Chain[float]":
        return self._wrap(pyd.std_deviation)()

    @t.overload
    def subtract(self: "Chain['SupportsSub[T, T2]']", subtrahend: T) -> "Chain[T2]": ...
    @t.overload
    def subtract(self: "Chain[T]", subtrahend: "SupportsSub[T, T2]") -> "Chain[T2]": ...
    def subtract(self, subtrahend):
        return self._wrap(pyd.subtract)(subtrahend)

    def transpose(self: "Chain[t.Iterable[t.Iterable[T]]]") -> "Chain[t.List[t.List[T]]]":
        return self._wrap(pyd.transpose)()

    @t.overload
    def variance(self: "Chain[t.Mapping[t.Any, 'SupportsAdd[int, t.Any]']]") -> "Chain[float]": ...
    @t.overload
    def variance(self: "Chain[t.Iterable['SupportsAdd[int, t.Any]']]") -> "Chain[float]": ...
    def variance(self):
        return self._wrap(pyd.variance)()

    @t.overload
    def zscore(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2, T, t.Dict[T, T2]], NumberT]
    ) -> "Chain[t.List[float]]": ...
    @t.overload
    def zscore(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2, T], NumberT]
    ) -> "Chain[t.List[float]]": ...
    @t.overload
    def zscore(
        self: "Chain[t.Mapping[t.Any, T2]]", iteratee: t.Callable[[T2], NumberT]
    ) -> "Chain[t.List[float]]": ...
    @t.overload
    def zscore(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, int, t.List[T]], NumberT]
    ) -> "Chain[t.List[float]]": ...
    @t.overload
    def zscore(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, int], NumberT]
    ) -> "Chain[t.List[float]]": ...
    @t.overload
    def zscore(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T], NumberT]
    ) -> "Chain[t.List[float]]": ...
    @t.overload
    def zscore(
        self: "Chain[t.Iterable[NumberT]]", iteratee: None = None
    ) -> "Chain[t.List[float]]": ...
    def zscore(self, iteratee=None):
        return self._wrap(pyd.zscore)(iteratee)

    @t.overload
    def assign(
        self: "Chain[t.Mapping[T, T2]]", *sources: t.Mapping[T3, T4]
    ) -> "Chain[t.Dict[t.Union[T, T3], t.Union[T2, T4]]]": ...
    @t.overload
    def assign(
        self: "Chain[t.Union[t.Tuple[T, ...], t.List[T]]]", *sources: t.Mapping[int, T2]
    ) -> "Chain[t.List[t.Union[T, T2]]]": ...
    def assign(self, *sources) -> "Chain[t.Union[t.List[t.Any], t.Dict[t.Any, t.Any]]]":
        return self._wrap(pyd.assign)(*sources)

    @t.overload
    def assign_with(
        self: "Chain[t.Mapping[T, T2]]",
        *sources: t.Mapping[T3, t.Any],
        customizer: t.Callable[[t.Union[T2, None]], T5],
    ) -> "Chain[t.Dict[t.Union[T, T3], t.Union[T2, T5]]]": ...
    @t.overload
    def assign_with(
        self: "Chain[t.Mapping[T, T2]]",
        *sources: t.Mapping[T3, T4],
        customizer: t.Callable[[t.Union[T2, None], T4], T5],
    ) -> "Chain[t.Dict[t.Union[T, T3], t.Union[T2, T5]]]": ...
    @t.overload
    def assign_with(
        self: "Chain[t.Mapping[T, T2]]",
        *sources: t.Mapping[T3, T4],
        customizer: t.Callable[[t.Union[T2, None], T4, T3], T5],
    ) -> "Chain[t.Dict[t.Union[T, T3], t.Union[T2, T5]]]": ...
    @t.overload
    def assign_with(
        self: "Chain[t.Mapping[T, T2]]",
        *sources: t.Mapping[T3, T4],
        customizer: t.Callable[[t.Union[T2, None], T4, T3, t.Dict[T, T2]], T5],
    ) -> "Chain[t.Dict[t.Union[T, T3], t.Union[T2, T5]]]": ...
    @t.overload
    def assign_with(
        self: "Chain[t.Mapping[T, T2]]",
        *sources: t.Mapping[T3, T4],
        customizer: t.Callable[[t.Union[T2, None], T4, T3, t.Dict[T, T2], t.Dict[T3, T4]], T5],
    ) -> "Chain[t.Dict[t.Union[T, T3], t.Union[T2, T5]]]": ...
    @t.overload
    def assign_with(
        self: "Chain[t.Mapping[T, T2]]", *sources: t.Mapping[T3, T4], customizer: None = None
    ) -> "Chain[t.Dict[t.Union[T, T3], t.Union[T2, T4]]]": ...
    def assign_with(self, *sources, customizer=None):
        return self._wrap(pyd.assign_with)(*sources, customizer=customizer)

    @t.overload
    def callables(
        self: "Chain[t.Mapping['SupportsRichComparisonT', t.Any]]",
    ) -> "Chain[t.List['SupportsRichComparisonT']]": ...
    @t.overload
    def callables(self: "Chain[t.Iterable[T]]") -> "Chain[t.List[T]]": ...
    def callables(self):
        return self._wrap(pyd.callables)()

    def clone(self: "Chain[T]") -> "Chain[T]":
        return self._wrap(pyd.clone)()

    @t.overload
    def clone_with(
        self: "Chain[t.Mapping[T, T2]]", customizer: t.Callable[[T2, T, t.Mapping[T, T2]], T3]
    ) -> "Chain[t.Dict[T, t.Union[T2, T3]]]": ...
    @t.overload
    def clone_with(
        self: "Chain[t.Mapping[T, T2]]", customizer: t.Callable[[T2, T], T3]
    ) -> "Chain[t.Dict[T, t.Union[T2, T3]]]": ...
    @t.overload
    def clone_with(
        self: "Chain[t.Mapping[T, T2]]", customizer: t.Callable[[T2], T3]
    ) -> "Chain[t.Dict[T, t.Union[T2, T3]]]": ...
    @t.overload
    def clone_with(
        self: "Chain[t.List[T]]", customizer: t.Callable[[T, int, t.List[T]], T2]
    ) -> "Chain[t.List[t.Union[T, T2]]]": ...
    @t.overload
    def clone_with(
        self: "Chain[t.List[T]]", customizer: t.Callable[[T, int], T2]
    ) -> "Chain[t.List[t.Union[T, T2]]]": ...
    @t.overload
    def clone_with(
        self: "Chain[t.List[T]]", customizer: t.Callable[[T], T2]
    ) -> "Chain[t.List[t.Union[T, T2]]]": ...
    @t.overload
    def clone_with(self: "Chain[T]", customizer: None = None) -> "Chain[T]": ...
    @t.overload
    def clone_with(self: "Chain[t.Any]", customizer: t.Callable[..., t.Any]) -> "Chain[t.Any]": ...
    def clone_with(self, customizer=None):
        return self._wrap(pyd.clone_with)(customizer)

    def clone_deep(self: "Chain[T]") -> "Chain[T]":
        return self._wrap(pyd.clone_deep)()

    @t.overload
    def clone_deep_with(
        self: "Chain[t.Mapping[T, T2]]", customizer: t.Callable[[T2, T, t.Mapping[T, T2]], T3]
    ) -> "Chain[t.Dict[T, t.Union[T2, T3]]]": ...
    @t.overload
    def clone_deep_with(
        self: "Chain[t.Mapping[T, T2]]", customizer: t.Callable[[T2, T], T3]
    ) -> "Chain[t.Dict[T, t.Union[T2, T3]]]": ...
    @t.overload
    def clone_deep_with(
        self: "Chain[t.Mapping[T, T2]]", customizer: t.Callable[[T2], T3]
    ) -> "Chain[t.Dict[T, t.Union[T2, T3]]]": ...
    @t.overload
    def clone_deep_with(
        self: "Chain[t.List[T]]", customizer: t.Callable[[T, int, t.List[T]], T2]
    ) -> "Chain[t.List[t.Union[T, T2]]]": ...
    @t.overload
    def clone_deep_with(
        self: "Chain[t.List[T]]", customizer: t.Callable[[T, int], T2]
    ) -> "Chain[t.List[t.Union[T, T2]]]": ...
    @t.overload
    def clone_deep_with(
        self: "Chain[t.List[T]]", customizer: t.Callable[[T], T2]
    ) -> "Chain[t.List[t.Union[T, T2]]]": ...
    @t.overload
    def clone_deep_with(self: "Chain[T]", customizer: None = None) -> "Chain[T]": ...
    @t.overload
    def clone_deep_with(
        self: "Chain[t.Any]", customizer: t.Callable[..., t.Any]
    ) -> "Chain[t.Any]": ...
    def clone_deep_with(self, customizer=None):
        return self._wrap(pyd.clone_deep_with)(customizer)

    def defaults(
        self: "Chain[t.Dict[T, T2]]", *sources: t.Dict[T3, T4]
    ) -> "Chain[t.Dict[t.Union[T, T3], t.Union[T2, T4]]]":
        return self._wrap(pyd.defaults)(*sources)

    def defaults_deep(
        self: "Chain[t.Dict[T, T2]]", *sources: t.Dict[T3, T4]
    ) -> "Chain[t.Dict[t.Union[T, T3], t.Union[T2, T4]]]":
        return self._wrap(pyd.defaults_deep)(*sources)

    @t.overload
    def find_key(
        self: "Chain[t.Mapping[T, T2]]", predicate: t.Callable[[T2, T, t.Dict[T, T2]], t.Any]
    ) -> "Chain[t.Union[T, None]]": ...
    @t.overload
    def find_key(
        self: "Chain[t.Mapping[T, T2]]", predicate: t.Callable[[T2, T], t.Any]
    ) -> "Chain[t.Union[T, None]]": ...
    @t.overload
    def find_key(
        self: "Chain[t.Mapping[T, T2]]", predicate: t.Callable[[T2], t.Any]
    ) -> "Chain[t.Union[T, None]]": ...
    @t.overload
    def find_key(
        self: "Chain[t.Mapping[T, t.Any]]", predicate: None = None
    ) -> "Chain[t.Union[T, None]]": ...
    @t.overload
    def find_key(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, int, t.List[T]], t.Any]
    ) -> "Chain[t.Union[int, None]]": ...
    @t.overload
    def find_key(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, int], t.Any]
    ) -> "Chain[t.Union[int, None]]": ...
    @t.overload
    def find_key(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T], t.Any]
    ) -> "Chain[t.Union[int, None]]": ...
    @t.overload
    def find_key(
        self: "Chain[t.Iterable[t.Any]]", iteratee: None = None
    ) -> "Chain[t.Union[int, None]]": ...
    def find_key(self, predicate=None):
        return self._wrap(pyd.find_key)(predicate)

    @t.overload
    def find_last_key(
        self: "Chain[t.Mapping[T, T2]]", predicate: t.Callable[[T2, T, t.Dict[T, T2]], t.Any]
    ) -> "Chain[t.Union[T, None]]": ...
    @t.overload
    def find_last_key(
        self: "Chain[t.Mapping[T, T2]]", predicate: t.Callable[[T2, T], t.Any]
    ) -> "Chain[t.Union[T, None]]": ...
    @t.overload
    def find_last_key(
        self: "Chain[t.Mapping[T, T2]]", predicate: t.Callable[[T2], t.Any]
    ) -> "Chain[t.Union[T, None]]": ...
    @t.overload
    def find_last_key(
        self: "Chain[t.Mapping[T, t.Any]]", predicate: None = None
    ) -> "Chain[t.Union[T, None]]": ...
    @t.overload
    def find_last_key(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, int, t.List[T]], t.Any]
    ) -> "Chain[t.Union[int, None]]": ...
    @t.overload
    def find_last_key(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, int], t.Any]
    ) -> "Chain[t.Union[int, None]]": ...
    @t.overload
    def find_last_key(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T], t.Any]
    ) -> "Chain[t.Union[int, None]]": ...
    @t.overload
    def find_last_key(
        self: "Chain[t.Iterable[t.Any]]", iteratee: None = None
    ) -> "Chain[t.Union[int, None]]": ...
    def find_last_key(self, predicate=None):
        return self._wrap(pyd.find_last_key)(predicate)

    @t.overload
    def for_in(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2, T, t.Dict[T, T2]], t.Any]
    ) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def for_in(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2, T], t.Any]
    ) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def for_in(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2], t.Any]
    ) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def for_in(
        self: "Chain[t.Mapping[T, T2]]", iteratee: None = None
    ) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def for_in(
        self: "Chain[t.Sequence[T]]", iteratee: t.Callable[[T, int, t.List[T]], t.Any]
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def for_in(
        self: "Chain[t.Sequence[T]]", iteratee: t.Callable[[T, int], t.Any]
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def for_in(
        self: "Chain[t.Sequence[T]]", iteratee: t.Callable[[T], t.Any]
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def for_in(self: "Chain[t.Sequence[T]]", iteratee: None = None) -> "Chain[t.List[T]]": ...
    def for_in(self, iteratee=None):
        return self._wrap(pyd.for_in)(iteratee)

    @t.overload
    def for_in_right(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2, T, t.Dict[T, T2]], t.Any]
    ) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def for_in_right(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2, T], t.Any]
    ) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def for_in_right(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2], t.Any]
    ) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def for_in_right(
        self: "Chain[t.Mapping[T, T2]]", iteratee: None = None
    ) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def for_in_right(
        self: "Chain[t.Sequence[T]]", iteratee: t.Callable[[T, int, t.List[T]], t.Any]
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def for_in_right(
        self: "Chain[t.Sequence[T]]", iteratee: t.Callable[[T, int], t.Any]
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def for_in_right(
        self: "Chain[t.Sequence[T]]", iteratee: t.Callable[[T], t.Any]
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def for_in_right(self: "Chain[t.Sequence[T]]", iteratee: None = None) -> "Chain[t.List[T]]": ...
    def for_in_right(self, iteratee=None):
        return self._wrap(pyd.for_in_right)(iteratee)

    @t.overload
    def get(self: "Chain[t.List[T]]", path: int, default: T2) -> "Chain[t.Union[T, T2]]": ...
    @t.overload
    def get(
        self: "Chain[t.List[T]]", path: int, default: None = None
    ) -> "Chain[t.Union[T, None]]": ...
    @t.overload
    def get(self: "Chain[t.Any]", path: PathT, default: t.Any = None) -> "Chain[t.Any]": ...
    def get(self: "Chain[t.Any]", path: PathT, default: t.Any = None) -> "Chain[t.Any]":
        return self._wrap(pyd.get)(path, default)

    def has(self: "Chain[t.Any]", path: PathT) -> "Chain[bool]":
        return self._wrap(pyd.has)(path)

    @t.overload
    def invert(self: "Chain[t.Mapping[T, T2]]") -> "Chain[t.Dict[T2, T]]": ...
    @t.overload
    def invert(self: "Chain[t.Union[t.Iterator[T], t.Sequence[T]]]") -> "Chain[t.Dict[T, int]]": ...
    def invert(self):
        return self._wrap(pyd.invert)()

    @t.overload
    def invert_by(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2], T3]
    ) -> "Chain[t.Dict[T3, t.List[T]]]": ...
    @t.overload
    def invert_by(
        self: "Chain[t.Mapping[T, T2]]", iteratee: None = None
    ) -> "Chain[t.Dict[T2, t.List[T]]]": ...
    @t.overload
    def invert_by(
        self: "Chain[t.Union[t.Iterator[T], t.Sequence[T]]]", iteratee: t.Callable[[T], T2]
    ) -> "Chain[t.Dict[T2, t.List[int]]]": ...
    @t.overload
    def invert_by(
        self: "Chain[t.Union[t.Iterator[T], t.Sequence[T]]]", iteratee: None = None
    ) -> "Chain[t.Dict[T, t.List[int]]]": ...
    def invert_by(self, iteratee=None):
        return self._wrap(pyd.invert_by)(iteratee)

    def invoke(self: "Chain[t.Any]", path: PathT, *args: t.Any, **kwargs: t.Any) -> "Chain[t.Any]":
        return self._wrap(pyd.invoke)(path, *args, **kwargs)

    @t.overload
    def keys(self: "Chain[t.Iterable[T]]") -> "Chain[t.List[T]]": ...
    @t.overload
    def keys(self: "Chain[t.Any]") -> "Chain[t.List[t.Any]]": ...
    def keys(self):
        return self._wrap(pyd.keys)()

    @t.overload
    def map_keys(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2, T, t.Dict[T, T2]], T3]
    ) -> "Chain[t.Dict[T3, T2]]": ...
    @t.overload
    def map_keys(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2, T], T3]
    ) -> "Chain[t.Dict[T3, T2]]": ...
    @t.overload
    def map_keys(
        self: "Chain[t.Mapping[t.Any, T2]]", iteratee: t.Callable[[T2], T3]
    ) -> "Chain[t.Dict[T3, T2]]": ...
    @t.overload
    def map_keys(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, int, t.List[T]], T2]
    ) -> "Chain[t.Dict[T2, T]]": ...
    @t.overload
    def map_keys(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, int], T2]
    ) -> "Chain[t.Dict[T2, T]]": ...
    @t.overload
    def map_keys(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T], T2]
    ) -> "Chain[t.Dict[T2, T]]": ...
    @t.overload
    def map_keys(
        self: "Chain[t.Iterable[t.Any]]", iteratee: t.Union[IterateeObjT, None] = None
    ) -> "Chain[t.Dict[t.Any, t.Any]]": ...
    def map_keys(self, iteratee=None):
        return self._wrap(pyd.map_keys)(iteratee)

    @t.overload
    def map_values(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2, T, t.Dict[T, T2]], T3]
    ) -> "Chain[t.Dict[T, T3]]": ...
    @t.overload
    def map_values(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2, T], T3]
    ) -> "Chain[t.Dict[T, T3]]": ...
    @t.overload
    def map_values(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2], T3]
    ) -> "Chain[t.Dict[T, T3]]": ...
    @t.overload
    def map_values(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, int, t.List[T]], T2]
    ) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def map_values(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T, int], T2]
    ) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def map_values(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T], T2]
    ) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def map_values(
        self: "Chain[t.Iterable[t.Any]]", iteratee: t.Union[IterateeObjT, None] = None
    ) -> "Chain[t.Dict[t.Any, t.Any]]": ...
    def map_values(self, iteratee=None):
        return self._wrap(pyd.map_values)(iteratee)

    def map_values_deep(
        self: "Chain[t.Iterable[t.Any]]",
        iteratee: t.Union[t.Callable[..., t.Any], None] = None,
        property_path: t.Any = UNSET,
    ) -> "Chain[t.Any]":
        return self._wrap(pyd.map_values_deep)(iteratee, property_path)

    def apply(self: "Chain[T]", func: t.Callable[[T], T2]) -> "Chain[T2]":
        return self._wrap(pyd.apply)(func)

    def apply_if(
        self: "Chain[T]", func: t.Callable[[T], T2], predicate: t.Callable[[T], bool]
    ) -> "Chain[t.Union[T, T2]]":
        return self._wrap(pyd.apply_if)(func, predicate)

    def apply_if_not_none(
        self: "Chain[t.Optional[T]]", func: t.Callable[[T], T2]
    ) -> "Chain[t.Optional[T2]]":
        return self._wrap(pyd.apply_if_not_none)(func)

    @t.overload
    def apply_catch(
        self: "Chain[T]",
        func: t.Callable[[T], T2],
        exceptions: t.Iterable[t.Type[Exception]],
        default: T3,
    ) -> "Chain[t.Union[T2, T3]]": ...
    @t.overload
    def apply_catch(
        self: "Chain[T]",
        func: t.Callable[[T], T2],
        exceptions: t.Iterable[t.Type[Exception]],
        default: Unset = UNSET,
    ) -> "Chain[t.Union[T, T2]]": ...
    def apply_catch(self, func, exceptions, default=UNSET):
        return self._wrap(pyd.apply_catch)(func, exceptions, default)

    @t.overload
    def merge(
        self: "Chain[t.Mapping[T, T2]]", *sources: t.Mapping[T3, T4]
    ) -> "Chain[t.Dict[t.Union[T, T3], t.Union[T2, T4]]]": ...
    @t.overload
    def merge(
        self: "Chain[t.Sequence[T]]", *sources: t.Sequence[T2]
    ) -> "Chain[t.List[t.Union[T, T2]]]": ...
    def merge(self, *sources):
        return self._wrap(pyd.merge)(*sources)

    def merge_with(self: "Chain[t.Any]", *sources: t.Any, **kwargs: t.Any) -> "Chain[t.Any]":
        return self._wrap(pyd.merge_with)(*sources, **kwargs)

    @t.overload
    def omit(self: "Chain[t.Mapping[T, T2]]", *properties: PathT) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def omit(
        self: "Chain[t.Union[t.Iterator[T], t.Sequence[T]]]", *properties: PathT
    ) -> "Chain[t.Dict[int, T]]": ...
    @t.overload
    def omit(self: "Chain[t.Any]", *properties: PathT) -> "Chain[t.Dict[t.Any, t.Any]]": ...
    def omit(self, *properties):
        return self._wrap(pyd.omit)(*properties)

    @t.overload
    def omit_by(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2, T], t.Any]
    ) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def omit_by(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2], t.Any]
    ) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def omit_by(self: "Chain[t.Dict[T, T2]]", iteratee: None = None) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def omit_by(
        self: "Chain[t.Union[t.Iterator[T], t.Sequence[T]]]", iteratee: t.Callable[[T, int], t.Any]
    ) -> "Chain[t.Dict[int, T]]": ...
    @t.overload
    def omit_by(
        self: "Chain[t.Union[t.Iterator[T], t.Sequence[T]]]", iteratee: t.Callable[[T], t.Any]
    ) -> "Chain[t.Dict[int, T]]": ...
    @t.overload
    def omit_by(self: "Chain[t.List[T]]", iteratee: None = None) -> "Chain[t.Dict[int, T]]": ...
    @t.overload
    def omit_by(
        self: "Chain[t.Any]", iteratee: t.Union[t.Callable[..., t.Any], None] = None
    ) -> "Chain[t.Dict[t.Any, t.Any]]": ...
    def omit_by(self, iteratee=None):
        return self._wrap(pyd.omit_by)(iteratee)

    def parse_int(
        self: "Chain[t.Any]", radix: t.Union[int, None] = None
    ) -> "Chain[t.Union[int, None]]":
        return self._wrap(pyd.parse_int)(radix)

    @t.overload
    def pick(self: "Chain[t.Mapping[T, T2]]", *properties: PathT) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def pick(
        self: "Chain[t.Union[t.Tuple[T, ...], t.List[T]]]", *properties: PathT
    ) -> "Chain[t.Dict[int, T]]": ...
    @t.overload
    def pick(self: "Chain[t.Any]", *properties: PathT) -> "Chain[t.Dict[t.Any, t.Any]]": ...
    def pick(self, *properties):
        return self._wrap(pyd.pick)(*properties)

    @t.overload
    def pick_by(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2], t.Any]
    ) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def pick_by(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T2, T], t.Any]
    ) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def pick_by(self: "Chain[t.Dict[T, T2]]", iteratee: None = None) -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def pick_by(
        self: "Chain[t.Union[t.Tuple[T, ...], t.List[T]]]", iteratee: t.Callable[[T, int], t.Any]
    ) -> "Chain[t.Dict[int, T]]": ...
    @t.overload
    def pick_by(
        self: "Chain[t.Union[t.Tuple[T, ...], t.List[T]]]", iteratee: t.Callable[[T], t.Any]
    ) -> "Chain[t.Dict[int, T]]": ...
    @t.overload
    def pick_by(
        self: "Chain[t.Union[t.Tuple[T, ...], t.List[T]]]", iteratee: None = None
    ) -> "Chain[t.Dict[int, T]]": ...
    @t.overload
    def pick_by(
        self: "Chain[t.Any]", iteratee: t.Union[t.Callable[..., t.Any], None] = None
    ) -> "Chain[t.Dict[t.Any, t.Any]]": ...
    def pick_by(self, iteratee=None):
        return self._wrap(pyd.pick_by)(iteratee)

    def rename_keys(
        self: "Chain[t.Dict[T, T2]]", key_map: t.Dict[t.Any, T3]
    ) -> "Chain[t.Dict[t.Union[T, T3], T2]]":
        return self._wrap(pyd.rename_keys)(key_map)

    def set_(self: "Chain[T]", path: PathT, value: t.Any) -> "Chain[T]":
        return self._wrap(pyd.set_)(path, value)

    set = set_

    def set_with(
        self: "Chain[T]",
        path: PathT,
        value: t.Any,
        customizer: t.Union[t.Callable[..., t.Any], None] = None,
    ) -> "Chain[T]":
        return self._wrap(pyd.set_with)(path, value, customizer)

    def to_boolean(
        self: "Chain[t.Any]",
        true_values: t.Tuple[str, ...] = ("true", "1"),
        false_values: t.Tuple[str, ...] = ("false", "0"),
    ) -> "Chain[t.Union[bool, None]]":
        return self._wrap(pyd.to_boolean)(true_values, false_values)

    @t.overload
    def to_dict(self: "Chain[t.Mapping[T, T2]]") -> "Chain[t.Dict[T, T2]]": ...
    @t.overload
    def to_dict(
        self: "Chain[t.Union[t.Iterator[T], t.Sequence[T]]]",
    ) -> "Chain[t.Dict[int, T]]": ...
    @t.overload
    def to_dict(self: "Chain[t.Any]") -> "Chain[t.Dict[t.Any, t.Any]]": ...
    def to_dict(self):
        return self._wrap(pyd.to_dict)()

    def to_integer(self: "Chain[t.Any]") -> "Chain[int]":
        return self._wrap(pyd.to_integer)()

    @t.overload
    def to_list(
        self: "Chain[t.Dict[t.Any, T]]", split_strings: bool = True
    ) -> "Chain[t.List[T]]": ...
    @t.overload
    def to_list(self: "Chain[t.Iterable[T]]", split_strings: bool = True) -> "Chain[t.List[T]]": ...
    @t.overload
    def to_list(self: "Chain[T]", split_strings: bool = True) -> "Chain[t.List[T]]": ...
    def to_list(self, split_strings=True):
        return self._wrap(pyd.to_list)(split_strings)

    def to_number(self: "Chain[t.Any]", precision: int = 0) -> "Chain[t.Union[float, None]]":
        return self._wrap(pyd.to_number)(precision)

    @t.overload
    def to_pairs(self: "Chain[t.Mapping[T, T2]]") -> "Chain[t.List[t.Tuple[T, T2]]]": ...
    @t.overload
    def to_pairs(
        self: "Chain[t.Union[t.Iterator[T], t.Sequence[T]]]",
    ) -> "Chain[t.List[t.Tuple[int, T]]]": ...
    @t.overload
    def to_pairs(self: "Chain[t.Any]") -> "Chain[t.List[t.Any]]": ...
    def to_pairs(self):
        return self._wrap(pyd.to_pairs)()

    @t.overload
    def transform(
        self: "Chain[t.Mapping[T, T2]]",
        iteratee: t.Callable[[T3, T2, T, t.Dict[T, T2]], t.Any],
        accumulator: T3,
    ) -> "Chain[T3]": ...
    @t.overload
    def transform(
        self: "Chain[t.Mapping[T, T2]]", iteratee: t.Callable[[T3, T2, T], t.Any], accumulator: T3
    ) -> "Chain[T3]": ...
    @t.overload
    def transform(
        self: "Chain[t.Mapping[t.Any, T2]]", iteratee: t.Callable[[T3, T2], t.Any], accumulator: T3
    ) -> "Chain[T3]": ...
    @t.overload
    def transform(
        self: "Chain[t.Mapping[t.Any, t.Any]]", iteratee: t.Callable[[T3], t.Any], accumulator: T3
    ) -> "Chain[T3]": ...
    @t.overload
    def transform(
        self: "Chain[t.Iterable[T]]",
        iteratee: t.Callable[[T3, T, int, t.List[T]], t.Any],
        accumulator: T3,
    ) -> "Chain[T3]": ...
    @t.overload
    def transform(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T3, T, int], t.Any], accumulator: T3
    ) -> "Chain[T3]": ...
    @t.overload
    def transform(
        self: "Chain[t.Iterable[T]]", iteratee: t.Callable[[T3, T], t.Any], accumulator: T3
    ) -> "Chain[T3]": ...
    @t.overload
    def transform(
        self: "Chain[t.Iterable[t.Any]]", iteratee: t.Callable[[T3], t.Any], accumulator: T3
    ) -> "Chain[T3]": ...
    @t.overload
    def transform(
        self: "Chain[t.Any]", iteratee: t.Any = None, accumulator: t.Any = None
    ) -> "Chain[t.Any]": ...
    def transform(self, iteratee=None, accumulator=None):
        return self._wrap(pyd.transform)(iteratee, accumulator)

    @t.overload
    def update(
        self: "Chain[t.Dict[t.Any, T2]]", path: PathT, updater: t.Callable[[T2], t.Any]
    ) -> "Chain[t.Dict[t.Any, t.Any]]": ...
    @t.overload
    def update(
        self: "Chain[t.List[T]]", path: PathT, updater: t.Callable[[T], t.Any]
    ) -> "Chain[t.List[t.Any]]": ...
    @t.overload
    def update(self: "Chain[T]", path: PathT, updater: t.Callable[..., t.Any]) -> "Chain[T]": ...
    def update(self, path, updater):
        return self._wrap(pyd.update)(path, updater)

    @t.overload
    def update_with(
        self: "Chain[t.Dict[t.Any, T2]]",
        path: PathT,
        updater: t.Callable[[T2], t.Any],
        customizer: t.Union[t.Callable[..., t.Any], None],
    ) -> "Chain[t.Dict[t.Any, t.Any]]": ...
    @t.overload
    def update_with(
        self: "Chain[t.List[T]]",
        path: PathT,
        updater: t.Callable[[T], t.Any],
        customizer: t.Union[t.Callable[..., t.Any], None] = None,
    ) -> "Chain[t.List[t.Any]]": ...
    @t.overload
    def update_with(
        self: "Chain[T]",
        path: PathT,
        updater: t.Callable[..., t.Any],
        customizer: t.Union[t.Callable[..., t.Any], None] = None,
    ) -> "Chain[T]": ...
    def update_with(self, path, updater, customizer=None):
        return self._wrap(pyd.update_with)(path, updater, customizer)

    def unset(
        self: "Chain[t.Union[t.List[t.Any], t.Dict[t.Any, t.Any]]]", path: PathT
    ) -> "Chain[bool]":
        return self._wrap(pyd.unset)(path)

    @t.overload
    def values(self: "Chain[t.Mapping[t.Any, T2]]") -> "Chain[t.List[T2]]": ...
    @t.overload
    def values(self: "Chain[t.Iterable[T]]") -> "Chain[t.List[T]]": ...
    @t.overload
    def values(self: "Chain[t.Any]") -> "Chain[t.List[t.Any]]": ...
    def values(self):
        return self._wrap(pyd.values)()

    def eq(self: "Chain[t.Any]", other: t.Any) -> "Chain[bool]":
        return self._wrap(pyd.eq)(other)

    def eq_cmp(self: "Chain[T]") -> "Chain[t.Callable[[T], bool]]":
        return self._wrap(pyd.eq_cmp)()

    def gt(self: "Chain['SupportsDunderGT[T]']", other: T) -> "Chain[bool]":
        return self._wrap(pyd.gt)(other)

    def gt_cmp(self: "Chain[T]") -> "Chain[t.Callable[['SupportsDunderGT[T]'], bool]]":
        return self._wrap(pyd.gt_cmp)()

    def gte(self: "Chain['SupportsDunderGE[T]']", other: T) -> "Chain[bool]":
        return self._wrap(pyd.gte)(other)

    def gte_cmp(self: "Chain[T]") -> "Chain[t.Callable[['SupportsDunderGE[T]'], bool]]":
        return self._wrap(pyd.gte_cmp)()

    def lt(self: "Chain['SupportsDunderLT[T]']", other: T) -> "Chain[bool]":
        return self._wrap(pyd.lt)(other)

    def lt_cmp(self: "Chain[T]") -> "Chain[t.Callable[['SupportsDunderLT[T]'], bool]]":
        return self._wrap(pyd.lt_cmp)()

    def lte(self: "Chain['SupportsDunderLE[T]']", other: T) -> "Chain[bool]":
        return self._wrap(pyd.lte)(other)

    def lte_cmp(self: "Chain[T]") -> "Chain[t.Callable[['SupportsDunderLE[T]'], bool]]":
        return self._wrap(pyd.lte_cmp)()

    def in_range(self: "Chain[t.Any]", start: t.Any = 0, end: t.Any = None) -> "Chain[bool]":
        return self._wrap(pyd.in_range)(start, end)

    def in_range_cmp(self: "Chain[t.Any]", end: t.Any = None) -> "Chain[t.Callable[[t.Any], bool]]":
        return self._wrap(pyd.in_range_cmp)(end)

    def is_associative(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_associative)()

    def is_blank(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_blank)()

    def is_boolean(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_boolean)()

    def is_builtin(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_builtin)()

    def is_date(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_date)()

    def is_decreasing(
        self: "Chain[t.Union['SupportsRichComparison', t.List['SupportsRichComparison']]]",
    ) -> "Chain[bool]":
        return self._wrap(pyd.is_decreasing)()

    def is_dict(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_dict)()

    def is_empty(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_empty)()

    def is_equal(self: "Chain[t.Any]", other: t.Any) -> "Chain[bool]":
        return self._wrap(pyd.is_equal)(other)

    def is_equal_cmp(self: "Chain[T]") -> "Chain[t.Callable[[T], bool]]":
        return self._wrap(pyd.is_equal_cmp)()

    @t.overload
    def is_equal_with(
        self: "Chain[T]", other: T2, customizer: t.Callable[[T, T2], T3]
    ) -> "Chain[T3]": ...
    @t.overload
    def is_equal_with(
        self: "Chain[t.Any]", other: t.Any, customizer: t.Callable[..., t.Any]
    ) -> "Chain[bool]": ...
    @t.overload
    def is_equal_with(self: "Chain[t.Any]", other: t.Any, customizer: None) -> "Chain[bool]": ...
    def is_equal_with(self, other, customizer):
        return self._wrap(pyd.is_equal_with)(other, customizer)

    def is_equal_with_cmp(
        self: "Chain[T]", customizer: t.Callable[[T, T], T3]
    ) -> "Chain[t.Callable[[T], T3]]":
        return self._wrap(pyd.is_equal_with_cmp)(customizer)

    def is_error(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_error)()

    def is_even(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_even)()

    def is_float(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_float)()

    def is_function(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_function)()

    def is_increasing(
        self: "Chain[t.Union['SupportsRichComparison', t.List['SupportsRichComparison']]]",
    ) -> "Chain[bool]":
        return self._wrap(pyd.is_increasing)()

    def is_indexed(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_indexed)()

    def is_instance_of(
        self: "Chain[t.Any]", types: t.Union[type, t.Tuple[type, ...]]
    ) -> "Chain[bool]":
        return self._wrap(pyd.is_instance_of)(types)

    def is_instance_of_cmp(
        self: "Chain[t.Union[type, t.Tuple[type, ...]]]",
    ) -> "Chain[t.Callable[[t.Any], bool]]":
        return self._wrap(pyd.is_instance_of_cmp)()

    def is_integer(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_integer)()

    def is_iterable(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_iterable)()

    def is_json(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_json)()

    def is_list(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_list)()

    def is_match(self: "Chain[t.Any]", source: t.Any) -> "Chain[bool]":
        return self._wrap(pyd.is_match)(source)

    def is_match_cmp(self: "Chain[t.Any]") -> "Chain[t.Callable[[t.Any], bool]]":
        return self._wrap(pyd.is_match_cmp)()

    def is_match_with(
        self: "Chain[t.Any]",
        source: t.Any,
        customizer: t.Any = None,
        _key: t.Any = UNSET,
        _obj: t.Any = UNSET,
        _source: t.Any = UNSET,
    ) -> "Chain[bool]":
        return self._wrap(pyd.is_match_with)(source, customizer, _key, _obj, _source)

    def is_match_with_cmp(
        self: "Chain[t.Any]", customizer: t.Any = None
    ) -> "Chain[t.Callable[[t.Any], bool]]":
        return self._wrap(pyd.is_match_with_cmp)(customizer)

    def is_monotone(
        self: "Chain[t.Union[T, t.List[T]]]", op: t.Callable[[T, T], t.Any]
    ) -> "Chain[bool]":
        return self._wrap(pyd.is_monotone)(op)

    def is_monotone_cmp(
        self: "Chain[t.Callable[[T, T], t.Any]]",
    ) -> "Chain[t.Callable[[t.Union[T, t.List[T]]], bool]]":
        return self._wrap(pyd.is_monotone_cmp)()

    def is_nan(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_nan)()

    def is_negative(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_negative)()

    def is_none(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_none)()

    def is_number(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_number)()

    def is_object(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_object)()

    def is_odd(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_odd)()

    def is_positive(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_positive)()

    def is_reg_exp(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_reg_exp)()

    def is_set(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_set)()

    def is_strictly_decreasing(
        self: "Chain[t.Union['SupportsRichComparison', t.List['SupportsRichComparison']]]",
    ) -> "Chain[bool]":
        return self._wrap(pyd.is_strictly_decreasing)()

    def is_strictly_increasing(
        self: "Chain[t.Union['SupportsRichComparison', t.List['SupportsRichComparison']]]",
    ) -> "Chain[bool]":
        return self._wrap(pyd.is_strictly_increasing)()

    def is_string(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_string)()

    def is_tuple(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_tuple)()

    def is_zero(self: "Chain[t.Any]") -> "Chain[bool]":
        return self._wrap(pyd.is_zero)()

    def camel_case(self: "Chain[t.Any]") -> "Chain[str]":
        return self._wrap(pyd.camel_case)()

    def capitalize(self: "Chain[t.Any]", strict: bool = True) -> "Chain[str]":
        return self._wrap(pyd.capitalize)(strict)

    def chars(self: "Chain[t.Any]") -> "Chain[t.List[str]]":
        return self._wrap(pyd.chars)()

    def chop(self: "Chain[t.Any]", step: int) -> "Chain[t.List[str]]":
        return self._wrap(pyd.chop)(step)

    def chop_right(self: "Chain[t.Any]", step: int) -> "Chain[t.List[str]]":
        return self._wrap(pyd.chop_right)(step)

    def clean(self: "Chain[t.Any]") -> "Chain[str]":
        return self._wrap(pyd.clean)()

    def count_substr(self: "Chain[t.Any]", subtext: t.Any) -> "Chain[int]":
        return self._wrap(pyd.count_substr)(subtext)

    def deburr(self: "Chain[t.Any]") -> "Chain[str]":
        return self._wrap(pyd.deburr)()

    def decapitalize(self: "Chain[t.Any]") -> "Chain[str]":
        return self._wrap(pyd.decapitalize)()

    def ends_with(
        self: "Chain[t.Any]", target: t.Any, position: t.Union[int, None] = None
    ) -> "Chain[bool]":
        return self._wrap(pyd.ends_with)(target, position)

    def ensure_ends_with(self: "Chain[t.Any]", suffix: t.Any) -> "Chain[str]":
        return self._wrap(pyd.ensure_ends_with)(suffix)

    def ensure_starts_with(self: "Chain[t.Any]", prefix: t.Any) -> "Chain[str]":
        return self._wrap(pyd.ensure_starts_with)(prefix)

    def escape(self: "Chain[t.Any]") -> "Chain[str]":
        return self._wrap(pyd.escape)()

    def escape_reg_exp(self: "Chain[t.Any]") -> "Chain[str]":
        return self._wrap(pyd.escape_reg_exp)()

    def has_substr(self: "Chain[t.Any]", subtext: t.Any) -> "Chain[bool]":
        return self._wrap(pyd.has_substr)(subtext)

    def human_case(self: "Chain[t.Any]") -> "Chain[str]":
        return self._wrap(pyd.human_case)()

    def insert_substr(self: "Chain[t.Any]", index: int, subtext: t.Any) -> "Chain[str]":
        return self._wrap(pyd.insert_substr)(index, subtext)

    def join(self: "Chain[t.Iterable[t.Any]]", separator: t.Any = "") -> "Chain[str]":
        return self._wrap(pyd.join)(separator)

    def kebab_case(self: "Chain[t.Any]") -> "Chain[str]":
        return self._wrap(pyd.kebab_case)()

    def lines(self: "Chain[t.Any]") -> "Chain[t.List[str]]":
        return self._wrap(pyd.lines)()

    def lower_case(self: "Chain[t.Any]") -> "Chain[str]":
        return self._wrap(pyd.lower_case)()

    def lower_first(self: "Chain[str]") -> "Chain[str]":
        return self._wrap(pyd.lower_first)()

    def number_format(
        self: "Chain[NumberT]",
        scale: int = 0,
        decimal_separator: str = ".",
        order_separator: str = ",",
    ) -> "Chain[str]":
        return self._wrap(pyd.number_format)(scale, decimal_separator, order_separator)

    def pad(self: "Chain[t.Any]", length: int, chars: t.Any = " ") -> "Chain[str]":
        return self._wrap(pyd.pad)(length, chars)

    def pad_end(self: "Chain[t.Any]", length: int, chars: t.Any = " ") -> "Chain[str]":
        return self._wrap(pyd.pad_end)(length, chars)

    def pad_start(self: "Chain[t.Any]", length: int, chars: t.Any = " ") -> "Chain[str]":
        return self._wrap(pyd.pad_start)(length, chars)

    def pascal_case(self: "Chain[t.Any]", strict: bool = True) -> "Chain[str]":
        return self._wrap(pyd.pascal_case)(strict)

    def predecessor(self: "Chain[t.Any]") -> "Chain[str]":
        return self._wrap(pyd.predecessor)()

    def prune(self: "Chain[t.Any]", length: int = 0, omission: str = "...") -> "Chain[str]":
        return self._wrap(pyd.prune)(length, omission)

    def quote(self: "Chain[t.Any]", quote_char: t.Any = '"') -> "Chain[str]":
        return self._wrap(pyd.quote)(quote_char)

    def reg_exp_js_match(self: "Chain[t.Any]", reg_exp: str) -> "Chain[t.List[str]]":
        return self._wrap(pyd.reg_exp_js_match)(reg_exp)

    def reg_exp_js_replace(
        self: "Chain[t.Any]", reg_exp: str, repl: t.Union[str, t.Callable[[re.Match[str]], str]]
    ) -> "Chain[str]":
        return self._wrap(pyd.reg_exp_js_replace)(reg_exp, repl)

    def reg_exp_replace(
        self: "Chain[t.Any]",
        pattern: t.Any,
        repl: t.Union[str, t.Callable[[re.Match[str]], str]],
        ignore_case: bool = False,
        count: int = 0,
    ) -> "Chain[str]":
        return self._wrap(pyd.reg_exp_replace)(pattern, repl, ignore_case, count)

    def repeat(self: "Chain[t.Any]", n: t.SupportsInt = 0) -> "Chain[str]":
        return self._wrap(pyd.repeat)(n)

    def replace(
        self: "Chain[t.Any]",
        pattern: t.Any,
        repl: t.Union[str, t.Callable[[re.Match[str]], str]],
        ignore_case: bool = False,
        count: int = 0,
        escape: bool = True,
        from_start: bool = False,
        from_end: bool = False,
    ) -> "Chain[str]":
        return self._wrap(pyd.replace)(
            pattern, repl, ignore_case, count, escape, from_start, from_end
        )

    def replace_end(
        self: "Chain[t.Any]",
        pattern: t.Any,
        repl: t.Union[str, t.Callable[[re.Match[str]], str]],
        ignore_case: bool = False,
        escape: bool = True,
    ) -> "Chain[str]":
        return self._wrap(pyd.replace_end)(pattern, repl, ignore_case, escape)

    def replace_start(
        self: "Chain[t.Any]",
        pattern: t.Any,
        repl: t.Union[str, t.Callable[[re.Match[str]], str]],
        ignore_case: bool = False,
        escape: bool = True,
    ) -> "Chain[str]":
        return self._wrap(pyd.replace_start)(pattern, repl, ignore_case, escape)

    def separator_case(self: "Chain[t.Any]", separator: str) -> "Chain[str]":
        return self._wrap(pyd.separator_case)(separator)

    def series_phrase(
        self: "Chain[t.List[t.Any]]",
        separator: t.Any = ", ",
        last_separator: t.Any = " and ",
        serial: bool = False,
    ) -> "Chain[str]":
        return self._wrap(pyd.series_phrase)(separator, last_separator, serial)

    def series_phrase_serial(
        self: "Chain[t.List[t.Any]]", separator: t.Any = ", ", last_separator: t.Any = " and "
    ) -> "Chain[str]":
        return self._wrap(pyd.series_phrase_serial)(separator, last_separator)

    def slugify(self: "Chain[t.Any]", separator: str = "-") -> "Chain[str]":
        return self._wrap(pyd.slugify)(separator)

    def snake_case(self: "Chain[t.Any]") -> "Chain[str]":
        return self._wrap(pyd.snake_case)()

    def split(
        self: "Chain[t.Any]", separator: t.Union[str, Unset, None] = UNSET
    ) -> "Chain[t.List[str]]":
        return self._wrap(pyd.split)(separator)

    def start_case(self: "Chain[t.Any]") -> "Chain[str]":
        return self._wrap(pyd.start_case)()

    def starts_with(self: "Chain[t.Any]", target: t.Any, position: int = 0) -> "Chain[bool]":
        return self._wrap(pyd.starts_with)(target, position)

    def strip_tags(self: "Chain[t.Any]") -> "Chain[str]":
        return self._wrap(pyd.strip_tags)()

    def substr_left(self: "Chain[t.Any]", subtext: str) -> "Chain[str]":
        return self._wrap(pyd.substr_left)(subtext)

    def substr_left_end(self: "Chain[t.Any]", subtext: str) -> "Chain[str]":
        return self._wrap(pyd.substr_left_end)(subtext)

    def substr_right(self: "Chain[t.Any]", subtext: str) -> "Chain[str]":
        return self._wrap(pyd.substr_right)(subtext)

    def substr_right_end(self: "Chain[t.Any]", subtext: str) -> "Chain[str]":
        return self._wrap(pyd.substr_right_end)(subtext)

    def successor(self: "Chain[t.Any]") -> "Chain[str]":
        return self._wrap(pyd.successor)()

    def surround(self: "Chain[t.Any]", wrapper: t.Any) -> "Chain[str]":
        return self._wrap(pyd.surround)(wrapper)

    def swap_case(self: "Chain[t.Any]") -> "Chain[str]":
        return self._wrap(pyd.swap_case)()

    def title_case(self: "Chain[t.Any]") -> "Chain[str]":
        return self._wrap(pyd.title_case)()

    def to_lower(self: "Chain[t.Any]") -> "Chain[str]":
        return self._wrap(pyd.to_lower)()

    def to_upper(self: "Chain[t.Any]") -> "Chain[str]":
        return self._wrap(pyd.to_upper)()

    def trim(self: "Chain[t.Any]", chars: t.Union[str, None] = None) -> "Chain[str]":
        return self._wrap(pyd.trim)(chars)

    def trim_end(self: "Chain[t.Any]", chars: t.Union[str, None] = None) -> "Chain[str]":
        return self._wrap(pyd.trim_end)(chars)

    def trim_start(self: "Chain[t.Any]", chars: t.Union[str, None] = None) -> "Chain[str]":
        return self._wrap(pyd.trim_start)(chars)

    def truncate(
        self: "Chain[t.Any]",
        length: int = 30,
        omission: str = "...",
        separator: t.Union[str, re.Pattern[str], None] = None,
    ) -> "Chain[str]":
        return self._wrap(pyd.truncate)(length, omission, separator)

    def unescape(self: "Chain[t.Any]") -> "Chain[str]":
        return self._wrap(pyd.unescape)()

    def upper_case(self: "Chain[t.Any]") -> "Chain[str]":
        return self._wrap(pyd.upper_case)()

    def upper_first(self: "Chain[str]") -> "Chain[str]":
        return self._wrap(pyd.upper_first)()

    def unquote(self: "Chain[t.Any]", quote_char: t.Any = '"') -> "Chain[str]":
        return self._wrap(pyd.unquote)(quote_char)

    def url(self: "Chain[t.Any]", *paths: t.Any, **params: t.Any) -> "Chain[str]":
        return self._wrap(pyd.url)(*paths, **params)

    def words(self: "Chain[t.Any]", pattern: t.Union[str, None] = None) -> "Chain[t.List[str]]":
        return self._wrap(pyd.words)(pattern)

    def attempt(
        self: "Chain[t.Callable[P, T]]", *args: "P.args", **kwargs: "P.kwargs"
    ) -> "Chain[t.Union[T, Exception]]":
        return self._wrap(pyd.attempt)(*args, **kwargs)

    @t.overload
    def cond(
        self: "Chain[t.List[t.Tuple[t.Callable[P, t.Any], t.Callable[P, T]]]]",
        *extra_pairs: t.Tuple[t.Callable[P, t.Any], t.Callable[P, T]],
    ) -> "Chain[t.Callable[P, T]]": ...
    @t.overload
    def cond(
        self: "Chain[t.List[t.List[t.Callable[P, t.Any]]]]",
        *extra_pairs: t.List[t.Callable[P, t.Any]],
    ) -> "Chain[t.Callable[P, t.Any]]": ...
    def cond(self, *extra_pairs):
        return self._wrap(pyd.cond)(*extra_pairs)

    @t.overload
    def conforms(
        self: "Chain[t.Dict[T, t.Callable[[T2], t.Any]]]",
    ) -> "Chain[t.Callable[[t.Dict[T, T2]], bool]]": ...
    @t.overload
    def conforms(
        self: "Chain[t.List[t.Callable[[T], t.Any]]]",
    ) -> "Chain[t.Callable[[t.List[T]], bool]]": ...
    def conforms(
        self: "Chain[t.Union[t.List[t.Any], t.Dict[t.Any, t.Any]]]",
    ) -> "Chain[t.Callable[..., t.Any]]":
        return self._wrap(pyd.conforms)()

    @t.overload
    def conforms_to(
        self: "Chain[t.Dict[T, T2]]", source: t.Dict[T, t.Callable[[T2], t.Any]]
    ) -> "Chain[bool]": ...
    @t.overload
    def conforms_to(
        self: "Chain[t.List[T]]", source: t.List[t.Callable[[T], t.Any]]
    ) -> "Chain[bool]": ...
    def conforms_to(self, source):
        return self._wrap(pyd.conforms_to)(source)

    def constant(self: "Chain[T]") -> "Chain[t.Callable[..., T]]":
        return self._wrap(pyd.constant)()

    def default_to(self: "Chain[t.Union[T, None]]", default_value: T2) -> "Chain[t.Union[T, T2]]":
        return self._wrap(pyd.default_to)(default_value)

    @t.overload
    def default_to_any(self: "Chain[None]", *default_values: None) -> "Chain[None]": ...
    @t.overload
    def default_to_any(
        self: "Chain[t.Union[T, None]]", default_value1: None, default_value2: T2
    ) -> "Chain[t.Union[T, T2]]": ...
    @t.overload
    def default_to_any(
        self: "Chain[t.Union[T, None]]",
        default_value1: None,
        default_value2: None,
        default_value3: T2,
    ) -> "Chain[t.Union[T, T2]]": ...
    @t.overload
    def default_to_any(
        self: "Chain[t.Union[T, None]]",
        default_value1: None,
        default_value2: None,
        default_value3: None,
        default_value4: T2,
    ) -> "Chain[t.Union[T, T2]]": ...
    @t.overload
    def default_to_any(
        self: "Chain[t.Union[T, None]]",
        default_value1: None,
        default_value2: None,
        default_value3: None,
        default_value4: None,
        default_value5: T2,
    ) -> "Chain[t.Union[T, T2]]": ...
    @t.overload
    def default_to_any(
        self: "Chain[t.Union[T, None]]", *default_values: T2
    ) -> "Chain[t.Union[T, T2]]": ...
    def default_to_any(self, *default_values):
        return self._wrap(pyd.default_to_any)(*default_values)

    @t.overload
    def identity(self: "Chain[T]", *args: t.Any) -> "Chain[T]": ...
    @t.overload
    def iteratee(self: "Chain[t.Callable[P, T]]") -> "Chain[t.Callable[P, T]]": ...
    @t.overload
    def iteratee(self: "Chain[t.Any]") -> "Chain[t.Callable[..., t.Any]]": ...
    def iteratee(self):
        return self._wrap(pyd.iteratee)()

    def matches(self: "Chain[t.Any]") -> "Chain[t.Callable[[t.Any], bool]]":
        return self._wrap(pyd.matches)()

    def matches_property(self: "Chain[t.Any]", value: t.Any) -> "Chain[t.Callable[[t.Any], bool]]":
        return self._wrap(pyd.matches_property)(value)

    @t.overload
    def memoize(
        self: "Chain[t.Callable[P, T]]", resolver: None = None
    ) -> "Chain[MemoizedFunc[P, T, str]]": ...
    @t.overload
    def memoize(
        self: "Chain[t.Callable[P, T]]", resolver: t.Union[t.Callable[P, T2], None] = None
    ) -> "Chain[MemoizedFunc[P, T, T2]]": ...
    def memoize(self, resolver=None):
        return self._wrap(pyd.memoize)(resolver)

    def method(
        self: "Chain[PathT]", *args: t.Any, **kwargs: t.Any
    ) -> "Chain[t.Callable[..., t.Any]]":
        return self._wrap(pyd.method)(*args, **kwargs)

    def method_of(
        self: "Chain[t.Any]", *args: t.Any, **kwargs: t.Any
    ) -> "Chain[t.Callable[..., t.Any]]":
        return self._wrap(pyd.method_of)(*args, **kwargs)

    def noop(self: "Chain[t.Any]", *args: t.Any, **kwargs: t.Any) -> "Chain[None]":
        return self._wrap(pyd.noop)(*args, **kwargs)

    def over(self: "Chain[t.Iterable[t.Callable[P, T]]]") -> "Chain[t.Callable[P, t.List[T]]]":
        return self._wrap(pyd.over)()

    def over_every(self: "Chain[t.Iterable[t.Callable[P, t.Any]]]") -> "Chain[t.Callable[P, bool]]":
        return self._wrap(pyd.over_every)()

    def over_some(self: "Chain[t.Iterable[t.Callable[P, t.Any]]]") -> "Chain[t.Callable[P, bool]]":
        return self._wrap(pyd.over_some)()

    def property_(self: "Chain[PathT]") -> "Chain[t.Callable[[t.Any], t.Any]]":
        return self._wrap(pyd.property_)()

    property = property_

    def properties(self: "Chain[t.Any]", *paths: t.Any) -> "Chain[t.Callable[[t.Any], t.Any]]":
        return self._wrap(pyd.properties)(*paths)

    def property_of(self: "Chain[t.Any]") -> "Chain[t.Callable[[PathT], t.Any]]":
        return self._wrap(pyd.property_of)()

    @t.overload
    def random(
        self: "Chain[int]", stop: int = 1, *, floating: Literal[False] = False
    ) -> "Chain[int]": ...
    @t.overload
    def random(self: "Chain[float]", stop: int = 1, floating: bool = False) -> "Chain[float]": ...
    @t.overload
    def random(self: "Chain[float]", stop: float, floating: bool = False) -> "Chain[float]": ...
    @t.overload
    def random(
        self: "Chain[t.Union[float, int]]",
        stop: t.Union[float, int] = 1,
        *,
        floating: Literal[True],
    ) -> "Chain[float]": ...
    def random(
        self: "Chain[t.Union[float, int]]", stop: t.Union[float, int] = 1, floating: bool = False
    ):
        return self._wrap(pyd.random)(stop, floating)

    @t.overload
    def range_(self: "Chain[int]") -> "Chain[t.Generator[int, None, None]]": ...
    @t.overload
    def range_(
        self: "Chain[int]", stop: int, step: int = 1
    ) -> "Chain[t.Generator[int, None, None]]": ...
    def range_(self, *args):
        return self._wrap(pyd.range_)(*args)

    range = range_

    @t.overload
    def range_right(self: "Chain[int]") -> "Chain[t.Generator[int, None, None]]": ...
    @t.overload
    def range_right(
        self: "Chain[int]", stop: int, step: int = 1
    ) -> "Chain[t.Generator[int, None, None]]": ...
    def range_right(self, *args):
        return self._wrap(pyd.range_right)(*args)

    @t.overload
    def result(self: "Chain[None]", key: t.Any, default: None = None) -> "Chain[None]": ...
    @t.overload
    def result(self: "Chain[None]", key: t.Any, default: T) -> "Chain[T]": ...
    @t.overload
    def result(self: "Chain[t.Any]", key: t.Any, default: t.Any = None) -> "Chain[t.Any]": ...
    def result(self, key, default=None):
        return self._wrap(pyd.result)(key, default)

    def retry(
        self: "Chain[int]",
        delay: t.Union[int, float] = 0.5,
        max_delay: t.Union[int, float] = 150.0,
        scale: t.Union[int, float] = 2.0,
        jitter: t.Union[int, float, t.Tuple[t.Union[int, float], t.Union[int, float]]] = 0,
        exceptions: t.Iterable[Type[Exception]] = (Exception,),
        on_exception: t.Union[t.Callable[[Exception, int], t.Any], None] = None,
    ) -> "Chain[t.Callable[[CallableT], CallableT]]":
        return self._wrap(pyd.retry)(delay, max_delay, scale, jitter, exceptions, on_exception)

    @t.overload
    def times(self: "Chain[int]", iteratee: t.Callable[..., T]) -> "Chain[t.List[T]]": ...
    @t.overload
    def times(self: "Chain[int]", iteratee: None = None) -> "Chain[t.List[int]]": ...
    def times(self: "Chain[int]", iteratee=None):
        return self._wrap(pyd.times)(iteratee)

    def to_path(self: "Chain[PathT]") -> "Chain[t.List[t.Hashable]]":
        return self._wrap(pyd.to_path)()