pub mod imgproc {
	//! # Image Processing
	//! 
	//! This module includes image-processing functions.
	//!    # Image Filtering
	//! 
	//! Functions and classes described in this section are used to perform various linear or non-linear
	//! filtering operations on 2D images (represented as Mat's). It means that for each pixel location
	//!  in the source image (normally, rectangular), its neighborhood is considered and used to
	//! compute the response. In case of a linear filter, it is a weighted sum of pixel values. In case of
	//! morphological operations, it is the minimum or maximum values, and so on. The computed response is
	//! stored in the destination image at the same location . It means that the output image
	//! will be of the same size as the input image. Normally, the functions support multi-channel arrays,
	//! in which case every channel is processed independently. Therefore, the output image will also have
	//! the same number of channels as the input one.
	//! 
	//! Another common feature of the functions and classes described in this section is that, unlike
	//! simple arithmetic functions, they need to extrapolate values of some non-existing pixels. For
	//! example, if you want to smooth an image using a Gaussian  filter, then, when
	//! processing the left-most pixels in each row, you need pixels to the left of them, that is, outside
	//! of the image. You can let these pixels be the same as the left-most image pixels ("replicated
	//! border" extrapolation method), or assume that all the non-existing pixels are zeros ("constant
	//! border" extrapolation method), and so on. OpenCV enables you to specify the extrapolation method.
	//! For details, see [border_types]
	//! 
	//! @anchor filter_depths
	//! ### Depth combinations
	//! Input depth (src.depth()) | Output depth (ddepth)
	//! --------------------------|----------------------
	//! CV_8U                     | -1/CV_16S/CV_32F/CV_64F
	//! CV_16U/CV_16S             | -1/CV_32F/CV_64F
	//! CV_32F                    | -1/CV_32F
	//! CV_64F                    | -1/CV_64F
	//! 
	//! 
	//! Note: when ddepth=-1, the output image will have the same depth as the source.
	//! 
	//! 
	//! Note: if you need double floating-point accuracy and using single floating-point input data
	//! (CV_32F input and CV_64F output depth combination), you can use [Mat].convertTo to convert
	//! the input data to the desired precision.
	//! 
	//!    # Geometric Image Transformations
	//! 
	//! The functions in this section perform various geometrical transformations of 2D images. They do not
	//! change the image content but deform the pixel grid and map this deformed grid to the destination
	//! image. In fact, to avoid sampling artifacts, the mapping is done in the reverse order, from
	//! destination to the source. That is, for each pixel  of the destination image, the
	//! functions compute coordinates of the corresponding "donor" pixel in the source image and copy the
	//! pixel value:
	//! 
	//! 
	//! 
	//! In case when you specify the forward mapping , the OpenCV functions first compute the corresponding inverse mapping
	//!  and then use the above formula.
	//! 
	//! The actual implementations of the geometrical transformations, from the most generic remap and to
	//! the simplest and the fastest resize, need to solve two main problems with the above formula:
	//! 
	//! - Extrapolation of non-existing pixels. Similarly to the filtering functions described in the
	//! previous section, for some , either one of , or , or both
	//! of them may fall outside of the image. In this case, an extrapolation method needs to be used.
	//! OpenCV provides the same selection of extrapolation methods as in the filtering functions. In
	//! addition, it provides the method #BORDER_TRANSPARENT. This means that the corresponding pixels in
	//! the destination image will not be modified at all.
	//! 
	//! - Interpolation of pixel values. Usually  and  are floating-point
	//! numbers. This means that  can be either an affine or perspective
	//! transformation, or radial lens distortion correction, and so on. So, a pixel value at fractional
	//! coordinates needs to be retrieved. In the simplest case, the coordinates can be just rounded to the
	//! nearest integer coordinates and the corresponding pixel can be used. This is called a
	//! nearest-neighbor interpolation. However, a better result can be achieved by using more
	//! sophisticated [interpolation methods](http://en.wikipedia.org/wiki/Multivariate_interpolation) ,
	//! where a polynomial function is fit into some neighborhood of the computed pixel , and then the value of the polynomial at  is taken as the
	//! interpolated pixel value. In OpenCV, you can choose between several interpolation methods. See
	//! [resize] for details.
	//! 
	//! 
	//! Note: The geometrical transformations do not work with `CV_8S` or `CV_32S` images.
	//! 
	//!    # Miscellaneous Image Transformations
	//!    # Drawing Functions
	//! 
	//! Drawing functions work with matrices/images of arbitrary depth. The boundaries of the shapes can be
	//! rendered with antialiasing (implemented only for 8-bit images for now). All the functions include
	//! the parameter color that uses an RGB value (that may be constructed with the Scalar constructor )
	//! for color images and brightness for grayscale images. For color images, the channel ordering is
	//! normally *Blue, Green, Red*. This is what imshow, imread, and imwrite expect. So, if you form a
	//! color using the Scalar constructor, it should look like:
	//! 
	//! 
	//! 
	//! If you are using your own image rendering and I/O functions, you can use any channel ordering. The
	//! drawing functions process each channel independently and do not depend on the channel order or even
	//! on the used color space. The whole image can be converted from BGR to RGB or to a different color
	//! space using cvtColor .
	//! 
	//! If a drawn figure is partially or completely outside the image, the drawing functions clip it. Also,
	//! many drawing functions can handle pixel coordinates specified with sub-pixel accuracy. This means
	//! that the coordinates can be passed as fixed-point numbers encoded as integers. The number of
	//! fractional bits is specified by the shift parameter and the real point coordinates are calculated as
	//!  . This feature is
	//! especially effective when rendering antialiased shapes.
	//! 
	//! 
	//! Note: The functions do not support alpha-transparency when the target image is 4-channel. In this
	//! case, the color[3] is simply copied to the repainted pixels. Thus, if you want to paint
	//! semi-transparent shapes, you can paint them in a separate buffer and then blend it with the main
	//! image.
	//! 
	//!    # Color Space Conversions
	//!    # ColorMaps in OpenCV
	//! 
	//! The human perception isn't built for observing fine changes in grayscale images. Human eyes are more
	//! sensitive to observing changes between colors, so you often need to recolor your grayscale images to
	//! get a clue about them. OpenCV now comes with various colormaps to enhance the visualization in your
	//! computer vision application.
	//! 
	//! In OpenCV you only need applyColorMap to apply a colormap on a given image. The following sample
	//! code reads the path to an image from command line, applies a Jet colormap on it and shows the
	//! result:
	//! 
	//! @include snippets/imgproc_applyColorMap.cpp
	//! ## See also
	//! [colormap_types]
	//! 
	//!    # Planar Subdivision
	//! 
	//! The Subdiv2D class described in this section is used to perform various planar subdivision on
	//! a set of 2D points (represented as vector of Point2f). OpenCV subdivides a plane into triangles
	//! using the Delaunay's algorithm, which corresponds to the dual graph of the Voronoi diagram.
	//! In the figure below, the Delaunay's triangulation is marked with black lines and the Voronoi
	//! diagram with red lines.
	//! 
	//! 
	//! 
	//! The subdivisions can be used for the 3D piece-wise transformation of a plane, morphing, fast
	//! location of points on the plane, building special graphs (such as NNG,RNG), and so forth.
	//! 
	//!    # Histograms
	//!    # Structural Analysis and Shape Descriptors
	//!    # Motion Analysis and Object Tracking
	//!    # Feature Detection
	//!    # Object Detection
	//!    # Image Segmentation
	//!    # C API
	//!    # Hardware Acceleration Layer
	//!        # Functions
	//!        # Interface
	use crate::{mod_prelude::*, core, sys, types};
	pub mod prelude {
		pub use { super::GeneralizedHoughTraitConst, super::GeneralizedHoughTrait, super::GeneralizedHoughBallardTraitConst, super::GeneralizedHoughBallardTrait, super::GeneralizedHoughGuilTraitConst, super::GeneralizedHoughGuilTrait, super::CLAHETraitConst, super::CLAHETrait, super::Subdiv2DTraitConst, super::Subdiv2DTrait, super::LineSegmentDetectorTraitConst, super::LineSegmentDetectorTrait, super::LineIteratorTraitConst, super::LineIteratorTrait, super::IntelligentScissorsMBTraitConst, super::IntelligentScissorsMBTrait };
	}
	
	/// the threshold value  is a weighted sum (cross-correlation with a Gaussian
	/// window) of the  neighborhood of 
	/// minus C . The default sigma (standard deviation) is used for the specified blockSize . See
	/// #getGaussianKernel
	pub const ADAPTIVE_THRESH_GAUSSIAN_C: i32 = 1;
	/// the threshold value  is a mean of the  neighborhood of  minus C
	pub const ADAPTIVE_THRESH_MEAN_C: i32 = 0;
	/// Same as CCL_GRANA. It is preferable to use the flag with the name of the algorithm (CCL_BBDT) rather than the one with the name of the first author (CCL_GRANA).
	pub const CCL_BBDT: i32 = 4;
	/// Spaghetti [Bolelli2019](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Bolelli2019) algorithm for 8-way connectivity, Spaghetti4C [Bolelli2021](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Bolelli2021) algorithm for 4-way connectivity. The parallel implementation described in [Bolelli2017](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Bolelli2017) is available for both Spaghetti and Spaghetti4C.
	pub const CCL_BOLELLI: i32 = 2;
	/// Spaghetti [Bolelli2019](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Bolelli2019) algorithm for 8-way connectivity, Spaghetti4C [Bolelli2021](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Bolelli2021) algorithm for 4-way connectivity.
	pub const CCL_DEFAULT: i32 = -1;
	/// BBDT [Grana2010](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Grana2010) algorithm for 8-way connectivity, SAUF algorithm for 4-way connectivity. The parallel implementation described in [Bolelli2017](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Bolelli2017) is available for both BBDT and SAUF.
	pub const CCL_GRANA: i32 = 1;
	/// Same as CCL_WU. It is preferable to use the flag with the name of the algorithm (CCL_SAUF) rather than the one with the name of the first author (CCL_WU).
	pub const CCL_SAUF: i32 = 3;
	/// Same as CCL_BOLELLI. It is preferable to use the flag with the name of the algorithm (CCL_SPAGHETTI) rather than the one with the name of the first author (CCL_BOLELLI).
	pub const CCL_SPAGHETTI: i32 = 5;
	/// SAUF [Wu2009](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Wu2009) algorithm for 8-way connectivity, SAUF algorithm for 4-way connectivity. The parallel implementation described in [Bolelli2017](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Bolelli2017) is available for SAUF.
	pub const CCL_WU: i32 = 0;
	/// The total area (in pixels) of the connected component
	pub const CC_STAT_AREA: i32 = 4;
	/// The vertical size of the bounding box
	pub const CC_STAT_HEIGHT: i32 = 3;
	/// The leftmost (x) coordinate which is the inclusive start of the bounding
	/// box in the horizontal direction.
	pub const CC_STAT_LEFT: i32 = 0;
	/// Max enumeration value. Used internally only for memory allocation
	pub const CC_STAT_MAX: i32 = 5;
	/// The topmost (y) coordinate which is the inclusive start of the bounding
	/// box in the vertical direction.
	pub const CC_STAT_TOP: i32 = 1;
	/// The horizontal size of the bounding box
	pub const CC_STAT_WIDTH: i32 = 2;
	/// stores absolutely all the contour points. That is, any 2 subsequent points (x1,y1) and
	/// (x2,y2) of the contour will be either horizontal, vertical or diagonal neighbors, that is,
	/// max(abs(x1-x2),abs(y2-y1))==1.
	pub const CHAIN_APPROX_NONE: i32 = 1;
	/// compresses horizontal, vertical, and diagonal segments and leaves only their end points.
	/// For example, an up-right rectangular contour is encoded with 4 points.
	pub const CHAIN_APPROX_SIMPLE: i32 = 2;
	/// applies one of the flavors of the Teh-Chin chain approximation algorithm [TehChin89](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_TehChin89)
	pub const CHAIN_APPROX_TC89_KCOS: i32 = 4;
	/// applies one of the flavors of the Teh-Chin chain approximation algorithm [TehChin89](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_TehChin89)
	pub const CHAIN_APPROX_TC89_L1: i32 = 3;
	/// 
	pub const COLORMAP_AUTUMN: i32 = 0;
	/// 
	pub const COLORMAP_BONE: i32 = 1;
	/// 
	pub const COLORMAP_CIVIDIS: i32 = 17;
	/// 
	pub const COLORMAP_COOL: i32 = 8;
	/// 
	pub const COLORMAP_DEEPGREEN: i32 = 21;
	/// 
	pub const COLORMAP_HOT: i32 = 11;
	/// 
	pub const COLORMAP_HSV: i32 = 9;
	/// 
	pub const COLORMAP_INFERNO: i32 = 14;
	/// 
	pub const COLORMAP_JET: i32 = 2;
	/// 
	pub const COLORMAP_MAGMA: i32 = 13;
	/// 
	pub const COLORMAP_OCEAN: i32 = 5;
	/// 
	pub const COLORMAP_PARULA: i32 = 12;
	/// 
	pub const COLORMAP_PINK: i32 = 10;
	/// 
	pub const COLORMAP_PLASMA: i32 = 15;
	/// 
	pub const COLORMAP_RAINBOW: i32 = 4;
	/// 
	pub const COLORMAP_SPRING: i32 = 7;
	/// 
	pub const COLORMAP_SUMMER: i32 = 6;
	/// 
	pub const COLORMAP_TURBO: i32 = 20;
	/// 
	pub const COLORMAP_TWILIGHT: i32 = 18;
	/// 
	pub const COLORMAP_TWILIGHT_SHIFTED: i32 = 19;
	/// 
	pub const COLORMAP_VIRIDIS: i32 = 16;
	/// 
	pub const COLORMAP_WINTER: i32 = 3;
	/// convert between RGB/BGR and BGR555 (16-bit images)
	pub const COLOR_BGR2BGR555: i32 = 22;
	/// convert between RGB/BGR and BGR565 (16-bit images)
	pub const COLOR_BGR2BGR565: i32 = 12;
	/// add alpha channel to RGB or BGR image
	pub const COLOR_BGR2BGRA: i32 = 0;
	/// convert between RGB/BGR and grayscale, [color_convert_rgb_gray] "color conversions"
	pub const COLOR_BGR2GRAY: i32 = 6;
	/// convert RGB/BGR to HLS (hue lightness saturation) with H range 0..180 if 8 bit image, [color_convert_rgb_hls] "color conversions"
	pub const COLOR_BGR2HLS: i32 = 52;
	/// convert RGB/BGR to HLS (hue lightness saturation) with H range 0..255 if 8 bit image, [color_convert_rgb_hls] "color conversions"
	pub const COLOR_BGR2HLS_FULL: i32 = 68;
	/// convert RGB/BGR to HSV (hue saturation value) with H range 0..180 if 8 bit image, [color_convert_rgb_hsv] "color conversions"
	pub const COLOR_BGR2HSV: i32 = 40;
	/// convert RGB/BGR to HSV (hue saturation value) with H range 0..255 if 8 bit image, [color_convert_rgb_hsv] "color conversions"
	pub const COLOR_BGR2HSV_FULL: i32 = 66;
	/// convert RGB/BGR to CIE Lab, [color_convert_rgb_lab] "color conversions"
	pub const COLOR_BGR2Lab: i32 = 44;
	/// convert RGB/BGR to CIE Luv, [color_convert_rgb_luv] "color conversions"
	pub const COLOR_BGR2Luv: i32 = 50;
	pub const COLOR_BGR2RGB: i32 = 4;
	/// convert between RGB and BGR color spaces (with or without alpha channel)
	pub const COLOR_BGR2RGBA: i32 = 2;
	/// convert RGB/BGR to CIE XYZ, [color_convert_rgb_xyz] "color conversions"
	pub const COLOR_BGR2XYZ: i32 = 32;
	/// convert RGB/BGR to luma-chroma (aka YCC), [color_convert_rgb_ycrcb] "color conversions"
	pub const COLOR_BGR2YCrCb: i32 = 36;
	/// convert between RGB/BGR and YUV
	pub const COLOR_BGR2YUV: i32 = 82;
	/// RGB to YUV 4:2:0 family
	pub const COLOR_BGR2YUV_I420: i32 = 128;
	/// RGB to YUV 4:2:0 family
	pub const COLOR_BGR2YUV_IYUV: i32 = 128;
	/// RGB to YUV 4:2:0 family
	pub const COLOR_BGR2YUV_YV12: i32 = 132;
	pub const COLOR_BGR5552BGR: i32 = 24;
	pub const COLOR_BGR5552BGRA: i32 = 28;
	pub const COLOR_BGR5552GRAY: i32 = 31;
	pub const COLOR_BGR5552RGB: i32 = 25;
	pub const COLOR_BGR5552RGBA: i32 = 29;
	pub const COLOR_BGR5652BGR: i32 = 14;
	pub const COLOR_BGR5652BGRA: i32 = 18;
	pub const COLOR_BGR5652GRAY: i32 = 21;
	pub const COLOR_BGR5652RGB: i32 = 15;
	pub const COLOR_BGR5652RGBA: i32 = 19;
	/// remove alpha channel from RGB or BGR image
	pub const COLOR_BGRA2BGR: i32 = 1;
	pub const COLOR_BGRA2BGR555: i32 = 26;
	pub const COLOR_BGRA2BGR565: i32 = 16;
	pub const COLOR_BGRA2GRAY: i32 = 10;
	pub const COLOR_BGRA2RGB: i32 = 3;
	pub const COLOR_BGRA2RGBA: i32 = 5;
	/// RGB to YUV 4:2:0 family
	pub const COLOR_BGRA2YUV_I420: i32 = 130;
	/// RGB to YUV 4:2:0 family
	pub const COLOR_BGRA2YUV_IYUV: i32 = 130;
	/// RGB to YUV 4:2:0 family
	pub const COLOR_BGRA2YUV_YV12: i32 = 134;
	/// equivalent to RGGB Bayer pattern
	pub const COLOR_BayerBG2BGR: i32 = 46;
	/// equivalent to RGGB Bayer pattern
	pub const COLOR_BayerBG2BGRA: i32 = 139;
	/// equivalent to RGGB Bayer pattern
	pub const COLOR_BayerBG2BGR_EA: i32 = 135;
	/// equivalent to RGGB Bayer pattern
	pub const COLOR_BayerBG2BGR_VNG: i32 = 62;
	/// equivalent to RGGB Bayer pattern
	pub const COLOR_BayerBG2GRAY: i32 = 86;
	/// equivalent to RGGB Bayer pattern
	pub const COLOR_BayerBG2RGB: i32 = 48;
	/// equivalent to RGGB Bayer pattern
	pub const COLOR_BayerBG2RGBA: i32 = 141;
	/// equivalent to RGGB Bayer pattern
	pub const COLOR_BayerBG2RGB_EA: i32 = 137;
	/// equivalent to RGGB Bayer pattern
	pub const COLOR_BayerBG2RGB_VNG: i32 = 64;
	pub const COLOR_BayerBGGR2BGR: i32 = 48;
	pub const COLOR_BayerBGGR2BGRA: i32 = 141;
	pub const COLOR_BayerBGGR2BGR_EA: i32 = 137;
	pub const COLOR_BayerBGGR2BGR_VNG: i32 = 64;
	pub const COLOR_BayerBGGR2GRAY: i32 = 88;
	pub const COLOR_BayerBGGR2RGB: i32 = 46;
	pub const COLOR_BayerBGGR2RGBA: i32 = 139;
	pub const COLOR_BayerBGGR2RGB_EA: i32 = 135;
	pub const COLOR_BayerBGGR2RGB_VNG: i32 = 62;
	/// equivalent to GRBG Bayer pattern
	pub const COLOR_BayerGB2BGR: i32 = 47;
	/// equivalent to GRBG Bayer pattern
	pub const COLOR_BayerGB2BGRA: i32 = 140;
	/// equivalent to GRBG Bayer pattern
	pub const COLOR_BayerGB2BGR_EA: i32 = 136;
	/// equivalent to GRBG Bayer pattern
	pub const COLOR_BayerGB2BGR_VNG: i32 = 63;
	/// equivalent to GRBG Bayer pattern
	pub const COLOR_BayerGB2GRAY: i32 = 87;
	/// equivalent to GRBG Bayer pattern
	pub const COLOR_BayerGB2RGB: i32 = 49;
	/// equivalent to GRBG Bayer pattern
	pub const COLOR_BayerGB2RGBA: i32 = 142;
	/// equivalent to GRBG Bayer pattern
	pub const COLOR_BayerGB2RGB_EA: i32 = 138;
	/// equivalent to GRBG Bayer pattern
	pub const COLOR_BayerGB2RGB_VNG: i32 = 65;
	pub const COLOR_BayerGBRG2BGR: i32 = 49;
	pub const COLOR_BayerGBRG2BGRA: i32 = 142;
	pub const COLOR_BayerGBRG2BGR_EA: i32 = 138;
	pub const COLOR_BayerGBRG2BGR_VNG: i32 = 65;
	pub const COLOR_BayerGBRG2GRAY: i32 = 89;
	pub const COLOR_BayerGBRG2RGB: i32 = 47;
	pub const COLOR_BayerGBRG2RGBA: i32 = 140;
	pub const COLOR_BayerGBRG2RGB_EA: i32 = 136;
	pub const COLOR_BayerGBRG2RGB_VNG: i32 = 63;
	/// equivalent to GBRG Bayer pattern
	pub const COLOR_BayerGR2BGR: i32 = 49;
	/// equivalent to GBRG Bayer pattern
	pub const COLOR_BayerGR2BGRA: i32 = 142;
	/// equivalent to GBRG Bayer pattern
	pub const COLOR_BayerGR2BGR_EA: i32 = 138;
	/// equivalent to GBRG Bayer pattern
	pub const COLOR_BayerGR2BGR_VNG: i32 = 65;
	/// equivalent to GBRG Bayer pattern
	pub const COLOR_BayerGR2GRAY: i32 = 89;
	/// equivalent to GBRG Bayer pattern
	pub const COLOR_BayerGR2RGB: i32 = 47;
	/// equivalent to GBRG Bayer pattern
	pub const COLOR_BayerGR2RGBA: i32 = 140;
	/// equivalent to GBRG Bayer pattern
	pub const COLOR_BayerGR2RGB_EA: i32 = 136;
	/// equivalent to GBRG Bayer pattern
	pub const COLOR_BayerGR2RGB_VNG: i32 = 63;
	pub const COLOR_BayerGRBG2BGR: i32 = 47;
	pub const COLOR_BayerGRBG2BGRA: i32 = 140;
	pub const COLOR_BayerGRBG2BGR_EA: i32 = 136;
	pub const COLOR_BayerGRBG2BGR_VNG: i32 = 63;
	pub const COLOR_BayerGRBG2GRAY: i32 = 87;
	pub const COLOR_BayerGRBG2RGB: i32 = 49;
	pub const COLOR_BayerGRBG2RGBA: i32 = 142;
	pub const COLOR_BayerGRBG2RGB_EA: i32 = 138;
	pub const COLOR_BayerGRBG2RGB_VNG: i32 = 65;
	/// equivalent to BGGR Bayer pattern
	pub const COLOR_BayerRG2BGR: i32 = 48;
	/// equivalent to BGGR Bayer pattern
	pub const COLOR_BayerRG2BGRA: i32 = 141;
	/// equivalent to BGGR Bayer pattern
	pub const COLOR_BayerRG2BGR_EA: i32 = 137;
	/// equivalent to BGGR Bayer pattern
	pub const COLOR_BayerRG2BGR_VNG: i32 = 64;
	/// equivalent to BGGR Bayer pattern
	pub const COLOR_BayerRG2GRAY: i32 = 88;
	/// equivalent to BGGR Bayer pattern
	pub const COLOR_BayerRG2RGB: i32 = 46;
	/// equivalent to BGGR Bayer pattern
	pub const COLOR_BayerRG2RGBA: i32 = 139;
	/// equivalent to BGGR Bayer pattern
	pub const COLOR_BayerRG2RGB_EA: i32 = 135;
	/// equivalent to BGGR Bayer pattern
	pub const COLOR_BayerRG2RGB_VNG: i32 = 62;
	pub const COLOR_BayerRGGB2BGR: i32 = 46;
	pub const COLOR_BayerRGGB2BGRA: i32 = 139;
	pub const COLOR_BayerRGGB2BGR_EA: i32 = 135;
	pub const COLOR_BayerRGGB2BGR_VNG: i32 = 62;
	pub const COLOR_BayerRGGB2GRAY: i32 = 86;
	pub const COLOR_BayerRGGB2RGB: i32 = 48;
	pub const COLOR_BayerRGGB2RGBA: i32 = 141;
	pub const COLOR_BayerRGGB2RGB_EA: i32 = 137;
	pub const COLOR_BayerRGGB2RGB_VNG: i32 = 64;
	pub const COLOR_COLORCVT_MAX: i32 = 143;
	pub const COLOR_GRAY2BGR: i32 = 8;
	/// convert between grayscale and BGR555 (16-bit images)
	pub const COLOR_GRAY2BGR555: i32 = 30;
	/// convert between grayscale to BGR565 (16-bit images)
	pub const COLOR_GRAY2BGR565: i32 = 20;
	pub const COLOR_GRAY2BGRA: i32 = 9;
	pub const COLOR_GRAY2RGB: i32 = 8;
	pub const COLOR_GRAY2RGBA: i32 = 9;
	/// backward conversions HLS to RGB/BGR with H range 0..180 if 8 bit image
	pub const COLOR_HLS2BGR: i32 = 60;
	/// backward conversions HLS to RGB/BGR with H range 0..255 if 8 bit image
	pub const COLOR_HLS2BGR_FULL: i32 = 72;
	pub const COLOR_HLS2RGB: i32 = 61;
	pub const COLOR_HLS2RGB_FULL: i32 = 73;
	/// backward conversions HSV to RGB/BGR with H range 0..180 if 8 bit image
	pub const COLOR_HSV2BGR: i32 = 54;
	/// backward conversions HSV to RGB/BGR with H range 0..255 if 8 bit image
	pub const COLOR_HSV2BGR_FULL: i32 = 70;
	pub const COLOR_HSV2RGB: i32 = 55;
	pub const COLOR_HSV2RGB_FULL: i32 = 71;
	pub const COLOR_LBGR2Lab: i32 = 74;
	pub const COLOR_LBGR2Luv: i32 = 76;
	pub const COLOR_LRGB2Lab: i32 = 75;
	pub const COLOR_LRGB2Luv: i32 = 77;
	pub const COLOR_Lab2BGR: i32 = 56;
	pub const COLOR_Lab2LBGR: i32 = 78;
	pub const COLOR_Lab2LRGB: i32 = 79;
	pub const COLOR_Lab2RGB: i32 = 57;
	pub const COLOR_Luv2BGR: i32 = 58;
	pub const COLOR_Luv2LBGR: i32 = 80;
	pub const COLOR_Luv2LRGB: i32 = 81;
	pub const COLOR_Luv2RGB: i32 = 59;
	pub const COLOR_RGB2BGR: i32 = 4;
	pub const COLOR_RGB2BGR555: i32 = 23;
	pub const COLOR_RGB2BGR565: i32 = 13;
	pub const COLOR_RGB2BGRA: i32 = 2;
	pub const COLOR_RGB2GRAY: i32 = 7;
	pub const COLOR_RGB2HLS: i32 = 53;
	pub const COLOR_RGB2HLS_FULL: i32 = 69;
	pub const COLOR_RGB2HSV: i32 = 41;
	pub const COLOR_RGB2HSV_FULL: i32 = 67;
	pub const COLOR_RGB2Lab: i32 = 45;
	pub const COLOR_RGB2Luv: i32 = 51;
	pub const COLOR_RGB2RGBA: i32 = 0;
	pub const COLOR_RGB2XYZ: i32 = 33;
	pub const COLOR_RGB2YCrCb: i32 = 37;
	pub const COLOR_RGB2YUV: i32 = 83;
	/// RGB to YUV 4:2:0 family
	pub const COLOR_RGB2YUV_I420: i32 = 127;
	/// RGB to YUV 4:2:0 family
	pub const COLOR_RGB2YUV_IYUV: i32 = 127;
	/// RGB to YUV 4:2:0 family
	pub const COLOR_RGB2YUV_YV12: i32 = 131;
	pub const COLOR_RGBA2BGR: i32 = 3;
	pub const COLOR_RGBA2BGR555: i32 = 27;
	pub const COLOR_RGBA2BGR565: i32 = 17;
	pub const COLOR_RGBA2BGRA: i32 = 5;
	pub const COLOR_RGBA2GRAY: i32 = 11;
	pub const COLOR_RGBA2RGB: i32 = 1;
	/// RGB to YUV 4:2:0 family
	pub const COLOR_RGBA2YUV_I420: i32 = 129;
	/// RGB to YUV 4:2:0 family
	pub const COLOR_RGBA2YUV_IYUV: i32 = 129;
	/// RGB to YUV 4:2:0 family
	pub const COLOR_RGBA2YUV_YV12: i32 = 133;
	/// alpha premultiplication
	pub const COLOR_RGBA2mRGBA: i32 = 125;
	pub const COLOR_XYZ2BGR: i32 = 34;
	pub const COLOR_XYZ2RGB: i32 = 35;
	pub const COLOR_YCrCb2BGR: i32 = 38;
	pub const COLOR_YCrCb2RGB: i32 = 39;
	pub const COLOR_YUV2BGR: i32 = 84;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2BGRA_I420: i32 = 105;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2BGRA_IYUV: i32 = 105;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2BGRA_NV12: i32 = 95;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2BGRA_NV21: i32 = 97;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2BGRA_UYNV: i32 = 112;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2BGRA_UYVY: i32 = 112;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2BGRA_Y422: i32 = 112;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2BGRA_YUNV: i32 = 120;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2BGRA_YUY2: i32 = 120;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2BGRA_YUYV: i32 = 120;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2BGRA_YV12: i32 = 103;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2BGRA_YVYU: i32 = 122;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2BGR_I420: i32 = 101;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2BGR_IYUV: i32 = 101;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2BGR_NV12: i32 = 91;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2BGR_NV21: i32 = 93;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2BGR_UYNV: i32 = 108;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2BGR_UYVY: i32 = 108;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2BGR_Y422: i32 = 108;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2BGR_YUNV: i32 = 116;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2BGR_YUY2: i32 = 116;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2BGR_YUYV: i32 = 116;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2BGR_YV12: i32 = 99;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2BGR_YVYU: i32 = 118;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2GRAY_420: i32 = 106;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2GRAY_I420: i32 = 106;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2GRAY_IYUV: i32 = 106;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2GRAY_NV12: i32 = 106;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2GRAY_NV21: i32 = 106;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2GRAY_UYNV: i32 = 123;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2GRAY_UYVY: i32 = 123;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2GRAY_Y422: i32 = 123;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2GRAY_YUNV: i32 = 124;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2GRAY_YUY2: i32 = 124;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2GRAY_YUYV: i32 = 124;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2GRAY_YV12: i32 = 106;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2GRAY_YVYU: i32 = 124;
	pub const COLOR_YUV2RGB: i32 = 85;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2RGBA_I420: i32 = 104;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2RGBA_IYUV: i32 = 104;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2RGBA_NV12: i32 = 94;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2RGBA_NV21: i32 = 96;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2RGBA_UYNV: i32 = 111;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2RGBA_UYVY: i32 = 111;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2RGBA_Y422: i32 = 111;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2RGBA_YUNV: i32 = 119;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2RGBA_YUY2: i32 = 119;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2RGBA_YUYV: i32 = 119;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2RGBA_YV12: i32 = 102;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2RGBA_YVYU: i32 = 121;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2RGB_I420: i32 = 100;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2RGB_IYUV: i32 = 100;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2RGB_NV12: i32 = 90;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2RGB_NV21: i32 = 92;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2RGB_UYNV: i32 = 107;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2RGB_UYVY: i32 = 107;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2RGB_Y422: i32 = 107;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2RGB_YUNV: i32 = 115;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2RGB_YUY2: i32 = 115;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2RGB_YUYV: i32 = 115;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV2RGB_YV12: i32 = 98;
	/// YUV 4:2:2 family to RGB
	pub const COLOR_YUV2RGB_YVYU: i32 = 117;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV420p2BGR: i32 = 99;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV420p2BGRA: i32 = 103;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV420p2GRAY: i32 = 106;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV420p2RGB: i32 = 98;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV420p2RGBA: i32 = 102;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV420sp2BGR: i32 = 93;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV420sp2BGRA: i32 = 97;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV420sp2GRAY: i32 = 106;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV420sp2RGB: i32 = 92;
	/// YUV 4:2:0 family to RGB
	pub const COLOR_YUV420sp2RGBA: i32 = 96;
	/// alpha premultiplication
	pub const COLOR_mRGBA2RGBA: i32 = 126;
	/// 
	pub const CONTOURS_MATCH_I1: i32 = 1;
	/// 
	pub const CONTOURS_MATCH_I2: i32 = 2;
	/// 
	pub const CONTOURS_MATCH_I3: i32 = 3;
	/// distance = max(|x1-x2|,|y1-y2|)
	pub const DIST_C: i32 = 3;
	/// distance = c^2(|x|/c-log(1+|x|/c)), c = 1.3998
	pub const DIST_FAIR: i32 = 5;
	/// distance = |x|<c ? x^2/2 : c(|x|-c/2), c=1.345
	pub const DIST_HUBER: i32 = 7;
	/// distance = |x1-x2| + |y1-y2|
	pub const DIST_L1: i32 = 1;
	/// L1-L2 metric: distance = 2(sqrt(1+x*x/2) - 1))
	pub const DIST_L12: i32 = 4;
	/// the simple euclidean distance
	pub const DIST_L2: i32 = 2;
	/// each connected component of zeros in src (as well as all the non-zero pixels closest to the
	/// connected component) will be assigned the same label
	pub const DIST_LABEL_CCOMP: i32 = 0;
	/// each zero pixel (and all the non-zero pixels closest to it) gets its own label.
	pub const DIST_LABEL_PIXEL: i32 = 1;
	/// mask=3
	pub const DIST_MASK_3: i32 = 3;
	/// mask=5
	pub const DIST_MASK_5: i32 = 5;
	pub const DIST_MASK_PRECISE: i32 = 0;
	/// User defined distance
	pub const DIST_USER: i32 = -1;
	/// distance = c^2/2(1-exp(-(x/c)^2)), c = 2.9846
	pub const DIST_WELSCH: i32 = 6;
	pub const FILLED: i32 = -1;
	pub const FILTER_SCHARR: i32 = -1;
	/// If set, the difference between the current pixel and seed pixel is considered. Otherwise,
	/// the difference between neighbor pixels is considered (that is, the range is floating).
	pub const FLOODFILL_FIXED_RANGE: i32 = 65536;
	/// If set, the function does not change the image ( newVal is ignored), and only fills the
	/// mask with the value specified in bits 8-16 of flags as described above. This option only make
	/// sense in function variants that have the mask parameter.
	pub const FLOODFILL_MASK_ONLY: i32 = 131072;
	/// normal size serif font
	pub const FONT_HERSHEY_COMPLEX: i32 = 3;
	/// smaller version of FONT_HERSHEY_COMPLEX
	pub const FONT_HERSHEY_COMPLEX_SMALL: i32 = 5;
	/// normal size sans-serif font (more complex than FONT_HERSHEY_SIMPLEX)
	pub const FONT_HERSHEY_DUPLEX: i32 = 2;
	/// small size sans-serif font
	pub const FONT_HERSHEY_PLAIN: i32 = 1;
	/// more complex variant of FONT_HERSHEY_SCRIPT_SIMPLEX
	pub const FONT_HERSHEY_SCRIPT_COMPLEX: i32 = 7;
	/// hand-writing style font
	pub const FONT_HERSHEY_SCRIPT_SIMPLEX: i32 = 6;
	/// normal size sans-serif font
	pub const FONT_HERSHEY_SIMPLEX: i32 = 0;
	/// normal size serif font (more complex than FONT_HERSHEY_COMPLEX)
	pub const FONT_HERSHEY_TRIPLEX: i32 = 4;
	/// flag for italic font
	pub const FONT_ITALIC: i32 = 16;
	/// an obvious background pixels
	pub const GC_BGD: i32 = 0;
	/// The value means that the algorithm should just resume.
	pub const GC_EVAL: i32 = 2;
	/// The value means that the algorithm should just run the grabCut algorithm (a single iteration) with the fixed model
	pub const GC_EVAL_FREEZE_MODEL: i32 = 3;
	/// an obvious foreground (object) pixel
	pub const GC_FGD: i32 = 1;
	/// The function initializes the state using the provided mask. Note that GC_INIT_WITH_RECT
	/// and GC_INIT_WITH_MASK can be combined. Then, all the pixels outside of the ROI are
	/// automatically initialized with GC_BGD .
	pub const GC_INIT_WITH_MASK: i32 = 1;
	/// The function initializes the state and the mask using the provided rectangle. After that it
	/// runs iterCount iterations of the algorithm.
	pub const GC_INIT_WITH_RECT: i32 = 0;
	/// a possible background pixel
	pub const GC_PR_BGD: i32 = 2;
	/// a possible foreground pixel
	pub const GC_PR_FGD: i32 = 3;
	/// Bhattacharyya distance
	/// (In fact, OpenCV computes Hellinger distance, which is related to Bhattacharyya coefficient.)
	/// 
	pub const HISTCMP_BHATTACHARYYA: i32 = 3;
	/// Chi-Square
	/// 
	pub const HISTCMP_CHISQR: i32 = 1;
	/// Alternative Chi-Square
	/// 
	/// This alternative formula is regularly used for texture comparison. See e.g. [Puzicha1997](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Puzicha1997)
	pub const HISTCMP_CHISQR_ALT: i32 = 4;
	/// Correlation
	/// 
	/// where
	/// 
	/// and  is a total number of histogram bins.
	pub const HISTCMP_CORREL: i32 = 0;
	/// Synonym for HISTCMP_BHATTACHARYYA
	pub const HISTCMP_HELLINGER: i32 = 3;
	/// Intersection
	/// 
	pub const HISTCMP_INTERSECT: i32 = 2;
	/// Kullback-Leibler divergence
	/// 
	pub const HISTCMP_KL_DIV: i32 = 5;
	/// basically *21HT*, described in [Yuen90](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Yuen90)
	pub const HOUGH_GRADIENT: i32 = 3;
	/// variation of HOUGH_GRADIENT to get better accuracy
	pub const HOUGH_GRADIENT_ALT: i32 = 4;
	/// multi-scale variant of the classical Hough transform. The lines are encoded the same way as
	/// HOUGH_STANDARD.
	pub const HOUGH_MULTI_SCALE: i32 = 2;
	/// probabilistic Hough transform (more efficient in case if the picture contains a few long
	/// linear segments). It returns line segments rather than the whole line. Each segment is
	/// represented by starting and ending points, and the matrix must be (the created sequence will
	/// be) of the CV_32SC4 type.
	pub const HOUGH_PROBABILISTIC: i32 = 1;
	/// classical or standard Hough transform. Every line is represented by two floating-point
	/// numbers  , where  is a distance between (0,0) point and the line,
	/// and  is the angle between x-axis and the normal to the line. Thus, the matrix must
	/// be (the created sequence will be) of CV_32FC2 type
	pub const HOUGH_STANDARD: i32 = 0;
	/// One of the rectangle is fully enclosed in the other
	pub const INTERSECT_FULL: i32 = 2;
	/// No intersection
	pub const INTERSECT_NONE: i32 = 0;
	/// There is a partial intersection
	pub const INTERSECT_PARTIAL: i32 = 1;
	/// resampling using pixel area relation. It may be a preferred method for image decimation, as
	/// it gives moire'-free results. But when the image is zoomed, it is similar to the INTER_NEAREST
	/// method.
	pub const INTER_AREA: i32 = 3;
	pub const INTER_BITS: i32 = 5;
	pub const INTER_BITS2: i32 = 10;
	/// bicubic interpolation
	pub const INTER_CUBIC: i32 = 2;
	/// Lanczos interpolation over 8x8 neighborhood
	pub const INTER_LANCZOS4: i32 = 4;
	/// bilinear interpolation
	pub const INTER_LINEAR: i32 = 1;
	/// Bit exact bilinear interpolation
	pub const INTER_LINEAR_EXACT: i32 = 5;
	/// mask for interpolation codes
	pub const INTER_MAX: i32 = 7;
	/// nearest neighbor interpolation
	pub const INTER_NEAREST: i32 = 0;
	/// Bit exact nearest neighbor interpolation. This will produce same results as
	/// the nearest neighbor method in PIL, scikit-image or Matlab.
	pub const INTER_NEAREST_EXACT: i32 = 6;
	pub const INTER_TAB_SIZE: i32 = 32;
	pub const INTER_TAB_SIZE2: i32 = 1024;
	/// 4-connected line
	pub const LINE_4: i32 = 4;
	/// 8-connected line
	pub const LINE_8: i32 = 8;
	/// antialiased line
	pub const LINE_AA: i32 = 16;
	/// Advanced refinement. Number of false alarms is calculated, lines are
	/// refined through increase of precision, decrement in size, etc.
	pub const LSD_REFINE_ADV: i32 = 2;
	/// No refinement applied
	pub const LSD_REFINE_NONE: i32 = 0;
	/// Standard refinement is applied. E.g. breaking arches into smaller straighter line approximations.
	pub const LSD_REFINE_STD: i32 = 1;
	/// A crosshair marker shape
	pub const MARKER_CROSS: i32 = 0;
	/// A diamond marker shape
	pub const MARKER_DIAMOND: i32 = 3;
	/// A square marker shape
	pub const MARKER_SQUARE: i32 = 4;
	/// A star marker shape, combination of cross and tilted cross
	pub const MARKER_STAR: i32 = 2;
	/// A 45 degree tilted crosshair marker shape
	pub const MARKER_TILTED_CROSS: i32 = 1;
	/// A downwards pointing triangle marker shape
	pub const MARKER_TRIANGLE_DOWN: i32 = 6;
	/// An upwards pointing triangle marker shape
	pub const MARKER_TRIANGLE_UP: i32 = 5;
	/// "black hat"
	/// 
	pub const MORPH_BLACKHAT: i32 = 6;
	/// a closing operation
	/// 
	pub const MORPH_CLOSE: i32 = 3;
	/// a cross-shaped structuring element:
	/// 
	pub const MORPH_CROSS: i32 = 1;
	/// see #dilate
	pub const MORPH_DILATE: i32 = 1;
	/// an elliptic structuring element, that is, a filled ellipse inscribed
	/// into the rectangle Rect(0, 0, esize.width, 0.esize.height)
	pub const MORPH_ELLIPSE: i32 = 2;
	/// see #erode
	pub const MORPH_ERODE: i32 = 0;
	/// a morphological gradient
	/// 
	pub const MORPH_GRADIENT: i32 = 4;
	/// "hit or miss"
	/// .- Only supported for CV_8UC1 binary images. A tutorial can be found in the documentation
	pub const MORPH_HITMISS: i32 = 7;
	/// an opening operation
	/// 
	pub const MORPH_OPEN: i32 = 2;
	/// a rectangular structuring element:  
	pub const MORPH_RECT: i32 = 0;
	/// "top hat"
	/// 
	pub const MORPH_TOPHAT: i32 = 5;
	/// retrieves all of the contours and organizes them into a two-level hierarchy. At the top
	/// level, there are external boundaries of the components. At the second level, there are
	/// boundaries of the holes. If there is another contour inside a hole of a connected component, it
	/// is still put at the top level.
	pub const RETR_CCOMP: i32 = 2;
	/// retrieves only the extreme outer contours. It sets `hierarchy[i][2]=hierarchy[i][3]=-1` for
	/// all the contours.
	pub const RETR_EXTERNAL: i32 = 0;
	pub const RETR_FLOODFILL: i32 = 4;
	/// retrieves all of the contours without establishing any hierarchical relationships.
	pub const RETR_LIST: i32 = 1;
	/// retrieves all of the contours and reconstructs a full hierarchy of nested contours.
	pub const RETR_TREE: i32 = 3;
	pub const Subdiv2D_NEXT_AROUND_DST: i32 = 34;
	pub const Subdiv2D_NEXT_AROUND_LEFT: i32 = 19;
	pub const Subdiv2D_NEXT_AROUND_ORG: i32 = 0;
	pub const Subdiv2D_NEXT_AROUND_RIGHT: i32 = 49;
	pub const Subdiv2D_PREV_AROUND_DST: i32 = 51;
	pub const Subdiv2D_PREV_AROUND_LEFT: i32 = 32;
	pub const Subdiv2D_PREV_AROUND_ORG: i32 = 17;
	pub const Subdiv2D_PREV_AROUND_RIGHT: i32 = 2;
	/// Point location error
	pub const Subdiv2D_PTLOC_ERROR: i32 = -2;
	/// Point inside some facet
	pub const Subdiv2D_PTLOC_INSIDE: i32 = 0;
	/// Point on some edge
	pub const Subdiv2D_PTLOC_ON_EDGE: i32 = 2;
	/// Point outside the subdivision bounding rect
	pub const Subdiv2D_PTLOC_OUTSIDE_RECT: i32 = -1;
	/// Point coincides with one of the subdivision vertices
	pub const Subdiv2D_PTLOC_VERTEX: i32 = 1;
	/// 
	pub const THRESH_BINARY: i32 = 0;
	/// 
	pub const THRESH_BINARY_INV: i32 = 1;
	pub const THRESH_MASK: i32 = 7;
	/// flag, use Otsu algorithm to choose the optimal threshold value
	pub const THRESH_OTSU: i32 = 8;
	/// 
	pub const THRESH_TOZERO: i32 = 3;
	/// 
	pub const THRESH_TOZERO_INV: i32 = 4;
	/// flag, use Triangle algorithm to choose the optimal threshold value
	pub const THRESH_TRIANGLE: i32 = 16;
	/// 
	pub const THRESH_TRUNC: i32 = 2;
	/// !< 
	/// where
	/// 
	/// with mask:
	/// 
	pub const TM_CCOEFF: i32 = 4;
	/// !< 
	pub const TM_CCOEFF_NORMED: i32 = 5;
	/// !< 
	/// with mask:
	/// 
	pub const TM_CCORR: i32 = 2;
	/// !< 
	/// with mask:
	/// 
	pub const TM_CCORR_NORMED: i32 = 3;
	/// !< 
	/// with mask:
	/// 
	pub const TM_SQDIFF: i32 = 0;
	/// !< 
	/// with mask:
	/// 
	pub const TM_SQDIFF_NORMED: i32 = 1;
	/// flag, fills all of the destination image pixels. If some of them correspond to outliers in the
	/// source image, they are set to zero
	pub const WARP_FILL_OUTLIERS: i32 = 8;
	/// flag, inverse transformation
	/// 
	/// For example, [linear_polar] or [log_polar] transforms:
	/// - flag is __not__ set: 
	/// - flag is set: 
	pub const WARP_INVERSE_MAP: i32 = 16;
	/// Remaps an image to/from polar space.
	pub const WARP_POLAR_LINEAR: i32 = 0;
	/// Remaps an image to/from semilog-polar space.
	pub const WARP_POLAR_LOG: i32 = 256;
	/// adaptive threshold algorithm
	/// ## See also
	/// adaptiveThreshold
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum AdaptiveThresholdTypes {
		/// the threshold value  is a mean of the  neighborhood of  minus C
		ADAPTIVE_THRESH_MEAN_C = 0,
		/// the threshold value  is a weighted sum (cross-correlation with a Gaussian
		/// window) of the  neighborhood of 
		/// minus C . The default sigma (standard deviation) is used for the specified blockSize . See
		/// #getGaussianKernel
		ADAPTIVE_THRESH_GAUSSIAN_C = 1,
	}
	
	opencv_type_enum! { crate::imgproc::AdaptiveThresholdTypes }
	
	/// the color conversion codes
	/// ## See also
	/// [imgproc_color_conversions]
	/// @ingroup imgproc_color_conversions
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum ColorConversionCodes {
		/// add alpha channel to RGB or BGR image
		COLOR_BGR2BGRA = 0,
		// Duplicate, use COLOR_BGR2BGRA instead
		// COLOR_RGB2RGBA = 0,
		/// remove alpha channel from RGB or BGR image
		COLOR_BGRA2BGR = 1,
		// Duplicate, use COLOR_BGRA2BGR instead
		// COLOR_RGBA2RGB = 1,
		/// convert between RGB and BGR color spaces (with or without alpha channel)
		COLOR_BGR2RGBA = 2,
		// Duplicate, use COLOR_BGR2RGBA instead
		// COLOR_RGB2BGRA = 2,
		COLOR_RGBA2BGR = 3,
		// Duplicate, use COLOR_RGBA2BGR instead
		// COLOR_BGRA2RGB = 3,
		COLOR_BGR2RGB = 4,
		// Duplicate, use COLOR_BGR2RGB instead
		// COLOR_RGB2BGR = 4,
		COLOR_BGRA2RGBA = 5,
		// Duplicate, use COLOR_BGRA2RGBA instead
		// COLOR_RGBA2BGRA = 5,
		/// convert between RGB/BGR and grayscale, [color_convert_rgb_gray] "color conversions"
		COLOR_BGR2GRAY = 6,
		COLOR_RGB2GRAY = 7,
		COLOR_GRAY2BGR = 8,
		// Duplicate, use COLOR_GRAY2BGR instead
		// COLOR_GRAY2RGB = 8,
		COLOR_GRAY2BGRA = 9,
		// Duplicate, use COLOR_GRAY2BGRA instead
		// COLOR_GRAY2RGBA = 9,
		COLOR_BGRA2GRAY = 10,
		COLOR_RGBA2GRAY = 11,
		/// convert between RGB/BGR and BGR565 (16-bit images)
		COLOR_BGR2BGR565 = 12,
		COLOR_RGB2BGR565 = 13,
		COLOR_BGR5652BGR = 14,
		COLOR_BGR5652RGB = 15,
		COLOR_BGRA2BGR565 = 16,
		COLOR_RGBA2BGR565 = 17,
		COLOR_BGR5652BGRA = 18,
		COLOR_BGR5652RGBA = 19,
		/// convert between grayscale to BGR565 (16-bit images)
		COLOR_GRAY2BGR565 = 20,
		COLOR_BGR5652GRAY = 21,
		/// convert between RGB/BGR and BGR555 (16-bit images)
		COLOR_BGR2BGR555 = 22,
		COLOR_RGB2BGR555 = 23,
		COLOR_BGR5552BGR = 24,
		COLOR_BGR5552RGB = 25,
		COLOR_BGRA2BGR555 = 26,
		COLOR_RGBA2BGR555 = 27,
		COLOR_BGR5552BGRA = 28,
		COLOR_BGR5552RGBA = 29,
		/// convert between grayscale and BGR555 (16-bit images)
		COLOR_GRAY2BGR555 = 30,
		COLOR_BGR5552GRAY = 31,
		/// convert RGB/BGR to CIE XYZ, [color_convert_rgb_xyz] "color conversions"
		COLOR_BGR2XYZ = 32,
		COLOR_RGB2XYZ = 33,
		COLOR_XYZ2BGR = 34,
		COLOR_XYZ2RGB = 35,
		/// convert RGB/BGR to luma-chroma (aka YCC), [color_convert_rgb_ycrcb] "color conversions"
		COLOR_BGR2YCrCb = 36,
		COLOR_RGB2YCrCb = 37,
		COLOR_YCrCb2BGR = 38,
		COLOR_YCrCb2RGB = 39,
		/// convert RGB/BGR to HSV (hue saturation value) with H range 0..180 if 8 bit image, [color_convert_rgb_hsv] "color conversions"
		COLOR_BGR2HSV = 40,
		COLOR_RGB2HSV = 41,
		/// convert RGB/BGR to CIE Lab, [color_convert_rgb_lab] "color conversions"
		COLOR_BGR2Lab = 44,
		COLOR_RGB2Lab = 45,
		/// convert RGB/BGR to CIE Luv, [color_convert_rgb_luv] "color conversions"
		COLOR_BGR2Luv = 50,
		COLOR_RGB2Luv = 51,
		/// convert RGB/BGR to HLS (hue lightness saturation) with H range 0..180 if 8 bit image, [color_convert_rgb_hls] "color conversions"
		COLOR_BGR2HLS = 52,
		COLOR_RGB2HLS = 53,
		/// backward conversions HSV to RGB/BGR with H range 0..180 if 8 bit image
		COLOR_HSV2BGR = 54,
		COLOR_HSV2RGB = 55,
		COLOR_Lab2BGR = 56,
		COLOR_Lab2RGB = 57,
		COLOR_Luv2BGR = 58,
		COLOR_Luv2RGB = 59,
		/// backward conversions HLS to RGB/BGR with H range 0..180 if 8 bit image
		COLOR_HLS2BGR = 60,
		COLOR_HLS2RGB = 61,
		/// convert RGB/BGR to HSV (hue saturation value) with H range 0..255 if 8 bit image, [color_convert_rgb_hsv] "color conversions"
		COLOR_BGR2HSV_FULL = 66,
		COLOR_RGB2HSV_FULL = 67,
		/// convert RGB/BGR to HLS (hue lightness saturation) with H range 0..255 if 8 bit image, [color_convert_rgb_hls] "color conversions"
		COLOR_BGR2HLS_FULL = 68,
		COLOR_RGB2HLS_FULL = 69,
		/// backward conversions HSV to RGB/BGR with H range 0..255 if 8 bit image
		COLOR_HSV2BGR_FULL = 70,
		COLOR_HSV2RGB_FULL = 71,
		/// backward conversions HLS to RGB/BGR with H range 0..255 if 8 bit image
		COLOR_HLS2BGR_FULL = 72,
		COLOR_HLS2RGB_FULL = 73,
		COLOR_LBGR2Lab = 74,
		COLOR_LRGB2Lab = 75,
		COLOR_LBGR2Luv = 76,
		COLOR_LRGB2Luv = 77,
		COLOR_Lab2LBGR = 78,
		COLOR_Lab2LRGB = 79,
		COLOR_Luv2LBGR = 80,
		COLOR_Luv2LRGB = 81,
		/// convert between RGB/BGR and YUV
		COLOR_BGR2YUV = 82,
		COLOR_RGB2YUV = 83,
		COLOR_YUV2BGR = 84,
		COLOR_YUV2RGB = 85,
		/// YUV 4:2:0 family to RGB
		COLOR_YUV2RGB_NV12 = 90,
		/// YUV 4:2:0 family to RGB
		COLOR_YUV2BGR_NV12 = 91,
		/// YUV 4:2:0 family to RGB
		COLOR_YUV2RGB_NV21 = 92,
		/// YUV 4:2:0 family to RGB
		COLOR_YUV2BGR_NV21 = 93,
		// YUV 4:2:0 family to RGB
		// Duplicate, use COLOR_YUV2RGB_NV21 instead
		// COLOR_YUV420sp2RGB = 92,
		// YUV 4:2:0 family to RGB
		// Duplicate, use COLOR_YUV2BGR_NV21 instead
		// COLOR_YUV420sp2BGR = 93,
		/// YUV 4:2:0 family to RGB
		COLOR_YUV2RGBA_NV12 = 94,
		/// YUV 4:2:0 family to RGB
		COLOR_YUV2BGRA_NV12 = 95,
		/// YUV 4:2:0 family to RGB
		COLOR_YUV2RGBA_NV21 = 96,
		/// YUV 4:2:0 family to RGB
		COLOR_YUV2BGRA_NV21 = 97,
		// YUV 4:2:0 family to RGB
		// Duplicate, use COLOR_YUV2RGBA_NV21 instead
		// COLOR_YUV420sp2RGBA = 96,
		// YUV 4:2:0 family to RGB
		// Duplicate, use COLOR_YUV2BGRA_NV21 instead
		// COLOR_YUV420sp2BGRA = 97,
		/// YUV 4:2:0 family to RGB
		COLOR_YUV2RGB_YV12 = 98,
		/// YUV 4:2:0 family to RGB
		COLOR_YUV2BGR_YV12 = 99,
		/// YUV 4:2:0 family to RGB
		COLOR_YUV2RGB_IYUV = 100,
		/// YUV 4:2:0 family to RGB
		COLOR_YUV2BGR_IYUV = 101,
		// YUV 4:2:0 family to RGB
		// Duplicate, use COLOR_YUV2RGB_IYUV instead
		// COLOR_YUV2RGB_I420 = 100,
		// YUV 4:2:0 family to RGB
		// Duplicate, use COLOR_YUV2BGR_IYUV instead
		// COLOR_YUV2BGR_I420 = 101,
		// YUV 4:2:0 family to RGB
		// Duplicate, use COLOR_YUV2RGB_YV12 instead
		// COLOR_YUV420p2RGB = 98,
		// YUV 4:2:0 family to RGB
		// Duplicate, use COLOR_YUV2BGR_YV12 instead
		// COLOR_YUV420p2BGR = 99,
		/// YUV 4:2:0 family to RGB
		COLOR_YUV2RGBA_YV12 = 102,
		/// YUV 4:2:0 family to RGB
		COLOR_YUV2BGRA_YV12 = 103,
		/// YUV 4:2:0 family to RGB
		COLOR_YUV2RGBA_IYUV = 104,
		/// YUV 4:2:0 family to RGB
		COLOR_YUV2BGRA_IYUV = 105,
		// YUV 4:2:0 family to RGB
		// Duplicate, use COLOR_YUV2RGBA_IYUV instead
		// COLOR_YUV2RGBA_I420 = 104,
		// YUV 4:2:0 family to RGB
		// Duplicate, use COLOR_YUV2BGRA_IYUV instead
		// COLOR_YUV2BGRA_I420 = 105,
		// YUV 4:2:0 family to RGB
		// Duplicate, use COLOR_YUV2RGBA_YV12 instead
		// COLOR_YUV420p2RGBA = 102,
		// YUV 4:2:0 family to RGB
		// Duplicate, use COLOR_YUV2BGRA_YV12 instead
		// COLOR_YUV420p2BGRA = 103,
		/// YUV 4:2:0 family to RGB
		COLOR_YUV2GRAY_420 = 106,
		// YUV 4:2:0 family to RGB
		// Duplicate, use COLOR_YUV2GRAY_420 instead
		// COLOR_YUV2GRAY_NV21 = 106,
		// YUV 4:2:0 family to RGB
		// Duplicate, use COLOR_YUV2GRAY_NV21 instead
		// COLOR_YUV2GRAY_NV12 = 106,
		// YUV 4:2:0 family to RGB
		// Duplicate, use COLOR_YUV2GRAY_NV12 instead
		// COLOR_YUV2GRAY_YV12 = 106,
		// YUV 4:2:0 family to RGB
		// Duplicate, use COLOR_YUV2GRAY_YV12 instead
		// COLOR_YUV2GRAY_IYUV = 106,
		// YUV 4:2:0 family to RGB
		// Duplicate, use COLOR_YUV2GRAY_IYUV instead
		// COLOR_YUV2GRAY_I420 = 106,
		// YUV 4:2:0 family to RGB
		// Duplicate, use COLOR_YUV2GRAY_I420 instead
		// COLOR_YUV420sp2GRAY = 106,
		// YUV 4:2:0 family to RGB
		// Duplicate, use COLOR_YUV420sp2GRAY instead
		// COLOR_YUV420p2GRAY = 106,
		/// YUV 4:2:2 family to RGB
		COLOR_YUV2RGB_UYVY = 107,
		/// YUV 4:2:2 family to RGB
		COLOR_YUV2BGR_UYVY = 108,
		// YUV 4:2:2 family to RGB
		// Duplicate, use COLOR_YUV2RGB_UYVY instead
		// COLOR_YUV2RGB_Y422 = 107,
		// YUV 4:2:2 family to RGB
		// Duplicate, use COLOR_YUV2BGR_UYVY instead
		// COLOR_YUV2BGR_Y422 = 108,
		// YUV 4:2:2 family to RGB
		// Duplicate, use COLOR_YUV2RGB_Y422 instead
		// COLOR_YUV2RGB_UYNV = 107,
		// YUV 4:2:2 family to RGB
		// Duplicate, use COLOR_YUV2BGR_Y422 instead
		// COLOR_YUV2BGR_UYNV = 108,
		/// YUV 4:2:2 family to RGB
		COLOR_YUV2RGBA_UYVY = 111,
		/// YUV 4:2:2 family to RGB
		COLOR_YUV2BGRA_UYVY = 112,
		// YUV 4:2:2 family to RGB
		// Duplicate, use COLOR_YUV2RGBA_UYVY instead
		// COLOR_YUV2RGBA_Y422 = 111,
		// YUV 4:2:2 family to RGB
		// Duplicate, use COLOR_YUV2BGRA_UYVY instead
		// COLOR_YUV2BGRA_Y422 = 112,
		// YUV 4:2:2 family to RGB
		// Duplicate, use COLOR_YUV2RGBA_Y422 instead
		// COLOR_YUV2RGBA_UYNV = 111,
		// YUV 4:2:2 family to RGB
		// Duplicate, use COLOR_YUV2BGRA_Y422 instead
		// COLOR_YUV2BGRA_UYNV = 112,
		/// YUV 4:2:2 family to RGB
		COLOR_YUV2RGB_YUY2 = 115,
		/// YUV 4:2:2 family to RGB
		COLOR_YUV2BGR_YUY2 = 116,
		/// YUV 4:2:2 family to RGB
		COLOR_YUV2RGB_YVYU = 117,
		/// YUV 4:2:2 family to RGB
		COLOR_YUV2BGR_YVYU = 118,
		// YUV 4:2:2 family to RGB
		// Duplicate, use COLOR_YUV2RGB_YUY2 instead
		// COLOR_YUV2RGB_YUYV = 115,
		// YUV 4:2:2 family to RGB
		// Duplicate, use COLOR_YUV2BGR_YUY2 instead
		// COLOR_YUV2BGR_YUYV = 116,
		// YUV 4:2:2 family to RGB
		// Duplicate, use COLOR_YUV2RGB_YUYV instead
		// COLOR_YUV2RGB_YUNV = 115,
		// YUV 4:2:2 family to RGB
		// Duplicate, use COLOR_YUV2BGR_YUYV instead
		// COLOR_YUV2BGR_YUNV = 116,
		/// YUV 4:2:2 family to RGB
		COLOR_YUV2RGBA_YUY2 = 119,
		/// YUV 4:2:2 family to RGB
		COLOR_YUV2BGRA_YUY2 = 120,
		/// YUV 4:2:2 family to RGB
		COLOR_YUV2RGBA_YVYU = 121,
		/// YUV 4:2:2 family to RGB
		COLOR_YUV2BGRA_YVYU = 122,
		// YUV 4:2:2 family to RGB
		// Duplicate, use COLOR_YUV2RGBA_YUY2 instead
		// COLOR_YUV2RGBA_YUYV = 119,
		// YUV 4:2:2 family to RGB
		// Duplicate, use COLOR_YUV2BGRA_YUY2 instead
		// COLOR_YUV2BGRA_YUYV = 120,
		// YUV 4:2:2 family to RGB
		// Duplicate, use COLOR_YUV2RGBA_YUYV instead
		// COLOR_YUV2RGBA_YUNV = 119,
		// YUV 4:2:2 family to RGB
		// Duplicate, use COLOR_YUV2BGRA_YUYV instead
		// COLOR_YUV2BGRA_YUNV = 120,
		/// YUV 4:2:2 family to RGB
		COLOR_YUV2GRAY_UYVY = 123,
		/// YUV 4:2:2 family to RGB
		COLOR_YUV2GRAY_YUY2 = 124,
		// YUV 4:2:2 family to RGB
		// Duplicate, use COLOR_YUV2GRAY_UYVY instead
		// COLOR_YUV2GRAY_Y422 = 123,
		// YUV 4:2:2 family to RGB
		// Duplicate, use COLOR_YUV2GRAY_Y422 instead
		// COLOR_YUV2GRAY_UYNV = 123,
		// YUV 4:2:2 family to RGB
		// Duplicate, use COLOR_YUV2GRAY_YUY2 instead
		// COLOR_YUV2GRAY_YVYU = 124,
		// YUV 4:2:2 family to RGB
		// Duplicate, use COLOR_YUV2GRAY_YVYU instead
		// COLOR_YUV2GRAY_YUYV = 124,
		// YUV 4:2:2 family to RGB
		// Duplicate, use COLOR_YUV2GRAY_YUYV instead
		// COLOR_YUV2GRAY_YUNV = 124,
		/// alpha premultiplication
		COLOR_RGBA2mRGBA = 125,
		/// alpha premultiplication
		COLOR_mRGBA2RGBA = 126,
		/// RGB to YUV 4:2:0 family
		COLOR_RGB2YUV_I420 = 127,
		/// RGB to YUV 4:2:0 family
		COLOR_BGR2YUV_I420 = 128,
		// RGB to YUV 4:2:0 family
		// Duplicate, use COLOR_RGB2YUV_I420 instead
		// COLOR_RGB2YUV_IYUV = 127,
		// RGB to YUV 4:2:0 family
		// Duplicate, use COLOR_BGR2YUV_I420 instead
		// COLOR_BGR2YUV_IYUV = 128,
		/// RGB to YUV 4:2:0 family
		COLOR_RGBA2YUV_I420 = 129,
		/// RGB to YUV 4:2:0 family
		COLOR_BGRA2YUV_I420 = 130,
		// RGB to YUV 4:2:0 family
		// Duplicate, use COLOR_RGBA2YUV_I420 instead
		// COLOR_RGBA2YUV_IYUV = 129,
		// RGB to YUV 4:2:0 family
		// Duplicate, use COLOR_BGRA2YUV_I420 instead
		// COLOR_BGRA2YUV_IYUV = 130,
		/// RGB to YUV 4:2:0 family
		COLOR_RGB2YUV_YV12 = 131,
		/// RGB to YUV 4:2:0 family
		COLOR_BGR2YUV_YV12 = 132,
		/// RGB to YUV 4:2:0 family
		COLOR_RGBA2YUV_YV12 = 133,
		/// RGB to YUV 4:2:0 family
		COLOR_BGRA2YUV_YV12 = 134,
		/// equivalent to RGGB Bayer pattern
		COLOR_BayerBG2BGR = 46,
		/// equivalent to GRBG Bayer pattern
		COLOR_BayerGB2BGR = 47,
		/// equivalent to BGGR Bayer pattern
		COLOR_BayerRG2BGR = 48,
		/// equivalent to GBRG Bayer pattern
		COLOR_BayerGR2BGR = 49,
		// Duplicate, use COLOR_BayerBG2BGR instead
		// COLOR_BayerRGGB2BGR = 46,
		// Duplicate, use COLOR_BayerGB2BGR instead
		// COLOR_BayerGRBG2BGR = 47,
		// Duplicate, use COLOR_BayerRG2BGR instead
		// COLOR_BayerBGGR2BGR = 48,
		// Duplicate, use COLOR_BayerGR2BGR instead
		// COLOR_BayerGBRG2BGR = 49,
		// Duplicate, use COLOR_BayerBGGR2BGR instead
		// COLOR_BayerRGGB2RGB = 48,
		// Duplicate, use COLOR_BayerGBRG2BGR instead
		// COLOR_BayerGRBG2RGB = 49,
		// Duplicate, use COLOR_BayerRGGB2BGR instead
		// COLOR_BayerBGGR2RGB = 46,
		// Duplicate, use COLOR_BayerGRBG2BGR instead
		// COLOR_BayerGBRG2RGB = 47,
		// equivalent to RGGB Bayer pattern
		// Duplicate, use COLOR_BayerRGGB2RGB instead
		// COLOR_BayerBG2RGB = 48,
		// equivalent to GRBG Bayer pattern
		// Duplicate, use COLOR_BayerGRBG2RGB instead
		// COLOR_BayerGB2RGB = 49,
		// equivalent to BGGR Bayer pattern
		// Duplicate, use COLOR_BayerBGGR2RGB instead
		// COLOR_BayerRG2RGB = 46,
		// equivalent to GBRG Bayer pattern
		// Duplicate, use COLOR_BayerGBRG2RGB instead
		// COLOR_BayerGR2RGB = 47,
		/// equivalent to RGGB Bayer pattern
		COLOR_BayerBG2GRAY = 86,
		/// equivalent to GRBG Bayer pattern
		COLOR_BayerGB2GRAY = 87,
		/// equivalent to BGGR Bayer pattern
		COLOR_BayerRG2GRAY = 88,
		/// equivalent to GBRG Bayer pattern
		COLOR_BayerGR2GRAY = 89,
		// Duplicate, use COLOR_BayerBG2GRAY instead
		// COLOR_BayerRGGB2GRAY = 86,
		// Duplicate, use COLOR_BayerGB2GRAY instead
		// COLOR_BayerGRBG2GRAY = 87,
		// Duplicate, use COLOR_BayerRG2GRAY instead
		// COLOR_BayerBGGR2GRAY = 88,
		// Duplicate, use COLOR_BayerGR2GRAY instead
		// COLOR_BayerGBRG2GRAY = 89,
		/// equivalent to RGGB Bayer pattern
		COLOR_BayerBG2BGR_VNG = 62,
		/// equivalent to GRBG Bayer pattern
		COLOR_BayerGB2BGR_VNG = 63,
		/// equivalent to BGGR Bayer pattern
		COLOR_BayerRG2BGR_VNG = 64,
		/// equivalent to GBRG Bayer pattern
		COLOR_BayerGR2BGR_VNG = 65,
		// Duplicate, use COLOR_BayerBG2BGR_VNG instead
		// COLOR_BayerRGGB2BGR_VNG = 62,
		// Duplicate, use COLOR_BayerGB2BGR_VNG instead
		// COLOR_BayerGRBG2BGR_VNG = 63,
		// Duplicate, use COLOR_BayerRG2BGR_VNG instead
		// COLOR_BayerBGGR2BGR_VNG = 64,
		// Duplicate, use COLOR_BayerGR2BGR_VNG instead
		// COLOR_BayerGBRG2BGR_VNG = 65,
		// Duplicate, use COLOR_BayerBGGR2BGR_VNG instead
		// COLOR_BayerRGGB2RGB_VNG = 64,
		// Duplicate, use COLOR_BayerGBRG2BGR_VNG instead
		// COLOR_BayerGRBG2RGB_VNG = 65,
		// Duplicate, use COLOR_BayerRGGB2BGR_VNG instead
		// COLOR_BayerBGGR2RGB_VNG = 62,
		// Duplicate, use COLOR_BayerGRBG2BGR_VNG instead
		// COLOR_BayerGBRG2RGB_VNG = 63,
		// equivalent to RGGB Bayer pattern
		// Duplicate, use COLOR_BayerRGGB2RGB_VNG instead
		// COLOR_BayerBG2RGB_VNG = 64,
		// equivalent to GRBG Bayer pattern
		// Duplicate, use COLOR_BayerGRBG2RGB_VNG instead
		// COLOR_BayerGB2RGB_VNG = 65,
		// equivalent to BGGR Bayer pattern
		// Duplicate, use COLOR_BayerBGGR2RGB_VNG instead
		// COLOR_BayerRG2RGB_VNG = 62,
		// equivalent to GBRG Bayer pattern
		// Duplicate, use COLOR_BayerGBRG2RGB_VNG instead
		// COLOR_BayerGR2RGB_VNG = 63,
		/// equivalent to RGGB Bayer pattern
		COLOR_BayerBG2BGR_EA = 135,
		/// equivalent to GRBG Bayer pattern
		COLOR_BayerGB2BGR_EA = 136,
		/// equivalent to BGGR Bayer pattern
		COLOR_BayerRG2BGR_EA = 137,
		/// equivalent to GBRG Bayer pattern
		COLOR_BayerGR2BGR_EA = 138,
		// Duplicate, use COLOR_BayerBG2BGR_EA instead
		// COLOR_BayerRGGB2BGR_EA = 135,
		// Duplicate, use COLOR_BayerGB2BGR_EA instead
		// COLOR_BayerGRBG2BGR_EA = 136,
		// Duplicate, use COLOR_BayerRG2BGR_EA instead
		// COLOR_BayerBGGR2BGR_EA = 137,
		// Duplicate, use COLOR_BayerGR2BGR_EA instead
		// COLOR_BayerGBRG2BGR_EA = 138,
		// Duplicate, use COLOR_BayerBGGR2BGR_EA instead
		// COLOR_BayerRGGB2RGB_EA = 137,
		// Duplicate, use COLOR_BayerGBRG2BGR_EA instead
		// COLOR_BayerGRBG2RGB_EA = 138,
		// Duplicate, use COLOR_BayerRGGB2BGR_EA instead
		// COLOR_BayerBGGR2RGB_EA = 135,
		// Duplicate, use COLOR_BayerGRBG2BGR_EA instead
		// COLOR_BayerGBRG2RGB_EA = 136,
		// equivalent to RGGB Bayer pattern
		// Duplicate, use COLOR_BayerRGGB2RGB_EA instead
		// COLOR_BayerBG2RGB_EA = 137,
		// equivalent to GRBG Bayer pattern
		// Duplicate, use COLOR_BayerGRBG2RGB_EA instead
		// COLOR_BayerGB2RGB_EA = 138,
		// equivalent to BGGR Bayer pattern
		// Duplicate, use COLOR_BayerBGGR2RGB_EA instead
		// COLOR_BayerRG2RGB_EA = 135,
		// equivalent to GBRG Bayer pattern
		// Duplicate, use COLOR_BayerGBRG2RGB_EA instead
		// COLOR_BayerGR2RGB_EA = 136,
		/// equivalent to RGGB Bayer pattern
		COLOR_BayerBG2BGRA = 139,
		/// equivalent to GRBG Bayer pattern
		COLOR_BayerGB2BGRA = 140,
		/// equivalent to BGGR Bayer pattern
		COLOR_BayerRG2BGRA = 141,
		/// equivalent to GBRG Bayer pattern
		COLOR_BayerGR2BGRA = 142,
		// Duplicate, use COLOR_BayerBG2BGRA instead
		// COLOR_BayerRGGB2BGRA = 139,
		// Duplicate, use COLOR_BayerGB2BGRA instead
		// COLOR_BayerGRBG2BGRA = 140,
		// Duplicate, use COLOR_BayerRG2BGRA instead
		// COLOR_BayerBGGR2BGRA = 141,
		// Duplicate, use COLOR_BayerGR2BGRA instead
		// COLOR_BayerGBRG2BGRA = 142,
		// Duplicate, use COLOR_BayerBGGR2BGRA instead
		// COLOR_BayerRGGB2RGBA = 141,
		// Duplicate, use COLOR_BayerGBRG2BGRA instead
		// COLOR_BayerGRBG2RGBA = 142,
		// Duplicate, use COLOR_BayerRGGB2BGRA instead
		// COLOR_BayerBGGR2RGBA = 139,
		// Duplicate, use COLOR_BayerGRBG2BGRA instead
		// COLOR_BayerGBRG2RGBA = 140,
		// equivalent to RGGB Bayer pattern
		// Duplicate, use COLOR_BayerRGGB2RGBA instead
		// COLOR_BayerBG2RGBA = 141,
		// equivalent to GRBG Bayer pattern
		// Duplicate, use COLOR_BayerGRBG2RGBA instead
		// COLOR_BayerGB2RGBA = 142,
		// equivalent to BGGR Bayer pattern
		// Duplicate, use COLOR_BayerBGGR2RGBA instead
		// COLOR_BayerRG2RGBA = 139,
		// equivalent to GBRG Bayer pattern
		// Duplicate, use COLOR_BayerGBRG2RGBA instead
		// COLOR_BayerGR2RGBA = 140,
		COLOR_COLORCVT_MAX = 143,
	}
	
	opencv_type_enum! { crate::imgproc::ColorConversionCodes }
	
	/// GNU Octave/MATLAB equivalent colormaps
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum ColormapTypes {
		/// 
		COLORMAP_AUTUMN = 0,
		/// 
		COLORMAP_BONE = 1,
		/// 
		COLORMAP_JET = 2,
		/// 
		COLORMAP_WINTER = 3,
		/// 
		COLORMAP_RAINBOW = 4,
		/// 
		COLORMAP_OCEAN = 5,
		/// 
		COLORMAP_SUMMER = 6,
		/// 
		COLORMAP_SPRING = 7,
		/// 
		COLORMAP_COOL = 8,
		/// 
		COLORMAP_HSV = 9,
		/// 
		COLORMAP_PINK = 10,
		/// 
		COLORMAP_HOT = 11,
		/// 
		COLORMAP_PARULA = 12,
		/// 
		COLORMAP_MAGMA = 13,
		/// 
		COLORMAP_INFERNO = 14,
		/// 
		COLORMAP_PLASMA = 15,
		/// 
		COLORMAP_VIRIDIS = 16,
		/// 
		COLORMAP_CIVIDIS = 17,
		/// 
		COLORMAP_TWILIGHT = 18,
		/// 
		COLORMAP_TWILIGHT_SHIFTED = 19,
		/// 
		COLORMAP_TURBO = 20,
		/// 
		COLORMAP_DEEPGREEN = 21,
	}
	
	opencv_type_enum! { crate::imgproc::ColormapTypes }
	
	/// connected components algorithm
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum ConnectedComponentsAlgorithmsTypes {
		/// Spaghetti [Bolelli2019](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Bolelli2019) algorithm for 8-way connectivity, Spaghetti4C [Bolelli2021](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Bolelli2021) algorithm for 4-way connectivity.
		CCL_DEFAULT = -1,
		/// SAUF [Wu2009](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Wu2009) algorithm for 8-way connectivity, SAUF algorithm for 4-way connectivity. The parallel implementation described in [Bolelli2017](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Bolelli2017) is available for SAUF.
		CCL_WU = 0,
		/// BBDT [Grana2010](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Grana2010) algorithm for 8-way connectivity, SAUF algorithm for 4-way connectivity. The parallel implementation described in [Bolelli2017](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Bolelli2017) is available for both BBDT and SAUF.
		CCL_GRANA = 1,
		/// Spaghetti [Bolelli2019](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Bolelli2019) algorithm for 8-way connectivity, Spaghetti4C [Bolelli2021](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Bolelli2021) algorithm for 4-way connectivity. The parallel implementation described in [Bolelli2017](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Bolelli2017) is available for both Spaghetti and Spaghetti4C.
		CCL_BOLELLI = 2,
		/// Same as CCL_WU. It is preferable to use the flag with the name of the algorithm (CCL_SAUF) rather than the one with the name of the first author (CCL_WU).
		CCL_SAUF = 3,
		/// Same as CCL_GRANA. It is preferable to use the flag with the name of the algorithm (CCL_BBDT) rather than the one with the name of the first author (CCL_GRANA).
		CCL_BBDT = 4,
		/// Same as CCL_BOLELLI. It is preferable to use the flag with the name of the algorithm (CCL_SPAGHETTI) rather than the one with the name of the first author (CCL_BOLELLI).
		CCL_SPAGHETTI = 5,
	}
	
	opencv_type_enum! { crate::imgproc::ConnectedComponentsAlgorithmsTypes }
	
	/// connected components statistics
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum ConnectedComponentsTypes {
		/// The leftmost (x) coordinate which is the inclusive start of the bounding
		/// box in the horizontal direction.
		CC_STAT_LEFT = 0,
		/// The topmost (y) coordinate which is the inclusive start of the bounding
		/// box in the vertical direction.
		CC_STAT_TOP = 1,
		/// The horizontal size of the bounding box
		CC_STAT_WIDTH = 2,
		/// The vertical size of the bounding box
		CC_STAT_HEIGHT = 3,
		/// The total area (in pixels) of the connected component
		CC_STAT_AREA = 4,
		/// Max enumeration value. Used internally only for memory allocation
		CC_STAT_MAX = 5,
	}
	
	opencv_type_enum! { crate::imgproc::ConnectedComponentsTypes }
	
	/// the contour approximation algorithm
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum ContourApproximationModes {
		/// stores absolutely all the contour points. That is, any 2 subsequent points (x1,y1) and
		/// (x2,y2) of the contour will be either horizontal, vertical or diagonal neighbors, that is,
		/// max(abs(x1-x2),abs(y2-y1))==1.
		CHAIN_APPROX_NONE = 1,
		/// compresses horizontal, vertical, and diagonal segments and leaves only their end points.
		/// For example, an up-right rectangular contour is encoded with 4 points.
		CHAIN_APPROX_SIMPLE = 2,
		/// applies one of the flavors of the Teh-Chin chain approximation algorithm [TehChin89](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_TehChin89)
		CHAIN_APPROX_TC89_L1 = 3,
		/// applies one of the flavors of the Teh-Chin chain approximation algorithm [TehChin89](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_TehChin89)
		CHAIN_APPROX_TC89_KCOS = 4,
	}
	
	opencv_type_enum! { crate::imgproc::ContourApproximationModes }
	
	/// distanceTransform algorithm flags
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum DistanceTransformLabelTypes {
		/// each connected component of zeros in src (as well as all the non-zero pixels closest to the
		/// connected component) will be assigned the same label
		DIST_LABEL_CCOMP = 0,
		/// each zero pixel (and all the non-zero pixels closest to it) gets its own label.
		DIST_LABEL_PIXEL = 1,
	}
	
	opencv_type_enum! { crate::imgproc::DistanceTransformLabelTypes }
	
	/// Mask size for distance transform
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum DistanceTransformMasks {
		/// mask=3
		DIST_MASK_3 = 3,
		/// mask=5
		DIST_MASK_5 = 5,
		DIST_MASK_PRECISE = 0,
	}
	
	opencv_type_enum! { crate::imgproc::DistanceTransformMasks }
	
	/// Distance types for Distance Transform and M-estimators
	/// ## See also
	/// distanceTransform, fitLine
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum DistanceTypes {
		/// User defined distance
		DIST_USER = -1,
		/// distance = |x1-x2| + |y1-y2|
		DIST_L1 = 1,
		/// the simple euclidean distance
		DIST_L2 = 2,
		/// distance = max(|x1-x2|,|y1-y2|)
		DIST_C = 3,
		/// L1-L2 metric: distance = 2(sqrt(1+x*x/2) - 1))
		DIST_L12 = 4,
		/// distance = c^2(|x|/c-log(1+|x|/c)), c = 1.3998
		DIST_FAIR = 5,
		/// distance = c^2/2(1-exp(-(x/c)^2)), c = 2.9846
		DIST_WELSCH = 6,
		/// distance = |x|<c ? x^2/2 : c(|x|-c/2), c=1.345
		DIST_HUBER = 7,
	}
	
	opencv_type_enum! { crate::imgproc::DistanceTypes }
	
	/// floodfill algorithm flags
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum FloodFillFlags {
		/// If set, the difference between the current pixel and seed pixel is considered. Otherwise,
		/// the difference between neighbor pixels is considered (that is, the range is floating).
		FLOODFILL_FIXED_RANGE = 65536,
		/// If set, the function does not change the image ( newVal is ignored), and only fills the
		/// mask with the value specified in bits 8-16 of flags as described above. This option only make
		/// sense in function variants that have the mask parameter.
		FLOODFILL_MASK_ONLY = 131072,
	}
	
	opencv_type_enum! { crate::imgproc::FloodFillFlags }
	
	/// class of the pixel in GrabCut algorithm
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum GrabCutClasses {
		/// an obvious background pixels
		GC_BGD = 0,
		/// an obvious foreground (object) pixel
		GC_FGD = 1,
		/// a possible background pixel
		GC_PR_BGD = 2,
		/// a possible foreground pixel
		GC_PR_FGD = 3,
	}
	
	opencv_type_enum! { crate::imgproc::GrabCutClasses }
	
	/// GrabCut algorithm flags
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum GrabCutModes {
		/// The function initializes the state and the mask using the provided rectangle. After that it
		/// runs iterCount iterations of the algorithm.
		GC_INIT_WITH_RECT = 0,
		/// The function initializes the state using the provided mask. Note that GC_INIT_WITH_RECT
		/// and GC_INIT_WITH_MASK can be combined. Then, all the pixels outside of the ROI are
		/// automatically initialized with GC_BGD .
		GC_INIT_WITH_MASK = 1,
		/// The value means that the algorithm should just resume.
		GC_EVAL = 2,
		/// The value means that the algorithm should just run the grabCut algorithm (a single iteration) with the fixed model
		GC_EVAL_FREEZE_MODEL = 3,
	}
	
	opencv_type_enum! { crate::imgproc::GrabCutModes }
	
	/// Only a subset of Hershey fonts <https://en.wikipedia.org/wiki/Hershey_fonts> are supported
	/// @ingroup imgproc_draw
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum HersheyFonts {
		/// normal size sans-serif font
		FONT_HERSHEY_SIMPLEX = 0,
		/// small size sans-serif font
		FONT_HERSHEY_PLAIN = 1,
		/// normal size sans-serif font (more complex than FONT_HERSHEY_SIMPLEX)
		FONT_HERSHEY_DUPLEX = 2,
		/// normal size serif font
		FONT_HERSHEY_COMPLEX = 3,
		/// normal size serif font (more complex than FONT_HERSHEY_COMPLEX)
		FONT_HERSHEY_TRIPLEX = 4,
		/// smaller version of FONT_HERSHEY_COMPLEX
		FONT_HERSHEY_COMPLEX_SMALL = 5,
		/// hand-writing style font
		FONT_HERSHEY_SCRIPT_SIMPLEX = 6,
		/// more complex variant of FONT_HERSHEY_SCRIPT_SIMPLEX
		FONT_HERSHEY_SCRIPT_COMPLEX = 7,
		/// flag for italic font
		FONT_ITALIC = 16,
	}
	
	opencv_type_enum! { crate::imgproc::HersheyFonts }
	
	/// Histogram comparison methods
	/// @ingroup imgproc_hist
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum HistCompMethods {
		/// Correlation
		/// 
		/// where
		/// 
		/// and  is a total number of histogram bins.
		HISTCMP_CORREL = 0,
		/// Chi-Square
		/// 
		HISTCMP_CHISQR = 1,
		/// Intersection
		/// 
		HISTCMP_INTERSECT = 2,
		/// Bhattacharyya distance
		/// (In fact, OpenCV computes Hellinger distance, which is related to Bhattacharyya coefficient.)
		/// 
		HISTCMP_BHATTACHARYYA = 3,
		// Synonym for HISTCMP_BHATTACHARYYA
		// Duplicate, use HISTCMP_BHATTACHARYYA instead
		// HISTCMP_HELLINGER = 3,
		/// Alternative Chi-Square
		/// 
		/// This alternative formula is regularly used for texture comparison. See e.g. [Puzicha1997](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Puzicha1997)
		HISTCMP_CHISQR_ALT = 4,
		/// Kullback-Leibler divergence
		/// 
		HISTCMP_KL_DIV = 5,
	}
	
	opencv_type_enum! { crate::imgproc::HistCompMethods }
	
	/// Variants of a Hough transform
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum HoughModes {
		/// classical or standard Hough transform. Every line is represented by two floating-point
		/// numbers  , where  is a distance between (0,0) point and the line,
		/// and  is the angle between x-axis and the normal to the line. Thus, the matrix must
		/// be (the created sequence will be) of CV_32FC2 type
		HOUGH_STANDARD = 0,
		/// probabilistic Hough transform (more efficient in case if the picture contains a few long
		/// linear segments). It returns line segments rather than the whole line. Each segment is
		/// represented by starting and ending points, and the matrix must be (the created sequence will
		/// be) of the CV_32SC4 type.
		HOUGH_PROBABILISTIC = 1,
		/// multi-scale variant of the classical Hough transform. The lines are encoded the same way as
		/// HOUGH_STANDARD.
		HOUGH_MULTI_SCALE = 2,
		/// basically *21HT*, described in [Yuen90](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Yuen90)
		HOUGH_GRADIENT = 3,
		/// variation of HOUGH_GRADIENT to get better accuracy
		HOUGH_GRADIENT_ALT = 4,
	}
	
	opencv_type_enum! { crate::imgproc::HoughModes }
	
	/// interpolation algorithm
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum InterpolationFlags {
		/// nearest neighbor interpolation
		INTER_NEAREST = 0,
		/// bilinear interpolation
		INTER_LINEAR = 1,
		/// bicubic interpolation
		INTER_CUBIC = 2,
		/// resampling using pixel area relation. It may be a preferred method for image decimation, as
		/// it gives moire'-free results. But when the image is zoomed, it is similar to the INTER_NEAREST
		/// method.
		INTER_AREA = 3,
		/// Lanczos interpolation over 8x8 neighborhood
		INTER_LANCZOS4 = 4,
		/// Bit exact bilinear interpolation
		INTER_LINEAR_EXACT = 5,
		/// Bit exact nearest neighbor interpolation. This will produce same results as
		/// the nearest neighbor method in PIL, scikit-image or Matlab.
		INTER_NEAREST_EXACT = 6,
		/// mask for interpolation codes
		INTER_MAX = 7,
		/// flag, fills all of the destination image pixels. If some of them correspond to outliers in the
		/// source image, they are set to zero
		WARP_FILL_OUTLIERS = 8,
		/// flag, inverse transformation
		/// 
		/// For example, [linear_polar] or [log_polar] transforms:
		/// - flag is __not__ set: 
		/// - flag is set: 
		WARP_INVERSE_MAP = 16,
	}
	
	opencv_type_enum! { crate::imgproc::InterpolationFlags }
	
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum InterpolationMasks {
		INTER_BITS = 5,
		INTER_BITS2 = 10,
		INTER_TAB_SIZE = 32,
		INTER_TAB_SIZE2 = 1024,
	}
	
	opencv_type_enum! { crate::imgproc::InterpolationMasks }
	
	/// Variants of Line Segment %Detector
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum LineSegmentDetectorModes {
		/// No refinement applied
		LSD_REFINE_NONE = 0,
		/// Standard refinement is applied. E.g. breaking arches into smaller straighter line approximations.
		LSD_REFINE_STD = 1,
		/// Advanced refinement. Number of false alarms is calculated, lines are
		/// refined through increase of precision, decrement in size, etc.
		LSD_REFINE_ADV = 2,
	}
	
	opencv_type_enum! { crate::imgproc::LineSegmentDetectorModes }
	
	/// types of line
	/// @ingroup imgproc_draw
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum LineTypes {
		FILLED = -1,
		/// 4-connected line
		LINE_4 = 4,
		/// 8-connected line
		LINE_8 = 8,
		/// antialiased line
		LINE_AA = 16,
	}
	
	opencv_type_enum! { crate::imgproc::LineTypes }
	
	/// Possible set of marker types used for the cv::drawMarker function
	/// @ingroup imgproc_draw
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum MarkerTypes {
		/// A crosshair marker shape
		MARKER_CROSS = 0,
		/// A 45 degree tilted crosshair marker shape
		MARKER_TILTED_CROSS = 1,
		/// A star marker shape, combination of cross and tilted cross
		MARKER_STAR = 2,
		/// A diamond marker shape
		MARKER_DIAMOND = 3,
		/// A square marker shape
		MARKER_SQUARE = 4,
		/// An upwards pointing triangle marker shape
		MARKER_TRIANGLE_UP = 5,
		/// A downwards pointing triangle marker shape
		MARKER_TRIANGLE_DOWN = 6,
	}
	
	opencv_type_enum! { crate::imgproc::MarkerTypes }
	
	/// shape of the structuring element
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum MorphShapes {
		/// a rectangular structuring element:  
		MORPH_RECT = 0,
		/// a cross-shaped structuring element:
		/// 
		MORPH_CROSS = 1,
		/// an elliptic structuring element, that is, a filled ellipse inscribed
		/// into the rectangle Rect(0, 0, esize.width, 0.esize.height)
		MORPH_ELLIPSE = 2,
	}
	
	opencv_type_enum! { crate::imgproc::MorphShapes }
	
	/// type of morphological operation
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum MorphTypes {
		/// see #erode
		MORPH_ERODE = 0,
		/// see #dilate
		MORPH_DILATE = 1,
		/// an opening operation
		/// 
		MORPH_OPEN = 2,
		/// a closing operation
		/// 
		MORPH_CLOSE = 3,
		/// a morphological gradient
		/// 
		MORPH_GRADIENT = 4,
		/// "top hat"
		/// 
		MORPH_TOPHAT = 5,
		/// "black hat"
		/// 
		MORPH_BLACKHAT = 6,
		/// "hit or miss"
		/// .- Only supported for CV_8UC1 binary images. A tutorial can be found in the documentation
		MORPH_HITMISS = 7,
	}
	
	opencv_type_enum! { crate::imgproc::MorphTypes }
	
	/// types of intersection between rectangles
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum RectanglesIntersectTypes {
		/// No intersection
		INTERSECT_NONE = 0,
		/// There is a partial intersection
		INTERSECT_PARTIAL = 1,
		/// One of the rectangle is fully enclosed in the other
		INTERSECT_FULL = 2,
	}
	
	opencv_type_enum! { crate::imgproc::RectanglesIntersectTypes }
	
	/// mode of the contour retrieval algorithm
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum RetrievalModes {
		/// retrieves only the extreme outer contours. It sets `hierarchy[i][2]=hierarchy[i][3]=-1` for
		/// all the contours.
		RETR_EXTERNAL = 0,
		/// retrieves all of the contours without establishing any hierarchical relationships.
		RETR_LIST = 1,
		/// retrieves all of the contours and organizes them into a two-level hierarchy. At the top
		/// level, there are external boundaries of the components. At the second level, there are
		/// boundaries of the holes. If there is another contour inside a hole of a connected component, it
		/// is still put at the top level.
		RETR_CCOMP = 2,
		/// retrieves all of the contours and reconstructs a full hierarchy of nested contours.
		RETR_TREE = 3,
		RETR_FLOODFILL = 4,
	}
	
	opencv_type_enum! { crate::imgproc::RetrievalModes }
	
	/// Shape matching methods
	/// 
	///  denotes object1, denotes object2
	/// 
	/// 
	/// 
	/// and  are the Hu moments of  and  , respectively.
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum ShapeMatchModes {
		/// 
		CONTOURS_MATCH_I1 = 1,
		/// 
		CONTOURS_MATCH_I2 = 2,
		/// 
		CONTOURS_MATCH_I3 = 3,
	}
	
	opencv_type_enum! { crate::imgproc::ShapeMatchModes }
	
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum SpecialFilter {
		FILTER_SCHARR = -1,
	}
	
	opencv_type_enum! { crate::imgproc::SpecialFilter }
	
	/// type of the template matching operation
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum TemplateMatchModes {
		/// !< 
		/// with mask:
		/// 
		TM_SQDIFF = 0,
		/// !< 
		/// with mask:
		/// 
		TM_SQDIFF_NORMED = 1,
		/// !< 
		/// with mask:
		/// 
		TM_CCORR = 2,
		/// !< 
		/// with mask:
		/// 
		TM_CCORR_NORMED = 3,
		/// !< 
		/// where
		/// 
		/// with mask:
		/// 
		TM_CCOEFF = 4,
		/// !< 
		TM_CCOEFF_NORMED = 5,
	}
	
	opencv_type_enum! { crate::imgproc::TemplateMatchModes }
	
	/// type of the threshold operation
	/// 
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum ThresholdTypes {
		/// 
		THRESH_BINARY = 0,
		/// 
		THRESH_BINARY_INV = 1,
		/// 
		THRESH_TRUNC = 2,
		/// 
		THRESH_TOZERO = 3,
		/// 
		THRESH_TOZERO_INV = 4,
		THRESH_MASK = 7,
		/// flag, use Otsu algorithm to choose the optimal threshold value
		THRESH_OTSU = 8,
		/// flag, use Triangle algorithm to choose the optimal threshold value
		THRESH_TRIANGLE = 16,
	}
	
	opencv_type_enum! { crate::imgproc::ThresholdTypes }
	
	/// \brief Specify the polar mapping mode
	/// ## See also
	/// warpPolar
	#[repr(C)]
	#[derive(Copy, Clone, Debug, PartialEq, Eq)]
	pub enum WarpPolarMode {
		/// Remaps an image to/from polar space.
		WARP_POLAR_LINEAR = 0,
		/// Remaps an image to/from semilog-polar space.
		WARP_POLAR_LOG = 256,
	}
	
	opencv_type_enum! { crate::imgproc::WarpPolarMode }
	
	/// \overload
	/// 
	/// Finds edges in an image using the Canny algorithm with custom image gradient.
	/// 
	/// ## Parameters
	/// * dx: 16-bit x derivative of input image (CV_16SC1 or CV_16SC3).
	/// * dy: 16-bit y derivative of input image (same type as dx).
	/// * edges: output edge map; single channels 8-bit image, which has the same size as image .
	/// * threshold1: first threshold for the hysteresis procedure.
	/// * threshold2: second threshold for the hysteresis procedure.
	/// * L2gradient: a flag, indicating whether a more accurate  norm
	///  should be used to calculate the image gradient magnitude (
	/// L2gradient=true ), or whether the default  norm  is enough (
	/// L2gradient=false ).
	/// 
	/// ## Note
	/// This alternative version of [canny_derivative] function uses the following default values for its arguments:
	/// * l2gradient: false
	#[inline]
	pub fn canny_derivative_def(dx: &impl core::ToInputArray, dy: &impl core::ToInputArray, edges: &mut impl core::ToOutputArray, threshold1: f64, threshold2: f64) -> Result<()> {
		input_array_arg!(dx);
		input_array_arg!(dy);
		output_array_arg!(edges);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_Canny_const__InputArrayR_const__InputArrayR_const__OutputArrayR_double_double(dx.as_raw__InputArray(), dy.as_raw__InputArray(), edges.as_raw__OutputArray(), threshold1, threshold2, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// \overload
	/// 
	/// Finds edges in an image using the Canny algorithm with custom image gradient.
	/// 
	/// ## Parameters
	/// * dx: 16-bit x derivative of input image (CV_16SC1 or CV_16SC3).
	/// * dy: 16-bit y derivative of input image (same type as dx).
	/// * edges: output edge map; single channels 8-bit image, which has the same size as image .
	/// * threshold1: first threshold for the hysteresis procedure.
	/// * threshold2: second threshold for the hysteresis procedure.
	/// * L2gradient: a flag, indicating whether a more accurate  norm
	///  should be used to calculate the image gradient magnitude (
	/// L2gradient=true ), or whether the default  norm  is enough (
	/// L2gradient=false ).
	/// 
	/// ## C++ default parameters
	/// * l2gradient: false
	#[inline]
	pub fn canny_derivative(dx: &impl core::ToInputArray, dy: &impl core::ToInputArray, edges: &mut impl core::ToOutputArray, threshold1: f64, threshold2: f64, l2gradient: bool) -> Result<()> {
		input_array_arg!(dx);
		input_array_arg!(dy);
		output_array_arg!(edges);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_Canny_const__InputArrayR_const__InputArrayR_const__OutputArrayR_double_double_bool(dx.as_raw__InputArray(), dy.as_raw__InputArray(), edges.as_raw__OutputArray(), threshold1, threshold2, l2gradient, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Finds edges in an image using the Canny algorithm [Canny86](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Canny86) .
	/// 
	/// The function finds edges in the input image and marks them in the output map edges using the
	/// Canny algorithm. The smallest value between threshold1 and threshold2 is used for edge linking. The
	/// largest value is used to find initial segments of strong edges. See
	/// <http://en.wikipedia.org/wiki/Canny_edge_detector>
	/// 
	/// ## Parameters
	/// * image: 8-bit input image.
	/// * edges: output edge map; single channels 8-bit image, which has the same size as image .
	/// * threshold1: first threshold for the hysteresis procedure.
	/// * threshold2: second threshold for the hysteresis procedure.
	/// * apertureSize: aperture size for the Sobel operator.
	/// * L2gradient: a flag, indicating whether a more accurate  norm
	///  should be used to calculate the image gradient magnitude (
	/// L2gradient=true ), or whether the default  norm  is enough (
	/// L2gradient=false ).
	/// 
	/// ## Note
	/// This alternative version of [canny] function uses the following default values for its arguments:
	/// * aperture_size: 3
	/// * l2gradient: false
	#[inline]
	pub fn canny_def(image: &impl core::ToInputArray, edges: &mut impl core::ToOutputArray, threshold1: f64, threshold2: f64) -> Result<()> {
		input_array_arg!(image);
		output_array_arg!(edges);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_Canny_const__InputArrayR_const__OutputArrayR_double_double(image.as_raw__InputArray(), edges.as_raw__OutputArray(), threshold1, threshold2, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Finds edges in an image using the Canny algorithm [Canny86](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Canny86) .
	/// 
	/// The function finds edges in the input image and marks them in the output map edges using the
	/// Canny algorithm. The smallest value between threshold1 and threshold2 is used for edge linking. The
	/// largest value is used to find initial segments of strong edges. See
	/// <http://en.wikipedia.org/wiki/Canny_edge_detector>
	/// 
	/// ## Parameters
	/// * image: 8-bit input image.
	/// * edges: output edge map; single channels 8-bit image, which has the same size as image .
	/// * threshold1: first threshold for the hysteresis procedure.
	/// * threshold2: second threshold for the hysteresis procedure.
	/// * apertureSize: aperture size for the Sobel operator.
	/// * L2gradient: a flag, indicating whether a more accurate  norm
	///  should be used to calculate the image gradient magnitude (
	/// L2gradient=true ), or whether the default  norm  is enough (
	/// L2gradient=false ).
	/// 
	/// ## C++ default parameters
	/// * aperture_size: 3
	/// * l2gradient: false
	#[inline]
	pub fn canny(image: &impl core::ToInputArray, edges: &mut impl core::ToOutputArray, threshold1: f64, threshold2: f64, aperture_size: i32, l2gradient: bool) -> Result<()> {
		input_array_arg!(image);
		output_array_arg!(edges);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_Canny_const__InputArrayR_const__OutputArrayR_double_double_int_bool(image.as_raw__InputArray(), edges.as_raw__OutputArray(), threshold1, threshold2, aperture_size, l2gradient, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Computes the "minimal work" distance between two weighted point configurations.
	/// 
	/// The function computes the earth mover distance and/or a lower boundary of the distance between the
	/// two weighted point configurations. One of the applications described in [RubnerSept98](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_RubnerSept98),
	/// [Rubner2000](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Rubner2000) is multi-dimensional histogram comparison for image retrieval. EMD is a transportation
	/// problem that is solved using some modification of a simplex algorithm, thus the complexity is
	/// exponential in the worst case, though, on average it is much faster. In the case of a real metric
	/// the lower boundary can be calculated even faster (using linear-time algorithm) and it can be used
	/// to determine roughly whether the two signatures are far enough so that they cannot relate to the
	/// same object.
	/// 
	/// ## Parameters
	/// * signature1: First signature, a  floating-point matrix.
	/// Each row stores the point weight followed by the point coordinates. The matrix is allowed to have
	/// a single column (weights only) if the user-defined cost matrix is used. The weights must be
	/// non-negative and have at least one non-zero value.
	/// * signature2: Second signature of the same format as signature1 , though the number of rows
	/// may be different. The total weights may be different. In this case an extra "dummy" point is added
	/// to either signature1 or signature2. The weights must be non-negative and have at least one non-zero
	/// value.
	/// * distType: Used metric. See #DistanceTypes.
	/// * cost: User-defined  cost matrix. Also, if a cost matrix
	/// is used, lower boundary lowerBound cannot be calculated because it needs a metric function.
	/// * lowerBound: Optional input/output parameter: lower boundary of a distance between the two
	/// signatures that is a distance between mass centers. The lower boundary may not be calculated if
	/// the user-defined cost matrix is used, the total weights of point configurations are not equal, or
	/// if the signatures consist of weights only (the signature matrices have a single column). You
	/// **must** initialize \*lowerBound . If the calculated distance between mass centers is greater or
	/// equal to \*lowerBound (it means that the signatures are far enough), the function does not
	/// calculate EMD. In any case \*lowerBound is set to the calculated distance between mass centers on
	/// return. Thus, if you want to calculate both distance between mass centers and EMD, \*lowerBound
	/// should be set to 0.
	/// * flow: Resultant  flow matrix:  is
	/// a flow from  -th point of signature1 to  -th point of signature2 .
	/// 
	/// ## Note
	/// This alternative version of [emd] function uses the following default values for its arguments:
	/// * cost: noArray()
	/// * lower_bound: 0
	/// * flow: noArray()
	#[inline]
	pub fn emd_def(signature1: &impl core::ToInputArray, signature2: &impl core::ToInputArray, dist_type: i32) -> Result<f32> {
		input_array_arg!(signature1);
		input_array_arg!(signature2);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_EMD_const__InputArrayR_const__InputArrayR_int(signature1.as_raw__InputArray(), signature2.as_raw__InputArray(), dist_type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Computes the "minimal work" distance between two weighted point configurations.
	/// 
	/// The function computes the earth mover distance and/or a lower boundary of the distance between the
	/// two weighted point configurations. One of the applications described in [RubnerSept98](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_RubnerSept98),
	/// [Rubner2000](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Rubner2000) is multi-dimensional histogram comparison for image retrieval. EMD is a transportation
	/// problem that is solved using some modification of a simplex algorithm, thus the complexity is
	/// exponential in the worst case, though, on average it is much faster. In the case of a real metric
	/// the lower boundary can be calculated even faster (using linear-time algorithm) and it can be used
	/// to determine roughly whether the two signatures are far enough so that they cannot relate to the
	/// same object.
	/// 
	/// ## Parameters
	/// * signature1: First signature, a  floating-point matrix.
	/// Each row stores the point weight followed by the point coordinates. The matrix is allowed to have
	/// a single column (weights only) if the user-defined cost matrix is used. The weights must be
	/// non-negative and have at least one non-zero value.
	/// * signature2: Second signature of the same format as signature1 , though the number of rows
	/// may be different. The total weights may be different. In this case an extra "dummy" point is added
	/// to either signature1 or signature2. The weights must be non-negative and have at least one non-zero
	/// value.
	/// * distType: Used metric. See #DistanceTypes.
	/// * cost: User-defined  cost matrix. Also, if a cost matrix
	/// is used, lower boundary lowerBound cannot be calculated because it needs a metric function.
	/// * lowerBound: Optional input/output parameter: lower boundary of a distance between the two
	/// signatures that is a distance between mass centers. The lower boundary may not be calculated if
	/// the user-defined cost matrix is used, the total weights of point configurations are not equal, or
	/// if the signatures consist of weights only (the signature matrices have a single column). You
	/// **must** initialize \*lowerBound . If the calculated distance between mass centers is greater or
	/// equal to \*lowerBound (it means that the signatures are far enough), the function does not
	/// calculate EMD. In any case \*lowerBound is set to the calculated distance between mass centers on
	/// return. Thus, if you want to calculate both distance between mass centers and EMD, \*lowerBound
	/// should be set to 0.
	/// * flow: Resultant  flow matrix:  is
	/// a flow from  -th point of signature1 to  -th point of signature2 .
	/// 
	/// ## C++ default parameters
	/// * cost: noArray()
	/// * lower_bound: 0
	/// * flow: noArray()
	#[inline]
	pub fn emd(signature1: &impl core::ToInputArray, signature2: &impl core::ToInputArray, dist_type: i32, cost: &impl core::ToInputArray, lower_bound: Option<&mut f32>, flow: &mut impl core::ToOutputArray) -> Result<f32> {
		input_array_arg!(signature1);
		input_array_arg!(signature2);
		input_array_arg!(cost);
		output_array_arg!(flow);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_EMD_const__InputArrayR_const__InputArrayR_int_const__InputArrayR_floatX_const__OutputArrayR(signature1.as_raw__InputArray(), signature2.as_raw__InputArray(), dist_type, cost.as_raw__InputArray(), lower_bound.map_or(::core::ptr::null_mut(), |lower_bound| lower_bound as *mut _), flow.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Blurs an image using a Gaussian filter.
	/// 
	/// The function convolves the source image with the specified Gaussian kernel. In-place filtering is
	/// supported.
	/// 
	/// ## Parameters
	/// * src: input image; the image can have any number of channels, which are processed
	/// independently, but the depth should be CV_8U, CV_16U, CV_16S, CV_32F or CV_64F.
	/// * dst: output image of the same size and type as src.
	/// * ksize: Gaussian kernel size. ksize.width and ksize.height can differ but they both must be
	/// positive and odd. Or, they can be zero's and then they are computed from sigma.
	/// * sigmaX: Gaussian kernel standard deviation in X direction.
	/// * sigmaY: Gaussian kernel standard deviation in Y direction; if sigmaY is zero, it is set to be
	/// equal to sigmaX, if both sigmas are zeros, they are computed from ksize.width and ksize.height,
	/// respectively (see [get_gaussian_kernel] for details); to fully control the result regardless of
	/// possible future modifications of all this semantics, it is recommended to specify all of ksize,
	/// sigmaX, and sigmaY.
	/// * borderType: pixel extrapolation method, see #BorderTypes. [BORDER_WRAP] is not supported.
	/// ## See also
	/// sepFilter2D, filter2D, blur, boxFilter, bilateralFilter, medianBlur
	/// 
	/// ## Note
	/// This alternative version of [gaussian_blur] function uses the following default values for its arguments:
	/// * sigma_y: 0
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn gaussian_blur_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, ksize: core::Size, sigma_x: f64) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_GaussianBlur_const__InputArrayR_const__OutputArrayR_Size_double(src.as_raw__InputArray(), dst.as_raw__OutputArray(), ksize.opencv_as_extern(), sigma_x, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Blurs an image using a Gaussian filter.
	/// 
	/// The function convolves the source image with the specified Gaussian kernel. In-place filtering is
	/// supported.
	/// 
	/// ## Parameters
	/// * src: input image; the image can have any number of channels, which are processed
	/// independently, but the depth should be CV_8U, CV_16U, CV_16S, CV_32F or CV_64F.
	/// * dst: output image of the same size and type as src.
	/// * ksize: Gaussian kernel size. ksize.width and ksize.height can differ but they both must be
	/// positive and odd. Or, they can be zero's and then they are computed from sigma.
	/// * sigmaX: Gaussian kernel standard deviation in X direction.
	/// * sigmaY: Gaussian kernel standard deviation in Y direction; if sigmaY is zero, it is set to be
	/// equal to sigmaX, if both sigmas are zeros, they are computed from ksize.width and ksize.height,
	/// respectively (see [get_gaussian_kernel] for details); to fully control the result regardless of
	/// possible future modifications of all this semantics, it is recommended to specify all of ksize,
	/// sigmaX, and sigmaY.
	/// * borderType: pixel extrapolation method, see #BorderTypes. [BORDER_WRAP] is not supported.
	/// ## See also
	/// sepFilter2D, filter2D, blur, boxFilter, bilateralFilter, medianBlur
	/// 
	/// ## C++ default parameters
	/// * sigma_y: 0
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn gaussian_blur(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, ksize: core::Size, sigma_x: f64, sigma_y: f64, border_type: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_GaussianBlur_const__InputArrayR_const__OutputArrayR_Size_double_double_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), ksize.opencv_as_extern(), sigma_x, sigma_y, border_type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Finds circles in a grayscale image using the Hough transform.
	/// 
	/// The function finds circles in a grayscale image using a modification of the Hough transform.
	/// 
	/// Example: :
	/// @include snippets/imgproc_HoughLinesCircles.cpp
	/// 
	/// 
	/// Note: Usually the function detects the centers of circles well. However, it may fail to find correct
	/// radii. You can assist to the function by specifying the radius range ( minRadius and maxRadius ) if
	/// you know it. Or, in the case of [HOUGH_GRADIENT] method you may set maxRadius to a negative number
	/// to return centers only without radius search, and find the correct radius using an additional procedure.
	/// 
	/// It also helps to smooth image a bit unless it's already soft. For example,
	/// GaussianBlur() with 7x7 kernel and 1.5x1.5 sigma or similar blurring may help.
	/// 
	/// ## Parameters
	/// * image: 8-bit, single-channel, grayscale input image.
	/// * circles: Output vector of found circles. Each vector is encoded as  3 or 4 element
	/// floating-point vector  or  .
	/// * method: Detection method, see #HoughModes. The available methods are [HOUGH_GRADIENT] and #HOUGH_GRADIENT_ALT.
	/// * dp: Inverse ratio of the accumulator resolution to the image resolution. For example, if
	/// dp=1 , the accumulator has the same resolution as the input image. If dp=2 , the accumulator has
	/// half as big width and height. For [HOUGH_GRADIENT_ALT] the recommended value is dp=1.5,
	/// unless some small very circles need to be detected.
	/// * minDist: Minimum distance between the centers of the detected circles. If the parameter is
	/// too small, multiple neighbor circles may be falsely detected in addition to a true one. If it is
	/// too large, some circles may be missed.
	/// * param1: First method-specific parameter. In case of [HOUGH_GRADIENT] and #HOUGH_GRADIENT_ALT,
	/// it is the higher threshold of the two passed to the Canny edge detector (the lower one is twice smaller).
	/// Note that [HOUGH_GRADIENT_ALT] uses [scharr] algorithm to compute image derivatives, so the threshold value
	/// shough normally be higher, such as 300 or normally exposed and contrasty images.
	/// * param2: Second method-specific parameter. In case of #HOUGH_GRADIENT, it is the
	/// accumulator threshold for the circle centers at the detection stage. The smaller it is, the more
	/// false circles may be detected. Circles, corresponding to the larger accumulator values, will be
	/// returned first. In the case of [HOUGH_GRADIENT_ALT] algorithm, this is the circle "perfectness" measure.
	/// The closer it to 1, the better shaped circles algorithm selects. In most cases 0.9 should be fine.
	/// If you want get better detection of small circles, you may decrease it to 0.85, 0.8 or even less.
	/// But then also try to limit the search range [minRadius, maxRadius] to avoid many false circles.
	/// * minRadius: Minimum circle radius.
	/// * maxRadius: Maximum circle radius. If <= 0, uses the maximum image dimension. If < 0, [HOUGH_GRADIENT] returns
	/// centers without finding the radius. [HOUGH_GRADIENT_ALT] always computes circle radiuses.
	/// ## See also
	/// fitEllipse, minEnclosingCircle
	/// 
	/// ## Note
	/// This alternative version of [hough_circles] function uses the following default values for its arguments:
	/// * param1: 100
	/// * param2: 100
	/// * min_radius: 0
	/// * max_radius: 0
	#[inline]
	pub fn hough_circles_def(image: &impl core::ToInputArray, circles: &mut impl core::ToOutputArray, method: i32, dp: f64, min_dist: f64) -> Result<()> {
		input_array_arg!(image);
		output_array_arg!(circles);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_HoughCircles_const__InputArrayR_const__OutputArrayR_int_double_double(image.as_raw__InputArray(), circles.as_raw__OutputArray(), method, dp, min_dist, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Finds circles in a grayscale image using the Hough transform.
	/// 
	/// The function finds circles in a grayscale image using a modification of the Hough transform.
	/// 
	/// Example: :
	/// @include snippets/imgproc_HoughLinesCircles.cpp
	/// 
	/// 
	/// Note: Usually the function detects the centers of circles well. However, it may fail to find correct
	/// radii. You can assist to the function by specifying the radius range ( minRadius and maxRadius ) if
	/// you know it. Or, in the case of [HOUGH_GRADIENT] method you may set maxRadius to a negative number
	/// to return centers only without radius search, and find the correct radius using an additional procedure.
	/// 
	/// It also helps to smooth image a bit unless it's already soft. For example,
	/// GaussianBlur() with 7x7 kernel and 1.5x1.5 sigma or similar blurring may help.
	/// 
	/// ## Parameters
	/// * image: 8-bit, single-channel, grayscale input image.
	/// * circles: Output vector of found circles. Each vector is encoded as  3 or 4 element
	/// floating-point vector  or  .
	/// * method: Detection method, see #HoughModes. The available methods are [HOUGH_GRADIENT] and #HOUGH_GRADIENT_ALT.
	/// * dp: Inverse ratio of the accumulator resolution to the image resolution. For example, if
	/// dp=1 , the accumulator has the same resolution as the input image. If dp=2 , the accumulator has
	/// half as big width and height. For [HOUGH_GRADIENT_ALT] the recommended value is dp=1.5,
	/// unless some small very circles need to be detected.
	/// * minDist: Minimum distance between the centers of the detected circles. If the parameter is
	/// too small, multiple neighbor circles may be falsely detected in addition to a true one. If it is
	/// too large, some circles may be missed.
	/// * param1: First method-specific parameter. In case of [HOUGH_GRADIENT] and #HOUGH_GRADIENT_ALT,
	/// it is the higher threshold of the two passed to the Canny edge detector (the lower one is twice smaller).
	/// Note that [HOUGH_GRADIENT_ALT] uses [scharr] algorithm to compute image derivatives, so the threshold value
	/// shough normally be higher, such as 300 or normally exposed and contrasty images.
	/// * param2: Second method-specific parameter. In case of #HOUGH_GRADIENT, it is the
	/// accumulator threshold for the circle centers at the detection stage. The smaller it is, the more
	/// false circles may be detected. Circles, corresponding to the larger accumulator values, will be
	/// returned first. In the case of [HOUGH_GRADIENT_ALT] algorithm, this is the circle "perfectness" measure.
	/// The closer it to 1, the better shaped circles algorithm selects. In most cases 0.9 should be fine.
	/// If you want get better detection of small circles, you may decrease it to 0.85, 0.8 or even less.
	/// But then also try to limit the search range [minRadius, maxRadius] to avoid many false circles.
	/// * minRadius: Minimum circle radius.
	/// * maxRadius: Maximum circle radius. If <= 0, uses the maximum image dimension. If < 0, [HOUGH_GRADIENT] returns
	/// centers without finding the radius. [HOUGH_GRADIENT_ALT] always computes circle radiuses.
	/// ## See also
	/// fitEllipse, minEnclosingCircle
	/// 
	/// ## C++ default parameters
	/// * param1: 100
	/// * param2: 100
	/// * min_radius: 0
	/// * max_radius: 0
	#[inline]
	pub fn hough_circles(image: &impl core::ToInputArray, circles: &mut impl core::ToOutputArray, method: i32, dp: f64, min_dist: f64, param1: f64, param2: f64, min_radius: i32, max_radius: i32) -> Result<()> {
		input_array_arg!(image);
		output_array_arg!(circles);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_HoughCircles_const__InputArrayR_const__OutputArrayR_int_double_double_double_double_int_int(image.as_raw__InputArray(), circles.as_raw__OutputArray(), method, dp, min_dist, param1, param2, min_radius, max_radius, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Finds line segments in a binary image using the probabilistic Hough transform.
	/// 
	/// The function implements the probabilistic Hough transform algorithm for line detection, described
	/// in [Matas00](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Matas00)
	/// 
	/// See the line detection example below:
	/// @include snippets/imgproc_HoughLinesP.cpp
	/// This is a sample picture the function parameters have been tuned for:
	/// 
	/// 
	/// 
	/// And this is the output of the above program in case of the probabilistic Hough transform:
	/// 
	/// 
	/// 
	/// ## Parameters
	/// * image: 8-bit, single-channel binary source image. The image may be modified by the function.
	/// * lines: Output vector of lines. Each line is represented by a 4-element vector
	///  , where  and  are the ending points of each detected
	/// line segment.
	/// * rho: Distance resolution of the accumulator in pixels.
	/// * theta: Angle resolution of the accumulator in radians.
	/// * threshold: %Accumulator threshold parameter. Only those lines are returned that get enough
	/// votes (  ).
	/// * minLineLength: Minimum line length. Line segments shorter than that are rejected.
	/// * maxLineGap: Maximum allowed gap between points on the same line to link them.
	/// ## See also
	/// LineSegmentDetector
	/// 
	/// ## Note
	/// This alternative version of [hough_lines_p] function uses the following default values for its arguments:
	/// * min_line_length: 0
	/// * max_line_gap: 0
	#[inline]
	pub fn hough_lines_p_def(image: &impl core::ToInputArray, lines: &mut impl core::ToOutputArray, rho: f64, theta: f64, threshold: i32) -> Result<()> {
		input_array_arg!(image);
		output_array_arg!(lines);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_HoughLinesP_const__InputArrayR_const__OutputArrayR_double_double_int(image.as_raw__InputArray(), lines.as_raw__OutputArray(), rho, theta, threshold, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Finds line segments in a binary image using the probabilistic Hough transform.
	/// 
	/// The function implements the probabilistic Hough transform algorithm for line detection, described
	/// in [Matas00](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Matas00)
	/// 
	/// See the line detection example below:
	/// @include snippets/imgproc_HoughLinesP.cpp
	/// This is a sample picture the function parameters have been tuned for:
	/// 
	/// 
	/// 
	/// And this is the output of the above program in case of the probabilistic Hough transform:
	/// 
	/// 
	/// 
	/// ## Parameters
	/// * image: 8-bit, single-channel binary source image. The image may be modified by the function.
	/// * lines: Output vector of lines. Each line is represented by a 4-element vector
	///  , where  and  are the ending points of each detected
	/// line segment.
	/// * rho: Distance resolution of the accumulator in pixels.
	/// * theta: Angle resolution of the accumulator in radians.
	/// * threshold: %Accumulator threshold parameter. Only those lines are returned that get enough
	/// votes (  ).
	/// * minLineLength: Minimum line length. Line segments shorter than that are rejected.
	/// * maxLineGap: Maximum allowed gap between points on the same line to link them.
	/// ## See also
	/// LineSegmentDetector
	/// 
	/// ## C++ default parameters
	/// * min_line_length: 0
	/// * max_line_gap: 0
	#[inline]
	pub fn hough_lines_p(image: &impl core::ToInputArray, lines: &mut impl core::ToOutputArray, rho: f64, theta: f64, threshold: i32, min_line_length: f64, max_line_gap: f64) -> Result<()> {
		input_array_arg!(image);
		output_array_arg!(lines);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_HoughLinesP_const__InputArrayR_const__OutputArrayR_double_double_int_double_double(image.as_raw__InputArray(), lines.as_raw__OutputArray(), rho, theta, threshold, min_line_length, max_line_gap, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Finds lines in a set of points using the standard Hough transform.
	/// 
	/// The function finds lines in a set of points using a modification of the Hough transform.
	/// @include snippets/imgproc_HoughLinesPointSet.cpp
	/// ## Parameters
	/// * point: Input vector of points. Each vector must be encoded as a Point vector . Type must be CV_32FC2 or CV_32SC2.
	/// * lines: Output vector of found lines. Each vector is encoded as a vector<Vec3d> .
	/// The larger the value of 'votes', the higher the reliability of the Hough line.
	/// * lines_max: Max count of Hough lines.
	/// * threshold: %Accumulator threshold parameter. Only those lines are returned that get enough
	/// votes (  ).
	/// * min_rho: Minimum value for  for the accumulator (Note:  can be negative. The absolute value  is the distance of a line to the origin.).
	/// * max_rho: Maximum value for  for the accumulator.
	/// * rho_step: Distance resolution of the accumulator.
	/// * min_theta: Minimum angle value of the accumulator in radians.
	/// * max_theta: Upper bound for the angle value of the accumulator in radians. The actual maximum
	/// angle may be slightly less than max_theta, depending on the parameters min_theta and theta_step.
	/// * theta_step: Angle resolution of the accumulator in radians.
	#[inline]
	pub fn hough_lines_point_set(point: &impl core::ToInputArray, lines: &mut impl core::ToOutputArray, lines_max: i32, threshold: i32, min_rho: f64, max_rho: f64, rho_step: f64, min_theta: f64, max_theta: f64, theta_step: f64) -> Result<()> {
		input_array_arg!(point);
		output_array_arg!(lines);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_HoughLinesPointSet_const__InputArrayR_const__OutputArrayR_int_int_double_double_double_double_double_double(point.as_raw__InputArray(), lines.as_raw__OutputArray(), lines_max, threshold, min_rho, max_rho, rho_step, min_theta, max_theta, theta_step, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Finds lines in a binary image using the standard Hough transform.
	/// 
	/// The function implements the standard or standard multi-scale Hough transform algorithm for line
	/// detection. See <http://homepages.inf.ed.ac.uk/rbf/HIPR2/hough.htm> for a good explanation of Hough
	/// transform.
	/// 
	/// ## Parameters
	/// * image: 8-bit, single-channel binary source image. The image may be modified by the function.
	/// * lines: Output vector of lines. Each line is represented by a 2 or 3 element vector
	///  or , where  is the distance from
	/// the coordinate origin  (top-left corner of the image),  is the line rotation
	/// angle in radians (  ), and
	///  is the value of accumulator.
	/// * rho: Distance resolution of the accumulator in pixels.
	/// * theta: Angle resolution of the accumulator in radians.
	/// * threshold: %Accumulator threshold parameter. Only those lines are returned that get enough
	/// votes (  ).
	/// * srn: For the multi-scale Hough transform, it is a divisor for the distance resolution rho.
	/// The coarse accumulator distance resolution is rho and the accurate accumulator resolution is
	/// rho/srn. If both srn=0 and stn=0, the classical Hough transform is used. Otherwise, both these
	/// parameters should be positive.
	/// * stn: For the multi-scale Hough transform, it is a divisor for the distance resolution theta.
	/// * min_theta: For standard and multi-scale Hough transform, minimum angle to check for lines.
	/// Must fall between 0 and max_theta.
	/// * max_theta: For standard and multi-scale Hough transform, an upper bound for the angle.
	/// Must fall between min_theta and CV_PI. The actual maximum angle in the accumulator may be slightly
	/// less than max_theta, depending on the parameters min_theta and theta.
	/// 
	/// ## Note
	/// This alternative version of [hough_lines] function uses the following default values for its arguments:
	/// * srn: 0
	/// * stn: 0
	/// * min_theta: 0
	/// * max_theta: CV_PI
	#[inline]
	pub fn hough_lines_def(image: &impl core::ToInputArray, lines: &mut impl core::ToOutputArray, rho: f64, theta: f64, threshold: i32) -> Result<()> {
		input_array_arg!(image);
		output_array_arg!(lines);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_HoughLines_const__InputArrayR_const__OutputArrayR_double_double_int(image.as_raw__InputArray(), lines.as_raw__OutputArray(), rho, theta, threshold, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Finds lines in a binary image using the standard Hough transform.
	/// 
	/// The function implements the standard or standard multi-scale Hough transform algorithm for line
	/// detection. See <http://homepages.inf.ed.ac.uk/rbf/HIPR2/hough.htm> for a good explanation of Hough
	/// transform.
	/// 
	/// ## Parameters
	/// * image: 8-bit, single-channel binary source image. The image may be modified by the function.
	/// * lines: Output vector of lines. Each line is represented by a 2 or 3 element vector
	///  or , where  is the distance from
	/// the coordinate origin  (top-left corner of the image),  is the line rotation
	/// angle in radians (  ), and
	///  is the value of accumulator.
	/// * rho: Distance resolution of the accumulator in pixels.
	/// * theta: Angle resolution of the accumulator in radians.
	/// * threshold: %Accumulator threshold parameter. Only those lines are returned that get enough
	/// votes (  ).
	/// * srn: For the multi-scale Hough transform, it is a divisor for the distance resolution rho.
	/// The coarse accumulator distance resolution is rho and the accurate accumulator resolution is
	/// rho/srn. If both srn=0 and stn=0, the classical Hough transform is used. Otherwise, both these
	/// parameters should be positive.
	/// * stn: For the multi-scale Hough transform, it is a divisor for the distance resolution theta.
	/// * min_theta: For standard and multi-scale Hough transform, minimum angle to check for lines.
	/// Must fall between 0 and max_theta.
	/// * max_theta: For standard and multi-scale Hough transform, an upper bound for the angle.
	/// Must fall between min_theta and CV_PI. The actual maximum angle in the accumulator may be slightly
	/// less than max_theta, depending on the parameters min_theta and theta.
	/// 
	/// ## C++ default parameters
	/// * srn: 0
	/// * stn: 0
	/// * min_theta: 0
	/// * max_theta: CV_PI
	#[inline]
	pub fn hough_lines(image: &impl core::ToInputArray, lines: &mut impl core::ToOutputArray, rho: f64, theta: f64, threshold: i32, srn: f64, stn: f64, min_theta: f64, max_theta: f64) -> Result<()> {
		input_array_arg!(image);
		output_array_arg!(lines);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_HoughLines_const__InputArrayR_const__OutputArrayR_double_double_int_double_double_double_double(image.as_raw__InputArray(), lines.as_raw__OutputArray(), rho, theta, threshold, srn, stn, min_theta, max_theta, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates seven Hu invariants.
	/// 
	/// The function calculates seven Hu invariants (introduced in [Hu62](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Hu62); see also
	/// <http://en.wikipedia.org/wiki/Image_moment>) defined as:
	/// 
	/// 
	/// 
	/// where  stands for  .
	/// 
	/// These values are proved to be invariants to the image scale, rotation, and reflection except the
	/// seventh one, whose sign is changed by reflection. This invariance is proved with the assumption of
	/// infinite image resolution. In case of raster images, the computed Hu invariants for the original and
	/// transformed images are a bit different.
	/// 
	/// ## Parameters
	/// * moments: Input moments computed with moments .
	/// * hu: Output Hu invariants.
	/// ## See also
	/// matchShapes
	/// 
	/// ## Overloaded parameters
	#[inline]
	pub fn hu_moments_1(m: core::Moments, hu: &mut impl core::ToOutputArray) -> Result<()> {
		output_array_arg!(hu);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_HuMoments_const_MomentsR_const__OutputArrayR(&m, hu.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates seven Hu invariants.
	/// 
	/// The function calculates seven Hu invariants (introduced in [Hu62](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Hu62); see also
	/// <http://en.wikipedia.org/wiki/Image_moment>) defined as:
	/// 
	/// 
	/// 
	/// where  stands for  .
	/// 
	/// These values are proved to be invariants to the image scale, rotation, and reflection except the
	/// seventh one, whose sign is changed by reflection. This invariance is proved with the assumption of
	/// infinite image resolution. In case of raster images, the computed Hu invariants for the original and
	/// transformed images are a bit different.
	/// 
	/// ## Parameters
	/// * moments: Input moments computed with moments .
	/// * hu: Output Hu invariants.
	/// ## See also
	/// matchShapes
	#[inline]
	pub fn hu_moments(moments: core::Moments, hu: &mut [f64; 7]) -> Result<()> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_HuMoments_const_MomentsR_doubleXX(&moments, hu, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates the Laplacian of an image.
	/// 
	/// The function calculates the Laplacian of the source image by adding up the second x and y
	/// derivatives calculated using the Sobel operator:
	/// 
	/// 
	/// 
	/// This is done when `ksize > 1`. When `ksize == 1`, the Laplacian is computed by filtering the image
	/// with the following  aperture:
	/// 
	/// 
	/// 
	/// ## Parameters
	/// * src: Source image.
	/// * dst: Destination image of the same size and the same number of channels as src .
	/// * ddepth: Desired depth of the destination image, see [filter_depths] "combinations".
	/// * ksize: Aperture size used to compute the second-derivative filters. See [get_deriv_kernels] for
	/// details. The size must be positive and odd.
	/// * scale: Optional scale factor for the computed Laplacian values. By default, no scaling is
	/// applied. See [get_deriv_kernels] for details.
	/// * delta: Optional delta value that is added to the results prior to storing them in dst .
	/// * borderType: Pixel extrapolation method, see #BorderTypes. [BORDER_WRAP] is not supported.
	/// ## See also
	/// Sobel, Scharr
	/// 
	/// ## Note
	/// This alternative version of [laplacian] function uses the following default values for its arguments:
	/// * ksize: 1
	/// * scale: 1
	/// * delta: 0
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn laplacian_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, ddepth: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_Laplacian_const__InputArrayR_const__OutputArrayR_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), ddepth, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates the Laplacian of an image.
	/// 
	/// The function calculates the Laplacian of the source image by adding up the second x and y
	/// derivatives calculated using the Sobel operator:
	/// 
	/// 
	/// 
	/// This is done when `ksize > 1`. When `ksize == 1`, the Laplacian is computed by filtering the image
	/// with the following  aperture:
	/// 
	/// 
	/// 
	/// ## Parameters
	/// * src: Source image.
	/// * dst: Destination image of the same size and the same number of channels as src .
	/// * ddepth: Desired depth of the destination image, see [filter_depths] "combinations".
	/// * ksize: Aperture size used to compute the second-derivative filters. See [get_deriv_kernels] for
	/// details. The size must be positive and odd.
	/// * scale: Optional scale factor for the computed Laplacian values. By default, no scaling is
	/// applied. See [get_deriv_kernels] for details.
	/// * delta: Optional delta value that is added to the results prior to storing them in dst .
	/// * borderType: Pixel extrapolation method, see #BorderTypes. [BORDER_WRAP] is not supported.
	/// ## See also
	/// Sobel, Scharr
	/// 
	/// ## C++ default parameters
	/// * ksize: 1
	/// * scale: 1
	/// * delta: 0
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn laplacian(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, ddepth: i32, ksize: i32, scale: f64, delta: f64, border_type: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_Laplacian_const__InputArrayR_const__OutputArrayR_int_int_double_double_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), ddepth, ksize, scale, delta, border_type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates the first x- or y- image derivative using Scharr operator.
	/// 
	/// The function computes the first x- or y- spatial image derivative using the Scharr operator. The
	/// call
	/// 
	/// 
	/// 
	/// is equivalent to
	/// 
	/// 
	/// 
	/// ## Parameters
	/// * src: input image.
	/// * dst: output image of the same size and the same number of channels as src.
	/// * ddepth: output image depth, see [filter_depths] "combinations"
	/// * dx: order of the derivative x.
	/// * dy: order of the derivative y.
	/// * scale: optional scale factor for the computed derivative values; by default, no scaling is
	/// applied (see [get_deriv_kernels] for details).
	/// * delta: optional delta value that is added to the results prior to storing them in dst.
	/// * borderType: pixel extrapolation method, see #BorderTypes. [BORDER_WRAP] is not supported.
	/// ## See also
	/// cartToPolar
	/// 
	/// ## Note
	/// This alternative version of [scharr] function uses the following default values for its arguments:
	/// * scale: 1
	/// * delta: 0
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn scharr_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, ddepth: i32, dx: i32, dy: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_Scharr_const__InputArrayR_const__OutputArrayR_int_int_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), ddepth, dx, dy, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates the first x- or y- image derivative using Scharr operator.
	/// 
	/// The function computes the first x- or y- spatial image derivative using the Scharr operator. The
	/// call
	/// 
	/// 
	/// 
	/// is equivalent to
	/// 
	/// 
	/// 
	/// ## Parameters
	/// * src: input image.
	/// * dst: output image of the same size and the same number of channels as src.
	/// * ddepth: output image depth, see [filter_depths] "combinations"
	/// * dx: order of the derivative x.
	/// * dy: order of the derivative y.
	/// * scale: optional scale factor for the computed derivative values; by default, no scaling is
	/// applied (see [get_deriv_kernels] for details).
	/// * delta: optional delta value that is added to the results prior to storing them in dst.
	/// * borderType: pixel extrapolation method, see #BorderTypes. [BORDER_WRAP] is not supported.
	/// ## See also
	/// cartToPolar
	/// 
	/// ## C++ default parameters
	/// * scale: 1
	/// * delta: 0
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn scharr(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, ddepth: i32, dx: i32, dy: i32, scale: f64, delta: f64, border_type: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_Scharr_const__InputArrayR_const__OutputArrayR_int_int_int_double_double_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), ddepth, dx, dy, scale, delta, border_type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates the first, second, third, or mixed image derivatives using an extended Sobel operator.
	/// 
	/// In all cases except one, the  separable kernel is used to
	/// calculate the derivative. When , the  or 
	/// kernel is used (that is, no Gaussian smoothing is done). `ksize = 1` can only be used for the first
	/// or the second x- or y- derivatives.
	/// 
	/// There is also the special value `ksize = [FILTER_SCHARR] (-1)` that corresponds to the  Scharr
	/// filter that may give more accurate results than the  Sobel. The Scharr aperture is
	/// 
	/// 
	/// 
	/// for the x-derivative, or transposed for the y-derivative.
	/// 
	/// The function calculates an image derivative by convolving the image with the appropriate kernel:
	/// 
	/// 
	/// 
	/// The Sobel operators combine Gaussian smoothing and differentiation, so the result is more or less
	/// resistant to the noise. Most often, the function is called with ( xorder = 1, yorder = 0, ksize = 3)
	/// or ( xorder = 0, yorder = 1, ksize = 3) to calculate the first x- or y- image derivative. The first
	/// case corresponds to a kernel of:
	/// 
	/// 
	/// 
	/// The second case corresponds to a kernel of:
	/// 
	/// 
	/// 
	/// ## Parameters
	/// * src: input image.
	/// * dst: output image of the same size and the same number of channels as src .
	/// * ddepth: output image depth, see [filter_depths] "combinations"; in the case of
	///    8-bit input images it will result in truncated derivatives.
	/// * dx: order of the derivative x.
	/// * dy: order of the derivative y.
	/// * ksize: size of the extended Sobel kernel; it must be 1, 3, 5, or 7.
	/// * scale: optional scale factor for the computed derivative values; by default, no scaling is
	/// applied (see [get_deriv_kernels] for details).
	/// * delta: optional delta value that is added to the results prior to storing them in dst.
	/// * borderType: pixel extrapolation method, see #BorderTypes. [BORDER_WRAP] is not supported.
	/// ## See also
	/// Scharr, Laplacian, sepFilter2D, filter2D, GaussianBlur, cartToPolar
	/// 
	/// ## Note
	/// This alternative version of [sobel] function uses the following default values for its arguments:
	/// * ksize: 3
	/// * scale: 1
	/// * delta: 0
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn sobel_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, ddepth: i32, dx: i32, dy: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_Sobel_const__InputArrayR_const__OutputArrayR_int_int_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), ddepth, dx, dy, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates the first, second, third, or mixed image derivatives using an extended Sobel operator.
	/// 
	/// In all cases except one, the  separable kernel is used to
	/// calculate the derivative. When , the  or 
	/// kernel is used (that is, no Gaussian smoothing is done). `ksize = 1` can only be used for the first
	/// or the second x- or y- derivatives.
	/// 
	/// There is also the special value `ksize = [FILTER_SCHARR] (-1)` that corresponds to the  Scharr
	/// filter that may give more accurate results than the  Sobel. The Scharr aperture is
	/// 
	/// 
	/// 
	/// for the x-derivative, or transposed for the y-derivative.
	/// 
	/// The function calculates an image derivative by convolving the image with the appropriate kernel:
	/// 
	/// 
	/// 
	/// The Sobel operators combine Gaussian smoothing and differentiation, so the result is more or less
	/// resistant to the noise. Most often, the function is called with ( xorder = 1, yorder = 0, ksize = 3)
	/// or ( xorder = 0, yorder = 1, ksize = 3) to calculate the first x- or y- image derivative. The first
	/// case corresponds to a kernel of:
	/// 
	/// 
	/// 
	/// The second case corresponds to a kernel of:
	/// 
	/// 
	/// 
	/// ## Parameters
	/// * src: input image.
	/// * dst: output image of the same size and the same number of channels as src .
	/// * ddepth: output image depth, see [filter_depths] "combinations"; in the case of
	///    8-bit input images it will result in truncated derivatives.
	/// * dx: order of the derivative x.
	/// * dy: order of the derivative y.
	/// * ksize: size of the extended Sobel kernel; it must be 1, 3, 5, or 7.
	/// * scale: optional scale factor for the computed derivative values; by default, no scaling is
	/// applied (see [get_deriv_kernels] for details).
	/// * delta: optional delta value that is added to the results prior to storing them in dst.
	/// * borderType: pixel extrapolation method, see #BorderTypes. [BORDER_WRAP] is not supported.
	/// ## See also
	/// Scharr, Laplacian, sepFilter2D, filter2D, GaussianBlur, cartToPolar
	/// 
	/// ## C++ default parameters
	/// * ksize: 3
	/// * scale: 1
	/// * delta: 0
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn sobel(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, ddepth: i32, dx: i32, dy: i32, ksize: i32, scale: f64, delta: f64, border_type: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_Sobel_const__InputArrayR_const__OutputArrayR_int_int_int_int_double_double_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), ddepth, dx, dy, ksize, scale, delta, border_type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Adds the per-element product of two input images to the accumulator image.
	/// 
	/// The function adds the product of two images or their selected regions to the accumulator dst :
	/// 
	/// 
	/// 
	/// The function supports multi-channel images. Each channel is processed independently.
	/// 
	/// ## Parameters
	/// * src1: First input image, 1- or 3-channel, 8-bit or 32-bit floating point.
	/// * src2: Second input image of the same type and the same size as src1 .
	/// * dst: %Accumulator image with the same number of channels as input images, 32-bit or 64-bit
	/// floating-point.
	/// * mask: Optional operation mask.
	/// ## See also
	/// accumulate, accumulateSquare, accumulateWeighted
	/// 
	/// ## Note
	/// This alternative version of [accumulate_product] function uses the following default values for its arguments:
	/// * mask: noArray()
	#[inline]
	pub fn accumulate_product_def(src1: &impl core::ToInputArray, src2: &impl core::ToInputArray, dst: &mut impl core::ToInputOutputArray) -> Result<()> {
		input_array_arg!(src1);
		input_array_arg!(src2);
		input_output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_accumulateProduct_const__InputArrayR_const__InputArrayR_const__InputOutputArrayR(src1.as_raw__InputArray(), src2.as_raw__InputArray(), dst.as_raw__InputOutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Adds the per-element product of two input images to the accumulator image.
	/// 
	/// The function adds the product of two images or their selected regions to the accumulator dst :
	/// 
	/// 
	/// 
	/// The function supports multi-channel images. Each channel is processed independently.
	/// 
	/// ## Parameters
	/// * src1: First input image, 1- or 3-channel, 8-bit or 32-bit floating point.
	/// * src2: Second input image of the same type and the same size as src1 .
	/// * dst: %Accumulator image with the same number of channels as input images, 32-bit or 64-bit
	/// floating-point.
	/// * mask: Optional operation mask.
	/// ## See also
	/// accumulate, accumulateSquare, accumulateWeighted
	/// 
	/// ## C++ default parameters
	/// * mask: noArray()
	#[inline]
	pub fn accumulate_product(src1: &impl core::ToInputArray, src2: &impl core::ToInputArray, dst: &mut impl core::ToInputOutputArray, mask: &impl core::ToInputArray) -> Result<()> {
		input_array_arg!(src1);
		input_array_arg!(src2);
		input_output_array_arg!(dst);
		input_array_arg!(mask);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_accumulateProduct_const__InputArrayR_const__InputArrayR_const__InputOutputArrayR_const__InputArrayR(src1.as_raw__InputArray(), src2.as_raw__InputArray(), dst.as_raw__InputOutputArray(), mask.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Adds the square of a source image to the accumulator image.
	/// 
	/// The function adds the input image src or its selected region, raised to a power of 2, to the
	/// accumulator dst :
	/// 
	/// 
	/// 
	/// The function supports multi-channel images. Each channel is processed independently.
	/// 
	/// ## Parameters
	/// * src: Input image as 1- or 3-channel, 8-bit or 32-bit floating point.
	/// * dst: %Accumulator image with the same number of channels as input image, 32-bit or 64-bit
	/// floating-point.
	/// * mask: Optional operation mask.
	/// ## See also
	/// accumulateSquare, accumulateProduct, accumulateWeighted
	/// 
	/// ## Note
	/// This alternative version of [accumulate_square] function uses the following default values for its arguments:
	/// * mask: noArray()
	#[inline]
	pub fn accumulate_square_def(src: &impl core::ToInputArray, dst: &mut impl core::ToInputOutputArray) -> Result<()> {
		input_array_arg!(src);
		input_output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_accumulateSquare_const__InputArrayR_const__InputOutputArrayR(src.as_raw__InputArray(), dst.as_raw__InputOutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Adds the square of a source image to the accumulator image.
	/// 
	/// The function adds the input image src or its selected region, raised to a power of 2, to the
	/// accumulator dst :
	/// 
	/// 
	/// 
	/// The function supports multi-channel images. Each channel is processed independently.
	/// 
	/// ## Parameters
	/// * src: Input image as 1- or 3-channel, 8-bit or 32-bit floating point.
	/// * dst: %Accumulator image with the same number of channels as input image, 32-bit or 64-bit
	/// floating-point.
	/// * mask: Optional operation mask.
	/// ## See also
	/// accumulateSquare, accumulateProduct, accumulateWeighted
	/// 
	/// ## C++ default parameters
	/// * mask: noArray()
	#[inline]
	pub fn accumulate_square(src: &impl core::ToInputArray, dst: &mut impl core::ToInputOutputArray, mask: &impl core::ToInputArray) -> Result<()> {
		input_array_arg!(src);
		input_output_array_arg!(dst);
		input_array_arg!(mask);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_accumulateSquare_const__InputArrayR_const__InputOutputArrayR_const__InputArrayR(src.as_raw__InputArray(), dst.as_raw__InputOutputArray(), mask.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Updates a running average.
	/// 
	/// The function calculates the weighted sum of the input image src and the accumulator dst so that dst
	/// becomes a running average of a frame sequence:
	/// 
	/// 
	/// 
	/// That is, alpha regulates the update speed (how fast the accumulator "forgets" about earlier images).
	/// The function supports multi-channel images. Each channel is processed independently.
	/// 
	/// ## Parameters
	/// * src: Input image as 1- or 3-channel, 8-bit or 32-bit floating point.
	/// * dst: %Accumulator image with the same number of channels as input image, 32-bit or 64-bit
	/// floating-point.
	/// * alpha: Weight of the input image.
	/// * mask: Optional operation mask.
	/// ## See also
	/// accumulate, accumulateSquare, accumulateProduct
	/// 
	/// ## Note
	/// This alternative version of [accumulate_weighted] function uses the following default values for its arguments:
	/// * mask: noArray()
	#[inline]
	pub fn accumulate_weighted_def(src: &impl core::ToInputArray, dst: &mut impl core::ToInputOutputArray, alpha: f64) -> Result<()> {
		input_array_arg!(src);
		input_output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_accumulateWeighted_const__InputArrayR_const__InputOutputArrayR_double(src.as_raw__InputArray(), dst.as_raw__InputOutputArray(), alpha, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Updates a running average.
	/// 
	/// The function calculates the weighted sum of the input image src and the accumulator dst so that dst
	/// becomes a running average of a frame sequence:
	/// 
	/// 
	/// 
	/// That is, alpha regulates the update speed (how fast the accumulator "forgets" about earlier images).
	/// The function supports multi-channel images. Each channel is processed independently.
	/// 
	/// ## Parameters
	/// * src: Input image as 1- or 3-channel, 8-bit or 32-bit floating point.
	/// * dst: %Accumulator image with the same number of channels as input image, 32-bit or 64-bit
	/// floating-point.
	/// * alpha: Weight of the input image.
	/// * mask: Optional operation mask.
	/// ## See also
	/// accumulate, accumulateSquare, accumulateProduct
	/// 
	/// ## C++ default parameters
	/// * mask: noArray()
	#[inline]
	pub fn accumulate_weighted(src: &impl core::ToInputArray, dst: &mut impl core::ToInputOutputArray, alpha: f64, mask: &impl core::ToInputArray) -> Result<()> {
		input_array_arg!(src);
		input_output_array_arg!(dst);
		input_array_arg!(mask);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_accumulateWeighted_const__InputArrayR_const__InputOutputArrayR_double_const__InputArrayR(src.as_raw__InputArray(), dst.as_raw__InputOutputArray(), alpha, mask.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Adds an image to the accumulator image.
	/// 
	/// The function adds src or some of its elements to dst :
	/// 
	/// 
	/// 
	/// The function supports multi-channel images. Each channel is processed independently.
	/// 
	/// The function cv::accumulate can be used, for example, to collect statistics of a scene background
	/// viewed by a still camera and for the further foreground-background segmentation.
	/// 
	/// ## Parameters
	/// * src: Input image of type CV_8UC(n), CV_16UC(n), CV_32FC(n) or CV_64FC(n), where n is a positive integer.
	/// * dst: %Accumulator image with the same number of channels as input image, and a depth of CV_32F or CV_64F.
	/// * mask: Optional operation mask.
	/// ## See also
	/// accumulateSquare, accumulateProduct, accumulateWeighted
	/// 
	/// ## Note
	/// This alternative version of [accumulate] function uses the following default values for its arguments:
	/// * mask: noArray()
	#[inline]
	pub fn accumulate_def(src: &impl core::ToInputArray, dst: &mut impl core::ToInputOutputArray) -> Result<()> {
		input_array_arg!(src);
		input_output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_accumulate_const__InputArrayR_const__InputOutputArrayR(src.as_raw__InputArray(), dst.as_raw__InputOutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Adds an image to the accumulator image.
	/// 
	/// The function adds src or some of its elements to dst :
	/// 
	/// 
	/// 
	/// The function supports multi-channel images. Each channel is processed independently.
	/// 
	/// The function cv::accumulate can be used, for example, to collect statistics of a scene background
	/// viewed by a still camera and for the further foreground-background segmentation.
	/// 
	/// ## Parameters
	/// * src: Input image of type CV_8UC(n), CV_16UC(n), CV_32FC(n) or CV_64FC(n), where n is a positive integer.
	/// * dst: %Accumulator image with the same number of channels as input image, and a depth of CV_32F or CV_64F.
	/// * mask: Optional operation mask.
	/// ## See also
	/// accumulateSquare, accumulateProduct, accumulateWeighted
	/// 
	/// ## C++ default parameters
	/// * mask: noArray()
	#[inline]
	pub fn accumulate(src: &impl core::ToInputArray, dst: &mut impl core::ToInputOutputArray, mask: &impl core::ToInputArray) -> Result<()> {
		input_array_arg!(src);
		input_output_array_arg!(dst);
		input_array_arg!(mask);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_accumulate_const__InputArrayR_const__InputOutputArrayR_const__InputArrayR(src.as_raw__InputArray(), dst.as_raw__InputOutputArray(), mask.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Applies an adaptive threshold to an array.
	/// 
	/// The function transforms a grayscale image to a binary image according to the formulae:
	/// *   **THRESH_BINARY**
	///    
	/// *   **THRESH_BINARY_INV**
	///    
	/// where  is a threshold calculated individually for each pixel (see adaptiveMethod parameter).
	/// 
	/// The function can process the image in-place.
	/// 
	/// ## Parameters
	/// * src: Source 8-bit single-channel image.
	/// * dst: Destination image of the same size and the same type as src.
	/// * maxValue: Non-zero value assigned to the pixels for which the condition is satisfied
	/// * adaptiveMethod: Adaptive thresholding algorithm to use, see #AdaptiveThresholdTypes.
	/// The [BORDER_REPLICATE] | [BORDER_ISOLATED] is used to process boundaries.
	/// * thresholdType: Thresholding type that must be either [THRESH_BINARY] or #THRESH_BINARY_INV,
	/// see #ThresholdTypes.
	/// * blockSize: Size of a pixel neighborhood that is used to calculate a threshold value for the
	/// pixel: 3, 5, 7, and so on.
	/// * C: Constant subtracted from the mean or weighted mean (see the details below). Normally, it
	/// is positive but may be zero or negative as well.
	/// ## See also
	/// threshold, blur, GaussianBlur
	#[inline]
	pub fn adaptive_threshold(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, max_value: f64, adaptive_method: i32, threshold_type: i32, block_size: i32, c: f64) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_adaptiveThreshold_const__InputArrayR_const__OutputArrayR_double_int_int_int_double(src.as_raw__InputArray(), dst.as_raw__OutputArray(), max_value, adaptive_method, threshold_type, block_size, c, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Applies a user colormap on a given image.
	/// 
	/// ## Parameters
	/// * src: The source image, grayscale or colored of type CV_8UC1 or CV_8UC3.
	/// * dst: The result is the colormapped source image. Note: Mat::create is called on dst.
	/// * userColor: The colormap to apply of type CV_8UC1 or CV_8UC3 and size 256
	#[inline]
	pub fn apply_color_map_user(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, user_color: &impl core::ToInputArray) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		input_array_arg!(user_color);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_applyColorMap_const__InputArrayR_const__OutputArrayR_const__InputArrayR(src.as_raw__InputArray(), dst.as_raw__OutputArray(), user_color.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Applies a GNU Octave/MATLAB equivalent colormap on a given image.
	/// 
	/// ## Parameters
	/// * src: The source image, grayscale or colored of type CV_8UC1 or CV_8UC3.
	/// * dst: The result is the colormapped source image. Note: Mat::create is called on dst.
	/// * colormap: The colormap to apply, see #ColormapTypes
	#[inline]
	pub fn apply_color_map(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, colormap: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_applyColorMap_const__InputArrayR_const__OutputArrayR_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), colormap, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Approximates a polygonal curve(s) with the specified precision.
	/// 
	/// The function cv::approxPolyDP approximates a curve or a polygon with another curve/polygon with less
	/// vertices so that the distance between them is less or equal to the specified precision. It uses the
	/// Douglas-Peucker algorithm <http://en.wikipedia.org/wiki/Ramer-Douglas-Peucker_algorithm>
	/// 
	/// ## Parameters
	/// * curve: Input vector of a 2D point stored in std::vector or Mat
	/// * approxCurve: Result of the approximation. The type should match the type of the input curve.
	/// * epsilon: Parameter specifying the approximation accuracy. This is the maximum distance
	/// between the original curve and its approximation.
	/// * closed: If true, the approximated curve is closed (its first and last vertices are
	/// connected). Otherwise, it is not closed.
	#[inline]
	pub fn approx_poly_dp(curve: &impl core::ToInputArray, approx_curve: &mut impl core::ToOutputArray, epsilon: f64, closed: bool) -> Result<()> {
		input_array_arg!(curve);
		output_array_arg!(approx_curve);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_approxPolyDP_const__InputArrayR_const__OutputArrayR_double_bool(curve.as_raw__InputArray(), approx_curve.as_raw__OutputArray(), epsilon, closed, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates a contour perimeter or a curve length.
	/// 
	/// The function computes a curve length or a closed contour perimeter.
	/// 
	/// ## Parameters
	/// * curve: Input vector of 2D points, stored in std::vector or Mat.
	/// * closed: Flag indicating whether the curve is closed or not.
	#[inline]
	pub fn arc_length(curve: &impl core::ToInputArray, closed: bool) -> Result<f64> {
		input_array_arg!(curve);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_arcLength_const__InputArrayR_bool(curve.as_raw__InputArray(), closed, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Draws an arrow segment pointing from the first point to the second one.
	/// 
	/// The function cv::arrowedLine draws an arrow between pt1 and pt2 points in the image. See also #line.
	/// 
	/// ## Parameters
	/// * img: Image.
	/// * pt1: The point the arrow starts from.
	/// * pt2: The point the arrow points to.
	/// * color: Line color.
	/// * thickness: Line thickness.
	/// * line_type: Type of the line. See [line_types]
	/// * shift: Number of fractional bits in the point coordinates.
	/// * tipLength: The length of the arrow tip in relation to the arrow length
	/// 
	/// ## Note
	/// This alternative version of [arrowed_line] function uses the following default values for its arguments:
	/// * thickness: 1
	/// * line_type: 8
	/// * shift: 0
	/// * tip_length: 0.1
	#[inline]
	pub fn arrowed_line_def(img: &mut impl core::ToInputOutputArray, pt1: core::Point, pt2: core::Point, color: core::Scalar) -> Result<()> {
		input_output_array_arg!(img);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_arrowedLine_const__InputOutputArrayR_Point_Point_const_ScalarR(img.as_raw__InputOutputArray(), pt1.opencv_as_extern(), pt2.opencv_as_extern(), &color, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Draws an arrow segment pointing from the first point to the second one.
	/// 
	/// The function cv::arrowedLine draws an arrow between pt1 and pt2 points in the image. See also #line.
	/// 
	/// ## Parameters
	/// * img: Image.
	/// * pt1: The point the arrow starts from.
	/// * pt2: The point the arrow points to.
	/// * color: Line color.
	/// * thickness: Line thickness.
	/// * line_type: Type of the line. See [line_types]
	/// * shift: Number of fractional bits in the point coordinates.
	/// * tipLength: The length of the arrow tip in relation to the arrow length
	/// 
	/// ## C++ default parameters
	/// * thickness: 1
	/// * line_type: 8
	/// * shift: 0
	/// * tip_length: 0.1
	#[inline]
	pub fn arrowed_line(img: &mut impl core::ToInputOutputArray, pt1: core::Point, pt2: core::Point, color: core::Scalar, thickness: i32, line_type: i32, shift: i32, tip_length: f64) -> Result<()> {
		input_output_array_arg!(img);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_arrowedLine_const__InputOutputArrayR_Point_Point_const_ScalarR_int_int_int_double(img.as_raw__InputOutputArray(), pt1.opencv_as_extern(), pt2.opencv_as_extern(), &color, thickness, line_type, shift, tip_length, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Applies the bilateral filter to an image.
	/// 
	/// The function applies bilateral filtering to the input image, as described in
	/// <http://www.dai.ed.ac.uk/CVonline/LOCAL_COPIES/MANDUCHI1/Bilateral_Filtering.html>
	/// bilateralFilter can reduce unwanted noise very well while keeping edges fairly sharp. However, it is
	/// very slow compared to most filters.
	/// 
	/// _Sigma values_: For simplicity, you can set the 2 sigma values to be the same. If they are small (\<
	/// 10), the filter will not have much effect, whereas if they are large (\> 150), they will have a very
	/// strong effect, making the image look "cartoonish".
	/// 
	/// _Filter size_: Large filters (d \> 5) are very slow, so it is recommended to use d=5 for real-time
	/// applications, and perhaps d=9 for offline applications that need heavy noise filtering.
	/// 
	/// This filter does not work inplace.
	/// ## Parameters
	/// * src: Source 8-bit or floating-point, 1-channel or 3-channel image.
	/// * dst: Destination image of the same size and type as src .
	/// * d: Diameter of each pixel neighborhood that is used during filtering. If it is non-positive,
	/// it is computed from sigmaSpace.
	/// * sigmaColor: Filter sigma in the color space. A larger value of the parameter means that
	/// farther colors within the pixel neighborhood (see sigmaSpace) will be mixed together, resulting
	/// in larger areas of semi-equal color.
	/// * sigmaSpace: Filter sigma in the coordinate space. A larger value of the parameter means that
	/// farther pixels will influence each other as long as their colors are close enough (see sigmaColor
	/// ). When d\>0, it specifies the neighborhood size regardless of sigmaSpace. Otherwise, d is
	/// proportional to sigmaSpace.
	/// * borderType: border mode used to extrapolate pixels outside of the image, see [border_types]
	/// 
	/// ## Note
	/// This alternative version of [bilateral_filter] function uses the following default values for its arguments:
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn bilateral_filter_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, d: i32, sigma_color: f64, sigma_space: f64) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_bilateralFilter_const__InputArrayR_const__OutputArrayR_int_double_double(src.as_raw__InputArray(), dst.as_raw__OutputArray(), d, sigma_color, sigma_space, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Applies the bilateral filter to an image.
	/// 
	/// The function applies bilateral filtering to the input image, as described in
	/// <http://www.dai.ed.ac.uk/CVonline/LOCAL_COPIES/MANDUCHI1/Bilateral_Filtering.html>
	/// bilateralFilter can reduce unwanted noise very well while keeping edges fairly sharp. However, it is
	/// very slow compared to most filters.
	/// 
	/// _Sigma values_: For simplicity, you can set the 2 sigma values to be the same. If they are small (\<
	/// 10), the filter will not have much effect, whereas if they are large (\> 150), they will have a very
	/// strong effect, making the image look "cartoonish".
	/// 
	/// _Filter size_: Large filters (d \> 5) are very slow, so it is recommended to use d=5 for real-time
	/// applications, and perhaps d=9 for offline applications that need heavy noise filtering.
	/// 
	/// This filter does not work inplace.
	/// ## Parameters
	/// * src: Source 8-bit or floating-point, 1-channel or 3-channel image.
	/// * dst: Destination image of the same size and type as src .
	/// * d: Diameter of each pixel neighborhood that is used during filtering. If it is non-positive,
	/// it is computed from sigmaSpace.
	/// * sigmaColor: Filter sigma in the color space. A larger value of the parameter means that
	/// farther colors within the pixel neighborhood (see sigmaSpace) will be mixed together, resulting
	/// in larger areas of semi-equal color.
	/// * sigmaSpace: Filter sigma in the coordinate space. A larger value of the parameter means that
	/// farther pixels will influence each other as long as their colors are close enough (see sigmaColor
	/// ). When d\>0, it specifies the neighborhood size regardless of sigmaSpace. Otherwise, d is
	/// proportional to sigmaSpace.
	/// * borderType: border mode used to extrapolate pixels outside of the image, see #BorderTypes
	/// 
	/// ## C++ default parameters
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn bilateral_filter(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, d: i32, sigma_color: f64, sigma_space: f64, border_type: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_bilateralFilter_const__InputArrayR_const__OutputArrayR_int_double_double_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), d, sigma_color, sigma_space, border_type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Performs linear blending of two images:
	/// 
	/// ## Parameters
	/// * src1: It has a type of CV_8UC(n) or CV_32FC(n), where n is a positive integer.
	/// * src2: It has the same type and size as src1.
	/// * weights1: It has a type of CV_32FC1 and the same size with src1.
	/// * weights2: It has a type of CV_32FC1 and the same size with src1.
	/// * dst: It is created if it does not have the same size and type with src1.
	#[inline]
	pub fn blend_linear(src1: &impl core::ToInputArray, src2: &impl core::ToInputArray, weights1: &impl core::ToInputArray, weights2: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray) -> Result<()> {
		input_array_arg!(src1);
		input_array_arg!(src2);
		input_array_arg!(weights1);
		input_array_arg!(weights2);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_blendLinear_const__InputArrayR_const__InputArrayR_const__InputArrayR_const__InputArrayR_const__OutputArrayR(src1.as_raw__InputArray(), src2.as_raw__InputArray(), weights1.as_raw__InputArray(), weights2.as_raw__InputArray(), dst.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Blurs an image using the normalized box filter.
	/// 
	/// The function smooths an image using the kernel:
	/// 
	/// 
	/// 
	/// The call `blur(src, dst, ksize, anchor, borderType)` is equivalent to `boxFilter(src, dst, src.type(), ksize,
	/// anchor, true, borderType)`.
	/// 
	/// ## Parameters
	/// * src: input image; it can have any number of channels, which are processed independently, but
	/// the depth should be CV_8U, CV_16U, CV_16S, CV_32F or CV_64F.
	/// * dst: output image of the same size and type as src.
	/// * ksize: blurring kernel size.
	/// * anchor: anchor point; default value Point(-1,-1) means that the anchor is at the kernel
	/// center.
	/// * borderType: border mode used to extrapolate pixels outside of the image, see #BorderTypes. [BORDER_WRAP] is not supported.
	/// ## See also
	/// boxFilter, bilateralFilter, GaussianBlur, medianBlur
	/// 
	/// ## Note
	/// This alternative version of [blur] function uses the following default values for its arguments:
	/// * anchor: Point(-1,-1)
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn blur_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, ksize: core::Size) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_blur_const__InputArrayR_const__OutputArrayR_Size(src.as_raw__InputArray(), dst.as_raw__OutputArray(), ksize.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Blurs an image using the normalized box filter.
	/// 
	/// The function smooths an image using the kernel:
	/// 
	/// 
	/// 
	/// The call `blur(src, dst, ksize, anchor, borderType)` is equivalent to `boxFilter(src, dst, src.type(), ksize,
	/// anchor, true, borderType)`.
	/// 
	/// ## Parameters
	/// * src: input image; it can have any number of channels, which are processed independently, but
	/// the depth should be CV_8U, CV_16U, CV_16S, CV_32F or CV_64F.
	/// * dst: output image of the same size and type as src.
	/// * ksize: blurring kernel size.
	/// * anchor: anchor point; default value Point(-1,-1) means that the anchor is at the kernel
	/// center.
	/// * borderType: border mode used to extrapolate pixels outside of the image, see #BorderTypes. [BORDER_WRAP] is not supported.
	/// ## See also
	/// boxFilter, bilateralFilter, GaussianBlur, medianBlur
	/// 
	/// ## C++ default parameters
	/// * anchor: Point(-1,-1)
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn blur(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, ksize: core::Size, anchor: core::Point, border_type: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_blur_const__InputArrayR_const__OutputArrayR_Size_Point_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), ksize.opencv_as_extern(), anchor.opencv_as_extern(), border_type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates the up-right bounding rectangle of a point set or non-zero pixels of gray-scale image.
	/// 
	/// The function calculates and returns the minimal up-right bounding rectangle for the specified point set or
	/// non-zero pixels of gray-scale image.
	/// 
	/// ## Parameters
	/// * array: Input gray-scale image or 2D point set, stored in std::vector or Mat.
	#[inline]
	pub fn bounding_rect(array: &impl core::ToInputArray) -> Result<core::Rect> {
		input_array_arg!(array);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_boundingRect_const__InputArrayR(array.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Blurs an image using the box filter.
	/// 
	/// The function smooths an image using the kernel:
	/// 
	/// 
	/// 
	/// where
	/// 
	/// 
	/// 
	/// Unnormalized box filter is useful for computing various integral characteristics over each pixel
	/// neighborhood, such as covariance matrices of image derivatives (used in dense optical flow
	/// algorithms, and so on). If you need to compute pixel sums over variable-size windows, use #integral.
	/// 
	/// ## Parameters
	/// * src: input image.
	/// * dst: output image of the same size and type as src.
	/// * ddepth: the output image depth (-1 to use src.depth()).
	/// * ksize: blurring kernel size.
	/// * anchor: anchor point; default value Point(-1,-1) means that the anchor is at the kernel
	/// center.
	/// * normalize: flag, specifying whether the kernel is normalized by its area or not.
	/// * borderType: border mode used to extrapolate pixels outside of the image, see #BorderTypes. [BORDER_WRAP] is not supported.
	/// ## See also
	/// blur, bilateralFilter, GaussianBlur, medianBlur, integral
	/// 
	/// ## Note
	/// This alternative version of [box_filter] function uses the following default values for its arguments:
	/// * anchor: Point(-1,-1)
	/// * normalize: true
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn box_filter_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, ddepth: i32, ksize: core::Size) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_boxFilter_const__InputArrayR_const__OutputArrayR_int_Size(src.as_raw__InputArray(), dst.as_raw__OutputArray(), ddepth, ksize.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Blurs an image using the box filter.
	/// 
	/// The function smooths an image using the kernel:
	/// 
	/// 
	/// 
	/// where
	/// 
	/// 
	/// 
	/// Unnormalized box filter is useful for computing various integral characteristics over each pixel
	/// neighborhood, such as covariance matrices of image derivatives (used in dense optical flow
	/// algorithms, and so on). If you need to compute pixel sums over variable-size windows, use #integral.
	/// 
	/// ## Parameters
	/// * src: input image.
	/// * dst: output image of the same size and type as src.
	/// * ddepth: the output image depth (-1 to use src.depth()).
	/// * ksize: blurring kernel size.
	/// * anchor: anchor point; default value Point(-1,-1) means that the anchor is at the kernel
	/// center.
	/// * normalize: flag, specifying whether the kernel is normalized by its area or not.
	/// * borderType: border mode used to extrapolate pixels outside of the image, see #BorderTypes. [BORDER_WRAP] is not supported.
	/// ## See also
	/// blur, bilateralFilter, GaussianBlur, medianBlur, integral
	/// 
	/// ## C++ default parameters
	/// * anchor: Point(-1,-1)
	/// * normalize: true
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn box_filter(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, ddepth: i32, ksize: core::Size, anchor: core::Point, normalize: bool, border_type: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_boxFilter_const__InputArrayR_const__OutputArrayR_int_Size_Point_bool_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), ddepth, ksize.opencv_as_extern(), anchor.opencv_as_extern(), normalize, border_type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Finds the four vertices of a rotated rect. Useful to draw the rotated rectangle.
	/// 
	/// The function finds the four vertices of a rotated rectangle. This function is useful to draw the
	/// rectangle. In C++, instead of using this function, you can directly use RotatedRect::points method. Please
	/// visit the [tutorial_bounding_rotated_ellipses] "tutorial on Creating Bounding rotated boxes and ellipses for contours" for more information.
	/// 
	/// ## Parameters
	/// * box: The input rotated rectangle. It may be the output of [minAreaRect].
	/// * points: The output array of four vertices of rectangles.
	#[inline]
	pub fn box_points(box_: core::RotatedRect, points: &mut impl core::ToOutputArray) -> Result<()> {
		output_array_arg!(points);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_boxPoints_RotatedRect_const__OutputArrayR(box_.opencv_as_extern(), points.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Constructs the Gaussian pyramid for an image.
	/// 
	/// The function constructs a vector of images and builds the Gaussian pyramid by recursively applying
	/// pyrDown to the previously built pyramid layers, starting from `dst[0]==src`.
	/// 
	/// ## Parameters
	/// * src: Source image. Check pyrDown for the list of supported types.
	/// * dst: Destination vector of maxlevel+1 images of the same type as src. dst[0] will be the
	/// same as src. dst[1] is the next pyramid layer, a smoothed and down-sized src, and so on.
	/// * maxlevel: 0-based index of the last (the smallest) pyramid layer. It must be non-negative.
	/// * borderType: Pixel extrapolation method, see [border_types] ([BORDER_CONSTANT] isn't supported)
	/// 
	/// ## Note
	/// This alternative version of [build_pyramid] function uses the following default values for its arguments:
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn build_pyramid_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, maxlevel: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_buildPyramid_const__InputArrayR_const__OutputArrayR_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), maxlevel, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Constructs the Gaussian pyramid for an image.
	/// 
	/// The function constructs a vector of images and builds the Gaussian pyramid by recursively applying
	/// pyrDown to the previously built pyramid layers, starting from `dst[0]==src`.
	/// 
	/// ## Parameters
	/// * src: Source image. Check pyrDown for the list of supported types.
	/// * dst: Destination vector of maxlevel+1 images of the same type as src. dst[0] will be the
	/// same as src. dst[1] is the next pyramid layer, a smoothed and down-sized src, and so on.
	/// * maxlevel: 0-based index of the last (the smallest) pyramid layer. It must be non-negative.
	/// * borderType: Pixel extrapolation method, see [border_types] ([BORDER_CONSTANT] isn't supported)
	/// 
	/// ## C++ default parameters
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn build_pyramid(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, maxlevel: i32, border_type: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_buildPyramid_const__InputArrayR_const__OutputArrayR_int_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), maxlevel, border_type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates the back projection of a histogram.
	/// 
	/// The function cv::calcBackProject calculates the back project of the histogram. That is, similarly to
	/// [calc_hist] , at each location (x, y) the function collects the values from the selected channels
	/// in the input images and finds the corresponding histogram bin. But instead of incrementing it, the
	/// function reads the bin value, scales it by scale , and stores in backProject(x,y) . In terms of
	/// statistics, the function computes probability of each element value in respect with the empirical
	/// probability distribution represented by the histogram. See how, for example, you can find and track
	/// a bright-colored object in a scene:
	/// 
	/// - Before tracking, show the object to the camera so that it covers almost the whole frame.
	/// Calculate a hue histogram. The histogram may have strong maximums, corresponding to the dominant
	/// colors in the object.
	/// 
	/// - When tracking, calculate a back projection of a hue plane of each input video frame using that
	/// pre-computed histogram. Threshold the back projection to suppress weak colors. It may also make
	/// sense to suppress pixels with non-sufficient color saturation and too dark or too bright pixels.
	/// 
	/// - Find connected components in the resulting picture and choose, for example, the largest
	/// component.
	/// 
	/// This is an approximate algorithm of the CamShift color object tracker.
	/// 
	/// ## Parameters
	/// * images: Source arrays. They all should have the same depth, CV_8U, CV_16U or CV_32F , and the same
	/// size. Each of them can have an arbitrary number of channels.
	/// * nimages: Number of source images.
	/// * channels: The list of channels used to compute the back projection. The number of channels
	/// must match the histogram dimensionality. The first array channels are numerated from 0 to
	/// images[0].channels()-1 , the second array channels are counted from images[0].channels() to
	/// images[0].channels() + images[1].channels()-1, and so on.
	/// * hist: Input histogram that can be dense or sparse.
	/// * backProject: Destination back projection array that is a single-channel array of the same
	/// size and depth as images[0] .
	/// * ranges: Array of arrays of the histogram bin boundaries in each dimension. See [calc_hist] .
	/// * scale: Optional scale factor for the output back projection.
	/// * uniform: Flag indicating whether the histogram is uniform or not (see above).
	/// ## See also
	/// calcHist, compareHist
	/// 
	/// ## Overloaded parameters
	#[inline]
	pub fn calc_back_project(images: &impl core::ToInputArray, channels: &core::Vector<i32>, hist: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, ranges: &core::Vector<f32>, scale: f64) -> Result<()> {
		input_array_arg!(images);
		input_array_arg!(hist);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_calcBackProject_const__InputArrayR_const_vectorLintGR_const__InputArrayR_const__OutputArrayR_const_vectorLfloatGR_double(images.as_raw__InputArray(), channels.as_raw_VectorOfi32(), hist.as_raw__InputArray(), dst.as_raw__OutputArray(), ranges.as_raw_VectorOff32(), scale, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// @overload
	/// 
	/// this variant supports only uniform histograms.
	/// 
	/// ranges argument is either empty vector or a flattened vector of histSize.size()*2 elements
	/// (histSize.size() element pairs). The first and second elements of each pair specify the lower and
	/// upper boundaries.
	/// 
	/// ## Note
	/// This alternative version of [calc_hist] function uses the following default values for its arguments:
	/// * accumulate: false
	#[inline]
	pub fn calc_hist_def(images: &impl core::ToInputArray, channels: &core::Vector<i32>, mask: &impl core::ToInputArray, hist: &mut impl core::ToOutputArray, hist_size: &core::Vector<i32>, ranges: &core::Vector<f32>) -> Result<()> {
		input_array_arg!(images);
		input_array_arg!(mask);
		output_array_arg!(hist);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_calcHist_const__InputArrayR_const_vectorLintGR_const__InputArrayR_const__OutputArrayR_const_vectorLintGR_const_vectorLfloatGR(images.as_raw__InputArray(), channels.as_raw_VectorOfi32(), mask.as_raw__InputArray(), hist.as_raw__OutputArray(), hist_size.as_raw_VectorOfi32(), ranges.as_raw_VectorOff32(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates a histogram of a set of arrays.
	/// 
	/// The function cv::calcHist calculates the histogram of one or more arrays. The elements of a tuple used
	/// to increment a histogram bin are taken from the corresponding input arrays at the same location. The
	/// sample below shows how to compute a 2D Hue-Saturation histogram for a color image. :
	/// @include snippets/imgproc_calcHist.cpp
	/// 
	/// ## Parameters
	/// * images: Source arrays. They all should have the same depth, CV_8U, CV_16U or CV_32F , and the same
	/// size. Each of them can have an arbitrary number of channels.
	/// * nimages: Number of source images.
	/// * channels: List of the dims channels used to compute the histogram. The first array channels
	/// are numerated from 0 to images[0].channels()-1 , the second array channels are counted from
	/// images[0].channels() to images[0].channels() + images[1].channels()-1, and so on.
	/// * mask: Optional mask. If the matrix is not empty, it must be an 8-bit array of the same size
	/// as images[i] . The non-zero mask elements mark the array elements counted in the histogram.
	/// * hist: Output histogram, which is a dense or sparse dims -dimensional array.
	/// * dims: Histogram dimensionality that must be positive and not greater than CV_MAX_DIMS
	/// (equal to 32 in the current OpenCV version).
	/// * histSize: Array of histogram sizes in each dimension.
	/// * ranges: Array of the dims arrays of the histogram bin boundaries in each dimension. When the
	/// histogram is uniform ( uniform =true), then for each dimension i it is enough to specify the lower
	/// (inclusive) boundary  of the 0-th histogram bin and the upper (exclusive) boundary
	///  for the last histogram bin histSize[i]-1 . That is, in case of a
	/// uniform histogram each of ranges[i] is an array of 2 elements. When the histogram is not uniform (
	/// uniform=false ), then each of ranges[i] contains histSize[i]+1 elements:
	/// 
	/// . The array elements, that are not between  and  , are not
	/// counted in the histogram.
	/// * uniform: Flag indicating whether the histogram is uniform or not (see above).
	/// * accumulate: Accumulation flag. If it is set, the histogram is not cleared in the beginning
	/// when it is allocated. This feature enables you to compute a single histogram from several sets of
	/// arrays, or to update the histogram in time.
	/// 
	/// ## Overloaded parameters
	/// 
	/// 
	/// this variant supports only uniform histograms.
	/// 
	/// ranges argument is either empty vector or a flattened vector of histSize.size()*2 elements
	/// (histSize.size() element pairs). The first and second elements of each pair specify the lower and
	/// upper boundaries.
	/// 
	/// ## C++ default parameters
	/// * accumulate: false
	#[inline]
	pub fn calc_hist(images: &impl core::ToInputArray, channels: &core::Vector<i32>, mask: &impl core::ToInputArray, hist: &mut impl core::ToOutputArray, hist_size: &core::Vector<i32>, ranges: &core::Vector<f32>, accumulate: bool) -> Result<()> {
		input_array_arg!(images);
		input_array_arg!(mask);
		output_array_arg!(hist);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_calcHist_const__InputArrayR_const_vectorLintGR_const__InputArrayR_const__OutputArrayR_const_vectorLintGR_const_vectorLfloatGR_bool(images.as_raw__InputArray(), channels.as_raw_VectorOfi32(), mask.as_raw__InputArray(), hist.as_raw__OutputArray(), hist_size.as_raw_VectorOfi32(), ranges.as_raw_VectorOff32(), accumulate, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Draws a circle.
	/// 
	/// The function cv::circle draws a simple or filled circle with a given center and radius.
	/// ## Parameters
	/// * img: Image where the circle is drawn.
	/// * center: Center of the circle.
	/// * radius: Radius of the circle.
	/// * color: Circle color.
	/// * thickness: Thickness of the circle outline, if positive. Negative values, like #FILLED,
	/// mean that a filled circle is to be drawn.
	/// * lineType: Type of the circle boundary. See [line_types]
	/// * shift: Number of fractional bits in the coordinates of the center and in the radius value.
	/// 
	/// ## Note
	/// This alternative version of [circle] function uses the following default values for its arguments:
	/// * thickness: 1
	/// * line_type: LINE_8
	/// * shift: 0
	#[inline]
	pub fn circle_def(img: &mut impl core::ToInputOutputArray, center: core::Point, radius: i32, color: core::Scalar) -> Result<()> {
		input_output_array_arg!(img);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_circle_const__InputOutputArrayR_Point_int_const_ScalarR(img.as_raw__InputOutputArray(), center.opencv_as_extern(), radius, &color, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Draws a circle.
	/// 
	/// The function cv::circle draws a simple or filled circle with a given center and radius.
	/// ## Parameters
	/// * img: Image where the circle is drawn.
	/// * center: Center of the circle.
	/// * radius: Radius of the circle.
	/// * color: Circle color.
	/// * thickness: Thickness of the circle outline, if positive. Negative values, like #FILLED,
	/// mean that a filled circle is to be drawn.
	/// * lineType: Type of the circle boundary. See [line_types]
	/// * shift: Number of fractional bits in the coordinates of the center and in the radius value.
	/// 
	/// ## C++ default parameters
	/// * thickness: 1
	/// * line_type: LINE_8
	/// * shift: 0
	#[inline]
	pub fn circle(img: &mut impl core::ToInputOutputArray, center: core::Point, radius: i32, color: core::Scalar, thickness: i32, line_type: i32, shift: i32) -> Result<()> {
		input_output_array_arg!(img);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_circle_const__InputOutputArrayR_Point_int_const_ScalarR_int_int_int(img.as_raw__InputOutputArray(), center.opencv_as_extern(), radius, &color, thickness, line_type, shift, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Clips the line against the image rectangle.
	/// 
	/// The function cv::clipLine calculates a part of the line segment that is entirely within the specified
	/// rectangle. It returns false if the line segment is completely outside the rectangle. Otherwise,
	/// it returns true .
	/// ## Parameters
	/// * imgSize: Image size. The image rectangle is Rect(0, 0, imgSize.width, imgSize.height) .
	/// * pt1: First line point.
	/// * pt2: Second line point.
	/// 
	/// ## Overloaded parameters
	/// 
	/// * imgRect: Image rectangle.
	/// * pt1: First line point.
	/// * pt2: Second line point.
	#[inline]
	pub fn clip_line(img_rect: core::Rect, pt1: &mut core::Point, pt2: &mut core::Point) -> Result<bool> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_clipLine_Rect_PointR_PointR(img_rect.opencv_as_extern(), pt1, pt2, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Clips the line against the image rectangle.
	/// 
	/// The function cv::clipLine calculates a part of the line segment that is entirely within the specified
	/// rectangle. It returns false if the line segment is completely outside the rectangle. Otherwise,
	/// it returns true .
	/// ## Parameters
	/// * imgSize: Image size. The image rectangle is Rect(0, 0, imgSize.width, imgSize.height) .
	/// * pt1: First line point.
	/// * pt2: Second line point.
	/// 
	/// ## Overloaded parameters
	/// 
	/// * imgSize: Image size. The image rectangle is Rect(0, 0, imgSize.width, imgSize.height) .
	/// * pt1: First line point.
	/// * pt2: Second line point.
	#[inline]
	pub fn clip_line_size_i64(img_size: core::Size2l, pt1: &mut core::Point2l, pt2: &mut core::Point2l) -> Result<bool> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_clipLine_Size2l_Point2lR_Point2lR(img_size.opencv_as_extern(), pt1, pt2, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Clips the line against the image rectangle.
	/// 
	/// The function cv::clipLine calculates a part of the line segment that is entirely within the specified
	/// rectangle. It returns false if the line segment is completely outside the rectangle. Otherwise,
	/// it returns true .
	/// ## Parameters
	/// * imgSize: Image size. The image rectangle is Rect(0, 0, imgSize.width, imgSize.height) .
	/// * pt1: First line point.
	/// * pt2: Second line point.
	#[inline]
	pub fn clip_line_size(img_size: core::Size, pt1: &mut core::Point, pt2: &mut core::Point) -> Result<bool> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_clipLine_Size_PointR_PointR(img_size.opencv_as_extern(), pt1, pt2, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Compares two histograms.
	/// 
	/// The function cv::compareHist compares two dense or two sparse histograms using the specified method.
	/// 
	/// The function returns  .
	/// 
	/// While the function works well with 1-, 2-, 3-dimensional dense histograms, it may not be suitable
	/// for high-dimensional sparse histograms. In such histograms, because of aliasing and sampling
	/// problems, the coordinates of non-zero histogram bins can slightly shift. To compare such histograms
	/// or more general sparse configurations of weighted points, consider using the [EMD] function.
	/// 
	/// ## Parameters
	/// * H1: First compared histogram.
	/// * H2: Second compared histogram of the same size as H1 .
	/// * method: Comparison method, see [hist_comp_methods]
	/// 
	/// ## Overloaded parameters
	#[inline]
	pub fn compare_hist_1(h1: &core::SparseMat, h2: &core::SparseMat, method: i32) -> Result<f64> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_compareHist_const_SparseMatR_const_SparseMatR_int(h1.as_raw_SparseMat(), h2.as_raw_SparseMat(), method, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Compares two histograms.
	/// 
	/// The function cv::compareHist compares two dense or two sparse histograms using the specified method.
	/// 
	/// The function returns  .
	/// 
	/// While the function works well with 1-, 2-, 3-dimensional dense histograms, it may not be suitable
	/// for high-dimensional sparse histograms. In such histograms, because of aliasing and sampling
	/// problems, the coordinates of non-zero histogram bins can slightly shift. To compare such histograms
	/// or more general sparse configurations of weighted points, consider using the [EMD] function.
	/// 
	/// ## Parameters
	/// * H1: First compared histogram.
	/// * H2: Second compared histogram of the same size as H1 .
	/// * method: Comparison method, see #HistCompMethods
	#[inline]
	pub fn compare_hist(h1: &impl core::ToInputArray, h2: &impl core::ToInputArray, method: i32) -> Result<f64> {
		input_array_arg!(h1);
		input_array_arg!(h2);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_compareHist_const__InputArrayR_const__InputArrayR_int(h1.as_raw__InputArray(), h2.as_raw__InputArray(), method, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// @overload
	/// ## Parameters
	/// * image: the 8-bit single-channel image to be labeled
	/// * labels: destination labeled image
	/// * stats: statistics output for each label, including the background label.
	/// Statistics are accessed via stats(label, COLUMN) where COLUMN is one of
	/// #ConnectedComponentsTypes, selecting the statistic. The data type is CV_32S.
	/// * centroids: centroid output for each label, including the background label. Centroids are
	/// accessed via centroids(label, 0) for x and centroids(label, 1) for y. The data type CV_64F.
	/// * connectivity: 8 or 4 for 8-way or 4-way connectivity respectively
	/// * ltype: output image label type. Currently CV_32S and CV_16U are supported.
	/// 
	/// ## Note
	/// This alternative version of [connected_components_with_stats] function uses the following default values for its arguments:
	/// * connectivity: 8
	/// * ltype: CV_32S
	#[inline]
	pub fn connected_components_with_stats_def(image: &impl core::ToInputArray, labels: &mut impl core::ToOutputArray, stats: &mut impl core::ToOutputArray, centroids: &mut impl core::ToOutputArray) -> Result<i32> {
		input_array_arg!(image);
		output_array_arg!(labels);
		output_array_arg!(stats);
		output_array_arg!(centroids);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_connectedComponentsWithStats_const__InputArrayR_const__OutputArrayR_const__OutputArrayR_const__OutputArrayR(image.as_raw__InputArray(), labels.as_raw__OutputArray(), stats.as_raw__OutputArray(), centroids.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// computes the connected components labeled image of boolean image and also produces a statistics output for each label
	/// 
	/// image with 4 or 8 way connectivity - returns N, the total number of labels [0, N-1] where 0
	/// represents the background label. ltype specifies the output label image type, an important
	/// consideration based on the total number of labels or alternatively the total number of pixels in
	/// the source image. ccltype specifies the connected components labeling algorithm to use, currently
	/// Bolelli (Spaghetti) [Bolelli2019](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Bolelli2019), Grana (BBDT) [Grana2010](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Grana2010) and Wu's (SAUF) [Wu2009](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Wu2009) algorithms
	/// are supported, see the [connected_components_algorithms_types] for details. Note that SAUF algorithm forces
	/// a row major ordering of labels while Spaghetti and BBDT do not.
	/// This function uses parallel version of the algorithms (statistics included) if at least one allowed
	/// parallel framework is enabled and if the rows of the image are at least twice the number returned by #getNumberOfCPUs.
	/// 
	/// ## Parameters
	/// * image: the 8-bit single-channel image to be labeled
	/// * labels: destination labeled image
	/// * stats: statistics output for each label, including the background label.
	/// Statistics are accessed via stats(label, COLUMN) where COLUMN is one of
	/// #ConnectedComponentsTypes, selecting the statistic. The data type is CV_32S.
	/// * centroids: centroid output for each label, including the background label. Centroids are
	/// accessed via centroids(label, 0) for x and centroids(label, 1) for y. The data type CV_64F.
	/// * connectivity: 8 or 4 for 8-way or 4-way connectivity respectively
	/// * ltype: output image label type. Currently CV_32S and CV_16U are supported.
	/// * ccltype: connected components algorithm type (see #ConnectedComponentsAlgorithmsTypes).
	/// 
	/// ## Overloaded parameters
	/// 
	/// * image: the 8-bit single-channel image to be labeled
	/// * labels: destination labeled image
	/// * stats: statistics output for each label, including the background label.
	/// Statistics are accessed via stats(label, COLUMN) where COLUMN is one of
	/// #ConnectedComponentsTypes, selecting the statistic. The data type is CV_32S.
	/// * centroids: centroid output for each label, including the background label. Centroids are
	/// accessed via centroids(label, 0) for x and centroids(label, 1) for y. The data type CV_64F.
	/// * connectivity: 8 or 4 for 8-way or 4-way connectivity respectively
	/// * ltype: output image label type. Currently CV_32S and CV_16U are supported.
	/// 
	/// ## C++ default parameters
	/// * connectivity: 8
	/// * ltype: CV_32S
	#[inline]
	pub fn connected_components_with_stats(image: &impl core::ToInputArray, labels: &mut impl core::ToOutputArray, stats: &mut impl core::ToOutputArray, centroids: &mut impl core::ToOutputArray, connectivity: i32, ltype: i32) -> Result<i32> {
		input_array_arg!(image);
		output_array_arg!(labels);
		output_array_arg!(stats);
		output_array_arg!(centroids);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_connectedComponentsWithStats_const__InputArrayR_const__OutputArrayR_const__OutputArrayR_const__OutputArrayR_int_int(image.as_raw__InputArray(), labels.as_raw__OutputArray(), stats.as_raw__OutputArray(), centroids.as_raw__OutputArray(), connectivity, ltype, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// computes the connected components labeled image of boolean image and also produces a statistics output for each label
	/// 
	/// image with 4 or 8 way connectivity - returns N, the total number of labels [0, N-1] where 0
	/// represents the background label. ltype specifies the output label image type, an important
	/// consideration based on the total number of labels or alternatively the total number of pixels in
	/// the source image. ccltype specifies the connected components labeling algorithm to use, currently
	/// Bolelli (Spaghetti) [Bolelli2019](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Bolelli2019), Grana (BBDT) [Grana2010](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Grana2010) and Wu's (SAUF) [Wu2009](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Wu2009) algorithms
	/// are supported, see the [connected_components_algorithms_types] for details. Note that SAUF algorithm forces
	/// a row major ordering of labels while Spaghetti and BBDT do not.
	/// This function uses parallel version of the algorithms (statistics included) if at least one allowed
	/// parallel framework is enabled and if the rows of the image are at least twice the number returned by #getNumberOfCPUs.
	/// 
	/// ## Parameters
	/// * image: the 8-bit single-channel image to be labeled
	/// * labels: destination labeled image
	/// * stats: statistics output for each label, including the background label.
	/// Statistics are accessed via stats(label, COLUMN) where COLUMN is one of
	/// #ConnectedComponentsTypes, selecting the statistic. The data type is CV_32S.
	/// * centroids: centroid output for each label, including the background label. Centroids are
	/// accessed via centroids(label, 0) for x and centroids(label, 1) for y. The data type CV_64F.
	/// * connectivity: 8 or 4 for 8-way or 4-way connectivity respectively
	/// * ltype: output image label type. Currently CV_32S and CV_16U are supported.
	/// * ccltype: connected components algorithm type (see #ConnectedComponentsAlgorithmsTypes).
	#[inline]
	pub fn connected_components_with_stats_with_algorithm(image: &impl core::ToInputArray, labels: &mut impl core::ToOutputArray, stats: &mut impl core::ToOutputArray, centroids: &mut impl core::ToOutputArray, connectivity: i32, ltype: i32, ccltype: i32) -> Result<i32> {
		input_array_arg!(image);
		output_array_arg!(labels);
		output_array_arg!(stats);
		output_array_arg!(centroids);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_connectedComponentsWithStats_const__InputArrayR_const__OutputArrayR_const__OutputArrayR_const__OutputArrayR_int_int_int(image.as_raw__InputArray(), labels.as_raw__OutputArray(), stats.as_raw__OutputArray(), centroids.as_raw__OutputArray(), connectivity, ltype, ccltype, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// @overload
	/// 
	/// ## Parameters
	/// * image: the 8-bit single-channel image to be labeled
	/// * labels: destination labeled image
	/// * connectivity: 8 or 4 for 8-way or 4-way connectivity respectively
	/// * ltype: output image label type. Currently CV_32S and CV_16U are supported.
	/// 
	/// ## Note
	/// This alternative version of [connected_components] function uses the following default values for its arguments:
	/// * connectivity: 8
	/// * ltype: CV_32S
	#[inline]
	pub fn connected_components_def(image: &impl core::ToInputArray, labels: &mut impl core::ToOutputArray) -> Result<i32> {
		input_array_arg!(image);
		output_array_arg!(labels);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_connectedComponents_const__InputArrayR_const__OutputArrayR(image.as_raw__InputArray(), labels.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// computes the connected components labeled image of boolean image
	/// 
	/// image with 4 or 8 way connectivity - returns N, the total number of labels [0, N-1] where 0
	/// represents the background label. ltype specifies the output label image type, an important
	/// consideration based on the total number of labels or alternatively the total number of pixels in
	/// the source image. ccltype specifies the connected components labeling algorithm to use, currently
	/// Bolelli (Spaghetti) [Bolelli2019](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Bolelli2019), Grana (BBDT) [Grana2010](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Grana2010) and Wu's (SAUF) [Wu2009](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Wu2009) algorithms
	/// are supported, see the [connected_components_algorithms_types] for details. Note that SAUF algorithm forces
	/// a row major ordering of labels while Spaghetti and BBDT do not.
	/// This function uses parallel version of the algorithms if at least one allowed
	/// parallel framework is enabled and if the rows of the image are at least twice the number returned by #getNumberOfCPUs.
	/// 
	/// ## Parameters
	/// * image: the 8-bit single-channel image to be labeled
	/// * labels: destination labeled image
	/// * connectivity: 8 or 4 for 8-way or 4-way connectivity respectively
	/// * ltype: output image label type. Currently CV_32S and CV_16U are supported.
	/// * ccltype: connected components algorithm type (see the #ConnectedComponentsAlgorithmsTypes).
	/// 
	/// ## Overloaded parameters
	/// 
	/// 
	/// * image: the 8-bit single-channel image to be labeled
	/// * labels: destination labeled image
	/// * connectivity: 8 or 4 for 8-way or 4-way connectivity respectively
	/// * ltype: output image label type. Currently CV_32S and CV_16U are supported.
	/// 
	/// ## C++ default parameters
	/// * connectivity: 8
	/// * ltype: CV_32S
	#[inline]
	pub fn connected_components(image: &impl core::ToInputArray, labels: &mut impl core::ToOutputArray, connectivity: i32, ltype: i32) -> Result<i32> {
		input_array_arg!(image);
		output_array_arg!(labels);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_connectedComponents_const__InputArrayR_const__OutputArrayR_int_int(image.as_raw__InputArray(), labels.as_raw__OutputArray(), connectivity, ltype, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// computes the connected components labeled image of boolean image
	/// 
	/// image with 4 or 8 way connectivity - returns N, the total number of labels [0, N-1] where 0
	/// represents the background label. ltype specifies the output label image type, an important
	/// consideration based on the total number of labels or alternatively the total number of pixels in
	/// the source image. ccltype specifies the connected components labeling algorithm to use, currently
	/// Bolelli (Spaghetti) [Bolelli2019](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Bolelli2019), Grana (BBDT) [Grana2010](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Grana2010) and Wu's (SAUF) [Wu2009](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Wu2009) algorithms
	/// are supported, see the [connected_components_algorithms_types] for details. Note that SAUF algorithm forces
	/// a row major ordering of labels while Spaghetti and BBDT do not.
	/// This function uses parallel version of the algorithms if at least one allowed
	/// parallel framework is enabled and if the rows of the image are at least twice the number returned by #getNumberOfCPUs.
	/// 
	/// ## Parameters
	/// * image: the 8-bit single-channel image to be labeled
	/// * labels: destination labeled image
	/// * connectivity: 8 or 4 for 8-way or 4-way connectivity respectively
	/// * ltype: output image label type. Currently CV_32S and CV_16U are supported.
	/// * ccltype: connected components algorithm type (see the #ConnectedComponentsAlgorithmsTypes).
	#[inline]
	pub fn connected_components_with_algorithm(image: &impl core::ToInputArray, labels: &mut impl core::ToOutputArray, connectivity: i32, ltype: i32, ccltype: i32) -> Result<i32> {
		input_array_arg!(image);
		output_array_arg!(labels);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_connectedComponents_const__InputArrayR_const__OutputArrayR_int_int_int(image.as_raw__InputArray(), labels.as_raw__OutputArray(), connectivity, ltype, ccltype, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates a contour area.
	/// 
	/// The function computes a contour area. Similarly to moments , the area is computed using the Green
	/// formula. Thus, the returned area and the number of non-zero pixels, if you draw the contour using
	/// [draw_contours] or [fill_poly] , can be different. Also, the function will most certainly give a wrong
	/// results for contours with self-intersections.
	/// 
	/// Example:
	/// ```C++
	///    vector<Point> contour;
	///    contour.push_back(Point2f(0, 0));
	///    contour.push_back(Point2f(10, 0));
	///    contour.push_back(Point2f(10, 10));
	///    contour.push_back(Point2f(5, 4));
	/// 
	///    double area0 = contourArea(contour);
	///    vector<Point> approx;
	///    approxPolyDP(contour, approx, 5, true);
	///    double area1 = contourArea(approx);
	/// 
	///    cout << "area0 =" << area0 << endl <<
	///            "area1 =" << area1 << endl <<
	///            "approx poly vertices" << approx.size() << endl;
	/// ```
	/// 
	/// ## Parameters
	/// * contour: Input vector of 2D points (contour vertices), stored in std::vector or Mat.
	/// * oriented: Oriented area flag. If it is true, the function returns a signed area value,
	/// depending on the contour orientation (clockwise or counter-clockwise). Using this feature you can
	/// determine orientation of a contour by taking the sign of an area. By default, the parameter is
	/// false, which means that the absolute value is returned.
	/// 
	/// ## Note
	/// This alternative version of [contour_area] function uses the following default values for its arguments:
	/// * oriented: false
	#[inline]
	pub fn contour_area_def(contour: &impl core::ToInputArray) -> Result<f64> {
		input_array_arg!(contour);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_contourArea_const__InputArrayR(contour.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates a contour area.
	/// 
	/// The function computes a contour area. Similarly to moments , the area is computed using the Green
	/// formula. Thus, the returned area and the number of non-zero pixels, if you draw the contour using
	/// [draw_contours] or [fill_poly] , can be different. Also, the function will most certainly give a wrong
	/// results for contours with self-intersections.
	/// 
	/// Example:
	/// ```C++
	///    vector<Point> contour;
	///    contour.push_back(Point2f(0, 0));
	///    contour.push_back(Point2f(10, 0));
	///    contour.push_back(Point2f(10, 10));
	///    contour.push_back(Point2f(5, 4));
	/// 
	///    double area0 = contourArea(contour);
	///    vector<Point> approx;
	///    approxPolyDP(contour, approx, 5, true);
	///    double area1 = contourArea(approx);
	/// 
	///    cout << "area0 =" << area0 << endl <<
	///            "area1 =" << area1 << endl <<
	///            "approx poly vertices" << approx.size() << endl;
	/// ```
	/// 
	/// ## Parameters
	/// * contour: Input vector of 2D points (contour vertices), stored in std::vector or Mat.
	/// * oriented: Oriented area flag. If it is true, the function returns a signed area value,
	/// depending on the contour orientation (clockwise or counter-clockwise). Using this feature you can
	/// determine orientation of a contour by taking the sign of an area. By default, the parameter is
	/// false, which means that the absolute value is returned.
	/// 
	/// ## C++ default parameters
	/// * oriented: false
	#[inline]
	pub fn contour_area(contour: &impl core::ToInputArray, oriented: bool) -> Result<f64> {
		input_array_arg!(contour);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_contourArea_const__InputArrayR_bool(contour.as_raw__InputArray(), oriented, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Converts image transformation maps from one representation to another.
	/// 
	/// The function converts a pair of maps for remap from one representation to another. The following
	/// options ( (map1.type(), map2.type())  (dstmap1.type(), dstmap2.type()) ) are
	/// supported:
	/// 
	/// - . This is the
	/// most frequently used conversion operation, in which the original floating-point maps (see #remap)
	/// are converted to a more compact and much faster fixed-point representation. The first output array
	/// contains the rounded coordinates and the second array (created only when nninterpolation=false )
	/// contains indices in the interpolation tables.
	/// 
	/// - . The same as above but
	/// the original maps are stored in one 2-channel matrix.
	/// 
	/// - Reverse conversion. Obviously, the reconstructed floating-point maps will not be exactly the same
	/// as the originals.
	/// 
	/// ## Parameters
	/// * map1: The first input map of type CV_16SC2, CV_32FC1, or CV_32FC2 .
	/// * map2: The second input map of type CV_16UC1, CV_32FC1, or none (empty matrix),
	/// respectively.
	/// * dstmap1: The first output map that has the type dstmap1type and the same size as src .
	/// * dstmap2: The second output map.
	/// * dstmap1type: Type of the first output map that should be CV_16SC2, CV_32FC1, or
	/// CV_32FC2 .
	/// * nninterpolation: Flag indicating whether the fixed-point maps are used for the
	/// nearest-neighbor or for a more complex interpolation.
	/// ## See also
	/// remap, undistort, initUndistortRectifyMap
	/// 
	/// ## Note
	/// This alternative version of [convert_maps] function uses the following default values for its arguments:
	/// * nninterpolation: false
	#[inline]
	pub fn convert_maps_def(map1: &impl core::ToInputArray, map2: &impl core::ToInputArray, dstmap1: &mut impl core::ToOutputArray, dstmap2: &mut impl core::ToOutputArray, dstmap1type: i32) -> Result<()> {
		input_array_arg!(map1);
		input_array_arg!(map2);
		output_array_arg!(dstmap1);
		output_array_arg!(dstmap2);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_convertMaps_const__InputArrayR_const__InputArrayR_const__OutputArrayR_const__OutputArrayR_int(map1.as_raw__InputArray(), map2.as_raw__InputArray(), dstmap1.as_raw__OutputArray(), dstmap2.as_raw__OutputArray(), dstmap1type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Converts image transformation maps from one representation to another.
	/// 
	/// The function converts a pair of maps for remap from one representation to another. The following
	/// options ( (map1.type(), map2.type())  (dstmap1.type(), dstmap2.type()) ) are
	/// supported:
	/// 
	/// - . This is the
	/// most frequently used conversion operation, in which the original floating-point maps (see #remap)
	/// are converted to a more compact and much faster fixed-point representation. The first output array
	/// contains the rounded coordinates and the second array (created only when nninterpolation=false )
	/// contains indices in the interpolation tables.
	/// 
	/// - . The same as above but
	/// the original maps are stored in one 2-channel matrix.
	/// 
	/// - Reverse conversion. Obviously, the reconstructed floating-point maps will not be exactly the same
	/// as the originals.
	/// 
	/// ## Parameters
	/// * map1: The first input map of type CV_16SC2, CV_32FC1, or CV_32FC2 .
	/// * map2: The second input map of type CV_16UC1, CV_32FC1, or none (empty matrix),
	/// respectively.
	/// * dstmap1: The first output map that has the type dstmap1type and the same size as src .
	/// * dstmap2: The second output map.
	/// * dstmap1type: Type of the first output map that should be CV_16SC2, CV_32FC1, or
	/// CV_32FC2 .
	/// * nninterpolation: Flag indicating whether the fixed-point maps are used for the
	/// nearest-neighbor or for a more complex interpolation.
	/// ## See also
	/// remap, undistort, initUndistortRectifyMap
	/// 
	/// ## C++ default parameters
	/// * nninterpolation: false
	#[inline]
	pub fn convert_maps(map1: &impl core::ToInputArray, map2: &impl core::ToInputArray, dstmap1: &mut impl core::ToOutputArray, dstmap2: &mut impl core::ToOutputArray, dstmap1type: i32, nninterpolation: bool) -> Result<()> {
		input_array_arg!(map1);
		input_array_arg!(map2);
		output_array_arg!(dstmap1);
		output_array_arg!(dstmap2);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_convertMaps_const__InputArrayR_const__InputArrayR_const__OutputArrayR_const__OutputArrayR_int_bool(map1.as_raw__InputArray(), map2.as_raw__InputArray(), dstmap1.as_raw__OutputArray(), dstmap2.as_raw__OutputArray(), dstmap1type, nninterpolation, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Finds the convex hull of a point set.
	/// 
	/// The function cv::convexHull finds the convex hull of a 2D point set using the Sklansky's algorithm [Sklansky82](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Sklansky82)
	/// that has *O(N logN)* complexity in the current implementation.
	/// 
	/// ## Parameters
	/// * points: Input 2D point set, stored in std::vector or Mat.
	/// * hull: Output convex hull. It is either an integer vector of indices or vector of points. In
	/// the first case, the hull elements are 0-based indices of the convex hull points in the original
	/// array (since the set of convex hull points is a subset of the original point set). In the second
	/// case, hull elements are the convex hull points themselves.
	/// * clockwise: Orientation flag. If it is true, the output convex hull is oriented clockwise.
	/// Otherwise, it is oriented counter-clockwise. The assumed coordinate system has its X axis pointing
	/// to the right, and its Y axis pointing upwards.
	/// * returnPoints: Operation flag. In case of a matrix, when the flag is true, the function
	/// returns convex hull points. Otherwise, it returns indices of the convex hull points. When the
	/// output array is std::vector, the flag is ignored, and the output depends on the type of the
	/// vector: std::vector\<int\> implies returnPoints=false, std::vector\<Point\> implies
	/// returnPoints=true.
	/// 
	/// 
	/// Note: `points` and `hull` should be different arrays, inplace processing isn't supported.
	/// 
	/// Check [tutorial_hull] "the corresponding tutorial" for more details.
	/// 
	/// useful links:
	/// 
	/// <https://www.learnopencv.com/convex-hull-using-opencv-in-python-and-c/>
	/// 
	/// ## Note
	/// This alternative version of [convex_hull] function uses the following default values for its arguments:
	/// * clockwise: false
	/// * return_points: true
	#[inline]
	pub fn convex_hull_def(points: &impl core::ToInputArray, hull: &mut impl core::ToOutputArray) -> Result<()> {
		input_array_arg!(points);
		output_array_arg!(hull);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_convexHull_const__InputArrayR_const__OutputArrayR(points.as_raw__InputArray(), hull.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Finds the convex hull of a point set.
	/// 
	/// The function cv::convexHull finds the convex hull of a 2D point set using the Sklansky's algorithm [Sklansky82](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Sklansky82)
	/// that has *O(N logN)* complexity in the current implementation.
	/// 
	/// ## Parameters
	/// * points: Input 2D point set, stored in std::vector or Mat.
	/// * hull: Output convex hull. It is either an integer vector of indices or vector of points. In
	/// the first case, the hull elements are 0-based indices of the convex hull points in the original
	/// array (since the set of convex hull points is a subset of the original point set). In the second
	/// case, hull elements are the convex hull points themselves.
	/// * clockwise: Orientation flag. If it is true, the output convex hull is oriented clockwise.
	/// Otherwise, it is oriented counter-clockwise. The assumed coordinate system has its X axis pointing
	/// to the right, and its Y axis pointing upwards.
	/// * returnPoints: Operation flag. In case of a matrix, when the flag is true, the function
	/// returns convex hull points. Otherwise, it returns indices of the convex hull points. When the
	/// output array is std::vector, the flag is ignored, and the output depends on the type of the
	/// vector: std::vector\<int\> implies returnPoints=false, std::vector\<Point\> implies
	/// returnPoints=true.
	/// 
	/// 
	/// Note: `points` and `hull` should be different arrays, inplace processing isn't supported.
	/// 
	/// Check [tutorial_hull] "the corresponding tutorial" for more details.
	/// 
	/// useful links:
	/// 
	/// <https://www.learnopencv.com/convex-hull-using-opencv-in-python-and-c/>
	/// 
	/// ## C++ default parameters
	/// * clockwise: false
	/// * return_points: true
	#[inline]
	pub fn convex_hull(points: &impl core::ToInputArray, hull: &mut impl core::ToOutputArray, clockwise: bool, return_points: bool) -> Result<()> {
		input_array_arg!(points);
		output_array_arg!(hull);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_convexHull_const__InputArrayR_const__OutputArrayR_bool_bool(points.as_raw__InputArray(), hull.as_raw__OutputArray(), clockwise, return_points, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Finds the convexity defects of a contour.
	/// 
	/// The figure below displays convexity defects of a hand contour:
	/// 
	/// 
	/// 
	/// ## Parameters
	/// * contour: Input contour.
	/// * convexhull: Convex hull obtained using convexHull that should contain indices of the contour
	/// points that make the hull.
	/// * convexityDefects: The output vector of convexity defects. In C++ and the new Python/Java
	/// interface each convexity defect is represented as 4-element integer vector (a.k.a. #Vec4i):
	/// (start_index, end_index, farthest_pt_index, fixpt_depth), where indices are 0-based indices
	/// in the original contour of the convexity defect beginning, end and the farthest point, and
	/// fixpt_depth is fixed-point approximation (with 8 fractional bits) of the distance between the
	/// farthest contour point and the hull. That is, to get the floating-point value of the depth will be
	/// fixpt_depth/256.0.
	#[inline]
	pub fn convexity_defects(contour: &impl core::ToInputArray, convexhull: &impl core::ToInputArray, convexity_defects: &mut impl core::ToOutputArray) -> Result<()> {
		input_array_arg!(contour);
		input_array_arg!(convexhull);
		output_array_arg!(convexity_defects);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_convexityDefects_const__InputArrayR_const__InputArrayR_const__OutputArrayR(contour.as_raw__InputArray(), convexhull.as_raw__InputArray(), convexity_defects.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates eigenvalues and eigenvectors of image blocks for corner detection.
	/// 
	/// For every pixel  , the function cornerEigenValsAndVecs considers a blockSize  blockSize
	/// neighborhood  . It calculates the covariation matrix of derivatives over the neighborhood as:
	/// 
	/// 
	/// 
	/// where the derivatives are computed using the Sobel operator.
	/// 
	/// After that, it finds eigenvectors and eigenvalues of  and stores them in the destination image as
	///  where
	/// 
	/// *    are the non-sorted eigenvalues of 
	/// *    are the eigenvectors corresponding to 
	/// *    are the eigenvectors corresponding to 
	/// 
	/// The output of the function can be used for robust edge or corner detection.
	/// 
	/// ## Parameters
	/// * src: Input single-channel 8-bit or floating-point image.
	/// * dst: Image to store the results. It has the same size as src and the type CV_32FC(6) .
	/// * blockSize: Neighborhood size (see details below).
	/// * ksize: Aperture parameter for the Sobel operator.
	/// * borderType: Pixel extrapolation method. See #BorderTypes. [BORDER_WRAP] is not supported.
	/// ## See also
	/// cornerMinEigenVal, cornerHarris, preCornerDetect
	/// 
	/// ## Note
	/// This alternative version of [corner_eigen_vals_and_vecs] function uses the following default values for its arguments:
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn corner_eigen_vals_and_vecs_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, block_size: i32, ksize: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_cornerEigenValsAndVecs_const__InputArrayR_const__OutputArrayR_int_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), block_size, ksize, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates eigenvalues and eigenvectors of image blocks for corner detection.
	/// 
	/// For every pixel  , the function cornerEigenValsAndVecs considers a blockSize  blockSize
	/// neighborhood  . It calculates the covariation matrix of derivatives over the neighborhood as:
	/// 
	/// 
	/// 
	/// where the derivatives are computed using the Sobel operator.
	/// 
	/// After that, it finds eigenvectors and eigenvalues of  and stores them in the destination image as
	///  where
	/// 
	/// *    are the non-sorted eigenvalues of 
	/// *    are the eigenvectors corresponding to 
	/// *    are the eigenvectors corresponding to 
	/// 
	/// The output of the function can be used for robust edge or corner detection.
	/// 
	/// ## Parameters
	/// * src: Input single-channel 8-bit or floating-point image.
	/// * dst: Image to store the results. It has the same size as src and the type CV_32FC(6) .
	/// * blockSize: Neighborhood size (see details below).
	/// * ksize: Aperture parameter for the Sobel operator.
	/// * borderType: Pixel extrapolation method. See #BorderTypes. [BORDER_WRAP] is not supported.
	/// ## See also
	/// cornerMinEigenVal, cornerHarris, preCornerDetect
	/// 
	/// ## C++ default parameters
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn corner_eigen_vals_and_vecs(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, block_size: i32, ksize: i32, border_type: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_cornerEigenValsAndVecs_const__InputArrayR_const__OutputArrayR_int_int_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), block_size, ksize, border_type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Harris corner detector.
	/// 
	/// The function runs the Harris corner detector on the image. Similarly to cornerMinEigenVal and
	/// cornerEigenValsAndVecs , for each pixel  it calculates a  gradient covariance
	/// matrix  over a  neighborhood. Then, it
	/// computes the following characteristic:
	/// 
	/// 
	/// 
	/// Corners in the image can be found as the local maxima of this response map.
	/// 
	/// ## Parameters
	/// * src: Input single-channel 8-bit or floating-point image.
	/// * dst: Image to store the Harris detector responses. It has the type CV_32FC1 and the same
	/// size as src .
	/// * blockSize: Neighborhood size (see the details on [corner_eigen_vals_and_vecs] ).
	/// * ksize: Aperture parameter for the Sobel operator.
	/// * k: Harris detector free parameter. See the formula above.
	/// * borderType: Pixel extrapolation method. See #BorderTypes. [BORDER_WRAP] is not supported.
	/// 
	/// ## Note
	/// This alternative version of [corner_harris] function uses the following default values for its arguments:
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn corner_harris_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, block_size: i32, ksize: i32, k: f64) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_cornerHarris_const__InputArrayR_const__OutputArrayR_int_int_double(src.as_raw__InputArray(), dst.as_raw__OutputArray(), block_size, ksize, k, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Harris corner detector.
	/// 
	/// The function runs the Harris corner detector on the image. Similarly to cornerMinEigenVal and
	/// cornerEigenValsAndVecs , for each pixel  it calculates a  gradient covariance
	/// matrix  over a  neighborhood. Then, it
	/// computes the following characteristic:
	/// 
	/// 
	/// 
	/// Corners in the image can be found as the local maxima of this response map.
	/// 
	/// ## Parameters
	/// * src: Input single-channel 8-bit or floating-point image.
	/// * dst: Image to store the Harris detector responses. It has the type CV_32FC1 and the same
	/// size as src .
	/// * blockSize: Neighborhood size (see the details on [corner_eigen_vals_and_vecs] ).
	/// * ksize: Aperture parameter for the Sobel operator.
	/// * k: Harris detector free parameter. See the formula above.
	/// * borderType: Pixel extrapolation method. See #BorderTypes. [BORDER_WRAP] is not supported.
	/// 
	/// ## C++ default parameters
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn corner_harris(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, block_size: i32, ksize: i32, k: f64, border_type: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_cornerHarris_const__InputArrayR_const__OutputArrayR_int_int_double_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), block_size, ksize, k, border_type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates the minimal eigenvalue of gradient matrices for corner detection.
	/// 
	/// The function is similar to cornerEigenValsAndVecs but it calculates and stores only the minimal
	/// eigenvalue of the covariance matrix of derivatives, that is,  in terms
	/// of the formulae in the cornerEigenValsAndVecs description.
	/// 
	/// ## Parameters
	/// * src: Input single-channel 8-bit or floating-point image.
	/// * dst: Image to store the minimal eigenvalues. It has the type CV_32FC1 and the same size as
	/// src .
	/// * blockSize: Neighborhood size (see the details on [corner_eigen_vals_and_vecs] ).
	/// * ksize: Aperture parameter for the Sobel operator.
	/// * borderType: Pixel extrapolation method. See #BorderTypes. [BORDER_WRAP] is not supported.
	/// 
	/// ## Note
	/// This alternative version of [corner_min_eigen_val] function uses the following default values for its arguments:
	/// * ksize: 3
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn corner_min_eigen_val_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, block_size: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_cornerMinEigenVal_const__InputArrayR_const__OutputArrayR_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), block_size, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates the minimal eigenvalue of gradient matrices for corner detection.
	/// 
	/// The function is similar to cornerEigenValsAndVecs but it calculates and stores only the minimal
	/// eigenvalue of the covariance matrix of derivatives, that is,  in terms
	/// of the formulae in the cornerEigenValsAndVecs description.
	/// 
	/// ## Parameters
	/// * src: Input single-channel 8-bit or floating-point image.
	/// * dst: Image to store the minimal eigenvalues. It has the type CV_32FC1 and the same size as
	/// src .
	/// * blockSize: Neighborhood size (see the details on [corner_eigen_vals_and_vecs] ).
	/// * ksize: Aperture parameter for the Sobel operator.
	/// * borderType: Pixel extrapolation method. See #BorderTypes. [BORDER_WRAP] is not supported.
	/// 
	/// ## C++ default parameters
	/// * ksize: 3
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn corner_min_eigen_val(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, block_size: i32, ksize: i32, border_type: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_cornerMinEigenVal_const__InputArrayR_const__OutputArrayR_int_int_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), block_size, ksize, border_type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Refines the corner locations.
	/// 
	/// The function iterates to find the sub-pixel accurate location of corners or radial saddle
	/// points as described in [forstner1987fast](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_forstner1987fast), and as shown on the figure below.
	/// 
	/// 
	/// 
	/// Sub-pixel accurate corner locator is based on the observation that every vector from the center 
	/// to a point  located within a neighborhood of  is orthogonal to the image gradient at 
	/// subject to image and measurement noise. Consider the expression:
	/// 
	/// 
	/// 
	/// where  is an image gradient at one of the points  in a neighborhood of  . The
	/// value of  is to be found so that  is minimized. A system of equations may be set up
	/// with  set to zero:
	/// 
	/// 
	/// 
	/// where the gradients are summed within a neighborhood ("search window") of  . Calling the first
	/// gradient term  and the second gradient term  gives:
	/// 
	/// 
	/// 
	/// The algorithm sets the center of the neighborhood window at this new center  and then iterates
	/// until the center stays within a set threshold.
	/// 
	/// ## Parameters
	/// * image: Input single-channel, 8-bit or float image.
	/// * corners: Initial coordinates of the input corners and refined coordinates provided for
	/// output.
	/// * winSize: Half of the side length of the search window. For example, if winSize=Size(5,5) ,
	/// then a  search window is used.
	/// * zeroZone: Half of the size of the dead region in the middle of the search zone over which
	/// the summation in the formula below is not done. It is used sometimes to avoid possible
	/// singularities of the autocorrelation matrix. The value of (-1,-1) indicates that there is no such
	/// a size.
	/// * criteria: Criteria for termination of the iterative process of corner refinement. That is,
	/// the process of corner position refinement stops either after criteria.maxCount iterations or when
	/// the corner position moves by less than criteria.epsilon on some iteration.
	#[inline]
	pub fn corner_sub_pix(image: &impl core::ToInputArray, corners: &mut impl core::ToInputOutputArray, win_size: core::Size, zero_zone: core::Size, criteria: core::TermCriteria) -> Result<()> {
		input_array_arg!(image);
		input_output_array_arg!(corners);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_cornerSubPix_const__InputArrayR_const__InputOutputArrayR_Size_Size_TermCriteria(image.as_raw__InputArray(), corners.as_raw__InputOutputArray(), win_size.opencv_as_extern(), zero_zone.opencv_as_extern(), criteria.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Creates a smart pointer to a cv::CLAHE class and initializes it.
	/// 
	/// ## Parameters
	/// * clipLimit: Threshold for contrast limiting.
	/// * tileGridSize: Size of grid for histogram equalization. Input image will be divided into
	/// equally sized rectangular tiles. tileGridSize defines the number of tiles in row and column.
	/// 
	/// ## Note
	/// This alternative version of [create_clahe] function uses the following default values for its arguments:
	/// * clip_limit: 40.0
	/// * tile_grid_size: Size(8,8)
	#[inline]
	pub fn create_clahe_def() -> Result<core::Ptr<crate::imgproc::CLAHE>> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_createCLAHE(ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		let ret = unsafe { core::Ptr::<crate::imgproc::CLAHE>::opencv_from_extern(ret) };
		Ok(ret)
	}
	
	/// Creates a smart pointer to a cv::CLAHE class and initializes it.
	/// 
	/// ## Parameters
	/// * clipLimit: Threshold for contrast limiting.
	/// * tileGridSize: Size of grid for histogram equalization. Input image will be divided into
	/// equally sized rectangular tiles. tileGridSize defines the number of tiles in row and column.
	/// 
	/// ## C++ default parameters
	/// * clip_limit: 40.0
	/// * tile_grid_size: Size(8,8)
	#[inline]
	pub fn create_clahe(clip_limit: f64, tile_grid_size: core::Size) -> Result<core::Ptr<crate::imgproc::CLAHE>> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_createCLAHE_double_Size(clip_limit, tile_grid_size.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		let ret = unsafe { core::Ptr::<crate::imgproc::CLAHE>::opencv_from_extern(ret) };
		Ok(ret)
	}
	
	/// Creates a smart pointer to a cv::GeneralizedHoughBallard class and initializes it.
	#[inline]
	pub fn create_generalized_hough_ballard() -> Result<core::Ptr<crate::imgproc::GeneralizedHoughBallard>> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_createGeneralizedHoughBallard(ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		let ret = unsafe { core::Ptr::<crate::imgproc::GeneralizedHoughBallard>::opencv_from_extern(ret) };
		Ok(ret)
	}
	
	/// Creates a smart pointer to a cv::GeneralizedHoughGuil class and initializes it.
	#[inline]
	pub fn create_generalized_hough_guil() -> Result<core::Ptr<crate::imgproc::GeneralizedHoughGuil>> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_createGeneralizedHoughGuil(ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		let ret = unsafe { core::Ptr::<crate::imgproc::GeneralizedHoughGuil>::opencv_from_extern(ret) };
		Ok(ret)
	}
	
	/// This function computes a Hanning window coefficients in two dimensions.
	/// 
	/// See (<http://en.wikipedia.org/wiki/Hann_function>) and (<http://en.wikipedia.org/wiki/Window_function>)
	/// for more information.
	/// 
	/// An example is shown below:
	/// ```C++
	///    // create hanning window of size 100x100 and type CV_32F
	///    Mat hann;
	///    createHanningWindow(hann, Size(100, 100), CV_32F);
	/// ```
	/// 
	/// ## Parameters
	/// * dst: Destination array to place Hann coefficients in
	/// * winSize: The window size specifications (both width and height must be > 1)
	/// * type: Created array type
	#[inline]
	pub fn create_hanning_window(dst: &mut impl core::ToOutputArray, win_size: core::Size, typ: i32) -> Result<()> {
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_createHanningWindow_const__OutputArrayR_Size_int(dst.as_raw__OutputArray(), win_size.opencv_as_extern(), typ, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Creates a smart pointer to a LineSegmentDetector object and initializes it.
	/// 
	/// The LineSegmentDetector algorithm is defined using the standard values. Only advanced users may want
	/// to edit those, as to tailor it for their own application.
	/// 
	/// ## Parameters
	/// * refine: The way found lines will be refined, see [line_segment_detector_modes]
	/// * scale: The scale of the image that will be used to find the lines. Range (0..1].
	/// * sigma_scale: Sigma for Gaussian filter. It is computed as sigma = sigma_scale/scale.
	/// * quant: Bound to the quantization error on the gradient norm.
	/// * ang_th: Gradient angle tolerance in degrees.
	/// * log_eps: Detection threshold: -log10(NFA) \> log_eps. Used only when advance refinement is chosen.
	/// * density_th: Minimal density of aligned region points in the enclosing rectangle.
	/// * n_bins: Number of bins in pseudo-ordering of gradient modulus.
	/// 
	/// ## Note
	/// This alternative version of [create_line_segment_detector] function uses the following default values for its arguments:
	/// * refine: LSD_REFINE_STD
	/// * scale: 0.8
	/// * sigma_scale: 0.6
	/// * quant: 2.0
	/// * ang_th: 22.5
	/// * log_eps: 0
	/// * density_th: 0.7
	/// * n_bins: 1024
	#[inline]
	pub fn create_line_segment_detector_def() -> Result<core::Ptr<crate::imgproc::LineSegmentDetector>> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_createLineSegmentDetector(ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		let ret = unsafe { core::Ptr::<crate::imgproc::LineSegmentDetector>::opencv_from_extern(ret) };
		Ok(ret)
	}
	
	/// Creates a smart pointer to a LineSegmentDetector object and initializes it.
	/// 
	/// The LineSegmentDetector algorithm is defined using the standard values. Only advanced users may want
	/// to edit those, as to tailor it for their own application.
	/// 
	/// ## Parameters
	/// * refine: The way found lines will be refined, see [line_segment_detector_modes]
	/// * scale: The scale of the image that will be used to find the lines. Range (0..1].
	/// * sigma_scale: Sigma for Gaussian filter. It is computed as sigma = sigma_scale/scale.
	/// * quant: Bound to the quantization error on the gradient norm.
	/// * ang_th: Gradient angle tolerance in degrees.
	/// * log_eps: Detection threshold: -log10(NFA) \> log_eps. Used only when advance refinement is chosen.
	/// * density_th: Minimal density of aligned region points in the enclosing rectangle.
	/// * n_bins: Number of bins in pseudo-ordering of gradient modulus.
	/// 
	/// ## C++ default parameters
	/// * refine: LSD_REFINE_STD
	/// * scale: 0.8
	/// * sigma_scale: 0.6
	/// * quant: 2.0
	/// * ang_th: 22.5
	/// * log_eps: 0
	/// * density_th: 0.7
	/// * n_bins: 1024
	#[inline]
	pub fn create_line_segment_detector(refine: i32, scale: f64, sigma_scale: f64, quant: f64, ang_th: f64, log_eps: f64, density_th: f64, n_bins: i32) -> Result<core::Ptr<crate::imgproc::LineSegmentDetector>> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_createLineSegmentDetector_int_double_double_double_double_double_double_int(refine, scale, sigma_scale, quant, ang_th, log_eps, density_th, n_bins, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		let ret = unsafe { core::Ptr::<crate::imgproc::LineSegmentDetector>::opencv_from_extern(ret) };
		Ok(ret)
	}
	
	/// Converts an image from one color space to another where the source image is
	/// stored in two planes.
	/// 
	/// This function only supports YUV420 to RGB conversion as of now.
	/// 
	/// ## Parameters
	/// * src1: : 8-bit image (#CV_8U) of the Y plane.
	/// * src2: : image containing interleaved U/V plane.
	/// * dst: : output image.
	/// * code: : Specifies the type of conversion. It can take any of the following values:
	/// - [COLOR_YUV2BGR_NV12]
	/// - [COLOR_YUV2RGB_NV12]
	/// - [COLOR_YUV2BGRA_NV12]
	/// - [COLOR_YUV2RGBA_NV12]
	/// - [COLOR_YUV2BGR_NV21]
	/// - [COLOR_YUV2RGB_NV21]
	/// - [COLOR_YUV2BGRA_NV21]
	/// - #COLOR_YUV2RGBA_NV21
	#[inline]
	pub fn cvt_color_two_plane(src1: &impl core::ToInputArray, src2: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, code: i32) -> Result<()> {
		input_array_arg!(src1);
		input_array_arg!(src2);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_cvtColorTwoPlane_const__InputArrayR_const__InputArrayR_const__OutputArrayR_int(src1.as_raw__InputArray(), src2.as_raw__InputArray(), dst.as_raw__OutputArray(), code, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Converts an image from one color space to another.
	/// 
	/// The function converts an input image from one color space to another. In case of a transformation
	/// to-from RGB color space, the order of the channels should be specified explicitly (RGB or BGR). Note
	/// that the default color format in OpenCV is often referred to as RGB but it is actually BGR (the
	/// bytes are reversed). So the first byte in a standard (24-bit) color image will be an 8-bit Blue
	/// component, the second byte will be Green, and the third byte will be Red. The fourth, fifth, and
	/// sixth bytes would then be the second pixel (Blue, then Green, then Red), and so on.
	/// 
	/// The conventional ranges for R, G, and B channel values are:
	/// *   0 to 255 for CV_8U images
	/// *   0 to 65535 for CV_16U images
	/// *   0 to 1 for CV_32F images
	/// 
	/// In case of linear transformations, the range does not matter. But in case of a non-linear
	/// transformation, an input RGB image should be normalized to the proper value range to get the correct
	/// results, for example, for RGB  L\*u\*v\* transformation. For example, if you have a
	/// 32-bit floating-point image directly converted from an 8-bit image without any scaling, then it will
	/// have the 0..255 value range instead of 0..1 assumed by the function. So, before calling [cvt_color] ,
	/// you need first to scale the image down:
	/// ```C++
	///    img *= 1./255;
	///    cvtColor(img, img, COLOR_BGR2Luv);
	/// ```
	/// 
	/// If you use [cvt_color] with 8-bit images, the conversion will have some information lost. For many
	/// applications, this will not be noticeable but it is recommended to use 32-bit images in applications
	/// that need the full range of colors or that convert an image before an operation and then convert
	/// back.
	/// 
	/// If conversion adds the alpha channel, its value will set to the maximum of corresponding channel
	/// range: 255 for CV_8U, 65535 for CV_16U, 1 for CV_32F.
	/// 
	/// ## Parameters
	/// * src: input image: 8-bit unsigned, 16-bit unsigned ( CV_16UC... ), or single-precision
	/// floating-point.
	/// * dst: output image of the same size and depth as src.
	/// * code: color space conversion code (see #ColorConversionCodes).
	/// * dstCn: number of channels in the destination image; if the parameter is 0, the number of the
	/// channels is derived automatically from src and code.
	/// ## See also
	/// [imgproc_color_conversions]
	/// 
	/// ## Note
	/// This alternative version of [cvt_color] function uses the following default values for its arguments:
	/// * dst_cn: 0
	#[inline]
	pub fn cvt_color_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, code: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_cvtColor_const__InputArrayR_const__OutputArrayR_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), code, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Converts an image from one color space to another.
	/// 
	/// The function converts an input image from one color space to another. In case of a transformation
	/// to-from RGB color space, the order of the channels should be specified explicitly (RGB or BGR). Note
	/// that the default color format in OpenCV is often referred to as RGB but it is actually BGR (the
	/// bytes are reversed). So the first byte in a standard (24-bit) color image will be an 8-bit Blue
	/// component, the second byte will be Green, and the third byte will be Red. The fourth, fifth, and
	/// sixth bytes would then be the second pixel (Blue, then Green, then Red), and so on.
	/// 
	/// The conventional ranges for R, G, and B channel values are:
	/// *   0 to 255 for CV_8U images
	/// *   0 to 65535 for CV_16U images
	/// *   0 to 1 for CV_32F images
	/// 
	/// In case of linear transformations, the range does not matter. But in case of a non-linear
	/// transformation, an input RGB image should be normalized to the proper value range to get the correct
	/// results, for example, for RGB  L\*u\*v\* transformation. For example, if you have a
	/// 32-bit floating-point image directly converted from an 8-bit image without any scaling, then it will
	/// have the 0..255 value range instead of 0..1 assumed by the function. So, before calling [cvt_color] ,
	/// you need first to scale the image down:
	/// ```C++
	///    img *= 1./255;
	///    cvtColor(img, img, COLOR_BGR2Luv);
	/// ```
	/// 
	/// If you use [cvt_color] with 8-bit images, the conversion will have some information lost. For many
	/// applications, this will not be noticeable but it is recommended to use 32-bit images in applications
	/// that need the full range of colors or that convert an image before an operation and then convert
	/// back.
	/// 
	/// If conversion adds the alpha channel, its value will set to the maximum of corresponding channel
	/// range: 255 for CV_8U, 65535 for CV_16U, 1 for CV_32F.
	/// 
	/// ## Parameters
	/// * src: input image: 8-bit unsigned, 16-bit unsigned ( CV_16UC... ), or single-precision
	/// floating-point.
	/// * dst: output image of the same size and depth as src.
	/// * code: color space conversion code (see #ColorConversionCodes).
	/// * dstCn: number of channels in the destination image; if the parameter is 0, the number of the
	/// channels is derived automatically from src and code.
	/// ## See also
	/// [imgproc_color_conversions]
	/// 
	/// ## C++ default parameters
	/// * dst_cn: 0
	#[inline]
	pub fn cvt_color(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, code: i32, dst_cn: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_cvtColor_const__InputArrayR_const__OutputArrayR_int_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), code, dst_cn, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// main function for all demosaicing processes
	/// 
	/// ## Parameters
	/// * src: input image: 8-bit unsigned or 16-bit unsigned.
	/// * dst: output image of the same size and depth as src.
	/// * code: Color space conversion code (see the description below).
	/// * dstCn: number of channels in the destination image; if the parameter is 0, the number of the
	/// channels is derived automatically from src and code.
	/// 
	/// The function can do the following transformations:
	/// 
	/// *   Demosaicing using bilinear interpolation
	/// 
	///    [color_bayer_bg2_bgr] , [color_bayer_gb2_bgr] , [color_bayer_rg2_bgr] , [color_bayer_gr2_bgr]
	/// 
	///    [color_bayer_bg2_gray] , [color_bayer_gb2_gray] , [color_bayer_rg2_gray] , [color_bayer_gr2_gray]
	/// 
	/// *   Demosaicing using Variable Number of Gradients.
	/// 
	///    [color_bayer_bg2_bgr_vng] , [color_bayer_gb2_bgr_vng] , [color_bayer_rg2_bgr_vng] , [color_bayer_gr2_bgr_vng]
	/// 
	/// *   Edge-Aware Demosaicing.
	/// 
	///    [color_bayer_bg2_bgr_ea] , [color_bayer_gb2_bgr_ea] , [color_bayer_rg2_bgr_ea] , [color_bayer_gr2_bgr_ea]
	/// 
	/// *   Demosaicing with alpha channel
	/// 
	///    [color_bayer_bg2_bgra] , [color_bayer_gb2_bgra] , [color_bayer_rg2_bgra] , [color_bayer_gr2_bgra]
	/// ## See also
	/// cvtColor
	/// 
	/// ## Note
	/// This alternative version of [demosaicing] function uses the following default values for its arguments:
	/// * dst_cn: 0
	#[inline]
	pub fn demosaicing_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, code: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_demosaicing_const__InputArrayR_const__OutputArrayR_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), code, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// main function for all demosaicing processes
	/// 
	/// ## Parameters
	/// * src: input image: 8-bit unsigned or 16-bit unsigned.
	/// * dst: output image of the same size and depth as src.
	/// * code: Color space conversion code (see the description below).
	/// * dstCn: number of channels in the destination image; if the parameter is 0, the number of the
	/// channels is derived automatically from src and code.
	/// 
	/// The function can do the following transformations:
	/// 
	/// *   Demosaicing using bilinear interpolation
	/// 
	///    [color_bayer_bg2_bgr] , [color_bayer_gb2_bgr] , [color_bayer_rg2_bgr] , [color_bayer_gr2_bgr]
	/// 
	///    [color_bayer_bg2_gray] , [color_bayer_gb2_gray] , [color_bayer_rg2_gray] , [color_bayer_gr2_gray]
	/// 
	/// *   Demosaicing using Variable Number of Gradients.
	/// 
	///    [color_bayer_bg2_bgr_vng] , [color_bayer_gb2_bgr_vng] , [color_bayer_rg2_bgr_vng] , [color_bayer_gr2_bgr_vng]
	/// 
	/// *   Edge-Aware Demosaicing.
	/// 
	///    [color_bayer_bg2_bgr_ea] , [color_bayer_gb2_bgr_ea] , [color_bayer_rg2_bgr_ea] , [color_bayer_gr2_bgr_ea]
	/// 
	/// *   Demosaicing with alpha channel
	/// 
	///    [color_bayer_bg2_bgra] , [color_bayer_gb2_bgra] , [color_bayer_rg2_bgra] , [color_bayer_gr2_bgra]
	/// ## See also
	/// cvtColor
	/// 
	/// ## C++ default parameters
	/// * dst_cn: 0
	#[inline]
	pub fn demosaicing(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, code: i32, dst_cn: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_demosaicing_const__InputArrayR_const__OutputArrayR_int_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), code, dst_cn, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Dilates an image by using a specific structuring element.
	/// 
	/// The function dilates the source image using the specified structuring element that determines the
	/// shape of a pixel neighborhood over which the maximum is taken:
	/// 
	/// 
	/// The function supports the in-place mode. Dilation can be applied several ( iterations ) times. In
	/// case of multi-channel images, each channel is processed independently.
	/// 
	/// ## Parameters
	/// * src: input image; the number of channels can be arbitrary, but the depth should be one of
	/// CV_8U, CV_16U, CV_16S, CV_32F or CV_64F.
	/// * dst: output image of the same size and type as src.
	/// * kernel: structuring element used for dilation; if element=Mat(), a 3 x 3 rectangular
	/// structuring element is used. Kernel can be created using [get_structuring_element]
	/// * anchor: position of the anchor within the element; default value (-1, -1) means that the
	/// anchor is at the element center.
	/// * iterations: number of times dilation is applied.
	/// * borderType: pixel extrapolation method, see #BorderTypes. [BORDER_WRAP] is not suported.
	/// * borderValue: border value in case of a constant border
	/// ## See also
	/// erode, morphologyEx, getStructuringElement
	/// 
	/// ## Note
	/// This alternative version of [dilate] function uses the following default values for its arguments:
	/// * anchor: Point(-1,-1)
	/// * iterations: 1
	/// * border_type: BORDER_CONSTANT
	/// * border_value: morphologyDefaultBorderValue()
	#[inline]
	pub fn dilate_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, kernel: &impl core::ToInputArray) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		input_array_arg!(kernel);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_dilate_const__InputArrayR_const__OutputArrayR_const__InputArrayR(src.as_raw__InputArray(), dst.as_raw__OutputArray(), kernel.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Dilates an image by using a specific structuring element.
	/// 
	/// The function dilates the source image using the specified structuring element that determines the
	/// shape of a pixel neighborhood over which the maximum is taken:
	/// 
	/// 
	/// The function supports the in-place mode. Dilation can be applied several ( iterations ) times. In
	/// case of multi-channel images, each channel is processed independently.
	/// 
	/// ## Parameters
	/// * src: input image; the number of channels can be arbitrary, but the depth should be one of
	/// CV_8U, CV_16U, CV_16S, CV_32F or CV_64F.
	/// * dst: output image of the same size and type as src.
	/// * kernel: structuring element used for dilation; if element=Mat(), a 3 x 3 rectangular
	/// structuring element is used. Kernel can be created using [get_structuring_element]
	/// * anchor: position of the anchor within the element; default value (-1, -1) means that the
	/// anchor is at the element center.
	/// * iterations: number of times dilation is applied.
	/// * borderType: pixel extrapolation method, see #BorderTypes. [BORDER_WRAP] is not suported.
	/// * borderValue: border value in case of a constant border
	/// ## See also
	/// erode, morphologyEx, getStructuringElement
	/// 
	/// ## C++ default parameters
	/// * anchor: Point(-1,-1)
	/// * iterations: 1
	/// * border_type: BORDER_CONSTANT
	/// * border_value: morphologyDefaultBorderValue()
	#[inline]
	pub fn dilate(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, kernel: &impl core::ToInputArray, anchor: core::Point, iterations: i32, border_type: i32, border_value: core::Scalar) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		input_array_arg!(kernel);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_dilate_const__InputArrayR_const__OutputArrayR_const__InputArrayR_Point_int_int_const_ScalarR(src.as_raw__InputArray(), dst.as_raw__OutputArray(), kernel.as_raw__InputArray(), anchor.opencv_as_extern(), iterations, border_type, &border_value, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates the distance to the closest zero pixel for each pixel of the source image.
	/// 
	/// The function cv::distanceTransform calculates the approximate or precise distance from every binary
	/// image pixel to the nearest zero pixel. For zero image pixels, the distance will obviously be zero.
	/// 
	/// When maskSize == [DIST_MASK_PRECISE] and distanceType == [DIST_L2] , the function runs the
	/// algorithm described in [Felzenszwalb04](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Felzenszwalb04) . This algorithm is parallelized with the TBB library.
	/// 
	/// In other cases, the algorithm [Borgefors86](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Borgefors86) is used. This means that for a pixel the function
	/// finds the shortest path to the nearest zero pixel consisting of basic shifts: horizontal, vertical,
	/// diagonal, or knight's move (the latest is available for a  mask). The overall
	/// distance is calculated as a sum of these basic distances. Since the distance function should be
	/// symmetric, all of the horizontal and vertical shifts must have the same cost (denoted as a ), all
	/// the diagonal shifts must have the same cost (denoted as `b`), and all knight's moves must have the
	/// same cost (denoted as `c`). For the [DIST_C] and [DIST_L1] types, the distance is calculated
	/// precisely, whereas for [DIST_L2] (Euclidean distance) the distance can be calculated only with a
	/// relative error (a  mask gives more accurate results). For `a`,`b`, and `c`, OpenCV
	/// uses the values suggested in the original paper:
	/// - DIST_L1: `a = 1, b = 2`
	/// - DIST_L2:
	///    - `3 x 3`: `a=0.955, b=1.3693`
	///    - `5 x 5`: `a=1, b=1.4, c=2.1969`
	/// - DIST_C: `a = 1, b = 1`
	/// 
	/// Typically, for a fast, coarse distance estimation #DIST_L2, a  mask is used. For a
	/// more accurate distance estimation #DIST_L2, a  mask or the precise algorithm is used.
	/// Note that both the precise and the approximate algorithms are linear on the number of pixels.
	/// 
	/// This variant of the function does not only compute the minimum distance for each pixel 
	/// but also identifies the nearest connected component consisting of zero pixels
	/// (labelType==#DIST_LABEL_CCOMP) or the nearest zero pixel (labelType==#DIST_LABEL_PIXEL). Index of the
	/// component/pixel is stored in `labels(x, y)`. When labelType==#DIST_LABEL_CCOMP, the function
	/// automatically finds connected components of zero pixels in the input image and marks them with
	/// distinct labels. When labelType==#DIST_LABEL_PIXEL, the function scans through the input image and
	/// marks all the zero pixels with distinct labels.
	/// 
	/// In this mode, the complexity is still linear. That is, the function provides a very fast way to
	/// compute the Voronoi diagram for a binary image. Currently, the second variant can use only the
	/// approximate distance transform algorithm, i.e. maskSize=[DIST_MASK_PRECISE] is not supported
	/// yet.
	/// 
	/// ## Parameters
	/// * src: 8-bit, single-channel (binary) source image.
	/// * dst: Output image with calculated distances. It is a 8-bit or 32-bit floating-point,
	/// single-channel image of the same size as src.
	/// * labels: Output 2D array of labels (the discrete Voronoi diagram). It has the type
	/// CV_32SC1 and the same size as src.
	/// * distanceType: Type of distance, see [distance_types]
	/// * maskSize: Size of the distance transform mask, see #DistanceTransformMasks.
	/// [DIST_MASK_PRECISE] is not supported by this variant. In case of the [DIST_L1] or [DIST_C] distance type,
	/// the parameter is forced to 3 because a  mask gives the same result as  or any larger aperture.
	/// * labelType: Type of the label array to build, see #DistanceTransformLabelTypes.
	/// 
	/// ## Note
	/// This alternative version of [distance_transform_with_labels] function uses the following default values for its arguments:
	/// * label_type: DIST_LABEL_CCOMP
	#[inline]
	pub fn distance_transform_with_labels_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, labels: &mut impl core::ToOutputArray, distance_type: i32, mask_size: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		output_array_arg!(labels);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_distanceTransform_const__InputArrayR_const__OutputArrayR_const__OutputArrayR_int_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), labels.as_raw__OutputArray(), distance_type, mask_size, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates the distance to the closest zero pixel for each pixel of the source image.
	/// 
	/// The function cv::distanceTransform calculates the approximate or precise distance from every binary
	/// image pixel to the nearest zero pixel. For zero image pixels, the distance will obviously be zero.
	/// 
	/// When maskSize == [DIST_MASK_PRECISE] and distanceType == [DIST_L2] , the function runs the
	/// algorithm described in [Felzenszwalb04](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Felzenszwalb04) . This algorithm is parallelized with the TBB library.
	/// 
	/// In other cases, the algorithm [Borgefors86](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Borgefors86) is used. This means that for a pixel the function
	/// finds the shortest path to the nearest zero pixel consisting of basic shifts: horizontal, vertical,
	/// diagonal, or knight's move (the latest is available for a  mask). The overall
	/// distance is calculated as a sum of these basic distances. Since the distance function should be
	/// symmetric, all of the horizontal and vertical shifts must have the same cost (denoted as a ), all
	/// the diagonal shifts must have the same cost (denoted as `b`), and all knight's moves must have the
	/// same cost (denoted as `c`). For the [DIST_C] and [DIST_L1] types, the distance is calculated
	/// precisely, whereas for [DIST_L2] (Euclidean distance) the distance can be calculated only with a
	/// relative error (a  mask gives more accurate results). For `a`,`b`, and `c`, OpenCV
	/// uses the values suggested in the original paper:
	/// - DIST_L1: `a = 1, b = 2`
	/// - DIST_L2:
	///    - `3 x 3`: `a=0.955, b=1.3693`
	///    - `5 x 5`: `a=1, b=1.4, c=2.1969`
	/// - DIST_C: `a = 1, b = 1`
	/// 
	/// Typically, for a fast, coarse distance estimation #DIST_L2, a  mask is used. For a
	/// more accurate distance estimation #DIST_L2, a  mask or the precise algorithm is used.
	/// Note that both the precise and the approximate algorithms are linear on the number of pixels.
	/// 
	/// This variant of the function does not only compute the minimum distance for each pixel 
	/// but also identifies the nearest connected component consisting of zero pixels
	/// (labelType==#DIST_LABEL_CCOMP) or the nearest zero pixel (labelType==#DIST_LABEL_PIXEL). Index of the
	/// component/pixel is stored in `labels(x, y)`. When labelType==#DIST_LABEL_CCOMP, the function
	/// automatically finds connected components of zero pixels in the input image and marks them with
	/// distinct labels. When labelType==#DIST_LABEL_PIXEL, the function scans through the input image and
	/// marks all the zero pixels with distinct labels.
	/// 
	/// In this mode, the complexity is still linear. That is, the function provides a very fast way to
	/// compute the Voronoi diagram for a binary image. Currently, the second variant can use only the
	/// approximate distance transform algorithm, i.e. maskSize=[DIST_MASK_PRECISE] is not supported
	/// yet.
	/// 
	/// ## Parameters
	/// * src: 8-bit, single-channel (binary) source image.
	/// * dst: Output image with calculated distances. It is a 8-bit or 32-bit floating-point,
	/// single-channel image of the same size as src.
	/// * labels: Output 2D array of labels (the discrete Voronoi diagram). It has the type
	/// CV_32SC1 and the same size as src.
	/// * distanceType: Type of distance, see [distance_types]
	/// * maskSize: Size of the distance transform mask, see #DistanceTransformMasks.
	/// [DIST_MASK_PRECISE] is not supported by this variant. In case of the [DIST_L1] or [DIST_C] distance type,
	/// the parameter is forced to 3 because a  mask gives the same result as  or any larger aperture.
	/// * labelType: Type of the label array to build, see #DistanceTransformLabelTypes.
	/// 
	/// ## C++ default parameters
	/// * label_type: DIST_LABEL_CCOMP
	#[inline]
	pub fn distance_transform_with_labels(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, labels: &mut impl core::ToOutputArray, distance_type: i32, mask_size: i32, label_type: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		output_array_arg!(labels);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_distanceTransform_const__InputArrayR_const__OutputArrayR_const__OutputArrayR_int_int_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), labels.as_raw__OutputArray(), distance_type, mask_size, label_type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// @overload
	/// ## Parameters
	/// * src: 8-bit, single-channel (binary) source image.
	/// * dst: Output image with calculated distances. It is a 8-bit or 32-bit floating-point,
	/// single-channel image of the same size as src .
	/// * distanceType: Type of distance, see [distance_types]
	/// * maskSize: Size of the distance transform mask, see #DistanceTransformMasks. In case of the
	/// [DIST_L1] or [DIST_C] distance type, the parameter is forced to 3 because a  mask gives
	/// the same result as  or any larger aperture.
	/// * dstType: Type of output image. It can be CV_8U or CV_32F. Type CV_8U can be used only for
	/// the first variant of the function and distanceType == #DIST_L1.
	/// 
	/// ## Note
	/// This alternative version of [distance_transform] function uses the following default values for its arguments:
	/// * dst_type: CV_32F
	#[inline]
	pub fn distance_transform_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, distance_type: i32, mask_size: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_distanceTransform_const__InputArrayR_const__OutputArrayR_int_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), distance_type, mask_size, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates the distance to the closest zero pixel for each pixel of the source image.
	/// 
	/// The function cv::distanceTransform calculates the approximate or precise distance from every binary
	/// image pixel to the nearest zero pixel. For zero image pixels, the distance will obviously be zero.
	/// 
	/// When maskSize == [DIST_MASK_PRECISE] and distanceType == [DIST_L2] , the function runs the
	/// algorithm described in [Felzenszwalb04](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Felzenszwalb04) . This algorithm is parallelized with the TBB library.
	/// 
	/// In other cases, the algorithm [Borgefors86](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Borgefors86) is used. This means that for a pixel the function
	/// finds the shortest path to the nearest zero pixel consisting of basic shifts: horizontal, vertical,
	/// diagonal, or knight's move (the latest is available for a  mask). The overall
	/// distance is calculated as a sum of these basic distances. Since the distance function should be
	/// symmetric, all of the horizontal and vertical shifts must have the same cost (denoted as a ), all
	/// the diagonal shifts must have the same cost (denoted as `b`), and all knight's moves must have the
	/// same cost (denoted as `c`). For the [DIST_C] and [DIST_L1] types, the distance is calculated
	/// precisely, whereas for [DIST_L2] (Euclidean distance) the distance can be calculated only with a
	/// relative error (a  mask gives more accurate results). For `a`,`b`, and `c`, OpenCV
	/// uses the values suggested in the original paper:
	/// - DIST_L1: `a = 1, b = 2`
	/// - DIST_L2:
	///    - `3 x 3`: `a=0.955, b=1.3693`
	///    - `5 x 5`: `a=1, b=1.4, c=2.1969`
	/// - DIST_C: `a = 1, b = 1`
	/// 
	/// Typically, for a fast, coarse distance estimation #DIST_L2, a  mask is used. For a
	/// more accurate distance estimation #DIST_L2, a  mask or the precise algorithm is used.
	/// Note that both the precise and the approximate algorithms are linear on the number of pixels.
	/// 
	/// This variant of the function does not only compute the minimum distance for each pixel 
	/// but also identifies the nearest connected component consisting of zero pixels
	/// (labelType==#DIST_LABEL_CCOMP) or the nearest zero pixel (labelType==#DIST_LABEL_PIXEL). Index of the
	/// component/pixel is stored in `labels(x, y)`. When labelType==#DIST_LABEL_CCOMP, the function
	/// automatically finds connected components of zero pixels in the input image and marks them with
	/// distinct labels. When labelType==#DIST_LABEL_PIXEL, the function scans through the input image and
	/// marks all the zero pixels with distinct labels.
	/// 
	/// In this mode, the complexity is still linear. That is, the function provides a very fast way to
	/// compute the Voronoi diagram for a binary image. Currently, the second variant can use only the
	/// approximate distance transform algorithm, i.e. maskSize=[DIST_MASK_PRECISE] is not supported
	/// yet.
	/// 
	/// ## Parameters
	/// * src: 8-bit, single-channel (binary) source image.
	/// * dst: Output image with calculated distances. It is a 8-bit or 32-bit floating-point,
	/// single-channel image of the same size as src.
	/// * labels: Output 2D array of labels (the discrete Voronoi diagram). It has the type
	/// CV_32SC1 and the same size as src.
	/// * distanceType: Type of distance, see [distance_types]
	/// * maskSize: Size of the distance transform mask, see #DistanceTransformMasks.
	/// [DIST_MASK_PRECISE] is not supported by this variant. In case of the [DIST_L1] or [DIST_C] distance type,
	/// the parameter is forced to 3 because a  mask gives the same result as  or any larger aperture.
	/// * labelType: Type of the label array to build, see #DistanceTransformLabelTypes.
	/// 
	/// ## Overloaded parameters
	/// 
	/// * src: 8-bit, single-channel (binary) source image.
	/// * dst: Output image with calculated distances. It is a 8-bit or 32-bit floating-point,
	/// single-channel image of the same size as src .
	/// * distanceType: Type of distance, see [distance_types]
	/// * maskSize: Size of the distance transform mask, see #DistanceTransformMasks. In case of the
	/// [DIST_L1] or [DIST_C] distance type, the parameter is forced to 3 because a  mask gives
	/// the same result as  or any larger aperture.
	/// * dstType: Type of output image. It can be CV_8U or CV_32F. Type CV_8U can be used only for
	/// the first variant of the function and distanceType == #DIST_L1.
	/// 
	/// ## C++ default parameters
	/// * dst_type: CV_32F
	#[inline]
	pub fn distance_transform(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, distance_type: i32, mask_size: i32, dst_type: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_distanceTransform_const__InputArrayR_const__OutputArrayR_int_int_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), distance_type, mask_size, dst_type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Performs the per-element division of the first Fourier spectrum by the second Fourier spectrum.
	/// 
	/// The function cv::divSpectrums performs the per-element division of the first array by the second array.
	/// The arrays are CCS-packed or complex matrices that are results of a real or complex Fourier transform.
	/// 
	/// ## Parameters
	/// * a: first input array.
	/// * b: second input array of the same size and type as src1 .
	/// * c: output array of the same size and type as src1 .
	/// * flags: operation flags; currently, the only supported flag is cv::DFT_ROWS, which indicates that
	/// each row of src1 and src2 is an independent 1D Fourier spectrum. If you do not want to use this flag, then simply add a `0` as value.
	/// * conjB: optional flag that conjugates the second input array before the multiplication (true)
	/// or not (false).
	/// 
	/// ## Note
	/// This alternative version of [div_spectrums] function uses the following default values for its arguments:
	/// * conj_b: false
	#[inline]
	pub fn div_spectrums_def(a: &impl core::ToInputArray, b: &impl core::ToInputArray, c: &mut impl core::ToOutputArray, flags: i32) -> Result<()> {
		input_array_arg!(a);
		input_array_arg!(b);
		output_array_arg!(c);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_divSpectrums_const__InputArrayR_const__InputArrayR_const__OutputArrayR_int(a.as_raw__InputArray(), b.as_raw__InputArray(), c.as_raw__OutputArray(), flags, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Performs the per-element division of the first Fourier spectrum by the second Fourier spectrum.
	/// 
	/// The function cv::divSpectrums performs the per-element division of the first array by the second array.
	/// The arrays are CCS-packed or complex matrices that are results of a real or complex Fourier transform.
	/// 
	/// ## Parameters
	/// * a: first input array.
	/// * b: second input array of the same size and type as src1 .
	/// * c: output array of the same size and type as src1 .
	/// * flags: operation flags; currently, the only supported flag is cv::DFT_ROWS, which indicates that
	/// each row of src1 and src2 is an independent 1D Fourier spectrum. If you do not want to use this flag, then simply add a `0` as value.
	/// * conjB: optional flag that conjugates the second input array before the multiplication (true)
	/// or not (false).
	/// 
	/// ## C++ default parameters
	/// * conj_b: false
	#[inline]
	pub fn div_spectrums(a: &impl core::ToInputArray, b: &impl core::ToInputArray, c: &mut impl core::ToOutputArray, flags: i32, conj_b: bool) -> Result<()> {
		input_array_arg!(a);
		input_array_arg!(b);
		output_array_arg!(c);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_divSpectrums_const__InputArrayR_const__InputArrayR_const__OutputArrayR_int_bool(a.as_raw__InputArray(), b.as_raw__InputArray(), c.as_raw__OutputArray(), flags, conj_b, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Draws contours outlines or filled contours.
	/// 
	/// The function draws contour outlines in the image if  or fills the area
	/// bounded by the contours if  . The example below shows how to retrieve
	/// connected components from the binary image and label them: :
	/// @include snippets/imgproc_drawContours.cpp
	/// 
	/// ## Parameters
	/// * image: Destination image.
	/// * contours: All the input contours. Each contour is stored as a point vector.
	/// * contourIdx: Parameter indicating a contour to draw. If it is negative, all the contours are drawn.
	/// * color: Color of the contours.
	/// * thickness: Thickness of lines the contours are drawn with. If it is negative (for example,
	/// thickness=[FILLED] ), the contour interiors are drawn.
	/// * lineType: Line connectivity. See [line_types]
	/// * hierarchy: Optional information about hierarchy. It is only needed if you want to draw only
	/// some of the contours (see maxLevel ).
	/// * maxLevel: Maximal level for drawn contours. If it is 0, only the specified contour is drawn.
	/// If it is 1, the function draws the contour(s) and all the nested contours. If it is 2, the function
	/// draws the contours, all the nested contours, all the nested-to-nested contours, and so on. This
	/// parameter is only taken into account when there is hierarchy available.
	/// * offset: Optional contour shift parameter. Shift all the drawn contours by the specified
	///  .
	/// 
	/// Note: When thickness=#FILLED, the function is designed to handle connected components with holes correctly
	/// even when no hierarchy data is provided. This is done by analyzing all the outlines together
	/// using even-odd rule. This may give incorrect results if you have a joint collection of separately retrieved
	/// contours. In order to solve this problem, you need to call [draw_contours] separately for each sub-group
	/// of contours, or iterate over the collection using contourIdx parameter.
	/// 
	/// ## Note
	/// This alternative version of [draw_contours] function uses the following default values for its arguments:
	/// * thickness: 1
	/// * line_type: LINE_8
	/// * hierarchy: noArray()
	/// * max_level: INT_MAX
	/// * offset: Point()
	#[inline]
	pub fn draw_contours_def(image: &mut impl core::ToInputOutputArray, contours: &impl core::ToInputArray, contour_idx: i32, color: core::Scalar) -> Result<()> {
		input_output_array_arg!(image);
		input_array_arg!(contours);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_drawContours_const__InputOutputArrayR_const__InputArrayR_int_const_ScalarR(image.as_raw__InputOutputArray(), contours.as_raw__InputArray(), contour_idx, &color, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Draws contours outlines or filled contours.
	/// 
	/// The function draws contour outlines in the image if  or fills the area
	/// bounded by the contours if  . The example below shows how to retrieve
	/// connected components from the binary image and label them: :
	/// @include snippets/imgproc_drawContours.cpp
	/// 
	/// ## Parameters
	/// * image: Destination image.
	/// * contours: All the input contours. Each contour is stored as a point vector.
	/// * contourIdx: Parameter indicating a contour to draw. If it is negative, all the contours are drawn.
	/// * color: Color of the contours.
	/// * thickness: Thickness of lines the contours are drawn with. If it is negative (for example,
	/// thickness=[FILLED] ), the contour interiors are drawn.
	/// * lineType: Line connectivity. See [line_types]
	/// * hierarchy: Optional information about hierarchy. It is only needed if you want to draw only
	/// some of the contours (see maxLevel ).
	/// * maxLevel: Maximal level for drawn contours. If it is 0, only the specified contour is drawn.
	/// If it is 1, the function draws the contour(s) and all the nested contours. If it is 2, the function
	/// draws the contours, all the nested contours, all the nested-to-nested contours, and so on. This
	/// parameter is only taken into account when there is hierarchy available.
	/// * offset: Optional contour shift parameter. Shift all the drawn contours by the specified
	///  .
	/// 
	/// Note: When thickness=#FILLED, the function is designed to handle connected components with holes correctly
	/// even when no hierarchy data is provided. This is done by analyzing all the outlines together
	/// using even-odd rule. This may give incorrect results if you have a joint collection of separately retrieved
	/// contours. In order to solve this problem, you need to call [draw_contours] separately for each sub-group
	/// of contours, or iterate over the collection using contourIdx parameter.
	/// 
	/// ## C++ default parameters
	/// * thickness: 1
	/// * line_type: LINE_8
	/// * hierarchy: noArray()
	/// * max_level: INT_MAX
	/// * offset: Point()
	#[inline]
	pub fn draw_contours(image: &mut impl core::ToInputOutputArray, contours: &impl core::ToInputArray, contour_idx: i32, color: core::Scalar, thickness: i32, line_type: i32, hierarchy: &impl core::ToInputArray, max_level: i32, offset: core::Point) -> Result<()> {
		input_output_array_arg!(image);
		input_array_arg!(contours);
		input_array_arg!(hierarchy);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_drawContours_const__InputOutputArrayR_const__InputArrayR_int_const_ScalarR_int_int_const__InputArrayR_int_Point(image.as_raw__InputOutputArray(), contours.as_raw__InputArray(), contour_idx, &color, thickness, line_type, hierarchy.as_raw__InputArray(), max_level, offset.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Draws a marker on a predefined position in an image.
	/// 
	/// The function cv::drawMarker draws a marker on a given position in the image. For the moment several
	/// marker types are supported, see [marker_types] for more information.
	/// 
	/// ## Parameters
	/// * img: Image.
	/// * position: The point where the crosshair is positioned.
	/// * color: Line color.
	/// * markerType: The specific type of marker you want to use, see [marker_types]
	/// * thickness: Line thickness.
	/// * line_type: Type of the line, See [line_types]
	/// * markerSize: The length of the marker axis [default = 20 pixels]
	/// 
	/// ## Note
	/// This alternative version of [draw_marker] function uses the following default values for its arguments:
	/// * marker_type: MARKER_CROSS
	/// * marker_size: 20
	/// * thickness: 1
	/// * line_type: 8
	#[inline]
	pub fn draw_marker_def(img: &mut impl core::ToInputOutputArray, position: core::Point, color: core::Scalar) -> Result<()> {
		input_output_array_arg!(img);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_drawMarker_const__InputOutputArrayR_Point_const_ScalarR(img.as_raw__InputOutputArray(), position.opencv_as_extern(), &color, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Draws a marker on a predefined position in an image.
	/// 
	/// The function cv::drawMarker draws a marker on a given position in the image. For the moment several
	/// marker types are supported, see [marker_types] for more information.
	/// 
	/// ## Parameters
	/// * img: Image.
	/// * position: The point where the crosshair is positioned.
	/// * color: Line color.
	/// * markerType: The specific type of marker you want to use, see [marker_types]
	/// * thickness: Line thickness.
	/// * line_type: Type of the line, See [line_types]
	/// * markerSize: The length of the marker axis [default = 20 pixels]
	/// 
	/// ## C++ default parameters
	/// * marker_type: MARKER_CROSS
	/// * marker_size: 20
	/// * thickness: 1
	/// * line_type: 8
	#[inline]
	pub fn draw_marker(img: &mut impl core::ToInputOutputArray, position: core::Point, color: core::Scalar, marker_type: i32, marker_size: i32, thickness: i32, line_type: i32) -> Result<()> {
		input_output_array_arg!(img);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_drawMarker_const__InputOutputArrayR_Point_const_ScalarR_int_int_int_int(img.as_raw__InputOutputArray(), position.opencv_as_extern(), &color, marker_type, marker_size, thickness, line_type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Approximates an elliptic arc with a polyline.
	/// 
	/// The function ellipse2Poly computes the vertices of a polyline that approximates the specified
	/// elliptic arc. It is used by #ellipse. If `arcStart` is greater than `arcEnd`, they are swapped.
	/// 
	/// ## Parameters
	/// * center: Center of the arc.
	/// * axes: Half of the size of the ellipse main axes. See [ellipse] for details.
	/// * angle: Rotation angle of the ellipse in degrees. See [ellipse] for details.
	/// * arcStart: Starting angle of the elliptic arc in degrees.
	/// * arcEnd: Ending angle of the elliptic arc in degrees.
	/// * delta: Angle between the subsequent polyline vertices. It defines the approximation
	/// accuracy.
	/// * pts: Output vector of polyline vertices.
	/// 
	/// ## Overloaded parameters
	/// 
	/// * center: Center of the arc.
	/// * axes: Half of the size of the ellipse main axes. See [ellipse] for details.
	/// * angle: Rotation angle of the ellipse in degrees. See [ellipse] for details.
	/// * arcStart: Starting angle of the elliptic arc in degrees.
	/// * arcEnd: Ending angle of the elliptic arc in degrees.
	/// * delta: Angle between the subsequent polyline vertices. It defines the approximation accuracy.
	/// * pts: Output vector of polyline vertices.
	#[inline]
	pub fn ellipse_2_poly_f64(center: core::Point2d, axes: core::Size2d, angle: i32, arc_start: i32, arc_end: i32, delta: i32, pts: &mut core::Vector<core::Point2d>) -> Result<()> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_ellipse2Poly_Point2d_Size2d_int_int_int_int_vectorLPoint2dGR(center.opencv_as_extern(), axes.opencv_as_extern(), angle, arc_start, arc_end, delta, pts.as_raw_mut_VectorOfPoint2d(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Approximates an elliptic arc with a polyline.
	/// 
	/// The function ellipse2Poly computes the vertices of a polyline that approximates the specified
	/// elliptic arc. It is used by #ellipse. If `arcStart` is greater than `arcEnd`, they are swapped.
	/// 
	/// ## Parameters
	/// * center: Center of the arc.
	/// * axes: Half of the size of the ellipse main axes. See [ellipse] for details.
	/// * angle: Rotation angle of the ellipse in degrees. See [ellipse] for details.
	/// * arcStart: Starting angle of the elliptic arc in degrees.
	/// * arcEnd: Ending angle of the elliptic arc in degrees.
	/// * delta: Angle between the subsequent polyline vertices. It defines the approximation
	/// accuracy.
	/// * pts: Output vector of polyline vertices.
	#[inline]
	pub fn ellipse_2_poly(center: core::Point, axes: core::Size, angle: i32, arc_start: i32, arc_end: i32, delta: i32, pts: &mut core::Vector<core::Point>) -> Result<()> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_ellipse2Poly_Point_Size_int_int_int_int_vectorLPointGR(center.opencv_as_extern(), axes.opencv_as_extern(), angle, arc_start, arc_end, delta, pts.as_raw_mut_VectorOfPoint(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Draws a simple or thick elliptic arc or fills an ellipse sector.
	/// 
	/// The function cv::ellipse with more parameters draws an ellipse outline, a filled ellipse, an elliptic
	/// arc, or a filled ellipse sector. The drawing code uses general parametric form.
	/// A piecewise-linear curve is used to approximate the elliptic arc
	/// boundary. If you need more control of the ellipse rendering, you can retrieve the curve using
	/// [ellipse2_poly] and then render it with [polylines] or fill it with #fillPoly. If you use the first
	/// variant of the function and want to draw the whole ellipse, not an arc, pass `startAngle=0` and
	/// `endAngle=360`. If `startAngle` is greater than `endAngle`, they are swapped. The figure below explains
	/// the meaning of the parameters to draw the blue arc.
	/// 
	/// 
	/// 
	/// ## Parameters
	/// * img: Image.
	/// * center: Center of the ellipse.
	/// * axes: Half of the size of the ellipse main axes.
	/// * angle: Ellipse rotation angle in degrees.
	/// * startAngle: Starting angle of the elliptic arc in degrees.
	/// * endAngle: Ending angle of the elliptic arc in degrees.
	/// * color: Ellipse color.
	/// * thickness: Thickness of the ellipse arc outline, if positive. Otherwise, this indicates that
	/// a filled ellipse sector is to be drawn.
	/// * lineType: Type of the ellipse boundary. See [line_types]
	/// * shift: Number of fractional bits in the coordinates of the center and values of axes.
	/// 
	/// ## Note
	/// This alternative version of [ellipse] function uses the following default values for its arguments:
	/// * thickness: 1
	/// * line_type: LINE_8
	/// * shift: 0
	#[inline]
	pub fn ellipse_def(img: &mut impl core::ToInputOutputArray, center: core::Point, axes: core::Size, angle: f64, start_angle: f64, end_angle: f64, color: core::Scalar) -> Result<()> {
		input_output_array_arg!(img);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_ellipse_const__InputOutputArrayR_Point_Size_double_double_double_const_ScalarR(img.as_raw__InputOutputArray(), center.opencv_as_extern(), axes.opencv_as_extern(), angle, start_angle, end_angle, &color, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Draws a simple or thick elliptic arc or fills an ellipse sector.
	/// 
	/// The function cv::ellipse with more parameters draws an ellipse outline, a filled ellipse, an elliptic
	/// arc, or a filled ellipse sector. The drawing code uses general parametric form.
	/// A piecewise-linear curve is used to approximate the elliptic arc
	/// boundary. If you need more control of the ellipse rendering, you can retrieve the curve using
	/// [ellipse2_poly] and then render it with [polylines] or fill it with #fillPoly. If you use the first
	/// variant of the function and want to draw the whole ellipse, not an arc, pass `startAngle=0` and
	/// `endAngle=360`. If `startAngle` is greater than `endAngle`, they are swapped. The figure below explains
	/// the meaning of the parameters to draw the blue arc.
	/// 
	/// 
	/// 
	/// ## Parameters
	/// * img: Image.
	/// * center: Center of the ellipse.
	/// * axes: Half of the size of the ellipse main axes.
	/// * angle: Ellipse rotation angle in degrees.
	/// * startAngle: Starting angle of the elliptic arc in degrees.
	/// * endAngle: Ending angle of the elliptic arc in degrees.
	/// * color: Ellipse color.
	/// * thickness: Thickness of the ellipse arc outline, if positive. Otherwise, this indicates that
	/// a filled ellipse sector is to be drawn.
	/// * lineType: Type of the ellipse boundary. See [line_types]
	/// * shift: Number of fractional bits in the coordinates of the center and values of axes.
	/// 
	/// ## C++ default parameters
	/// * thickness: 1
	/// * line_type: LINE_8
	/// * shift: 0
	#[inline]
	pub fn ellipse(img: &mut impl core::ToInputOutputArray, center: core::Point, axes: core::Size, angle: f64, start_angle: f64, end_angle: f64, color: core::Scalar, thickness: i32, line_type: i32, shift: i32) -> Result<()> {
		input_output_array_arg!(img);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_ellipse_const__InputOutputArrayR_Point_Size_double_double_double_const_ScalarR_int_int_int(img.as_raw__InputOutputArray(), center.opencv_as_extern(), axes.opencv_as_extern(), angle, start_angle, end_angle, &color, thickness, line_type, shift, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// @overload
	/// ## Parameters
	/// * img: Image.
	/// * box: Alternative ellipse representation via RotatedRect. This means that the function draws
	/// an ellipse inscribed in the rotated rectangle.
	/// * color: Ellipse color.
	/// * thickness: Thickness of the ellipse arc outline, if positive. Otherwise, this indicates that
	/// a filled ellipse sector is to be drawn.
	/// * lineType: Type of the ellipse boundary. See [line_types]
	/// 
	/// ## Note
	/// This alternative version of [ellipse_rotated_rect] function uses the following default values for its arguments:
	/// * thickness: 1
	/// * line_type: LINE_8
	#[inline]
	pub fn ellipse_rotated_rect_def(img: &mut impl core::ToInputOutputArray, box_: core::RotatedRect, color: core::Scalar) -> Result<()> {
		input_output_array_arg!(img);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_ellipse_const__InputOutputArrayR_const_RotatedRectR_const_ScalarR(img.as_raw__InputOutputArray(), &box_, &color, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Draws a simple or thick elliptic arc or fills an ellipse sector.
	/// 
	/// The function cv::ellipse with more parameters draws an ellipse outline, a filled ellipse, an elliptic
	/// arc, or a filled ellipse sector. The drawing code uses general parametric form.
	/// A piecewise-linear curve is used to approximate the elliptic arc
	/// boundary. If you need more control of the ellipse rendering, you can retrieve the curve using
	/// [ellipse2_poly] and then render it with [polylines] or fill it with #fillPoly. If you use the first
	/// variant of the function and want to draw the whole ellipse, not an arc, pass `startAngle=0` and
	/// `endAngle=360`. If `startAngle` is greater than `endAngle`, they are swapped. The figure below explains
	/// the meaning of the parameters to draw the blue arc.
	/// 
	/// 
	/// 
	/// ## Parameters
	/// * img: Image.
	/// * center: Center of the ellipse.
	/// * axes: Half of the size of the ellipse main axes.
	/// * angle: Ellipse rotation angle in degrees.
	/// * startAngle: Starting angle of the elliptic arc in degrees.
	/// * endAngle: Ending angle of the elliptic arc in degrees.
	/// * color: Ellipse color.
	/// * thickness: Thickness of the ellipse arc outline, if positive. Otherwise, this indicates that
	/// a filled ellipse sector is to be drawn.
	/// * lineType: Type of the ellipse boundary. See [line_types]
	/// * shift: Number of fractional bits in the coordinates of the center and values of axes.
	/// 
	/// ## Overloaded parameters
	/// 
	/// * img: Image.
	/// * box: Alternative ellipse representation via RotatedRect. This means that the function draws
	/// an ellipse inscribed in the rotated rectangle.
	/// * color: Ellipse color.
	/// * thickness: Thickness of the ellipse arc outline, if positive. Otherwise, this indicates that
	/// a filled ellipse sector is to be drawn.
	/// * lineType: Type of the ellipse boundary. See #LineTypes
	/// 
	/// ## C++ default parameters
	/// * thickness: 1
	/// * line_type: LINE_8
	#[inline]
	pub fn ellipse_rotated_rect(img: &mut impl core::ToInputOutputArray, box_: core::RotatedRect, color: core::Scalar, thickness: i32, line_type: i32) -> Result<()> {
		input_output_array_arg!(img);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_ellipse_const__InputOutputArrayR_const_RotatedRectR_const_ScalarR_int_int(img.as_raw__InputOutputArray(), &box_, &color, thickness, line_type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Equalizes the histogram of a grayscale image.
	/// 
	/// The function equalizes the histogram of the input image using the following algorithm:
	/// 
	/// - Calculate the histogram  for src .
	/// - Normalize the histogram so that the sum of histogram bins is 255.
	/// - Compute the integral of the histogram:
	/// 
	/// - Transform the image using  as a look-up table: 
	/// 
	/// The algorithm normalizes the brightness and increases the contrast of the image.
	/// 
	/// ## Parameters
	/// * src: Source 8-bit single channel image.
	/// * dst: Destination image of the same size and type as src .
	#[inline]
	pub fn equalize_hist(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_equalizeHist_const__InputArrayR_const__OutputArrayR(src.as_raw__InputArray(), dst.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Erodes an image by using a specific structuring element.
	/// 
	/// The function erodes the source image using the specified structuring element that determines the
	/// shape of a pixel neighborhood over which the minimum is taken:
	/// 
	/// 
	/// 
	/// The function supports the in-place mode. Erosion can be applied several ( iterations ) times. In
	/// case of multi-channel images, each channel is processed independently.
	/// 
	/// ## Parameters
	/// * src: input image; the number of channels can be arbitrary, but the depth should be one of
	/// CV_8U, CV_16U, CV_16S, CV_32F or CV_64F.
	/// * dst: output image of the same size and type as src.
	/// * kernel: structuring element used for erosion; if `element=Mat()`, a `3 x 3` rectangular
	/// structuring element is used. Kernel can be created using #getStructuringElement.
	/// * anchor: position of the anchor within the element; default value (-1, -1) means that the
	/// anchor is at the element center.
	/// * iterations: number of times erosion is applied.
	/// * borderType: pixel extrapolation method, see #BorderTypes. [BORDER_WRAP] is not supported.
	/// * borderValue: border value in case of a constant border
	/// ## See also
	/// dilate, morphologyEx, getStructuringElement
	/// 
	/// ## Note
	/// This alternative version of [erode] function uses the following default values for its arguments:
	/// * anchor: Point(-1,-1)
	/// * iterations: 1
	/// * border_type: BORDER_CONSTANT
	/// * border_value: morphologyDefaultBorderValue()
	#[inline]
	pub fn erode_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, kernel: &impl core::ToInputArray) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		input_array_arg!(kernel);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_erode_const__InputArrayR_const__OutputArrayR_const__InputArrayR(src.as_raw__InputArray(), dst.as_raw__OutputArray(), kernel.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Erodes an image by using a specific structuring element.
	/// 
	/// The function erodes the source image using the specified structuring element that determines the
	/// shape of a pixel neighborhood over which the minimum is taken:
	/// 
	/// 
	/// 
	/// The function supports the in-place mode. Erosion can be applied several ( iterations ) times. In
	/// case of multi-channel images, each channel is processed independently.
	/// 
	/// ## Parameters
	/// * src: input image; the number of channels can be arbitrary, but the depth should be one of
	/// CV_8U, CV_16U, CV_16S, CV_32F or CV_64F.
	/// * dst: output image of the same size and type as src.
	/// * kernel: structuring element used for erosion; if `element=Mat()`, a `3 x 3` rectangular
	/// structuring element is used. Kernel can be created using #getStructuringElement.
	/// * anchor: position of the anchor within the element; default value (-1, -1) means that the
	/// anchor is at the element center.
	/// * iterations: number of times erosion is applied.
	/// * borderType: pixel extrapolation method, see #BorderTypes. [BORDER_WRAP] is not supported.
	/// * borderValue: border value in case of a constant border
	/// ## See also
	/// dilate, morphologyEx, getStructuringElement
	/// 
	/// ## C++ default parameters
	/// * anchor: Point(-1,-1)
	/// * iterations: 1
	/// * border_type: BORDER_CONSTANT
	/// * border_value: morphologyDefaultBorderValue()
	#[inline]
	pub fn erode(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, kernel: &impl core::ToInputArray, anchor: core::Point, iterations: i32, border_type: i32, border_value: core::Scalar) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		input_array_arg!(kernel);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_erode_const__InputArrayR_const__OutputArrayR_const__InputArrayR_Point_int_int_const_ScalarR(src.as_raw__InputArray(), dst.as_raw__OutputArray(), kernel.as_raw__InputArray(), anchor.opencv_as_extern(), iterations, border_type, &border_value, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Fills a convex polygon.
	/// 
	/// The function cv::fillConvexPoly draws a filled convex polygon. This function is much faster than the
	/// function [fill_poly] . It can fill not only convex polygons but any monotonic polygon without
	/// self-intersections, that is, a polygon whose contour intersects every horizontal line (scan line)
	/// twice at the most (though, its top-most and/or the bottom edge could be horizontal).
	/// 
	/// ## Parameters
	/// * img: Image.
	/// * points: Polygon vertices.
	/// * color: Polygon color.
	/// * lineType: Type of the polygon boundaries. See [line_types]
	/// * shift: Number of fractional bits in the vertex coordinates.
	/// 
	/// ## Note
	/// This alternative version of [fill_convex_poly] function uses the following default values for its arguments:
	/// * line_type: LINE_8
	/// * shift: 0
	#[inline]
	pub fn fill_convex_poly_def(img: &mut impl core::ToInputOutputArray, points: &impl core::ToInputArray, color: core::Scalar) -> Result<()> {
		input_output_array_arg!(img);
		input_array_arg!(points);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_fillConvexPoly_const__InputOutputArrayR_const__InputArrayR_const_ScalarR(img.as_raw__InputOutputArray(), points.as_raw__InputArray(), &color, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Fills a convex polygon.
	/// 
	/// The function cv::fillConvexPoly draws a filled convex polygon. This function is much faster than the
	/// function [fill_poly] . It can fill not only convex polygons but any monotonic polygon without
	/// self-intersections, that is, a polygon whose contour intersects every horizontal line (scan line)
	/// twice at the most (though, its top-most and/or the bottom edge could be horizontal).
	/// 
	/// ## Parameters
	/// * img: Image.
	/// * points: Polygon vertices.
	/// * color: Polygon color.
	/// * lineType: Type of the polygon boundaries. See [line_types]
	/// * shift: Number of fractional bits in the vertex coordinates.
	/// 
	/// ## C++ default parameters
	/// * line_type: LINE_8
	/// * shift: 0
	#[inline]
	pub fn fill_convex_poly(img: &mut impl core::ToInputOutputArray, points: &impl core::ToInputArray, color: core::Scalar, line_type: i32, shift: i32) -> Result<()> {
		input_output_array_arg!(img);
		input_array_arg!(points);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_fillConvexPoly_const__InputOutputArrayR_const__InputArrayR_const_ScalarR_int_int(img.as_raw__InputOutputArray(), points.as_raw__InputArray(), &color, line_type, shift, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Fills the area bounded by one or more polygons.
	/// 
	/// The function cv::fillPoly fills an area bounded by several polygonal contours. The function can fill
	/// complex areas, for example, areas with holes, contours with self-intersections (some of their
	/// parts), and so forth.
	/// 
	/// ## Parameters
	/// * img: Image.
	/// * pts: Array of polygons where each polygon is represented as an array of points.
	/// * color: Polygon color.
	/// * lineType: Type of the polygon boundaries. See [line_types]
	/// * shift: Number of fractional bits in the vertex coordinates.
	/// * offset: Optional offset of all points of the contours.
	/// 
	/// ## Note
	/// This alternative version of [fill_poly] function uses the following default values for its arguments:
	/// * line_type: LINE_8
	/// * shift: 0
	/// * offset: Point()
	#[inline]
	pub fn fill_poly_def(img: &mut impl core::ToInputOutputArray, pts: &impl core::ToInputArray, color: core::Scalar) -> Result<()> {
		input_output_array_arg!(img);
		input_array_arg!(pts);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_fillPoly_const__InputOutputArrayR_const__InputArrayR_const_ScalarR(img.as_raw__InputOutputArray(), pts.as_raw__InputArray(), &color, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Fills the area bounded by one or more polygons.
	/// 
	/// The function cv::fillPoly fills an area bounded by several polygonal contours. The function can fill
	/// complex areas, for example, areas with holes, contours with self-intersections (some of their
	/// parts), and so forth.
	/// 
	/// ## Parameters
	/// * img: Image.
	/// * pts: Array of polygons where each polygon is represented as an array of points.
	/// * color: Polygon color.
	/// * lineType: Type of the polygon boundaries. See [line_types]
	/// * shift: Number of fractional bits in the vertex coordinates.
	/// * offset: Optional offset of all points of the contours.
	/// 
	/// ## C++ default parameters
	/// * line_type: LINE_8
	/// * shift: 0
	/// * offset: Point()
	#[inline]
	pub fn fill_poly(img: &mut impl core::ToInputOutputArray, pts: &impl core::ToInputArray, color: core::Scalar, line_type: i32, shift: i32, offset: core::Point) -> Result<()> {
		input_output_array_arg!(img);
		input_array_arg!(pts);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_fillPoly_const__InputOutputArrayR_const__InputArrayR_const_ScalarR_int_int_Point(img.as_raw__InputOutputArray(), pts.as_raw__InputArray(), &color, line_type, shift, offset.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Convolves an image with the kernel.
	/// 
	/// The function applies an arbitrary linear filter to an image. In-place operation is supported. When
	/// the aperture is partially outside the image, the function interpolates outlier pixel values
	/// according to the specified border mode.
	/// 
	/// The function does actually compute correlation, not the convolution:
	/// 
	/// 
	/// 
	/// That is, the kernel is not mirrored around the anchor point. If you need a real convolution, flip
	/// the kernel using [flip] and set the new anchor to `(kernel.cols - anchor.x - 1, kernel.rows -
	/// anchor.y - 1)`.
	/// 
	/// The function uses the DFT-based algorithm in case of sufficiently large kernels (~`11 x 11` or
	/// larger) and the direct algorithm for small kernels.
	/// 
	/// ## Parameters
	/// * src: input image.
	/// * dst: output image of the same size and the same number of channels as src.
	/// * ddepth: desired depth of the destination image, see [filter_depths] "combinations"
	/// * kernel: convolution kernel (or rather a correlation kernel), a single-channel floating point
	/// matrix; if you want to apply different kernels to different channels, split the image into
	/// separate color planes using split and process them individually.
	/// * anchor: anchor of the kernel that indicates the relative position of a filtered point within
	/// the kernel; the anchor should lie within the kernel; default value (-1,-1) means that the anchor
	/// is at the kernel center.
	/// * delta: optional value added to the filtered pixels before storing them in dst.
	/// * borderType: pixel extrapolation method, see #BorderTypes. [BORDER_WRAP] is not supported.
	/// ## See also
	/// sepFilter2D, dft, matchTemplate
	/// 
	/// ## Note
	/// This alternative version of [filter_2d] function uses the following default values for its arguments:
	/// * anchor: Point(-1,-1)
	/// * delta: 0
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn filter_2d_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, ddepth: i32, kernel: &impl core::ToInputArray) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		input_array_arg!(kernel);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_filter2D_const__InputArrayR_const__OutputArrayR_int_const__InputArrayR(src.as_raw__InputArray(), dst.as_raw__OutputArray(), ddepth, kernel.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Convolves an image with the kernel.
	/// 
	/// The function applies an arbitrary linear filter to an image. In-place operation is supported. When
	/// the aperture is partially outside the image, the function interpolates outlier pixel values
	/// according to the specified border mode.
	/// 
	/// The function does actually compute correlation, not the convolution:
	/// 
	/// 
	/// 
	/// That is, the kernel is not mirrored around the anchor point. If you need a real convolution, flip
	/// the kernel using [flip] and set the new anchor to `(kernel.cols - anchor.x - 1, kernel.rows -
	/// anchor.y - 1)`.
	/// 
	/// The function uses the DFT-based algorithm in case of sufficiently large kernels (~`11 x 11` or
	/// larger) and the direct algorithm for small kernels.
	/// 
	/// ## Parameters
	/// * src: input image.
	/// * dst: output image of the same size and the same number of channels as src.
	/// * ddepth: desired depth of the destination image, see [filter_depths] "combinations"
	/// * kernel: convolution kernel (or rather a correlation kernel), a single-channel floating point
	/// matrix; if you want to apply different kernels to different channels, split the image into
	/// separate color planes using split and process them individually.
	/// * anchor: anchor of the kernel that indicates the relative position of a filtered point within
	/// the kernel; the anchor should lie within the kernel; default value (-1,-1) means that the anchor
	/// is at the kernel center.
	/// * delta: optional value added to the filtered pixels before storing them in dst.
	/// * borderType: pixel extrapolation method, see #BorderTypes. [BORDER_WRAP] is not supported.
	/// ## See also
	/// sepFilter2D, dft, matchTemplate
	/// 
	/// ## C++ default parameters
	/// * anchor: Point(-1,-1)
	/// * delta: 0
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn filter_2d(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, ddepth: i32, kernel: &impl core::ToInputArray, anchor: core::Point, delta: f64, border_type: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		input_array_arg!(kernel);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_filter2D_const__InputArrayR_const__OutputArrayR_int_const__InputArrayR_Point_double_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), ddepth, kernel.as_raw__InputArray(), anchor.opencv_as_extern(), delta, border_type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Finds contours in a binary image.
	/// 
	/// The function retrieves contours from the binary image using the algorithm [Suzuki85](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Suzuki85) . The contours
	/// are a useful tool for shape analysis and object detection and recognition. See squares.cpp in the
	/// OpenCV sample directory.
	/// 
	/// Note: Since opencv 3.2 source image is not modified by this function.
	/// 
	/// ## Parameters
	/// * image: Source, an 8-bit single-channel image. Non-zero pixels are treated as 1's. Zero
	/// pixels remain 0's, so the image is treated as binary . You can use #compare, #inRange, [threshold] ,
	/// #adaptiveThreshold, #Canny, and others to create a binary image out of a grayscale or color one.
	/// If mode equals to [RETR_CCOMP] or #RETR_FLOODFILL, the input can also be a 32-bit integer image of labels (CV_32SC1).
	/// * contours: Detected contours. Each contour is stored as a vector of points (e.g.
	/// std::vector<std::vector<cv::Point> >).
	/// * hierarchy: Optional output vector (e.g. std::vector<cv::Vec4i>), containing information about the image topology. It has
	/// as many elements as the number of contours. For each i-th contour contours[i], the elements
	/// hierarchy[i][0] , hierarchy[i][1] , hierarchy[i][2] , and hierarchy[i][3] are set to 0-based indices
	/// in contours of the next and previous contours at the same hierarchical level, the first child
	/// contour and the parent contour, respectively. If for the contour i there are no next, previous,
	/// parent, or nested contours, the corresponding elements of hierarchy[i] will be negative.
	/// 
	/// Note: In Python, hierarchy is nested inside a top level array. Use hierarchy[0][i] to access hierarchical elements of i-th contour.
	/// * mode: Contour retrieval mode, see [retrieval_modes]
	/// * method: Contour approximation method, see [contour_approximation_modes]
	/// * offset: Optional offset by which every contour point is shifted. This is useful if the
	/// contours are extracted from the image ROI and then they should be analyzed in the whole image
	/// context.
	/// 
	/// ## Note
	/// This alternative version of [find_contours_with_hierarchy] function uses the following default values for its arguments:
	/// * offset: Point()
	#[inline]
	pub fn find_contours_with_hierarchy_def(image: &impl core::ToInputArray, contours: &mut impl core::ToOutputArray, hierarchy: &mut impl core::ToOutputArray, mode: i32, method: i32) -> Result<()> {
		input_array_arg!(image);
		output_array_arg!(contours);
		output_array_arg!(hierarchy);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_findContours_const__InputArrayR_const__OutputArrayR_const__OutputArrayR_int_int(image.as_raw__InputArray(), contours.as_raw__OutputArray(), hierarchy.as_raw__OutputArray(), mode, method, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Finds contours in a binary image.
	/// 
	/// The function retrieves contours from the binary image using the algorithm [Suzuki85](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Suzuki85) . The contours
	/// are a useful tool for shape analysis and object detection and recognition. See squares.cpp in the
	/// OpenCV sample directory.
	/// 
	/// Note: Since opencv 3.2 source image is not modified by this function.
	/// 
	/// ## Parameters
	/// * image: Source, an 8-bit single-channel image. Non-zero pixels are treated as 1's. Zero
	/// pixels remain 0's, so the image is treated as binary . You can use #compare, #inRange, [threshold] ,
	/// #adaptiveThreshold, #Canny, and others to create a binary image out of a grayscale or color one.
	/// If mode equals to [RETR_CCOMP] or #RETR_FLOODFILL, the input can also be a 32-bit integer image of labels (CV_32SC1).
	/// * contours: Detected contours. Each contour is stored as a vector of points (e.g.
	/// std::vector<std::vector<cv::Point> >).
	/// * hierarchy: Optional output vector (e.g. std::vector<cv::Vec4i>), containing information about the image topology. It has
	/// as many elements as the number of contours. For each i-th contour contours[i], the elements
	/// hierarchy[i][0] , hierarchy[i][1] , hierarchy[i][2] , and hierarchy[i][3] are set to 0-based indices
	/// in contours of the next and previous contours at the same hierarchical level, the first child
	/// contour and the parent contour, respectively. If for the contour i there are no next, previous,
	/// parent, or nested contours, the corresponding elements of hierarchy[i] will be negative.
	/// 
	/// Note: In Python, hierarchy is nested inside a top level array. Use hierarchy[0][i] to access hierarchical elements of i-th contour.
	/// * mode: Contour retrieval mode, see [retrieval_modes]
	/// * method: Contour approximation method, see [contour_approximation_modes]
	/// * offset: Optional offset by which every contour point is shifted. This is useful if the
	/// contours are extracted from the image ROI and then they should be analyzed in the whole image
	/// context.
	/// 
	/// ## C++ default parameters
	/// * offset: Point()
	#[inline]
	pub fn find_contours_with_hierarchy(image: &impl core::ToInputArray, contours: &mut impl core::ToOutputArray, hierarchy: &mut impl core::ToOutputArray, mode: i32, method: i32, offset: core::Point) -> Result<()> {
		input_array_arg!(image);
		output_array_arg!(contours);
		output_array_arg!(hierarchy);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_findContours_const__InputArrayR_const__OutputArrayR_const__OutputArrayR_int_int_Point(image.as_raw__InputArray(), contours.as_raw__OutputArray(), hierarchy.as_raw__OutputArray(), mode, method, offset.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// @overload
	/// 
	/// ## Note
	/// This alternative version of [find_contours] function uses the following default values for its arguments:
	/// * offset: Point()
	#[inline]
	pub fn find_contours_def(image: &impl core::ToInputArray, contours: &mut impl core::ToOutputArray, mode: i32, method: i32) -> Result<()> {
		input_array_arg!(image);
		output_array_arg!(contours);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_findContours_const__InputArrayR_const__OutputArrayR_int_int(image.as_raw__InputArray(), contours.as_raw__OutputArray(), mode, method, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Finds contours in a binary image.
	/// 
	/// The function retrieves contours from the binary image using the algorithm [Suzuki85](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Suzuki85) . The contours
	/// are a useful tool for shape analysis and object detection and recognition. See squares.cpp in the
	/// OpenCV sample directory.
	/// 
	/// Note: Since opencv 3.2 source image is not modified by this function.
	/// 
	/// ## Parameters
	/// * image: Source, an 8-bit single-channel image. Non-zero pixels are treated as 1's. Zero
	/// pixels remain 0's, so the image is treated as binary . You can use #compare, #inRange, [threshold] ,
	/// #adaptiveThreshold, #Canny, and others to create a binary image out of a grayscale or color one.
	/// If mode equals to [RETR_CCOMP] or #RETR_FLOODFILL, the input can also be a 32-bit integer image of labels (CV_32SC1).
	/// * contours: Detected contours. Each contour is stored as a vector of points (e.g.
	/// std::vector<std::vector<cv::Point> >).
	/// * hierarchy: Optional output vector (e.g. std::vector<cv::Vec4i>), containing information about the image topology. It has
	/// as many elements as the number of contours. For each i-th contour contours[i], the elements
	/// hierarchy[i][0] , hierarchy[i][1] , hierarchy[i][2] , and hierarchy[i][3] are set to 0-based indices
	/// in contours of the next and previous contours at the same hierarchical level, the first child
	/// contour and the parent contour, respectively. If for the contour i there are no next, previous,
	/// parent, or nested contours, the corresponding elements of hierarchy[i] will be negative.
	/// 
	/// Note: In Python, hierarchy is nested inside a top level array. Use hierarchy[0][i] to access hierarchical elements of i-th contour.
	/// * mode: Contour retrieval mode, see [retrieval_modes]
	/// * method: Contour approximation method, see [contour_approximation_modes]
	/// * offset: Optional offset by which every contour point is shifted. This is useful if the
	/// contours are extracted from the image ROI and then they should be analyzed in the whole image
	/// context.
	/// 
	/// ## Overloaded parameters
	/// 
	/// ## C++ default parameters
	/// * offset: Point()
	#[inline]
	pub fn find_contours(image: &impl core::ToInputArray, contours: &mut impl core::ToOutputArray, mode: i32, method: i32, offset: core::Point) -> Result<()> {
		input_array_arg!(image);
		output_array_arg!(contours);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_findContours_const__InputArrayR_const__OutputArrayR_int_int_Point(image.as_raw__InputArray(), contours.as_raw__OutputArray(), mode, method, offset.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Fits an ellipse around a set of 2D points.
	/// 
	/// The function calculates the ellipse that fits a set of 2D points.
	/// It returns the rotated rectangle in which the ellipse is inscribed.
	/// The Approximate Mean Square (AMS) proposed by [Taubin1991](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Taubin1991) is used.
	/// 
	/// For an ellipse, this basis set is ,
	/// which is a set of six free coefficients .
	/// However, to specify an ellipse, all that is needed is five numbers; the major and minor axes lengths ,
	/// the position , and the orientation . This is because the basis set includes lines,
	/// quadratics, parabolic and hyperbolic functions as well as elliptical functions as possible fits.
	/// If the fit is found to be a parabolic or hyperbolic function then the standard [fit_ellipse] method is used.
	/// The AMS method restricts the fit to parabolic, hyperbolic and elliptical curves
	/// by imposing the condition that  where
	/// the matrices  and  are the partial derivatives of the design matrix  with
	/// respect to x and y. The matrices are formed row by row applying the following to
	/// each of the points in the set:
	/// \f{align*}{
	/// D(i,:)&=\left\{x_i^2, x_i y_i, y_i^2, x_i, y_i, 1\right\} &
	/// D_x(i,:)&=\left\{2 x_i,y_i,0,1,0,0\right\} &
	/// D_y(i,:)&=\left\{0,x_i,2 y_i,0,1,0\right\}
	/// \f}
	/// The AMS method minimizes the cost function
	/// \f{equation*}{
	/// \epsilon ^2=\frac{ A^T D^T D A }{ A^T (D_x^T D_x +  D_y^T D_y) A^T }
	/// \f}
	/// 
	/// The minimum cost is found by solving the generalized eigenvalue problem.
	/// 
	/// \f{equation*}{
	/// D^T D A = \lambda  \left( D_x^T D_x +  D_y^T D_y\right) A
	/// \f}
	/// 
	/// ## Parameters
	/// * points: Input 2D point set, stored in std::vector\<\> or Mat
	#[inline]
	pub fn fit_ellipse_ams(points: &impl core::ToInputArray) -> Result<core::RotatedRect> {
		input_array_arg!(points);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_fitEllipseAMS_const__InputArrayR(points.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Fits an ellipse around a set of 2D points.
	/// 
	/// The function calculates the ellipse that fits a set of 2D points.
	/// It returns the rotated rectangle in which the ellipse is inscribed.
	/// The Direct least square (Direct) method by [Fitzgibbon1999](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Fitzgibbon1999) is used.
	/// 
	/// For an ellipse, this basis set is ,
	/// which is a set of six free coefficients .
	/// However, to specify an ellipse, all that is needed is five numbers; the major and minor axes lengths ,
	/// the position , and the orientation . This is because the basis set includes lines,
	/// quadratics, parabolic and hyperbolic functions as well as elliptical functions as possible fits.
	/// The Direct method confines the fit to ellipses by ensuring that .
	/// The condition imposed is that  which satisfies the inequality
	/// and as the coefficients can be arbitrarily scaled is not overly restrictive.
	/// 
	/// \f{equation*}{
	/// \epsilon ^2= A^T D^T D A \quad \text{with} \quad A^T C A =1 \quad \text{and} \quad C=\left(\begin{matrix}
	/// 0 & 0  & 2  & 0  & 0  &  0  \\
	/// 0 & -1  & 0  & 0  & 0  &  0 \\
	/// 2 & 0  & 0  & 0  & 0  &  0 \\
	/// 0 & 0  & 0  & 0  & 0  &  0 \\
	/// 0 & 0  & 0  & 0  & 0  &  0 \\
	/// 0 & 0  & 0  & 0  & 0  &  0
	/// \end{matrix} \right)
	/// \f}
	/// 
	/// The minimum cost is found by solving the generalized eigenvalue problem.
	/// 
	/// \f{equation*}{
	/// D^T D A = \lambda  \left( C\right) A
	/// \f}
	/// 
	/// The system produces only one positive eigenvalue  which is chosen as the solution
	/// with its eigenvector . These are used to find the coefficients
	/// 
	/// \f{equation*}{
	/// A = \sqrt{\frac{1}{\mathbf{u}^T C \mathbf{u}}}  \mathbf{u}
	/// \f}
	/// The scaling factor guarantees that  .
	/// 
	/// ## Parameters
	/// * points: Input 2D point set, stored in std::vector\<\> or Mat
	#[inline]
	pub fn fit_ellipse_direct(points: &impl core::ToInputArray) -> Result<core::RotatedRect> {
		input_array_arg!(points);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_fitEllipseDirect_const__InputArrayR(points.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Fits an ellipse around a set of 2D points.
	/// 
	/// The function calculates the ellipse that fits (in a least-squares sense) a set of 2D points best of
	/// all. It returns the rotated rectangle in which the ellipse is inscribed. The first algorithm described by [Fitzgibbon95](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Fitzgibbon95)
	/// is used. Developer should keep in mind that it is possible that the returned
	/// ellipse/rotatedRect data contains negative indices, due to the data points being close to the
	/// border of the containing Mat element.
	/// 
	/// ## Parameters
	/// * points: Input 2D point set, stored in std::vector\<\> or Mat
	#[inline]
	pub fn fit_ellipse(points: &impl core::ToInputArray) -> Result<core::RotatedRect> {
		input_array_arg!(points);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_fitEllipse_const__InputArrayR(points.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Fits a line to a 2D or 3D point set.
	/// 
	/// The function fitLine fits a line to a 2D or 3D point set by minimizing  where
	///  is a distance between the  point, the line and  is a distance function, one
	/// of the following:
	/// *  DIST_L2
	/// 
	/// - DIST_L1
	/// 
	/// - DIST_L12
	/// 
	/// - DIST_FAIR
	/// 
	/// - DIST_WELSCH
	/// 
	/// - DIST_HUBER
	/// 
	/// 
	/// The algorithm is based on the M-estimator ( <http://en.wikipedia.org/wiki/M-estimator> ) technique
	/// that iteratively fits the line using the weighted least-squares algorithm. After each iteration the
	/// weights  are adjusted to be inversely proportional to  .
	/// 
	/// ## Parameters
	/// * points: Input vector of 2D or 3D points, stored in std::vector\<\> or Mat.
	/// * line: Output line parameters. In case of 2D fitting, it should be a vector of 4 elements
	/// (like Vec4f) - (vx, vy, x0, y0), where (vx, vy) is a normalized vector collinear to the line and
	/// (x0, y0) is a point on the line. In case of 3D fitting, it should be a vector of 6 elements (like
	/// Vec6f) - (vx, vy, vz, x0, y0, z0), where (vx, vy, vz) is a normalized vector collinear to the line
	/// and (x0, y0, z0) is a point on the line.
	/// * distType: Distance used by the M-estimator, see [distance_types]
	/// * param: Numerical parameter ( C ) for some types of distances. If it is 0, an optimal value
	/// is chosen.
	/// * reps: Sufficient accuracy for the radius (distance between the coordinate origin and the line).
	/// * aeps: Sufficient accuracy for the angle. 0.01 would be a good default value for reps and aeps.
	#[inline]
	pub fn fit_line(points: &impl core::ToInputArray, line: &mut impl core::ToOutputArray, dist_type: i32, param: f64, reps: f64, aeps: f64) -> Result<()> {
		input_array_arg!(points);
		output_array_arg!(line);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_fitLine_const__InputArrayR_const__OutputArrayR_int_double_double_double(points.as_raw__InputArray(), line.as_raw__OutputArray(), dist_type, param, reps, aeps, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// @overload
	/// 
	/// variant without `mask` parameter
	/// 
	/// ## Note
	/// This alternative version of [flood_fill] function uses the following default values for its arguments:
	/// * rect: 0
	/// * lo_diff: Scalar()
	/// * up_diff: Scalar()
	/// * flags: 4
	#[inline]
	pub fn flood_fill_def(image: &mut impl core::ToInputOutputArray, seed_point: core::Point, new_val: core::Scalar) -> Result<i32> {
		input_output_array_arg!(image);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_floodFill_const__InputOutputArrayR_Point_Scalar(image.as_raw__InputOutputArray(), seed_point.opencv_as_extern(), new_val.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Fills a connected component with the given color.
	/// 
	/// The function cv::floodFill fills a connected component starting from the seed point with the specified
	/// color. The connectivity is determined by the color/brightness closeness of the neighbor pixels. The
	/// pixel at  is considered to belong to the repainted domain if:
	/// 
	/// - in case of a grayscale image and floating range
	/// 
	/// 
	/// 
	/// - in case of a grayscale image and fixed range
	/// 
	/// 
	/// 
	/// - in case of a color image and floating range
	/// 
	/// 
	/// and
	/// 
	/// 
	/// 
	/// - in case of a color image and fixed range
	/// 
	/// 
	/// and
	/// 
	/// 
	/// 
	/// where  is the value of one of pixel neighbors that is already known to belong to the
	/// component. That is, to be added to the connected component, a color/brightness of the pixel should
	/// be close enough to:
	/// - Color/brightness of one of its neighbors that already belong to the connected component in case
	/// of a floating range.
	/// - Color/brightness of the seed point in case of a fixed range.
	/// 
	/// Use these functions to either mark a connected component with the specified color in-place, or build
	/// a mask and then extract the contour, or copy the region to another image, and so on.
	/// 
	/// ## Parameters
	/// * image: Input/output 1- or 3-channel, 8-bit, or floating-point image. It is modified by the
	/// function unless the [FLOODFILL_MASK_ONLY] flag is set in the second variant of the function. See
	/// the details below.
	/// * mask: Operation mask that should be a single-channel 8-bit image, 2 pixels wider and 2 pixels
	/// taller than image. If an empty Mat is passed it will be created automatically. Since this is both an
	/// input and output parameter, you must take responsibility of initializing it.
	/// Flood-filling cannot go across non-zero pixels in the input mask. For example,
	/// an edge detector output can be used as a mask to stop filling at edges. On output, pixels in the
	/// mask corresponding to filled pixels in the image are set to 1 or to the specified value in flags
	/// as described below. Additionally, the function fills the border of the mask with ones to simplify
	/// internal processing. It is therefore possible to use the same mask in multiple calls to the function
	/// to make sure the filled areas do not overlap.
	/// * seedPoint: Starting point.
	/// * newVal: New value of the repainted domain pixels.
	/// * loDiff: Maximal lower brightness/color difference between the currently observed pixel and
	/// one of its neighbors belonging to the component, or a seed pixel being added to the component.
	/// * upDiff: Maximal upper brightness/color difference between the currently observed pixel and
	/// one of its neighbors belonging to the component, or a seed pixel being added to the component.
	/// * rect: Optional output parameter set by the function to the minimum bounding rectangle of the
	/// repainted domain.
	/// * flags: Operation flags. The first 8 bits contain a connectivity value. The default value of
	/// 4 means that only the four nearest neighbor pixels (those that share an edge) are considered. A
	/// connectivity value of 8 means that the eight nearest neighbor pixels (those that share a corner)
	/// will be considered. The next 8 bits (8-16) contain a value between 1 and 255 with which to fill
	/// the mask (the default value is 1). For example, 4 | ( 255 \<\< 8 ) will consider 4 nearest
	/// neighbours and fill the mask with a value of 255. The following additional options occupy higher
	/// bits and therefore may be further combined with the connectivity and mask fill values using
	/// bit-wise or (|), see #FloodFillFlags.
	/// 
	/// 
	/// Note: Since the mask is larger than the filled image, a pixel  in image corresponds to the
	/// pixel  in the mask .
	/// ## See also
	/// findContours
	/// 
	/// ## Overloaded parameters
	/// 
	/// 
	/// variant without `mask` parameter
	/// 
	/// ## C++ default parameters
	/// * rect: 0
	/// * lo_diff: Scalar()
	/// * up_diff: Scalar()
	/// * flags: 4
	#[inline]
	pub fn flood_fill(image: &mut impl core::ToInputOutputArray, seed_point: core::Point, new_val: core::Scalar, rect: &mut core::Rect, lo_diff: core::Scalar, up_diff: core::Scalar, flags: i32) -> Result<i32> {
		input_output_array_arg!(image);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_floodFill_const__InputOutputArrayR_Point_Scalar_RectX_Scalar_Scalar_int(image.as_raw__InputOutputArray(), seed_point.opencv_as_extern(), new_val.opencv_as_extern(), rect, lo_diff.opencv_as_extern(), up_diff.opencv_as_extern(), flags, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Fills a connected component with the given color.
	/// 
	/// The function cv::floodFill fills a connected component starting from the seed point with the specified
	/// color. The connectivity is determined by the color/brightness closeness of the neighbor pixels. The
	/// pixel at  is considered to belong to the repainted domain if:
	/// 
	/// - in case of a grayscale image and floating range
	/// 
	/// 
	/// 
	/// - in case of a grayscale image and fixed range
	/// 
	/// 
	/// 
	/// - in case of a color image and floating range
	/// 
	/// 
	/// and
	/// 
	/// 
	/// 
	/// - in case of a color image and fixed range
	/// 
	/// 
	/// and
	/// 
	/// 
	/// 
	/// where  is the value of one of pixel neighbors that is already known to belong to the
	/// component. That is, to be added to the connected component, a color/brightness of the pixel should
	/// be close enough to:
	/// - Color/brightness of one of its neighbors that already belong to the connected component in case
	/// of a floating range.
	/// - Color/brightness of the seed point in case of a fixed range.
	/// 
	/// Use these functions to either mark a connected component with the specified color in-place, or build
	/// a mask and then extract the contour, or copy the region to another image, and so on.
	/// 
	/// ## Parameters
	/// * image: Input/output 1- or 3-channel, 8-bit, or floating-point image. It is modified by the
	/// function unless the [FLOODFILL_MASK_ONLY] flag is set in the second variant of the function. See
	/// the details below.
	/// * mask: Operation mask that should be a single-channel 8-bit image, 2 pixels wider and 2 pixels
	/// taller than image. If an empty Mat is passed it will be created automatically. Since this is both an
	/// input and output parameter, you must take responsibility of initializing it.
	/// Flood-filling cannot go across non-zero pixels in the input mask. For example,
	/// an edge detector output can be used as a mask to stop filling at edges. On output, pixels in the
	/// mask corresponding to filled pixels in the image are set to 1 or to the specified value in flags
	/// as described below. Additionally, the function fills the border of the mask with ones to simplify
	/// internal processing. It is therefore possible to use the same mask in multiple calls to the function
	/// to make sure the filled areas do not overlap.
	/// * seedPoint: Starting point.
	/// * newVal: New value of the repainted domain pixels.
	/// * loDiff: Maximal lower brightness/color difference between the currently observed pixel and
	/// one of its neighbors belonging to the component, or a seed pixel being added to the component.
	/// * upDiff: Maximal upper brightness/color difference between the currently observed pixel and
	/// one of its neighbors belonging to the component, or a seed pixel being added to the component.
	/// * rect: Optional output parameter set by the function to the minimum bounding rectangle of the
	/// repainted domain.
	/// * flags: Operation flags. The first 8 bits contain a connectivity value. The default value of
	/// 4 means that only the four nearest neighbor pixels (those that share an edge) are considered. A
	/// connectivity value of 8 means that the eight nearest neighbor pixels (those that share a corner)
	/// will be considered. The next 8 bits (8-16) contain a value between 1 and 255 with which to fill
	/// the mask (the default value is 1). For example, 4 | ( 255 \<\< 8 ) will consider 4 nearest
	/// neighbours and fill the mask with a value of 255. The following additional options occupy higher
	/// bits and therefore may be further combined with the connectivity and mask fill values using
	/// bit-wise or (|), see #FloodFillFlags.
	/// 
	/// 
	/// Note: Since the mask is larger than the filled image, a pixel  in image corresponds to the
	/// pixel  in the mask .
	/// ## See also
	/// findContours
	/// 
	/// ## Note
	/// This alternative version of [flood_fill_mask] function uses the following default values for its arguments:
	/// * rect: 0
	/// * lo_diff: Scalar()
	/// * up_diff: Scalar()
	/// * flags: 4
	#[inline]
	pub fn flood_fill_mask_def(image: &mut impl core::ToInputOutputArray, mask: &mut impl core::ToInputOutputArray, seed_point: core::Point, new_val: core::Scalar) -> Result<i32> {
		input_output_array_arg!(image);
		input_output_array_arg!(mask);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_floodFill_const__InputOutputArrayR_const__InputOutputArrayR_Point_Scalar(image.as_raw__InputOutputArray(), mask.as_raw__InputOutputArray(), seed_point.opencv_as_extern(), new_val.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Fills a connected component with the given color.
	/// 
	/// The function cv::floodFill fills a connected component starting from the seed point with the specified
	/// color. The connectivity is determined by the color/brightness closeness of the neighbor pixels. The
	/// pixel at  is considered to belong to the repainted domain if:
	/// 
	/// - in case of a grayscale image and floating range
	/// 
	/// 
	/// 
	/// - in case of a grayscale image and fixed range
	/// 
	/// 
	/// 
	/// - in case of a color image and floating range
	/// 
	/// 
	/// and
	/// 
	/// 
	/// 
	/// - in case of a color image and fixed range
	/// 
	/// 
	/// and
	/// 
	/// 
	/// 
	/// where  is the value of one of pixel neighbors that is already known to belong to the
	/// component. That is, to be added to the connected component, a color/brightness of the pixel should
	/// be close enough to:
	/// - Color/brightness of one of its neighbors that already belong to the connected component in case
	/// of a floating range.
	/// - Color/brightness of the seed point in case of a fixed range.
	/// 
	/// Use these functions to either mark a connected component with the specified color in-place, or build
	/// a mask and then extract the contour, or copy the region to another image, and so on.
	/// 
	/// ## Parameters
	/// * image: Input/output 1- or 3-channel, 8-bit, or floating-point image. It is modified by the
	/// function unless the [FLOODFILL_MASK_ONLY] flag is set in the second variant of the function. See
	/// the details below.
	/// * mask: Operation mask that should be a single-channel 8-bit image, 2 pixels wider and 2 pixels
	/// taller than image. If an empty Mat is passed it will be created automatically. Since this is both an
	/// input and output parameter, you must take responsibility of initializing it.
	/// Flood-filling cannot go across non-zero pixels in the input mask. For example,
	/// an edge detector output can be used as a mask to stop filling at edges. On output, pixels in the
	/// mask corresponding to filled pixels in the image are set to 1 or to the specified value in flags
	/// as described below. Additionally, the function fills the border of the mask with ones to simplify
	/// internal processing. It is therefore possible to use the same mask in multiple calls to the function
	/// to make sure the filled areas do not overlap.
	/// * seedPoint: Starting point.
	/// * newVal: New value of the repainted domain pixels.
	/// * loDiff: Maximal lower brightness/color difference between the currently observed pixel and
	/// one of its neighbors belonging to the component, or a seed pixel being added to the component.
	/// * upDiff: Maximal upper brightness/color difference between the currently observed pixel and
	/// one of its neighbors belonging to the component, or a seed pixel being added to the component.
	/// * rect: Optional output parameter set by the function to the minimum bounding rectangle of the
	/// repainted domain.
	/// * flags: Operation flags. The first 8 bits contain a connectivity value. The default value of
	/// 4 means that only the four nearest neighbor pixels (those that share an edge) are considered. A
	/// connectivity value of 8 means that the eight nearest neighbor pixels (those that share a corner)
	/// will be considered. The next 8 bits (8-16) contain a value between 1 and 255 with which to fill
	/// the mask (the default value is 1). For example, 4 | ( 255 \<\< 8 ) will consider 4 nearest
	/// neighbours and fill the mask with a value of 255. The following additional options occupy higher
	/// bits and therefore may be further combined with the connectivity and mask fill values using
	/// bit-wise or (|), see #FloodFillFlags.
	/// 
	/// 
	/// Note: Since the mask is larger than the filled image, a pixel  in image corresponds to the
	/// pixel  in the mask .
	/// ## See also
	/// findContours
	/// 
	/// ## C++ default parameters
	/// * rect: 0
	/// * lo_diff: Scalar()
	/// * up_diff: Scalar()
	/// * flags: 4
	#[inline]
	pub fn flood_fill_mask(image: &mut impl core::ToInputOutputArray, mask: &mut impl core::ToInputOutputArray, seed_point: core::Point, new_val: core::Scalar, rect: &mut core::Rect, lo_diff: core::Scalar, up_diff: core::Scalar, flags: i32) -> Result<i32> {
		input_output_array_arg!(image);
		input_output_array_arg!(mask);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_floodFill_const__InputOutputArrayR_const__InputOutputArrayR_Point_Scalar_RectX_Scalar_Scalar_int(image.as_raw__InputOutputArray(), mask.as_raw__InputOutputArray(), seed_point.opencv_as_extern(), new_val.opencv_as_extern(), rect, lo_diff.opencv_as_extern(), up_diff.opencv_as_extern(), flags, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates an affine transform from three pairs of the corresponding points.
	/// 
	/// The function calculates the  matrix of an affine transform so that:
	/// 
	/// 
	/// 
	/// where
	/// 
	/// 
	/// 
	/// ## Parameters
	/// * src: Coordinates of triangle vertices in the source image.
	/// * dst: Coordinates of the corresponding triangle vertices in the destination image.
	/// ## See also
	/// warpAffine, transform
	#[inline]
	pub fn get_affine_transform_slice(src: &[core::Point2f], dst: &[core::Point2f]) -> Result<core::Mat> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_getAffineTransform_const_Point2fX_const_Point2fX(src.as_ptr(), dst.as_ptr(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		let ret = unsafe { core::Mat::opencv_from_extern(ret) };
		Ok(ret)
	}
	
	#[inline]
	pub fn get_affine_transform(src: &impl core::ToInputArray, dst: &impl core::ToInputArray) -> Result<core::Mat> {
		input_array_arg!(src);
		input_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_getAffineTransform_const__InputArrayR_const__InputArrayR(src.as_raw__InputArray(), dst.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		let ret = unsafe { core::Mat::opencv_from_extern(ret) };
		Ok(ret)
	}
	
	/// Returns filter coefficients for computing spatial image derivatives.
	/// 
	/// The function computes and returns the filter coefficients for spatial image derivatives. When
	/// `ksize=FILTER_SCHARR`, the Scharr  kernels are generated (see #Scharr). Otherwise, Sobel
	/// kernels are generated (see #Sobel). The filters are normally passed to [sep_filter_2d] or to
	/// 
	/// ## Parameters
	/// * kx: Output matrix of row filter coefficients. It has the type ktype .
	/// * ky: Output matrix of column filter coefficients. It has the type ktype .
	/// * dx: Derivative order in respect of x.
	/// * dy: Derivative order in respect of y.
	/// * ksize: Aperture size. It can be FILTER_SCHARR, 1, 3, 5, or 7.
	/// * normalize: Flag indicating whether to normalize (scale down) the filter coefficients or not.
	/// Theoretically, the coefficients should have the denominator . If you are
	/// going to filter floating-point images, you are likely to use the normalized kernels. But if you
	/// compute derivatives of an 8-bit image, store the results in a 16-bit image, and wish to preserve
	/// all the fractional bits, you may want to set normalize=false .
	/// * ktype: Type of filter coefficients. It can be CV_32f or CV_64F .
	/// 
	/// ## Note
	/// This alternative version of [get_deriv_kernels] function uses the following default values for its arguments:
	/// * normalize: false
	/// * ktype: CV_32F
	#[inline]
	pub fn get_deriv_kernels_def(kx: &mut impl core::ToOutputArray, ky: &mut impl core::ToOutputArray, dx: i32, dy: i32, ksize: i32) -> Result<()> {
		output_array_arg!(kx);
		output_array_arg!(ky);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_getDerivKernels_const__OutputArrayR_const__OutputArrayR_int_int_int(kx.as_raw__OutputArray(), ky.as_raw__OutputArray(), dx, dy, ksize, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Returns filter coefficients for computing spatial image derivatives.
	/// 
	/// The function computes and returns the filter coefficients for spatial image derivatives. When
	/// `ksize=FILTER_SCHARR`, the Scharr  kernels are generated (see #Scharr). Otherwise, Sobel
	/// kernels are generated (see #Sobel). The filters are normally passed to [sep_filter_2d] or to
	/// 
	/// ## Parameters
	/// * kx: Output matrix of row filter coefficients. It has the type ktype .
	/// * ky: Output matrix of column filter coefficients. It has the type ktype .
	/// * dx: Derivative order in respect of x.
	/// * dy: Derivative order in respect of y.
	/// * ksize: Aperture size. It can be FILTER_SCHARR, 1, 3, 5, or 7.
	/// * normalize: Flag indicating whether to normalize (scale down) the filter coefficients or not.
	/// Theoretically, the coefficients should have the denominator . If you are
	/// going to filter floating-point images, you are likely to use the normalized kernels. But if you
	/// compute derivatives of an 8-bit image, store the results in a 16-bit image, and wish to preserve
	/// all the fractional bits, you may want to set normalize=false .
	/// * ktype: Type of filter coefficients. It can be CV_32f or CV_64F .
	/// 
	/// ## C++ default parameters
	/// * normalize: false
	/// * ktype: CV_32F
	#[inline]
	pub fn get_deriv_kernels(kx: &mut impl core::ToOutputArray, ky: &mut impl core::ToOutputArray, dx: i32, dy: i32, ksize: i32, normalize: bool, ktype: i32) -> Result<()> {
		output_array_arg!(kx);
		output_array_arg!(ky);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_getDerivKernels_const__OutputArrayR_const__OutputArrayR_int_int_int_bool_int(kx.as_raw__OutputArray(), ky.as_raw__OutputArray(), dx, dy, ksize, normalize, ktype, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates the font-specific size to use to achieve a given height in pixels.
	/// 
	/// ## Parameters
	/// * fontFace: Font to use, see cv::HersheyFonts.
	/// * pixelHeight: Pixel height to compute the fontScale for
	/// * thickness: Thickness of lines used to render the text.See putText for details.
	/// ## Returns
	/// The fontSize to use for cv::putText
	/// ## See also
	/// cv::putText
	/// 
	/// ## Note
	/// This alternative version of [get_font_scale_from_height] function uses the following default values for its arguments:
	/// * thickness: 1
	#[inline]
	pub fn get_font_scale_from_height_def(font_face: i32, pixel_height: i32) -> Result<f64> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_getFontScaleFromHeight_const_int_const_int(font_face, pixel_height, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates the font-specific size to use to achieve a given height in pixels.
	/// 
	/// ## Parameters
	/// * fontFace: Font to use, see cv::HersheyFonts.
	/// * pixelHeight: Pixel height to compute the fontScale for
	/// * thickness: Thickness of lines used to render the text.See putText for details.
	/// ## Returns
	/// The fontSize to use for cv::putText
	/// ## See also
	/// cv::putText
	/// 
	/// ## C++ default parameters
	/// * thickness: 1
	#[inline]
	pub fn get_font_scale_from_height(font_face: i32, pixel_height: i32, thickness: i32) -> Result<f64> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_getFontScaleFromHeight_const_int_const_int_const_int(font_face, pixel_height, thickness, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Returns Gabor filter coefficients.
	/// 
	/// For more details about gabor filter equations and parameters, see: [Gabor
	/// Filter](http://en.wikipedia.org/wiki/Gabor_filter).
	/// 
	/// ## Parameters
	/// * ksize: Size of the filter returned.
	/// * sigma: Standard deviation of the gaussian envelope.
	/// * theta: Orientation of the normal to the parallel stripes of a Gabor function.
	/// * lambd: Wavelength of the sinusoidal factor.
	/// * gamma: Spatial aspect ratio.
	/// * psi: Phase offset.
	/// * ktype: Type of filter coefficients. It can be CV_32F or CV_64F .
	/// 
	/// ## Note
	/// This alternative version of [get_gabor_kernel] function uses the following default values for its arguments:
	/// * psi: CV_PI*0.5
	/// * ktype: CV_64F
	#[inline]
	pub fn get_gabor_kernel_def(ksize: core::Size, sigma: f64, theta: f64, lambd: f64, gamma: f64) -> Result<core::Mat> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_getGaborKernel_Size_double_double_double_double(ksize.opencv_as_extern(), sigma, theta, lambd, gamma, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		let ret = unsafe { core::Mat::opencv_from_extern(ret) };
		Ok(ret)
	}
	
	/// Returns Gabor filter coefficients.
	/// 
	/// For more details about gabor filter equations and parameters, see: [Gabor
	/// Filter](http://en.wikipedia.org/wiki/Gabor_filter).
	/// 
	/// ## Parameters
	/// * ksize: Size of the filter returned.
	/// * sigma: Standard deviation of the gaussian envelope.
	/// * theta: Orientation of the normal to the parallel stripes of a Gabor function.
	/// * lambd: Wavelength of the sinusoidal factor.
	/// * gamma: Spatial aspect ratio.
	/// * psi: Phase offset.
	/// * ktype: Type of filter coefficients. It can be CV_32F or CV_64F .
	/// 
	/// ## C++ default parameters
	/// * psi: CV_PI*0.5
	/// * ktype: CV_64F
	#[inline]
	pub fn get_gabor_kernel(ksize: core::Size, sigma: f64, theta: f64, lambd: f64, gamma: f64, psi: f64, ktype: i32) -> Result<core::Mat> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_getGaborKernel_Size_double_double_double_double_double_int(ksize.opencv_as_extern(), sigma, theta, lambd, gamma, psi, ktype, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		let ret = unsafe { core::Mat::opencv_from_extern(ret) };
		Ok(ret)
	}
	
	/// Returns Gaussian filter coefficients.
	/// 
	/// The function computes and returns the  matrix of Gaussian filter
	/// coefficients:
	/// 
	/// 
	/// 
	/// where  and  is the scale factor chosen so that .
	/// 
	/// Two of such generated kernels can be passed to sepFilter2D. Those functions automatically recognize
	/// smoothing kernels (a symmetrical kernel with sum of weights equal to 1) and handle them accordingly.
	/// You may also use the higher-level GaussianBlur.
	/// ## Parameters
	/// * ksize: Aperture size. It should be odd (  ) and positive.
	/// * sigma: Gaussian standard deviation. If it is non-positive, it is computed from ksize as
	/// `sigma = 0.3*((ksize-1)*0.5 - 1) + 0.8`.
	/// * ktype: Type of filter coefficients. It can be CV_32F or CV_64F .
	/// ## See also
	/// sepFilter2D, getDerivKernels, getStructuringElement, GaussianBlur
	/// 
	/// ## Note
	/// This alternative version of [get_gaussian_kernel] function uses the following default values for its arguments:
	/// * ktype: CV_64F
	#[inline]
	pub fn get_gaussian_kernel_def(ksize: i32, sigma: f64) -> Result<core::Mat> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_getGaussianKernel_int_double(ksize, sigma, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		let ret = unsafe { core::Mat::opencv_from_extern(ret) };
		Ok(ret)
	}
	
	/// Returns Gaussian filter coefficients.
	/// 
	/// The function computes and returns the  matrix of Gaussian filter
	/// coefficients:
	/// 
	/// 
	/// 
	/// where  and  is the scale factor chosen so that .
	/// 
	/// Two of such generated kernels can be passed to sepFilter2D. Those functions automatically recognize
	/// smoothing kernels (a symmetrical kernel with sum of weights equal to 1) and handle them accordingly.
	/// You may also use the higher-level GaussianBlur.
	/// ## Parameters
	/// * ksize: Aperture size. It should be odd (  ) and positive.
	/// * sigma: Gaussian standard deviation. If it is non-positive, it is computed from ksize as
	/// `sigma = 0.3*((ksize-1)*0.5 - 1) + 0.8`.
	/// * ktype: Type of filter coefficients. It can be CV_32F or CV_64F .
	/// ## See also
	/// sepFilter2D, getDerivKernels, getStructuringElement, GaussianBlur
	/// 
	/// ## C++ default parameters
	/// * ktype: CV_64F
	#[inline]
	pub fn get_gaussian_kernel(ksize: i32, sigma: f64, ktype: i32) -> Result<core::Mat> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_getGaussianKernel_int_double_int(ksize, sigma, ktype, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		let ret = unsafe { core::Mat::opencv_from_extern(ret) };
		Ok(ret)
	}
	
	/// @overload
	/// 
	/// ## Note
	/// This alternative version of [get_perspective_transform_slice] function uses the following default values for its arguments:
	/// * solve_method: DECOMP_LU
	#[inline]
	pub fn get_perspective_transform_slice_def(src: &[core::Point2f], dst: &[core::Point2f]) -> Result<core::Mat> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_getPerspectiveTransform_const_Point2fX_const_Point2fX(src.as_ptr(), dst.as_ptr(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		let ret = unsafe { core::Mat::opencv_from_extern(ret) };
		Ok(ret)
	}
	
	/// Calculates a perspective transform from four pairs of the corresponding points.
	/// 
	/// The function calculates the  matrix of a perspective transform so that:
	/// 
	/// 
	/// 
	/// where
	/// 
	/// 
	/// 
	/// ## Parameters
	/// * src: Coordinates of quadrangle vertices in the source image.
	/// * dst: Coordinates of the corresponding quadrangle vertices in the destination image.
	/// * solveMethod: method passed to cv::solve (#DecompTypes)
	/// ## See also
	/// findHomography, warpPerspective, perspectiveTransform
	/// 
	/// ## Overloaded parameters
	/// 
	/// ## C++ default parameters
	/// * solve_method: DECOMP_LU
	#[inline]
	pub fn get_perspective_transform_slice(src: &[core::Point2f], dst: &[core::Point2f], solve_method: i32) -> Result<core::Mat> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_getPerspectiveTransform_const_Point2fX_const_Point2fX_int(src.as_ptr(), dst.as_ptr(), solve_method, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		let ret = unsafe { core::Mat::opencv_from_extern(ret) };
		Ok(ret)
	}
	
	/// Calculates a perspective transform from four pairs of the corresponding points.
	/// 
	/// The function calculates the  matrix of a perspective transform so that:
	/// 
	/// 
	/// 
	/// where
	/// 
	/// 
	/// 
	/// ## Parameters
	/// * src: Coordinates of quadrangle vertices in the source image.
	/// * dst: Coordinates of the corresponding quadrangle vertices in the destination image.
	/// * solveMethod: method passed to cv::solve (#DecompTypes)
	/// ## See also
	/// findHomography, warpPerspective, perspectiveTransform
	/// 
	/// ## Note
	/// This alternative version of [get_perspective_transform] function uses the following default values for its arguments:
	/// * solve_method: DECOMP_LU
	#[inline]
	pub fn get_perspective_transform_def(src: &impl core::ToInputArray, dst: &impl core::ToInputArray) -> Result<core::Mat> {
		input_array_arg!(src);
		input_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_getPerspectiveTransform_const__InputArrayR_const__InputArrayR(src.as_raw__InputArray(), dst.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		let ret = unsafe { core::Mat::opencv_from_extern(ret) };
		Ok(ret)
	}
	
	/// Calculates a perspective transform from four pairs of the corresponding points.
	/// 
	/// The function calculates the  matrix of a perspective transform so that:
	/// 
	/// 
	/// 
	/// where
	/// 
	/// 
	/// 
	/// ## Parameters
	/// * src: Coordinates of quadrangle vertices in the source image.
	/// * dst: Coordinates of the corresponding quadrangle vertices in the destination image.
	/// * solveMethod: method passed to cv::solve (#DecompTypes)
	/// ## See also
	/// findHomography, warpPerspective, perspectiveTransform
	/// 
	/// ## C++ default parameters
	/// * solve_method: DECOMP_LU
	#[inline]
	pub fn get_perspective_transform(src: &impl core::ToInputArray, dst: &impl core::ToInputArray, solve_method: i32) -> Result<core::Mat> {
		input_array_arg!(src);
		input_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_getPerspectiveTransform_const__InputArrayR_const__InputArrayR_int(src.as_raw__InputArray(), dst.as_raw__InputArray(), solve_method, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		let ret = unsafe { core::Mat::opencv_from_extern(ret) };
		Ok(ret)
	}
	
	/// Retrieves a pixel rectangle from an image with sub-pixel accuracy.
	/// 
	/// The function getRectSubPix extracts pixels from src:
	/// 
	/// 
	/// 
	/// where the values of the pixels at non-integer coordinates are retrieved using bilinear
	/// interpolation. Every channel of multi-channel images is processed independently. Also
	/// the image should be a single channel or three channel image. While the center of the
	/// rectangle must be inside the image, parts of the rectangle may be outside.
	/// 
	/// ## Parameters
	/// * image: Source image.
	/// * patchSize: Size of the extracted patch.
	/// * center: Floating point coordinates of the center of the extracted rectangle within the
	/// source image. The center must be inside the image.
	/// * patch: Extracted patch that has the size patchSize and the same number of channels as src .
	/// * patchType: Depth of the extracted pixels. By default, they have the same depth as src .
	/// ## See also
	/// warpAffine, warpPerspective
	/// 
	/// ## Note
	/// This alternative version of [get_rect_sub_pix] function uses the following default values for its arguments:
	/// * patch_type: -1
	#[inline]
	pub fn get_rect_sub_pix_def(image: &impl core::ToInputArray, patch_size: core::Size, center: core::Point2f, patch: &mut impl core::ToOutputArray) -> Result<()> {
		input_array_arg!(image);
		output_array_arg!(patch);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_getRectSubPix_const__InputArrayR_Size_Point2f_const__OutputArrayR(image.as_raw__InputArray(), patch_size.opencv_as_extern(), center.opencv_as_extern(), patch.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Retrieves a pixel rectangle from an image with sub-pixel accuracy.
	/// 
	/// The function getRectSubPix extracts pixels from src:
	/// 
	/// 
	/// 
	/// where the values of the pixels at non-integer coordinates are retrieved using bilinear
	/// interpolation. Every channel of multi-channel images is processed independently. Also
	/// the image should be a single channel or three channel image. While the center of the
	/// rectangle must be inside the image, parts of the rectangle may be outside.
	/// 
	/// ## Parameters
	/// * image: Source image.
	/// * patchSize: Size of the extracted patch.
	/// * center: Floating point coordinates of the center of the extracted rectangle within the
	/// source image. The center must be inside the image.
	/// * patch: Extracted patch that has the size patchSize and the same number of channels as src .
	/// * patchType: Depth of the extracted pixels. By default, they have the same depth as src .
	/// ## See also
	/// warpAffine, warpPerspective
	/// 
	/// ## C++ default parameters
	/// * patch_type: -1
	#[inline]
	pub fn get_rect_sub_pix(image: &impl core::ToInputArray, patch_size: core::Size, center: core::Point2f, patch: &mut impl core::ToOutputArray, patch_type: i32) -> Result<()> {
		input_array_arg!(image);
		output_array_arg!(patch);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_getRectSubPix_const__InputArrayR_Size_Point2f_const__OutputArrayR_int(image.as_raw__InputArray(), patch_size.opencv_as_extern(), center.opencv_as_extern(), patch.as_raw__OutputArray(), patch_type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates an affine matrix of 2D rotation.
	/// 
	/// The function calculates the following matrix:
	/// 
	/// 
	/// 
	/// where
	/// 
	/// 
	/// 
	/// The transformation maps the rotation center to itself. If this is not the target, adjust the shift.
	/// 
	/// ## Parameters
	/// * center: Center of the rotation in the source image.
	/// * angle: Rotation angle in degrees. Positive values mean counter-clockwise rotation (the
	/// coordinate origin is assumed to be the top-left corner).
	/// * scale: Isotropic scale factor.
	/// ## See also
	/// getAffineTransform, warpAffine, transform
	#[inline]
	pub fn get_rotation_matrix_2d(center: core::Point2f, angle: f64, scale: f64) -> Result<core::Mat> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_getRotationMatrix2D_Point2f_double_double(center.opencv_as_extern(), angle, scale, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		let ret = unsafe { core::Mat::opencv_from_extern(ret) };
		Ok(ret)
	}
	
	/// ## See also
	/// getRotationMatrix2D
	#[inline]
	#[cfg(not(target_os = "windows"))]
	pub fn get_rotation_matrix_2d_matx(center: core::Point2f, angle: f64, scale: f64) -> Result<core::Matx23d> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_getRotationMatrix2D__Point2f_double_double(center.opencv_as_extern(), angle, scale, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Returns a structuring element of the specified size and shape for morphological operations.
	/// 
	/// The function constructs and returns the structuring element that can be further passed to #erode,
	/// [dilate] or #morphologyEx. But you can also construct an arbitrary binary mask yourself and use it as
	/// the structuring element.
	/// 
	/// ## Parameters
	/// * shape: Element shape that could be one of [morph_shapes]
	/// * ksize: Size of the structuring element.
	/// * anchor: Anchor position within the element. The default value  means that the
	/// anchor is at the center. Note that only the shape of a cross-shaped element depends on the anchor
	/// position. In other cases the anchor just regulates how much the result of the morphological
	/// operation is shifted.
	/// 
	/// ## Note
	/// This alternative version of [get_structuring_element] function uses the following default values for its arguments:
	/// * anchor: Point(-1,-1)
	#[inline]
	pub fn get_structuring_element_def(shape: i32, ksize: core::Size) -> Result<core::Mat> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_getStructuringElement_int_Size(shape, ksize.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		let ret = unsafe { core::Mat::opencv_from_extern(ret) };
		Ok(ret)
	}
	
	/// Returns a structuring element of the specified size and shape for morphological operations.
	/// 
	/// The function constructs and returns the structuring element that can be further passed to #erode,
	/// [dilate] or #morphologyEx. But you can also construct an arbitrary binary mask yourself and use it as
	/// the structuring element.
	/// 
	/// ## Parameters
	/// * shape: Element shape that could be one of [morph_shapes]
	/// * ksize: Size of the structuring element.
	/// * anchor: Anchor position within the element. The default value  means that the
	/// anchor is at the center. Note that only the shape of a cross-shaped element depends on the anchor
	/// position. In other cases the anchor just regulates how much the result of the morphological
	/// operation is shifted.
	/// 
	/// ## C++ default parameters
	/// * anchor: Point(-1,-1)
	#[inline]
	pub fn get_structuring_element(shape: i32, ksize: core::Size, anchor: core::Point) -> Result<core::Mat> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_getStructuringElement_int_Size_Point(shape, ksize.opencv_as_extern(), anchor.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		let ret = unsafe { core::Mat::opencv_from_extern(ret) };
		Ok(ret)
	}
	
	/// Calculates the width and height of a text string.
	/// 
	/// The function cv::getTextSize calculates and returns the size of a box that contains the specified text.
	/// That is, the following code renders some text, the tight box surrounding it, and the baseline: :
	/// ```C++
	///    String text = "Funny text inside the box";
	///    int fontFace = FONT_HERSHEY_SCRIPT_SIMPLEX;
	///    double fontScale = 2;
	///    int thickness = 3;
	/// 
	///    Mat img(600, 800, CV_8UC3, Scalar::all(0));
	/// 
	///    int baseline=0;
	///    Size textSize = getTextSize(text, fontFace,
	///                                 fontScale, thickness, &baseline);
	///    baseline += thickness;
	/// 
	///    // center the text
	///    Point textOrg((img.cols - textSize.width)/2,
	///                   (img.rows + textSize.height)/2);
	/// 
	///    // draw the box
	///    rectangle(img, textOrg + Point(0, baseline),
	///               textOrg + Point(textSize.width, -textSize.height),
	///               Scalar(0,0,255));
	///    // ... and the baseline first
	///    line(img, textOrg + Point(0, thickness),
	///          textOrg + Point(textSize.width, thickness),
	///          Scalar(0, 0, 255));
	/// 
	///    // then put the text itself
	///    putText(img, text, textOrg, fontFace, fontScale,
	///            Scalar::all(255), thickness, 8);
	/// ```
	/// 
	/// 
	/// ## Parameters
	/// * text: Input text string.
	/// * fontFace: Font to use, see #HersheyFonts.
	/// * fontScale: Font scale factor that is multiplied by the font-specific base size.
	/// * thickness: Thickness of lines used to render the text. See [put_text] for details.
	/// * baseLine:[out] y-coordinate of the baseline relative to the bottom-most text
	/// point.
	/// ## Returns
	/// The size of a box that contains the specified text.
	/// ## See also
	/// putText
	#[inline]
	pub fn get_text_size(text: &str, font_face: i32, font_scale: f64, thickness: i32, base_line: &mut i32) -> Result<core::Size> {
		extern_container_arg!(text);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_getTextSize_const_StringR_int_double_int_intX(text.opencv_as_extern(), font_face, font_scale, thickness, base_line, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Determines strong corners on an image.
	/// 
	/// The function finds the most prominent corners in the image or in the specified image region, as
	/// described in [Shi94](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Shi94)
	/// 
	/// *   Function calculates the corner quality measure at every source image pixel using the
	///    [corner_min_eigen_val] or [corner_harris] .
	/// *   Function performs a non-maximum suppression (the local maximums in *3 x 3* neighborhood are
	///    retained).
	/// *   The corners with the minimal eigenvalue less than
	///     are rejected.
	/// *   The remaining corners are sorted by the quality measure in the descending order.
	/// *   Function throws away each corner for which there is a stronger corner at a distance less than
	///    maxDistance.
	/// 
	/// The function can be used to initialize a point-based tracker of an object.
	/// 
	/// 
	/// Note: If the function is called with different values A and B of the parameter qualityLevel , and
	/// A \> B, the vector of returned corners with qualityLevel=A will be the prefix of the output vector
	/// with qualityLevel=B .
	/// 
	/// ## Parameters
	/// * image: Input 8-bit or floating-point 32-bit, single-channel image.
	/// * corners: Output vector of detected corners.
	/// * maxCorners: Maximum number of corners to return. If there are more corners than are found,
	/// the strongest of them is returned. `maxCorners <= 0` implies that no limit on the maximum is set
	/// and all detected corners are returned.
	/// * qualityLevel: Parameter characterizing the minimal accepted quality of image corners. The
	/// parameter value is multiplied by the best corner quality measure, which is the minimal eigenvalue
	/// (see [corner_min_eigen_val] ) or the Harris function response (see [corner_harris] ). The corners with the
	/// quality measure less than the product are rejected. For example, if the best corner has the
	/// quality measure = 1500, and the qualityLevel=0.01 , then all the corners with the quality measure
	/// less than 15 are rejected.
	/// * minDistance: Minimum possible Euclidean distance between the returned corners.
	/// * mask: Optional region of interest. If the image is not empty (it needs to have the type
	/// CV_8UC1 and the same size as image ), it specifies the region in which the corners are detected.
	/// * blockSize: Size of an average block for computing a derivative covariation matrix over each
	/// pixel neighborhood. See cornerEigenValsAndVecs .
	/// * useHarrisDetector: Parameter indicating whether to use a Harris detector (see #cornerHarris)
	/// or #cornerMinEigenVal.
	/// * k: Free parameter of the Harris detector.
	/// ## See also
	/// cornerMinEigenVal, cornerHarris, calcOpticalFlowPyrLK, estimateRigidTransform,
	/// 
	/// ## Note
	/// This alternative version of [good_features_to_track] function uses the following default values for its arguments:
	/// * mask: noArray()
	/// * block_size: 3
	/// * use_harris_detector: false
	/// * k: 0.04
	#[inline]
	pub fn good_features_to_track_def(image: &impl core::ToInputArray, corners: &mut impl core::ToOutputArray, max_corners: i32, quality_level: f64, min_distance: f64) -> Result<()> {
		input_array_arg!(image);
		output_array_arg!(corners);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_goodFeaturesToTrack_const__InputArrayR_const__OutputArrayR_int_double_double(image.as_raw__InputArray(), corners.as_raw__OutputArray(), max_corners, quality_level, min_distance, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Same as above, but returns also quality measure of the detected corners.
	/// 
	/// ## Parameters
	/// * image: Input 8-bit or floating-point 32-bit, single-channel image.
	/// * corners: Output vector of detected corners.
	/// * maxCorners: Maximum number of corners to return. If there are more corners than are found,
	/// the strongest of them is returned. `maxCorners <= 0` implies that no limit on the maximum is set
	/// and all detected corners are returned.
	/// * qualityLevel: Parameter characterizing the minimal accepted quality of image corners. The
	/// parameter value is multiplied by the best corner quality measure, which is the minimal eigenvalue
	/// (see [corner_min_eigen_val] ) or the Harris function response (see [corner_harris] ). The corners with the
	/// quality measure less than the product are rejected. For example, if the best corner has the
	/// quality measure = 1500, and the qualityLevel=0.01 , then all the corners with the quality measure
	/// less than 15 are rejected.
	/// * minDistance: Minimum possible Euclidean distance between the returned corners.
	/// * mask: Region of interest. If the image is not empty (it needs to have the type
	/// CV_8UC1 and the same size as image ), it specifies the region in which the corners are detected.
	/// * cornersQuality: Output vector of quality measure of the detected corners.
	/// * blockSize: Size of an average block for computing a derivative covariation matrix over each
	/// pixel neighborhood. See cornerEigenValsAndVecs .
	/// * gradientSize: Aperture parameter for the Sobel operator used for derivatives computation.
	/// See cornerEigenValsAndVecs .
	/// * useHarrisDetector: Parameter indicating whether to use a Harris detector (see #cornerHarris)
	/// or #cornerMinEigenVal.
	/// * k: Free parameter of the Harris detector.
	/// 
	/// ## Note
	/// This alternative version of [good_features_to_track_with_quality] function uses the following default values for its arguments:
	/// * block_size: 3
	/// * gradient_size: 3
	/// * use_harris_detector: false
	/// * k: 0.04
	#[inline]
	pub fn good_features_to_track_with_quality_def(image: &impl core::ToInputArray, corners: &mut impl core::ToOutputArray, max_corners: i32, quality_level: f64, min_distance: f64, mask: &impl core::ToInputArray, corners_quality: &mut impl core::ToOutputArray) -> Result<()> {
		input_array_arg!(image);
		output_array_arg!(corners);
		input_array_arg!(mask);
		output_array_arg!(corners_quality);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_goodFeaturesToTrack_const__InputArrayR_const__OutputArrayR_int_double_double_const__InputArrayR_const__OutputArrayR(image.as_raw__InputArray(), corners.as_raw__OutputArray(), max_corners, quality_level, min_distance, mask.as_raw__InputArray(), corners_quality.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Same as above, but returns also quality measure of the detected corners.
	/// 
	/// ## Parameters
	/// * image: Input 8-bit or floating-point 32-bit, single-channel image.
	/// * corners: Output vector of detected corners.
	/// * maxCorners: Maximum number of corners to return. If there are more corners than are found,
	/// the strongest of them is returned. `maxCorners <= 0` implies that no limit on the maximum is set
	/// and all detected corners are returned.
	/// * qualityLevel: Parameter characterizing the minimal accepted quality of image corners. The
	/// parameter value is multiplied by the best corner quality measure, which is the minimal eigenvalue
	/// (see [corner_min_eigen_val] ) or the Harris function response (see [corner_harris] ). The corners with the
	/// quality measure less than the product are rejected. For example, if the best corner has the
	/// quality measure = 1500, and the qualityLevel=0.01 , then all the corners with the quality measure
	/// less than 15 are rejected.
	/// * minDistance: Minimum possible Euclidean distance between the returned corners.
	/// * mask: Region of interest. If the image is not empty (it needs to have the type
	/// CV_8UC1 and the same size as image ), it specifies the region in which the corners are detected.
	/// * cornersQuality: Output vector of quality measure of the detected corners.
	/// * blockSize: Size of an average block for computing a derivative covariation matrix over each
	/// pixel neighborhood. See cornerEigenValsAndVecs .
	/// * gradientSize: Aperture parameter for the Sobel operator used for derivatives computation.
	/// See cornerEigenValsAndVecs .
	/// * useHarrisDetector: Parameter indicating whether to use a Harris detector (see #cornerHarris)
	/// or #cornerMinEigenVal.
	/// * k: Free parameter of the Harris detector.
	/// 
	/// ## C++ default parameters
	/// * block_size: 3
	/// * gradient_size: 3
	/// * use_harris_detector: false
	/// * k: 0.04
	#[inline]
	pub fn good_features_to_track_with_quality(image: &impl core::ToInputArray, corners: &mut impl core::ToOutputArray, max_corners: i32, quality_level: f64, min_distance: f64, mask: &impl core::ToInputArray, corners_quality: &mut impl core::ToOutputArray, block_size: i32, gradient_size: i32, use_harris_detector: bool, k: f64) -> Result<()> {
		input_array_arg!(image);
		output_array_arg!(corners);
		input_array_arg!(mask);
		output_array_arg!(corners_quality);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_goodFeaturesToTrack_const__InputArrayR_const__OutputArrayR_int_double_double_const__InputArrayR_const__OutputArrayR_int_int_bool_double(image.as_raw__InputArray(), corners.as_raw__OutputArray(), max_corners, quality_level, min_distance, mask.as_raw__InputArray(), corners_quality.as_raw__OutputArray(), block_size, gradient_size, use_harris_detector, k, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Determines strong corners on an image.
	/// 
	/// The function finds the most prominent corners in the image or in the specified image region, as
	/// described in [Shi94](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Shi94)
	/// 
	/// *   Function calculates the corner quality measure at every source image pixel using the
	///    [corner_min_eigen_val] or [corner_harris] .
	/// *   Function performs a non-maximum suppression (the local maximums in *3 x 3* neighborhood are
	///    retained).
	/// *   The corners with the minimal eigenvalue less than
	///     are rejected.
	/// *   The remaining corners are sorted by the quality measure in the descending order.
	/// *   Function throws away each corner for which there is a stronger corner at a distance less than
	///    maxDistance.
	/// 
	/// The function can be used to initialize a point-based tracker of an object.
	/// 
	/// 
	/// Note: If the function is called with different values A and B of the parameter qualityLevel , and
	/// A \> B, the vector of returned corners with qualityLevel=A will be the prefix of the output vector
	/// with qualityLevel=B .
	/// 
	/// ## Parameters
	/// * image: Input 8-bit or floating-point 32-bit, single-channel image.
	/// * corners: Output vector of detected corners.
	/// * maxCorners: Maximum number of corners to return. If there are more corners than are found,
	/// the strongest of them is returned. `maxCorners <= 0` implies that no limit on the maximum is set
	/// and all detected corners are returned.
	/// * qualityLevel: Parameter characterizing the minimal accepted quality of image corners. The
	/// parameter value is multiplied by the best corner quality measure, which is the minimal eigenvalue
	/// (see [corner_min_eigen_val] ) or the Harris function response (see [corner_harris] ). The corners with the
	/// quality measure less than the product are rejected. For example, if the best corner has the
	/// quality measure = 1500, and the qualityLevel=0.01 , then all the corners with the quality measure
	/// less than 15 are rejected.
	/// * minDistance: Minimum possible Euclidean distance between the returned corners.
	/// * mask: Optional region of interest. If the image is not empty (it needs to have the type
	/// CV_8UC1 and the same size as image ), it specifies the region in which the corners are detected.
	/// * blockSize: Size of an average block for computing a derivative covariation matrix over each
	/// pixel neighborhood. See cornerEigenValsAndVecs .
	/// * useHarrisDetector: Parameter indicating whether to use a Harris detector (see #cornerHarris)
	/// or #cornerMinEigenVal.
	/// * k: Free parameter of the Harris detector.
	/// ## See also
	/// cornerMinEigenVal, cornerHarris, calcOpticalFlowPyrLK, estimateRigidTransform,
	/// 
	/// ## C++ default parameters
	/// * mask: noArray()
	/// * block_size: 3
	/// * use_harris_detector: false
	/// * k: 0.04
	#[inline]
	pub fn good_features_to_track(image: &impl core::ToInputArray, corners: &mut impl core::ToOutputArray, max_corners: i32, quality_level: f64, min_distance: f64, mask: &impl core::ToInputArray, block_size: i32, use_harris_detector: bool, k: f64) -> Result<()> {
		input_array_arg!(image);
		output_array_arg!(corners);
		input_array_arg!(mask);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_goodFeaturesToTrack_const__InputArrayR_const__OutputArrayR_int_double_double_const__InputArrayR_int_bool_double(image.as_raw__InputArray(), corners.as_raw__OutputArray(), max_corners, quality_level, min_distance, mask.as_raw__InputArray(), block_size, use_harris_detector, k, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// ## Note
	/// This alternative version of [good_features_to_track_with_gradient] function uses the following default values for its arguments:
	/// * use_harris_detector: false
	/// * k: 0.04
	#[inline]
	pub fn good_features_to_track_with_gradient_def(image: &impl core::ToInputArray, corners: &mut impl core::ToOutputArray, max_corners: i32, quality_level: f64, min_distance: f64, mask: &impl core::ToInputArray, block_size: i32, gradient_size: i32) -> Result<()> {
		input_array_arg!(image);
		output_array_arg!(corners);
		input_array_arg!(mask);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_goodFeaturesToTrack_const__InputArrayR_const__OutputArrayR_int_double_double_const__InputArrayR_int_int(image.as_raw__InputArray(), corners.as_raw__OutputArray(), max_corners, quality_level, min_distance, mask.as_raw__InputArray(), block_size, gradient_size, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// ## C++ default parameters
	/// * use_harris_detector: false
	/// * k: 0.04
	#[inline]
	pub fn good_features_to_track_with_gradient(image: &impl core::ToInputArray, corners: &mut impl core::ToOutputArray, max_corners: i32, quality_level: f64, min_distance: f64, mask: &impl core::ToInputArray, block_size: i32, gradient_size: i32, use_harris_detector: bool, k: f64) -> Result<()> {
		input_array_arg!(image);
		output_array_arg!(corners);
		input_array_arg!(mask);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_goodFeaturesToTrack_const__InputArrayR_const__OutputArrayR_int_double_double_const__InputArrayR_int_int_bool_double(image.as_raw__InputArray(), corners.as_raw__OutputArray(), max_corners, quality_level, min_distance, mask.as_raw__InputArray(), block_size, gradient_size, use_harris_detector, k, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Runs the GrabCut algorithm.
	/// 
	/// The function implements the [GrabCut image segmentation algorithm](http://en.wikipedia.org/wiki/GrabCut).
	/// 
	/// ## Parameters
	/// * img: Input 8-bit 3-channel image.
	/// * mask: Input/output 8-bit single-channel mask. The mask is initialized by the function when
	/// mode is set to #GC_INIT_WITH_RECT. Its elements may have one of the #GrabCutClasses.
	/// * rect: ROI containing a segmented object. The pixels outside of the ROI are marked as
	/// "obvious background". The parameter is only used when mode==[GC_INIT_WITH_RECT] .
	/// * bgdModel: Temporary array for the background model. Do not modify it while you are
	/// processing the same image.
	/// * fgdModel: Temporary arrays for the foreground model. Do not modify it while you are
	/// processing the same image.
	/// * iterCount: Number of iterations the algorithm should make before returning the result. Note
	/// that the result can be refined with further calls with mode==[GC_INIT_WITH_MASK] or
	/// mode==GC_EVAL .
	/// * mode: Operation mode that could be one of the [grab_cut_modes]
	/// 
	/// ## Note
	/// This alternative version of [grab_cut] function uses the following default values for its arguments:
	/// * mode: GC_EVAL
	#[inline]
	pub fn grab_cut_def(img: &impl core::ToInputArray, mask: &mut impl core::ToInputOutputArray, rect: core::Rect, bgd_model: &mut impl core::ToInputOutputArray, fgd_model: &mut impl core::ToInputOutputArray, iter_count: i32) -> Result<()> {
		input_array_arg!(img);
		input_output_array_arg!(mask);
		input_output_array_arg!(bgd_model);
		input_output_array_arg!(fgd_model);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_grabCut_const__InputArrayR_const__InputOutputArrayR_Rect_const__InputOutputArrayR_const__InputOutputArrayR_int(img.as_raw__InputArray(), mask.as_raw__InputOutputArray(), rect.opencv_as_extern(), bgd_model.as_raw__InputOutputArray(), fgd_model.as_raw__InputOutputArray(), iter_count, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Runs the GrabCut algorithm.
	/// 
	/// The function implements the [GrabCut image segmentation algorithm](http://en.wikipedia.org/wiki/GrabCut).
	/// 
	/// ## Parameters
	/// * img: Input 8-bit 3-channel image.
	/// * mask: Input/output 8-bit single-channel mask. The mask is initialized by the function when
	/// mode is set to #GC_INIT_WITH_RECT. Its elements may have one of the #GrabCutClasses.
	/// * rect: ROI containing a segmented object. The pixels outside of the ROI are marked as
	/// "obvious background". The parameter is only used when mode==[GC_INIT_WITH_RECT] .
	/// * bgdModel: Temporary array for the background model. Do not modify it while you are
	/// processing the same image.
	/// * fgdModel: Temporary arrays for the foreground model. Do not modify it while you are
	/// processing the same image.
	/// * iterCount: Number of iterations the algorithm should make before returning the result. Note
	/// that the result can be refined with further calls with mode==[GC_INIT_WITH_MASK] or
	/// mode==GC_EVAL .
	/// * mode: Operation mode that could be one of the #GrabCutModes
	/// 
	/// ## C++ default parameters
	/// * mode: GC_EVAL
	#[inline]
	pub fn grab_cut(img: &impl core::ToInputArray, mask: &mut impl core::ToInputOutputArray, rect: core::Rect, bgd_model: &mut impl core::ToInputOutputArray, fgd_model: &mut impl core::ToInputOutputArray, iter_count: i32, mode: i32) -> Result<()> {
		input_array_arg!(img);
		input_output_array_arg!(mask);
		input_output_array_arg!(bgd_model);
		input_output_array_arg!(fgd_model);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_grabCut_const__InputArrayR_const__InputOutputArrayR_Rect_const__InputOutputArrayR_const__InputOutputArrayR_int_int(img.as_raw__InputArray(), mask.as_raw__InputOutputArray(), rect.opencv_as_extern(), bgd_model.as_raw__InputOutputArray(), fgd_model.as_raw__InputOutputArray(), iter_count, mode, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// @overload
	/// 
	/// ## Note
	/// This alternative version of [integral] function uses the following default values for its arguments:
	/// * sdepth: -1
	#[inline]
	pub fn integral_def(src: &impl core::ToInputArray, sum: &mut impl core::ToOutputArray) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(sum);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_integral_const__InputArrayR_const__OutputArrayR(src.as_raw__InputArray(), sum.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// @overload
	/// 
	/// ## Note
	/// This alternative version of [integral2] function uses the following default values for its arguments:
	/// * sdepth: -1
	/// * sqdepth: -1
	#[inline]
	pub fn integral2_def(src: &impl core::ToInputArray, sum: &mut impl core::ToOutputArray, sqsum: &mut impl core::ToOutputArray) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(sum);
		output_array_arg!(sqsum);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_integral_const__InputArrayR_const__OutputArrayR_const__OutputArrayR(src.as_raw__InputArray(), sum.as_raw__OutputArray(), sqsum.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates the integral of an image.
	/// 
	/// The function calculates one or more integral images for the source image as follows:
	/// 
	/// 
	/// 
	/// 
	/// 
	/// 
	/// 
	/// Using these integral images, you can calculate sum, mean, and standard deviation over a specific
	/// up-right or rotated rectangular region of the image in a constant time, for example:
	/// 
	/// 
	/// 
	/// It makes possible to do a fast blurring or fast block correlation with a variable window size, for
	/// example. In case of multi-channel images, sums for each channel are accumulated independently.
	/// 
	/// As a practical example, the next figure shows the calculation of the integral of a straight
	/// rectangle Rect(4,4,3,2) and of a tilted rectangle Rect(5,1,2,3) . The selected pixels in the
	/// original image are shown, as well as the relative pixels in the integral images sum and tilted .
	/// 
	/// 
	/// 
	/// ## Parameters
	/// * src: input image as , 8-bit or floating-point (32f or 64f).
	/// * sum: integral image as  , 32-bit integer or floating-point (32f or 64f).
	/// * sqsum: integral image for squared pixel values; it is , double-precision
	/// floating-point (64f) array.
	/// * tilted: integral for the image rotated by 45 degrees; it is  array with
	/// the same data type as sum.
	/// * sdepth: desired depth of the integral and the tilted integral images, CV_32S, CV_32F, or
	/// CV_64F.
	/// * sqdepth: desired depth of the integral image of squared pixel values, CV_32F or CV_64F.
	/// 
	/// ## Note
	/// This alternative version of [integral3] function uses the following default values for its arguments:
	/// * sdepth: -1
	/// * sqdepth: -1
	#[inline]
	pub fn integral3_def(src: &impl core::ToInputArray, sum: &mut impl core::ToOutputArray, sqsum: &mut impl core::ToOutputArray, tilted: &mut impl core::ToOutputArray) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(sum);
		output_array_arg!(sqsum);
		output_array_arg!(tilted);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_integral_const__InputArrayR_const__OutputArrayR_const__OutputArrayR_const__OutputArrayR(src.as_raw__InputArray(), sum.as_raw__OutputArray(), sqsum.as_raw__OutputArray(), tilted.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates the integral of an image.
	/// 
	/// The function calculates one or more integral images for the source image as follows:
	/// 
	/// 
	/// 
	/// 
	/// 
	/// 
	/// 
	/// Using these integral images, you can calculate sum, mean, and standard deviation over a specific
	/// up-right or rotated rectangular region of the image in a constant time, for example:
	/// 
	/// 
	/// 
	/// It makes possible to do a fast blurring or fast block correlation with a variable window size, for
	/// example. In case of multi-channel images, sums for each channel are accumulated independently.
	/// 
	/// As a practical example, the next figure shows the calculation of the integral of a straight
	/// rectangle Rect(4,4,3,2) and of a tilted rectangle Rect(5,1,2,3) . The selected pixels in the
	/// original image are shown, as well as the relative pixels in the integral images sum and tilted .
	/// 
	/// 
	/// 
	/// ## Parameters
	/// * src: input image as , 8-bit or floating-point (32f or 64f).
	/// * sum: integral image as  , 32-bit integer or floating-point (32f or 64f).
	/// * sqsum: integral image for squared pixel values; it is , double-precision
	/// floating-point (64f) array.
	/// * tilted: integral for the image rotated by 45 degrees; it is  array with
	/// the same data type as sum.
	/// * sdepth: desired depth of the integral and the tilted integral images, CV_32S, CV_32F, or
	/// CV_64F.
	/// * sqdepth: desired depth of the integral image of squared pixel values, CV_32F or CV_64F.
	/// 
	/// ## C++ default parameters
	/// * sdepth: -1
	/// * sqdepth: -1
	#[inline]
	pub fn integral3(src: &impl core::ToInputArray, sum: &mut impl core::ToOutputArray, sqsum: &mut impl core::ToOutputArray, tilted: &mut impl core::ToOutputArray, sdepth: i32, sqdepth: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(sum);
		output_array_arg!(sqsum);
		output_array_arg!(tilted);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_integral_const__InputArrayR_const__OutputArrayR_const__OutputArrayR_const__OutputArrayR_int_int(src.as_raw__InputArray(), sum.as_raw__OutputArray(), sqsum.as_raw__OutputArray(), tilted.as_raw__OutputArray(), sdepth, sqdepth, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates the integral of an image.
	/// 
	/// The function calculates one or more integral images for the source image as follows:
	/// 
	/// 
	/// 
	/// 
	/// 
	/// 
	/// 
	/// Using these integral images, you can calculate sum, mean, and standard deviation over a specific
	/// up-right or rotated rectangular region of the image in a constant time, for example:
	/// 
	/// 
	/// 
	/// It makes possible to do a fast blurring or fast block correlation with a variable window size, for
	/// example. In case of multi-channel images, sums for each channel are accumulated independently.
	/// 
	/// As a practical example, the next figure shows the calculation of the integral of a straight
	/// rectangle Rect(4,4,3,2) and of a tilted rectangle Rect(5,1,2,3) . The selected pixels in the
	/// original image are shown, as well as the relative pixels in the integral images sum and tilted .
	/// 
	/// 
	/// 
	/// ## Parameters
	/// * src: input image as , 8-bit or floating-point (32f or 64f).
	/// * sum: integral image as  , 32-bit integer or floating-point (32f or 64f).
	/// * sqsum: integral image for squared pixel values; it is , double-precision
	/// floating-point (64f) array.
	/// * tilted: integral for the image rotated by 45 degrees; it is  array with
	/// the same data type as sum.
	/// * sdepth: desired depth of the integral and the tilted integral images, CV_32S, CV_32F, or
	/// CV_64F.
	/// * sqdepth: desired depth of the integral image of squared pixel values, CV_32F or CV_64F.
	/// 
	/// ## Overloaded parameters
	/// 
	/// ## C++ default parameters
	/// * sdepth: -1
	/// * sqdepth: -1
	#[inline]
	pub fn integral2(src: &impl core::ToInputArray, sum: &mut impl core::ToOutputArray, sqsum: &mut impl core::ToOutputArray, sdepth: i32, sqdepth: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(sum);
		output_array_arg!(sqsum);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_integral_const__InputArrayR_const__OutputArrayR_const__OutputArrayR_int_int(src.as_raw__InputArray(), sum.as_raw__OutputArray(), sqsum.as_raw__OutputArray(), sdepth, sqdepth, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates the integral of an image.
	/// 
	/// The function calculates one or more integral images for the source image as follows:
	/// 
	/// 
	/// 
	/// 
	/// 
	/// 
	/// 
	/// Using these integral images, you can calculate sum, mean, and standard deviation over a specific
	/// up-right or rotated rectangular region of the image in a constant time, for example:
	/// 
	/// 
	/// 
	/// It makes possible to do a fast blurring or fast block correlation with a variable window size, for
	/// example. In case of multi-channel images, sums for each channel are accumulated independently.
	/// 
	/// As a practical example, the next figure shows the calculation of the integral of a straight
	/// rectangle Rect(4,4,3,2) and of a tilted rectangle Rect(5,1,2,3) . The selected pixels in the
	/// original image are shown, as well as the relative pixels in the integral images sum and tilted .
	/// 
	/// 
	/// 
	/// ## Parameters
	/// * src: input image as , 8-bit or floating-point (32f or 64f).
	/// * sum: integral image as  , 32-bit integer or floating-point (32f or 64f).
	/// * sqsum: integral image for squared pixel values; it is , double-precision
	/// floating-point (64f) array.
	/// * tilted: integral for the image rotated by 45 degrees; it is  array with
	/// the same data type as sum.
	/// * sdepth: desired depth of the integral and the tilted integral images, CV_32S, CV_32F, or
	/// CV_64F.
	/// * sqdepth: desired depth of the integral image of squared pixel values, CV_32F or CV_64F.
	/// 
	/// ## Overloaded parameters
	/// 
	/// ## C++ default parameters
	/// * sdepth: -1
	#[inline]
	pub fn integral(src: &impl core::ToInputArray, sum: &mut impl core::ToOutputArray, sdepth: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(sum);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_integral_const__InputArrayR_const__OutputArrayR_int(src.as_raw__InputArray(), sum.as_raw__OutputArray(), sdepth, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Finds intersection of two convex polygons
	/// 
	/// ## Parameters
	/// * p1: First polygon
	/// * p2: Second polygon
	/// * p12: Output polygon describing the intersecting area
	/// * handleNested: When true, an intersection is found if one of the polygons is fully enclosed in the other.
	/// When false, no intersection is found. If the polygons share a side or the vertex of one polygon lies on an edge
	/// of the other, they are not considered nested and an intersection will be found regardless of the value of handleNested.
	/// 
	/// ## Returns
	/// Absolute value of area of intersecting polygon
	/// 
	/// 
	/// Note: intersectConvexConvex doesn't confirm that both polygons are convex and will return invalid results if they aren't.
	/// 
	/// ## Note
	/// This alternative version of [intersect_convex_convex] function uses the following default values for its arguments:
	/// * handle_nested: true
	#[inline]
	pub fn intersect_convex_convex_def(p1: &impl core::ToInputArray, p2: &impl core::ToInputArray, p12: &mut impl core::ToOutputArray) -> Result<f32> {
		input_array_arg!(p1);
		input_array_arg!(p2);
		output_array_arg!(p12);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_intersectConvexConvex_const__InputArrayR_const__InputArrayR_const__OutputArrayR(p1.as_raw__InputArray(), p2.as_raw__InputArray(), p12.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Finds intersection of two convex polygons
	/// 
	/// ## Parameters
	/// * p1: First polygon
	/// * p2: Second polygon
	/// * p12: Output polygon describing the intersecting area
	/// * handleNested: When true, an intersection is found if one of the polygons is fully enclosed in the other.
	/// When false, no intersection is found. If the polygons share a side or the vertex of one polygon lies on an edge
	/// of the other, they are not considered nested and an intersection will be found regardless of the value of handleNested.
	/// 
	/// ## Returns
	/// Absolute value of area of intersecting polygon
	/// 
	/// 
	/// Note: intersectConvexConvex doesn't confirm that both polygons are convex and will return invalid results if they aren't.
	/// 
	/// ## C++ default parameters
	/// * handle_nested: true
	#[inline]
	pub fn intersect_convex_convex(p1: &impl core::ToInputArray, p2: &impl core::ToInputArray, p12: &mut impl core::ToOutputArray, handle_nested: bool) -> Result<f32> {
		input_array_arg!(p1);
		input_array_arg!(p2);
		output_array_arg!(p12);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_intersectConvexConvex_const__InputArrayR_const__InputArrayR_const__OutputArrayR_bool(p1.as_raw__InputArray(), p2.as_raw__InputArray(), p12.as_raw__OutputArray(), handle_nested, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Inverts an affine transformation.
	/// 
	/// The function computes an inverse affine transformation represented by  matrix M:
	/// 
	/// 
	/// 
	/// The result is also a  matrix of the same type as M.
	/// 
	/// ## Parameters
	/// * M: Original affine transformation.
	/// * iM: Output reverse affine transformation.
	#[inline]
	pub fn invert_affine_transform(m: &impl core::ToInputArray, i_m: &mut impl core::ToOutputArray) -> Result<()> {
		input_array_arg!(m);
		output_array_arg!(i_m);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_invertAffineTransform_const__InputArrayR_const__OutputArrayR(m.as_raw__InputArray(), i_m.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Tests a contour convexity.
	/// 
	/// The function tests whether the input contour is convex or not. The contour must be simple, that is,
	/// without self-intersections. Otherwise, the function output is undefined.
	/// 
	/// ## Parameters
	/// * contour: Input vector of 2D points, stored in std::vector\<\> or Mat
	#[inline]
	pub fn is_contour_convex(contour: &impl core::ToInputArray) -> Result<bool> {
		input_array_arg!(contour);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_isContourConvex_const__InputArrayR(contour.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Draws a line segment connecting two points.
	/// 
	/// The function line draws the line segment between pt1 and pt2 points in the image. The line is
	/// clipped by the image boundaries. For non-antialiased lines with integer coordinates, the 8-connected
	/// or 4-connected Bresenham algorithm is used. Thick lines are drawn with rounding endings. Antialiased
	/// lines are drawn using Gaussian filtering.
	/// 
	/// ## Parameters
	/// * img: Image.
	/// * pt1: First point of the line segment.
	/// * pt2: Second point of the line segment.
	/// * color: Line color.
	/// * thickness: Line thickness.
	/// * lineType: Type of the line. See #LineTypes.
	/// * shift: Number of fractional bits in the point coordinates.
	/// 
	/// ## Note
	/// This alternative version of [line] function uses the following default values for its arguments:
	/// * thickness: 1
	/// * line_type: LINE_8
	/// * shift: 0
	#[inline]
	pub fn line_def(img: &mut impl core::ToInputOutputArray, pt1: core::Point, pt2: core::Point, color: core::Scalar) -> Result<()> {
		input_output_array_arg!(img);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_line_const__InputOutputArrayR_Point_Point_const_ScalarR(img.as_raw__InputOutputArray(), pt1.opencv_as_extern(), pt2.opencv_as_extern(), &color, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Draws a line segment connecting two points.
	/// 
	/// The function line draws the line segment between pt1 and pt2 points in the image. The line is
	/// clipped by the image boundaries. For non-antialiased lines with integer coordinates, the 8-connected
	/// or 4-connected Bresenham algorithm is used. Thick lines are drawn with rounding endings. Antialiased
	/// lines are drawn using Gaussian filtering.
	/// 
	/// ## Parameters
	/// * img: Image.
	/// * pt1: First point of the line segment.
	/// * pt2: Second point of the line segment.
	/// * color: Line color.
	/// * thickness: Line thickness.
	/// * lineType: Type of the line. See #LineTypes.
	/// * shift: Number of fractional bits in the point coordinates.
	/// 
	/// ## C++ default parameters
	/// * thickness: 1
	/// * line_type: LINE_8
	/// * shift: 0
	#[inline]
	pub fn line(img: &mut impl core::ToInputOutputArray, pt1: core::Point, pt2: core::Point, color: core::Scalar, thickness: i32, line_type: i32, shift: i32) -> Result<()> {
		input_output_array_arg!(img);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_line_const__InputOutputArrayR_Point_Point_const_ScalarR_int_int_int(img.as_raw__InputOutputArray(), pt1.opencv_as_extern(), pt2.opencv_as_extern(), &color, thickness, line_type, shift, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Remaps an image to polar coordinates space.
	/// 
	/// 
	/// **Deprecated**: This function produces same result as cv::warpPolar(src, dst, src.size(), center, maxRadius, flags)
	/// 
	/// @internal
	/// Transform the source image using the following transformation (See [polar_remaps_reference_image] "Polar remaps reference image c)"):
	/// 
	/// 
	/// where
	/// 
	/// 
	/// and
	/// 
	/// 
	/// 
	/// ## Parameters
	/// * src: Source image
	/// * dst: Destination image. It will have same size and type as src.
	/// * center: The transformation center;
	/// * maxRadius: The radius of the bounding circle to transform. It determines the inverse magnitude scale parameter too.
	/// * flags: A combination of interpolation methods, see [interpolation_flags]
	/// 
	/// 
	/// Note:
	/// *   The function can not operate in-place.
	/// *   To calculate magnitude and angle in degrees [cart_to_polar] is used internally thus angles are measured from 0 to 360 with accuracy about 0.3 degrees.
	/// ## See also
	/// cv::logPolar
	/// @endinternal
	#[deprecated = "This function produces same result as cv::warpPolar(src, dst, src.size(), center, maxRadius, flags)"]
	#[inline]
	pub fn linear_polar(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, center: core::Point2f, max_radius: f64, flags: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_linearPolar_const__InputArrayR_const__OutputArrayR_Point2f_double_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), center.opencv_as_extern(), max_radius, flags, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Remaps an image to semilog-polar coordinates space.
	/// 
	/// 
	/// **Deprecated**: This function produces same result as cv::warpPolar(src, dst, src.size(), center, maxRadius, flags+WARP_POLAR_LOG);
	/// 
	/// @internal
	/// Transform the source image using the following transformation (See [polar_remaps_reference_image] "Polar remaps reference image d)"):
	/// 
	/// 
	/// where
	/// 
	/// 
	/// and
	/// 
	/// 
	/// The function emulates the human "foveal" vision and can be used for fast scale and
	/// rotation-invariant template matching, for object tracking and so forth.
	/// ## Parameters
	/// * src: Source image
	/// * dst: Destination image. It will have same size and type as src.
	/// * center: The transformation center; where the output precision is maximal
	/// * M: Magnitude scale parameter. It determines the radius of the bounding circle to transform too.
	/// * flags: A combination of interpolation methods, see [interpolation_flags]
	/// 
	/// 
	/// Note:
	/// *   The function can not operate in-place.
	/// *   To calculate magnitude and angle in degrees [cart_to_polar] is used internally thus angles are measured from 0 to 360 with accuracy about 0.3 degrees.
	/// ## See also
	/// cv::linearPolar
	/// @endinternal
	#[deprecated = "This function produces same result as cv::warpPolar(src, dst, src.size(), center, maxRadius, flags+WARP_POLAR_LOG);"]
	#[inline]
	pub fn log_polar(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, center: core::Point2f, m: f64, flags: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_logPolar_const__InputArrayR_const__OutputArrayR_Point2f_double_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), center.opencv_as_extern(), m, flags, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Compares two shapes.
	/// 
	/// The function compares two shapes. All three implemented methods use the Hu invariants (see #HuMoments)
	/// 
	/// ## Parameters
	/// * contour1: First contour or grayscale image.
	/// * contour2: Second contour or grayscale image.
	/// * method: Comparison method, see [shape_match_modes]
	/// * parameter: Method-specific parameter (not supported now).
	#[inline]
	pub fn match_shapes(contour1: &impl core::ToInputArray, contour2: &impl core::ToInputArray, method: i32, parameter: f64) -> Result<f64> {
		input_array_arg!(contour1);
		input_array_arg!(contour2);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_matchShapes_const__InputArrayR_const__InputArrayR_int_double(contour1.as_raw__InputArray(), contour2.as_raw__InputArray(), method, parameter, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Compares a template against overlapped image regions.
	/// 
	/// The function slides through image , compares the overlapped patches of size  against
	/// templ using the specified method and stores the comparison results in result . [template_match_modes]
	/// describes the formulae for the available comparison methods (  denotes image, 
	/// template,  result,  the optional mask ). The summation is done over template and/or
	/// the image patch: 
	/// 
	/// After the function finishes the comparison, the best matches can be found as global minimums (when
	/// [TM_SQDIFF] was used) or maximums (when [TM_CCORR] or [TM_CCOEFF] was used) using the
	/// [min_max_loc] function. In case of a color image, template summation in the numerator and each sum in
	/// the denominator is done over all of the channels and separate mean values are used for each channel.
	/// That is, the function can take a color template and a color image. The result will still be a
	/// single-channel image, which is easier to analyze.
	/// 
	/// ## Parameters
	/// * image: Image where the search is running. It must be 8-bit or 32-bit floating-point.
	/// * templ: Searched template. It must be not greater than the source image and have the same
	/// data type.
	/// * result: Map of comparison results. It must be single-channel 32-bit floating-point. If image
	/// is  and templ is  , then result is  .
	/// * method: Parameter specifying the comparison method, see [template_match_modes]
	/// * mask: Optional mask. It must have the same size as templ. It must either have the same number
	///            of channels as template or only one channel, which is then used for all template and
	///            image channels. If the data type is #CV_8U, the mask is interpreted as a binary mask,
	///            meaning only elements where mask is nonzero are used and are kept unchanged independent
	///            of the actual mask value (weight equals 1). For data tpye #CV_32F, the mask values are
	///            used as weights. The exact formulas are documented in #TemplateMatchModes.
	/// 
	/// ## Note
	/// This alternative version of [match_template] function uses the following default values for its arguments:
	/// * mask: noArray()
	#[inline]
	pub fn match_template_def(image: &impl core::ToInputArray, templ: &impl core::ToInputArray, result: &mut impl core::ToOutputArray, method: i32) -> Result<()> {
		input_array_arg!(image);
		input_array_arg!(templ);
		output_array_arg!(result);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_matchTemplate_const__InputArrayR_const__InputArrayR_const__OutputArrayR_int(image.as_raw__InputArray(), templ.as_raw__InputArray(), result.as_raw__OutputArray(), method, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Compares a template against overlapped image regions.
	/// 
	/// The function slides through image , compares the overlapped patches of size  against
	/// templ using the specified method and stores the comparison results in result . [template_match_modes]
	/// describes the formulae for the available comparison methods (  denotes image, 
	/// template,  result,  the optional mask ). The summation is done over template and/or
	/// the image patch: 
	/// 
	/// After the function finishes the comparison, the best matches can be found as global minimums (when
	/// [TM_SQDIFF] was used) or maximums (when [TM_CCORR] or [TM_CCOEFF] was used) using the
	/// [min_max_loc] function. In case of a color image, template summation in the numerator and each sum in
	/// the denominator is done over all of the channels and separate mean values are used for each channel.
	/// That is, the function can take a color template and a color image. The result will still be a
	/// single-channel image, which is easier to analyze.
	/// 
	/// ## Parameters
	/// * image: Image where the search is running. It must be 8-bit or 32-bit floating-point.
	/// * templ: Searched template. It must be not greater than the source image and have the same
	/// data type.
	/// * result: Map of comparison results. It must be single-channel 32-bit floating-point. If image
	/// is  and templ is  , then result is  .
	/// * method: Parameter specifying the comparison method, see [template_match_modes]
	/// * mask: Optional mask. It must have the same size as templ. It must either have the same number
	///            of channels as template or only one channel, which is then used for all template and
	///            image channels. If the data type is #CV_8U, the mask is interpreted as a binary mask,
	///            meaning only elements where mask is nonzero are used and are kept unchanged independent
	///            of the actual mask value (weight equals 1). For data tpye #CV_32F, the mask values are
	///            used as weights. The exact formulas are documented in #TemplateMatchModes.
	/// 
	/// ## C++ default parameters
	/// * mask: noArray()
	#[inline]
	pub fn match_template(image: &impl core::ToInputArray, templ: &impl core::ToInputArray, result: &mut impl core::ToOutputArray, method: i32, mask: &impl core::ToInputArray) -> Result<()> {
		input_array_arg!(image);
		input_array_arg!(templ);
		output_array_arg!(result);
		input_array_arg!(mask);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_matchTemplate_const__InputArrayR_const__InputArrayR_const__OutputArrayR_int_const__InputArrayR(image.as_raw__InputArray(), templ.as_raw__InputArray(), result.as_raw__OutputArray(), method, mask.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Blurs an image using the median filter.
	/// 
	/// The function smoothes an image using the median filter with the  aperture. Each channel of a multi-channel image is processed independently.
	/// In-place operation is supported.
	/// 
	/// 
	/// Note: The median filter uses [BORDER_REPLICATE] internally to cope with border pixels, see [border_types]
	/// 
	/// ## Parameters
	/// * src: input 1-, 3-, or 4-channel image; when ksize is 3 or 5, the image depth should be
	/// CV_8U, CV_16U, or CV_32F, for larger aperture sizes, it can only be CV_8U.
	/// * dst: destination array of the same size and type as src.
	/// * ksize: aperture linear size; it must be odd and greater than 1, for example: 3, 5, 7 ...
	/// ## See also
	/// bilateralFilter, blur, boxFilter, GaussianBlur
	#[inline]
	pub fn median_blur(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, ksize: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_medianBlur_const__InputArrayR_const__OutputArrayR_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), ksize, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Finds a rotated rectangle of the minimum area enclosing the input 2D point set.
	/// 
	/// The function calculates and returns the minimum-area bounding rectangle (possibly rotated) for a
	/// specified point set. Developer should keep in mind that the returned RotatedRect can contain negative
	/// indices when data is close to the containing Mat element boundary.
	/// 
	/// ## Parameters
	/// * points: Input vector of 2D points, stored in std::vector\<\> or Mat
	#[inline]
	pub fn min_area_rect(points: &impl core::ToInputArray) -> Result<core::RotatedRect> {
		input_array_arg!(points);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_minAreaRect_const__InputArrayR(points.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Finds a circle of the minimum area enclosing a 2D point set.
	/// 
	/// The function finds the minimal enclosing circle of a 2D point set using an iterative algorithm.
	/// 
	/// ## Parameters
	/// * points: Input vector of 2D points, stored in std::vector\<\> or Mat
	/// * center: Output center of the circle.
	/// * radius: Output radius of the circle.
	#[inline]
	pub fn min_enclosing_circle(points: &impl core::ToInputArray, center: &mut core::Point2f, radius: &mut f32) -> Result<()> {
		input_array_arg!(points);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_minEnclosingCircle_const__InputArrayR_Point2fR_floatR(points.as_raw__InputArray(), center, radius, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Finds a triangle of minimum area enclosing a 2D point set and returns its area.
	/// 
	/// The function finds a triangle of minimum area enclosing the given set of 2D points and returns its
	/// area. The output for a given 2D point set is shown in the image below. 2D points are depicted in
	/// *red* and the enclosing triangle in *yellow*.
	/// 
	/// 
	/// 
	/// The implementation of the algorithm is based on O'Rourke's [ORourke86](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_ORourke86) and Klee and Laskowski's
	/// [KleeLaskowski85](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_KleeLaskowski85) papers. O'Rourke provides a  algorithm for finding the minimal
	/// enclosing triangle of a 2D convex polygon with n vertices. Since the [min_enclosing_triangle] function
	/// takes a 2D point set as input an additional preprocessing step of computing the convex hull of the
	/// 2D point set is required. The complexity of the [convex_hull] function is  which is higher
	/// than . Thus the overall complexity of the function is .
	/// 
	/// ## Parameters
	/// * points: Input vector of 2D points with depth CV_32S or CV_32F, stored in std::vector\<\> or Mat
	/// * triangle: Output vector of three 2D points defining the vertices of the triangle. The depth
	/// of the OutputArray must be CV_32F.
	#[inline]
	pub fn min_enclosing_triangle(points: &impl core::ToInputArray, triangle: &mut impl core::ToOutputArray) -> Result<f64> {
		input_array_arg!(points);
		output_array_arg!(triangle);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_minEnclosingTriangle_const__InputArrayR_const__OutputArrayR(points.as_raw__InputArray(), triangle.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates all of the moments up to the third order of a polygon or rasterized shape.
	/// 
	/// The function computes moments, up to the 3rd order, of a vector shape or a rasterized shape. The
	/// results are returned in the structure cv::Moments.
	/// 
	/// ## Parameters
	/// * array: Raster image (single-channel, 8-bit or floating-point 2D array) or an array (
	///  or  ) of 2D points (Point or Point2f ).
	/// * binaryImage: If it is true, all non-zero image pixels are treated as 1's. The parameter is
	/// used for images only.
	/// ## Returns
	/// moments.
	/// 
	/// 
	/// Note: Only applicable to contour moments calculations from Python bindings: Note that the numpy
	/// type for the input array should be either np.int32 or np.float32.
	/// ## See also
	/// contourArea, arcLength
	/// 
	/// ## Note
	/// This alternative version of [moments] function uses the following default values for its arguments:
	/// * binary_image: false
	#[inline]
	pub fn moments_def(array: &impl core::ToInputArray) -> Result<core::Moments> {
		input_array_arg!(array);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_moments_const__InputArrayR(array.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates all of the moments up to the third order of a polygon or rasterized shape.
	/// 
	/// The function computes moments, up to the 3rd order, of a vector shape or a rasterized shape. The
	/// results are returned in the structure cv::Moments.
	/// 
	/// ## Parameters
	/// * array: Raster image (single-channel, 8-bit or floating-point 2D array) or an array (
	///  or  ) of 2D points (Point or Point2f ).
	/// * binaryImage: If it is true, all non-zero image pixels are treated as 1's. The parameter is
	/// used for images only.
	/// ## Returns
	/// moments.
	/// 
	/// 
	/// Note: Only applicable to contour moments calculations from Python bindings: Note that the numpy
	/// type for the input array should be either np.int32 or np.float32.
	/// ## See also
	/// contourArea, arcLength
	/// 
	/// ## C++ default parameters
	/// * binary_image: false
	#[inline]
	pub fn moments(array: &impl core::ToInputArray, binary_image: bool) -> Result<core::Moments> {
		input_array_arg!(array);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_moments_const__InputArrayR_bool(array.as_raw__InputArray(), binary_image, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// returns "magic" border value for erosion and dilation. It is automatically transformed to Scalar::all(-DBL_MAX) for dilation.
	#[inline]
	pub fn morphology_default_border_value() -> Result<core::Scalar> {
		return_send!(via ocvrs_return);
		unsafe { sys::cv_morphologyDefaultBorderValue(ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Performs advanced morphological transformations.
	/// 
	/// The function cv::morphologyEx can perform advanced morphological transformations using an erosion and dilation as
	/// basic operations.
	/// 
	/// Any of the operations can be done in-place. In case of multi-channel images, each channel is
	/// processed independently.
	/// 
	/// ## Parameters
	/// * src: Source image. The number of channels can be arbitrary. The depth should be one of
	/// CV_8U, CV_16U, CV_16S, CV_32F or CV_64F.
	/// * dst: Destination image of the same size and type as source image.
	/// * op: Type of a morphological operation, see [morph_types]
	/// * kernel: Structuring element. It can be created using #getStructuringElement.
	/// * anchor: Anchor position with the kernel. Negative values mean that the anchor is at the
	/// kernel center.
	/// * iterations: Number of times erosion and dilation are applied.
	/// * borderType: Pixel extrapolation method, see #BorderTypes. [BORDER_WRAP] is not supported.
	/// * borderValue: Border value in case of a constant border. The default value has a special
	/// meaning.
	/// ## See also
	/// dilate, erode, getStructuringElement
	/// 
	/// Note: The number of iterations is the number of times erosion or dilatation operation will be applied.
	/// For instance, an opening operation (#MORPH_OPEN) with two iterations is equivalent to apply
	/// successively: erode -> erode -> dilate -> dilate (and not erode -> dilate -> erode -> dilate).
	/// 
	/// ## Note
	/// This alternative version of [morphology_ex] function uses the following default values for its arguments:
	/// * anchor: Point(-1,-1)
	/// * iterations: 1
	/// * border_type: BORDER_CONSTANT
	/// * border_value: morphologyDefaultBorderValue()
	#[inline]
	pub fn morphology_ex_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, op: i32, kernel: &impl core::ToInputArray) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		input_array_arg!(kernel);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_morphologyEx_const__InputArrayR_const__OutputArrayR_int_const__InputArrayR(src.as_raw__InputArray(), dst.as_raw__OutputArray(), op, kernel.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Performs advanced morphological transformations.
	/// 
	/// The function cv::morphologyEx can perform advanced morphological transformations using an erosion and dilation as
	/// basic operations.
	/// 
	/// Any of the operations can be done in-place. In case of multi-channel images, each channel is
	/// processed independently.
	/// 
	/// ## Parameters
	/// * src: Source image. The number of channels can be arbitrary. The depth should be one of
	/// CV_8U, CV_16U, CV_16S, CV_32F or CV_64F.
	/// * dst: Destination image of the same size and type as source image.
	/// * op: Type of a morphological operation, see [morph_types]
	/// * kernel: Structuring element. It can be created using #getStructuringElement.
	/// * anchor: Anchor position with the kernel. Negative values mean that the anchor is at the
	/// kernel center.
	/// * iterations: Number of times erosion and dilation are applied.
	/// * borderType: Pixel extrapolation method, see #BorderTypes. [BORDER_WRAP] is not supported.
	/// * borderValue: Border value in case of a constant border. The default value has a special
	/// meaning.
	/// ## See also
	/// dilate, erode, getStructuringElement
	/// 
	/// Note: The number of iterations is the number of times erosion or dilatation operation will be applied.
	/// For instance, an opening operation (#MORPH_OPEN) with two iterations is equivalent to apply
	/// successively: erode -> erode -> dilate -> dilate (and not erode -> dilate -> erode -> dilate).
	/// 
	/// ## C++ default parameters
	/// * anchor: Point(-1,-1)
	/// * iterations: 1
	/// * border_type: BORDER_CONSTANT
	/// * border_value: morphologyDefaultBorderValue()
	#[inline]
	pub fn morphology_ex(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, op: i32, kernel: &impl core::ToInputArray, anchor: core::Point, iterations: i32, border_type: i32, border_value: core::Scalar) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		input_array_arg!(kernel);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_morphologyEx_const__InputArrayR_const__OutputArrayR_int_const__InputArrayR_Point_int_int_const_ScalarR(src.as_raw__InputArray(), dst.as_raw__OutputArray(), op, kernel.as_raw__InputArray(), anchor.opencv_as_extern(), iterations, border_type, &border_value, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// The function is used to detect translational shifts that occur between two images.
	/// 
	/// The operation takes advantage of the Fourier shift theorem for detecting the translational shift in
	/// the frequency domain. It can be used for fast image registration as well as motion estimation. For
	/// more information please see <http://en.wikipedia.org/wiki/Phase_correlation>
	/// 
	/// Calculates the cross-power spectrum of two supplied source arrays. The arrays are padded if needed
	/// with getOptimalDFTSize.
	/// 
	/// The function performs the following equations:
	/// - First it applies a Hanning window (see <http://en.wikipedia.org/wiki/Hann_function>) to each
	/// image to remove possible edge effects. This window is cached until the array size changes to speed
	/// up processing time.
	/// - Next it computes the forward DFTs of each source array:
	/// 
	/// where  is the forward DFT.
	/// - It then computes the cross-power spectrum of each frequency domain array:
	/// 
	/// - Next the cross-correlation is converted back into the time domain via the inverse DFT:
	/// 
	/// - Finally, it computes the peak location and computes a 5x5 weighted centroid around the peak to
	/// achieve sub-pixel accuracy.
	/// 
	/// - If non-zero, the response parameter is computed as the sum of the elements of r within the 5x5
	/// centroid around the peak location. It is normalized to a maximum of 1 (meaning there is a single
	/// peak) and will be smaller when there are multiple peaks.
	/// 
	/// ## Parameters
	/// * src1: Source floating point array (CV_32FC1 or CV_64FC1)
	/// * src2: Source floating point array (CV_32FC1 or CV_64FC1)
	/// * window: Floating point array with windowing coefficients to reduce edge effects (optional).
	/// * response: Signal power within the 5x5 centroid around the peak, between 0 and 1 (optional).
	/// ## Returns
	/// detected phase shift (sub-pixel) between the two arrays.
	/// ## See also
	/// dft, getOptimalDFTSize, idft, mulSpectrums createHanningWindow
	/// 
	/// ## Note
	/// This alternative version of [phase_correlate] function uses the following default values for its arguments:
	/// * window: noArray()
	/// * response: 0
	#[inline]
	pub fn phase_correlate_def(src1: &impl core::ToInputArray, src2: &impl core::ToInputArray) -> Result<core::Point2d> {
		input_array_arg!(src1);
		input_array_arg!(src2);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_phaseCorrelate_const__InputArrayR_const__InputArrayR(src1.as_raw__InputArray(), src2.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// The function is used to detect translational shifts that occur between two images.
	/// 
	/// The operation takes advantage of the Fourier shift theorem for detecting the translational shift in
	/// the frequency domain. It can be used for fast image registration as well as motion estimation. For
	/// more information please see <http://en.wikipedia.org/wiki/Phase_correlation>
	/// 
	/// Calculates the cross-power spectrum of two supplied source arrays. The arrays are padded if needed
	/// with getOptimalDFTSize.
	/// 
	/// The function performs the following equations:
	/// - First it applies a Hanning window (see <http://en.wikipedia.org/wiki/Hann_function>) to each
	/// image to remove possible edge effects. This window is cached until the array size changes to speed
	/// up processing time.
	/// - Next it computes the forward DFTs of each source array:
	/// 
	/// where  is the forward DFT.
	/// - It then computes the cross-power spectrum of each frequency domain array:
	/// 
	/// - Next the cross-correlation is converted back into the time domain via the inverse DFT:
	/// 
	/// - Finally, it computes the peak location and computes a 5x5 weighted centroid around the peak to
	/// achieve sub-pixel accuracy.
	/// 
	/// - If non-zero, the response parameter is computed as the sum of the elements of r within the 5x5
	/// centroid around the peak location. It is normalized to a maximum of 1 (meaning there is a single
	/// peak) and will be smaller when there are multiple peaks.
	/// 
	/// ## Parameters
	/// * src1: Source floating point array (CV_32FC1 or CV_64FC1)
	/// * src2: Source floating point array (CV_32FC1 or CV_64FC1)
	/// * window: Floating point array with windowing coefficients to reduce edge effects (optional).
	/// * response: Signal power within the 5x5 centroid around the peak, between 0 and 1 (optional).
	/// ## Returns
	/// detected phase shift (sub-pixel) between the two arrays.
	/// ## See also
	/// dft, getOptimalDFTSize, idft, mulSpectrums createHanningWindow
	/// 
	/// ## C++ default parameters
	/// * window: noArray()
	/// * response: 0
	#[inline]
	pub fn phase_correlate(src1: &impl core::ToInputArray, src2: &impl core::ToInputArray, window: &impl core::ToInputArray, response: &mut f64) -> Result<core::Point2d> {
		input_array_arg!(src1);
		input_array_arg!(src2);
		input_array_arg!(window);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_phaseCorrelate_const__InputArrayR_const__InputArrayR_const__InputArrayR_doubleX(src1.as_raw__InputArray(), src2.as_raw__InputArray(), window.as_raw__InputArray(), response, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Performs a point-in-contour test.
	/// 
	/// The function determines whether the point is inside a contour, outside, or lies on an edge (or
	/// coincides with a vertex). It returns positive (inside), negative (outside), or zero (on an edge)
	/// value, correspondingly. When measureDist=false , the return value is +1, -1, and 0, respectively.
	/// Otherwise, the return value is a signed distance between the point and the nearest contour edge.
	/// 
	/// See below a sample output of the function where each image pixel is tested against the contour:
	/// 
	/// 
	/// 
	/// ## Parameters
	/// * contour: Input contour.
	/// * pt: Point tested against the contour.
	/// * measureDist: If true, the function estimates the signed distance from the point to the
	/// nearest contour edge. Otherwise, the function only checks if the point is inside a contour or not.
	#[inline]
	pub fn point_polygon_test(contour: &impl core::ToInputArray, pt: core::Point2f, measure_dist: bool) -> Result<f64> {
		input_array_arg!(contour);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_pointPolygonTest_const__InputArrayR_Point2f_bool(contour.as_raw__InputArray(), pt.opencv_as_extern(), measure_dist, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Draws several polygonal curves.
	/// 
	/// ## Parameters
	/// * img: Image.
	/// * pts: Array of polygonal curves.
	/// * isClosed: Flag indicating whether the drawn polylines are closed or not. If they are closed,
	/// the function draws a line from the last vertex of each curve to its first vertex.
	/// * color: Polyline color.
	/// * thickness: Thickness of the polyline edges.
	/// * lineType: Type of the line segments. See [line_types]
	/// * shift: Number of fractional bits in the vertex coordinates.
	/// 
	/// The function cv::polylines draws one or more polygonal curves.
	/// 
	/// ## Note
	/// This alternative version of [polylines] function uses the following default values for its arguments:
	/// * thickness: 1
	/// * line_type: LINE_8
	/// * shift: 0
	#[inline]
	pub fn polylines_def(img: &mut impl core::ToInputOutputArray, pts: &impl core::ToInputArray, is_closed: bool, color: core::Scalar) -> Result<()> {
		input_output_array_arg!(img);
		input_array_arg!(pts);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_polylines_const__InputOutputArrayR_const__InputArrayR_bool_const_ScalarR(img.as_raw__InputOutputArray(), pts.as_raw__InputArray(), is_closed, &color, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Draws several polygonal curves.
	/// 
	/// ## Parameters
	/// * img: Image.
	/// * pts: Array of polygonal curves.
	/// * isClosed: Flag indicating whether the drawn polylines are closed or not. If they are closed,
	/// the function draws a line from the last vertex of each curve to its first vertex.
	/// * color: Polyline color.
	/// * thickness: Thickness of the polyline edges.
	/// * lineType: Type of the line segments. See [line_types]
	/// * shift: Number of fractional bits in the vertex coordinates.
	/// 
	/// The function cv::polylines draws one or more polygonal curves.
	/// 
	/// ## C++ default parameters
	/// * thickness: 1
	/// * line_type: LINE_8
	/// * shift: 0
	#[inline]
	pub fn polylines(img: &mut impl core::ToInputOutputArray, pts: &impl core::ToInputArray, is_closed: bool, color: core::Scalar, thickness: i32, line_type: i32, shift: i32) -> Result<()> {
		input_output_array_arg!(img);
		input_array_arg!(pts);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_polylines_const__InputOutputArrayR_const__InputArrayR_bool_const_ScalarR_int_int_int(img.as_raw__InputOutputArray(), pts.as_raw__InputArray(), is_closed, &color, thickness, line_type, shift, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates a feature map for corner detection.
	/// 
	/// The function calculates the complex spatial derivative-based function of the source image
	/// 
	/// 
	/// 
	/// where , are the first image derivatives, , are the second image
	/// derivatives, and  is the mixed derivative.
	/// 
	/// The corners can be found as local maximums of the functions, as shown below:
	/// ```C++
	///    Mat corners, dilated_corners;
	///    preCornerDetect(image, corners, 3);
	///    // dilation with 3x3 rectangular structuring element
	///    dilate(corners, dilated_corners, Mat(), 1);
	///    Mat corner_mask = corners == dilated_corners;
	/// ```
	/// 
	/// 
	/// ## Parameters
	/// * src: Source single-channel 8-bit of floating-point image.
	/// * dst: Output image that has the type CV_32F and the same size as src .
	/// * ksize: %Aperture size of the Sobel .
	/// * borderType: Pixel extrapolation method. See #BorderTypes. [BORDER_WRAP] is not supported.
	/// 
	/// ## Note
	/// This alternative version of [pre_corner_detect] function uses the following default values for its arguments:
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn pre_corner_detect_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, ksize: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_preCornerDetect_const__InputArrayR_const__OutputArrayR_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), ksize, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates a feature map for corner detection.
	/// 
	/// The function calculates the complex spatial derivative-based function of the source image
	/// 
	/// 
	/// 
	/// where , are the first image derivatives, , are the second image
	/// derivatives, and  is the mixed derivative.
	/// 
	/// The corners can be found as local maximums of the functions, as shown below:
	/// ```C++
	///    Mat corners, dilated_corners;
	///    preCornerDetect(image, corners, 3);
	///    // dilation with 3x3 rectangular structuring element
	///    dilate(corners, dilated_corners, Mat(), 1);
	///    Mat corner_mask = corners == dilated_corners;
	/// ```
	/// 
	/// 
	/// ## Parameters
	/// * src: Source single-channel 8-bit of floating-point image.
	/// * dst: Output image that has the type CV_32F and the same size as src .
	/// * ksize: %Aperture size of the Sobel .
	/// * borderType: Pixel extrapolation method. See #BorderTypes. [BORDER_WRAP] is not supported.
	/// 
	/// ## C++ default parameters
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn pre_corner_detect(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, ksize: i32, border_type: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_preCornerDetect_const__InputArrayR_const__OutputArrayR_int_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), ksize, border_type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Draws a text string.
	/// 
	/// The function cv::putText renders the specified text string in the image. Symbols that cannot be rendered
	/// using the specified font are replaced by question marks. See [get_text_size] for a text rendering code
	/// example.
	/// 
	/// ## Parameters
	/// * img: Image.
	/// * text: Text string to be drawn.
	/// * org: Bottom-left corner of the text string in the image.
	/// * fontFace: Font type, see #HersheyFonts.
	/// * fontScale: Font scale factor that is multiplied by the font-specific base size.
	/// * color: Text color.
	/// * thickness: Thickness of the lines used to draw a text.
	/// * lineType: Line type. See [line_types]
	/// * bottomLeftOrigin: When true, the image data origin is at the bottom-left corner. Otherwise,
	/// it is at the top-left corner.
	/// 
	/// ## Note
	/// This alternative version of [put_text] function uses the following default values for its arguments:
	/// * thickness: 1
	/// * line_type: LINE_8
	/// * bottom_left_origin: false
	#[inline]
	pub fn put_text_def(img: &mut impl core::ToInputOutputArray, text: &str, org: core::Point, font_face: i32, font_scale: f64, color: core::Scalar) -> Result<()> {
		input_output_array_arg!(img);
		extern_container_arg!(text);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_putText_const__InputOutputArrayR_const_StringR_Point_int_double_Scalar(img.as_raw__InputOutputArray(), text.opencv_as_extern(), org.opencv_as_extern(), font_face, font_scale, color.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Draws a text string.
	/// 
	/// The function cv::putText renders the specified text string in the image. Symbols that cannot be rendered
	/// using the specified font are replaced by question marks. See [get_text_size] for a text rendering code
	/// example.
	/// 
	/// ## Parameters
	/// * img: Image.
	/// * text: Text string to be drawn.
	/// * org: Bottom-left corner of the text string in the image.
	/// * fontFace: Font type, see #HersheyFonts.
	/// * fontScale: Font scale factor that is multiplied by the font-specific base size.
	/// * color: Text color.
	/// * thickness: Thickness of the lines used to draw a text.
	/// * lineType: Line type. See [line_types]
	/// * bottomLeftOrigin: When true, the image data origin is at the bottom-left corner. Otherwise,
	/// it is at the top-left corner.
	/// 
	/// ## C++ default parameters
	/// * thickness: 1
	/// * line_type: LINE_8
	/// * bottom_left_origin: false
	#[inline]
	pub fn put_text(img: &mut impl core::ToInputOutputArray, text: &str, org: core::Point, font_face: i32, font_scale: f64, color: core::Scalar, thickness: i32, line_type: i32, bottom_left_origin: bool) -> Result<()> {
		input_output_array_arg!(img);
		extern_container_arg!(text);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_putText_const__InputOutputArrayR_const_StringR_Point_int_double_Scalar_int_int_bool(img.as_raw__InputOutputArray(), text.opencv_as_extern(), org.opencv_as_extern(), font_face, font_scale, color.opencv_as_extern(), thickness, line_type, bottom_left_origin, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Blurs an image and downsamples it.
	/// 
	/// By default, size of the output image is computed as `Size((src.cols+1)/2, (src.rows+1)/2)`, but in
	/// any case, the following conditions should be satisfied:
	/// 
	/// 
	/// 
	/// The function performs the downsampling step of the Gaussian pyramid construction. First, it
	/// convolves the source image with the kernel:
	/// 
	/// 
	/// 
	/// Then, it downsamples the image by rejecting even rows and columns.
	/// 
	/// ## Parameters
	/// * src: input image.
	/// * dst: output image; it has the specified size and the same type as src.
	/// * dstsize: size of the output image.
	/// * borderType: Pixel extrapolation method, see [border_types] ([BORDER_CONSTANT] isn't supported)
	/// 
	/// ## Note
	/// This alternative version of [pyr_down] function uses the following default values for its arguments:
	/// * dstsize: Size()
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn pyr_down_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_pyrDown_const__InputArrayR_const__OutputArrayR(src.as_raw__InputArray(), dst.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Blurs an image and downsamples it.
	/// 
	/// By default, size of the output image is computed as `Size((src.cols+1)/2, (src.rows+1)/2)`, but in
	/// any case, the following conditions should be satisfied:
	/// 
	/// 
	/// 
	/// The function performs the downsampling step of the Gaussian pyramid construction. First, it
	/// convolves the source image with the kernel:
	/// 
	/// 
	/// 
	/// Then, it downsamples the image by rejecting even rows and columns.
	/// 
	/// ## Parameters
	/// * src: input image.
	/// * dst: output image; it has the specified size and the same type as src.
	/// * dstsize: size of the output image.
	/// * borderType: Pixel extrapolation method, see [border_types] ([BORDER_CONSTANT] isn't supported)
	/// 
	/// ## C++ default parameters
	/// * dstsize: Size()
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn pyr_down(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, dstsize: core::Size, border_type: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_pyrDown_const__InputArrayR_const__OutputArrayR_const_SizeR_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), &dstsize, border_type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Performs initial step of meanshift segmentation of an image.
	/// 
	/// The function implements the filtering stage of meanshift segmentation, that is, the output of the
	/// function is the filtered "posterized" image with color gradients and fine-grain texture flattened.
	/// At every pixel (X,Y) of the input image (or down-sized input image, see below) the function executes
	/// meanshift iterations, that is, the pixel (X,Y) neighborhood in the joint space-color hyperspace is
	/// considered:
	/// 
	/// 
	/// 
	/// where (R,G,B) and (r,g,b) are the vectors of color components at (X,Y) and (x,y), respectively
	/// (though, the algorithm does not depend on the color space used, so any 3-component color space can
	/// be used instead). Over the neighborhood the average spatial value (X',Y') and average color vector
	/// (R',G',B') are found and they act as the neighborhood center on the next iteration:
	/// 
	/// 
	/// 
	/// After the iterations over, the color components of the initial pixel (that is, the pixel from where
	/// the iterations started) are set to the final value (average color at the last iteration):
	/// 
	/// 
	/// 
	/// When maxLevel \> 0, the gaussian pyramid of maxLevel+1 levels is built, and the above procedure is
	/// run on the smallest layer first. After that, the results are propagated to the larger layer and the
	/// iterations are run again only on those pixels where the layer colors differ by more than sr from the
	/// lower-resolution layer of the pyramid. That makes boundaries of color regions sharper. Note that the
	/// results will be actually different from the ones obtained by running the meanshift procedure on the
	/// whole original image (i.e. when maxLevel==0).
	/// 
	/// ## Parameters
	/// * src: The source 8-bit, 3-channel image.
	/// * dst: The destination image of the same format and the same size as the source.
	/// * sp: The spatial window radius.
	/// * sr: The color window radius.
	/// * maxLevel: Maximum level of the pyramid for the segmentation.
	/// * termcrit: Termination criteria: when to stop meanshift iterations.
	/// 
	/// ## Note
	/// This alternative version of [pyr_mean_shift_filtering] function uses the following default values for its arguments:
	/// * max_level: 1
	/// * termcrit: TermCriteria(TermCriteria::MAX_ITER+TermCriteria::EPS,5,1)
	#[inline]
	pub fn pyr_mean_shift_filtering_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, sp: f64, sr: f64) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_pyrMeanShiftFiltering_const__InputArrayR_const__OutputArrayR_double_double(src.as_raw__InputArray(), dst.as_raw__OutputArray(), sp, sr, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Performs initial step of meanshift segmentation of an image.
	/// 
	/// The function implements the filtering stage of meanshift segmentation, that is, the output of the
	/// function is the filtered "posterized" image with color gradients and fine-grain texture flattened.
	/// At every pixel (X,Y) of the input image (or down-sized input image, see below) the function executes
	/// meanshift iterations, that is, the pixel (X,Y) neighborhood in the joint space-color hyperspace is
	/// considered:
	/// 
	/// 
	/// 
	/// where (R,G,B) and (r,g,b) are the vectors of color components at (X,Y) and (x,y), respectively
	/// (though, the algorithm does not depend on the color space used, so any 3-component color space can
	/// be used instead). Over the neighborhood the average spatial value (X',Y') and average color vector
	/// (R',G',B') are found and they act as the neighborhood center on the next iteration:
	/// 
	/// 
	/// 
	/// After the iterations over, the color components of the initial pixel (that is, the pixel from where
	/// the iterations started) are set to the final value (average color at the last iteration):
	/// 
	/// 
	/// 
	/// When maxLevel \> 0, the gaussian pyramid of maxLevel+1 levels is built, and the above procedure is
	/// run on the smallest layer first. After that, the results are propagated to the larger layer and the
	/// iterations are run again only on those pixels where the layer colors differ by more than sr from the
	/// lower-resolution layer of the pyramid. That makes boundaries of color regions sharper. Note that the
	/// results will be actually different from the ones obtained by running the meanshift procedure on the
	/// whole original image (i.e. when maxLevel==0).
	/// 
	/// ## Parameters
	/// * src: The source 8-bit, 3-channel image.
	/// * dst: The destination image of the same format and the same size as the source.
	/// * sp: The spatial window radius.
	/// * sr: The color window radius.
	/// * maxLevel: Maximum level of the pyramid for the segmentation.
	/// * termcrit: Termination criteria: when to stop meanshift iterations.
	/// 
	/// ## C++ default parameters
	/// * max_level: 1
	/// * termcrit: TermCriteria(TermCriteria::MAX_ITER+TermCriteria::EPS,5,1)
	#[inline]
	pub fn pyr_mean_shift_filtering(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, sp: f64, sr: f64, max_level: i32, termcrit: core::TermCriteria) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_pyrMeanShiftFiltering_const__InputArrayR_const__OutputArrayR_double_double_int_TermCriteria(src.as_raw__InputArray(), dst.as_raw__OutputArray(), sp, sr, max_level, termcrit.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Upsamples an image and then blurs it.
	/// 
	/// By default, size of the output image is computed as `Size(src.cols\*2, (src.rows\*2)`, but in any
	/// case, the following conditions should be satisfied:
	/// 
	/// 
	/// 
	/// The function performs the upsampling step of the Gaussian pyramid construction, though it can
	/// actually be used to construct the Laplacian pyramid. First, it upsamples the source image by
	/// injecting even zero rows and columns and then convolves the result with the same kernel as in
	/// pyrDown multiplied by 4.
	/// 
	/// ## Parameters
	/// * src: input image.
	/// * dst: output image. It has the specified size and the same type as src .
	/// * dstsize: size of the output image.
	/// * borderType: Pixel extrapolation method, see [border_types] (only [BORDER_DEFAULT] is supported)
	/// 
	/// ## Note
	/// This alternative version of [pyr_up] function uses the following default values for its arguments:
	/// * dstsize: Size()
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn pyr_up_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_pyrUp_const__InputArrayR_const__OutputArrayR(src.as_raw__InputArray(), dst.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Upsamples an image and then blurs it.
	/// 
	/// By default, size of the output image is computed as `Size(src.cols\*2, (src.rows\*2)`, but in any
	/// case, the following conditions should be satisfied:
	/// 
	/// 
	/// 
	/// The function performs the upsampling step of the Gaussian pyramid construction, though it can
	/// actually be used to construct the Laplacian pyramid. First, it upsamples the source image by
	/// injecting even zero rows and columns and then convolves the result with the same kernel as in
	/// pyrDown multiplied by 4.
	/// 
	/// ## Parameters
	/// * src: input image.
	/// * dst: output image. It has the specified size and the same type as src .
	/// * dstsize: size of the output image.
	/// * borderType: Pixel extrapolation method, see [border_types] (only [BORDER_DEFAULT] is supported)
	/// 
	/// ## C++ default parameters
	/// * dstsize: Size()
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn pyr_up(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, dstsize: core::Size, border_type: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_pyrUp_const__InputArrayR_const__OutputArrayR_const_SizeR_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), &dstsize, border_type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Draws a simple, thick, or filled up-right rectangle.
	/// 
	/// The function cv::rectangle draws a rectangle outline or a filled rectangle whose two opposite corners
	/// are pt1 and pt2.
	/// 
	/// ## Parameters
	/// * img: Image.
	/// * pt1: Vertex of the rectangle.
	/// * pt2: Vertex of the rectangle opposite to pt1 .
	/// * color: Rectangle color or brightness (grayscale image).
	/// * thickness: Thickness of lines that make up the rectangle. Negative values, like #FILLED,
	/// mean that the function has to draw a filled rectangle.
	/// * lineType: Type of the line. See [line_types]
	/// * shift: Number of fractional bits in the point coordinates.
	/// 
	/// ## Note
	/// This alternative version of [rectangle_points] function uses the following default values for its arguments:
	/// * thickness: 1
	/// * line_type: LINE_8
	/// * shift: 0
	#[inline]
	pub fn rectangle_points_def(img: &mut impl core::ToInputOutputArray, pt1: core::Point, pt2: core::Point, color: core::Scalar) -> Result<()> {
		input_output_array_arg!(img);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_rectangle_const__InputOutputArrayR_Point_Point_const_ScalarR(img.as_raw__InputOutputArray(), pt1.opencv_as_extern(), pt2.opencv_as_extern(), &color, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Draws a simple, thick, or filled up-right rectangle.
	/// 
	/// The function cv::rectangle draws a rectangle outline or a filled rectangle whose two opposite corners
	/// are pt1 and pt2.
	/// 
	/// ## Parameters
	/// * img: Image.
	/// * pt1: Vertex of the rectangle.
	/// * pt2: Vertex of the rectangle opposite to pt1 .
	/// * color: Rectangle color or brightness (grayscale image).
	/// * thickness: Thickness of lines that make up the rectangle. Negative values, like #FILLED,
	/// mean that the function has to draw a filled rectangle.
	/// * lineType: Type of the line. See [line_types]
	/// * shift: Number of fractional bits in the point coordinates.
	/// 
	/// ## C++ default parameters
	/// * thickness: 1
	/// * line_type: LINE_8
	/// * shift: 0
	#[inline]
	pub fn rectangle_points(img: &mut impl core::ToInputOutputArray, pt1: core::Point, pt2: core::Point, color: core::Scalar, thickness: i32, line_type: i32, shift: i32) -> Result<()> {
		input_output_array_arg!(img);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_rectangle_const__InputOutputArrayR_Point_Point_const_ScalarR_int_int_int(img.as_raw__InputOutputArray(), pt1.opencv_as_extern(), pt2.opencv_as_extern(), &color, thickness, line_type, shift, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// @overload
	/// 
	/// use `rec` parameter as alternative specification of the drawn rectangle: `r.tl() and
	/// r.br()-Point(1,1)` are opposite corners
	/// 
	/// ## Note
	/// This alternative version of [rectangle] function uses the following default values for its arguments:
	/// * thickness: 1
	/// * line_type: LINE_8
	/// * shift: 0
	#[inline]
	pub fn rectangle_def(img: &mut impl core::ToInputOutputArray, rec: core::Rect, color: core::Scalar) -> Result<()> {
		input_output_array_arg!(img);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_rectangle_const__InputOutputArrayR_Rect_const_ScalarR(img.as_raw__InputOutputArray(), rec.opencv_as_extern(), &color, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Draws a simple, thick, or filled up-right rectangle.
	/// 
	/// The function cv::rectangle draws a rectangle outline or a filled rectangle whose two opposite corners
	/// are pt1 and pt2.
	/// 
	/// ## Parameters
	/// * img: Image.
	/// * pt1: Vertex of the rectangle.
	/// * pt2: Vertex of the rectangle opposite to pt1 .
	/// * color: Rectangle color or brightness (grayscale image).
	/// * thickness: Thickness of lines that make up the rectangle. Negative values, like #FILLED,
	/// mean that the function has to draw a filled rectangle.
	/// * lineType: Type of the line. See [line_types]
	/// * shift: Number of fractional bits in the point coordinates.
	/// 
	/// ## Overloaded parameters
	/// 
	/// 
	/// use `rec` parameter as alternative specification of the drawn rectangle: `r.tl() and
	/// r.br()-Point(1,1)` are opposite corners
	/// 
	/// ## C++ default parameters
	/// * thickness: 1
	/// * line_type: LINE_8
	/// * shift: 0
	#[inline]
	pub fn rectangle(img: &mut impl core::ToInputOutputArray, rec: core::Rect, color: core::Scalar, thickness: i32, line_type: i32, shift: i32) -> Result<()> {
		input_output_array_arg!(img);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_rectangle_const__InputOutputArrayR_Rect_const_ScalarR_int_int_int(img.as_raw__InputOutputArray(), rec.opencv_as_extern(), &color, thickness, line_type, shift, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Applies a generic geometrical transformation to an image.
	/// 
	/// The function remap transforms the source image using the specified map:
	/// 
	/// 
	/// 
	/// where values of pixels with non-integer coordinates are computed using one of available
	/// interpolation methods.  and  can be encoded as separate floating-point maps
	/// in  and  respectively, or interleaved floating-point maps of  in
	/// , or fixed-point maps created by using #convertMaps. The reason you might want to
	/// convert from floating to fixed-point representations of a map is that they can yield much faster
	/// (\~2x) remapping operations. In the converted case,  contains pairs (cvFloor(x),
	/// cvFloor(y)) and  contains indices in a table of interpolation coefficients.
	/// 
	/// This function cannot operate in-place.
	/// 
	/// ## Parameters
	/// * src: Source image.
	/// * dst: Destination image. It has the same size as map1 and the same type as src .
	/// * map1: The first map of either (x,y) points or just x values having the type CV_16SC2 ,
	/// CV_32FC1, or CV_32FC2. See [convert_maps] for details on converting a floating point
	/// representation to fixed-point for speed.
	/// * map2: The second map of y values having the type CV_16UC1, CV_32FC1, or none (empty map
	/// if map1 is (x,y) points), respectively.
	/// * interpolation: Interpolation method (see #InterpolationFlags). The methods [INTER_AREA]
	/// and [INTER_LINEAR_EXACT] are not supported by this function.
	/// * borderMode: Pixel extrapolation method (see #BorderTypes). When
	/// borderMode=#BORDER_TRANSPARENT, it means that the pixels in the destination image that
	/// corresponds to the "outliers" in the source image are not modified by the function.
	/// * borderValue: Value used in case of a constant border. By default, it is 0.
	/// 
	/// Note:
	/// Due to current implementation limitations the size of an input and output images should be less than 32767x32767.
	/// 
	/// ## Note
	/// This alternative version of [remap] function uses the following default values for its arguments:
	/// * border_mode: BORDER_CONSTANT
	/// * border_value: Scalar()
	#[inline]
	pub fn remap_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, map1: &impl core::ToInputArray, map2: &impl core::ToInputArray, interpolation: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		input_array_arg!(map1);
		input_array_arg!(map2);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_remap_const__InputArrayR_const__OutputArrayR_const__InputArrayR_const__InputArrayR_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), map1.as_raw__InputArray(), map2.as_raw__InputArray(), interpolation, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Applies a generic geometrical transformation to an image.
	/// 
	/// The function remap transforms the source image using the specified map:
	/// 
	/// 
	/// 
	/// where values of pixels with non-integer coordinates are computed using one of available
	/// interpolation methods.  and  can be encoded as separate floating-point maps
	/// in  and  respectively, or interleaved floating-point maps of  in
	/// , or fixed-point maps created by using #convertMaps. The reason you might want to
	/// convert from floating to fixed-point representations of a map is that they can yield much faster
	/// (\~2x) remapping operations. In the converted case,  contains pairs (cvFloor(x),
	/// cvFloor(y)) and  contains indices in a table of interpolation coefficients.
	/// 
	/// This function cannot operate in-place.
	/// 
	/// ## Parameters
	/// * src: Source image.
	/// * dst: Destination image. It has the same size as map1 and the same type as src .
	/// * map1: The first map of either (x,y) points or just x values having the type CV_16SC2 ,
	/// CV_32FC1, or CV_32FC2. See [convert_maps] for details on converting a floating point
	/// representation to fixed-point for speed.
	/// * map2: The second map of y values having the type CV_16UC1, CV_32FC1, or none (empty map
	/// if map1 is (x,y) points), respectively.
	/// * interpolation: Interpolation method (see #InterpolationFlags). The methods [INTER_AREA]
	/// and [INTER_LINEAR_EXACT] are not supported by this function.
	/// * borderMode: Pixel extrapolation method (see #BorderTypes). When
	/// borderMode=#BORDER_TRANSPARENT, it means that the pixels in the destination image that
	/// corresponds to the "outliers" in the source image are not modified by the function.
	/// * borderValue: Value used in case of a constant border. By default, it is 0.
	/// 
	/// Note:
	/// Due to current implementation limitations the size of an input and output images should be less than 32767x32767.
	/// 
	/// ## C++ default parameters
	/// * border_mode: BORDER_CONSTANT
	/// * border_value: Scalar()
	#[inline]
	pub fn remap(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, map1: &impl core::ToInputArray, map2: &impl core::ToInputArray, interpolation: i32, border_mode: i32, border_value: core::Scalar) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		input_array_arg!(map1);
		input_array_arg!(map2);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_remap_const__InputArrayR_const__OutputArrayR_const__InputArrayR_const__InputArrayR_int_int_const_ScalarR(src.as_raw__InputArray(), dst.as_raw__OutputArray(), map1.as_raw__InputArray(), map2.as_raw__InputArray(), interpolation, border_mode, &border_value, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Resizes an image.
	/// 
	/// The function resize resizes the image src down to or up to the specified size. Note that the
	/// initial dst type or size are not taken into account. Instead, the size and type are derived from
	/// the `src`,`dsize`,`fx`, and `fy`. If you want to resize src so that it fits the pre-created dst,
	/// you may call the function as follows:
	/// ```C++
	///    // explicitly specify dsize=dst.size(); fx and fy will be computed from that.
	///    resize(src, dst, dst.size(), 0, 0, interpolation);
	/// ```
	/// 
	/// If you want to decimate the image by factor of 2 in each direction, you can call the function this
	/// way:
	/// ```C++
	///    // specify fx and fy and let the function compute the destination image size.
	///    resize(src, dst, Size(), 0.5, 0.5, interpolation);
	/// ```
	/// 
	/// To shrink an image, it will generally look best with [INTER_AREA] interpolation, whereas to
	/// enlarge an image, it will generally look best with [INTER_CUBIC] (slow) or [INTER_LINEAR]
	/// (faster but still looks OK).
	/// 
	/// ## Parameters
	/// * src: input image.
	/// * dst: output image; it has the size dsize (when it is non-zero) or the size computed from
	/// src.size(), fx, and fy; the type of dst is the same as of src.
	/// * dsize: output image size; if it equals zero (`None` in Python), it is computed as:
	///  
	///  Either dsize or both fx and fy must be non-zero.
	/// * fx: scale factor along the horizontal axis; when it equals 0, it is computed as
	/// 
	/// * fy: scale factor along the vertical axis; when it equals 0, it is computed as
	/// 
	/// * interpolation: interpolation method, see [interpolation_flags]
	/// ## See also
	/// warpAffine, warpPerspective, remap
	/// 
	/// ## Note
	/// This alternative version of [resize] function uses the following default values for its arguments:
	/// * fx: 0
	/// * fy: 0
	/// * interpolation: INTER_LINEAR
	#[inline]
	pub fn resize_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, dsize: core::Size) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_resize_const__InputArrayR_const__OutputArrayR_Size(src.as_raw__InputArray(), dst.as_raw__OutputArray(), dsize.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Resizes an image.
	/// 
	/// The function resize resizes the image src down to or up to the specified size. Note that the
	/// initial dst type or size are not taken into account. Instead, the size and type are derived from
	/// the `src`,`dsize`,`fx`, and `fy`. If you want to resize src so that it fits the pre-created dst,
	/// you may call the function as follows:
	/// ```C++
	///    // explicitly specify dsize=dst.size(); fx and fy will be computed from that.
	///    resize(src, dst, dst.size(), 0, 0, interpolation);
	/// ```
	/// 
	/// If you want to decimate the image by factor of 2 in each direction, you can call the function this
	/// way:
	/// ```C++
	///    // specify fx and fy and let the function compute the destination image size.
	///    resize(src, dst, Size(), 0.5, 0.5, interpolation);
	/// ```
	/// 
	/// To shrink an image, it will generally look best with [INTER_AREA] interpolation, whereas to
	/// enlarge an image, it will generally look best with [INTER_CUBIC] (slow) or [INTER_LINEAR]
	/// (faster but still looks OK).
	/// 
	/// ## Parameters
	/// * src: input image.
	/// * dst: output image; it has the size dsize (when it is non-zero) or the size computed from
	/// src.size(), fx, and fy; the type of dst is the same as of src.
	/// * dsize: output image size; if it equals zero (`None` in Python), it is computed as:
	///  
	///  Either dsize or both fx and fy must be non-zero.
	/// * fx: scale factor along the horizontal axis; when it equals 0, it is computed as
	/// 
	/// * fy: scale factor along the vertical axis; when it equals 0, it is computed as
	/// 
	/// * interpolation: interpolation method, see [interpolation_flags]
	/// ## See also
	/// warpAffine, warpPerspective, remap
	/// 
	/// ## C++ default parameters
	/// * fx: 0
	/// * fy: 0
	/// * interpolation: INTER_LINEAR
	#[inline]
	pub fn resize(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, dsize: core::Size, fx: f64, fy: f64, interpolation: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_resize_const__InputArrayR_const__OutputArrayR_Size_double_double_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), dsize.opencv_as_extern(), fx, fy, interpolation, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Finds out if there is any intersection between two rotated rectangles.
	/// 
	/// If there is then the vertices of the intersecting region are returned as well.
	/// 
	/// Below are some examples of intersection configurations. The hatched pattern indicates the
	/// intersecting region and the red vertices are returned by the function.
	/// 
	/// 
	/// 
	/// ## Parameters
	/// * rect1: First rectangle
	/// * rect2: Second rectangle
	/// * intersectingRegion: The output array of the vertices of the intersecting region. It returns
	/// at most 8 vertices. Stored as std::vector\<cv::Point2f\> or cv::Mat as Mx1 of type CV_32FC2.
	/// ## Returns
	/// One of #RectanglesIntersectTypes
	#[inline]
	pub fn rotated_rectangle_intersection(rect1: core::RotatedRect, rect2: core::RotatedRect, intersecting_region: &mut impl core::ToOutputArray) -> Result<i32> {
		output_array_arg!(intersecting_region);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_rotatedRectangleIntersection_const_RotatedRectR_const_RotatedRectR_const__OutputArrayR(&rect1, &rect2, intersecting_region.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Applies a separable linear filter to an image.
	/// 
	/// The function applies a separable linear filter to the image. That is, first, every row of src is
	/// filtered with the 1D kernel kernelX. Then, every column of the result is filtered with the 1D
	/// kernel kernelY. The final result shifted by delta is stored in dst .
	/// 
	/// ## Parameters
	/// * src: Source image.
	/// * dst: Destination image of the same size and the same number of channels as src .
	/// * ddepth: Destination image depth, see [filter_depths] "combinations"
	/// * kernelX: Coefficients for filtering each row.
	/// * kernelY: Coefficients for filtering each column.
	/// * anchor: Anchor position within the kernel. The default value  means that the anchor
	/// is at the kernel center.
	/// * delta: Value added to the filtered results before storing them.
	/// * borderType: Pixel extrapolation method, see #BorderTypes. [BORDER_WRAP] is not supported.
	/// ## See also
	/// filter2D, Sobel, GaussianBlur, boxFilter, blur
	/// 
	/// ## Note
	/// This alternative version of [sep_filter_2d] function uses the following default values for its arguments:
	/// * anchor: Point(-1,-1)
	/// * delta: 0
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn sep_filter_2d_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, ddepth: i32, kernel_x: &impl core::ToInputArray, kernel_y: &impl core::ToInputArray) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		input_array_arg!(kernel_x);
		input_array_arg!(kernel_y);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_sepFilter2D_const__InputArrayR_const__OutputArrayR_int_const__InputArrayR_const__InputArrayR(src.as_raw__InputArray(), dst.as_raw__OutputArray(), ddepth, kernel_x.as_raw__InputArray(), kernel_y.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Applies a separable linear filter to an image.
	/// 
	/// The function applies a separable linear filter to the image. That is, first, every row of src is
	/// filtered with the 1D kernel kernelX. Then, every column of the result is filtered with the 1D
	/// kernel kernelY. The final result shifted by delta is stored in dst .
	/// 
	/// ## Parameters
	/// * src: Source image.
	/// * dst: Destination image of the same size and the same number of channels as src .
	/// * ddepth: Destination image depth, see [filter_depths] "combinations"
	/// * kernelX: Coefficients for filtering each row.
	/// * kernelY: Coefficients for filtering each column.
	/// * anchor: Anchor position within the kernel. The default value  means that the anchor
	/// is at the kernel center.
	/// * delta: Value added to the filtered results before storing them.
	/// * borderType: Pixel extrapolation method, see #BorderTypes. [BORDER_WRAP] is not supported.
	/// ## See also
	/// filter2D, Sobel, GaussianBlur, boxFilter, blur
	/// 
	/// ## C++ default parameters
	/// * anchor: Point(-1,-1)
	/// * delta: 0
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn sep_filter_2d(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, ddepth: i32, kernel_x: &impl core::ToInputArray, kernel_y: &impl core::ToInputArray, anchor: core::Point, delta: f64, border_type: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		input_array_arg!(kernel_x);
		input_array_arg!(kernel_y);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_sepFilter2D_const__InputArrayR_const__OutputArrayR_int_const__InputArrayR_const__InputArrayR_Point_double_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), ddepth, kernel_x.as_raw__InputArray(), kernel_y.as_raw__InputArray(), anchor.opencv_as_extern(), delta, border_type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates the first order image derivative in both x and y using a Sobel operator
	/// 
	/// Equivalent to calling:
	/// 
	/// ```C++
	/// Sobel( src, dx, CV_16SC1, 1, 0, 3 );
	/// Sobel( src, dy, CV_16SC1, 0, 1, 3 );
	/// ```
	/// 
	/// 
	/// ## Parameters
	/// * src: input image.
	/// * dx: output image with first-order derivative in x.
	/// * dy: output image with first-order derivative in y.
	/// * ksize: size of Sobel kernel. It must be 3.
	/// * borderType: pixel extrapolation method, see #BorderTypes.
	///                   Only #BORDER_DEFAULT=[BORDER_REFLECT_101] and [BORDER_REPLICATE] are supported.
	/// ## See also
	/// Sobel
	/// 
	/// ## Note
	/// This alternative version of [spatial_gradient] function uses the following default values for its arguments:
	/// * ksize: 3
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn spatial_gradient_def(src: &impl core::ToInputArray, dx: &mut impl core::ToOutputArray, dy: &mut impl core::ToOutputArray) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dx);
		output_array_arg!(dy);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_spatialGradient_const__InputArrayR_const__OutputArrayR_const__OutputArrayR(src.as_raw__InputArray(), dx.as_raw__OutputArray(), dy.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates the first order image derivative in both x and y using a Sobel operator
	/// 
	/// Equivalent to calling:
	/// 
	/// ```C++
	/// Sobel( src, dx, CV_16SC1, 1, 0, 3 );
	/// Sobel( src, dy, CV_16SC1, 0, 1, 3 );
	/// ```
	/// 
	/// 
	/// ## Parameters
	/// * src: input image.
	/// * dx: output image with first-order derivative in x.
	/// * dy: output image with first-order derivative in y.
	/// * ksize: size of Sobel kernel. It must be 3.
	/// * borderType: pixel extrapolation method, see #BorderTypes.
	///                   Only #BORDER_DEFAULT=[BORDER_REFLECT_101] and [BORDER_REPLICATE] are supported.
	/// ## See also
	/// Sobel
	/// 
	/// ## C++ default parameters
	/// * ksize: 3
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn spatial_gradient(src: &impl core::ToInputArray, dx: &mut impl core::ToOutputArray, dy: &mut impl core::ToOutputArray, ksize: i32, border_type: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dx);
		output_array_arg!(dy);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_spatialGradient_const__InputArrayR_const__OutputArrayR_const__OutputArrayR_int_int(src.as_raw__InputArray(), dx.as_raw__OutputArray(), dy.as_raw__OutputArray(), ksize, border_type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates the normalized sum of squares of the pixel values overlapping the filter.
	/// 
	/// For every pixel  in the source image, the function calculates the sum of squares of those neighboring
	/// pixel values which overlap the filter placed over the pixel .
	/// 
	/// The unnormalized square box filter can be useful in computing local image statistics such as the local
	/// variance and standard deviation around the neighborhood of a pixel.
	/// 
	/// ## Parameters
	/// * src: input image
	/// * dst: output image of the same size and type as src
	/// * ddepth: the output image depth (-1 to use src.depth())
	/// * ksize: kernel size
	/// * anchor: kernel anchor point. The default value of Point(-1, -1) denotes that the anchor is at the kernel
	/// center.
	/// * normalize: flag, specifying whether the kernel is to be normalized by it's area or not.
	/// * borderType: border mode used to extrapolate pixels outside of the image, see #BorderTypes. [BORDER_WRAP] is not supported.
	/// ## See also
	/// boxFilter
	/// 
	/// ## Note
	/// This alternative version of [sqr_box_filter] function uses the following default values for its arguments:
	/// * anchor: Point(-1,-1)
	/// * normalize: true
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn sqr_box_filter_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, ddepth: i32, ksize: core::Size) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_sqrBoxFilter_const__InputArrayR_const__OutputArrayR_int_Size(src.as_raw__InputArray(), dst.as_raw__OutputArray(), ddepth, ksize.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Calculates the normalized sum of squares of the pixel values overlapping the filter.
	/// 
	/// For every pixel  in the source image, the function calculates the sum of squares of those neighboring
	/// pixel values which overlap the filter placed over the pixel .
	/// 
	/// The unnormalized square box filter can be useful in computing local image statistics such as the local
	/// variance and standard deviation around the neighborhood of a pixel.
	/// 
	/// ## Parameters
	/// * src: input image
	/// * dst: output image of the same size and type as src
	/// * ddepth: the output image depth (-1 to use src.depth())
	/// * ksize: kernel size
	/// * anchor: kernel anchor point. The default value of Point(-1, -1) denotes that the anchor is at the kernel
	/// center.
	/// * normalize: flag, specifying whether the kernel is to be normalized by it's area or not.
	/// * borderType: border mode used to extrapolate pixels outside of the image, see #BorderTypes. [BORDER_WRAP] is not supported.
	/// ## See also
	/// boxFilter
	/// 
	/// ## C++ default parameters
	/// * anchor: Point(-1,-1)
	/// * normalize: true
	/// * border_type: BORDER_DEFAULT
	#[inline]
	pub fn sqr_box_filter(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, ddepth: i32, ksize: core::Size, anchor: core::Point, normalize: bool, border_type: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_sqrBoxFilter_const__InputArrayR_const__OutputArrayR_int_Size_Point_bool_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), ddepth, ksize.opencv_as_extern(), anchor.opencv_as_extern(), normalize, border_type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Blurs an image using the stackBlur.
	/// 
	/// The function applies and stackBlur to an image.
	/// stackBlur can generate similar results as Gaussian blur, and the time consumption does not increase with the increase of kernel size.
	/// It creates a kind of moving stack of colors whilst scanning through the image. Thereby it just has to add one new block of color to the right side
	/// of the stack and remove the leftmost color. The remaining colors on the topmost layer of the stack are either added on or reduced by one,
	/// depending on if they are on the right or on the left side of the stack. The only supported borderType is BORDER_REPLICATE.
	/// Original paper was proposed by Mario Klingemann, which can be found <http://underdestruction.com/2004/02/25/stackblur-2004>.
	/// 
	/// ## Parameters
	/// * src: input image. The number of channels can be arbitrary, but the depth should be one of
	/// CV_8U, CV_16U, CV_16S or CV_32F.
	/// * dst: output image of the same size and type as src.
	/// * ksize: stack-blurring kernel size. The ksize.width and ksize.height can differ but they both must be
	/// positive and odd.
	#[inline]
	pub fn stack_blur(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, ksize: core::Size) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_stackBlur_const__InputArrayR_const__OutputArrayR_Size(src.as_raw__InputArray(), dst.as_raw__OutputArray(), ksize.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Applies a fixed-level threshold to each array element.
	/// 
	/// The function applies fixed-level thresholding to a multiple-channel array. The function is typically
	/// used to get a bi-level (binary) image out of a grayscale image ( [compare] could be also used for
	/// this purpose) or for removing a noise, that is, filtering out pixels with too small or too large
	/// values. There are several types of thresholding supported by the function. They are determined by
	/// type parameter.
	/// 
	/// Also, the special values [THRESH_OTSU] or [THRESH_TRIANGLE] may be combined with one of the
	/// above values. In these cases, the function determines the optimal threshold value using the Otsu's
	/// or Triangle algorithm and uses it instead of the specified thresh.
	/// 
	/// 
	/// Note: Currently, the Otsu's and Triangle methods are implemented only for 8-bit single-channel images.
	/// 
	/// ## Parameters
	/// * src: input array (multiple-channel, 8-bit or 32-bit floating point).
	/// * dst: output array of the same size  and type and the same number of channels as src.
	/// * thresh: threshold value.
	/// * maxval: maximum value to use with the [THRESH_BINARY] and [THRESH_BINARY_INV] thresholding
	/// types.
	/// * type: thresholding type (see #ThresholdTypes).
	/// ## Returns
	/// the computed threshold value if Otsu's or Triangle methods used.
	/// ## See also
	/// adaptiveThreshold, findContours, compare, min, max
	#[inline]
	pub fn threshold(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, thresh: f64, maxval: f64, typ: i32) -> Result<f64> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_threshold_const__InputArrayR_const__OutputArrayR_double_double_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), thresh, maxval, typ, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Applies an affine transformation to an image.
	/// 
	/// The function warpAffine transforms the source image using the specified matrix:
	/// 
	/// 
	/// 
	/// when the flag [WARP_INVERSE_MAP] is set. Otherwise, the transformation is first inverted
	/// with [invert_affine_transform] and then put in the formula above instead of M. The function cannot
	/// operate in-place.
	/// 
	/// ## Parameters
	/// * src: input image.
	/// * dst: output image that has the size dsize and the same type as src .
	/// * M:  transformation matrix.
	/// * dsize: size of the output image.
	/// * flags: combination of interpolation methods (see #InterpolationFlags) and the optional
	/// flag [WARP_INVERSE_MAP] that means that M is the inverse transformation (
	///  ).
	/// * borderMode: pixel extrapolation method (see #BorderTypes); when
	/// borderMode=#BORDER_TRANSPARENT, it means that the pixels in the destination image corresponding to
	/// the "outliers" in the source image are not modified by the function.
	/// * borderValue: value used in case of a constant border; by default, it is 0.
	/// ## See also
	/// warpPerspective, resize, remap, getRectSubPix, transform
	/// 
	/// ## Note
	/// This alternative version of [warp_affine] function uses the following default values for its arguments:
	/// * flags: INTER_LINEAR
	/// * border_mode: BORDER_CONSTANT
	/// * border_value: Scalar()
	#[inline]
	pub fn warp_affine_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, m: &impl core::ToInputArray, dsize: core::Size) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		input_array_arg!(m);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_warpAffine_const__InputArrayR_const__OutputArrayR_const__InputArrayR_Size(src.as_raw__InputArray(), dst.as_raw__OutputArray(), m.as_raw__InputArray(), dsize.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Applies an affine transformation to an image.
	/// 
	/// The function warpAffine transforms the source image using the specified matrix:
	/// 
	/// 
	/// 
	/// when the flag [WARP_INVERSE_MAP] is set. Otherwise, the transformation is first inverted
	/// with [invert_affine_transform] and then put in the formula above instead of M. The function cannot
	/// operate in-place.
	/// 
	/// ## Parameters
	/// * src: input image.
	/// * dst: output image that has the size dsize and the same type as src .
	/// * M:  transformation matrix.
	/// * dsize: size of the output image.
	/// * flags: combination of interpolation methods (see #InterpolationFlags) and the optional
	/// flag [WARP_INVERSE_MAP] that means that M is the inverse transformation (
	///  ).
	/// * borderMode: pixel extrapolation method (see #BorderTypes); when
	/// borderMode=#BORDER_TRANSPARENT, it means that the pixels in the destination image corresponding to
	/// the "outliers" in the source image are not modified by the function.
	/// * borderValue: value used in case of a constant border; by default, it is 0.
	/// ## See also
	/// warpPerspective, resize, remap, getRectSubPix, transform
	/// 
	/// ## C++ default parameters
	/// * flags: INTER_LINEAR
	/// * border_mode: BORDER_CONSTANT
	/// * border_value: Scalar()
	#[inline]
	pub fn warp_affine(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, m: &impl core::ToInputArray, dsize: core::Size, flags: i32, border_mode: i32, border_value: core::Scalar) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		input_array_arg!(m);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_warpAffine_const__InputArrayR_const__OutputArrayR_const__InputArrayR_Size_int_int_const_ScalarR(src.as_raw__InputArray(), dst.as_raw__OutputArray(), m.as_raw__InputArray(), dsize.opencv_as_extern(), flags, border_mode, &border_value, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Applies a perspective transformation to an image.
	/// 
	/// The function warpPerspective transforms the source image using the specified matrix:
	/// 
	/// 
	/// 
	/// when the flag [WARP_INVERSE_MAP] is set. Otherwise, the transformation is first inverted with invert
	/// and then put in the formula above instead of M. The function cannot operate in-place.
	/// 
	/// ## Parameters
	/// * src: input image.
	/// * dst: output image that has the size dsize and the same type as src .
	/// * M:  transformation matrix.
	/// * dsize: size of the output image.
	/// * flags: combination of interpolation methods ([INTER_LINEAR] or #INTER_NEAREST) and the
	/// optional flag #WARP_INVERSE_MAP, that sets M as the inverse transformation (
	///  ).
	/// * borderMode: pixel extrapolation method ([BORDER_CONSTANT] or #BORDER_REPLICATE).
	/// * borderValue: value used in case of a constant border; by default, it equals 0.
	/// ## See also
	/// warpAffine, resize, remap, getRectSubPix, perspectiveTransform
	/// 
	/// ## Note
	/// This alternative version of [warp_perspective] function uses the following default values for its arguments:
	/// * flags: INTER_LINEAR
	/// * border_mode: BORDER_CONSTANT
	/// * border_value: Scalar()
	#[inline]
	pub fn warp_perspective_def(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, m: &impl core::ToInputArray, dsize: core::Size) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		input_array_arg!(m);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_warpPerspective_const__InputArrayR_const__OutputArrayR_const__InputArrayR_Size(src.as_raw__InputArray(), dst.as_raw__OutputArray(), m.as_raw__InputArray(), dsize.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Applies a perspective transformation to an image.
	/// 
	/// The function warpPerspective transforms the source image using the specified matrix:
	/// 
	/// 
	/// 
	/// when the flag [WARP_INVERSE_MAP] is set. Otherwise, the transformation is first inverted with invert
	/// and then put in the formula above instead of M. The function cannot operate in-place.
	/// 
	/// ## Parameters
	/// * src: input image.
	/// * dst: output image that has the size dsize and the same type as src .
	/// * M:  transformation matrix.
	/// * dsize: size of the output image.
	/// * flags: combination of interpolation methods ([INTER_LINEAR] or #INTER_NEAREST) and the
	/// optional flag #WARP_INVERSE_MAP, that sets M as the inverse transformation (
	///  ).
	/// * borderMode: pixel extrapolation method ([BORDER_CONSTANT] or #BORDER_REPLICATE).
	/// * borderValue: value used in case of a constant border; by default, it equals 0.
	/// ## See also
	/// warpAffine, resize, remap, getRectSubPix, perspectiveTransform
	/// 
	/// ## C++ default parameters
	/// * flags: INTER_LINEAR
	/// * border_mode: BORDER_CONSTANT
	/// * border_value: Scalar()
	#[inline]
	pub fn warp_perspective(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, m: &impl core::ToInputArray, dsize: core::Size, flags: i32, border_mode: i32, border_value: core::Scalar) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		input_array_arg!(m);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_warpPerspective_const__InputArrayR_const__OutputArrayR_const__InputArrayR_Size_int_int_const_ScalarR(src.as_raw__InputArray(), dst.as_raw__OutputArray(), m.as_raw__InputArray(), dsize.opencv_as_extern(), flags, border_mode, &border_value, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// \brief Remaps an image to polar or semilog-polar coordinates space
	/// 
	/// @anchor polar_remaps_reference_image
	/// 
	/// 
	/// Transform the source image using the following transformation:
	/// 
	/// 
	/// where
	/// 
	/// 
	/// and
	/// 
	/// 
	/// 
	/// \par Linear vs semilog mapping
	/// 
	/// Polar mapping can be linear or semi-log. Add one of [warp_polar_mode] to `flags` to specify the polar mapping mode.
	/// 
	/// Linear is the default mode.
	/// 
	/// The semilog mapping emulates the human "foveal" vision that permit very high acuity on the line of sight (central vision)
	/// in contrast to peripheral vision where acuity is minor.
	/// 
	/// \par Option on `dsize`:
	/// 
	/// - if both values in `dsize <=0 ` (default),
	/// the destination image will have (almost) same area of source bounding circle:
	/// 
	/// 
	/// 
	/// - if only `dsize.height <= 0`,
	/// the destination image area will be proportional to the bounding circle area but scaled by `Kx * Kx`:
	/// 
	/// 
	/// - if both values in `dsize > 0 `,
	/// the destination image will have the given size therefore the area of the bounding circle will be scaled to `dsize`.
	/// 
	/// 
	/// \par Reverse mapping
	/// 
	/// You can get reverse mapping adding [WARP_INVERSE_MAP] to `flags`
	/// \snippet polar_transforms.cpp InverseMap
	/// 
	/// In addiction, to calculate the original coordinate from a polar mapped coordinate :
	/// \snippet polar_transforms.cpp InverseCoordinate
	/// 
	/// ## Parameters
	/// * src: Source image.
	/// * dst: Destination image. It will have same type as src.
	/// * dsize: The destination image size (see description for valid options).
	/// * center: The transformation center.
	/// * maxRadius: The radius of the bounding circle to transform. It determines the inverse magnitude scale parameter too.
	/// * flags: A combination of interpolation methods, [interpolation_flags] + #WarpPolarMode.
	///            - Add [WARP_POLAR_LINEAR] to select linear polar mapping (default)
	///            - Add [WARP_POLAR_LOG] to select semilog polar mapping
	///            - Add [WARP_INVERSE_MAP] for reverse mapping.
	/// 
	/// Note:
	/// *  The function can not operate in-place.
	/// *  To calculate magnitude and angle in degrees [cart_to_polar] is used internally thus angles are measured from 0 to 360 with accuracy about 0.3 degrees.
	/// *  This function uses #remap. Due to current implementation limitations the size of an input and output images should be less than 32767x32767.
	/// ## See also
	/// cv::remap
	#[inline]
	pub fn warp_polar(src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray, dsize: core::Size, center: core::Point2f, max_radius: f64, flags: i32) -> Result<()> {
		input_array_arg!(src);
		output_array_arg!(dst);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_warpPolar_const__InputArrayR_const__OutputArrayR_Size_Point2f_double_int(src.as_raw__InputArray(), dst.as_raw__OutputArray(), dsize.opencv_as_extern(), center.opencv_as_extern(), max_radius, flags, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Performs a marker-based image segmentation using the watershed algorithm.
	/// 
	/// The function implements one of the variants of watershed, non-parametric marker-based segmentation
	/// algorithm, described in [Meyer92](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Meyer92) .
	/// 
	/// Before passing the image to the function, you have to roughly outline the desired regions in the
	/// image markers with positive (\>0) indices. So, every region is represented as one or more connected
	/// components with the pixel values 1, 2, 3, and so on. Such markers can be retrieved from a binary
	/// mask using [find_contours] and [draw_contours] (see the watershed.cpp demo). The markers are "seeds" of
	/// the future image regions. All the other pixels in markers , whose relation to the outlined regions
	/// is not known and should be defined by the algorithm, should be set to 0's. In the function output,
	/// each pixel in markers is set to a value of the "seed" components or to -1 at boundaries between the
	/// regions.
	/// 
	/// 
	/// Note: Any two neighbor connected components are not necessarily separated by a watershed boundary
	/// (-1's pixels); for example, they can touch each other in the initial marker image passed to the
	/// function.
	/// 
	/// ## Parameters
	/// * image: Input 8-bit 3-channel image.
	/// * markers: Input/output 32-bit single-channel image (map) of markers. It should have the same
	/// size as image .
	/// ## See also
	/// findContours
	#[inline]
	pub fn watershed(image: &impl core::ToInputArray, markers: &mut impl core::ToInputOutputArray) -> Result<()> {
		input_array_arg!(image);
		input_output_array_arg!(markers);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_watershed_const__InputArrayR_const__InputOutputArrayR(image.as_raw__InputArray(), markers.as_raw__InputOutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// ## Note
	/// This alternative version of [emd_1] function uses the following default values for its arguments:
	/// * cost: noArray()
	/// * lower_bound: Ptr<float>()
	/// * flow: noArray()
	#[inline]
	pub fn emd_1_def(signature1: &impl core::ToInputArray, signature2: &impl core::ToInputArray, dist_type: i32) -> Result<f32> {
		input_array_arg!(signature1);
		input_array_arg!(signature2);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_wrapperEMD_const__InputArrayR_const__InputArrayR_int(signature1.as_raw__InputArray(), signature2.as_raw__InputArray(), dist_type, ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// ## C++ default parameters
	/// * cost: noArray()
	/// * lower_bound: Ptr<float>()
	/// * flow: noArray()
	#[inline]
	pub fn emd_1(signature1: &impl core::ToInputArray, signature2: &impl core::ToInputArray, dist_type: i32, cost: &impl core::ToInputArray, mut lower_bound: core::Ptr<f32>, flow: &mut impl core::ToOutputArray) -> Result<f32> {
		input_array_arg!(signature1);
		input_array_arg!(signature2);
		input_array_arg!(cost);
		output_array_arg!(flow);
		return_send!(via ocvrs_return);
		unsafe { sys::cv_wrapperEMD_const__InputArrayR_const__InputArrayR_int_const__InputArrayR_PtrLfloatG_const__OutputArrayR(signature1.as_raw__InputArray(), signature2.as_raw__InputArray(), dist_type, cost.as_raw__InputArray(), lower_bound.as_raw_mut_PtrOff32(), flow.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
		return_receive!(unsafe ocvrs_return => ret);
		let ret = ret.into_result()?;
		Ok(ret)
	}
	
	/// Constant methods for [crate::imgproc::CLAHE]
	pub trait CLAHETraitConst: core::AlgorithmTraitConst {
		fn as_raw_CLAHE(&self) -> *const c_void;
	
		/// Returns threshold value for contrast limiting.
		#[inline]
		fn get_clip_limit(&self) -> Result<f64> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_CLAHE_getClipLimit_const(self.as_raw_CLAHE(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Returns Size defines the number of tiles in row and column.
		#[inline]
		fn get_tiles_grid_size(&self) -> Result<core::Size> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_CLAHE_getTilesGridSize_const(self.as_raw_CLAHE(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
	}
	
	/// Mutable methods for [crate::imgproc::CLAHE]
	pub trait CLAHETrait: core::AlgorithmTrait + crate::imgproc::CLAHETraitConst {
		fn as_raw_mut_CLAHE(&mut self) -> *mut c_void;
	
		/// Equalizes the histogram of a grayscale image using Contrast Limited Adaptive Histogram Equalization.
		/// 
		/// ## Parameters
		/// * src: Source image of type CV_8UC1 or CV_16UC1.
		/// * dst: Destination image.
		#[inline]
		fn apply(&mut self, src: &impl core::ToInputArray, dst: &mut impl core::ToOutputArray) -> Result<()> {
			input_array_arg!(src);
			output_array_arg!(dst);
			return_send!(via ocvrs_return);
			unsafe { sys::cv_CLAHE_apply_const__InputArrayR_const__OutputArrayR(self.as_raw_mut_CLAHE(), src.as_raw__InputArray(), dst.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Sets threshold for contrast limiting.
		/// 
		/// ## Parameters
		/// * clipLimit: threshold value.
		#[inline]
		fn set_clip_limit(&mut self, clip_limit: f64) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_CLAHE_setClipLimit_double(self.as_raw_mut_CLAHE(), clip_limit, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Sets size of grid for histogram equalization. Input image will be divided into
		/// equally sized rectangular tiles.
		/// 
		/// ## Parameters
		/// * tileGridSize: defines the number of tiles in row and column.
		#[inline]
		fn set_tiles_grid_size(&mut self, tile_grid_size: core::Size) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_CLAHE_setTilesGridSize_Size(self.as_raw_mut_CLAHE(), tile_grid_size.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		#[inline]
		fn collect_garbage(&mut self) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_CLAHE_collectGarbage(self.as_raw_mut_CLAHE(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
	}
	
	/// Base class for Contrast Limited Adaptive Histogram Equalization.
	pub struct CLAHE {
		ptr: *mut c_void
	}
	
	opencv_type_boxed! { CLAHE }
	
	impl Drop for CLAHE {
		#[inline]
		fn drop(&mut self) {
			unsafe { sys::cv_CLAHE_delete(self.as_raw_mut_CLAHE()) };
		}
	}
	
	unsafe impl Send for CLAHE {}
	
	impl core::AlgorithmTraitConst for CLAHE {
		#[inline] fn as_raw_Algorithm(&self) -> *const c_void { self.as_raw() }
	}
	
	impl core::AlgorithmTrait for CLAHE {
		#[inline] fn as_raw_mut_Algorithm(&mut self) -> *mut c_void { self.as_raw_mut() }
	}
	
	impl crate::imgproc::CLAHETraitConst for CLAHE {
		#[inline] fn as_raw_CLAHE(&self) -> *const c_void { self.as_raw() }
	}
	
	impl crate::imgproc::CLAHETrait for CLAHE {
		#[inline] fn as_raw_mut_CLAHE(&mut self) -> *mut c_void { self.as_raw_mut() }
	}
	
	impl CLAHE {
	}
	
	boxed_cast_base! { CLAHE, core::Algorithm, cv_CLAHE_to_Algorithm }
	
	impl std::fmt::Debug for CLAHE {
		#[inline]
		fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
			f.debug_struct("CLAHE")
				.finish()
		}
	}
	
	/// Constant methods for [crate::imgproc::GeneralizedHough]
	pub trait GeneralizedHoughTraitConst: core::AlgorithmTraitConst {
		fn as_raw_GeneralizedHough(&self) -> *const c_void;
	
		#[inline]
		fn get_canny_low_thresh(&self) -> Result<i32> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHough_getCannyLowThresh_const(self.as_raw_GeneralizedHough(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		#[inline]
		fn get_canny_high_thresh(&self) -> Result<i32> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHough_getCannyHighThresh_const(self.as_raw_GeneralizedHough(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		#[inline]
		fn get_min_dist(&self) -> Result<f64> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHough_getMinDist_const(self.as_raw_GeneralizedHough(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		#[inline]
		fn get_dp(&self) -> Result<f64> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHough_getDp_const(self.as_raw_GeneralizedHough(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		#[inline]
		fn get_max_buffer_size(&self) -> Result<i32> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHough_getMaxBufferSize_const(self.as_raw_GeneralizedHough(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
	}
	
	/// Mutable methods for [crate::imgproc::GeneralizedHough]
	pub trait GeneralizedHoughTrait: core::AlgorithmTrait + crate::imgproc::GeneralizedHoughTraitConst {
		fn as_raw_mut_GeneralizedHough(&mut self) -> *mut c_void;
	
		/// set template to search
		/// 
		/// ## C++ default parameters
		/// * templ_center: Point(-1,-1)
		#[inline]
		fn set_template(&mut self, templ: &impl core::ToInputArray, templ_center: core::Point) -> Result<()> {
			input_array_arg!(templ);
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHough_setTemplate_const__InputArrayR_Point(self.as_raw_mut_GeneralizedHough(), templ.as_raw__InputArray(), templ_center.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// set template to search
		/// 
		/// ## Note
		/// This alternative version of [GeneralizedHoughTrait::set_template] function uses the following default values for its arguments:
		/// * templ_center: Point(-1,-1)
		#[inline]
		fn set_template_def(&mut self, templ: &impl core::ToInputArray) -> Result<()> {
			input_array_arg!(templ);
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHough_setTemplate_const__InputArrayR(self.as_raw_mut_GeneralizedHough(), templ.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// ## C++ default parameters
		/// * templ_center: Point(-1,-1)
		#[inline]
		fn set_template_1(&mut self, edges: &impl core::ToInputArray, dx: &impl core::ToInputArray, dy: &impl core::ToInputArray, templ_center: core::Point) -> Result<()> {
			input_array_arg!(edges);
			input_array_arg!(dx);
			input_array_arg!(dy);
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHough_setTemplate_const__InputArrayR_const__InputArrayR_const__InputArrayR_Point(self.as_raw_mut_GeneralizedHough(), edges.as_raw__InputArray(), dx.as_raw__InputArray(), dy.as_raw__InputArray(), templ_center.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// ## Note
		/// This alternative version of [GeneralizedHoughTrait::set_template] function uses the following default values for its arguments:
		/// * templ_center: Point(-1,-1)
		#[inline]
		fn set_template_def_1(&mut self, edges: &impl core::ToInputArray, dx: &impl core::ToInputArray, dy: &impl core::ToInputArray) -> Result<()> {
			input_array_arg!(edges);
			input_array_arg!(dx);
			input_array_arg!(dy);
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHough_setTemplate_const__InputArrayR_const__InputArrayR_const__InputArrayR(self.as_raw_mut_GeneralizedHough(), edges.as_raw__InputArray(), dx.as_raw__InputArray(), dy.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// find template on image
		/// 
		/// ## C++ default parameters
		/// * votes: noArray()
		#[inline]
		fn detect(&mut self, image: &impl core::ToInputArray, positions: &mut impl core::ToOutputArray, votes: &mut impl core::ToOutputArray) -> Result<()> {
			input_array_arg!(image);
			output_array_arg!(positions);
			output_array_arg!(votes);
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHough_detect_const__InputArrayR_const__OutputArrayR_const__OutputArrayR(self.as_raw_mut_GeneralizedHough(), image.as_raw__InputArray(), positions.as_raw__OutputArray(), votes.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// find template on image
		/// 
		/// ## Note
		/// This alternative version of [GeneralizedHoughTrait::detect] function uses the following default values for its arguments:
		/// * votes: noArray()
		#[inline]
		fn detect_def(&mut self, image: &impl core::ToInputArray, positions: &mut impl core::ToOutputArray) -> Result<()> {
			input_array_arg!(image);
			output_array_arg!(positions);
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHough_detect_const__InputArrayR_const__OutputArrayR(self.as_raw_mut_GeneralizedHough(), image.as_raw__InputArray(), positions.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// ## C++ default parameters
		/// * votes: noArray()
		#[inline]
		fn detect_with_edges(&mut self, edges: &impl core::ToInputArray, dx: &impl core::ToInputArray, dy: &impl core::ToInputArray, positions: &mut impl core::ToOutputArray, votes: &mut impl core::ToOutputArray) -> Result<()> {
			input_array_arg!(edges);
			input_array_arg!(dx);
			input_array_arg!(dy);
			output_array_arg!(positions);
			output_array_arg!(votes);
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHough_detect_const__InputArrayR_const__InputArrayR_const__InputArrayR_const__OutputArrayR_const__OutputArrayR(self.as_raw_mut_GeneralizedHough(), edges.as_raw__InputArray(), dx.as_raw__InputArray(), dy.as_raw__InputArray(), positions.as_raw__OutputArray(), votes.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// ## Note
		/// This alternative version of [GeneralizedHoughTrait::detect_with_edges] function uses the following default values for its arguments:
		/// * votes: noArray()
		#[inline]
		fn detect_with_edges_def(&mut self, edges: &impl core::ToInputArray, dx: &impl core::ToInputArray, dy: &impl core::ToInputArray, positions: &mut impl core::ToOutputArray) -> Result<()> {
			input_array_arg!(edges);
			input_array_arg!(dx);
			input_array_arg!(dy);
			output_array_arg!(positions);
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHough_detect_const__InputArrayR_const__InputArrayR_const__InputArrayR_const__OutputArrayR(self.as_raw_mut_GeneralizedHough(), edges.as_raw__InputArray(), dx.as_raw__InputArray(), dy.as_raw__InputArray(), positions.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Canny low threshold.
		#[inline]
		fn set_canny_low_thresh(&mut self, canny_low_thresh: i32) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHough_setCannyLowThresh_int(self.as_raw_mut_GeneralizedHough(), canny_low_thresh, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Canny high threshold.
		#[inline]
		fn set_canny_high_thresh(&mut self, canny_high_thresh: i32) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHough_setCannyHighThresh_int(self.as_raw_mut_GeneralizedHough(), canny_high_thresh, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Minimum distance between the centers of the detected objects.
		#[inline]
		fn set_min_dist(&mut self, min_dist: f64) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHough_setMinDist_double(self.as_raw_mut_GeneralizedHough(), min_dist, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Inverse ratio of the accumulator resolution to the image resolution.
		#[inline]
		fn set_dp(&mut self, dp: f64) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHough_setDp_double(self.as_raw_mut_GeneralizedHough(), dp, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Maximal size of inner buffers.
		#[inline]
		fn set_max_buffer_size(&mut self, max_buffer_size: i32) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHough_setMaxBufferSize_int(self.as_raw_mut_GeneralizedHough(), max_buffer_size, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
	}
	
	/// finds arbitrary template in the grayscale image using Generalized Hough Transform
	pub struct GeneralizedHough {
		ptr: *mut c_void
	}
	
	opencv_type_boxed! { GeneralizedHough }
	
	impl Drop for GeneralizedHough {
		#[inline]
		fn drop(&mut self) {
			unsafe { sys::cv_GeneralizedHough_delete(self.as_raw_mut_GeneralizedHough()) };
		}
	}
	
	unsafe impl Send for GeneralizedHough {}
	
	impl core::AlgorithmTraitConst for GeneralizedHough {
		#[inline] fn as_raw_Algorithm(&self) -> *const c_void { self.as_raw() }
	}
	
	impl core::AlgorithmTrait for GeneralizedHough {
		#[inline] fn as_raw_mut_Algorithm(&mut self) -> *mut c_void { self.as_raw_mut() }
	}
	
	impl crate::imgproc::GeneralizedHoughTraitConst for GeneralizedHough {
		#[inline] fn as_raw_GeneralizedHough(&self) -> *const c_void { self.as_raw() }
	}
	
	impl crate::imgproc::GeneralizedHoughTrait for GeneralizedHough {
		#[inline] fn as_raw_mut_GeneralizedHough(&mut self) -> *mut c_void { self.as_raw_mut() }
	}
	
	impl GeneralizedHough {
	}
	
	boxed_cast_descendant! { GeneralizedHough, crate::imgproc::GeneralizedHoughBallard, cv_GeneralizedHough_to_GeneralizedHoughBallard }
	
	boxed_cast_descendant! { GeneralizedHough, crate::imgproc::GeneralizedHoughGuil, cv_GeneralizedHough_to_GeneralizedHoughGuil }
	
	boxed_cast_base! { GeneralizedHough, core::Algorithm, cv_GeneralizedHough_to_Algorithm }
	
	impl std::fmt::Debug for GeneralizedHough {
		#[inline]
		fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
			f.debug_struct("GeneralizedHough")
				.finish()
		}
	}
	
	/// Constant methods for [crate::imgproc::GeneralizedHoughBallard]
	pub trait GeneralizedHoughBallardTraitConst: crate::imgproc::GeneralizedHoughTraitConst {
		fn as_raw_GeneralizedHoughBallard(&self) -> *const c_void;
	
		#[inline]
		fn get_levels(&self) -> Result<i32> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughBallard_getLevels_const(self.as_raw_GeneralizedHoughBallard(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		#[inline]
		fn get_votes_threshold(&self) -> Result<i32> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughBallard_getVotesThreshold_const(self.as_raw_GeneralizedHoughBallard(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
	}
	
	/// Mutable methods for [crate::imgproc::GeneralizedHoughBallard]
	pub trait GeneralizedHoughBallardTrait: crate::imgproc::GeneralizedHoughBallardTraitConst + crate::imgproc::GeneralizedHoughTrait {
		fn as_raw_mut_GeneralizedHoughBallard(&mut self) -> *mut c_void;
	
		/// R-Table levels.
		#[inline]
		fn set_levels(&mut self, levels: i32) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughBallard_setLevels_int(self.as_raw_mut_GeneralizedHoughBallard(), levels, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// The accumulator threshold for the template centers at the detection stage. The smaller it is, the more false positions may be detected.
		#[inline]
		fn set_votes_threshold(&mut self, votes_threshold: i32) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughBallard_setVotesThreshold_int(self.as_raw_mut_GeneralizedHoughBallard(), votes_threshold, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
	}
	
	/// finds arbitrary template in the grayscale image using Generalized Hough Transform
	/// 
	/// Detects position only without translation and rotation [Ballard1981](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Ballard1981) .
	pub struct GeneralizedHoughBallard {
		ptr: *mut c_void
	}
	
	opencv_type_boxed! { GeneralizedHoughBallard }
	
	impl Drop for GeneralizedHoughBallard {
		#[inline]
		fn drop(&mut self) {
			unsafe { sys::cv_GeneralizedHoughBallard_delete(self.as_raw_mut_GeneralizedHoughBallard()) };
		}
	}
	
	unsafe impl Send for GeneralizedHoughBallard {}
	
	impl core::AlgorithmTraitConst for GeneralizedHoughBallard {
		#[inline] fn as_raw_Algorithm(&self) -> *const c_void { self.as_raw() }
	}
	
	impl core::AlgorithmTrait for GeneralizedHoughBallard {
		#[inline] fn as_raw_mut_Algorithm(&mut self) -> *mut c_void { self.as_raw_mut() }
	}
	
	impl crate::imgproc::GeneralizedHoughTraitConst for GeneralizedHoughBallard {
		#[inline] fn as_raw_GeneralizedHough(&self) -> *const c_void { self.as_raw() }
	}
	
	impl crate::imgproc::GeneralizedHoughTrait for GeneralizedHoughBallard {
		#[inline] fn as_raw_mut_GeneralizedHough(&mut self) -> *mut c_void { self.as_raw_mut() }
	}
	
	impl crate::imgproc::GeneralizedHoughBallardTraitConst for GeneralizedHoughBallard {
		#[inline] fn as_raw_GeneralizedHoughBallard(&self) -> *const c_void { self.as_raw() }
	}
	
	impl crate::imgproc::GeneralizedHoughBallardTrait for GeneralizedHoughBallard {
		#[inline] fn as_raw_mut_GeneralizedHoughBallard(&mut self) -> *mut c_void { self.as_raw_mut() }
	}
	
	impl GeneralizedHoughBallard {
	}
	
	boxed_cast_base! { GeneralizedHoughBallard, core::Algorithm, cv_GeneralizedHoughBallard_to_Algorithm }
	
	boxed_cast_base! { GeneralizedHoughBallard, crate::imgproc::GeneralizedHough, cv_GeneralizedHoughBallard_to_GeneralizedHough }
	
	impl std::fmt::Debug for GeneralizedHoughBallard {
		#[inline]
		fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
			f.debug_struct("GeneralizedHoughBallard")
				.finish()
		}
	}
	
	/// Constant methods for [crate::imgproc::GeneralizedHoughGuil]
	pub trait GeneralizedHoughGuilTraitConst: crate::imgproc::GeneralizedHoughTraitConst {
		fn as_raw_GeneralizedHoughGuil(&self) -> *const c_void;
	
		#[inline]
		fn get_xi(&self) -> Result<f64> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughGuil_getXi_const(self.as_raw_GeneralizedHoughGuil(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		#[inline]
		fn get_levels(&self) -> Result<i32> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughGuil_getLevels_const(self.as_raw_GeneralizedHoughGuil(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		#[inline]
		fn get_angle_epsilon(&self) -> Result<f64> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughGuil_getAngleEpsilon_const(self.as_raw_GeneralizedHoughGuil(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		#[inline]
		fn get_min_angle(&self) -> Result<f64> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughGuil_getMinAngle_const(self.as_raw_GeneralizedHoughGuil(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		#[inline]
		fn get_max_angle(&self) -> Result<f64> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughGuil_getMaxAngle_const(self.as_raw_GeneralizedHoughGuil(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		#[inline]
		fn get_angle_step(&self) -> Result<f64> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughGuil_getAngleStep_const(self.as_raw_GeneralizedHoughGuil(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		#[inline]
		fn get_angle_thresh(&self) -> Result<i32> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughGuil_getAngleThresh_const(self.as_raw_GeneralizedHoughGuil(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		#[inline]
		fn get_min_scale(&self) -> Result<f64> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughGuil_getMinScale_const(self.as_raw_GeneralizedHoughGuil(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		#[inline]
		fn get_max_scale(&self) -> Result<f64> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughGuil_getMaxScale_const(self.as_raw_GeneralizedHoughGuil(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		#[inline]
		fn get_scale_step(&self) -> Result<f64> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughGuil_getScaleStep_const(self.as_raw_GeneralizedHoughGuil(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		#[inline]
		fn get_scale_thresh(&self) -> Result<i32> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughGuil_getScaleThresh_const(self.as_raw_GeneralizedHoughGuil(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		#[inline]
		fn get_pos_thresh(&self) -> Result<i32> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughGuil_getPosThresh_const(self.as_raw_GeneralizedHoughGuil(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
	}
	
	/// Mutable methods for [crate::imgproc::GeneralizedHoughGuil]
	pub trait GeneralizedHoughGuilTrait: crate::imgproc::GeneralizedHoughGuilTraitConst + crate::imgproc::GeneralizedHoughTrait {
		fn as_raw_mut_GeneralizedHoughGuil(&mut self) -> *mut c_void;
	
		/// Angle difference in degrees between two points in feature.
		#[inline]
		fn set_xi(&mut self, xi: f64) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughGuil_setXi_double(self.as_raw_mut_GeneralizedHoughGuil(), xi, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Feature table levels.
		#[inline]
		fn set_levels(&mut self, levels: i32) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughGuil_setLevels_int(self.as_raw_mut_GeneralizedHoughGuil(), levels, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Maximal difference between angles that treated as equal.
		#[inline]
		fn set_angle_epsilon(&mut self, angle_epsilon: f64) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughGuil_setAngleEpsilon_double(self.as_raw_mut_GeneralizedHoughGuil(), angle_epsilon, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Minimal rotation angle to detect in degrees.
		#[inline]
		fn set_min_angle(&mut self, min_angle: f64) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughGuil_setMinAngle_double(self.as_raw_mut_GeneralizedHoughGuil(), min_angle, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Maximal rotation angle to detect in degrees.
		#[inline]
		fn set_max_angle(&mut self, max_angle: f64) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughGuil_setMaxAngle_double(self.as_raw_mut_GeneralizedHoughGuil(), max_angle, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Angle step in degrees.
		#[inline]
		fn set_angle_step(&mut self, angle_step: f64) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughGuil_setAngleStep_double(self.as_raw_mut_GeneralizedHoughGuil(), angle_step, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Angle votes threshold.
		#[inline]
		fn set_angle_thresh(&mut self, angle_thresh: i32) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughGuil_setAngleThresh_int(self.as_raw_mut_GeneralizedHoughGuil(), angle_thresh, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Minimal scale to detect.
		#[inline]
		fn set_min_scale(&mut self, min_scale: f64) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughGuil_setMinScale_double(self.as_raw_mut_GeneralizedHoughGuil(), min_scale, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Maximal scale to detect.
		#[inline]
		fn set_max_scale(&mut self, max_scale: f64) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughGuil_setMaxScale_double(self.as_raw_mut_GeneralizedHoughGuil(), max_scale, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Scale step.
		#[inline]
		fn set_scale_step(&mut self, scale_step: f64) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughGuil_setScaleStep_double(self.as_raw_mut_GeneralizedHoughGuil(), scale_step, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Scale votes threshold.
		#[inline]
		fn set_scale_thresh(&mut self, scale_thresh: i32) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughGuil_setScaleThresh_int(self.as_raw_mut_GeneralizedHoughGuil(), scale_thresh, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Position votes threshold.
		#[inline]
		fn set_pos_thresh(&mut self, pos_thresh: i32) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_GeneralizedHoughGuil_setPosThresh_int(self.as_raw_mut_GeneralizedHoughGuil(), pos_thresh, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
	}
	
	/// finds arbitrary template in the grayscale image using Generalized Hough Transform
	/// 
	/// Detects position, translation and rotation [Guil1999](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Guil1999) .
	pub struct GeneralizedHoughGuil {
		ptr: *mut c_void
	}
	
	opencv_type_boxed! { GeneralizedHoughGuil }
	
	impl Drop for GeneralizedHoughGuil {
		#[inline]
		fn drop(&mut self) {
			unsafe { sys::cv_GeneralizedHoughGuil_delete(self.as_raw_mut_GeneralizedHoughGuil()) };
		}
	}
	
	unsafe impl Send for GeneralizedHoughGuil {}
	
	impl core::AlgorithmTraitConst for GeneralizedHoughGuil {
		#[inline] fn as_raw_Algorithm(&self) -> *const c_void { self.as_raw() }
	}
	
	impl core::AlgorithmTrait for GeneralizedHoughGuil {
		#[inline] fn as_raw_mut_Algorithm(&mut self) -> *mut c_void { self.as_raw_mut() }
	}
	
	impl crate::imgproc::GeneralizedHoughTraitConst for GeneralizedHoughGuil {
		#[inline] fn as_raw_GeneralizedHough(&self) -> *const c_void { self.as_raw() }
	}
	
	impl crate::imgproc::GeneralizedHoughTrait for GeneralizedHoughGuil {
		#[inline] fn as_raw_mut_GeneralizedHough(&mut self) -> *mut c_void { self.as_raw_mut() }
	}
	
	impl crate::imgproc::GeneralizedHoughGuilTraitConst for GeneralizedHoughGuil {
		#[inline] fn as_raw_GeneralizedHoughGuil(&self) -> *const c_void { self.as_raw() }
	}
	
	impl crate::imgproc::GeneralizedHoughGuilTrait for GeneralizedHoughGuil {
		#[inline] fn as_raw_mut_GeneralizedHoughGuil(&mut self) -> *mut c_void { self.as_raw_mut() }
	}
	
	impl GeneralizedHoughGuil {
	}
	
	boxed_cast_base! { GeneralizedHoughGuil, core::Algorithm, cv_GeneralizedHoughGuil_to_Algorithm }
	
	boxed_cast_base! { GeneralizedHoughGuil, crate::imgproc::GeneralizedHough, cv_GeneralizedHoughGuil_to_GeneralizedHough }
	
	impl std::fmt::Debug for GeneralizedHoughGuil {
		#[inline]
		fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
			f.debug_struct("GeneralizedHoughGuil")
				.finish()
		}
	}
	
	/// Constant methods for [crate::imgproc::LineIterator]
	pub trait LineIteratorTraitConst {
		fn as_raw_LineIterator(&self) -> *const c_void;
	
		#[inline]
		fn ptr0(&self) -> *const u8 {
			let ret = unsafe { sys::cv_LineIterator_propPtr0_const(self.as_raw_LineIterator()) };
			ret
		}
		
		#[inline]
		fn step(&self) -> i32 {
			let ret = unsafe { sys::cv_LineIterator_propStep_const(self.as_raw_LineIterator()) };
			ret
		}
		
		#[inline]
		fn elem_size(&self) -> i32 {
			let ret = unsafe { sys::cv_LineIterator_propElemSize_const(self.as_raw_LineIterator()) };
			ret
		}
		
		#[inline]
		fn err(&self) -> i32 {
			let ret = unsafe { sys::cv_LineIterator_propErr_const(self.as_raw_LineIterator()) };
			ret
		}
		
		#[inline]
		fn count(&self) -> i32 {
			let ret = unsafe { sys::cv_LineIterator_propCount_const(self.as_raw_LineIterator()) };
			ret
		}
		
		#[inline]
		fn minus_delta(&self) -> i32 {
			let ret = unsafe { sys::cv_LineIterator_propMinusDelta_const(self.as_raw_LineIterator()) };
			ret
		}
		
		#[inline]
		fn plus_delta(&self) -> i32 {
			let ret = unsafe { sys::cv_LineIterator_propPlusDelta_const(self.as_raw_LineIterator()) };
			ret
		}
		
		#[inline]
		fn minus_step(&self) -> i32 {
			let ret = unsafe { sys::cv_LineIterator_propMinusStep_const(self.as_raw_LineIterator()) };
			ret
		}
		
		#[inline]
		fn plus_step(&self) -> i32 {
			let ret = unsafe { sys::cv_LineIterator_propPlusStep_const(self.as_raw_LineIterator()) };
			ret
		}
		
		#[inline]
		fn minus_shift(&self) -> i32 {
			let ret = unsafe { sys::cv_LineIterator_propMinusShift_const(self.as_raw_LineIterator()) };
			ret
		}
		
		#[inline]
		fn plus_shift(&self) -> i32 {
			let ret = unsafe { sys::cv_LineIterator_propPlusShift_const(self.as_raw_LineIterator()) };
			ret
		}
		
		#[inline]
		fn p(&self) -> core::Point {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_LineIterator_propP_const(self.as_raw_LineIterator(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			ret
		}
		
		#[inline]
		fn ptmode(&self) -> bool {
			let ret = unsafe { sys::cv_LineIterator_propPtmode_const(self.as_raw_LineIterator()) };
			ret
		}
		
		/// Returns coordinates of the current pixel.
		#[inline]
		fn pos(&self) -> Result<core::Point> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_LineIterator_pos_const(self.as_raw_LineIterator(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
	}
	
	/// Mutable methods for [crate::imgproc::LineIterator]
	pub trait LineIteratorTrait: crate::imgproc::LineIteratorTraitConst {
		fn as_raw_mut_LineIterator(&mut self) -> *mut c_void;
	
		#[inline]
		fn ptr(&mut self) -> *mut u8 {
			let ret = unsafe { sys::cv_LineIterator_propPtr(self.as_raw_mut_LineIterator()) };
			ret
		}
		
		#[inline]
		unsafe fn set_ptr(&mut self, val: *mut u8) {
			let ret = { sys::cv_LineIterator_propPtr_unsigned_charX(self.as_raw_mut_LineIterator(), val) };
			ret
		}
		
		#[inline]
		fn set_step(&mut self, val: i32) {
			let ret = unsafe { sys::cv_LineIterator_propStep_int(self.as_raw_mut_LineIterator(), val) };
			ret
		}
		
		#[inline]
		fn set_elem_size(&mut self, val: i32) {
			let ret = unsafe { sys::cv_LineIterator_propElemSize_int(self.as_raw_mut_LineIterator(), val) };
			ret
		}
		
		#[inline]
		fn set_err(&mut self, val: i32) {
			let ret = unsafe { sys::cv_LineIterator_propErr_int(self.as_raw_mut_LineIterator(), val) };
			ret
		}
		
		#[inline]
		fn set_count(&mut self, val: i32) {
			let ret = unsafe { sys::cv_LineIterator_propCount_int(self.as_raw_mut_LineIterator(), val) };
			ret
		}
		
		#[inline]
		fn set_minus_delta(&mut self, val: i32) {
			let ret = unsafe { sys::cv_LineIterator_propMinusDelta_int(self.as_raw_mut_LineIterator(), val) };
			ret
		}
		
		#[inline]
		fn set_plus_delta(&mut self, val: i32) {
			let ret = unsafe { sys::cv_LineIterator_propPlusDelta_int(self.as_raw_mut_LineIterator(), val) };
			ret
		}
		
		#[inline]
		fn set_minus_step(&mut self, val: i32) {
			let ret = unsafe { sys::cv_LineIterator_propMinusStep_int(self.as_raw_mut_LineIterator(), val) };
			ret
		}
		
		#[inline]
		fn set_plus_step(&mut self, val: i32) {
			let ret = unsafe { sys::cv_LineIterator_propPlusStep_int(self.as_raw_mut_LineIterator(), val) };
			ret
		}
		
		#[inline]
		fn set_minus_shift(&mut self, val: i32) {
			let ret = unsafe { sys::cv_LineIterator_propMinusShift_int(self.as_raw_mut_LineIterator(), val) };
			ret
		}
		
		#[inline]
		fn set_plus_shift(&mut self, val: i32) {
			let ret = unsafe { sys::cv_LineIterator_propPlusShift_int(self.as_raw_mut_LineIterator(), val) };
			ret
		}
		
		#[inline]
		fn set_p(&mut self, val: core::Point) {
			let ret = unsafe { sys::cv_LineIterator_propP_Point(self.as_raw_mut_LineIterator(), val.opencv_as_extern()) };
			ret
		}
		
		#[inline]
		fn set_ptmode(&mut self, val: bool) {
			let ret = unsafe { sys::cv_LineIterator_propPtmode_bool(self.as_raw_mut_LineIterator(), val) };
			ret
		}
		
		#[inline]
		fn init(&mut self, img: &core::Mat, bounding_area_rect: core::Rect, pt1: core::Point, pt2: core::Point, connectivity: i32, left_to_right: bool) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_LineIterator_init_const_MatX_Rect_Point_Point_int_bool(self.as_raw_mut_LineIterator(), img.as_raw_Mat(), bounding_area_rect.opencv_as_extern(), pt1.opencv_as_extern(), pt2.opencv_as_extern(), connectivity, left_to_right, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Returns pointer to the current pixel.
		#[inline]
		fn try_deref_mut(&mut self) -> Result<*mut u8> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_LineIterator_operatorX(self.as_raw_mut_LineIterator(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Moves iterator to the next pixel on the line.
		/// 
		/// This is the prefix version (++it).
		#[inline]
		fn incr(&mut self) -> Result<crate::imgproc::LineIterator> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_LineIterator_operatorAA(self.as_raw_mut_LineIterator(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			let ret = unsafe { crate::imgproc::LineIterator::opencv_from_extern(ret) };
			Ok(ret)
		}
		
	}
	
	/// Class for iterating over all pixels on a raster line segment.
	/// 
	/// The class LineIterator is used to get each pixel of a raster line connecting
	/// two specified points.
	/// It can be treated as a versatile implementation of the Bresenham algorithm
	/// where you can stop at each pixel and do some extra processing, for
	/// example, grab pixel values along the line or draw a line with an effect
	/// (for example, with XOR operation).
	/// 
	/// The number of pixels along the line is stored in LineIterator::count.
	/// The method LineIterator::pos returns the current position in the image:
	/// 
	/// ```C++
	/// // grabs pixels along the line (pt1, pt2)
	/// // from 8-bit 3-channel image to the buffer
	/// LineIterator it(img, pt1, pt2, 8);
	/// LineIterator it2 = it;
	/// vector<Vec3b> buf(it.count);
	/// 
	/// for(int i = 0; i < it.count; i++, ++it)
	///    buf[i] = *(const Vec3b*)*it;
	/// 
	/// // alternative way of iterating through the line
	/// for(int i = 0; i < it2.count; i++, ++it2)
	/// {
	///    Vec3b val = img.at<Vec3b>(it2.pos());
	///    CV_Assert(buf[i] == val);
	/// }
	/// ```
	/// 
	pub struct LineIterator {
		ptr: *mut c_void
	}
	
	opencv_type_boxed! { LineIterator }
	
	impl Drop for LineIterator {
		#[inline]
		fn drop(&mut self) {
			unsafe { sys::cv_LineIterator_delete(self.as_raw_mut_LineIterator()) };
		}
	}
	
	unsafe impl Send for LineIterator {}
	
	impl crate::imgproc::LineIteratorTraitConst for LineIterator {
		#[inline] fn as_raw_LineIterator(&self) -> *const c_void { self.as_raw() }
	}
	
	impl crate::imgproc::LineIteratorTrait for LineIterator {
		#[inline] fn as_raw_mut_LineIterator(&mut self) -> *mut c_void { self.as_raw_mut() }
	}
	
	impl LineIterator {
		/// Initializes iterator object for the given line and image.
		/// 
		/// The returned iterator can be used to traverse all pixels on a line that
		/// connects the given two points.
		/// The line will be clipped on the image boundaries.
		/// 
		/// ## Parameters
		/// * img: Underlying image.
		/// * pt1: First endpoint of the line.
		/// * pt2: The other endpoint of the line.
		/// * connectivity: Pixel connectivity of the iterator. Valid values are 4 (iterator can move
		/// up, down, left and right) and 8 (iterator can also move diagonally).
		/// * leftToRight: If true, the line is traversed from the leftmost endpoint to the rightmost
		/// endpoint. Otherwise, the line is traversed from \p pt1 to \p pt2.
		/// 
		/// ## C++ default parameters
		/// * connectivity: 8
		/// * left_to_right: false
		#[inline]
		pub fn new(img: &core::Mat, pt1: core::Point, pt2: core::Point, connectivity: i32, left_to_right: bool) -> Result<crate::imgproc::LineIterator> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_LineIterator_LineIterator_const_MatR_Point_Point_int_bool(img.as_raw_Mat(), pt1.opencv_as_extern(), pt2.opencv_as_extern(), connectivity, left_to_right, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			let ret = unsafe { crate::imgproc::LineIterator::opencv_from_extern(ret) };
			Ok(ret)
		}
		
		/// Initializes iterator object for the given line and image.
		/// 
		/// The returned iterator can be used to traverse all pixels on a line that
		/// connects the given two points.
		/// The line will be clipped on the image boundaries.
		/// 
		/// ## Parameters
		/// * img: Underlying image.
		/// * pt1: First endpoint of the line.
		/// * pt2: The other endpoint of the line.
		/// * connectivity: Pixel connectivity of the iterator. Valid values are 4 (iterator can move
		/// up, down, left and right) and 8 (iterator can also move diagonally).
		/// * leftToRight: If true, the line is traversed from the leftmost endpoint to the rightmost
		/// endpoint. Otherwise, the line is traversed from \p pt1 to \p pt2.
		/// 
		/// ## Note
		/// This alternative version of [new] function uses the following default values for its arguments:
		/// * connectivity: 8
		/// * left_to_right: false
		#[inline]
		pub fn new_def(img: &core::Mat, pt1: core::Point, pt2: core::Point) -> Result<crate::imgproc::LineIterator> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_LineIterator_LineIterator_const_MatR_Point_Point(img.as_raw_Mat(), pt1.opencv_as_extern(), pt2.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			let ret = unsafe { crate::imgproc::LineIterator::opencv_from_extern(ret) };
			Ok(ret)
		}
		
		/// ## C++ default parameters
		/// * connectivity: 8
		/// * left_to_right: false
		#[inline]
		pub fn new_1(pt1: core::Point, pt2: core::Point, connectivity: i32, left_to_right: bool) -> Result<crate::imgproc::LineIterator> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_LineIterator_LineIterator_Point_Point_int_bool(pt1.opencv_as_extern(), pt2.opencv_as_extern(), connectivity, left_to_right, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			let ret = unsafe { crate::imgproc::LineIterator::opencv_from_extern(ret) };
			Ok(ret)
		}
		
		/// ## Note
		/// This alternative version of [new] function uses the following default values for its arguments:
		/// * connectivity: 8
		/// * left_to_right: false
		#[inline]
		pub fn new_def_1(pt1: core::Point, pt2: core::Point) -> Result<crate::imgproc::LineIterator> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_LineIterator_LineIterator_Point_Point(pt1.opencv_as_extern(), pt2.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			let ret = unsafe { crate::imgproc::LineIterator::opencv_from_extern(ret) };
			Ok(ret)
		}
		
		/// ## C++ default parameters
		/// * connectivity: 8
		/// * left_to_right: false
		#[inline]
		pub fn new_2(bounding_area_size: core::Size, pt1: core::Point, pt2: core::Point, connectivity: i32, left_to_right: bool) -> Result<crate::imgproc::LineIterator> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_LineIterator_LineIterator_Size_Point_Point_int_bool(bounding_area_size.opencv_as_extern(), pt1.opencv_as_extern(), pt2.opencv_as_extern(), connectivity, left_to_right, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			let ret = unsafe { crate::imgproc::LineIterator::opencv_from_extern(ret) };
			Ok(ret)
		}
		
		/// ## Note
		/// This alternative version of [new] function uses the following default values for its arguments:
		/// * connectivity: 8
		/// * left_to_right: false
		#[inline]
		pub fn new_def_2(bounding_area_size: core::Size, pt1: core::Point, pt2: core::Point) -> Result<crate::imgproc::LineIterator> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_LineIterator_LineIterator_Size_Point_Point(bounding_area_size.opencv_as_extern(), pt1.opencv_as_extern(), pt2.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			let ret = unsafe { crate::imgproc::LineIterator::opencv_from_extern(ret) };
			Ok(ret)
		}
		
		/// ## C++ default parameters
		/// * connectivity: 8
		/// * left_to_right: false
		#[inline]
		pub fn new_3(bounding_area_rect: core::Rect, pt1: core::Point, pt2: core::Point, connectivity: i32, left_to_right: bool) -> Result<crate::imgproc::LineIterator> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_LineIterator_LineIterator_Rect_Point_Point_int_bool(bounding_area_rect.opencv_as_extern(), pt1.opencv_as_extern(), pt2.opencv_as_extern(), connectivity, left_to_right, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			let ret = unsafe { crate::imgproc::LineIterator::opencv_from_extern(ret) };
			Ok(ret)
		}
		
		/// ## Note
		/// This alternative version of [new] function uses the following default values for its arguments:
		/// * connectivity: 8
		/// * left_to_right: false
		#[inline]
		pub fn new_def_3(bounding_area_rect: core::Rect, pt1: core::Point, pt2: core::Point) -> Result<crate::imgproc::LineIterator> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_LineIterator_LineIterator_Rect_Point_Point(bounding_area_rect.opencv_as_extern(), pt1.opencv_as_extern(), pt2.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			let ret = unsafe { crate::imgproc::LineIterator::opencv_from_extern(ret) };
			Ok(ret)
		}
		
	}
	
	impl std::fmt::Debug for LineIterator {
		#[inline]
		fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
			f.debug_struct("LineIterator")
				.field("ptr0", &crate::imgproc::LineIteratorTraitConst::ptr0(self))
				.field("step", &crate::imgproc::LineIteratorTraitConst::step(self))
				.field("elem_size", &crate::imgproc::LineIteratorTraitConst::elem_size(self))
				.field("err", &crate::imgproc::LineIteratorTraitConst::err(self))
				.field("count", &crate::imgproc::LineIteratorTraitConst::count(self))
				.field("minus_delta", &crate::imgproc::LineIteratorTraitConst::minus_delta(self))
				.field("plus_delta", &crate::imgproc::LineIteratorTraitConst::plus_delta(self))
				.field("minus_step", &crate::imgproc::LineIteratorTraitConst::minus_step(self))
				.field("plus_step", &crate::imgproc::LineIteratorTraitConst::plus_step(self))
				.field("minus_shift", &crate::imgproc::LineIteratorTraitConst::minus_shift(self))
				.field("plus_shift", &crate::imgproc::LineIteratorTraitConst::plus_shift(self))
				.field("p", &crate::imgproc::LineIteratorTraitConst::p(self))
				.field("ptmode", &crate::imgproc::LineIteratorTraitConst::ptmode(self))
				.finish()
		}
	}
	
	/// Constant methods for [crate::imgproc::LineSegmentDetector]
	pub trait LineSegmentDetectorTraitConst: core::AlgorithmTraitConst {
		fn as_raw_LineSegmentDetector(&self) -> *const c_void;
	
	}
	
	/// Mutable methods for [crate::imgproc::LineSegmentDetector]
	pub trait LineSegmentDetectorTrait: core::AlgorithmTrait + crate::imgproc::LineSegmentDetectorTraitConst {
		fn as_raw_mut_LineSegmentDetector(&mut self) -> *mut c_void;
	
		/// Finds lines in the input image.
		/// 
		/// This is the output of the default parameters of the algorithm on the above shown image.
		/// 
		/// 
		/// 
		/// ## Parameters
		/// * image: A grayscale (CV_8UC1) input image. If only a roi needs to be selected, use:
		/// `lsd_ptr-\>detect(image(roi), lines, ...); lines += Scalar(roi.x, roi.y, roi.x, roi.y);`
		/// * lines: A vector of Vec4f elements specifying the beginning and ending point of a line. Where
		/// Vec4f is (x1, y1, x2, y2), point 1 is the start, point 2 - end. Returned lines are strictly
		/// oriented depending on the gradient.
		/// * width: Vector of widths of the regions, where the lines are found. E.g. Width of line.
		/// * prec: Vector of precisions with which the lines are found.
		/// * nfa: Vector containing number of false alarms in the line region, with precision of 10%. The
		/// bigger the value, logarithmically better the detection.
		/// - -1 corresponds to 10 mean false alarms
		/// - 0 corresponds to 1 mean false alarm
		/// - 1 corresponds to 0.1 mean false alarms
		/// This vector will be calculated only when the objects type is #LSD_REFINE_ADV.
		/// 
		/// ## C++ default parameters
		/// * width: noArray()
		/// * prec: noArray()
		/// * nfa: noArray()
		#[inline]
		fn detect(&mut self, image: &impl core::ToInputArray, lines: &mut impl core::ToOutputArray, width: &mut impl core::ToOutputArray, prec: &mut impl core::ToOutputArray, nfa: &mut impl core::ToOutputArray) -> Result<()> {
			input_array_arg!(image);
			output_array_arg!(lines);
			output_array_arg!(width);
			output_array_arg!(prec);
			output_array_arg!(nfa);
			return_send!(via ocvrs_return);
			unsafe { sys::cv_LineSegmentDetector_detect_const__InputArrayR_const__OutputArrayR_const__OutputArrayR_const__OutputArrayR_const__OutputArrayR(self.as_raw_mut_LineSegmentDetector(), image.as_raw__InputArray(), lines.as_raw__OutputArray(), width.as_raw__OutputArray(), prec.as_raw__OutputArray(), nfa.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Finds lines in the input image.
		/// 
		/// This is the output of the default parameters of the algorithm on the above shown image.
		/// 
		/// 
		/// 
		/// ## Parameters
		/// * image: A grayscale (CV_8UC1) input image. If only a roi needs to be selected, use:
		/// `lsd_ptr-\>detect(image(roi), lines, ...); lines += Scalar(roi.x, roi.y, roi.x, roi.y);`
		/// * lines: A vector of Vec4f elements specifying the beginning and ending point of a line. Where
		/// Vec4f is (x1, y1, x2, y2), point 1 is the start, point 2 - end. Returned lines are strictly
		/// oriented depending on the gradient.
		/// * width: Vector of widths of the regions, where the lines are found. E.g. Width of line.
		/// * prec: Vector of precisions with which the lines are found.
		/// * nfa: Vector containing number of false alarms in the line region, with precision of 10%. The
		/// bigger the value, logarithmically better the detection.
		/// - -1 corresponds to 10 mean false alarms
		/// - 0 corresponds to 1 mean false alarm
		/// - 1 corresponds to 0.1 mean false alarms
		/// This vector will be calculated only when the objects type is #LSD_REFINE_ADV.
		/// 
		/// ## Note
		/// This alternative version of [LineSegmentDetectorTrait::detect] function uses the following default values for its arguments:
		/// * width: noArray()
		/// * prec: noArray()
		/// * nfa: noArray()
		#[inline]
		fn detect_def(&mut self, image: &impl core::ToInputArray, lines: &mut impl core::ToOutputArray) -> Result<()> {
			input_array_arg!(image);
			output_array_arg!(lines);
			return_send!(via ocvrs_return);
			unsafe { sys::cv_LineSegmentDetector_detect_const__InputArrayR_const__OutputArrayR(self.as_raw_mut_LineSegmentDetector(), image.as_raw__InputArray(), lines.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Draws the line segments on a given image.
		/// ## Parameters
		/// * image: The image, where the lines will be drawn. Should be bigger or equal to the image,
		/// where the lines were found.
		/// * lines: A vector of the lines that needed to be drawn.
		#[inline]
		fn draw_segments(&mut self, image: &mut impl core::ToInputOutputArray, lines: &impl core::ToInputArray) -> Result<()> {
			input_output_array_arg!(image);
			input_array_arg!(lines);
			return_send!(via ocvrs_return);
			unsafe { sys::cv_LineSegmentDetector_drawSegments_const__InputOutputArrayR_const__InputArrayR(self.as_raw_mut_LineSegmentDetector(), image.as_raw__InputOutputArray(), lines.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Draws two groups of lines in blue and red, counting the non overlapping (mismatching) pixels.
		/// 
		/// ## Parameters
		/// * size: The size of the image, where lines1 and lines2 were found.
		/// * lines1: The first group of lines that needs to be drawn. It is visualized in blue color.
		/// * lines2: The second group of lines. They visualized in red color.
		/// * image: Optional image, where the lines will be drawn. The image should be color(3-channel)
		/// in order for lines1 and lines2 to be drawn in the above mentioned colors.
		/// 
		/// ## C++ default parameters
		/// * image: noArray()
		#[inline]
		fn compare_segments(&mut self, size: core::Size, lines1: &impl core::ToInputArray, lines2: &impl core::ToInputArray, image: &mut impl core::ToInputOutputArray) -> Result<i32> {
			input_array_arg!(lines1);
			input_array_arg!(lines2);
			input_output_array_arg!(image);
			return_send!(via ocvrs_return);
			unsafe { sys::cv_LineSegmentDetector_compareSegments_const_SizeR_const__InputArrayR_const__InputArrayR_const__InputOutputArrayR(self.as_raw_mut_LineSegmentDetector(), &size, lines1.as_raw__InputArray(), lines2.as_raw__InputArray(), image.as_raw__InputOutputArray(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Draws two groups of lines in blue and red, counting the non overlapping (mismatching) pixels.
		/// 
		/// ## Parameters
		/// * size: The size of the image, where lines1 and lines2 were found.
		/// * lines1: The first group of lines that needs to be drawn. It is visualized in blue color.
		/// * lines2: The second group of lines. They visualized in red color.
		/// * image: Optional image, where the lines will be drawn. The image should be color(3-channel)
		/// in order for lines1 and lines2 to be drawn in the above mentioned colors.
		/// 
		/// ## Note
		/// This alternative version of [LineSegmentDetectorTrait::compare_segments] function uses the following default values for its arguments:
		/// * image: noArray()
		#[inline]
		fn compare_segments_def(&mut self, size: core::Size, lines1: &impl core::ToInputArray, lines2: &impl core::ToInputArray) -> Result<i32> {
			input_array_arg!(lines1);
			input_array_arg!(lines2);
			return_send!(via ocvrs_return);
			unsafe { sys::cv_LineSegmentDetector_compareSegments_const_SizeR_const__InputArrayR_const__InputArrayR(self.as_raw_mut_LineSegmentDetector(), &size, lines1.as_raw__InputArray(), lines2.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
	}
	
	/// Line segment detector class
	/// 
	/// following the algorithm described at [Rafael12](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Rafael12) .
	/// 
	/// 
	/// Note: Implementation has been removed from OpenCV version 3.4.6 to 3.4.15 and version 4.1.0 to 4.5.3 due original code license conflict.
	/// restored again after [Computation of a NFA](https://github.com/rafael-grompone-von-gioi/binomial_nfa) code published under the MIT license.
	pub struct LineSegmentDetector {
		ptr: *mut c_void
	}
	
	opencv_type_boxed! { LineSegmentDetector }
	
	impl Drop for LineSegmentDetector {
		#[inline]
		fn drop(&mut self) {
			unsafe { sys::cv_LineSegmentDetector_delete(self.as_raw_mut_LineSegmentDetector()) };
		}
	}
	
	unsafe impl Send for LineSegmentDetector {}
	
	impl core::AlgorithmTraitConst for LineSegmentDetector {
		#[inline] fn as_raw_Algorithm(&self) -> *const c_void { self.as_raw() }
	}
	
	impl core::AlgorithmTrait for LineSegmentDetector {
		#[inline] fn as_raw_mut_Algorithm(&mut self) -> *mut c_void { self.as_raw_mut() }
	}
	
	impl crate::imgproc::LineSegmentDetectorTraitConst for LineSegmentDetector {
		#[inline] fn as_raw_LineSegmentDetector(&self) -> *const c_void { self.as_raw() }
	}
	
	impl crate::imgproc::LineSegmentDetectorTrait for LineSegmentDetector {
		#[inline] fn as_raw_mut_LineSegmentDetector(&mut self) -> *mut c_void { self.as_raw_mut() }
	}
	
	impl LineSegmentDetector {
	}
	
	boxed_cast_base! { LineSegmentDetector, core::Algorithm, cv_LineSegmentDetector_to_Algorithm }
	
	impl std::fmt::Debug for LineSegmentDetector {
		#[inline]
		fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
			f.debug_struct("LineSegmentDetector")
				.finish()
		}
	}
	
	/// Constant methods for [crate::imgproc::Subdiv2D]
	pub trait Subdiv2DTraitConst {
		fn as_raw_Subdiv2D(&self) -> *const c_void;
	
		/// Returns a list of all edges.
		/// 
		/// ## Parameters
		/// * edgeList: Output vector.
		/// 
		/// The function gives each edge as a 4 numbers vector, where each two are one of the edge
		/// vertices. i.e. org_x = v[0], org_y = v[1], dst_x = v[2], dst_y = v[3].
		#[inline]
		fn get_edge_list(&self, edge_list: &mut core::Vector<core::Vec4f>) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_Subdiv2D_getEdgeList_const_vectorLVec4fGR(self.as_raw_Subdiv2D(), edge_list.as_raw_mut_VectorOfVec4f(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Returns a list of the leading edge ID connected to each triangle.
		/// 
		/// ## Parameters
		/// * leadingEdgeList: Output vector.
		/// 
		/// The function gives one edge ID for each triangle.
		#[inline]
		fn get_leading_edge_list(&self, leading_edge_list: &mut core::Vector<i32>) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_Subdiv2D_getLeadingEdgeList_const_vectorLintGR(self.as_raw_Subdiv2D(), leading_edge_list.as_raw_mut_VectorOfi32(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Returns a list of all triangles.
		/// 
		/// ## Parameters
		/// * triangleList: Output vector.
		/// 
		/// The function gives each triangle as a 6 numbers vector, where each two are one of the triangle
		/// vertices. i.e. p1_x = v[0], p1_y = v[1], p2_x = v[2], p2_y = v[3], p3_x = v[4], p3_y = v[5].
		#[inline]
		fn get_triangle_list(&self, triangle_list: &mut core::Vector<core::Vec6f>) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_Subdiv2D_getTriangleList_const_vectorLVec6fGR(self.as_raw_Subdiv2D(), triangle_list.as_raw_mut_VectorOfVec6f(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Returns vertex location from vertex ID.
		/// 
		/// ## Parameters
		/// * vertex: vertex ID.
		/// * firstEdge: Optional. The first edge ID which is connected to the vertex.
		/// ## Returns
		/// vertex (x,y)
		/// 
		/// ## C++ default parameters
		/// * first_edge: 0
		#[inline]
		fn get_vertex(&self, vertex: i32, first_edge: &mut i32) -> Result<core::Point2f> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_Subdiv2D_getVertex_const_int_intX(self.as_raw_Subdiv2D(), vertex, first_edge, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Returns vertex location from vertex ID.
		/// 
		/// ## Parameters
		/// * vertex: vertex ID.
		/// * firstEdge: Optional. The first edge ID which is connected to the vertex.
		/// ## Returns
		/// vertex (x,y)
		/// 
		/// ## Note
		/// This alternative version of [Subdiv2DTraitConst::get_vertex] function uses the following default values for its arguments:
		/// * first_edge: 0
		#[inline]
		fn get_vertex_def(&self, vertex: i32) -> Result<core::Point2f> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_Subdiv2D_getVertex_const_int(self.as_raw_Subdiv2D(), vertex, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Returns one of the edges related to the given edge.
		/// 
		/// ## Parameters
		/// * edge: Subdivision edge ID.
		/// * nextEdgeType: Parameter specifying which of the related edges to return.
		/// The following values are possible:
		/// *   NEXT_AROUND_ORG next around the edge origin ( eOnext on the picture below if e is the input edge)
		/// *   NEXT_AROUND_DST next around the edge vertex ( eDnext )
		/// *   PREV_AROUND_ORG previous around the edge origin (reversed eRnext )
		/// *   PREV_AROUND_DST previous around the edge destination (reversed eLnext )
		/// *   NEXT_AROUND_LEFT next around the left facet ( eLnext )
		/// *   NEXT_AROUND_RIGHT next around the right facet ( eRnext )
		/// *   PREV_AROUND_LEFT previous around the left facet (reversed eOnext )
		/// *   PREV_AROUND_RIGHT previous around the right facet (reversed eDnext )
		/// 
		/// 
		/// 
		/// ## Returns
		/// edge ID related to the input edge.
		#[inline]
		fn get_edge(&self, edge: i32, next_edge_type: i32) -> Result<i32> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_Subdiv2D_getEdge_const_int_int(self.as_raw_Subdiv2D(), edge, next_edge_type, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Returns next edge around the edge origin.
		/// 
		/// ## Parameters
		/// * edge: Subdivision edge ID.
		/// 
		/// ## Returns
		/// an integer which is next edge ID around the edge origin: eOnext on the
		/// picture above if e is the input edge).
		#[inline]
		fn next_edge(&self, edge: i32) -> Result<i32> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_Subdiv2D_nextEdge_const_int(self.as_raw_Subdiv2D(), edge, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Returns another edge of the same quad-edge.
		/// 
		/// ## Parameters
		/// * edge: Subdivision edge ID.
		/// * rotate: Parameter specifying which of the edges of the same quad-edge as the input
		/// one to return. The following values are possible:
		/// *   0 - the input edge ( e on the picture below if e is the input edge)
		/// *   1 - the rotated edge ( eRot )
		/// *   2 - the reversed edge (reversed e (in green))
		/// *   3 - the reversed rotated edge (reversed eRot (in green))
		/// 
		/// ## Returns
		/// one of the edges ID of the same quad-edge as the input edge.
		#[inline]
		fn rotate_edge(&self, edge: i32, rotate: i32) -> Result<i32> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_Subdiv2D_rotateEdge_const_int_int(self.as_raw_Subdiv2D(), edge, rotate, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		#[inline]
		fn sym_edge(&self, edge: i32) -> Result<i32> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_Subdiv2D_symEdge_const_int(self.as_raw_Subdiv2D(), edge, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Returns the edge origin.
		/// 
		/// ## Parameters
		/// * edge: Subdivision edge ID.
		/// * orgpt: Output vertex location.
		/// 
		/// ## Returns
		/// vertex ID.
		/// 
		/// ## C++ default parameters
		/// * orgpt: 0
		#[inline]
		fn edge_org(&self, edge: i32, orgpt: &mut core::Point2f) -> Result<i32> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_Subdiv2D_edgeOrg_const_int_Point2fX(self.as_raw_Subdiv2D(), edge, orgpt, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Returns the edge origin.
		/// 
		/// ## Parameters
		/// * edge: Subdivision edge ID.
		/// * orgpt: Output vertex location.
		/// 
		/// ## Returns
		/// vertex ID.
		/// 
		/// ## Note
		/// This alternative version of [Subdiv2DTraitConst::edge_org] function uses the following default values for its arguments:
		/// * orgpt: 0
		#[inline]
		fn edge_org_def(&self, edge: i32) -> Result<i32> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_Subdiv2D_edgeOrg_const_int(self.as_raw_Subdiv2D(), edge, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Returns the edge destination.
		/// 
		/// ## Parameters
		/// * edge: Subdivision edge ID.
		/// * dstpt: Output vertex location.
		/// 
		/// ## Returns
		/// vertex ID.
		/// 
		/// ## C++ default parameters
		/// * dstpt: 0
		#[inline]
		fn edge_dst(&self, edge: i32, dstpt: &mut core::Point2f) -> Result<i32> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_Subdiv2D_edgeDst_const_int_Point2fX(self.as_raw_Subdiv2D(), edge, dstpt, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Returns the edge destination.
		/// 
		/// ## Parameters
		/// * edge: Subdivision edge ID.
		/// * dstpt: Output vertex location.
		/// 
		/// ## Returns
		/// vertex ID.
		/// 
		/// ## Note
		/// This alternative version of [Subdiv2DTraitConst::edge_dst] function uses the following default values for its arguments:
		/// * dstpt: 0
		#[inline]
		fn edge_dst_def(&self, edge: i32) -> Result<i32> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_Subdiv2D_edgeDst_const_int(self.as_raw_Subdiv2D(), edge, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
	}
	
	/// Mutable methods for [crate::imgproc::Subdiv2D]
	pub trait Subdiv2DTrait: crate::imgproc::Subdiv2DTraitConst {
		fn as_raw_mut_Subdiv2D(&mut self) -> *mut c_void;
	
		/// Creates a new empty Delaunay subdivision
		/// 
		/// ## Parameters
		/// * rect: Rectangle that includes all of the 2D points that are to be added to the subdivision.
		#[inline]
		fn init_delaunay(&mut self, rect: core::Rect) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_Subdiv2D_initDelaunay_Rect(self.as_raw_mut_Subdiv2D(), rect.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Insert a single point into a Delaunay triangulation.
		/// 
		/// ## Parameters
		/// * pt: Point to insert.
		/// 
		/// The function inserts a single point into a subdivision and modifies the subdivision topology
		/// appropriately. If a point with the same coordinates exists already, no new point is added.
		/// ## Returns
		/// the ID of the point.
		/// 
		/// 
		/// Note: If the point is outside of the triangulation specified rect a runtime error is raised.
		#[inline]
		fn insert(&mut self, pt: core::Point2f) -> Result<i32> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_Subdiv2D_insert_Point2f(self.as_raw_mut_Subdiv2D(), pt.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Insert multiple points into a Delaunay triangulation.
		/// 
		/// ## Parameters
		/// * ptvec: Points to insert.
		/// 
		/// The function inserts a vector of points into a subdivision and modifies the subdivision topology
		/// appropriately.
		#[inline]
		fn insert_multiple(&mut self, ptvec: &core::Vector<core::Point2f>) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_Subdiv2D_insert_const_vectorLPoint2fGR(self.as_raw_mut_Subdiv2D(), ptvec.as_raw_VectorOfPoint2f(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Returns the location of a point within a Delaunay triangulation.
		/// 
		/// ## Parameters
		/// * pt: Point to locate.
		/// * edge: Output edge that the point belongs to or is located to the right of it.
		/// * vertex: Optional output vertex the input point coincides with.
		/// 
		/// The function locates the input point within the subdivision and gives one of the triangle edges
		/// or vertices.
		/// 
		/// ## Returns
		/// an integer which specify one of the following five cases for point location:
		/// *  The point falls into some facet. The function returns [PTLOC_INSIDE] and edge will contain one of
		///    edges of the facet.
		/// *  The point falls onto the edge. The function returns [PTLOC_ON_EDGE] and edge will contain this edge.
		/// *  The point coincides with one of the subdivision vertices. The function returns [PTLOC_VERTEX] and
		///    vertex will contain a pointer to the vertex.
		/// *  The point is outside the subdivision reference rectangle. The function returns [PTLOC_OUTSIDE_RECT]
		///    and no pointers are filled.
		/// *  One of input arguments is invalid. A runtime error is raised or, if silent or "parent" error
		///    processing mode is selected, [PTLOC_ERROR] is returned.
		#[inline]
		fn locate(&mut self, pt: core::Point2f, edge: &mut i32, vertex: &mut i32) -> Result<i32> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_Subdiv2D_locate_Point2f_intR_intR(self.as_raw_mut_Subdiv2D(), pt.opencv_as_extern(), edge, vertex, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Finds the subdivision vertex closest to the given point.
		/// 
		/// ## Parameters
		/// * pt: Input point.
		/// * nearestPt: Output subdivision vertex point.
		/// 
		/// The function is another function that locates the input point within the subdivision. It finds the
		/// subdivision vertex that is the closest to the input point. It is not necessarily one of vertices
		/// of the facet containing the input point, though the facet (located using locate() ) is used as a
		/// starting point.
		/// 
		/// ## Returns
		/// vertex ID.
		/// 
		/// ## C++ default parameters
		/// * nearest_pt: 0
		#[inline]
		fn find_nearest(&mut self, pt: core::Point2f, nearest_pt: &mut core::Point2f) -> Result<i32> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_Subdiv2D_findNearest_Point2f_Point2fX(self.as_raw_mut_Subdiv2D(), pt.opencv_as_extern(), nearest_pt, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Finds the subdivision vertex closest to the given point.
		/// 
		/// ## Parameters
		/// * pt: Input point.
		/// * nearestPt: Output subdivision vertex point.
		/// 
		/// The function is another function that locates the input point within the subdivision. It finds the
		/// subdivision vertex that is the closest to the input point. It is not necessarily one of vertices
		/// of the facet containing the input point, though the facet (located using locate() ) is used as a
		/// starting point.
		/// 
		/// ## Returns
		/// vertex ID.
		/// 
		/// ## Note
		/// This alternative version of [Subdiv2DTrait::find_nearest] function uses the following default values for its arguments:
		/// * nearest_pt: 0
		#[inline]
		fn find_nearest_def(&mut self, pt: core::Point2f) -> Result<i32> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_Subdiv2D_findNearest_Point2f(self.as_raw_mut_Subdiv2D(), pt.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Returns a list of all Voronoi facets.
		/// 
		/// ## Parameters
		/// * idx: Vector of vertices IDs to consider. For all vertices you can pass empty vector.
		/// * facetList: Output vector of the Voronoi facets.
		/// * facetCenters: Output vector of the Voronoi facets center points.
		#[inline]
		fn get_voronoi_facet_list(&mut self, idx: &core::Vector<i32>, facet_list: &mut core::Vector<core::Vector<core::Point2f>>, facet_centers: &mut core::Vector<core::Point2f>) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_Subdiv2D_getVoronoiFacetList_const_vectorLintGR_vectorLvectorLPoint2fGGR_vectorLPoint2fGR(self.as_raw_mut_Subdiv2D(), idx.as_raw_VectorOfi32(), facet_list.as_raw_mut_VectorOfVectorOfPoint2f(), facet_centers.as_raw_mut_VectorOfPoint2f(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
	}
	
	pub struct Subdiv2D {
		ptr: *mut c_void
	}
	
	opencv_type_boxed! { Subdiv2D }
	
	impl Drop for Subdiv2D {
		#[inline]
		fn drop(&mut self) {
			unsafe { sys::cv_Subdiv2D_delete(self.as_raw_mut_Subdiv2D()) };
		}
	}
	
	unsafe impl Send for Subdiv2D {}
	
	impl crate::imgproc::Subdiv2DTraitConst for Subdiv2D {
		#[inline] fn as_raw_Subdiv2D(&self) -> *const c_void { self.as_raw() }
	}
	
	impl crate::imgproc::Subdiv2DTrait for Subdiv2D {
		#[inline] fn as_raw_mut_Subdiv2D(&mut self) -> *mut c_void { self.as_raw_mut() }
	}
	
	impl Subdiv2D {
		/// creates an empty Subdiv2D object.
		/// To create a new empty Delaunay subdivision you need to use the [init_delaunay] function.
		#[inline]
		pub fn default() -> Result<crate::imgproc::Subdiv2D> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_Subdiv2D_Subdiv2D(ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			let ret = unsafe { crate::imgproc::Subdiv2D::opencv_from_extern(ret) };
			Ok(ret)
		}
		
		/// creates an empty Subdiv2D object.
		/// To create a new empty Delaunay subdivision you need to use the [init_delaunay] function.
		/// 
		/// ## Overloaded parameters
		/// 
		/// 
		/// ## Parameters
		/// * rect: Rectangle that includes all of the 2D points that are to be added to the subdivision.
		/// 
		/// The function creates an empty Delaunay subdivision where 2D points can be added using the function
		/// insert() . All of the points to be added must be within the specified rectangle, otherwise a runtime
		/// error is raised.
		#[inline]
		pub fn new(rect: core::Rect) -> Result<crate::imgproc::Subdiv2D> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_Subdiv2D_Subdiv2D_Rect(rect.opencv_as_extern(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			let ret = unsafe { crate::imgproc::Subdiv2D::opencv_from_extern(ret) };
			Ok(ret)
		}
		
	}
	
	impl std::fmt::Debug for Subdiv2D {
		#[inline]
		fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
			f.debug_struct("Subdiv2D")
				.finish()
		}
	}
	
	/// Constant methods for [crate::imgproc::IntelligentScissorsMB]
	pub trait IntelligentScissorsMBTraitConst {
		fn as_raw_IntelligentScissorsMB(&self) -> *const c_void;
	
		/// Extracts optimal contour for the given target point on the image
		/// 
		/// 
		/// Note: buildMap() must be called before this call
		/// 
		/// ## Parameters
		/// * targetPt: The target point
		/// * contour:[out] The list of pixels which contains optimal path between the source and the target points of the image. Type is CV_32SC2 (compatible with `std::vector<Point>`)
		/// * backward: Flag to indicate reverse order of retrived pixels (use "true" value to fetch points from the target to the source point)
		/// 
		/// ## C++ default parameters
		/// * backward: false
		#[inline]
		fn get_contour(&self, target_pt: core::Point, contour: &mut impl core::ToOutputArray, backward: bool) -> Result<()> {
			output_array_arg!(contour);
			return_send!(via ocvrs_return);
			unsafe { sys::cv_segmentation_IntelligentScissorsMB_getContour_const_const_PointR_const__OutputArrayR_bool(self.as_raw_IntelligentScissorsMB(), &target_pt, contour.as_raw__OutputArray(), backward, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
		/// Extracts optimal contour for the given target point on the image
		/// 
		/// 
		/// Note: buildMap() must be called before this call
		/// 
		/// ## Parameters
		/// * targetPt: The target point
		/// * contour:[out] The list of pixels which contains optimal path between the source and the target points of the image. Type is CV_32SC2 (compatible with `std::vector<Point>`)
		/// * backward: Flag to indicate reverse order of retrived pixels (use "true" value to fetch points from the target to the source point)
		/// 
		/// ## Note
		/// This alternative version of [IntelligentScissorsMBTraitConst::get_contour] function uses the following default values for its arguments:
		/// * backward: false
		#[inline]
		fn get_contour_def(&self, target_pt: core::Point, contour: &mut impl core::ToOutputArray) -> Result<()> {
			output_array_arg!(contour);
			return_send!(via ocvrs_return);
			unsafe { sys::cv_segmentation_IntelligentScissorsMB_getContour_const_const_PointR_const__OutputArrayR(self.as_raw_IntelligentScissorsMB(), &target_pt, contour.as_raw__OutputArray(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
	}
	
	/// Mutable methods for [crate::imgproc::IntelligentScissorsMB]
	pub trait IntelligentScissorsMBTrait: crate::imgproc::IntelligentScissorsMBTraitConst {
		fn as_raw_mut_IntelligentScissorsMB(&mut self) -> *mut c_void;
	
		/// Specify weights of feature functions
		/// 
		/// Consider keeping weights normalized (sum of weights equals to 1.0)
		/// Discrete dynamic programming (DP) goal is minimization of costs between pixels.
		/// 
		/// ## Parameters
		/// * weight_non_edge: Specify cost of non-edge pixels (default: 0.43f)
		/// * weight_gradient_direction: Specify cost of gradient direction function (default: 0.43f)
		/// * weight_gradient_magnitude: Specify cost of gradient magnitude function (default: 0.14f)
		#[inline]
		fn set_weights(&mut self, weight_non_edge: f32, weight_gradient_direction: f32, weight_gradient_magnitude: f32) -> Result<crate::imgproc::IntelligentScissorsMB> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_segmentation_IntelligentScissorsMB_setWeights_float_float_float(self.as_raw_mut_IntelligentScissorsMB(), weight_non_edge, weight_gradient_direction, weight_gradient_magnitude, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			let ret = unsafe { crate::imgproc::IntelligentScissorsMB::opencv_from_extern(ret) };
			Ok(ret)
		}
		
		/// Specify gradient magnitude max value threshold
		/// 
		/// Zero limit value is used to disable gradient magnitude thresholding (default behavior, as described in original article).
		/// Otherwize pixels with `gradient magnitude >= threshold` have zero cost.
		/// 
		/// 
		/// Note: Thresholding should be used for images with irregular regions (to avoid stuck on parameters from high-contract areas, like embedded logos).
		/// 
		/// ## Parameters
		/// * gradient_magnitude_threshold_max: Specify gradient magnitude max value threshold (default: 0, disabled)
		/// 
		/// ## C++ default parameters
		/// * gradient_magnitude_threshold_max: 0.0f
		#[inline]
		fn set_gradient_magnitude_max_limit(&mut self, gradient_magnitude_threshold_max: f32) -> Result<crate::imgproc::IntelligentScissorsMB> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_segmentation_IntelligentScissorsMB_setGradientMagnitudeMaxLimit_float(self.as_raw_mut_IntelligentScissorsMB(), gradient_magnitude_threshold_max, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			let ret = unsafe { crate::imgproc::IntelligentScissorsMB::opencv_from_extern(ret) };
			Ok(ret)
		}
		
		/// Specify gradient magnitude max value threshold
		/// 
		/// Zero limit value is used to disable gradient magnitude thresholding (default behavior, as described in original article).
		/// Otherwize pixels with `gradient magnitude >= threshold` have zero cost.
		/// 
		/// 
		/// Note: Thresholding should be used for images with irregular regions (to avoid stuck on parameters from high-contract areas, like embedded logos).
		/// 
		/// ## Parameters
		/// * gradient_magnitude_threshold_max: Specify gradient magnitude max value threshold (default: 0, disabled)
		/// 
		/// ## Note
		/// This alternative version of [IntelligentScissorsMBTrait::set_gradient_magnitude_max_limit] function uses the following default values for its arguments:
		/// * gradient_magnitude_threshold_max: 0.0f
		#[inline]
		fn set_gradient_magnitude_max_limit_def(&mut self) -> Result<crate::imgproc::IntelligentScissorsMB> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_segmentation_IntelligentScissorsMB_setGradientMagnitudeMaxLimit(self.as_raw_mut_IntelligentScissorsMB(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			let ret = unsafe { crate::imgproc::IntelligentScissorsMB::opencv_from_extern(ret) };
			Ok(ret)
		}
		
		/// Switch to "Laplacian Zero-Crossing" edge feature extractor and specify its parameters
		/// 
		/// This feature extractor is used by default according to article.
		/// 
		/// Implementation has additional filtering for regions with low-amplitude noise.
		/// This filtering is enabled through parameter of minimal gradient amplitude (use some small value 4, 8, 16).
		/// 
		/// 
		/// Note: Current implementation of this feature extractor is based on processing of grayscale images (color image is converted to grayscale image first).
		/// 
		/// 
		/// Note: Canny edge detector is a bit slower, but provides better results (especially on color images): use setEdgeFeatureCannyParameters().
		/// 
		/// ## Parameters
		/// * gradient_magnitude_min_value: Minimal gradient magnitude value for edge pixels (default: 0, check is disabled)
		/// 
		/// ## C++ default parameters
		/// * gradient_magnitude_min_value: 0.0f
		#[inline]
		fn set_edge_feature_zero_crossing_parameters(&mut self, gradient_magnitude_min_value: f32) -> Result<crate::imgproc::IntelligentScissorsMB> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_segmentation_IntelligentScissorsMB_setEdgeFeatureZeroCrossingParameters_float(self.as_raw_mut_IntelligentScissorsMB(), gradient_magnitude_min_value, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			let ret = unsafe { crate::imgproc::IntelligentScissorsMB::opencv_from_extern(ret) };
			Ok(ret)
		}
		
		/// Switch to "Laplacian Zero-Crossing" edge feature extractor and specify its parameters
		/// 
		/// This feature extractor is used by default according to article.
		/// 
		/// Implementation has additional filtering for regions with low-amplitude noise.
		/// This filtering is enabled through parameter of minimal gradient amplitude (use some small value 4, 8, 16).
		/// 
		/// 
		/// Note: Current implementation of this feature extractor is based on processing of grayscale images (color image is converted to grayscale image first).
		/// 
		/// 
		/// Note: Canny edge detector is a bit slower, but provides better results (especially on color images): use setEdgeFeatureCannyParameters().
		/// 
		/// ## Parameters
		/// * gradient_magnitude_min_value: Minimal gradient magnitude value for edge pixels (default: 0, check is disabled)
		/// 
		/// ## Note
		/// This alternative version of [IntelligentScissorsMBTrait::set_edge_feature_zero_crossing_parameters] function uses the following default values for its arguments:
		/// * gradient_magnitude_min_value: 0.0f
		#[inline]
		fn set_edge_feature_zero_crossing_parameters_def(&mut self) -> Result<crate::imgproc::IntelligentScissorsMB> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_segmentation_IntelligentScissorsMB_setEdgeFeatureZeroCrossingParameters(self.as_raw_mut_IntelligentScissorsMB(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			let ret = unsafe { crate::imgproc::IntelligentScissorsMB::opencv_from_extern(ret) };
			Ok(ret)
		}
		
		/// Switch edge feature extractor to use Canny edge detector
		/// 
		/// 
		/// Note: "Laplacian Zero-Crossing" feature extractor is used by default (following to original article)
		/// ## See also
		/// Canny
		/// 
		/// ## C++ default parameters
		/// * aperture_size: 3
		/// * l2gradient: false
		#[inline]
		fn set_edge_feature_canny_parameters(&mut self, threshold1: f64, threshold2: f64, aperture_size: i32, l2gradient: bool) -> Result<crate::imgproc::IntelligentScissorsMB> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_segmentation_IntelligentScissorsMB_setEdgeFeatureCannyParameters_double_double_int_bool(self.as_raw_mut_IntelligentScissorsMB(), threshold1, threshold2, aperture_size, l2gradient, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			let ret = unsafe { crate::imgproc::IntelligentScissorsMB::opencv_from_extern(ret) };
			Ok(ret)
		}
		
		/// Switch edge feature extractor to use Canny edge detector
		/// 
		/// 
		/// Note: "Laplacian Zero-Crossing" feature extractor is used by default (following to original article)
		/// ## See also
		/// Canny
		/// 
		/// ## Note
		/// This alternative version of [IntelligentScissorsMBTrait::set_edge_feature_canny_parameters] function uses the following default values for its arguments:
		/// * aperture_size: 3
		/// * l2gradient: false
		#[inline]
		fn set_edge_feature_canny_parameters_def(&mut self, threshold1: f64, threshold2: f64) -> Result<crate::imgproc::IntelligentScissorsMB> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_segmentation_IntelligentScissorsMB_setEdgeFeatureCannyParameters_double_double(self.as_raw_mut_IntelligentScissorsMB(), threshold1, threshold2, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			let ret = unsafe { crate::imgproc::IntelligentScissorsMB::opencv_from_extern(ret) };
			Ok(ret)
		}
		
		/// Specify input image and extract image features
		/// 
		/// ## Parameters
		/// * image: input image. Type is [CV_8UC1] / #CV_8UC3
		#[inline]
		fn apply_image(&mut self, image: &impl core::ToInputArray) -> Result<crate::imgproc::IntelligentScissorsMB> {
			input_array_arg!(image);
			return_send!(via ocvrs_return);
			unsafe { sys::cv_segmentation_IntelligentScissorsMB_applyImage_const__InputArrayR(self.as_raw_mut_IntelligentScissorsMB(), image.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			let ret = unsafe { crate::imgproc::IntelligentScissorsMB::opencv_from_extern(ret) };
			Ok(ret)
		}
		
		/// Specify custom features of input image
		/// 
		/// Customized advanced variant of applyImage() call.
		/// 
		/// ## Parameters
		/// * non_edge: Specify cost of non-edge pixels. Type is CV_8UC1. Expected values are `{0, 1}`.
		/// * gradient_direction: Specify gradient direction feature. Type is CV_32FC2. Values are expected to be normalized: `x^2 + y^2 == 1`
		/// * gradient_magnitude: Specify cost of gradient magnitude function: Type is CV_32FC1. Values should be in range `[0, 1]`.
		/// * image: **Optional parameter**. Must be specified if subset of features is specified (non-specified features are calculated internally)
		/// 
		/// ## C++ default parameters
		/// * image: noArray()
		#[inline]
		fn apply_image_features(&mut self, non_edge: &impl core::ToInputArray, gradient_direction: &impl core::ToInputArray, gradient_magnitude: &impl core::ToInputArray, image: &impl core::ToInputArray) -> Result<crate::imgproc::IntelligentScissorsMB> {
			input_array_arg!(non_edge);
			input_array_arg!(gradient_direction);
			input_array_arg!(gradient_magnitude);
			input_array_arg!(image);
			return_send!(via ocvrs_return);
			unsafe { sys::cv_segmentation_IntelligentScissorsMB_applyImageFeatures_const__InputArrayR_const__InputArrayR_const__InputArrayR_const__InputArrayR(self.as_raw_mut_IntelligentScissorsMB(), non_edge.as_raw__InputArray(), gradient_direction.as_raw__InputArray(), gradient_magnitude.as_raw__InputArray(), image.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			let ret = unsafe { crate::imgproc::IntelligentScissorsMB::opencv_from_extern(ret) };
			Ok(ret)
		}
		
		/// Specify custom features of input image
		/// 
		/// Customized advanced variant of applyImage() call.
		/// 
		/// ## Parameters
		/// * non_edge: Specify cost of non-edge pixels. Type is CV_8UC1. Expected values are `{0, 1}`.
		/// * gradient_direction: Specify gradient direction feature. Type is CV_32FC2. Values are expected to be normalized: `x^2 + y^2 == 1`
		/// * gradient_magnitude: Specify cost of gradient magnitude function: Type is CV_32FC1. Values should be in range `[0, 1]`.
		/// * image: **Optional parameter**. Must be specified if subset of features is specified (non-specified features are calculated internally)
		/// 
		/// ## Note
		/// This alternative version of [IntelligentScissorsMBTrait::apply_image_features] function uses the following default values for its arguments:
		/// * image: noArray()
		#[inline]
		fn apply_image_features_def(&mut self, non_edge: &impl core::ToInputArray, gradient_direction: &impl core::ToInputArray, gradient_magnitude: &impl core::ToInputArray) -> Result<crate::imgproc::IntelligentScissorsMB> {
			input_array_arg!(non_edge);
			input_array_arg!(gradient_direction);
			input_array_arg!(gradient_magnitude);
			return_send!(via ocvrs_return);
			unsafe { sys::cv_segmentation_IntelligentScissorsMB_applyImageFeatures_const__InputArrayR_const__InputArrayR_const__InputArrayR(self.as_raw_mut_IntelligentScissorsMB(), non_edge.as_raw__InputArray(), gradient_direction.as_raw__InputArray(), gradient_magnitude.as_raw__InputArray(), ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			let ret = unsafe { crate::imgproc::IntelligentScissorsMB::opencv_from_extern(ret) };
			Ok(ret)
		}
		
		/// Prepares a map of optimal paths for the given source point on the image
		/// 
		/// 
		/// Note: applyImage() / applyImageFeatures() must be called before this call
		/// 
		/// ## Parameters
		/// * sourcePt: The source point used to find the paths
		#[inline]
		fn build_map(&mut self, source_pt: core::Point) -> Result<()> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_segmentation_IntelligentScissorsMB_buildMap_const_PointR(self.as_raw_mut_IntelligentScissorsMB(), &source_pt, ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			Ok(ret)
		}
		
	}
	
	/// Intelligent Scissors image segmentation
	/// 
	/// This class is used to find the path (contour) between two points
	/// which can be used for image segmentation.
	/// 
	/// Usage example:
	/// [usage_example_intelligent_scissors](https://github.com/opencv/opencv/blob/4.8.1/samples/cpp/tutorial_code/snippets/imgproc_segmentation.cpp#L1)
	/// 
	/// Reference: <a href="http://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.138.3811&rep=rep1&type=pdf">"Intelligent Scissors for Image Composition"</a>
	/// algorithm designed by Eric N. Mortensen and William A. Barrett, Brigham Young University
	/// [Mortensen95intelligentscissors](https://docs.opencv.org/4.8.1/d0/de3/citelist.html#CITEREF_Mortensen95intelligentscissors)
	pub struct IntelligentScissorsMB {
		ptr: *mut c_void
	}
	
	opencv_type_boxed! { IntelligentScissorsMB }
	
	impl Drop for IntelligentScissorsMB {
		#[inline]
		fn drop(&mut self) {
			unsafe { sys::cv_segmentation_IntelligentScissorsMB_delete(self.as_raw_mut_IntelligentScissorsMB()) };
		}
	}
	
	unsafe impl Send for IntelligentScissorsMB {}
	
	impl crate::imgproc::IntelligentScissorsMBTraitConst for IntelligentScissorsMB {
		#[inline] fn as_raw_IntelligentScissorsMB(&self) -> *const c_void { self.as_raw() }
	}
	
	impl crate::imgproc::IntelligentScissorsMBTrait for IntelligentScissorsMB {
		#[inline] fn as_raw_mut_IntelligentScissorsMB(&mut self) -> *mut c_void { self.as_raw_mut() }
	}
	
	impl IntelligentScissorsMB {
		#[inline]
		pub fn default() -> Result<crate::imgproc::IntelligentScissorsMB> {
			return_send!(via ocvrs_return);
			unsafe { sys::cv_segmentation_IntelligentScissorsMB_IntelligentScissorsMB(ocvrs_return.as_mut_ptr()) };
			return_receive!(unsafe ocvrs_return => ret);
			let ret = ret.into_result()?;
			let ret = unsafe { crate::imgproc::IntelligentScissorsMB::opencv_from_extern(ret) };
			Ok(ret)
		}
		
	}
	
	impl Clone for IntelligentScissorsMB {
		#[inline]
		fn clone(&self) -> Self {
			unsafe { Self::from_raw(sys::cv_segmentation_IntelligentScissorsMB_implicitClone_const(self.as_raw_IntelligentScissorsMB())) }
		}
	}
	
	impl std::fmt::Debug for IntelligentScissorsMB {
		#[inline]
		fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
			f.debug_struct("IntelligentScissorsMB")
				.finish()
		}
	}
}