METHOD FOR ADAPTIVELY DETECTING CHESSBOARD SUB-PIXEL LEVEL CORNER POINTS

Information

  • Patent Application
  • 20220198712
  • Publication Number
    20220198712
  • Date Filed
    March 05, 2020
    4 years ago
  • Date Published
    June 23, 2022
    2 years ago
Abstract
The present invention discloses a method for adaptively detecting chessboard sub-pixel level corner points. Adaptive detection of chessboard sub-pixel level corner points is completed by marking position of an initial unit grid on a chessboard, using a homography matrix H calculated by pixel coordinates of four corner points of the initial unit grid in a pixel coordinate system and world coordinates in a world coordinate system to expand outwards, adaptively adjusting size of an iteration window in the process of expanding outwards, and finally spreading to the whole chessboard region.
Description
TECHNICAL FIELD

The present invention belongs to the field of image processing and computer vision, and particularly relates to a method for adaptively detecting chessboard sub-pixel level corner points.


BACKGROUND

As a kind of special corner points, chessboard corner points are widely used in camera calibration and play an important role. Chessboard patterns are widely used for camera calibration because of obvious contrast, simple features, and easy detection and recognition. At the same time, the calibration accuracy of internal and external parameters of a camera is directly determined by the accuracy of chessboard corner point detection, and the accuracy of subsequent image processing tasks is directly determined by the accuracy of the calibrated parameters of the camera. Therefore, improving the accuracy of corner point detection of chessboard images is an important topic in the field of vision measurement.


According to the implementation mode, the existing corner point detection methods are generally divided into three categories: methods based on gray intensity, methods based on edge contour, and methods based on corner point models. The methods based on gray intensity are mainly to detect corner points by checking the variance in local gray value of images; the methods based on edge contour are mainly to detect corner points by analyzing the edge shape characteristics of images; and the basic framework of the methods based on corner point models is to match and filter images by building different types of corner point parameterization models.


However, none of the above-mentioned methods can completely cover the whole angle of field of the camera with a chessboard image or extract feature points of edge area by the chessboard image, so that the calibrated internal and external parameters of the camera are certainly not accurate. At the same time, for a chessboard image shot in a complex illumination condition, the situations of chessboard corner point wrong detection and missing detection may occur. For a chessboard image with low resolution or large distortion, improper size of an iteration window for calculating sub-pixel level corner points will lead to wrong or unstable position detection of the sub-pixel level corner points.


SUMMARY

The present invention aims to overcome the defects of the existing chessboard corner point detection technology and proposes a method for adaptively detecting chessboard sub-pixel level corner points, i.e., detection of sub-pixel level corner points is completed by setting marks on a chessboard to mark position of an initial unit grid, determining pixel coordinates of four corner points of the initial unit grid, using a homography matrix H calculated by the pixel coordinates of the four corner points of the initial unit grid in a pixel coordinate system and manually set world coordinates in a world coordinate system to expand outwards, adaptively adjusting size of an iteration window in the process of expanding outwards, and finally spreading to the whole chessboard region.


The present invention has the following specific technical solution: a method for adaptively detecting chessboard sub-pixel level corner points, comprising the following steps:


1) Setting marks: setting marks on a chessboard to mark position of an initial unit grid;


2) Shooting an image: using a camera to collect an image of a chessboard calibration target, and conducting preliminary image processing;


3) Detecting the marks: detecting pixel coordinates of the marks set in step 1) by a mark detection algorithm;


4) Using the marks: calculating pixel coordinates of four corner points of the initial unit grid defined by the marks according to the pixel coordinates detected in step 3), calculating sub-pixel level corner point coordinates by iteration and conducting verification;


5) Expanding outwards: calculating a homography matrix H according to the sub-pixel level corner point coordinates of the four corner points in step 4) and world coordinates thereof in a world coordinate system; multiplying the homography matrix H with world coordinates of four corner points of an adjacent unit grid of the marked unit grid in the world coordinate system to calculate sub-pixel level corner point coordinates of the other two unknown corner points of the adjacent unit grid; and


6) Adaptively adjusting: counting side lengths of the adjacent unit grid obtained in the process of expanding outwards in step 5), and dynamically adjusting size of an iteration window for calculating sub-pixel level corner points to increase accuracy of sub-pixel level corner point detection.


Step 2) “shooting an image” comprises the following specific steps:


Conducting gray processing and binarization operation to the image after the image is shot; due to light and shadow, the effect directly using Otsu's method is not very ideal, so dividing an image I into M*N blocks by block binarization method, with each block named Ii; as and using Otsu's method for each Ii to obtain a binarization image binary_I.


