This application is based upon and claims the benefit of priority of the prior Japanese Patent Application No. 2016-224362, filed on Nov. 17, 2016, the entire contents of which are incorporated herein by reference.
The embodiment discussed herein is related to an apparatus, a method for outputting image information, and a non-transitory computer-readable storage medium.
In an apparatus for generating an image of an object from pixel value information (information based on amounts of received light or the like) obtained by executing a reciprocation scan on the object with laser light in a main scan direction, a technique for detecting a positional deviation between pixel rows obtained by respective reciprocation scans and extending in a horizontal direction is known.
Examples of the related art include Japanese Laid-open Patent Publication No. 2016-080962.
According to an aspect of the invention, an apparatus for outputting image information includes: a memory; and a processor coupled to the memory and configured to: execute an acquisition process that includes acquiring pixel value information items from a sensor, the sensor being configured to execute a reciprocation scan with a measurement wave in a scan direction and output the pixel value information items obtained at multiple sampling angles during the reciprocation scan; execute a calculation process that includes calculating, based on the pixel value information items for one reciprocating motion in the reciprocation scan for each of multiple different arrangement orders in which a chronological pixel value information item on a forward path and a reverse-chronological pixel value information item on a backward path are assumed to be alternately assigned, differences between the chronological pixel value information item and the reverse-chronological pixel value information item which are adjacent to each other in an arrangement direction; and execute a generation process that includes generating, based on the differences, a correction information item related to the pixel value information items for the one reciprocating motion in the reciprocation scan.
The object and advantages of the invention will be realized and attained by means of the elements and combinations particularly pointed out in the claims.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory and are not restrictive of the invention, as claimed.
The aforementioned conventional technique is to detect a positional deviation between pixel rows. Thus, if there is a deviation in adjacency relationship between pixel value information items within a pixel row serving as a standard, a similar deviation in an adjacency relationship between pixel value information items within another pixel row may not be corrected.
A “deviation in an adjacency relationship between pixel value information items” within a pixel row occurs due to a deviation of an actual sampling angle from a regular sampling angle upon the acquisition of pixel value information items in the assignment of pixel value information items for one reciprocation scan to pixels of one pixel row.
It is preferable that a pixel value information item assigned to a pixel C located between two pixels A and B be information on a position PXc between positions PXa and PXb located on an object and related to pixel value information items assigned to the two pixels A and B. On the other hand, a state in which the pixel value information item assigned to the pixel C is information on a position PXd that is not located between the positions PXa and PXb indicates a “deviation in an adjacency relationship between pixel value information items” within a pixel row.
According to an aspect, the present disclosure aims to generate pixel rows in which a deviation in an adjacency relationship between pixel value information items does not exist.
Hereinafter, an embodiment is described in detail with reference to the accompanying drawings.
Before a description of an image information output apparatus, a distance measuring apparatus 10 (as an example of a sensor and a distance image sensor) that collaborates with the image information output apparatus is described below.
The distance measuring apparatus 10 is, for example, a laser sensor and includes a light projecting unit 11 and a light receiving unit 12.
The light projecting unit 11 includes a projection lens 111, a microelectromechanical systems (MEMS) mirror 112, a lens 113, and a near-infrared laser light source 114. A driving signal C1 is given to the near-infrared laser light source 114. Laser light emitted by the near-infrared laser light source 114 based on the driving signal C1 hits the MEMS mirror 112 via the lens 113 (refer to an arrow L1). The MEMS mirror 112 is rotatable around two axes perpendicular to each other (refer to arrows R1 and R2), and the laser light is reflected on the MEMS mirror 112 at various angles. The two axes perpendicular to each other are a horizontal axis and a vertical axis. The rotation of the MEMS mirror 112 around the vertical axis enables a scan to be executed in a main scan direction (horizontal direction). In addition, the rotation of the MEMS mirror 112 around the horizontal axis enables the main scan direction to be shifted to an auxiliary scan direction (top-bottom direction). The orientation of the MEMS mirror 112 is changed based on a control signal C2. The control signals C1 and C2 may be generated by a laser driving circuit (not illustrated) and a mirror control circuit (not illustrated) based on instructions from an external (for example, the image information output apparatus (described later)). In this case, the laser driving circuit and the mirror control circuit are included in the light projecting unit 11.
The laser light reflected on the MEMS mirror 112 is output as measurement waves to the outside of the light projecting unit 11 via the projection lens 111.
The light receiving unit 12 includes a light receiving lens 121, a photodiode 122, and a distance measuring circuit 124. The reflected wave L4 is incident on the photodiode 122 via the light receiving lens 121. The photodiode 122 generates an electric signal C3 based on the amount of the incident light and provides the electric signal C3 to the downstream-side distance measuring circuit 124. The distance measuring circuit 124 measures a distance to the target object based on a time period ΔT from the rising of a pulse P1 indicating the time t0 when the laser light is output to the rising of a pulse P2 indicating the time when a reflected wave of the laser light is received. Specifically, the distance to the target object is expressed as follows.
The distance to the target object=(c×ΔT)/2, where c is the speed of light and is approximately 300,000 km/s.
The distance measuring apparatus 10 outputs the laser light based on the pulse P1, measures the time period ΔT of the reciprocation of the laser light to the target object, and calculates the distance by multiplying the time period ΔT by the speed of light. Specifically, the distance measuring distance 10 calculates the distance to the target object with a time-of-flight (TOF) method using the laser light. The distance measuring apparatus 10 provides the obtained result of calculating the distance to the target object to the downstream-side apparatus (image information output apparatus (described later)).
The distance measuring apparatus 10 executes a reciprocation scan with a measurement wave in a scan direction (horizontal direction in this example) and generates distance information items at multiple sampling time points during the reciprocation scan. In
The distance measuring apparatus 10 may execute a scan in the main scan direction (horizontal direction) by rotating around the vertical axis (Y1 axis). In addition, the distance measuring apparatus 10 may rotate around the horizontal axis (X1 axis), thereby shifting the main scan direction to the auxiliary scan direction (top-bottom direction). In
Distance information items to be sampled indicate distances related to specific spatial positions (three-dimensional positions). The specific spatial positions are hereinafter referred to as “distance information positions”. If the distance information items do not include a background and are obtained, the distance information positions correspond to points at which the laser light is reflected and are, for example, positions on the target object.
Sampling time points for the forward path are set in such a manner that the sampling is executed every time the horizontal angle (angle around the vertical axis) of the MEMS mirror 112 is changed by a certain angle (hereinafter also referred to as “pitch angle Δβ”). For example, if the rate of change in the horizontal angle for the forward path is a fixed value, the sampling time points for the forward path are set in such a manner that the sampling is executed at equal time intervals. Similarly, sampling time points for the backward path are set in such a manner that the sampling is executed every time the horizontal angle (angle around the vertical axis) of the MEMS mirror 112 is changed by the certain angle (hereinafter referred to as “pitch angle Δβ”). For example, if the rate of change in the horizontal angle for the backward path is a fixed value, the sampling time points for the backward path are set in such a manner that the sampling is executed at equal time intervals.
Horizontal angles of the MEMS mirror 112 at the set sampling time points are referred to as “sampling horizontal angles”. In order to obtain distance information items on distance information positions as much as possible for the one reciprocation scan, it is preferable that sampling horizontal angles for the forward path be different from sampling horizontal angles for the backward path. Thus, in the example illustrated in
The MEMS mirror 112 is driven in such a manner that the horizontal angle of the MEMS mirror 112 is changed over time in accordance with a sine wave, for example. In this case, the sampling horizontal angles for the forward and backward paths may be set based on the driving signal C2 given to the MEMS mirror 112. Alternatively, if the MEMS mirror 112 outputs a horizontal angle signal (not illustrated) indicating the horizontal angle, the sampling horizontal angles for the forward and backward paths may be set based on the horizontal angle signal obtained from the MEMS mirror 112. The sampling horizontal angles may be set in a range of all horizontal angles, excluding the maximum and minimum horizontal angles of the MEMS mirror 112, of the MEMS mirror 112 in a reciprocation scan, for example.
The cause and the like of deviations in adjacency relationships between pixel value information items in the scan direction are described with reference to
In
As described above, the sampling horizontal angles for the backward path are slightly shifted from the sampling horizontal angles for the forward path based on the design of the distance measuring apparatus 10 (refer to
The actual sampling horizontal angles, however, may deviate from the regular sampling horizontal angles (nominal sampling horizontal angles based on the design), as illustrated in
The significant deviations of the actual sampling horizontal angles from the regular sampling horizontal angles may cause deviations in adjacency relationships of the actual sampling horizontal angles from adjacency relationships of the regular sampling horizontal angles and cause “deviations in adjacency relationships between pixel value information items” within pixel rows, as described later.
For example, it is assumed that distances are measured in a state illustrated in
If a distance image is generated in accordance with a chronological order of distance information items that do not have a deviation in adjacency relationships between sampling horizontal angles in the state illustrated in
When distance information items are obtained in the state in which there is not a deviation in the adjacency relationships between the sampling horizontal angles, an appropriate distance image may be obtained by assigning, in a chronological order, the distance information items to the pixels PX1 to PX16 arranged in the horizontal direction without a change (or without correction), as illustrated in
Specifically, the normal assignment method is as follows. In the normal assignment method, a chronological distance information item on a forward path is assigned to every two pixels (PX1, PX3, PX5, . . . in
On the other hand, it is assumed that there are deviations in adjacency relationships between sampling horizontal angles as illustrated in
Horizontal angles β1 to β16 are regular sampling horizontal angles. If there is not a deviation in adjacency relationships between sampling horizontal angles, the regular sampling horizontal angles and the numbers in the sampling order have correspondence relationships indicated by “without deviation” in
As indicated by “with deviations” in
The deviations of the sampling horizontal angles for the backward path are nearly uniform and larger than a half of one pitch angle Δβ to be used to change sampling horizontal angles. For example, a sampling horizontal angle in the 10th sampling is β16 and different from the regular sampling horizontal angle β14, or β16>β14+βΔ/2 (thus β16>β15).
Thus, adjacency relationships of the sampling horizontal angles for the backward path deviate by one with respect to relationships with the sampling horizontal angles for the forward path, as indicated by “with deviations” in
If a distance image is formed using the normal assignment method based on distance information items obtained in the state in which there are the deviations in the adjacency relationships between the sampling horizontal angles, the distance image may be an image illustrated in
Specifically, in the normal assignment method, as illustrated in
The “deviations in the adjacency relationships between the pixel value information items” within the pixel rows are defined as follows. It is assumed that a horizontal pixel position (X coordinate) located within the distance image and associated with a distance information item obtained at a sampling horizontal angle β2 between two sampling horizontal angles β1 and β3 is PX2. In addition, it is assumed that horizontal pixel positions located within the distance image and associated with distance information items obtained at sampling horizontal angles β1 and β3 are PX1 and PX3. In this case, a deviation in an adjacency relationship between pixel value information items within a pixel row indicates a state in which an inequality of PX1<PX2<PX3 is not established. The deviation in the adjacency relationship between the pixel value information items within the pixel row occurs when the actual sampling horizontal angle β2 is not between the sampling horizontal angles β1 and β3 and is smaller than the sampling horizontal angle β1 or larger than the sampling horizontal angle β3, for example.
As described above, when an actual sampling horizontal angle significantly deviates from a regular sampling horizontal angle, a deviation in an adjacency relationship between the sampling horizontal angles occurs. When a deviation in an adjacency relationship between sampling horizontal angles occurs, a deviation in an adjacency relationship between pixel value information items occurs as described above in the normal assignment method. A deviation in an adjacency relationship between sampling horizontal angles occurs when an actual sampling horizontal angle significantly deviates from a regular sampling horizontal angle only during a part (for example, a scan for a backward path) of a time period of one reciprocation scan. If actual sampling horizontal angles uniformly deviate from regular sampling horizontal angles during an entire single reciprocation scan, a deviation in an adjacency relationship between sampling horizontal angles does not occur.
Next, the image information output apparatus is described with reference to
The image information output apparatus 100 outputs image information such as a distance image based on distance information items obtained from the aforementioned distance measuring apparatus 10. The image information output apparatus 100 may collaborate with the distance measuring apparatus 10 to form a system.
The image information output apparatus 100 may be achieved by a computer connected to the distance measuring apparatus 10. The connection between the image information output apparatus 100 and the distance measuring apparatus 10 may be achieved by a wired communication path, a wireless communication path, or a combination of wired and wireless communication paths. For example, if the image information output apparatus 100 is a server installed relatively remotely from the distance measuring apparatus 10, the image information output apparatus 100 may be connected to the distance measuring apparatus 10 via a network. In this case, the network may include a wireless communication network for mobile phones, the Internet, a world wide web, a virtual private network (VPN), a wide area network (WAN), a cable network, or an arbitrary combination of two or more thereof. If the image information output apparatus 100 is installed relatively near the distance measuring apparatus 10, a wireless communication path between the image information output apparatus 100 and the distance measuring apparatus 10 may be achieved by near field communication, Bluetooth (registered trademark), Wireless Fidelity (Wi-Fi), or the like.
In the example illustrated in
The controller 101 is an arithmetic device that executes programs stored in the main storage section 102 and the auxiliary storage section 103. The controller 101 receives data from the input device 107 and a storage device, calculates and processes the data, and outputs the data to the storage device and the like.
The main storage section 102 is a read only memory (ROM), a random access memory (RAM), or the like. The main storage section 102 is a storage device that stores or temporarily stores data, programs such as application software, and programs such as an operating system (OS) that is basic software to be executed by the controller 101.
The auxiliary storage section 103 is a hard disk drive (HDD) or the like. The auxiliary storage section 103 is a storage device that stores data on the application software and the like.
The driving device 104 reads a program from a storage medium 105 such as a flexible disk and installs the read program in a storage device, for example.
The storage medium 105 stores a predetermined program. The program stored in the storage medium 105 is installed in the image information output apparatus 100 via the driving device 104. The installed predetermined program may be executed by the image information output apparatus 100.
The network I/F section 106 is an interface between the image information output apparatus 100 and a peripheral device (for example, the distance measuring apparatus 10) having a communication function and connected to the image information output apparatus 100 via a network configured with a data transmission path such as a wired line, a wireless line, or a combination of wired and wireless lines.
The input section 107 is cursor keys, a keyboard provided with a numeric keypad, various functional keys, and the like, a mouse, a touch pad, or the like.
In the example illustrated in
The image information output apparatus 100 includes a distance information item acquirer 150 (an example of a pixel value information acquirer), an evaluation value calculator 151 (an example of a calculator), and a correction information item generator 152. The distance information item acquirer 150, the evaluation value calculator 151, and the correction information item generator 152 may be achieved by causing the controller 101 illustrated in
The distance information item acquirer 150 acquires distance information items from the distance measuring apparatus 10 via, for example, the network I/F section 106. The distance information item acquirer 150 may acquire the distance information items from the distance measuring apparatus 10 via the storage medium 105 or the driving device 104. In this case, the distance information items to be acquired from the distance measuring apparatus 10 are stored in the storage medium 105 or the driving device 104 in advance.
The evaluation value calculator 151 calculates evaluation values related to a “deviation in adjacency relationships between pixel value information items” in the aforementioned scan direction for each reciprocation scan. The evaluation values are related to consistency between adjacency relationships between multiple sampling horizontal angles in the horizontal direction and adjacency relationships between distance information items in the horizontal direction in a distance image. If there is the consistency between the adjacency relationships between the sampling horizontal angles in the horizontal direction and the adjacency relationships between the distance information items in the horizontal direction in the distance image, there is not a “deviation in the adjacency relationships between the pixel value information items” in the aforementioned scan direction.
Specifically, the evaluation value calculator 151 calculates evaluation values in the case where distance information items for one reciprocation scan are assigned to pixels of the distance image by a predetermined assignment method. Each of the evaluation values indicates whether or not there is a “deviation in an adjacency relationship between pixel value information items” within a pixel row in the distance image obtained as a result of the assignment. For example, each of the evaluation values may be a parameter that becomes larger as a “deviation in an adjacency relationship between pixel value information items” within a pixel row becomes larger. In this case, the smallest evaluation value may be handled as a value indicating that there is not a “deviation in an adjacency relationship between pixel value information items” within a pixel row. Alternatively, each of the evaluation values may be a parameter that becomes smaller as a “deviation in an adjacency relationship between pixel value information items” within a pixel row becomes larger in the distance image obtained as a result of the assignment. In this case, the largest evaluation value may be handled as a value indicating that there is not a “deviation in an adjacency relationship between pixel value information items” within a pixel row. The evaluation values are arbitrary as long as each of the evaluation value indicates whether or not there is a deviation in an adjacency relationship between pixel value information items” within a pixel row in the distance image obtained as a result of the assignment.
When a “deviation in an adjacency relationship between pixel value information items” in the scan direction occurs, an adjacency relationship between a chronological distance information item on a forward path and a reverse-chronological distance information item on a backward path is different from a regular adjacency relationship, as described above. In a distance image obtained as a result of the deviation, a characteristic change (increase or reduction) in a difference between distance information items in the horizontal direction appears. For example, in the distance image illustrated in
The predetermined assignment method is to mostly alternately assign chronological distance information items on a forward path and reverse-chronological distance information items on a backward path to pixels PX1 to PX16 arranged in a single row in a distance image in the order from the pixel PX1 to the PX16. “Mostly alternately assigning the distance information items” indicates that it is acceptable for a distance information item on the forward path and a distance information item on the backward path not to be alternately assigned to pixels included in an edge portion of the distance image in the horizontal direction as a result of a “deviation caused by a change in the assignment method” as described later. The evaluation value calculator 151 calculates evaluation values for each of multiple predetermined assignment methods.
The multiple predetermined assignment methods include the aforementioned normal assignment method and methods (hereinafter referred to as “correction assignment methods”) of assigning distance information items on forward and backward paths to pixels in such a manner that pixels are shifted toward an arbitrary side in the horizontal direction in a distance image.
In the example illustrated in
The example illustrated in
Hereinafter, shifting, by one, each of pixels to which distance information items on a backward path are assigned in the first correction assignment method (No. 1) and the second correction assignment method (No. 2), compared with the normal assignment method, is also indicated by the fact that a “shifting number is 1”. Thus, since the pixels to which the distance information items on the backward path are assigned are shifted by two in the third correction assignment method (No. 3), compared with the normal assignment method, the “shifting number is 2”. The shifting number corresponds to the number of times that pixels to which distance information items on the backward path are assigned are shifted one by one in the certain direction, compared with the normal assignment method.
The evaluation value calculator 151 calculates evaluation values for each of the multiple predetermined assignment methods as described above. In the case where the predetermined assignment methods are different from each other, adjacency relationships between chronological distance information items on a forward path and reverse-chronological distance information items on a backward path in one of the predetermined assignment methods are changed from adjacency relationships between the chronological distance information items on the forward path and the reverse-chronological distance information items on the backward path in another one of the predetermined assignment methods. Specifically, for example, while a distance information item on the 7th sampling (for the forward path) has an adjacency relationship with and is adjacent to distance information items on the 11th and 10th sampling (for the backward path) in the normal assignment method, the distance information item on the 7th sampling (for the forward path) has a different adjacency relationship in each of the correction assignment methods. For example, in the first correction assignment method (No. 1), the distance information item on the 7th sampling (for the forward path) has an adjacency relationship with and is adjacent to the distance information items on the 10th and 9th sampling (for the backward path). In the second correction assignment method (No. 2), the distance information item on the 7th sampling (for the forward path) has an adjacency relationship with and is adjacent to the distance information items on the 12th and 11th sampling (for the backward path).
Since the adjacency relationships between the chronological distance information items on the forward path and the reverse-chronological distance information items on the backward path are changed in the aforementioned manner, the probabilities or degrees of “deviations in adjacency relationships between pixel value information items” within pixel rows may be detected with high accuracy. The evaluation value calculator 151 may not generate a single row of a distance image to be subjected to the assignment methods upon the calculation of evaluation values for the normal assignment method and the correction assignment methods, and it is sufficient if the evaluation value calculator 151 virtually reproduces a single row of the distance image to be subjected to the assignment methods and calculates the evaluation values.
The correction information item generator 152 compares the evaluation values calculated by the evaluation value calculator 151 for the multiple assignment methods with each other for each reciprocation scan and generates a correction information item on distance information items for each reciprocation scan based on the evaluation values. Each of the correction information items is generated based on the best evaluation value among evaluation values for each reciprocation scan. Specifically, each of the correction information items is generated based on an evaluation value indicating that there is not a “deviation in an adjacency relationship between pixel value information items” with a pixel row. For example, if each of the evaluation values is a parameter that becomes larger as a “deviation in an adjacency relationship between pixel value information items” within a pixel row becomes larger, each of the correction information items is generated based on the smallest evaluation value among the evaluation values.
Each of the correction information items may be information directly or indirectly indicating an assignment method (or an arrangement order in which pixel value information items are arranged) that does not cause a “deviation in an adjacency relationship between pixel value information item” within a pixel row. The correction information items, each of which directly or indirectly indicates an assignment method that does not cause a “deviation in an adjacency relationship between pixel value information items” within a pixel row, may be distance information items modified in such a manner that even if the assignment is executed using the normal assignment method, a “deviation in an adjacency relationship between pixel value information items” within a pixel row does not occur. The modified distance information items may be generated as follows in the example illustrated in
Alternatively, the correction information items may be a distance image obtained by executing the assignment using an assignment method that does not cause a “deviation in an adjacency relationship between pixel value information” within a pixel row.
According to the embodiment, a distance image that does not have a deviation in an adjacency relationship between pixel value information items may be obtained. Specifically, according to the embodiment, evaluation values, each of which indicates whether or not there is a “deviation in an adjacency relationship between pixel value information items” within a pixel row, are calculated for each of the multiple predetermined methods. In this case, an assignment method for which evaluation values that indicate that there is not a “deviation in an adjacency relationship between pixel value information items” are calculated is an assignment method that does not cause a “deviation in an adjacency relationship between pixel value information items”. Thus, a distance image that does not have a deviation in an adjacency relationship between pixel value information items may be obtained based on a correction information item indicating an assignment method that does not cause a “deviation in an adjacency relationship between pixel value information items”.
The distance information items are used as pixel value information items in the embodiment, but the embodiment is not limited to this. For example, pixel value information items (information items of the amounts or intensities of the light) based on the amounts of the light received by the light receiving unit 12 or the like may be used instead of the distance information items.
Next, several operational examples of the image information output apparatus 100 are described with reference to
In step S140, the distance information item acquirer 150 of the image information output apparatus 100 acquires distance information items for the latest one frame.
In step S142, the evaluation value calculator 151 of the image information output apparatus 100 generates a distance image (one frame) using the normal assignment method based on the distance information items, acquired in step S140, for the one frame. The normal assignment method is described above (refer to
In step S143, the evaluation calculator 151 executes an evaluation value calculation process to calculate the aforementioned evaluation values based on the distance image generated in step S142. An example of the evaluation value calculation process is described later with reference to
In step S144, the correction information item generator 152 of the image information output apparatus 100 identifies the smallest evaluation value for each of pixel rows based on the results of calculating the evaluation values in step S144. In the example illustrated in
In step S145, the correction information item generator 152 generates a correction information item for each of the pixel rows based on the smallest evaluation values identified in step S144. In
In step S146, the correction information item generator 152 corrects the distance image generated in step S142 based on the correction information items generated in step S148 and related to all the pixel rows for the single frame. Specifically, the correction information item generator 152 corrects, based on the correction information items, each of pixel rows for which correction information items that do not indicate that the shifting number M is 0 have been generated. Then, the correction information item generator 152 outputs the distance image (another form of the correction information items) after the correction. The distance image after the correction is obtained as a result of executing the assignment using an assignment method for which the smallest evaluation values have been calculated.
In the process illustrated in
In step S1600, the evaluation value calculator 151 sets the maximum value of the shifting number M to the maximum number “k” and sets a row number m of a “pixel row to be processed” to “1”. The shifting number M is the number of times that pixels to which distance information items on a backward path are assigned are shifted one by one toward the left or right side in the horizontal direction in the distance image generated in step S142. If the shifting number M is 0, the normal assignment method is used. If the shifting number M is equal to or larger than 1, any of the correction assignment methods is used. The maximum number “k” is an arbitrary integer of 1 or more and may be changed by a user. In
In step S1602, the evaluation value calculator 151 extracts, from the distance image generated in step S142, an m-th pixel row (pixel row extending in the horizontal direction) as a “pixel row to be processed”. For example, the evaluation value calculator 151 may extract the m-th pixel row from the top of the distance image in the vertical direction.
In step S1604, the evaluation value calculator 151 sets the shifting number M to an initial value “−k”. Specifically, M=−k.
In step S1606, the evaluation value calculator 151 determines whether or not the shifting number M is equal to or smaller than the maximum number k. If the shifting number M is equal to or smaller than the maximum number k, the process proceeds to step S1608. If the shifting number M is larger than the maximum number k, the process proceeds to step S1630.
In step S1608, the evaluation value calculator 151 determines whether or not the shifting number M is 0. If the shifting number M is 0, the process proceeds to step S1616. If the shifting number M is not 0, the process proceeds to step S1610.
In step S1610, the evaluation value calculator 151 determines whether or not the shifting number M is negative. If the shifting number M is negative, the process proceeds to step S1612. If the shifting number M is not negative (or is positive), the process proceeds to step S1614.
In step S1612, the evaluation value calculator 151 shifts the distance information items on the backward path one by one toward the left side the absolute number M of times in the distance image generated in step S142. For example, if M=−1, the shifting corresponds to the correction assignment method (No. 1) illustrated in
In step S1614, the evaluation value calculator 151 shifts the distance information items on the backward path one by one toward the right side the number M of times in the distance image generated in step S142. For example, if M=1, the shifting corresponds to the correction assignment method (No. 2) illustrated in
In step S1616, the evaluation value calculator 151 sets a sum to an initial value “0”. The sum finally becomes an evaluation value, as described later.
In step S1618, the evaluation value calculator 151 sets N to “1”.
In step S1620, the evaluation value calculator 151 determines whether or not N is smaller than a number Nmax of pixels arranged in the horizontal direction in the distance image. The number Nmax of pixels arranged in the horizontal direction in the distance image is a defined value. If N is smaller than the number Nmax of pixels arranged in the horizontal direction in the distance image, the process proceeds to step S1622. If N is not smaller than the number Nmax, the process proceeds to step S1626.
In step S1622, the evaluation value calculator 151 calculates the absolute value |ΔDN| of the difference ΔDN (=DN+1−DN) between a distance information item DN of an N-th pixel from the leftmost side of the distance image and a distance information item DN+1 of an (N+1)-th pixel from the leftmost side of the distance image. Then, the evaluation value calculator 151 updates the sum by adding the calculated absolute value |ΔDN| to the sum.
In step S1624, the evaluation value calculator 151 increments N by only “1” and repeats the process from step S1620. As a result, the sum Sm is finally expressed by the following Equation (1).
In step S1626, the evaluation value calculator 151 associates the final sum Sm with the shifting number M and the row number m indicating the currently set pixel row to be processed and stores the final sum Sm. The sum Sm stored in step S1626 is an evaluation value for the m-th pixel row for an assignment method related to the shifting number M.
In step S1628, the evaluation value calculator 151 increments the shifting number M by only “1”.
In step S1630, the evaluation value calculator 151 determines whether or not the row number m is smaller than a number NNMax of pixels arranged in the vertical direction in the distance image. The number NNMax of pixels arranged in the vertical direction in the distance image is a defined value. If the row number m is smaller than the number NNMax of pixels arranged in the vertical direction in the distance image, the process proceeds to step S1632 and returns to step S1602. If the row number m is not smaller than the number NNMax, the evaluation value calculator 151 determines that an unprocessed pixel row does not exist, and the evaluation value calculator 151 terminates the process.
In step S1632, the evaluation value calculator 151 increments the row number m by only “1”.
According to the first operational example, the sum is calculated according to Equation (1) as an evaluation value related to a “deviation in an adjacency relationship between pixel value information items” within a pixel row. Specifically, if distance information items of each pair of adjacent pixels within a pixel row to be processed are treated as a single pair, the evaluation value calculator 151 calculates, as an evaluation value, the sum of absolute values of differences between all pairs of distance information items. Then, the evaluation value calculator 151 calculates evaluation values for the pixel rows while changing the shifting number M. Thus, a number k of evaluation values in the case where the shifting number M is positive, a number k of evaluation values in the case where the shifting number M is negative, and a single evaluation value in the case where the shifting number M is 0, are obtained for each of the pixel rows, or a number 2k+1 of evaluation values are obtained for each of the pixel rows.
According to the first operational example, the evaluation values are calculated, while attention is paid to the fact that, if a deviation in an adjacency relationship between pixel value information items occurs in the distance image, the number of image portions in which differences between distance information items of pixels adjacent to each other in the horizontal direction are large is large. Specifically, the sum of absolute values of differences between distance information items of target pixels and distance information items of pixels adjacent to the target pixels is calculated as an evaluation value, while the number of times that the distance information items on the backward path are shifted one by one toward the left or right side is changed.
According to the first operational example, for each of the pixel rows, the shifting number M that does not cause a “deviation in an adjacency relationship between pixel value information items” may be accurately identified based on evaluation values for shifting numbers, and a highly accurate correction information item may be obtained.
In the example illustrated in
In the aforementioned first operational example, the evaluation value calculator 151 sets N to “1” in step S1618 and determines whether or not N is smaller than the number Nmax of pixels arranged in the horizontal direction in the distance image in step S1620 in the process illustrated in
In the first operational example, the evaluation value calculator 151 calculates sums Sm based on Equation (1) as the evaluation values, but is not limited to this. For example, the evaluation value calculator 151 may calculate, as each of the evaluation values, the number of image portions in which differences ΔDN are equal to or larger than a predetermined value Dth. The predetermined value Dth may be determined based on differences between distance information items of pixels adjacent to each other in the horizontal direction if a deviation in an adjacent relationship between pixel value information items occurs.
In the first operational example, a number k of evaluation values in the case where the shifting number M is positive and a number k of evaluation values in the case where the shifting number M is negative are calculated for each pixel row, but the evaluation values are not limited to this. For example, a number k of evaluation values in the case where the shifting number M is positive or negative may be calculated for each pixel row. The same applies the second and third operational examples described below.
The second operational example is different from the first operational example only in terms of an evaluation value calculation process to be executed in step S144. The evaluation value calculation process to be executed in the second operational example is described below.
Steps that are included in the process illustrated in
In step S1900, the evaluation value calculator 151 sets an immediately preceding value to “0”.
In step S1902, the evaluation value calculator 151 calculates the difference ΔDN (=DN+1−DN) between a distance information item DN of an N-th pixel from the leftmost side of the distance image and a distance information item DN+1 of an (N+1)-th pixel from the leftmost side of the distance image.
In step S1904, the evaluation value calculator 151 determines whether or not the immediately preceding value is different from 0 and whether or not the sign of the immediately preceding value is different from the sign of the difference ΔDN calculated in step S1902. For example, if the immediately preceding value is negative and the sign of the difference ΔDN calculated in step S1902 is positive, the result of the determination indicates “YES”. If the immediately preceding value is positive and the sign of the difference ΔDN calculated in step S1902 is negative, the result of the determination indicates “YES”. On the other hand, if the immediately preceding value is 0 or the difference ΔDN calculated in step S1902 is 0, the result of the determination indicates “NO”. If the immediately preceding value is not 0, the difference ΔDN calculated in step S1902 is not 0, and the immediately preceding value and the difference ΔDN are both positive or both negative, the result of the determination indicates “NO”. If the result of the determination indicates “YES”, the process proceeds to step S1906. If the result of the determination indicates “NO”, the process proceeds to step S1908.
In step S1906, the evaluation value calculator 151 updates a sum by adding the absolute value |ΔDN| of the difference ΔDN calculated in step S1902 to the sum.
In step S1908, the evaluation value calculator 151 sets (updates) the immediately preceding value to the difference ΔDN calculated in step S1902. The immediately preceding value is equal to the difference ΔDN.
The process proceeds to steps S1908 and S1624 and is repeated from step S1620. As a result, in the second operational example, the sum Sm is finally expressed according to the following Equation (2).
In Equation (2), if N is equal to or larger than 2, and the following requirement is satisfied, |CN+1−CN|=|DN+1−DN|.
The requirement is that (DN+1−DN)×(DN−DN−1)<0.
If this requirement is not satisfied or if N=1, |CN+1−CN|=0 in Equation (2).
According to the second operational example, as an evaluation value related to a “deviation in an adjacency relationship between pixel value information items” within a pixel row, the sum is calculated according to Equation (2). Specifically, if distance information items of each pair of adjacent pixels within a pixel row to be processed are treated as a single pair, the evaluation value calculator 151 calculates, as each of the evaluation values, the sum of absolute values of differences between pairs of distance information items of image portions in which the sign of the difference between a pair of distance information items of N-th and (N+1)-th pixels adjacent to each other is different from the sign of the difference between a pair of distance information items of (N+1)-th and (N+2)-th pixels adjacent to each other. Then, the evaluation value calculator 151 calculates evaluation values for each of the pixel rows while changing the shifting number M. Thus, a number k of evaluation values in the case where the shifting number M is positive, a number k of evaluation values in the case where the shifting number M is negative, and a single evaluation value in the case where the shifting number M is 0, are obtained for each of the pixel rows, or a number 2k+1 of evaluation values are obtained for each of the pixel rows.
If a deviation in an adjacency relationship between pixel value information items occurs in the distance image, the number of image portions in which the sign of the difference ΔDN between an N-th pixel and an (N+1)-th pixel adjacent to the N-th pixel on the right side is different from the sign of the difference ΔDN+1 between the (N+1)-th pixel and an (N+2)-th pixel adjacent to the (N+1)-th pixel is large. According to the second operational example, while this fact is paid attention, the evaluation values are calculated by summing absolute values of differences between pairs of distance information items of image portions in which the sign of the difference between a pair of distance information items of N-th and (N+1)-th pixels adjacent to each other is different from the sign of the difference between a pair of distance information items of (N+1)-th and (N+2)-th pixels adjacent to each other.
According to the second operational example, for each of the pixel rows, the shifting number M that does not cause a “deviation in an adjacency relationship between pixel value information items” may be accurately identified based on evaluation values related to the different shifting numbers, and a highly accurate correction information item may be obtained.
Thus, in the example illustrated in
In the second operational example, in
In the second operational example, the evaluation value calculator 151 calculates sums Sm based on Equation (2) as the evaluation values, but is not limited to this. For example, the evaluation value calculator 151 may calculate, as each of the evaluation values, the number of image portions in which the sign of the difference ΔDN between an N-th pixel and an (N+1)-th pixel adjacent to the N-th pixel on the right side is different from the sign of the difference ΔDN+1 between the (N+1)-th pixel and an (N+2)-th pixel adjacent to the (N+1)-th pixel on the right side.
The third operational example is different from the first operational example only in terms of an evaluation value calculation process to be executed in step S144. The evaluation value calculation process to be executed in the third operational example is described below.
Steps that are included in the process illustrated in
Step S2100 is executed if the result of the determination of step S1904 indicates “YES”.
In step S2100, the evaluation value calculator 151 determines whether or not the absolute value of the difference between the absolute value of the immediately preceding value and the absolute value of the difference ΔDN calculated in step S1902 is equal to or smaller than a predetermined threshold Th. The predetermined threshold Th is used to determine whether or not the absolute value of the difference ΔDN is close to the absolute value of the immediately preceding value. The predetermined threshold Th is an adaptive value. For example, the predetermined threshold Th is set based on a range of the difference between distance information items obtained at two adjacent sampling horizontal angles for the same object. If the result of the determination indicates “YES”, the process proceeds to step S1906. If the result of the determination indicates “NO”, the process proceeds to step S1908.
The process proceeds to steps S1908 and S1624 and is repeated from step S1620. As a result, in the third operational example, the sum Sm is finally expressed according to the following Equation (3).
In Equation (3), if N is equal to or larger than 2, and the following requirement is satisfied, |CN+1−CN|=|DN+1−DN|.
The requirement is that (DN+1−DN)×(DN−DN−1)<0 and −Th≤|DN+1−DN|−|DN−DN−1|≤Th.
If this requirement is not satisfied or if N=1, |CN+1−CN|=0 in Equation (3).
According to the third operational example, as an evaluation value related to a “deviation in an adjacency relationship between pixel value information items” within a pixel row, the sum Sm is calculated according to Equation (3). Specifically, if distance information items on each pair of adjacent pixels within a pixel row to be processed is treated as a pair, the evaluation value calculator 151 calculates, as each of the evaluation values, the sum of absolute values of differences between distance information items of image portions in which the sign of the difference between a pair of distance information items of N-th and (N+1) adjacent to each other pixels is different from the sign of the difference between a pair of distance information items of (N+1) and (N+2) pixels adjacent to each other and in which the absolute value of the difference between the pair of distance information items of the N-th and (N+1) pixels is close to the absolute value of the difference between the pair of distance information items of the (N+1) and (N+2) pixels. Then, the evaluation value calculator 151 calculates evaluation values for each of the pixel rows while changing the shifting number M. Thus, a number k of evaluation values in the case where the shifting number M is positive, a number k of evaluation values in the case where the shifting number M is negative, and an evaluation value in the case where the shifting number M is 0, are obtained for each of the pixel rows, or a number 2k+1 of evaluation values are obtained for each of the pixel rows.
If a deviation in an adjacency relationship between pixel value information items occurs in the distance image, the number of image portions in which the sign of the difference ΔDN between an N-th pixel and an (N+1)-th pixel adjacent to the N-th pixel on the right side is different from the sign of the difference ΔDN+1 between the (N+1)-th pixel and an (N+2)-th pixel adjacent to the (N+1)-th pixel on the right side and in which the absolute value of the difference between ΔDN is close to the absolute value of the difference between ΔDN+1 is large. According to the third operational example, while this fact is paid attention, the evaluation values are calculated by summing only absolute values of differences between pairs of distance information items of image portions in which the sign of the difference between a pair of distance information items of N-th and (N+1)-th pixels adjacent to each other is different from the sign of the difference between a pair of distance information items of (N+1)-th and (N+2)-th pixels adjacent to each other and in which the absolute value of the differences between the pair of distance information items of the N-th and (N+1)-th pixels is close to the pair of distance information items of the (N+1)-th and (N+2)-th pixels.
According to the third operational example, for each of the pixel rows, the shifting number M that does not cause a “deviation in an adjacency relationship between pixel value information items” may be accurately identified based on evaluation values for the different shifting numbers, and a highly accurate correction information item may be obtained.
Thus, in the example illustrated in
In the third operational example, the evaluation value calculator 151 calculates sums Sm based on Equation (3) as the evaluation values, but is not limited to this. For example, the evaluation value calculator 151 may calculate, as each of the evaluation values, the number of image portions in which the sign of the difference ΔDN between an N-th pixel and an (N+1)-th pixel adjacent to the Nth pixel on the right side is different from the sign of the difference ΔDN+1 between the (N+1)-th pixel and an (N+2)-th pixel adjacent to the (N+1)-th pixel on the right side and in which absolute values of the differences are close to each other.
Steps that are included in the process illustrated in
In step S150, the correction information item generator 152 executes a process of correcting the correction information items generated in step S148. The process of correcting the correction information items is described with reference to
In step S240, the correction information item generator 152 sets a row number L of a pixel row of the distance image to an initial value “2”.
In step S242, the correction information item generator 152 determines whether or not the row number L is smaller than the maximum number of pixel rows. The maximum number of pixel rows corresponds to the number NNmax of all pixels arranged in the vertical direction in the distance image and is a defined value. If the row number L is smaller than the number NNmax of all pixels arranged in the vertical direction in the distance image, the process proceeds to step S244. If the row number L is not smaller than the number NNmax, the process proceeds to step S250.
In step S244, the correction information item generator 152 determines whether or not a correction information item (shifting number M causing the minimum evaluation value) of an (L−1)-th pixel row is the same as a correction information item (shifting number M causing the minimum evaluation value) of an (L+1)-th pixel row. If the result of the determination indicates “YES”, the process proceeds to step S246. If the result of the determination indicates “NO”, the process returns to step S242.
In step S246, the correction information item generator 152 determines whether or not a correction information item of the L-th pixel row is different from the correction information item of the (L−1)-th pixel row or the correction information item of the (L+1)-th pixel row. If the result of the determination indicates “YES”, the process proceeds to step S248. If the result of the determination indicates “NO”, the process proceeds to step S249 and returns to step S242.
In step S248, the correction information item generator 152 replaces the correction information item of the L-th pixel row with the correction information item of the (L−1)-th pixel row or the correction information item of the (L+1)-th pixel row. Specifically, the correction information item generator 152 corrects the correction information item of the L-th pixel row in such a manner that the correction information item of the L-th pixel row is the same as the correction information item of the (L−1)-th pixel row or the correction information item of the (L+1)-th pixel row.
In step S249, the correction information item generator 152 increments L by only “1”.
In step S250, the correction information item generator 152 outputs a corrected distance image obtained by correcting the distance image generated in step S142 based on correction information items (including correction information items after the aforementioned correction), generated in step S148 or S248, of all the pixel rows for the one frame. Specifically, the correction information item generator 152 outputs the corrected distance image obtained by correcting the distance image generated in step S142 using the correction information item after the correction for the pixel row corrected in step S248 and using the correction information items generated in step S148 for pixel rows that are not corrected in step S248.
Deviations in the adjacency relationships between the aforementioned sampling horizontal angles are not uniform in an entire distance image and tend to occur for each of pixel rows (for each of reciprocation scans). The deviations in the adjacency relationships between the sampling horizontal angles, however, are not completely independent of each other in the pixel rows. The distance image may have a characteristic in which deviations in adjacency relationships between sampling horizontal angles in multiple pixel rows adjacent to each other continuously occur and are the same as or similar to each other. If noise that is an isolated point or the like is included in a distance information item within the distance image during a certain reciprocation scan, a correction information item for the certain reciprocation scan may not be appropriate due to an effect of the noise.
According to the fourth operational example, attention is paid to the fact that deviations in adjacency relationships between sampling horizontal angles in multiple pixel rows adjacent to each other may continuously occur and may be the same as or similar to each other, and if a correction information item of a pixel row immediately preceding a certain pixel row is the same as a correction information item of a pixel row immediately succeeding the certain pixel row, and a correction information item of the certain pixel row is different from the correction information items of the pixel rows immediately preceding and succeeding the certain pixel row, the correction information item of the certain pixel row is replaced with the correction information item of the pixel row immediately preceding the certain pixel row or the correction information item of the pixel row immediately succeeding the certain pixel row. Thus, a probability at which the accuracy of correction information items is reduced due to an effect of noise may be reduced.
Although the embodiment is described above, the present disclosure is not limited to the specific embodiment. Various modifications and changes may be made without departing from the scope of claims. In addition, all the constituent elements described in the embodiment or two or more of the constituent elements described in the embodiment may be combined.
For example, in the aforementioned embodiment, the distance measuring apparatus 10 uses laser light as a measurement wave, but is not limited to this. For example, the distance measuring apparatus 10 may use another measurement wave such as a millimeter wave.
All examples and conditional language recited herein are intended for pedagogical purposes to aid the reader in understanding the invention and the concepts contributed by the inventor to furthering the art, and are to be construed as being without limitation to such specifically recited examples and conditions, nor does the organization of such examples in the specification relate to a showing of the superiority and inferiority of the invention. Although the embodiment of the present invention has been described in detail, it should be understood that the various changes, substitutions, and alterations could be made hereto without departing from the spirit and scope of the invention.
Number | Date | Country | Kind |
---|---|---|---|
2016-224362 | Nov 2016 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5982524 | Fujimoto | Nov 1999 | A |
7079297 | Sakai | Jul 2006 | B2 |
8115980 | Park | Feb 2012 | B2 |
9690092 | Freedman | Jun 2017 | B2 |
20060192094 | Taniguchi | Aug 2006 | A1 |
20060245462 | Takeda | Nov 2006 | A1 |
20070047085 | Matsumoto | Mar 2007 | A1 |
20080055388 | Klemer | Mar 2008 | A1 |
20090279156 | Yen | Nov 2009 | A1 |
20120097833 | Lin | Apr 2012 | A1 |
20160377849 | Onda | Dec 2016 | A1 |
20170244944 | Ohara | Aug 2017 | A1 |
Number | Date | Country |
---|---|---|
2016-080962 | May 2016 | JP |
Number | Date | Country | |
---|---|---|---|
20180137793 A1 | May 2018 | US |