__all__ = [ "IntPointer", "MatLike", "MatShape", "Size", "Size2f", "Scalar", "Point", "Point2i", "Point2f", "Point2d", "Point3i", "Point3f", "Point3d", "Range", "Rect", "Rect2i", "Rect2d", "Moments", "RotatedRect", "TermCriteria", "Vec2i", "Vec2f", "Vec2d", "Vec3i", "Vec3f", "Vec3d", "Vec4i", "Vec4f", "Vec4d", "Vec6f", "FeatureDetector", "DescriptorExtractor", "FeatureExtractor", "GProtoArg", "GProtoInputArgs", "GProtoOutputArgs", "GRunArg", "GOptRunArg", "GMetaArg", "Prim", "Matx33f", "Matx33d", "Matx44f", "Matx44d", "GTypeInfo", "ExtractArgsCallback", "ExtractMetaCallback", "LayerId", "IndexParams", "SearchParams", "map_string_and_string", "map_string_and_int", "map_string_and_vector_size_t", "map_string_and_vector_float", "map_int_and_double", ] import cv2 import cv2.dnn import cv2.gapi.wip.draw import cv2.mat_wrapper import numpy import sys import typing if numpy.lib.NumpyVersion(numpy.__version__) > "1.20.0" and sys.version_info >= (3, 9): NumPyArrayGeneric = numpy.ndarray[typing.Any, numpy.dtype[numpy.generic]] else: NumPyArrayGeneric = numpy.ndarray if numpy.lib.NumpyVersion(numpy.__version__) > "1.20.0" and sys.version_info >= (3, 9): NumPyArrayFloat32 = numpy.ndarray[typing.Any, numpy.dtype[numpy.float32]] else: NumPyArrayFloat32 = numpy.ndarray if numpy.lib.NumpyVersion(numpy.__version__) > "1.20.0" and sys.version_info >= (3, 9): NumPyArrayFloat64 = numpy.ndarray[typing.Any, numpy.dtype[numpy.float64]] else: NumPyArrayFloat64 = numpy.ndarray if typing.TYPE_CHECKING: TermCriteria_Type = cv2.TermCriteria_Type else: TermCriteria_Type = int IntPointer = int """Represents an arbitrary pointer""" MatLike = typing.Union[cv2.mat_wrapper.Mat, NumPyArrayGeneric] MatShape = typing.Sequence[int] Size = typing.Sequence[int] """Required length is 2""" Size2f = typing.Sequence[float] """Required length is 2""" Scalar = typing.Sequence[float] """Required length is at most 4""" Point = typing.Sequence[int] """Required length is 2""" Point2i = Point Point2f = typing.Sequence[float] """Required length is 2""" Point2d = typing.Sequence[float] """Required length is 2""" Point3i = typing.Sequence[int] """Required length is 3""" Point3f = typing.Sequence[float] """Required length is 3""" Point3d = typing.Sequence[float] """Required length is 3""" Range = typing.Sequence[int] """Required length is 2""" Rect = typing.Sequence[int] """Required length is 4""" Rect2i = typing.Sequence[int] """Required length is 4""" Rect2d = typing.Sequence[float] """Required length is 4""" Moments = typing.Dict[str, float] RotatedRect = typing.Tuple[Point2f, Size, float] """Any type providing sequence protocol is supported""" TermCriteria = typing.Tuple[TermCriteria_Type, int, float] """Any type providing sequence protocol is supported""" Vec2i = typing.Sequence[int] """Required length is 2""" Vec2f = typing.Sequence[float] """Required length is 2""" Vec2d = typing.Sequence[float] """Required length is 2""" Vec3i = typing.Sequence[int] """Required length is 3""" Vec3f = typing.Sequence[float] """Required length is 3""" Vec3d = typing.Sequence[float] """Required length is 3""" Vec4i = typing.Sequence[int] """Required length is 4""" Vec4f = typing.Sequence[float] """Required length is 4""" Vec4d = typing.Sequence[float] """Required length is 4""" Vec6f = typing.Sequence[float] """Required length is 6""" FeatureDetector = cv2.Feature2D DescriptorExtractor = cv2.Feature2D FeatureExtractor = cv2.Feature2D GProtoArg = typing.Union[Scalar, cv2.GMat, cv2.GOpaqueT, cv2.GArrayT] GProtoInputArgs = typing.Sequence[GProtoArg] GProtoOutputArgs = typing.Sequence[GProtoArg] GRunArg = typing.Union[MatLike, Scalar, cv2.GOpaqueT, cv2.GArrayT, typing.Sequence[typing.Any], None] GOptRunArg = typing.Optional[GRunArg] GMetaArg = typing.Union[cv2.GMat, Scalar, cv2.GOpaqueT, cv2.GArrayT] Prim = typing.Union[cv2.gapi.wip.draw.Text, cv2.gapi.wip.draw.Circle, cv2.gapi.wip.draw.Image, cv2.gapi.wip.draw.Line, cv2.gapi.wip.draw.Rect, cv2.gapi.wip.draw.Mosaic, cv2.gapi.wip.draw.Poly] Matx33f = NumPyArrayFloat32 """NDArray(shape=(3, 3), dtype=numpy.float32)""" Matx33d = NumPyArrayFloat64 """NDArray(shape=(3, 3), dtype=numpy.float64)""" Matx44f = NumPyArrayFloat32 """NDArray(shape=(4, 4), dtype=numpy.float32)""" Matx44d = NumPyArrayFloat64 """NDArray(shape=(4, 4), dtype=numpy.float64)""" GTypeInfo = typing.Union[cv2.GMat, Scalar, cv2.GOpaqueT, cv2.GArrayT] ExtractArgsCallback = typing.Callable[[typing.Sequence[GTypeInfo]], typing.Sequence[GRunArg]] ExtractMetaCallback = typing.Callable[[typing.Sequence[GTypeInfo]], typing.Sequence[GMetaArg]] LayerId = cv2.dnn.DictValue IndexParams = typing.Dict[str, typing.Union[bool, int, float, str]] SearchParams = typing.Dict[str, typing.Union[bool, int, float, str]] map_string_and_string = typing.Dict[str, str] map_string_and_int = typing.Dict[str, int] map_string_and_vector_size_t = typing.Dict[str, typing.Sequence[int]] map_string_and_vector_float = typing.Dict[str, typing.Sequence[float]] map_int_and_double = typing.Dict[int, float]