Step 4) comprises the following specific steps:


4-1) Calculating coordinates of four initial corner points of the unit grid defined by the marks in a pixel coordinate system according to geometrical relationship;


4-2) Letting a sub-pixel level corner point to be solved be q, then the line vector between surrounding points pi and q thereof is (pi-q); for any point pi in a search window thereof, letting the gray gradient at pi be Gi, then the following formula is obtained:






G
i*(pi−q)=0


Solving the formula by least square method:






G
i
T
G
i
q=G
i
T
G
i
p
i


i.e.:






q=(GiTGi)−1*(GiTGipi)


The coordinate of an initial corner point is an integer and is assumed to be q0, and a window is selected centering on q0; the radius win of the iteration window of the sub-pixel level corner point is obtained; each point of the window is pi; the quantity of pi is N, Gaussian weight is introduced, the weight at point pi is wi, and the coordinate q of the sub-pixel level corner point is:






q
=




i
=
0

N





(


G
i
T



G
i


)


-
1


*

(


G
i
T



G
i



w
i



p
i


)







Using sobel convolution to calculate the gray gradient Gi at point pi; for point pi:







G
i

=

[



dx


dy



]








G
i
T

=

[



dx




dy



]










G
i
T



G
i


=

[



dxdx


dxdy




dxdy


dydy



]


;




4-3) Obtaining lengths of the four sides of the initially marked unit grid through the pixel coordinates of the four corner points of the unit grid defined by the marks, naming the lengths of the four sides in the same direction (clockwise or counterclockwise) as d1, d2, d3, d4 and the corresponding included angles of every two adjacent sides as θ1, θ2, θ3, θ4 respectively; when the average value d of the four side lengths of the unit grid and the radius win of the iteration window satisfy the following fitting relation:






win
=

[



k
*

d
_


+
c



p
*

Σ

i
=
1

4




|


θ
i

-

π
2


|

4


+
b


]





the sub-pixel level corner point detected is the most accurate, wherein k and p are coefficients of first order terms, and c and b are constants; based on the known k, ρ, c, b, d and θi, the initial value of the radius win of the window is taken as w0;


4-4) Verifying the four sub-pixel level corner point coordinates; naming the lengths of the four sides of the unit grid in the same direction (clockwise or counterclockwise) as d′1, d′2, d′3, d′4, the tangents of the four sides as ϕ1, ϕ2, ϕ3, ϕ4, and the corresponding included angles of every two adjacent sides as θ′1, θ′2, θ′3, θ′4 respectively; setting parameters μ12, λ1, λ2, η1, η2, δ1 and δ2, and taking μ1111=0.9 and μ2222=1.1; the side lengths needs to satisfy that:








μ
1




d
1



d
3





μ
2


,


λ
1




d
2



d
4





λ
2


,



η
1




ϕ
1


ϕ
3





η
2






and






δ
1





ϕ
2


ϕ
4




δ
2


;





if the above relations are not satisfied, the size of the iteration window win for calculating sub-pixel level corner points shall be dynamically adjusted until the relations are satisfied.


Step 5) comprises the following specific steps:


5-1) Using the coordinates P1, P2, P3 and P4 of the four initial corner points of the initially marked unit grid; according to the imaging principle of the camera, the pixel coordinate of a projection point P in the pixel coordinate system of a point W(Xw, Yw, Zw) in the world coordinate system is (u, v), i.e.:








Z
c



[



u




v




1



]


=




[




1
dx



0



u
0





0



1
dy




v
0





0


0


1



]



[



f


0


0


0




0


f


0


0




0


0


1


0



]




[



R


T





0




1



]







[




X
w






Y
w






Z
w





1



]

=



[




f
x



0



u
0



0




0



f
y




v
0



0




0


0


1


0



]



[



R


T





0




1



]




[




X
w






Y
w






Z
w





1



]









wherein Zc is the Z-coordinate of point W in a camera coordinate system, u0 is the center coordinate of the image in x direction, v0 is the center coordinate of the image in y direction, f is a focal length, R is a rotation matrix, T is a translation vector, fx is a scale factor on u axis, fy is a scale factor on v axis, dx is a pixel size in x direction, and dy is a pixel size in y direction;


5-2) Recording Z=0 of a point in the plane of the chessboard calibration target, so:








Z
c



[



u




v




1



]


=




[




1
dx



0



u
0





0



1
dy




v
0





0


0


1



]



