The present invention relates to optical distance measurement, and more particularly, to an optical distance measurement system and related method having sensed values filtration mechanism and low hardware resources requirement.
A conventional distance measurement system captures reflection caused by light encountering an obstacle, and analyzes a location where the reflection comes from to determine a distance from the distance measurement system to the obstacle (i.e., depth of the obstacle). Such measurement is based on triangulation, which calculates depth information of the obstacle according to the location where the reflection comes from. In modern applications, the light sources usually emits linear light rather than spot light, which allows to simultaneously obtain depth information with respect to multiple points on the obstacle such that the distance measurement can be speeded up. However, the distance measurement system determines the depth information based on predetermined parameters and measured data. Calculation of the depth information with respect to different points on the obstacle actually relies on different predetermined parameters. Hence, the distance measurement system needs a huge amount of storage space and hardware resources to store predetermined parameters for different detecting points and calculate the depth information based on these predetermined parameters.
With aforementioned in mind, it is one objective of the present invention to provide a depth information calculation method with reduced requirements of storage space and hardware resources. The present invention uses locations of centroid of few detecting points to calculate depth information corresponding to more detecting points. In addition, the preset invention improves the reliability of sensed values by filtration mechanism on sensed values, thereby improves the accuracy of depth information calculation.
According to one embodiment of the present invention, an image processing method is provided. The image processing method comprises: acquiring a plurality of sensed values based on detecting light; comparing sensed values of each row with a corresponding threshold value to select a plurality of selected sensed values from the plurality of sensed values; determining a location of a centroid according to the plurality of selected sensed values; and calculating a plurality of depth values with respect to a plurality of detecting points according to the location of the centroid and a plurality of depth information transformation functions respectively corresponding to the detecting points.
According to one embodiment of the present invention, an image processing system is provided. The image processing system comprises an optical sensing device, a filtering module, a centroid determination module and a depth information calculation module. The optical sensing device is arranged for acquiring a plurality of sensed values based on detecting light. The filtering module is coupled to the optical sensing device and arranged for comparing sensed values of each row with a corresponding threshold value to select a plurality of selected sensed values from the plurality of sensed values. The centroid determination module is coupled to the filtering module and arranged for determining a location of a centroid according to the plurality of selected sensed values. The depth information calculation module is coupled to centroid determination module and arranged for calculating a plurality of depth values with respect to a plurality of detecting points according to the location of the centroid and a plurality of depth information transformation functions respectively corresponding to the detecting points.
According to one embodiment of the present invention, an image processing method is provided. The image processing method comprises: acquiring a plurality of sensed values at different times; comparing sensed values of each row with a corresponding threshold value to select a plurality of selected sensed values from the plurality of sensed values that are acquired at different times; determining a plurality of locations of centroid according to the plurality of selected sensed values; and calculating a plurality of depth information corresponding to the plurality of locations of centroid according to the plurality of locations of centroid and a plurality of transformation functions.
These and other objectives of the present invention will no doubt become obvious to those of ordinary skill in the art after reading the following detailed description of the preferred embodiment that is illustrated in the various figures and drawings.
Please refer to
In the flow of the present invention, before the position of the centroid is determined (i.e., the image positions X1 and X2), the reliability of the sensed values needs to be enhanced. That is, unreliable sensed values will be appropriately excluded, which is achieved by following filtering operations.
Firstly, when the optical sensing device 110 generates a sensed frame, the present invention picks up a proper region of interest (ROI) within the sensed frame. Only the sensed values inside the ROI will be selected, and the sensed values outside the ROI will be excluded. This is because the optical distance measurement system has its limitation on use. It is difficult to measure depth information of the obstacle far away from the distance measurement system because the reflection coming from the faraway obstacle cannot be effectively captured to get valid sensed values (due to the limited intensity of the light). In other words, the sensed values outside the ROI could be noises or generated by other light sources rather than the light source of the optical distance measurement. With the ROI filtering, such sensed values can be excluded.
Further, according to sensed values of each row of pixels in the sensed frame, the present invention calculates a threshold value for each row of pixels. Then, compare sensed values of each row of pixels with a threshold value corresponding to the row. Sensed values lower than the threshold value will be considered as noises and excluded, and sensed values higher than the threshold value will be reserved and used in depth information calculation. In one embodiment, a threshold value for a row of pixels can be determined by a maximum SMAX (which is a greatest value of sensed values of pixels of the row) and a mean SAVG (which is a mean of sensed values of pixels of the row), and the threshold value is equal to (SMAX+SAVG)/2. Please note that, this is just one way of calculating the threshold values, and should not be considered as limitations of the present invention.
After the sensed values are filtered by the above-mentioned ROI filtering and threshold value filtering to exclude noises/unwanted sensed values, a confidential level of each row of sensed values will be further considered. The sensed values of low intensities will not be considered (from point of view of a row of pixels). As a subsequence, ambiguous sensed values can be excluded. That is, some sensed values may not be determined as noises in the ROI filtering and the threshold value filtering, but these sensed values might have weak intensity, which could be interfered with by stronger noises in the sensed frame. In order to improve the reliability of the sensed values, a confidence level filtering will be applied to exclude ambiguous sensed values and reserve the unambiguous sensed values. In one embodiment, the confidence level is determined according to the determined threshold value. As mentioned above, each row of sensed values corresponds to a specific threshold value. According to the threshold value, sensed values in a row that are higher than the threshold value corresponding to that row will be summed to obtain a summation SSUM, while those are lower than the threshold value will be averaged to obtain a low mean SLAVG. The confidence level corresponding to a row will be SSUM/SLAVG. When a confidence level of a row is lower than a predetermined lowest confidence level, the sensed values of that row will be determined as unreliable. Similar to the threshold value filtering, the unreliable sensed values will be excluded and not used in the depth information calculation. With the above-mentioned filtering, one or multiple rows of sensed values can be therefore obtained. According to reserved sensed values, a centroid of a row of pixels will be determined, which can be used to determine distances of the obstacle 200 with respect to each detecting point.
There is a function between the position of the centroid XN and the depth of the obstacle 200. This function could be approximated and expressed as an M-degree polynomial as below:
ZM(x)=K0(XN){circumflex over ( )}M+K1(XN){circumflex over ( )}(M−1)+ . . . KM
If the degree M is higher, the M-degree polynomial could be more close to the actual function between the position of the centroid and the depth. However, based on hardware cost considerations, the degree M should be controlled. Hence, the present invention uses linear functions to approximate M-degree polynomial function. Please refer to
Z′(x)=ZN(x), X0<x<X1;
=ZP(x), X1<x<X2
With such technique, the number of coefficients of the M-degree polynomial needs to be stored by the storage device can be significantly reduced. Also, complicated calculation on high-degree terms of the M-degree polynomial can be avoided (which needs more hardware resources). Please note that the above-mentioned number of linear functions used to approximate the M-degree polynomial is just for purpose of illustrates rather than limitation. In other embodiments, other number of linear functions can be used to approximate in more steps.
On the other hand, as the optical sensing device 110 of the optical distance measurement system 100 receives the light through lens. However, the edge of lens usually causes geometric distortion, which causes a linear image to be visually non-linear in the sensed frame (as shown by
As shown by
For example, the depth information transformation function Z100(x) corresponding to the detecting point P100 could be determined by the depth information transformation functions corresponding to detecting points P30 and P160 which the point P100 are surrounded by. Specifically, the depth information transformation function Z100(x) could be determined as:
Z100(x)=w0*Z30(x)+w1*Z160(x);
Furthermore, depth information transformation functions corresponding to the detecting points that are located between the detecting points P160 and P290 could be determined according to a weighted summation based on Z160(x) and Z290(x). It should be noted that determination of depth information transformation function of each detecting point and corresponding weighting factors varies with the position of the detecting point. For example, the detecting point P20 that is at the left side of the detecting point P30 could have a depth information transformation function Z20 as below:
Z20(x)=w3*Z30(x)+w4*Z160(x).
With such technique, the requirement of storage space could be significantly reduced. In addition, the optical distance measurement system only needs to record a couple of specific depth information transformation functions and weighting factors for each detecting point. According to this information, the depth information transformation function of each detecting point can be determined. Then, apply the position of the centroid into the depth information transformation function of each detecting point, and depth information of each detecting point can be therefore obtained. According to various embodiment of the present invention, fewer or more depth information transformation functions can be used to determine the depth information transformation function of each detecting point.
The above-mentioned embodiments can be summarized as a flow chart of
The flow of
The plurality of depth information transformation functions are still obtained by way of linear function approximation.
In another embodiment of the present invention, an optical distance measurement system is provided. As shown by
Steps and modules in the embodiments of the invention may include functionality that may be implemented as software executed by a processor, hardware circuits or structures, or a combination of both. The processor may be a general-purpose or dedicated processor. The software may comprise programming logic, instructions or data to implement certain functionality for an embodiment of the invention. The software may be stored in a medium accessible by a machine or computer-readable medium, such as read-only memory (ROM), random-access memory (RAM), magnetic disk (e.g., floppy disk and hard drive), optical disk (e.g., CD-ROM) or any other data storage medium. In one embodiment of the invention, the media may store programming instructions in a compressed and/or encrypted format, as well as instructions that may have to be compiled or installed by an installer before being executed by the processor. Alternatively, an embodiment of the invention may be implemented as specific hardware components that contain hard-wired logic, field programmable gate array, complex programmable logic device, or application-specific integrated circuit, for performing the recited functionality, or by any combination of programmed general-purpose computer components and custom hardware component.
Since the present invention significantly simplifies the depth information calculation, and also maintain the reliability, the requirement for hardware resources can be reduced. With the method of the present invention, depth information of multiple detecting points can be simultaneously calculated once getting a series of sensed values, such that the distance measurement can be speeded up. In addition, the present invention performs filtering on sensed values for several times, and the accuracy of the depth information calculation can be thus guaranteed.
Those skilled in the art will readily observe that numerous modifications and alterations of the device and method may be made while retaining the teachings of the invention. Accordingly, the above disclosure should be construed as limited only by the metes and bounds of the appended claims.
Number | Date | Country | Kind |
---|---|---|---|
103146094 | Dec 2014 | TW | national |
This application is a continuation application of U.S. application Ser. No. 17/485,518, filed on Sep. 27, 2021, which is a continuation application of U.S. application Ser. No. 16/108,066, filed on Aug. 21, 2018, which is a continuation application of U.S. application Ser. No. 14/864,809, filed on Sep. 24, 2015. The contents of these applications are incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
4575304 | Nakagawa | Mar 1986 | A |
20050111009 | Keightley | May 2005 | A1 |
20080159595 | Park | Jul 2008 | A1 |
20090262369 | Chuang | Oct 2009 | A1 |
20100045963 | Yamaguchi | Feb 2010 | A1 |
20100277748 | Potapenko | Nov 2010 | A1 |
20120062868 | Kludas | Mar 2012 | A1 |
20120069320 | Slmonov | Mar 2012 | A1 |
20130135605 | Wada | May 2013 | A1 |
20130141538 | DaneshPanah | Jun 2013 | A1 |
20130169595 | Chang | Jul 2013 | A1 |
20140016113 | Holt | Jan 2014 | A1 |
20140055575 | Imamura | Feb 2014 | A1 |
20150092018 | Kang | Apr 2015 | A1 |
20150299992 | Shirai | Oct 2015 | A1 |
20160018526 | Van Den Bossche | Jan 2016 | A1 |
20160252619 | Markendorf | Sep 2016 | A1 |
20180073873 | Takao | Mar 2018 | A1 |
20180101173 | Banerjee | Apr 2018 | A1 |
Number | Date | Country |
---|---|---|
101561267 | Oct 2009 | CN |
101652628 | Feb 2010 | CN |
101655350 | Feb 2010 | CN |
102356298 | Feb 2012 | CN |
102706319 | Oct 2012 | CN |
103116739 | May 2013 | CN |
103456007 | Dec 2013 | CN |
0 970 391 | Dec 2001 | EP |
201231935 | Aug 2012 | TW |
201323832 | Jun 2013 | TW |
201415415 | Apr 2014 | TW |
201416644 | May 2014 | TW |
2012077039 | Jun 2012 | WO |
Number | Date | Country | |
---|---|---|---|
20240027619 A1 | Jan 2024 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 17485518 | Sep 2021 | US |
Child | 18376430 | US | |
Parent | 16108066 | Aug 2018 | US |
Child | 17485518 | US | |
Parent | 14864809 | Sep 2015 | US |
Child | 16108066 | US |