The present invention relates to a self-position calculating apparatus and a self-position calculating method.
A technology has been known in which: cameras installed in a vehicle capture images of surroundings of the vehicle; and an amount of movement of the vehicle is obtained based on changes in the images (see Japanese Patent Application Publication No. 2008-175717). Japanese Patent Application Publication No. 2008-175717 aims at obtaining the amount of movement of the vehicle accurately even when the vehicle moves slightly at slow-speed. To this end, a feature point is detected from each image; the position of the feature point on the image is obtained; and thereby, the amount of movement of the vehicle is obtained from a direction and a distance of movement (amount of movement) of the feature point.
If, however, the feature point is detected under a bad condition, it is difficult to accurately obtain the amount of movement of the vehicle from the position of the feature point.
The present invention has been made with the foregoing situation taken into consideration. An object of the present invention is to provide a self-position calculating apparatus and a self-position calculating method which are capable of accurately and stably estimating a current position of the vehicle regardless of the condition under which feature points are detected.
A self-position calculating apparatus according to an aspect of the present invention includes: a light projector configured to project a patterned light beam onto a road surface around a vehicle; and an image capturing unit configured to capture an image of the road surface around the vehicle including an area onto which the patterned light beam is projected. The self-position calculating apparatus calculates an orientation angle of the vehicle relative to the road surface from a position of the patterned light beam on the image obtained by the image capturing unit, and calculates an amount of change in the orientation of the vehicle based on temporal changes in multiple feature points on the road surface which are detected from the image. Furthermore, the self-position calculating apparatus calculates current position and orientation angle of the vehicle by adding the amount of change in the orientation to initial position and orientation angle of the vehicle. If a condition under which the multiple feature points are detected is too bad to satisfy a first criterion, the self-position calculating apparatus projects the patterned light beam.
Referring to the drawings, descriptions will be provided for embodiments. The same components across the drawings will be denoted by the same reference signs. Descriptions for such components will be omitted.
The camera 12 is a digital camera using a solid-state image sensor such as a CCD and a CMOS, and obtains processable digital images. What the camera 12 captures is the road surface around the vehicle. The road surface around the vehicle includes road surfaces in front of, in the back of, at sides of, and beneath the vehicle. As shown in
The height at and direction in which to set the camera 12 are adjusted in a way that enables the camera 12 to capture images of feature points (textures) on the road surface 31 in front of the vehicle 10 and the patterned light beam 32b projected from the light projector 11. The focus and diaphragm of the lens of the camera 12 are automatically adjusted as well. The camera 12 repeatedly captures images at predetermined time intervals, and thereby obtains a series of image (frame) groups. Image data obtained by the camera 12 is transferred to the ECU 13, and is stored in a memory included in the ECU 13.
As shown in
Returning to
The multiple information processors include a patterned light beam extractor 21, an orientation angle calculator 22, an orientation change amount calculator 24, a self-position calculator 26, a patterned light beam controller 27, a detection condition determining section 30, and a calculation state determining section 35. The orientation change amount calculator 24 includes a feature point detector 23.
The patterned light beam extractor 21 reads an image obtained by the camera 12 from the memory, and extracts the position of the patterned light beam from this image. For example, as shown in
The orientation angle calculator 22 reads the data on the position of the patterned light beam 32a from the memory, and calculates the distance and orientation angle of the vehicle 10 relative to the road surface 31 from the position of the patterned light beam 32a on the image obtained by the camera 12. For example, as shown in
To put it specifically, since the camera 12 and the light projector 11 are fixed to the vehicle 10, the direction in which to project the patterned light beam 32a and the distance (the base length Lb) between the camera 12 and the light projector 11 are already known. For this reason, using the trigonometrical measurement principle, the orientation angle calculator 22 is capable of obtaining the position of each spotlighted area on the road surface 31, as the position (Xj, Yj, Zj) of each spotlight relative to the camera 12, from the coordinates (Uj, Vj) of each spotlight on the image.
It should be noted that, in many cases, the position (Xj, Yj, Zj) of each spotlight relative to the camera 12 is not present on the same plane. This is because the relative position of each spotlight changes according to the unevenness of the asphalt of the road surface 31. For this reason, the method of least squares may be used to obtain a plane equation which makes the sum of squares of distance difference of each spotlight becomes least.
The feature point detector 23 reads the image obtained by the camera 12 from the memory, and detects feature points on the road surface 31 from the image read from the memory. In order to detect the feature points on the road surface 31, the feature point detector 23 may use a method described in “D. G. Lowe, “Distinctive Image Features from Scale-Invariant Keypoints,” Int. J. Comput. Vis., vol. 60, no. 2, pp. 91-110, November 200.” Otherwise, the feature point detector 23 may use a method described in “Kanazawa Yasushi, Kanatani Kenichi, “Detection of Feature Points for Computer Vision,” IEICE Journal, vol. 87, no. 12, pp. 1043-1048, December 2004.”
To put it specifically, for example, the feature point detector 23 uses the Harris operator or the SUSAN operator as that points, such as apexes of an object, the luminance values of which are largely different from those of the vicinities of the points are detected as the feature points. Instead, however, the feature point detector 23 may use a SIFT (Scale-Invariant Feature Transform) feature amount so that points around which the luminance values change with certain regularity are detected as the feature points. After detecting the feature points, the feature point detector 23 counts the total number N of feature points detected from one image, and assigns identification numbers (i (1≦i≦N)) to the respective feature points. The position (Ui, Vi) of each feature point on the image are stored in the memory inside the ECU 13.
It should be noted that the embodiment treats particles of asphalt mixture with a particle size of not less than 1 cm but not greater than 2 cm as the feature points on the road surface 31. The camera 12 employs the VGA resolution mode (approximate 300 thousand pixels) in order to detect the feature points. In addition, the distance from the camera 12 to the road surface 31 is approximately 70 cm. Moreover, the direction in which the camera 12 captures images is tilted at approximately 45 degrees to the road surface 31 from the horizontal plane. What is more, the luminance value of each image obtained by the camera 12 and thereafter sent to the ECU 13 is within a range of 0 to 255 (0: darkest, 255: brightest).
The orientation change amount calculator 24 reads, from the memory, the positions (Ui, Vi) of the respective multiple feature points on an image included in a previous frame which is among the flames captured during each certain information process cycle. Furthermore, the orientation change amount calculator 24 reads, from the memory, the positions (Ui, Vi) of the respective multiple feature points on an image included in a current frame. Thereafter, based on changes in the positions of the multiple feature points on the images, the orientation change amount calculator 24 obtains an amount of change in the orientation of the vehicle. In this respect, the “amount of change in the orientation of the vehicle” includes both amounts of changes in “the distance and orientation angle” of the vehicle relative to the road surface 31 and an “amount of movement of the vehicle (the camera 12)” on the road surface. Descriptions will be hereinbelow provided for how to calculate the amounts of changes in the distance and orientation angle and the amount of movement of the vehicle.
It should be noted that the three-dimensional coordinates (Xi, Yi, Zi) of the relative position relative to the camera 12 are set in a way that: the Z-axis coincides with the direction in which the camera 12 captures the image; and the X and Y axes orthogonal to each other in a plane including the camera 12 are lines normal to the direction in which the camera 12 captures the image. Meanwhile, the coordinates on the image 38 are set such that: the V-axis coincides with the horizontal direction; and the U-axis coincides with the vertical direction.
It should be noted that instead of using all the feature points whose relative positions are calculated, the orientation change amount calculator 24 may select optimum feature points based on positional relationships among the feature points. An example of a selection method usable for this purpose is the epipolar geometry (the epipolar line geometry described in R. I. Hartley, “A linear method for reconstruction from lines and points,” Proc. 5th International Conference on Computer Vision, Cambridge, Mass., pp. 882-887 (1995)).
The associating of the feature points in the current frame with the feature points in the previous frame may be achieved, for example, by: storing an image of a small area around each detected feature point into the memory; and for each feature point, making a determination from a similarity in luminance information and a similarity in color information. To put it specifically, the ECU 13 stores a 5(horizontal)×5(vertical)-pixel image around each detected feature point into the memory. If for example, the difference in the luminance information among 20 or more pixels is equal to or less than 1%, the orientation change amount calculator 24 determines that the feature point in question is associated between the current and previous frames.
If like in this case, the feature points Te1, Te2, Te3 whose relative positions (Xi, Yi, Zi) are calculated are detected from the frame image 38′ obtained at the ensuing timing as well, the orientation change amount calculator 24 is capable of calculating the “amount of change in the orientation of the vehicle” from the temporal changes in the multiple feature points on the road surface.
The self-position calculator 26 calculates the distance and orientation angle from the “amounts of changes in the distance and orientation angle” calculated by the orientation change amount calculator 24. In addition, the self-position calculator 26 calculates the current position of the vehicle from the “amount of movement of the vehicle” calculated by the orientation change amount calculator 24.
To put it specifically, in a case where the distance and orientation angle calculated by the orientation angle calculator 22 (see
To put it specifically, if three or more feature points each corresponding between the previous and current frames can be detected continuously from the two frames, the continuation of the process (integration operation) of adding the amounts of changes in the distance and orientation angle makes it possible to continuously update the distance and orientation angle without using the patterned light beam 32a. Nevertheless, the distance and orientation angle calculated using the patterned light beam 32a, or a predetermined initial distance and orientation angle, may be used for the first information process cycle. In other words, the distance and orientation angle which are starting points of the integration operation may be calculated using the patterned light beam 32a, or may be set at predetermined initial values. It is desirable that the predetermined initial distance and the predetermined initial orientation angle are a distance and an orientation angle determined with at least the occupants and payload of the vehicle 10 taken into consideration. For example, the distance and orientation angle calculated using the patterned light beam 32a which is projected while the ignition switch of the vehicle 10 is on and when the shift position is moved from the parking position to another position may be used as the predetermined initial distance and the predetermined initial orientation angle. Thereby, it is possible to obtain the distance and orientation angle which is not affected by the roll or pitch of the vehicle 10 due to a turn, acceleration or deceleration of the vehicle 10.
The embodiment is configured such that: the amounts of changes in the distance and orientation angle are repeatedly calculated, and are each time added thereto; and thereby, the amounts of changes in the distance and orientation angle are updated with the most recent numerical values. Instead, however, the embodiment may be configured such that: only the amount of change in the orientation angle of the camera 12 relative to the road surface 31 is repeatedly calculated, and are each time updated. In this case, it may be supposed that the distance between the road surface 31 and the camera 12 remains constant. This makes it possible to reduce the operation load on the ECU 13 while minimizing the error in estimating the amount (ΔL) of movement with the amount of change in the orientation angle taken into consideration, and to increase the operation speed of the ECU 13.
The detection condition determining section 30 determines whether or not a condition under which the feature point detector 23 detects the feature points Te is too bad to satisfy a first criterion. For example, if like a concrete pavement inside a tunnel, the road surface is less patterned and uneven with particles of asphalt mixture, the feature points detectable from an image of the road surface decreases in number. The decreased number of detectable feature points makes it difficult to continuously detect the feature points which are associated between the previous and current frames, and lowers the accuracy with which the distance and orientation angle are updated.
As a measure against this problem, the detection condition determining section 30 determines that the condition under which the feature point detector 23 detects the feature points Te is too bad to satisfy the first criterion, if for example, the number of feature points, whose positions relative to the camera 12 are calculated and can be detected from an image obtained in the subsequent information process cycle, is less than a predetermined threshold value (four, for example). In other words, if four or more feature points associated between the previous and current frames cannot be detected, the detection condition determining section 30 determines that the condition under which the feature points Te are detected is too bad to satisfy the first criterion. Incidentally, as shown in
Based on the result of the determination made by the detection condition determining section 30, the patterned light beam controller 27 controls how the light projector 11 projects the patterned light beam 32a. If the detection condition determining section 30 determines that the condition under which the multiple feature points are detected is good enough to satisfy the first criterion, the patterned light beam controller 27 turns off the patterned light beam 32a. On the other hand, if the detection condition determining section 30 determines that the condition under which the multiple feature points are detected is too bad to satisfy the first criterion, the patterned light beam controller 27 projects the patterned light beam 32a. To put it specifically, based on the result of the determination made by the detection condition determining section 30, the patterned light beam controller 27 switches on and off a patterned light beam projection flag, and sends the patterned light beam projection flag to the light projector [[1]]11. Based on the patterned light beam projection flag, the light projector [[1]] 11 projects or turns off the patterned light beam 32a in the next information process cycle.
Furthermore, the detection condition determining section 30 determines whether or not the condition under which the feature point detector 23 detects the feature points Te is too bad to satisfy a second criterion which is lower than the first criterion. For example, if three or more feature points associated between the previous and current frames cannot be detected, the detection condition determining section 30 determines that the condition under which the feature points Te are detected is too bad to satisfy the second criterion.
If the detection condition determining section 30 determines that the condition under which the multiple feature points are detected is good enough to satisfy the second criterion, the orientation angle calculator 22 calculates no distance or orientation angle from the position of the patterned light beam 32a. On the other hand, if the detection condition determining section 30 determines that the condition under which the multiple feature points are detected is too bad to satisfy the second criterion, the orientation angle calculator 22 calculates the distance and orientation angle from the position of the patterned light beam 32a, since the plane G cannot be defined from the feature points Te.
If the detection condition determining section 30 determines that the condition under which the multiple feature points are detected satisfies the second criterion, the self-position calculator 26 retains the starting points of the integration operations as they are. On the other hand, if the detection condition determining section 30 determines that the condition under which the multiple feature points are detected is too bad to satisfy the second criterion, the self-position calculator 26 resets the starting points of the integration operations (the orientation angle and the initial position of the vehicle) at the distance and orientation angle calculated by the orientation angle calculator 22 (see
It should be noted that in the first embodiment, based on the number of feature points associated between the previous and current frames, the detection condition determining section 30 determines under what condition the multiple feature points are detected. Instead, however, the detection condition determining section 30 may be configured such that, based on the total number N of feature points detected from one image, the detection condition determining section 30 determines under what condition the multiple feature points are detected. To put it specifically, the configuration may be such that if the total number N of feature points detected from one image is equal to or less than a predetermined threshold value (9, for example), the detection condition determining section 30 determines that the condition under which the multiple feature points are detected is bad. A numerical value (12) three times the predetermined threshold value (4) may be set as such a threshold value because there is likelihood that some of detected feature points are not associated between the previous and current frames.
The calculation state determining section 35 determines whether or not a state of calculation of the distance and orientation angle by the orientation angle calculator 22 is too bad to satisfy a third criterion. For example, in a case where the patterned light beam is projected onto a bump on the road surface 31, the accuracy of the calculation of the distance and orientation angle decreases significantly because the bump on the road surface 31 is larger than dents and projections of the asphalt pavement. If the condition under which the multiple feature points are detected is too bad to satisfy the second criterion, and concurrently if the state of the calculation of the distance and orientation angle is too bad to satisfy the third criterion, there would otherwise be no means for accurately detecting the distance and orientation angle, as well as the amounts of changes in the distance and orientation angle.
With this taken into consideration, the calculation state determining section 35 determines that the state of the calculation of the distance and orientation angle by the orientation angle calculator 22 is too bad to satisfy the third criterion, if standard deviations of the distance and orientation angle calculated by the orientation angle calculator 22 are greater than predetermined threshold values. Furthermore, if the number of spotlights detected out of the 35 spotlights is less than three, the calculation state determining section 35 determines that the state of the calculation of the distance and orientation angle by the orientation angle calculator 22 is too bad to satisfy the third criterion, since theoretically, the plane equation of the road surface 31 cannot be obtained. In a case where the plane equation is obtained using the method of least square, if an absolute value of a maximum value among the differences between the spotlights and the plane obtained by the plane equation is equal to or greater than a certain threshold value (0.05 m, for example), the calculation state determining section 35 may determine that the state of the calculation of the distance and orientation angle by the orientation angle calculator 22 is too bad to satisfy the third criterion.
If the detection condition determining section 30 determines that the condition under which the multiple feature points are detected is too bad to satisfy the second criterion, and concurrently if the calculation state determining section 35 determines that the state of the calculation of the distance and orientation angle by the orientation angle calculator 22 is too bad to satisfy the third criterion, the self-position calculator 26 uses the distance and orientation angle obtained in the previous information process cycle, as well as the current position of the vehicle, as the starting points of the integration operations. This makes it possible to minimize an error in calculating the amount of movement of the vehicle.
(Information Process Cycle)
Next, as an example of a self-position calculating method of estimating the amount of movement of the vehicle 10 from the image 38 obtained by the camera 12, the information process cycle to be repeatedly performed by the ECU 13 will be described referring to
In step S01 in
Proceeding to step S03, the ECU 13 controls the camera 12 to obtain the image 38 by making the camera 12 shoot the road surface 31 around the vehicle 10, inclusive of an area onto which the patterned light beam 32a is projected. The ECU 13 stores the data on the image obtained by the camera 12 into the memory.
It should be noted that the ECU 13 is capable of automatically controlling the diaphragm of the camera 12. The ECU 13 may be configured to perform a feedback control of the diaphragm of the camera 12 in a way that makes a value of brightness of the next image becomes equal to a median value between the maximum and minimum values in accordance with of an average of the brightness of the image 38 obtained in the previous information process cycle. Otherwise, since the value of the brightness of the area onto which the patterned light beam 32a is projected, the ECU 13 may obtain an average value of the brightness of the previously-obtained image 38 from an area outside a part from which the patterned light beam 32a is extracted.
Proceeding to step S05, the detection condition determining section 30 determines under what condition the multiple feature points are detected. Based on the result of the determination made by the detection condition determining section 30, the patterned light beam controller 27 switches the patterned light beam projection flag, and sends the resultant flag to the light projector 11. Meanwhile, based on the result of the determination made by the detection condition determining section 30, the orientation angle calculator 22 calculates or does not calculate the distance and orientation angle. Details of step S05 will be later described referring to
Proceeding to step S07, the ECU 13 detects the feature points from the image 38, extracts the feature points each corresponding between the previous and current information process cycles from the detected feature points, and calculates the amounts of changes in the distance and orientation angle, and the amount of movement of the vehicle from the positions (Ui, Vi) of the respective extracted feature points on the image.
To put it specifically, to begin with, the feature point detector 23 reads the image 38 obtained by the camera 12 from the memory, detects the feature points on the road surface 31 from the image 38, and stores the positions (Ui, Vi) of the respective feature points on the image into the memory. The orientation change amount calculator 24 reads the positions (Ui, Vi) of the respective feature points on the image from the memory, and calculates the positions (Xi, Yi, Zi) of the respective feature points relative to the camera 12 from the distance and orientation angle, as well as the positions (Ui, Vi) of the respective feature points on the image. Incidentally, the orientation change amount calculator 24 uses the starting points (the distance and orientation angle) which are set in step S09 in the previous information process cycle. Thereafter, the orientation change amount calculator 24 stores the positions (Xi, Yi, Zi) of the respective feature points relative to the camera 12 into the memory.
Then, the orientation change amount calculator 24 reads the positions (Ui, Vi) of the respective feature points on the image, and the relative positions (Xi, Yi, Zi) of the respective feature points calculated in step S07 in the previous information process cycle from the memory. The orientation change amount calculator 24 calculates the amounts of changes in the distance and orientation angle using: the relative positions (Xi, Yi, Zi) of the respective feature points each corresponding between the previous and current information process cycles; and the positions (Ui, Vi) of the respective thus-corresponding feature points on the image. Furthermore, the orientation change amount calculator 24 calculates the amount of movement of the vehicle from the previous relative positions (Xi, Yi, Zi) of the respective feature points in the previous information process cycle and the current relative positions (Xi, Yi, Zi) of the respective feature points in the current information process cycle. The “amounts of changes in the distance and orientation angle” and the “amount of movement of the vehicle” which are calculated in step S07 are used for the process in step S11.
Proceeding to step S09, the ECU 13 sets the starting points of the integration operations depending on: the condition under which the multiple feature points are detected; and the state of the calculation of the distance and orientation angle from the patterned light beam. Details will be later described referring to
Proceeding to step S11, the self-position calculator 26 calculates the distance and orientation angle, as well as the current position of the vehicle from: the starting points of the integration operations set in the process in step S09; and the “amounts of changes in the distance and orientation angle” and the “amount of movement of the vehicle” calculated in the process in step S07.
Thus, the self-position calculating apparatus of the embodiment is capable of calculating the current position of the vehicle 10 by repeatedly performing the foregoing series of information process cycles to integrate the amount of movement of the vehicle 10.
Referring to a flowchart in
On the other hand, if four or more feature points are not detected (if NO in step S501), the condition under which the multiple feature points are detected can be determined as being too bad to the first criterion. For this reason, the procedure proceeds to step S503, in which the patterned light beam controller 27 sets the patterned light beam projection flag ON and sends the ON flag to the light projector 11. Thereafter, the procedure proceeds to step S507.
In step S507, the detection condition determining section 30 determines whether or not three or more feature points associated between the previous and current frames are detected. If three or more feature points are detected (if YES in step S507), the amounts of changes in the distance and orientation angle can be calculated from the temporal changes in the feature points. For this reason, the procedure proceeds to step S07 in
On the other hand, if three or more feature points are not detected (if NO in step S507), the amounts of changes in the distance and orientation angle cannot be calculated from the temporal changes in the feature points. For this reason, the procedure proceeds to step S509, in which the orientation angle calculator 22 calculates the distance and orientation angle from the temporal changes in the feature points. Thereafter, the procedure proceeds to step S07 in
In step S509, to begin with, the patterned light beam extractor 21 reads the image 38 obtained by the camera 12 from the memory, and extracts the position of the patterned light beam 32a from the image 38, as shown in
The orientation angle calculator 22 reads the data on the position of the patterned light beam 32a from the memory, calculates the distance and orientation angle from the position of the patterned light beam 32a, and stores the thus-calculated distance and orientation angle into the memory.
Referring to
During cycles t0 to t3, the number of feature points associated between the previous and current frames is four or more. For this reason, the patterned light beam projection flag is OFF, and a “three-dimensional measurement flag” is OFF as well. While the three-dimensional measurement flag is OFF, the orientation angle calculator 22 does not calculate the distance or orientation angle from the patterned light beam 32a. During cycles t4 to t6, the number of feature points associated between the previous and current frames is three. For this reason, the determination “NO” is made in step S501 in
Referring to a flowchart in
In step S901, the detection condition determining section 30 determines whether or not the condition under which the feature point detector 23 detects the feature points Te is too bad to satisfy the second criterion. In other words, the detection condition determining section 30 determines whether or not the number of feature points Te associated between the previous and current frames is three or more. If the detection condition determining section 30 determines that the number is less than three (if YES in step S901), the procedure proceeds to step S903. If the detection condition determining section 30 determines that the number is three or more (if NO in step S901), the procedure proceeds to step S909.
In step S909, the ECU 13 retains the currently-set starting points of the integration operations as they are.
In step S903, the calculation state determining section 35 determines whether or not the state of the calculation of the distance and orientation angle by the orientation angle calculator 22 is too bad to satisfy the third criterion. For example, the calculation state determining section 35 determines whether or not the orientation angle calculator 22 succeeds in calculating the distance and orientation angle in step S509 in the same information process cycle. If the calculation state determining section 35 determines that the orientation angle calculator 22 succeeds (if YES in step S903), the procedure proceeds to step S905. If the calculation state determining section 35 determines that the orientation angle calculator 22 fails (if NO in step S903), the procedure proceeds to step S907.
In step S905, the ECU 13 sets the starting points of the integration operations at the distance and orientation angle calculated by the orientation angle calculator 22 in step S509, and the current position of the vehicle obtained at the time of the calculation. Using the distance and orientation angle as the starting points, the integration operations are started afresh. In addition, using the current position of the vehicle as the starting point, the other integration is started afresh.
In step S907, the ECU 13 sets the starting points of the integration operations at the distance and orientation angle employed in the previous information process cycle, and the current position of the vehicle used in the previous information process cycle. Using the distance and orientation angle as the starting points, the integration operations are started afresh. In addition, using the current position of the vehicle as the starting point, the other integration is started afresh. Thereafter, the procedure proceeds to a process of step S11 in
The following operation/working-effect can be obtained from the first embodiment as described above.
The detection of the multiple feature points under a bad condition results in a decrease in the accuracy with which the orientation change amount calculator 24 calculates the distance and orientation angle, and accordingly leads to an increase in the error in estimating the amount of movement of the vehicle 10.
According to the first embodiment, if the detection condition determining section 30 determines that the condition under which the multiple feature points are detected is too bad to satisfy the first criterion (if NO in step S501), the patterned light beam controller 27 projects the patterned light beam 32a. Thereby, the distance and orientation angle can be calculated from the position of the patterned light beam 32a. This makes it possible to start the integration operations anew using the starting points which are reset at the error-minimized distance and orientation angle calculated from the position of the patterned light beam 32a. Accordingly, the current position of the vehicle 10 can be estimated accurately and stably.
Moreover, the road surface which makes the multiple feature points detected under a bad condition includes, for example, a road surface which offers small numbers of patterns, dents and projections to be used as feature points. Since the road surface offering small numbers of patterns, dents and projections is very flat, less noise components are included in the distance and orientation angle calculated from the patterned light beam 32a. On the other hand, in the case of the road surface 31 from which the feature points can be detected under a good condition, positions on the road surface 31 off which the patterned light beam 32a is reflected are not stable due to dents and projections of the asphalt pavement, and accordingly more noise components are included in the distance and orientation angle calculated from the patterned light beam 32a. According to the first embodiment, the distance and orientation angle can be obtained accurately and stably by selectively either updating the distance and orientation angle using the feature points or calculating the distance and orientation angle using the patterned light beam 32a depending on the conditions under which the feature points are detected.
Furthermore, in some cases, the condition under which the feature points are detected becomes bad because of a reduction in the contrast of the image 38 due to a sudden change in the illuminance of the road surface 31. According to the first embodiment, no sensor, such as an illuminometer, need be additionally provided to the self-position calculating apparatus since the condition under which the feature points are detected is directly determined. This contributes to a reduction in costs, and a reduction in the weight of the apparatus.
According to the first embodiment, if the detection condition determining section 30 determines that the condition under which the multiple feature points are detected is good enough to satisfy the first criterion (if YES in step S501), the patterned light beam controller 27 stops projecting the patterned light beam 32a. The light projection can be limited to only the case where the condition under which the multiple feature points are detected is too bad to satisfy the first criterion. Thus, it is possible to minimize power consumption for the light projection by projecting the patterned light beam 32a only as needed.
The determination in step S05 in
A second embodiment will be described using an example where the timing of calculating the distance and orientation angle using the patterned light beam 32a is controlled according to a length of time which elapses after the projection of the patterned light beam 32a is started. The hardware configuration of the self-position calculating apparatus of the second embodiment is the same as shown in
Referring to
To put it specifically, the ECU 13 measures the length of time which elapses after the patterned light beam projection flag is switched from off to on in step S503. In step S511, the ECU 13 determines whether or not a first predetermined length of time elapses after the patterned light beam projection flag is thus switched. If the first predetermined length of time does not elapse (if NO in step S511), the procedure proceeds to step S07 without calculating the distance and orientation angle from the position of the patterned light beam 32a. On the other hand, if the first predetermined length of time elapses (if YES in step S511), the procedure proceeds to step S509, where the distance and orientation angle are calculated from the position of the patterned light beam 32a. Thereafter, the procedure proceeds to step S07.
It should be noted that as shown in
As described above, the calculation of the distance and orientation angle using the patterned light beam 32a requires the patterned light beam projection flag to be switched on in the previous cycle in advance. In the second embodiment, the orientation angle calculator 22 starts to calculate the distance and orientation angle from the position of the patterned light beam 32a after the first predetermined length of time (D1) elapses from when the projection of the patterned light beam 32a is started. This makes it possible to adequately control the timing of projecting the patterned light beam 32a and the timing of calculating the distance and orientation angle.
A third embodiment will be described using an example where even when the condition under which the feature points are detected is determined as good enough to satisfy the first criterion after the projection of the patterned light beam 32a is started, the patterned light beam 32a continues being projected until a second predetermined length of time elapses after the determination.
If the detection condition determining section 30 determines that the condition under which the multiple feature points are detected is not worse than the first criterion, the patterned light beam controller 27 stops projecting the patterned light beam 32a after the second predetermined length of time elapses from when the detection condition determining section 30 makes the determination.
Referring to
The ECU 13 measures a length of time which elapses after four or more feature points are determined as being associated between the previous and current frames. If four or more feature points are determined as being associated between the previous and current frames (if YES in step S501), the procedure proceeds to step S513, where the ECU 13 determines whether or not the second predetermined length of time elapses after four or more feature points are determined as being associated between the previous and current frames. If the second predetermined length of time elapses (if YES in step S513), the procedure proceeds to step S505, where the patterned light beam controller 27 switches the patterned light beam projection flag from on to off. On the other hand, if the second predetermined length of time does not elapse (if NO in step S513), the procedure proceeds to step S515, where the patterned light beam controller 27 keeps the patterned light beam projection flag on.
It should be noted that as shown in
Thereby, once the projection of the patterned light beam 32a is started, the patterned light beam 32a is not turned off immediately after the condition under which the multiple feature points are detected becomes better. To put it specifically, hysteresis (a history effect) can be provided to the condition under which the patterned light beam 32a is projected. This makes it possible to inhibit the patterned light beam 32a from flickering, and thus to mitigate irritation which is caused by the flickering of the patterned light beam 32a.
A fourth embodiment will be described using an example where hysteresis is provided to the condition where the patterned light beam 32a is turned off unlike in the third embodiment. Even when the condition under which the multiple feature points are detected is determined as becoming too bad to satisfy the first criterion after the patterned light beam 32a is turned off, the patterned light beam controller 27 keeps the patterned light beam 32a turned off until a third predetermined length of time elapses after the determination. If the detection condition determining section 30 determines that the condition under which the multiple feature points are detected is too bad to satisfy the first criterion, the patterned light beam controller 27 starts projecting the patterned light beam 32a after the third predetermined length of time elapses from when the detection condition determining section 30 makes the determination.
Referring to
The ECU 13 measures a length of time which elapses after the number of feature points associated between the previous and current frames is determined as being not equal to or greater than five. If the number of feature points associated between the previous and current frames is determined as being not equal to or greater than five (if NO in step S501), the procedure proceeds to step S517, where the ECU 13 determines whether or not the third predetermined length of time elapses after the number of feature points associated between the previous and current frames is determined as being not equal to or greater than five. If the third predetermined length of time elapses (if YES in step S517), the procedure proceeds to step S503, where the patterned light beam controller 27 switches the patterned light beam projection flag on. On the other hand, if the third predetermined length of time does not elapse (if NO in step S517), the procedure proceeds to step S505, where the patterned light beam controller 27 keeps the patterned light beam projection flag off.
It should be noted that as shown in
Thereby, once the projection of the patterned light beam 32a is stopped, the projection of the patterned light beam 32a is not started immediately after the condition under which the multiple feature points are detected becomes worse. To put it specifically, hysteresis (a history effect) can be provided to the condition under which the patterned light beam 32a is turned off. This makes it possible to inhibit the patterned light beam 32a from flickering, and thus to mitigate irritation which is caused by the flickering of the patterned light beam 32a.
Although the first to fourth embodiments have been described as above, neither of the descriptions and drawings constituting parts of the disclosure shall be construed as limiting the present invention. The disclosure will make various alternative embodiments, examples and operational techniques clear to those skilled in the art.
Although
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/JP2014/054311 | 2/24/2014 | WO | 00 |