[



f


0


0


0




0


f


0


0




0


0


1


0



]




[




r
1




r
2




r
3



t



]







[




X
w






Y
w





0




1



]

=



[




f
x



0



u
0



0




0



f
y




v
0



0




0


0


1


0



]



[




r
1




r
2



t



]




[




X
w






Y
w





1



]









wherein r1 , r2 and r3 are three column vectors of the rotation matrix R respectively, and t is a translation vector in x and y directions;


Based on that ZcP′=HW′, letting







A
=

[




f
x



0



u
0



0




0



f
y




v
0



0




0


0


1


0



]


,




then the homography matrix H is obtained:






H=A[r
1
r
2
t]


Step 6) comprises the following specific steps:


6-1) In the process of expanding outwards, obtaining the coordinates of the other two unknown corner points of the adjacent unit grid according to the homography matrix H, obtaining the lengths of the four sides of the adjacent unit grid according to the coordinates of the two corner points, naming the lengths of the four sides in the same direction (clockwise or counterclockwise) as d1, d2, d3, d4 and the corresponding included angles of every two adjacent sides as θ1, θ2, θ3, θ4 respectively; when the average value d of the four side lengths of the unit grid and the radius win of the iteration window satisfy the following fitting relation:






win
=

[



k
*

d
¯


+
c



ρ
*




i
=
1

4







θ
i

-

π
2




4



+
b


]





the sub-pixel level corner point detected is the most accurate, wherein k and ρ are coefficients of first order teams, and c and b are constants; based on the known k, ρ, c, b, d and θi, the initial value of the radius win of the window is taken as w0;


6-2) Verifying the accuracy of the sub-pixel level corner point coordinates of the four points of the adjacent unit grid; naming the lengths of the four sides of the adjacent unit grid in the same direction (clockwise or counterclockwise) as d′1, d′2, d′3, d′4, the tangents of the four sides as ϕ1, ϕ2, ϕ3, ϕ4, and the corresponding included angles of every two adjacent sides as θ′1, θ′2, θ′3, θ′4 respectively; setting parameters μ1, μ2, λ1, λ2, η1, η2, δ1 and δ2, and taking μ1111=0.9 and μ2222=1.1; the side lengths needs to satisfy that:








μ
1




d
1



d
3





μ
2


,


λ
1




d
2



d
4





λ
2


,



η
1




ϕ
1


ϕ
3





η
2






and






δ
1





ϕ
2


ϕ
4




δ
2


;





if the above relations are not satisfied, the size of the iteration window win for calculating sub-pixel level corner points shall be dynamically adjusted until the relations are satisfied.


The present invention has the following beneficial effects: the present invention proposes a method for adaptively detecting chessboard corner points, having the following characteristics:


1. Simple procedure and easy implementation;


2. For a chessboard image with low resolution or large distortion, the size of the iteration window of sub-pixel level corner points can be dynamically adjusted, so that error rate of sub-pixel level corner point detection is reduced;


3. Corner point detection speed is high and will not be influenced by incompleteness of the chessboard, and a collected image only need to carry manually set marks; and


4. The whole angle of field of a camera can be completely covered with the chessboard image, and feature points of edge area can be extracted, so that the calibrated internal and external parameters of the camera are more accurate.





DESCRIPTION OF DRAWINGS


FIG. 1 is an overall flow chart of a solution;



FIG. 2 is a chessboard marking diagram of an embodiment;



FIG. 3 is a schematic diagram of adaptive detection of sub-pixel level corner points in an embodiment;



FIG. 4 shows results of adaptive detection of sub-pixel level corner points; and



FIG. 5 shows details of corner point detection.





DETAILED DESCRIPTION

The present invention proposes a method for adaptively detecting chessboard sub-pixel level corner points, which realizes adaptive detection of chessboard sub-pixel level corner points by six steps, i.e., setting marks, shooting an image, detecting the marks, using the marks, expanding outwards and adaptively adjusting. The present invention will be described in detail below in combination with drawings and embodiments by taking the example of setting five circles on a chessboard as marks.


1) First, a printed chessboard is required, and a calibration target can be a chessboard with five circles or a common chessboard calibration target pasted with five circles as markers. As shown in FIG. 2, the positions of the five circles are distributed in the five white unit grids of 3*3 chessboard grids in the central region of black and white chessboard, the diameters of the five circles are smaller than the side lengths of the white unit grids, the serial number of the central circle is recorded as C0, and the serial numbers of the rest four circles are recorded as C1, C2, C3 and C4.


