Method of and apparatus for generating a depth map utilized in autofocusing

Information

  • Patent Application
  • 20070297784
  • Publication Number
    20070297784
  • Date Filed
    June 22, 2006
    18 years ago
  • Date Published
    December 27, 2007
    17 years ago
Abstract
A method of and an apparatus for determining a depth map utilizing a movable lens and an image sensor are described herein. The depth information is acquired by moving the lens a short distance and acquiring multiple images with different blur quantities. An improved method of simulating gaussian blur and an approximation equation that relates a known gaussian blur quantity to a known pillbox quantity are used in conjunction with a non-linear blur difference equation. The blur quantity difference is able to be calculated and then used to determine the depth map. Many applications are possible using the method and system described herein, such as autofocusing, surveillance, robot/computer vision, autonomous vehicle navigation, multi-dimensional imaging and data compression.
Description

BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 illustrates an exemplary arrangement of a lens in a first position and in a second position to receive two images with different blur quantities on a sensor.



FIG. 2A illustrates an example of gaussian blur in continuous time.



FIG. 2B illustrates an example of gaussian blur in discrete time.



FIG. 2C illustrates an example of gaussian blur in discrete time.



FIG. 3 illustrates an exemplary arrangement of a lens and a sensor to receive two images with different blur quantities.



FIG. 4 illustrates two images with different blur quantities.



FIG. 5 illustrates two images with different blur quantities.



FIG. 6 illustrates a lens with designated lengths used for determining the blur quantity.



FIG. 7 illustrates a graphical representation of an imaging device.





DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT

A method of and an apparatus for determining a depth map are described herein. The depth information is acquired by moving a lens a short distance and acquiring multiple pictures with different blur quantities or functions. A more accurate gaussian blur implementation, in addition to a non-linear version of the blur difference allow a better determination of the depth map. By telescoping between the two blurred functions using the gaussian blur implementation, a depth map is determined. In the ideal optical scenario, the two functions are pillbox blur functions.



FIG. 1 illustrates an example of a lens 100 in a first position and in a second position to generate two images with different blur quantities on a sensor 102. With the lens 100 in focus position A, the distance from a scene (not shown) to the lens 100 is the distance do and the distance between the lens and the focal point is the distance d1, where the distance do is much greater than the distance d1. The distance between the lens 100 and the sensor 102 is the distance DJ. Furthermore, the blur radius with the lens 100 in focus position A is radius r1. When the lens 100 is in focus position A+\delta, the distance from the scene (not shown) to the lens 100 is still the distance d0, however the distance between the lens and the focal point is the distance d2 where the distance d0 is much greater than the distance d2. The distance between the lens 100 and the sensor 102 is the distance D4. Hence, the blur radius with the lens 100 in focus position A+\delta is the radius r2. Once the different blur radii, r1 and r2, are known, depths of objects in the scene are able to be determined for use in a number of applications.



FIGS. 2A-C illustrate examples of gaussian blurs. In FIG. 2A, a well known result is shown in continuous time where σ1=1 and σ12=1; σ2=2 and σ22=4; σ12=√{square root over (5)} and σ1222=5. Each section of equation (1), shown below, is shown in graph form in FIG. 2A. The section with σ12 reaches a maximum of 0.3989, the section with σ22 reaches 0.1995 and the section with σ1222 reaches 0.1784.











1


2






πσ
1
2








-

(


x
2


2


σ
1
2



)



*

1


2






πσ
2
2








-

(


x
2


2


σ
2
2



)




=


1


2






π


(


σ
1
2

+

σ
2
2


)









-

(


x
2


2


(


σ
1
2

+

σ
2
2


)



)








(
1
)








FIG. 2B shows the gaussian blur calculated in discrete time using sampled data. The result is similar to that in FIG. 2A.











1


2






πσ
1
2








-

(


x
i
2


2


σ
1
2



)



*

1


2






πσ
2
2








-

(


x
i
2


2


σ
2
2



)




=


1


2






π


(


σ
1
2

+

σ
2
2


)









-

(


x
i
2


2


(


σ
1
2

+

σ
2
2


)



)








(
2
)








FIG. 2C is also in discrete time using sampled data. However, the result is not same as in FIGS. 2A and 2B. The section of equation (3) with σ1222 does not reach 0.1784. Hence, there are issues with accuracy using this method.














1


2





π






σ
1
2








-

(


x
k
2


2


σ
1
2



)



*







1


2





π






σ
1
2








-

(


x
k
2


2


σ
2
2



)







=


1


2






π


