Chessboard Pdf Open Cv Face Detection
Note
Opencv: Best way to detect corners on chessboard. Ask Question. Up vote 11 down vote favorite. OpenCV: solvePnP detection problems. Opencv detect cubes (corners) 0. OpenCV algorithm output index. Best practice for chessboard recognition quality measure. Camera calibration with square chessboard. Mat img = imread (argv [1], CV_LOAD_IMAGE_GRAYSCALE); Detect a chessboard in this image using findChessboard function.
We assume that by now you have already read the previous tutorials. If not, please check previous tutorials at http://polito-java-opencv-tutorials.readthedocs.org/en/latest/index.html. You can also find the source code and resources at https://github.com/java-opencv/Polito-Java-OpenCV-Tutorials-Source-Code
Goal¶
The goal of this tutorial is to learn how to calibrate a camera given a set of chessboard images.
What is the camera calibration?¶
The camera calibration is the process with which we can obtain the camera parameters such as intrinsic and extrinsic parameters, distortions and so on. The calibration of the camera is often necessary when the alignment between the lens and the optic sensors chip is not correct; the effect produced by this wrong alignment is usually more visible in low quality cameras.
Calibration Pattern¶
Open Cv Group
As we said earlier we are going to need some sort of pattern that the program can recognize in order to make the calibration work. The pattern that we are going to use is a chessboard image.
The reason why we use this image is because there are some OpenCV functions that can recognize this pattern and draw a scheme which highlights the intersections between each block.To make the calibration work you need to print the chessboard image and show it to the cam; it is important to maintain the sheet still, better if stick to a surface.In order to make a good calibration, we need to have about 20 samples of the pattern taken from different angles and distances.
What we will do in this tutorial¶
- Create some TextEdit field to give some inputs to our program
- Recognize the pattern using some OpenCV functions
- Calibrate and show the video stream.
Getting Started¶
Create a new JavaFX project (e.g. “CameraCalibration”) with the usual OpenCV user library.Open Scene Builder and add a Border Pane with:
- on TOP we need to have the possibility to set the number of samples for the calibration, the number of horizontal corners we have in the test image, the number of vertical corners we have in the test image and a button to update this data. To make things cleaner let’s put all these elements inside a HBox.
Let’s also add some labels before each text fields.Each text field is going to need an id, and let’s put a standard value for them already.
For the button instead, set the id and a method for the onAction field:
- on the LEFT add an ImageView inside a VBox for the normal cam stream; set an id for it.
- on the RIGHT add an ImageView inside a VBox for the calibrated cam stream; set an id for it.
- in the BOTTOM add a start/stop cam stream button and a snapshot button inside a HBox; set an id and a action method for each one.
Your GUI will look something like this:
Pattern Recognition¶
The calibration process consists on showing to the cam the chessboard pattern from different angles, depth and points of view. For each recognized pattern we need to track:
some reference system’s 3D point where the chessboard is located (let’s assume that the Z axe is always 0):
the image’s 2D points (operation made by OpenCV with findChessboardCorners):
The findChessboardCorners
function attempts to determine whether the input image is a view of the chessboard pattern and locate the internal chessboard corners.Its parameters are:
- image Source chessboard view. It must be an 8-bit grayscale or color image.
- patternSize Number of inner corners per a chessboard row and column
- corners Output array of detected corners.
- flags Various operation flags that can be zero or a combination of the following values:
CV_CALIB_CB_ADAPTIVE_THRESH
Use adaptive thresholding to convert the image to black and white, rather than a fixed threshold level (computed from the average image brightness).CV_CALIB_CB_NORMALIZE_IMAGE
Normalize the image gamma with “equalizeHist” before applying fixed or adaptive thresholding.CV_CALIB_CB_FILTER_QUADS
Use additional criteria (like contour area, perimeter, square-like shape) to filter out false quads extracted at the contour retrieval stage.CALIB_CB_FAST_CHECK
Run a fast check on the image that looks for chessboard corners, and shortcut the call if none is found. This can drastically speed up the call in the degenerate condition when no chessboard is observed.
Warning
Before doing the findChessboardCorners
convert the image to gayscale and save the board size into a Size variable:
If the recognition went well found
should be true
.
For square images the positions of the corners are only approximate. We may improve this by calling the cornerSubPix
function. It will produce better calibration result.
We can now highlight the found points on stream:
The function draws individual chessboard corners detected either as red circles if the board was not found, or as colored corners connected with lines if the board was found.
Its parameters are: Megaman zero.
- image Destination image. It must be an 8-bit color image.
- patternSize Number of inner corners per a chessboard row and column.
- corners Array of detected corners, the output of findChessboardCorners.
- patternWasFound Parameter indicating whether the complete board was found or not. The return value of
findChessboardCorners
should be passed here.
Now we can activate the Snapshot button to save the data.
We should take the set number of “snapshots” from different angles and depth, in order to make the calibration.
Note
We don’t actually save the image but just the data we need.
Saving Data¶
By clicking on the snapshot button we cal the takeSnapshot
method. Here we need to save the data (2D and 3D points) if we did not make enough sample:
Otherwise we can calibrate the camera.
Camera Calibration¶
For the camera calibration we should create initiate some needed variable and then call the actual calibration function:
The calibrateCamera
function estimates the intrinsic camera parameters and extrinsic parameters for each of the views. The algorithm is based on [Zhang2000] and [BouguetMCT]. The coordinates of 3D object points and their corresponding 2D projections in each view must be specified.Its parameters are:
- objectPoints In the new interface it is a vector of vectors of calibration pattern points in the calibration pattern coordinate space. The outer vector contains as many elements as the number of the pattern views. The points are 3D, but since they are in a pattern coordinate system, then, if the rig is planar, it may make sense to put the model to a XY coordinate plane so that Z-coordinate of each input object point is 0.
- imagePoints It is a vector of vectors of the projections of calibration pattern points.
- imageSize Size of the image used only to initialize the intrinsic camera matrix.
- cameraMatrix Output 3x3 floating-point camera matrix A = fx 0 cx 0 fy cy 0 0 1 . If
CV_CALIB_USE_INTRINSIC_GUESS
and/orCV_CALIB_FIX_ASPECT_RATIO
are specified, some or all of fx, fy, cx, cy must be initialized before calling the function. - distCoeffs Output vector of distortion coefficients of 4, 5, or 8 elements.
- rvecs Output vector of rotation vectors estimated for each pattern view. That is, each k-th rotation vector together with the corresponding k-th translation vector.
- tvecs Output vector of translation vectors estimated for each pattern view.
We ran calibration and got camera’s matrix with the distortion coefficients we may want to correct the image using undistort
function:
The undistort
function transforms an image to compensate radial and tangential lens distortion.