2) The chessboard is shot by a camera until the black and white chessboard can completely cover the whole angle of field of the camera, and gray processing and binarization are respectively conducted to a collected image.


3) Taking an image I as an example, five circles in the image are detected by Hough circle detection algorithm, and pixel coordinates of the five circles are recorded. Middle points of four lines connecting the four peripheral circles C1, C2, C3 and C4 to the central circle C0 are calculated and numbered as P1, P2, P3 and P4, and the four points are used as four initial corner points. It is assumed that the side lengths of P1P2, P2P3, P3P4, P4P1 are respectively d1, d2, d3, d4, and the corresponding included angles of every two sides are respectively θ1, θ2, θ3, θ4. According to empirical formulas obtained from previous observation, when the average value d of the four side lengths of the unit grid and the radius win of the iteration window satisfy the following fitting relation:






win
=

[



k
*

d
¯


+
c



ρ
*




i
=
1

4







θ
i

-

π
2




4



+
b


]





the sub-pixel level corner point detected is the most accurate, wherein k and ρ are coefficients of first order terms, and c and b are constants. Based on the known k, ρ, c, b, d and θi, the initial value of the radius win of the window is taken as w0=7 in the embodiment.


4) After sub-pixel level corner point coordinates of the four points are calculated by iteration, the accuracy of the sub-pixel level corner point coordinates calculated need to be verified. The lengths of the four sides of the unit grid are named in the same direction (clockwise or counterclockwise) as d′1, d′2, d′3, d′4, the tangents of the four sides are named as ϕ1, ϕ2, ϕ3, ϕ4, and the corresponding included angles of every two adjacent sides are named as θ′1, θ′2, θ′3, θ′4 respectively. Parameters μ1, μ2, λ1, λ2, η1, η2, δ1 and δ2 are set, and μ1111=0.9 and μ2222=1.1;are taken. The side lengths needs to satisfy that:








μ
1




d
1



d
3





μ
2


,


λ
1




d
2



d
4





λ
2


,


η
1




ϕ
1


ϕ
3





η
2






and






δ
1





ϕ
2


ϕ
4





δ
2

.






If the above relations are not satisfied, the size of the iteration window win for calculating sub-pixel level corner points shall be dynamically adjusted until the relations are satisfied. Four sub-pixel level corner points P1, P2, P3 and P4 are solved by iteration according to the solving principle of sub-pixel level corner points.


4) The points on the chessboard are assigned with values one by one in a world coordinate system according to the four initial sub-pixel level corner points. A homography matrix H can be obtained by the relationship between the four points in the world coordinate system and those in a pixel coordinate system.


5) By using the homography matrix H of the initial four points and the coordinates of a pair of points P5 and P6 to be solved of an adjacent unit grid in the world coordinate system, pixel coordinates of next two points P5 and P6 can be obtained, and then new sub-pixel level corner points P5 and P6 are solved by iteration according to the solving principle of sub-pixel level corner points.


6) All sub-pixel level corner points on the chessboard are calculated by expanding and spreading outwards from the unit grid defined by the four points to the positive half axis of the X axis, the negative half axis of X axis, the positive half axis of the Y axis, and the negative half axis of Y axis.


7) In the process of expanding outwards, the other two unknown rough sub-pixel level corner points of the adjacent unit grid can be obtained according to the homography matrix H, the rough lengths of the four sides of the adjacent unit grid can be obtained according to the coordinates of the two rough corner points, the lengths of the four sides are named in the same direction (clockwise or counterclockwise) as d1, d2, d3, d4, and the corresponding included angles of every two adjacent sides are named as θ1, θ2, θ3, θ4 respectively. According to empirical formulas obtained from previous observation, when the average value d of the four side lengths of the unit grid and the radius win of the iteration window satisfy the following fitting relation:






win
=

[



k
*

d
¯


+
c



ρ
*




i
=
1

4







θ
i

-

π
2




4



+
b


]





the sub-pixel level corner point detected is the most accurate, wherein k and ρ are coefficients of first order terms, and c and b are constants. Based on the known k, ρ, c, b, d and θi, the initial value of the radius win of the window is taken as w0=5.


8) After sub-pixel level corner point coordinates of the four points are calculated by iteration, the accuracy of the sub-pixel level corner point coordinates calculated need to be verified. The lengths of the four sides of the unit grid are named in the same direction (clockwise or counterclockwise) as d′1, d′2, d′3, d′4, the tangents of the four sides are named as ϕ1, ϕ2, ϕ3, ϕ4, and the corresponding included angles of every two adjacent sides are named as θ′1, θ′2, θ′3, θ′4 respectively. Parameters μ1, μ2, λ1, λ2, η1, η2, δ1 and δ2 are set, and μ1111=0.9 and μ2222=1.1 are taken. The side lengths needs to satisfy that:








