This application is related to and claims priority from Japanese Patent Application No. 2015-164926 filed on Aug. 24, 2015, the contents of which are hereby incorporated by reference.
1. Field of the Invention
The present invention relates to parallax detection devices to be applied to distance measuring devices, capable of detecting a parallax of a target object on the basis of a plurality of images acquired detection points by in-vehicle cameras at different detection points.
2. Description of the Related Art
There has been known a distance measuring device having a parallax detection device, a first image acquiring device and a second image acquiring device such as in-vehicle stereo cameras. The distance measuring device is mounted on a vehicle, for example. In the distance measuring device, the first image acquiring device acquires a first image, and the second image acquiring device acquires a second image. The parallax detection device in the distance measuring device compares the first image and the second image, and detects a distance from the vehicle to a target object in the first image on the basis of the comparison results. The distance measuring device uses a dynamic programming method to calculate a point having a minimum value of an object function. The dynamic programming method is a known method because of being widely used. The object function includes data terms and regularization terms of the first image and the second image. The parallax detection device in the distance measuring device detects a parallax of the target object to be measured in the acquired first image on the basis of the point having the minimum value of the object function, and detects the distance from the distance measuring device to the target object on the basis of the detected parallax. For example, a patent document 1 discloses the conventional distance measuring device previously described.
However, the distance measuring device disclosed by the patent document 1 uses the object function including regularization terms, and the value of the object function rapidly varies at a point near the minimum value of the object function, and there is a possible case which provides discrete detection results of the parallax. When the detection results of the parallax become discrete values, the distance to the target object measured on the basis of the parallax becomes discrete values, and this reduces and deteriorates distance measuring accuracy of the parallax detection device in the distance measuring device.
It is therefore desired to provide a parallax detection device capable of detecting a parallax of acquired images with improved detection accuracy within a reduced processing time.
An exemplary embodiment provides a parallax detection device having a computer system including a central processing unit, i.e. a CPU. The computer system provides an image acquiring section, a low resolution image making section, a first parallax detection section and a second parallax detection section. The image acquiring section acquires a first image and a second image acquired at different image acquiring points by the image acquiring devices so that the first image and the second mage contain the same image acquiring region.
The low resolution image making section converts the first image and the second image acquired by the image acquiring section to a first low resolution image and a second low resolution image, respectively. The first low resolution image has a predetermined low resolution. The second low resolution image has the predetermined low resolution. The predetermined low resolution is lower than the resolution of each of the first image and the second image.
The first parallax detection section divides the first low resolution image into a plurality of low resolution blocks. Each of the low resolution blocks is composed of a plurality of pixels. The first parallax detection section detects a parallax of each of the low resolution blocks by searching a low resolution corresponding block in the second low resolution image, for every low resolution block of the first low resolution image by using a dynamic programming method. The low resolution corresponding block has the region which is the same as the region of the low resolution block in the first low resolution image.
The second parallax detection section divides the first image acquired by the image acquiring section into a plurality of resolution blocks. Each of the resolution blocks is composed of a plurality of pixels. The second parallax detection section determins a parallax of each of the resolution blocks by detecting a resolution corresponding block having a region which is the same as the region of the resolution block in the second image for every resolution block on the basis of a block matching method for searching the block having a high similarity of the resolution block in the second image.
The second parallax detection section limits the searching region to search the resolution corresponding blocks in the second image by using the block matching method on the basis of the parallax detection results detected by the first parallax detection section.
The structure of the parallax detection device according to the exemplary embodiment of the present invention detects the parallax by using the block matching method in addition to the dynamic programming method. Accordingly, it is possible for the parallax detection device to avoid the parallax detection results being discontinuous which is often caused by a target function containing regularization terms during the examination by the dynamic programming method. This makes it possible to increase the parallax detection accuracy of the parallax detection device.
Further, the structure of the parallax detection device according to the exemplary embodiment of the present invention uses the dynamic programming method for processing the first low resolution image which has been converted from the first image and the second low resolution image which has been converted from the second image.
This structure of the parallax detection device makes it possible to reduce the processing load when performing the dynamic programming method for detecting the parallax. Still further, the parallax detection device according to the exemplary embodiment of the present invention limits the searching region for searching the blocks by using the block matching method. This structure makes it possible to reduce the processing load when the parallax detection device uses the block matching method to detect the parallax. As previously described, the structure of the parallax detection device makes it possible to reduce the processing time and increase the parallax detection accuracy.
A preferred, non-limiting embodiment of the present invention will be described by way of example with reference to the accompanying drawings, in which:
Hereinafter, various embodiments of the present invention will be described with reference to the accompanying drawings. In the following description of the various embodiments, like reference characters or numerals designate like or equivalent component parts throughout the several diagrams.
A description will now be given of the distance measuring device 1 having the image processing device 4 according to an exemplary embodiment with reference to
The distance measuring device 1 according to the exemplary embodiment is mounted on a vehicle. As shown in
The right side image acquiring device 2 and the left side image acquiring device 3 successively acquire front-view images, i.e. a front landscape of the vehicle. The right side image acquiring device 2 and the left side image acquiring device 3 transmit the acquired images to the image processing device 4.
The right side image acquiring device 2 is arranged at a right side of the vehicle. The left side image acquiring device 3 is arranged at a left side of the vehicle. Hereinafter, the images acquired by the right side image acquiring device 2 are referred to as the right side images. The images acquired by the left side image acquiring device 3 are referred to as the left side images.
The right side image acquiring device 2 and the left side image acquiring device 3 are arranged to be parallel to each other on the vehicle. Specifically, the right side image acquiring device 2 and the left side image acquiring device 3 are arranged on the vehicle so that an optical axis of the right side image acquiring device 2 and an optical axis of the left side image acquiring device 3 are arranged to be parallel to each other. Further, the right side image acquiring device 2 and the left side image acquiring device 3 are arranged to be separated from to each other by a predetermined base line length along a horizontal direction so that a lateral axis of a surface of the image acquired by the right side image acquiring device 2 and a lateral axis of a surface of the image acquired by the left side image acquiring device 3 are aliened with each other.
In general, a two dimensional orthogonal coordinate system has an X axis and a Y axis, and a surface of acquired image and an optical axis of the image acquiring device cross each other at an origin of the two dimensional orthogonal coordinate system. The lateral axis of the surface of the acquired image is the X axis of the two dimensional orthogonal coordinate system on the surface of the acquired image.
In particular, the image processing device 4 is composed of a central processing unit (CPU), a read only memory (ROM), a random access memory (RAM), an input/output (I/O) unit, bus lines, etc. Through the bus lines the CPU, the ROM, the RAM, the I/O unit are connected together. The CPU reads programs stored in the ROM, and executes the programs in order to perform various processes. The CPU, the ROM, the RAM and the I/O unit are omitted from
In the distance measuring device 1 having the structure previously described, the image processing device 4 executes the distance measuring process repeatedly during the operation thereof.
In step S10 shown in
In step S20, the image processing device 4 corrects a misalignment in the vertical direction between the right side image and the left side image received in step S10 so as to arrange these images parallel to each other. Specifically, the image processing device 4 converts the coordinate in the vertical direction of each of the pixels in the right side image and the left side image according to predetermined correction parameters in order to make a height of each image region (for example, pixels) coincide in the right side image and the left side image corresponding to each other. This process corrects the misalignment in the vertical direction between the right side image and the left side image. The operation flow progresses to step S30.
In step S30, the image processing device 4 makes first resolution images having a predetermined first resolution, and second resolution images having a predetermined second resolution on the basis of the right side image and the left side image (see G0 shown in
The first resolution images and the second resolution images are lower in resolution than the right side image and the left side image. That is, the process in step S30, the image processing device 4 provides a first resolution right side image and a first resolution left side image having the predetermined first resolution (which are designated by reference character G1 shown in
In the following explanation of the exemplary embodiment, the predetermined first resolution is a quarter of the resolution in the vertical direction and lateral direction of the right side image (original image) and the left side image (original image) which have been acquired by the right side image acquiring device 2 and the left side image acquiring device 3, respectively.
Further, the predetermined second resolution is a half of the resolution in the vertical direction and lateral direction of the right side image and the left side image (i.e. the original images) which have been acquired by the right side image acquiring device 2 and the left side image acquiring device 3, respectively. The operation flow progresses to step S40.
A description will now be given of the first parallax calculation process in step S40 shown in
The image processing device 4 divides the reference image having the predetermined first resolution into a plurality of blocks BL, each block BL having a rectangle shape composed of p pixels on the X axis (p is a positive integer) and on the Y axis direction by q pixels (q is a positive integer).
Next, the image processing device 4 detects the searching region SR having the Y coordinate position in the comparison image, where the Y coordinate position is the same as the Y coordinate position of each of the block BL divided in the reference image.
The image processing device 4 extracts the blocks as node setting blocks BLn from the comparison image, each block BLn has a parallax which is different from the parallax of each block BL, and the same size of each block BL (i.e. which has the p pixels in the X axis direction and t pixels in the Y axis direction).
The image processing device 4 arranges the node points NP in the node point space NPS on the basis of the extracted node setting blocks BLn.
For example, as shown in
In this case, the node point NP1(1) (see the direction designated by the arrow AL2 shown in
For example, the image processing device 4 extracts, as the node setting block BLn (see the direction designated by the arrow AL3 shown in
Similarly, the image processing device 4 extracts, as the node setting block BLn from the comparison image in the searching region SR, which corresponds to the block BB2 located adjacent to the block BB1 in the reference image.
For example, the image processing device 4 extracts, as the node setting block BLn (see the direction designated by the arrow AL5 shown in
In this case, the node point NP2(1), which corresponds to the block BC2(1), is arranged at the coordinate (x2, y1, d1) (see the direction designated by the arrow AL6 shown in
The image processing device 4 calculates a cost of each of the nodes NP arranged in the node point space NPS. The cost indicates a degree of similarity between two blocks which have been used to arrange the node points NP in the node point space NPS. The two blocks indicate the block BL in the reference image and the node setting block BLn extracted from the comparison image when the node point NP corresponding to this block BL is arranged. For example, the image processing device 4 calculates the cost of the node point NP1(1) on the basis of the block BB1 and the block BC1(1).
The node position p is composed of the X coordinate position and the Y coordinate position of the node point NP in the node point space NPS, and the parallax of the node point NP is designated by using up.
The cost of the node point NP arranged at the position specified by the node point position p and the parallax up is designated by using D (p, up).
The image processing device 4 calculates the cost D (p, up) on the basis of the known structural similarity SSIM by using the following equation (1).
where, μx indicates an average value of brightness of pixels contained in the block BL in the reference image, μy indicates an average value of brightness of pixels contained in the node point setting block BLn in the comparison image, σx indicates a standard deviation of brightness of pixels contained in the block BL in the reference image, σy indicates a standard deviation in brightness of the pixels contained in the node point setting blocks BLn in the comparison image, and σxy indicates a covariance in brightness of the pixels contained in the block BL in the reference image and the node point setting blocks BLn in the comparison image.
The image processing device 4 arranges the node points NP in the node point space NPS for the overall divided blocks BL. After calculating the cost D (p, up) of all node points NP which have been arranged, the image processing device 4 completes the process in step S210. The operation flow progresses to step S220.
In step S220, as shown in
As has already been shown in
The image processing device 4 calculates the X direction moving cost Ex of the node point NP in each of the X-Z planes.
A description will now be given of the method of calculating the X direction moving cost Ex of the node point NP in each of the X-Z planes.
For example, as shown in
In general, the smaller the parallax, the smaller the value of i, and the more the X coordinate position of the node point NP approaches to the origin, the more the value of j becomes a small value.
The image processing device 4 selects, as the end point, one of the node points NP arranged on the X-Z plane. The image processing device 4 selects, as the start point, the node point NP which is close to the origin in the X-Z plane. For example, the image processing device 4 selects as the start point, the node point NP arranged on i-th row and first column in the X-Z plane.
The image processing device 4 moves the node point NP from the start point along the X direction by one, i.e. the node point NP is moved to the node point arranged at the second column along the X direction designated by the arrow M1 shown in
Further, the image processing device 4 moves the node point NP on the second column along the X direction by one, i.e. to the node point arranged at the third column.
The image processing device 4 repeats the moving of the node point NP, i.e. sequentially moves the node point NP along the X direction by one until the node point NP reaches the end point. The moving path along the positive X direction of the node point NP is referred to as the rightward direction moving path.
The image processing device 4 calculates the cost E of the detected moving path by using the following equation (2).
where the first term in the equation (2) is a data term which indicates the sum of the cost D (p, up) of the node points NP arranged on the moving path. The second term in the equation (2) is a regularization term. In the equation (2), the second term S (up, uq) indicates a parallax term when the node Np having the parallax up is moved to the node point NP having the parallax uq.
The second term S (up, uq) is a function value which increases when increasing a difference between the parallax up and the parallax uq.
In the exemplary embodiment, the second term S (up, uq) is an absolute value of the difference between the parallax up and the parallax uq. Accordingly, the second term in the equation (2) indicates the total sum in change of the parallax when the node point is moved along the rightward direction moving path.
The process previously described makes it possible to determine all of the possible rightward direction moving paths when the start point is selected from one of the node points arranged on the first column and the end point is selected from the plurality of the node points NP, and to calculate the cost E of each of the overall possible moving paths. The image processing device 4 calculates the moving path having the minimum cost E.
The image processing device 4 according to the exemplary embodiment calculates and specifies the moving path having the minimum cost E by using the known Viterbi algorithm as a kind of the dynamic programming method instead of calculating the cost E of each of the overall possible moving paths.
In step S220, the image processing device 4 specifies the rightward direction moving path having the minimum cost E from the overall node points NP arranged in the X-Z plane. This calculates the minimum cost (hereinafter, the rightward direction moving cost) in the rightward direction moving path in each of all of the node points NP arranged on the X-Z plane.
Next, like the method of calculating the rightward direction moving cost previously described, the image processing device 4 calculates the minimum cost (hereinafter, the leftward direction moving cost) of the leftward direction moving path on the X-Z plane composed of the overall node points NP.
Specifically, the image processing device 4 selects, as the end point, one from the plurality of the node points NP arranged on the X-Z plane. The image processing device 4 selects, as the start point, one selected from the node points NP (i.e. the node point NP arranged at the final column in the row i), which is farthest on the X coordinate in the X-Z plane from the origin on the X-Z plane. The image processing device 4 moves the node point NP by one, i.e. to one of the node points arranged at the adjacent column in the negative direction of the X axis from the start point by one (see the direction M2 shown in
Further, the image processing device 4 moves the current node point NP to the node point NP arranged at the adjacent column. The image processing device 4 sequentially moves the current node point NP from the start point in the negative direction on the X axis by one column to the end point NP through a single moving path. Hereinafter, this moving path is referred to as the leftward direction moving path. The operation flow progresses to step S220.
In step S220, like the case of the rightward direction moving path previously described, the image processing device 4 specifies the leftward direction moving path having the minimum cost E in the overall node points NP arranged in the X-Z plane. The image processing device 4 calculates the leftward direction moving path having the minimum cost (hereinafter, the leftward direction moving cost) in the overall node points NP in the X-Z plane.
In step S220, the image processing device 4 adds the rightward direction moving cost and the leftward direction moving cost in the overall node points NP arranged on the X-Z plane to obtain the X direction moving cost Ex.
After calculating the X direction moving cost Ex in the X-Z plane, the image processing device 4 calculates the X direction moving cost Ex in the next X-Z plane. After calculation of the X direction moving cost Ex in the overall X-Z plane, the image processing device 4 completes the process in step S220. The operation flow progresses to step S230.
In step S230, as shown in
In step S230, the image processing device 4 calculates the Y direction moving cost Ey of the node point NP in each of the plurality of the Y-Z planes. The image processing device 4 uses the Y-Z planes in order to calculate the Y direction moving cost Ey of the node points NP, instead of using the X-Z planes for calculating the X direction moving cost previously described.
Specifically, the image processing device 4 selects, as the start point, one selected from the node points NP, i.e. the Y coordinate of which is nearest to the origin of the Y-Z plane. The image processing device 4 sequentially moves the node point NP in the forward direction of the Y axis by one column (see the direction designated by the arrow M3 shown in
Further, the image processing device 4 selects, as the start point, one from the node points NP, i.e. the Y coordinate of which is farthest from the origin of the Y-Z plane. The image processing device 4 sequentially moves the node point NP in the negative direction of the Y axis by one column (see the direction designated by the arrow M4 shown in
In step S230, the image processing device 4 specifies the downward moving path having the minimum cost E and the upward moving path having the minimum cost in the overall node points NP arranged on the Y-Z plane. This process makes it possible to calculate the minimum cost in the downward moving path (hereinafter, referred to as the downward moving cost) and the minimum cost in the upward moving path (hereinafter, referred to as the upward moving cost).
In step S230, the image processing device 4 further calculates, as a Y direction moving cost Ey, an addition of the downward moving cost and the upward moving cost in the overall node points NP arranged on the Y-Z planes.
After calculation of the Y direction moving cost Ey in this Y-Z plane, the image processing device 4 calculates the Y direction moving cost Ey, in next Y-Z plane by the same procedure previously described. After calculation of the Y direction moving cost Ey for the overall Y-Z planes, the image processing device 4 completes the process in step S230. The operation flow progresses to step S240.
In step S240, as shown in
In step S240, as shown in
In step S240, the image processing device 4 calculates a right oblique direction moving cost Ex−y of the node points NP arranged on each of the right oblique planes PL21 to PL23. The procedure of calculating the right oblique upward direction moving cost Ex−y of the node points NP is the same as the procedure of calculating the X direction moving cost Ex of the node points NP other than using the right oblique planes instead of the X-Z planes.
Specifically, the image processing device 4 selects, as the start point, one selected from the node points NP, i.e. which is nearest to the Y axis. The image processing device 4 moves the node point NP to the X axis by one column (see the direction designated by the arrow M5 shown in
Further, the image processing device 4 selects, as the start point, one from the node points NP, i.e. which is farthest from the X axis. The image processing device 4 moves the node point NP to the Y axis by one column (see the direction designated by the arrow M6 shown in
In step S240, the image processing device 4 specifies the right upward moving path having the minimum cost E and the left downward moving path having the minimum cost in the overall node points NP arranged on the right oblique plane. This process makes it possible to calculate the minimum cost in the right upward moving path (hereinafter, referred to as the right upward moving path cost) and the minimum cost in the left downward moving path (hereinafter, referred to as the left downward moving path cost).
In step S240, the image processing device 4 further calculates, as a right oblique direction moving cost Ex−y, an addition of the right upward moving cost and the left downward moving cost in the overall node points NP arranged on these right oblique planes.
After calculation of the right oblique direction moving cost Ex−y in this right oblique plane, the image processing device 4 calculates the right oblique direction moving cost Ex−y, in next right oblique plane by the same procedure previously described. After calculation of the right oblique direction moving cost Ex−y for the overall right oblique planes, the image processing device 4 completes the process in step S240. The operation flow progresses to step S250.
In step S250, as shown in
In step S250, as shown in
In step S250, the image processing device 4 calculates a left oblique direction moving cost Ex+y of the node points NP arranged on each of the left oblique planes PL31 to PL34. The calculation of the left oblique upward direction moving cost Ex+y is basically equal to the calculation of the X direction moving cost Ex of the node points NP previously described, but is different from the use of the left oblique planes.
Specifically, the image processing device 4 selects, as the start point, one selected from the node points NP, i.e. which is nearest to the origin. The image processing device 4 moves the node point NP toward the direction apart from the origin, by one column (see the direction designated by the arrow M7 shown in
Further, the image processing device 4 selects, as the start point, one from the node points NP, i.e. which is farthest from the origin. The image processing device 4 moves the node point NP toward the direction to approach the origin by one column (see the direction designated by the arrow M8 shown in
In step S250, the image processing device 4 specifies the right downward moving path having the minimum cost E, and the left upward moving path having the minimum cost E in the overall node points NP arranged on the left oblique plane. This process makes it possible to calculate the minimum cost of the right downward moving path (hereinafter, referred to as the right downward moving path cost) and the minimum cost of the left upward moving path (hereinafter, referred to as the left upward moving path cost).
Further, in step S250, the image processing device 4 adds the right downward moving cost and the left upward moving cost together in the overall node points NP arranged on these left oblique planes, and detects the addition result as a left oblique direction moving cost Ex+y.
After calculation of the left oblique direction moving cost Ex+y in the left oblique plane, the image processing device 4 calculates the left oblique direction moving cost Ex+y, in a next left oblique plane by the same procedure previously described. After calculation of the left oblique direction moving cost Ex+y for the overall left oblique planes, the image processing device 4 completes the process in step S250. The operation flow progresses to step S260.
In step S260, as shown in
E
sum
=E
x
+E
y
+E
x−y
+E
x+y (3)
The operation flow progresses to step S270.
In step S270, the image processing device 4 selects the node point NP having the minimum overall direction moving cost Esum from the plurality of the node points NP having a different parallax, the same X coordinate position and the same Y coordinate position in each of the blocks BL which form the reference image. The image processing device 4 completes the first parallax calculation process in step S40 shown in
After the completion of the first parallax calculation process in step S40 shown in
A description will now be given of the second parallax calculation process in step S50 shown in
Because the second parallax calculation process in step S50 shown in
After the process in step S310, the operation flow progresses to step S320. In step S320, the image processing device 4 calculates the X direction moving cost Ex of the node point NP. In the process in step S320, the image processing device 4 calculates the X direction moving cost Ex of each of the node points NP which are located near the node point NP selected in step S270, but does not calculate the X direction moving cost Ex of the overall node points NP in the node point space NPS.
In step S320, because the image processing device 4 calculates the X direction moving cost Ex of the node point NP by using the same method shown in step S220, the explanation thereof is omitted here. After the process in step S320, the operation flow progresses to step S330.
In step S330, the image processing device 4 calculates the Y direction moving cost Ey of the node point NP. In the process of step S330, the image processing device 4 calculates the Y direction moving cost Ey of each of the node points NP which are located near the node point NP selected in step S270, not calculate the Y direction moving cost Ey of the overall node points NP arranged in the node point space NPS.
In step S330, because the image processing device 4 uses the same calculation method shown in step S230 to calculate the Y direction moving cost Ey of the node point NP, the explanation thereof is omitted here. After the process in step S330, the operation flow progresses to step S340.
In step S340, the image processing device 4 calculates the right oblique direction moving cost Ex−y of the node point NP. In the process in step S340, the image processing device 4 calculates the right oblique direction moving cost Ex−y of each of the node points NP which are located near the node point NP selected in step S270, not calculate the right oblique direction moving cost Ex−y of the overall node points NP.
In step S340, because the image processing device 4 uses the same calculation method shown in step S240 to calculate the right oblique direction moving cost Ex−y of the node point NP, the explanation thereof is omitted here. After the process in step S340, the operation flow progresses to step S350.
In step S350, the image processing device 4 calculates the left oblique direction moving cost Ex+y of the node point NP. In the process in step S350, the image processing device 4 calculates the left oblique direction moving cost Ex+y of each of the node points NP which are located near the node point NP selected in step S270, not calculate the left oblique direction moving cost Ex+y of the overall node points NP.
In step S350, because the image processing device 4 uses the same calculation method shown in step S250 to calculate the left oblique direction moving cost Ex+y of the node point NP, the explanation thereof is omitted here. The operation flow progresses to step S350. After the process in step S350, the operation flow progresses to step S360.
In step S360, the image processing device 4 calculates the overall direction moving cost Esum by using the same method in step S260. The operation flow progresses to step S370.
In step S370, the image processing device 4 selects the node point NP having the minimum overall direction moving cost Esum from the plurality of the node points NP having a different parallax in each of the blocks BL which form the reference image. The operation flow progresses to step S380.
In step S380, the image processing device 4 detects the parallax of the node point NP selected in step S370 as the parallax of the corresponding block BL. After the process in step S380, i.e. determining the parallax of each of the overall blocks BL forming the reference image, the image processing device 4 completes the execution of the second parallax calculation process. The operation flow progresses to step S60 shown in
Next, the image processing device 4 executes a block matching process in step S60 shown in
In step S60, the image processing device 4 uses the right side image and the left side image, which have been parallel to each other, as the reference image and the comparison image, respectively. The image processing device 4 divides the reference image, i.e. the right side image into the blocks BLm, each block BL having a rectangle shape composed of (2m+1) pixels (m is a positive integer) in the X axis and (2n+1) pixels (n is a positive integer) in the Y axis.
In step S60, the image processing device 4 detects a corresponding point searching region in each of the divided blocks BLm.
The image processing device 4 detects the parallax of the block BLm on the basis of the result in step S380. Specifically, the image processing device 4 selects the block BL containing the coordinate (xm, ym) of the block BLm in the right side image having the second resolution, and detects the parallax of the specified block BL as the parallax of the block BLm.
Next, the image processing device 4 detects the searching region SRc in the comparison image on the basis of the parallax and coordinate of the block BLm in the reference image.
The X direction range of the searching region SRc is designated from (xm+ds−2L) to (xm+ds+2L), and the Y direction range of the searching region SRc is designated from (ym−2n) to (ym+2n), where ds [pixies] indicates the parallax of the block BLm and (2L+1) [pixels] indicates the X direction length of the searching region SRc.
The image processing device 4 moves, in the searching region SRc, the searching block BLs having the size which is the same as the size of the block BLm, where the searching block ZBLs has a rectangular shape having m pixels in the X axis direction and n pixels in the Y axis direction. The image processing device 4 moves the searching blocks BLs in the searching region SRc, and executes the known SAD (Sum of Absolute Difference) method by using the pixels contained in each of the searching blocks BLs and the pixels contained in the blocks BLm in the reference image.
When the block BLm is located at the coordinate (xm, ym), and the X coordinate position of the searching block BLs is Xs, the image processing device 4 obtains an evaluation value M (xm, ym, xs) by using the SAD. The obtained evaluation value M (xm, ym, xs) is designated by using the following equation (4).
where Is indicates brightness of each pixel contained in the searching block BLs.
After the parallax of one block BLm, the image processing device 4 repeatedly executes the parallax calculation for a next block BLm. When completing the parallax calculation for the overall blocks BLm, the image processing device 4 completes the process in step S60.
After the process in step S60 shown in
In step S70, the image processing device 4 calculates a distance to the target object by using the known distance calculation equation using the parallax data on the basis of the parallax of the overall blocks BLm calculated in step S60, the image processing device 4 completes the distance measuring process. This makes it possible to specify the distance to the object in each block BLm forming the reference image.
The distance measuring device 1 having the image processing device 4 according to the exemplary embodiment provides the distance measuring results which are obtained by the dynamic programming method using the image having the first resolution and the image having the second resolution, and performing the block matching of the original images, where the original images have been captured by the right side image acquiring device 2 and the left side image acquiring device 3 mounted on the vehicle.
The comparison measuring results are obtained by performing the dynamic programming method using the image having the first resolution, the image having the second resolution, and the captured original images.
The image G11 shown in
As can be clearly understood from the comparison result of the image G13 with the image G15 shown in
The image processing device 4 in the distance measuring device 1 according to the exemplary embodiment having the structure previously described obtains the right side image and the left side image acquired simultaneously by using the right side image acquiring device 2 and the left side image acquiring device 3 having a different viewpoint (step S10).
The image processing device 4 in the distance measuring device 1 makes the right side images and the left side images having the predetermined first resolution and the predetermined second resolution (i.e. the low resolution right side images and the low resolution left side images) on the basis of the right side image and the left side image acquired by the image acquiring devices 2 and 3 so that the predetermined first resolution and the predetermined second resolution are lower than the resolution of the right side image and the left side image acquired by the image acquiring devices (step S30).
The distance measuring device 1 according to the exemplary embodiment divides the low resolution right side image into a plurality of the blocks BL composed of a plurality of pixels.
Further, the distance measuring device 1 having the image processing device 4 according to the exemplary embodiment detects the parallax of each block BL by the dynamic programming method of searching the node point setting block BLn having the region which is the same as the region of the block BL for every divided block BL in the low resolution left side image (step S210 to S270, and steps S310 to S370).
The distance measuring device 1 having the image processing device 4 according to the exemplary embodiment divides the right side image acquired by the right side image acquiring device 2 into a plurality of the blocks BLm. The distance measuring device 1 detects the parallax of the block BLm by performing the block matching method to determine the block (hereinafter, referred to as the image resolution corresponding block) having the region which is the same as the region of the block BLm in the left side image for every divided block BLm (step S60).
Further, the distance measuring device 1 detects the searching region (step S60) by searching the image resolution corresponding block by using the block matching method in the right side image on the basis of the parallax detection results (steps S40 and S50) by using the dynamic programming method.
As previously described in detail, the distance measuring device 1 uses the block matching method to detect the parallax of the block in addition to using the dynamic programming method. The distance measuring device 1 having the structure previously described can avoid obtaining discontinuous parallax detection results caused by the target function containing the regularization terms in the dynamic programming method. This makes it possible to increase the parallax detection accuracy. Further, because of processing the right side image and left side image having the low resolution by performing the dynamic programming method, the distance measuring device 1 can reduce the processing load to detect the parallax. Still further, because the distance measuring device 1 limits the searching region to search the blocks by using the block matching method, it is possible to reduce the processing load to detect the parallax on the basis of the block matching method. As previously described, the distance measuring device 1 having the image processing device 4 according to the exemplary embodiment can reduce the processing period of time to increase the parallax detection accuracy simultaneously.
Further, the distance measuring device 1 arranges the node points NP in the node point space NPS. Each of these node points NP is specified on the basis of the two dimensional position and the parallax of the block BL in the low resolution right side image for every block BL. The node point space NPS is a three dimensional space determined by the two dimensional position of each block BL and the parallax of the block BL (steps S210 and S310).
Further, the distance measuring device 1 having the image processing device 4 calculates the cost D (p, up) which is reduced when increasing the similarity between the block BL corresponding to the node point NP and the node point setting block BLn in the left side image having the low resolution which is separated from the block BL by the parallax of the corresponding node point NP (steps S210 and S310).
Further, the distance measuring device 1 having the image processing device 4 calculates the parallax cost S (up, uq) which increases when increasing the difference in parallax between the first node point and the second node point when the node point NP is moved to another node point NP in the node point space NPS (steps S220 to S250, and steps S320 to S350).
In addition, the distance measuring device 1 having the image processing device 4 selects the node points as the end point and the first start point, respectively, from the node points NP arranged in the node point space NP. The first start point is located at one end position of the node point space NPS. The distance measuring device 1 having the image processing device 4 detects the rightward direction moving path, the downward moving path, the right oblique moving path and the right downward moving path, each of which is from the start point to the end point (steps S220 to S250, the steps S320 to S350).
Hereinafter, the group composed of the rightward direction moving path, the downward moving path, the right oblique moving path and the right downward moving path is referred to as the first moving path.
Still further, the distance measuring device 1 having the image processing device 4 selects the node point as the second start point from the node points NP arranged in the node point space NP. The second start point is located at the other end point opposite to the one end point in the node point space NPS. The distance measuring device 1 having the image processing device 4 detects the leftward direction moving path, the upward moving path, the left oblique moving path and the left downward moving path, each of which is from the second start point to the other end point (steps S220 to S250, the steps S320 to S350).
Hereinafter, the group composed of the leftward direction moving path, the upward moving path, the left oblique moving path and the left downward moving path is referred to as the second moving path.
Further, the distance measuring device 1 having the image processing device 4 detects the total sum of the cost D (p, up) of the node point NP arranged on the first moving path and the parallax cost S (up, uq) of the first moving path as the rightward direction moving cost, the downward moving cost, the right upward moving cost, and the right downward moving cost (steps S220 to S250, and the steps S320 to S350). Hereinafter, the group of the rightward direction moving cost, the downward moving cost, the right upward moving cost, and left downward moving cost is referred to as the first moving cost.
Still further, the distance measuring device 1 having the image processing device 4 detects the total sum of the cost D (p, up) of the node points NP arranged on the second moving path and the parallax cost S (up, uq) of the second moving path as the leftward direction moving cost, the upward moving cost, the left downward moving cost, and the left upward moving cost (steps S220 to S250, and the steps S320 to S350). Hereinafter, the group of the leftward direction moving cost, the upward moving cost, the left downward moving cost, and the left upward moving cost is referred to as the second moving cost.
The distance measuring device 1 having the image processing device 4 searches the first moving path having the first minimum moving cost (hereinafter, referred to as the first minimum moving path) and the second moving path having the second minimum moving cost (hereinafter, referred to as the second minimum moving cost) by using the dynamic programming method (steps S220 to S250, and the steps S320 to S350).
The distance measuring device 1 having the image processing device 4 calculates the X direction moving cost Ex, the Y direction moving cost Ey, the right oblique direction moving cost Ex−y, and the left oblique direction moving cost Ex+y, on the basis of the first minimum moving cost and the second minimum moving cost (steps S220 to S250, and steps S320 to S350).
The distance measuring device 1 having the image processing device 4 detects, as the parallax of the block BL, the parallax of the node point NP having the minimum total direction moving cost Esum in the node points corresponding to the block BL for every block BL (steps S260, S270, S360 and S370).
As previously described, the distance measuring device 1 having the image processing device 4 detects the parallax by using the dynamic programming method which uses, as the target function, the moving cost containing the parallax cost S (up, uq) as the regularization term. Further, the distance measuring device 1 having the image processing device 4 detects the parallax by using the block matching method finally. This makes it possible for the distance measuring device 1 to avoid obtaining discontinuous parallax detection results. This makes it possible to increase the parallax detection accuracy
The distance measuring device 1 having the image processing device 4 calculates the X direction moving cost Ex, the Y direction moving cost Ey, the right oblique direction moving cost Ex−y and the left oblique direction moving cost Ex+y in different directions, i.e. in the X direction, the Y direction, the right oblique direction, and the left oblique direction, respectively (steps S260, S270, S360 and S370).
The distance measuring device 1 having the image processing device 4 detects the parallax of the block BL on the basis of the calculated costs, i.e. the X direction moving cost Ex, the Y direction moving cost Ey, the right oblique direction moving cost Ex−y and the left oblique direction moving cost Ex+y (steps S260, S270, S360 and S370).
As previously described in detail, the distance measuring device 1 having the image processing device 4 detects the parallax on the basis of the moving costs calculated in a plurality of the different moving directions, it is possible to reduce the influence of noise, to the parallax detection results, where the noise is contained in the right side image and the left side image acquired by the right side image acquiring device 2 and the left side image acquiring device 3. The structure and behavior of the distance measuring device 1 having the image processing device 4 makes it possible to increase the parallax detection accuracy.
The distance measuring device 1 having the image processing device 4 makes the first resolution right side image having the predetermined first resolution, the first resolution left side image having the predetermined first resolution, the second resolution right side image having the predetermined second resolution, and the second resolution left side image having the predetermined second resolution. The predetermined first resolution is different from the predetermined second resolution. Each of the predetermined first resolution and the predetermined second resolution is lower than the resolution of the right side image and the left side image acquired by the right side image acquiring device 2 and the left side image acquiring device 3 (step S30).
The distance measuring device 1 having the image processing device 4 detects the parallax of the block BL on the in the first resolution right side image (step S30), and then limits the parallax searching range in the second resolution right side image having the predetermined second resolution by using the dynamic programming method on the basis of the parallax detection results of the blocks BL in the first resolution right side image having the predetermined first resolution (step S50).
This makes it possible for the parallax detection device 4 in the distance measuring device 1 to reduce the parallax searching range when the image having the predetermined second resolution which is higher than the predetermined first resolution by using the dynamic programming method. It is also possible to reduce the processing load to detect the parallax by using the dynamic programming method.
Further, the distance measuring device 1 having the image processing device 4 performs a sub pixel estimation of fitting the correlation, between the evaluation value M (xm, ym, xs), the block BLm and the parallax of the searching block BLs in the left side image, by using the fitting function, and detects the parallax of the block BLm on the basis of the sub pixel estimation (step S60). This makes it possible for the distance measuring device 1 having the image processing device 4 to detect the parallax with the sub pixel accuracy.
As previously described, the image processing device 4 corresponds to the parallax detection device, the process in step S10 corresponds to the image acquiring section for receiving the right side image and the left side image transmitted from the right side image acquiring device 2 and the left side image acquiring device 3. The process in step S30 corresponds to a low resolution image making section, the processes in step S210 to S270 and step S310 to S370 correspond to a first parallax detection section, and the process in step S60 corresponds to a second parallax detection section.
The right side image corresponds to the first image, and the left side image corresponds to the second image. The right side image having the predetermined first resolution and the right side image having the predetermined second resolution correspond to the first low resolution image. The left side image having the predetermined first resolution and the left side image having the predetermined second resolution correspond to the second low resolution image.
The block BL corresponds to the low resolution block, and the blocks BLm correspond to the resolution blocks.
The processes in steps S210 and S310 correspond to a node point arrangement section. The processes in steps S220 to S250, and steps S320 to S350 correspond to a cost calculation section. The processes in steps S260, S270, S360 and S370 correspond to a parallax determination section.
The cost D (p, up) corresponds to the node point cost, the cost S (up, uq) corresponds to the parallax cost. The X direction moving cost Ex, the Y direction moving cost Ey, the right oblique direction moving cost Ex−y, and the left oblique direction moving cost Ex+y correspond to the movement direction moving costs.
The distance measuring device 1 having the image processing device 4 according to the exemplary embodiment has been explained. However, the concept of the present invention is not limited by this exemplary embodiment previously described. It is possible for the present invention to provide various modifications within the scope of the present invention.
The distance measuring device 1 uses the two image acquiring devices, i.e. the right side image acquiring device 2 and the left side image acquiring device 3. However, the concept of the present invention is not limited by this structure. For example, it is possible for the distance measuring device 1 to have not less than three image acquiring devices.
The exemplary embodiment previously described has shown the right side image and the left side image acquired by the right side image acquiring device 2 and the left side image acquiring device 3 having different two resolutions. However, the concept of the present invention is not limited by this structure. For example, it is possible for the distance measuring device 1 to make the right side image and the left side image having a single low resolution, or not less than three low resolutions.
As previously described, the distance measuring device 1 having the image processing device 4 according to the exemplary embodiment calculates the X direction moving cost Ex, the Y direction moving cost Ey, the right oblique direction moving cost Ex−y, and the left oblique direction moving cost Ex+y, adds them to obtain the total direction moving cost Esum, and detects the parallax on the basis of the calculated total direction moving cost Esum. However, the concept of the present invention is not limited by this structure. For example, it is possible for the distance measuring device 1 having the image processing device 4 to use, instead of using the total direction moving cost Esum, a method of considering the X direction moving cost Ex, the Y direction moving cost Ey, the right oblique direction moving cost Ex−y, and the left oblique direction moving cost Ex+y so as to detect the parallax on the basis of these costs Ex, Ey, Ex−y and Ex+y.
While specific embodiments of the present invention have been described in detail, it will be appreciated by those skilled in the art that various modifications and alternatives to those details could be developed in light of the overall teachings of the disclosure. Accordingly, the particular arrangements disclosed are meant to be illustrative only and not to limit the scope of the present invention which is to be given the full breadth of the following claims and all equivalents thereof.
Number | Date | Country | Kind |
---|---|---|---|
2015-164926 | Aug 2015 | JP | national |