(


σ
1
2

+

σ
2
2


)









-

(


x
k
2


2


(


σ
1
2

+

σ
2
2


)



)








(
3
)







The accuracy of determining the gaussian blur is able to be improved by using the following method based on differential equations.


In one dimension:





f: R→R





L: R x R+→R






L(x;0)=f(x)





g: R x R+\{0}→R


where f is the one dimensional signal and L is defined by L(x;0)=f(x) and convolution with g, the gaussian blur kernel. Then:











L


(

x
;
t

)


=




-



+






1


2





π





t








ξ
2


2

t









f


(

x
-
ξ

)





ξ




,

t
>
0





(
4
)







and is defined by the diffusion equation:













L



t


=


1
2






2


L




x
2





,


L


(

x
;
0

)


=

f


(
x
)







(
5
)







Using Euler's method, the continuous equation:












L



t


=


1
2






2


L




x
2








(
6
)







can be discretized and rewritten in the following form:











L

i
,

k
+
1



=




Δ





t

2



L


i
+
1

,
k



+


(

1
-

Δ





t


)



L

i
,
k



+



Δ





t

2



L


i
-
1

,
k





,


Δ





t



1
2






(
7
)







For example, if Δt=½, it is easy to realize the implementation above using the following convolution kernel:

    • [¼ ½ ¼]


      Although the example where Δt=½ is used above and below for clarity, it should be understood that values for Δt less than ½ such as ¼ are able to be used as well in one dimension. For instance, if Δt=¼, then the kernel obtained is [⅛ ¾ ⅛]. By reducing the Δt value from ½ to ¼, the number of iterations needed to have the same effect increases. The equations below utilize the assumption that Δt=½ for one dimension. The Central Limit Theorem shows that the repeated iteration of the kernel quickly yields a gaussian function:





[¼ ½ ¼]*[¼ ½ ¼]* . . . * [¼ ½ ¼]


Equation (8) is the old, less accurate version of determining the blur.













1


2





π






σ
start
2








-

(


x
m
2


2


σ
start
2



)



*







1


2





π






σ
?
2








-

(


x
m
2


2


σ
?
2



)







=


1


2






πσ
finish
2








-

(


x
m
2


2


σ
finish
2



)








(
8
)







Equation (9) is an improved version. Using the number of iterations of [¼ ½ ¼] needed to be applied to telescope between and σstart 2 and σfinish2, the σ?2 is able to be calculated accurately.











1


2





π






σ
start
2








-

(


x
m
2


2


σ
start
2



)



*

[


1
/
4







1
/
2







1
/
4


]

*

*

[


1
/
4







1
/
2







1
/
4


]


=


1


2






πσ
finish
2








-

(


x
m
2


2


σ
finish
2



)








(
9
)







Using a similar numerical analysis approach shown in the ID case, we obtain the following convolution kernel for the 2D case for Δt=¼. It should be understood that values for Δt less than ¼ such as ⅛ are able to be used as well in two dimensions. By reducing the Δt value from ¼ to ⅛, the number of iterations needed to have the same effect increases.









1
48




1
12




1
48






1
12




7
12




1
12






1
48




1
12




1
48







Fast implementation of the convolution kernel is possible using vector shifts, multiplication and addition.


In one dimension for example:





h=[¼ ½ ¼]





data=[a1 a2 a3 a4 a5 a6 a7 a8 a9 a10]





result=data*h, such that:





result=¼*[a2 a3 a4 a5 a6 a7 a8 a9 a10 a1]+½*[a1 a2 a3 a4 a5 a6 a7 a8 a9 a10]+¼*[a10 a1 a2 a3 a4 a5 a6 a7 a8 a9]


Furthermore, the one dimensional version is easily generalized to two dimensions. The following relationship exists for the one dimensional and two dimensional kernels:













One Dimension
Two Dimensions







Blur Variance → Iterations Needed
Blur Variance → Iterations Needed


σ2 = 1 → 2
σ2 = 1 → 4


σ2 = 4 → 8
σ2 = 4 → 16


σ2 = 9 → 18
σ2 = 9 → 36


σ2 = 16 → 32
σ2 = 16 → 64









Thus, a unique relationship exists for the one dimensional and two dimensional cases.
One Dimension:





    • Δσ2=3 Δiterations=6

    • Δσ2=5 Δiterations=10×2

    • Δσ2=7 Δiterations=14





Two Dimensions:





    • Δσ2=3 Δiterations=12

    • Δσ2=5 Δiterations=20×4

    • Δσ2=7 Δiterations=28