μ
1




d
1



d
3





μ
2


,


λ
1




d
2



d
4





λ
2


,


η
1




ϕ
1


ϕ
3





η
2






and






δ
1





ϕ
2


ϕ
4





δ
2

.






If the above relations are not satisfied, the size of the iteration window win for calculating sub-pixel level corner points shall be dynamically adjusted until the relations are satisfied.

Claims
  • 1. A method for adaptively detecting chessboard sub-pixel level corner points, comprising the following steps: 1) setting marks: setting marks on a chessboard to mark position of an initial unit grid;2) shooting an image: using a camera to collect an image of a chessboard calibration target, and conducting preliminary image processing;3) detecting the marks: detecting pixel coordinates of the marks set in step 1) by a mark detection algorithm;4) using the marks: calculating pixel coordinates of four corner points of the initial unit grid defined by the marks according to the pixel coordinates detected in step 3), calculating sub-pixel level corner point coordinates by iteration and conducting verification;5) expanding outwards: calculating a homography matrix H according to the sub-pixel level corner point coordinates of the four corner points in step 4) and world coordinates thereof in a world coordinate system; multiplying the homography matrix H with world coordinates of four corner points of an adjacent unit grid of the marked unit grid in the world coordinate system to calculate sub-pixel level corner point coordinates of the other two unknown corner points of the adjacent unit grid;6) adaptively adjusting: counting side lengths of the adjacent unit grid obtained in the process of expanding outwards in step 5), and dynamically adjusting size of an iteration window for calculating sub-pixel level corner points to increase accuracy of sub-pixel level corner point detection.
  • 2. The method for adaptively detecting chessboard sub-pixel level corner points according to claim 1, wherein step 2) comprises the following specific steps: conducting gray processing and binarization operation to the image after the image is shot; dividing an image I into M*N blocks by block binarization method, with each block named as Ii; and using Otsu's method for each Ii to obtain a binarization image binary_I.
  • 3. The method for adaptively detecting chessboard sub-pixel level corner points according to claim 2, wherein step 4) comprises the following specific steps: 4-1) calculating coordinates of four initial corner points of the unit grid defined by the marks in a pixel coordinate system according to geometrical relationship;4-2) letting a sub-pixel level corner point to be solved be q, then the line vector between surrounding points pi and q thereof is (pi−q); for any point pi in a search window thereof, letting the gray gradient at pi be Gi, then the following formula is obtained: Gi*(pi−q)=0solving the formula by least square method: GiTGiq=GiTGipi i.e.: q=(GiTGi)−1*(GiTGipi)the coordinate of an initial corner point is an integer and is assumed to be q0, and a window is selected centering on q0; the radius win of the iteration window of the sub-pixel level corner point is obtained; each point of the window is pi; the quantity of pi is N, Gaussian weight is introduced, the weight at point pi is wi, and the coordinate q of the sub-pixel level corner point is:
  • 4. The method for adaptively detecting chessboard sub-pixel level corner points according to claim 1, wherein step 5) comprises the following specific steps: 5-1) using the coordinates P1, P2, P3 and P4 of the four initial corner points of the initially marked unit grid; according to the imaging principle of the camera, the pixel coordinate of a projection point P in the pixel coordinate system of a point W(Xw, Yw, Zw) in the world coordinate system is (u, v), i.e.:
  • 5. The method for adaptively detecting chessboard sub-pixel level corner points according to claim 4, wherein step 6) comprises the following specific steps: 6-1) in the process of expanding outwards, obtaining the coordinates of the other two unknown corner points of the adjacent unit grid according to the homography matrix H, obtaining the lengths of the four sides of the adjacent unit grid according to the coordinates of the two corner points, naming the lengths of the four sides in the same direction (clockwise or counterclockwise) as d1, d2, d3, d4 and the corresponding included angles of every two adjacent sides as θ1, θ2, θ3, θ4 respectively; when the average value d of the four side lengths of the unit grid and the radius win of the iteration window satisfy the following fitting relation:
Priority Claims (1)
Number Date Country Kind
202010027812.0 Jan 2020 CN national
PCT Information
Filing Document Filing Date Country Kind
PCT/CN2020/077959 3/5/2020 WO 00