The present disclosure related to 3D digital imaging and optical 3D reconstruction, and more particularly, it refers to a calibration arrangement for a structured light system using a tele-centric lens.
This section introduces aspects that may help facilitate a better understanding of the disclosure. Accordingly, these statements are to be read in this light and are not to be understood as admissions about what is or is not prior art.
With recent advances in precision manufacturing, there has been an increasing demand for the development of efficient and accurate micro-level 3D metrology approaches. A structured light (SL) system with digital fringe projection technology is regarded as a potential solution to micro-scale 3D profilometry based on its capability of high-speed, high-resolution measurement. To migrate this 3D imaging technology into micro-scale level, a variety of approaches were carried out, either by modifying one channel of a stereo microscope with different projection technologies, or using small field-of-view (FOV), non-telecentric lenses with long working distance (LWD).
Apart from the technologies mentioned above, an alternative approach for microscopic 3D imaging is to use telecentric lenses because of their unique properties of orthographic projection, low distortion and invariant magnification over a specific distance range. However, the calibration of such optical systems is not straightforward especially for Z direction, since the telecentricity will result in insensitivity of depth changing along optical axis. Tian et al. in U.S. Pub. App. 20160261851 (incorporated herein by reference in its entirety into the present specification) described a system that uses a translation stage for Z-axis calibration. The orthographic projection model in Tian et al. is uses an intrinsic matrix (a transformation matrix from camera lens coordinate system to camera image (CCD) coordinates system) and extrinsic matrix (a transformation matrix from world coordinate system to camera lens coordinate system). Within this method, dimensions along X and Y are calibrated through the relationship between pixel coordinate and physical coordinate of feature points on a calibration target (e.g. center points of a circle array); Z value is determined by the linear relationship between phase and depth value (in the form of positional information of a translation stage). This method requires a high precision translation stage that is expensive. This technology has shown the possibility to calibrate a telecentric SL system analogously to a regular pin-hole SL system.
There is, therefore an unmet need for a novel approach to a calibration method using a calibration target in a telecentric three dimensional imaging system without a translation stage which does not require positional knowledge of the calibration target.
A vision system having a telecentric lens is disclosed. The vision system includes a projector having a non-telecentric pin-hole lens, a camera having a telecentric lens positioned a distance away from the projector, and a processor. The processor controls the camera and the projector and is configured to calibrate the camera and projector according to i) control the camera to capture one or more images from a calibration target including one or more feature points with known world X-Y coordinates placed on a surface (Cal-Image), ii)identify feature points in the Cal-Image generating one or more set of coordinates, iii) control the projector to project at least one set of orthogonal fringe pattern onto the calibration target while commanding the camera to capture one image of the fringe pattern crossing the calibration target (Fringe-Image), iv) analyze the Fringe-Image to calculate the absolute phase of the at least one projected orthogonal fringe pattern, v) analyzing the absolute phase to establish a translation relationship between the X-Y coordinates of the camera to the X-Y coordinates of the projector, vi) calibrate the projector by calculating intrinsic and extrinsic matrices and calculate position of the calibration target in world XYZ coordinates, and vii) establish a calibration a matrix for the camera to thereby calibrate the camera.
A method to calibrate a camera having a telecentric lens and a projector in a vision system is also disclosed. The method includes placing a calibration target on a surface, controlling the camera to capture one or more images from a calibration target including one or more feature points with known world X-Y coordinates placed on a surface (Cal-Image), identifying feature points in the Cal-Image generating one or more set of coordinates, controlling the projector to project at least one set of orthogonal fringe pattern onto the calibration target while commanding the camera to capture one image of the fringe pattern crossing the calibration target (Fringe-Image), analyzing the Fringe-Image to calculate the absolute phase of the at least one projected orthogonal fringe pattern, analyzing the absolute phase to establish a translation relationship between the X-Y coordinates of the camera to the X-Y coordinates of the projector, calibrating the projector by calculating intrinsic and extrinsic matrices and calculate position of the calibration target in world XYZ coordinates, and establishing a calibration a matrix for the camera to thereby calibrate the camera.
The above and other objects, features, and advantages of the present invention will become more apparent when taken in conjunction with the following description and drawings wherein identical reference numerals have been used, where possible, to designate identical features that are common to the figures, and wherein:
The attached drawings are for purposes of illustration and are not necessarily to scale.
For the purposes of promoting an understanding of the principles of the present disclosure, reference will now be made to the embodiments illustrated in the drawings, and specific language will be used to describe the same. It will nevertheless be understood that no limitation of the scope of this disclosure is thereby intended.
A novel approach is provided for a calibration method using a calibration target in a telecentric three dimensional imaging system without a translation stage that does not require positional knowledge of the calibration target. In the present disclosure the terms “about” can allow for a degree of variability in a value or range, for example, within 10%, within 5%, or within 1% of a stated value or of a stated limit of a range.
Referring to
The principals of calibration for the system 100 is described as follows. The camera model with a telecentric lens is demonstrated in
where sxc and syc are respectively the magnification ratio in X and Y direction. The transformation from the world coordinate (ow,xw,yw,zw) to the camera coordinate can be formulated as follows:
where rijc and tic respectively denote the rotation and translation parameters. Combining Eq. (1)-(2), the projection from 3D object points to 2D camera image points can be formulated as:
since uc, uv, xw, yw, and zw are all known, mijc coefficients are determined by applying, e.g., a least square method.
The projector model uses a pin-hole imaging model, known to a person having ordinary skill in the art, and which is illustrated in
where sp represents the scaling factor; α and β are respectively the effective focal lengths of the camera u and v direction. The
matrix is the intrinsic matrix (a transformation matrix from projector lens coordinate system to projector DMD (digital micro-mirror device) coordinates system) and the [R3×3p t3×1p] matrix is the extrinsic matrix (a transformation matrix from world coordinate system to projector lens coordinate system). Multiple methods may be used to determine the intrinsic camera parameters, including the focal length, optical image center location on the camera CCD. This calculation can be performed by any number of standard imaging libraries. For example, this calculation can be solved by the cvCalibrateCamera2 function in the OpenCV library from Intel Corporation of Santa Clara, Calif., U.S., as provided by, e.g., U.S. Pub. App. No. 20110026014, incorporated herein by reference in its entirety into the present specification. The cvCalibrateCamera2 function takes as inputs the set of X-Y-Z coordinates and their associated X-Y coordinates on the image sensor 120, and generates the following intrinsic lens parameters: Focal Length (in pixels), Vertical Image Origin (in pixels), and Horizontal Image Origin (in pixels). In one embodiment, the dimensions of the focal length and the vertical and horizontal image origins are converted to physical dimensions to be used in modeling the projector 106. In order to convert pixels to millimeters, the physical size of the projector DMD is calculated, as well as the number of pixels on that size. These values are commonly published in the specifications of the projector. To convert the focal length in pixels to a focal length in millimeters, the following calculation is used: Focal Length(mm)=Focal Length(pixels)*Sensor size(mm)/Sensor Pixels.
For each orientation of the planar calibration target 118 captured by the camera 102 and mapped to the projector 106, the position of the calibration target 118 can be calculated through the cvFindExtrinsicCameraParams2 function in the Intel OpenCV software library. This function takes as inputs the X-Y-Z coordinates of the feature points (e.g., circle centers (see
In order to calibrate the camera 102 and its telecentric lens 104, the following procedure is carried out in accordance to
The processor 130 determines the absolute phase information of the fringe pattern by using a least-square phase-shifting algorithm with 9 steps (N=9). The k-th projected fringe image can be expressed as follows:
I
k(x,y)=I′(x,y)+I″(x,y)cos(ϕ+2kπ/N) (5)
where I′(x, y) represents the average intensity, I″(x, y) the intensity modulation, and ϕ(x, y) the phase—the processor 130 solves the phase according to:
This equation produces wrapped phase map ranging [−π, +π). Using a multi-frequency phase shifting technique, allowing the processor 130 to extract the absolute phase maps Φha and Φva without 2π discontinuities respectively from captured images with horizontal (see
In establishing the translation relationship between the camera 102 and the projector 106, the processor 130 determines the circle center with respect to the X-Y coordinates of the projector 106 by using the absolute phases obtained from above, the projector's circle center (up, vp) can be uniquely determined from the camera circle centers obtained (see above) according to the following equations:
u
p=ϕhac(uc,vc)×P1/2π, (7)
v
p=ϕvac(uc,vc)×P2/2π, (8)
where P1 and P2 are respectively the fringe periods of the horizontal (ha: horizontal absolute phase) and vertical (va: vertical absolute phase) patterns used above for absolute phase determination. This step converts the absolute phase values into projector pixels.
The processor 130 uses the above-obtained information to determine the projector intrinsic parameters (i.e. α, β, γ, u0c, v0c) (step 210) using standard camera calibration toolbox software.
The processor 130 aligns the world coordinates (ow; xw, yw, zw) with the projector coordinates (op; xp, yp, zp) (step 212). The transformation matrix [R3×3p, t3×1p] from the world coordinates (ow; xw, yw, zw) to the projector coordinates (op; xp, yp, zp) becomes [I3×3,03×1], which is composed of a 3×3 identity matrix I3×3 and a 3×1 zeros vector 03×1. To obtain the 3D world coordinates of target points, first calculate the target coordinate (ot; xt, yt, 0) by assuming its Z coordinate to be zero, and assign the upper left circle center (point A in
where ∥⋅∥ denotes the least square difference. Mp denotes the projection from the world coordinate to image coordinate. After this step, the 3D coordinates of the target points (i.e. circle centers) can be obtained by applying this transformation to the points in target coordinate.
In determining the camera calibration matrix, the processor 130 then solves camera parameters mijc in the least-square sense using Eq. (3). After calibrating both the camera and the projector, using Eq. (3) and Eq. (4), the 3D coordinate (xw, yw, zw) of a real-world object can be computed.
To show the efficacy of the calibration methodology discussed here, the 3D geometry of a flat plane was measured and was compare with an ideal plane obtained through least-square fitting.
Further, to visually demonstrate the calibration method of the present disclosure, two different types of objects with complex geometries were measured. First a ball grid array (
Those skilled in the art will recognize that numerous modifications can be made to the specific implementations described above. The implementations should not be limited to the particular limitations described. Other implementations may be possible.
The present U.S. patent application is related to and claims the priority benefit of U.S. Non-Provisional patent Ser. No. 15/273,463, filed on Sep. 22, 2016, which claims the priority benefit of U.S. Provisional Patent Application Ser. No. 62/221,699, filed Sep. 22, 2015, the contents of which are hereby incorporated by reference in their entirety into the present disclosure.
This invention was made with government support under CMMI-1531048 awarded by the National Science Foundation. The government has certain rights in the invention.
Number | Date | Country | |
---|---|---|---|
62221699 | Sep 2015 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15273463 | Sep 2016 | US |
Child | 16524761 | US |