The above relationship is true for the “non-linear” variance quantity σ22−σ12=Δσ2=Δσ2 where σ2212. Thus, it is possible to accurately simulate and compute the change in Gaussian blur utilizing the method described above.

From FIG. 3, equations are able to be derived to determine the blur difference. FIG. 3 shows a lens 100, with a distance of D2 between the lens 100 and the sensor 102. Since the lens 100 is movable, the distance between the lens 100 and the sensor 102 is variable such that the distances are represented by the distance D2 and the distance D1. The distance from the scene (not shown) and the lens 100 is the distance d0 which is much larger than the distance between the lens 100 and the focal point designated as the distance di. Depending on the distance of the lens 100 from the sensor 102, the blur radius varies. In FIG. 3, the lens 100 moves a short distance and two radii are determined and designated as the radius r1 and the radius r2. The value f is designated the focal length.













r
1

=




d
0



D
1


-


d
0



f
l


-


f
l



D
1




2


d
0



f
num









=

>


(

r
1

)

2








=


(




d
0



D
1


-


d
0



f
l


-


f
l



D
1




2


d
0



f
num



)

2








(
10
)










r
2

=




d
0



D
2


-


d
0



f
l


-


f
l



D
2




2


d
0



f
num









=

>


(

r
2

)

2








=


(




d
0



D
2


-


d
0



f
l


-


f
l



D
2




2


d
0



f
num



)

2








(
11
)







Assuming r1 is larger than r2, the following positive valued quantity is able to be computed:












(

r
1

)

2

-


(

r
2

)

2


=







(



d
0



D
1


-


d
0



f
l


-


f
l



D
1



)

2

-







(



d
0



D
2


-


d
0



f
l


-


f
l



D
2



)

2





2


d
0



f
num







(
12
)







Equation (12) is a non-linear version of the blur difference. Re-arranging equation (12) results in the following equation:












[



-

(


-


(

r
1

)

2


+


(

r
2

)

2


)





(

2


f
num


)

2


+


(


D
2

-

f
l


)

2

-


(


D
1

-

f
l


)

2


]



d
0
2


+


[

2


f
1



{



(


D
2

-

f
l


)



D
2


-


(


D
1

-

f
l


)



D
1



}


]



d
0


-

[



(


f
l



D
1


)

2

-


(


f
l



D
2


)

2


]


=
0




(
13
)







Then, using the quadratic formula, the depth d0 is able to be determined:






ax
2
+bx +c=0






a=[−(−(r1)2+(r2)2)(2fnum)2+(D2−f1)2−(D1−f1)2]  (14)






b=[2f1{(D2−f1)D2−(D1−f1)D1}]






c=[(f1D1)2−(f1D2)2]



FIG. 4 illustrates two images with different blur quantities. A first image 400 has a narrower blur quantity 404 than a second image 402 having a wider blur quantity 406. Using a telescoping gaussian blur, the blur quantity 404 of the first image 400 is related to the blur quantity 406 of the second image 402. In the ideal optical scenario, the two blur quantities or functions are pillbox blur functions.



FIG. 5 illustrates a first image 500 with a blur radius r1 and a second image 502 with a blur radius r2. A number of equations are implemented utilizing the difference in blur of the two images. Based on the first image 500:








r
_

1





r
_

1





2






σ
1


_












(

r
1
2

)

_







From the second image 502:
















r
2

_





r
2

_





2






σ
2


_












(

r
2
2

)

_










Then
,






Δ



(

r
2

)

_


=



(

r
2
2

)

_

-


(

r
1
2

)

_









(
15
)







Δ





Iterations

=


4





Δ



(

σ
2

)

_


=



4


(



(

σ
2
2

)

_

-


(

σ
1
2

)

_


)




Δ



(

r
2

)

_



=



(

r
2
2

)

_

-


(

r
1
2

)

_








(
16
)







The overbar denotes quantities in pixel based/pixel reference units.


FIG. 6 illustrates a lens with designated parameters. Equation (17) is derived from FIG. 6 where changing the distance of the lens to the object and to the sensor affect the parameters used to compute the blur difference.



















r
_

=





lens
->
D

2

*


abs


(

lens
->


f_

just

-
f_defocus


)



lens
->
f_just


*












lens
->
pixel_num


lens
->
imager_size












LPN
=

Lens
->
pixel_num








LIS
=

Lens
->
imager_size






(
17
)












(

LPN
LIS

)


-
2



4





Δ



(

σ
2

)

_


=





(

LPN
LIS

)


-
2



4


