Cv2. StereoRectify Method (Double[,] ,Double[] ,Double[,] ,Double[] , Size,Double[,] ,Double[] ,Double[,] ,Double[,] ,Double[,] ,Double[,] ,Double[,] , StereoRectificationFlag, Double, Size, Rect, Rect) OpenCvSharp Class Library
computes the rectification transformation for a stereo camera from its intrinsic and extrinsic parameters

Namespace:  OpenCvSharp.CPlusPlus
Assembly:  OpenCvSharp.CPlusPlus (in OpenCvSharp.CPlusPlus.dll) Version: 1.0.0.0 (1.0.0.0)
Syntax

public static void StereoRectify(
	double[,] cameraMatrix1,
	double[] distCoeffs1,
	double[,] cameraMatrix2,
	double[] distCoeffs2,
	Size imageSize,
	double[,] R,
	double[] T,
	out double[,] R1,
	out double[,] R2,
	out double[,] P1,
	out double[,] P2,
	out double[,] Q,
	StereoRectificationFlag flags,
	double alpha,
	Size newImageSize,
	out Rect validPixROI1,
	out Rect validPixROI2
)

Parameters

cameraMatrix1
Type:System.Double[,]
First camera matrix.
distCoeffs1
Type:System.Double[]
First camera distortion parameters.
cameraMatrix2
Type:System.Double[,]
Second camera matrix.
distCoeffs2
Type:System.Double[]
Second camera distortion parameters.
imageSize
Type: OpenCvSharp.CPlusPlus.Size
Size of the image used for stereo calibration.
R
Type:System.Double[,]
Rotation matrix between the coordinate systems of the first and the second cameras.
T
Type:System.Double[]
Translation vector between coordinate systems of the cameras.
R1
Type:System.Double[,]
Output 3x3 rectification transform (rotation matrix) for the first camera.
R2
Type:System.Double[,]
Output 3x3 rectification transform (rotation matrix) for the second camera.
P1
Type:System.Double[,]
Output 3x4 projection matrix in the new (rectified) coordinate systems for the first camera.
P2
Type:System.Double[,]
Output 3x4 projection matrix in the new (rectified) coordinate systems for the second camera.
Q
Type:System.Double[,]
Output 4x4 disparity-to-depth mapping matrix (see reprojectImageTo3D() ).
flags
Type: OpenCvSharp.StereoRectificationFlag
Operation flags that may be zero or CV_CALIB_ZERO_DISPARITY. If the flag is set, the function makes the principal points of each camera have the same pixel coordinates in the rectified views. And if the flag is not set, the function may still shift the images in the horizontal or vertical direction (depending on the orientation of epipolar lines) to maximize the useful image area.
alpha
Type: System.Double
Free scaling parameter. If it is -1 or absent, the function performs the default scaling. Otherwise, the parameter should be between 0 and 1. alpha=0 means that the rectified images are zoomed and shifted so that only valid pixels are visible (no black areas after rectification). alpha=1 means that the rectified image is decimated and shifted so that all the pixels from the original images from the cameras are retained in the rectified images (no source image pixels are lost). Obviously, any intermediate value yields an intermediate result between those two extreme cases.
newImageSize
Type: OpenCvSharp.CPlusPlus.Size
New image resolution after rectification. The same size should be passed to initUndistortRectifyMap(). When (0,0) is passed (default), it is set to the original imageSize . Setting it to larger value can help you preserve details in the original image, especially when there is a big radial distortion.
validPixROI1
Type: OpenCvSharp.CPlusPlus.Rect
Optional output rectangles inside the rectified images where all the pixels are valid. If alpha=0 , the ROIs cover the whole images. Otherwise, they are likely to be smaller.
validPixROI2
Type: OpenCvSharp.CPlusPlus.Rect
Optional output rectangles inside the rectified images where all the pixels are valid. If alpha=0 , the ROIs cover the whole images. Otherwise, they are likely to be smaller.
See Also

Reference