(



(

σ
2
2

)

_

-


(

σ
1
2

)

_


)














(

LPN
LIS

)


-
2



Δ







(

r
2

)

_








=





(

LPN
LIS

)


-
2




(



(

r
2
2

)

_

-


(

r
1
2

)

_


)








=




(

r
2
2

)

-

(

r
1
2

)








=



Δ






(

r
2

)









(
18
)







Therefore, using equation (18) the blur difference Δ(r2) is able to be determined.

Hence, a first image with a first blur quantity and a second image with a second blur quantity are able to be used to determine a variance delta Δ 2) after a number of iterations. From the variance delta, a blur difference Δ(r2) is determined from equation 18. Using the quadratic formula and the blur radius delta, a depth d0 is able to be determined, as shown below.










Δ






(

r
2

)







-
b

±



b
2

-

4

ac





2

a




d
0






(
19
)







By determining the depth d0, a device is able to utilize the depth information for applications such as autofocusing.


The pillbox (r) and gaussian (σ) blur kernels have the following approximate relationship with respect to filtered energy: r˜2σ.


Therefore, taking a first image with pillbox blur equal to the value r1 and convolving it with the approximate telescoping solution of [3×3 kernel] for 1 to n iterations yields a pillbox blur equal to the value r2.

Through observations, better performance occurs when the difference in blur in the first image to the second image is small. Furthermore, it is helpful for the blur quantities to be small.



FIG. 7 illustrates a graphical representation of an imaging device implementing the method described herein. The imaging device 700 is utilized to capture an image from a scene (not shown) as would any typical imaging device. One or more input signals 704 are acquired from the scene (not shown) and pass through the movable lens 100. The one or more signals 704 are then received at the image sensor 102 which is coupled to a computing module 702 including, but not limited to, a processor and data storage. Within the computing module 702 are one or more programs for performing the methods described herein. The imaging device 700 includes, but is not limited to cameras, video cameras, camcorders, digital cameras, cell phones, and PDAs.


There are a number of devices that are able to utilize the method of receiving multiple blurred images to generate a depth map. Such a device obtains a signal of an image from a scene. The signal passes through a lens and is received by an image sensor. The lens is then moved a short distance and the signal passes through again and is received by the image sensor. With different distances between the lens and the sensor, the signals of the images arrive at the sensors with differing blur quantities. An improved method of simulating gaussian blur and an approximation equation that relates a known gaussian blur quantity to a known pillbox quantity are used in conjunction with a non-linear blur difference equation. The blur quantity difference is able to be calculated and then used to determine the depth map. With the depth information, tasks like image segmentation and object detection are better performed. Many applications are possible with the method and system described herein, including, but not limited to autofocusing, surveillance, robot/computer vision, autonomous vehicle navigation, multi-dimensional imaging and data compression. For a user of the device which implements the method described herein, the functionality is similar to that of other related technologies. For example, a person who is taking a picture with a camera which implements the method to receive multiple blurred images, uses the camera as a generic autofocusing camera. The camera generates a depth map, and then automatically focuses the lens until it establishes the proper focus for the picture, so that the user is able to take a clear picture. However, as described above, the method and system described herein have significant advantages over other autofocusing devices.


In operation, the method and system for receiving multiple blurred images to determine a depth map improve a device's ability to perform a number of functions such as autofocusing. As described above, when a user is utilizing a device which implements the method and system described herein, the device functions as a typical device would from the user's perspective. The improvements of being able to compute a depth map using multiple blurred images received at a sensor by moving a lens a short distance enable more accurate and improved autofocusing. An improved method of simulating gaussian blur assists in determining the depth for autofocusing. Using non-linear blur difference instead of linear provides better accuracy as well. The approximate depth map is generated by implementing a pillbox blur based imaging system using an algorithm based on a gaussian blur approximation.


In other embodiments, the image sensor is moved in addition to or instead of the lens to acquire pictures with different blur quantities.


The present invention has been described in terms of specific embodiments incorporating details to facilitate the understanding of principles of construction and operation of the invention. Such reference herein to specific embodiments and details thereof is not intended to limit the scope of the claims appended hereto. It will be readily apparent to one skilled in the art that other various modifications may be made in the embodiment chosen for illustration without departing from the spirit and scope of the invention as defined by the claims.

Claims
  • 1. An apparatus for determining depth information comprising: a. a lens for acquiring an image signal;b. an image sensor for receiving the image signal, wherein one or more of the lens and the image sensor are movable in relation to each other; andc. a processing module coupled to the image sensor for determining depth information by using a first blur quantity and a second blur quantity to determine a non-linear blur difference.
  • 2. The apparatus as claimed in claim 1 wherein the lens, the image sensor and the processing module are contained within an imaging device.
  • 3. The apparatus as claimed in claim 2 wherein the imaging device is selected from the group consisting of a camera, a video camera, a camcorder, a digital camera, a cell phone and a PDA.
  • 4. The apparatus as claimed in claim 1 wherein the lens is movable and acquires the image signal at a first position and then at a second position.
  • 5. The apparatus as claimed in claim 1 wherein the processing module simulates gaussian blur.
  • 6. The apparatus as claimed in claim 5 wherein the processing module simulates gaussian blur using iterations of a convolution kernel.
  • 7. The apparatus as claimed in claim 1 wherein the processing module relates a gaussian blur quantity to a pillbox blur quantity.
  • 8. A method of determining depth information comprising: a. receiving a first image signal with a first blur quantity at an image sensor after the first image signal passes through a lens at a first position;b. receiving a second image signal with a second blur quantity at the image sensor after the second image signal passes through the lens at a second position;c. computing a non-linear blur difference using the first blur quantity and the second blur quantity; andd. generating a depth map from the non-linear blur difference.
  • 9. The method as claimed in claim 8 wherein the method is performed within an imaging device.
  • 10. The method as claimed in claim 9 wherein the imaging device is selected from the group consisting of a camera, a video camera, a camcorder, a digital camera, a cell phone and a PDA.
  • 11. The method as claimed in claim 8 further comprising simulating gaussian blur.
  • 12. The method as claimed in claim 11 wherein simulating gaussian blur uses iterations of a convolution kernel.
  • 13. The method as claimed in claim 8 further comprising relating a gaussian blur quantity to a pillbox blur quantity.
  • 14. A method calculating depth information comprising: a. simulating a gaussian blur quantity using a convolution kernel;b. relating the gaussian blur quantity to a pillbox blur quantity;c. computing a non-linear blur difference; andd. generating a depth map from the non-linear blur difference.
  • 15. The method as claimed in claim 14 wherein the method is performed within an imaging device.
  • 16. The method as claimed in claim 15 wherein the imaging device is selected from the group consisting of a camera, a video camera, a camcorder, a digital camera, a cell phone and a PDA.
  • 17. The method as claimed in claim 14 wherein simulating gaussian blur uses iterations of a convolution kernel.
  • 18. A capture and display device comprising: a. a lens for receiving an image signal;b. an image sensor for receiving the received image signal, wherein one or more of the lens and the image sensor are movable in relation to each other; andc. a program coupled to the image sensor for determining depth information by using a first blur quantity and a second blur quantity to determine a non-linear blur difference.
  • 19. The capture and display device as claimed in claim 18 wherein the lens, the image sensor and the program are contained within an imaging device.
  • 20. The capture and display device as claimed in claim 19 wherein the imaging device is selected from the group consisting of a camera, a video camera, a camcorder, a digital camera, a cell phone and a PDA.
  • 21. The capture and display device as claimed in claim 18 wherein the lens is movable and acquires the image signal at a first position and then at a second position.
  • 22. The capture and display device as claimed in claim 18 wherein the program simulates gaussian blur.
  • 23. The capture and display device as claimed in claim 22 wherein the program simulates gaussian blur using iterations of a convolution kernel.
  • 24. The capture and display device as claimed in claim 18 wherein the program relates a gaussian blur quantity to a pillbox blur quantity.
  • 25. An apparatus for determining depth information comprising: a. a lens for receiving an image signal;b. an image sensor for receiving the received image signal, wherein one or more of the lens and the image sensor are movable in relation to each other; andc. a processing module coupled to the image sensor for determining depth information by using a first blur quantity and a second blur quantity to determine a non-linear blur difference, wherein a gaussian blur is simulated.
  • 26. The apparatus as claimed in claim 25 wherein the lens, the image sensor and the processing module are contained within an imaging device.
  • 27. The apparatus as claimed in claim 26 wherein the imaging device is selected from the group consisting of a camera, a video camera, a camcorder, a digital camera, a cell phone and a PDA.
  • 28. The apparatus as claimed in claim 25 wherein the image sensor is movable and acquires the image signal at a first position and then at a second position.
  • 29. The apparatus as claimed in claim 25 wherein the processing module simulates the gaussian blur using iterations of a convolution kernel.
  • 30. The apparatus as claimed in claim 25 wherein the processing module relates the gaussian blur quantity to a pillbox blur quantity.