Depth Map Calculation in a Stereo Camera System
A method for generating a depth map is described. The method includes obtaining a first image of a scene from a first image capture unit, the first image having a first depth-of-field (DOF), obtaining a second image of the scene from a second image capture unit, the second image having a second DOF that is different than the first DOF. Each pixel in the second image has a corresponding pixel in the first image. The method also includes generating a plurality of third images, each corresponding to a blurred version of the second image at each of a plurality of specified depths, generating a plurality of fourth images, each representing a difference between the first image and one or the plurality of third images, and generating a depth map where each pixel in the depth map is based on the pixels in one of the plurality of fourth images.
This disclosure relates generally to the field of digital image capture and processing, and more particularly to the field of depth map calculation.
The process of estimating the depth of a scene from two cameras is commonly referred to as stereoscopic vision and, when using multiple cameras, multi-view stereo. In practice, many multi-camera systems use disparity as a proxy for depth. (As used herein, disparity is taken to mean the difference in the projected location of a scene point in one image compared to that same point in another image captured by a different camera.) With a geometrically calibrated camera system, disparity can be mapped onto scene depth. The fundamental task for such multi-camera vision-based depth estimation systems then is to find matches, or correspondences, of points between images from two or more cameras. Using geometric calibration, the correspondences of a point in a reference image (A) can be shown to lie along a certain line, curve or path in another image (B).
Difficulties in generating a depth map may arise when disparity is not easily calculated. For example, if the stereo camera system is directed at an object that has a pattern which makes determining disparity more difficult.
SUMMARYIn one embodiment, a method for generating a depth map is described. The method includes obtaining a first image of a scene from a first image capture unit, the first image having a first depth-of-field (DOF) and a first number of pixels, obtaining a second image of the scene from a second image capture unit, the second image having a second DOF that is different than the first DOF, the second image having the first number of pixels, wherein each pixel in the second image has a corresponding pixel in the first image, generating a plurality of third images, each corresponding to a blurred version of the second image at each of a plurality of specified depths, generating a plurality of fourth images, each representing a difference between the first image and one of the plurality of third images, and generating a depth map having the first number of pixels, wherein each pixel in the depth map is based on a plurality of pixels, wherein each of the plurality of pixels corresponds to the pixel in one of the plurality of fourth images.
In another embodiment, the method may be embodied in computer executable program code and stored in a non-transitory storage device. In yet another embodiment, the method may be implemented in an electronic device having image capture capabilities.
This disclosure pertains to systems, methods, and computer readable media for generating a depth map. In general, techniques are disclosed for using a stereo camera system to capture two images of an object, determining a difference in blur between the two images at a particular point, and determining a depth for a depth map based on the difference in blur. In one or more embodiments, disparity information between the two images may also be determined and used in generating a depth map. This may be useful, for example, in a stereo camera system that includes two cameras with different depth-of-fields (DOF's) at the same focal length.
In the following description, for purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the disclosed concepts. As part of this description, some of this disclosure's drawings represent structures and devices in block diagram form in order to avoid obscuring the novel aspects of the disclosed embodiments. In this context, it should be understood that references to numbered drawing elements without associated identifiers (e.g., 100) refer to all instances of the drawing element with identifiers (e.g., 100a and 100b). Further, as part of this description, some of this disclosure's drawings may be provided in the form of a flow diagram. The boxes in any particular flow diagram may be presented in a particular order. However, it should be understood that the particular flow of any flow diagram is used only to exemplify one embodiment. In other embodiments, any of the various components depicted in the flow diagram may be deleted, or the components may be performed in a different order, or even concurrently. In addition, other embodiments may include additional steps not depicted as part of the flow diagram. The language used in this disclosure has been principally selected for readability and instructional purposes, and may not have been selected to delineate or circumscribe the disclosed subject matter. Reference in this disclosure to “one embodiment” or to “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment, and multiple references to “one embodiment” or to “an embodiment” should not be understood as necessarily all referring to the same embodiment or to different embodiments.
It should be appreciated that in the development of any actual implementation (as in any development project), numerous decisions must be made to achieve the developers' specific goals (e.g., compliance with system and business-related constraints), and that these goals will vary from one implementation to another. It will also be appreciated that such development efforts might be complex and time consuming, but would nevertheless be a routine undertaking for those of ordinary skill in the art of image capture having the benefit of this disclosure.
For purposes of this disclosure, the term “lens” refers to a lens assembly, which could include multiple lenses. In one or more embodiments, the lens may be moved to various positions to capture images at multiple depths and, as a result, multiple points of focus. Further in one or more embodiments, the lens may refer to any kind of lens, such as a telescopic lens or a wide angle lens. As such, the term lens can mean a single optical element or multiple elements configured into a stack or other arrangement.
For purposes of this disclosure, the term “camera” refers to a single lens assembly along with the sensor element and other circuitry utilized to capture an image. For purposes of this disclosure, two or more cameras may share a single sensor element and other circuitry, but include two different lens assemblies. However, in one or more embodiments, two or more cameras may include separate lens assemblies as well as separate sensor elements and circuitry.
Referring to
Camera system 100 may include one or more lenses 105. More specifically, as described above, lenses 105A and 105B may actually each include a lens assembly, which may include a number of optical lenses, each with various lens characteristics. For example, each lens may include its own physical imperfections that impact the quality of an image captured by the particular lens. When multiple lenses are combined, for example in the case of a compound lens, the various physical characteristics of the lenses may impact the characteristics of images captured through the lens assembly, such as focal points. In addition, each of lenses 105A and 105B may have similar characteristics, or may have different characteristics, such as a different depth of field (DOF).
As depicted in
Camera system 100 may also include an actuator 130, and mode select input 140. In one or more embodiments, actuator 130 may manage control of one or more of the lens assemblies 105. For example, the actuator 130 may control focus and aperture size. Orientation sensor 135 and mode select input 140 may supply input to control unit 145. In one embodiment, camera system may use a charged coupled device (or a complementary metal-oxide semiconductor as image sensor 110), an electro-mechanical unit (e.g., a voice coil motor) as actuator 130.
Turning to
Turning to
The flow chart begins at 305 where the first camera, such as that including lens assembly 215A captures an image of an object, such as object 200. At 310, the second camera captures a second image of the same object. In one or more embodiments, the first and second camera may be part of a stereo camera system. The first and second camera may have different depths of focus. For example, the first camera may include a telephoto lens, whereas the second camera includes a wide angle lens. In one or more embodiments, the camera may capture an image of any target, whether it is known or unknown.
The flow chart continues at 315, and a set of images are generated by applying a disparity warping to the first image based on a set of specified depths. In one or more embodiments, the disparity between the first image and the second image may be known to the camera system. For example, during calibration, a disparity map may be generated that indicates the disparity between the images of the two cameras at various distances. Thus, a disparity warping may be applied to the first image at various depths to generate a set of images to compensate for the difference between the first and second cameras when capturing images of the same object. In one or more embodiment, hypothesis depths may be determined based on any variety of factors. For example, in one or more embodiments, the depths may be selected based on the DOF of the first camera or the second camera. As another example, the hypothesis depths may be predetermined. Further, as another example, an initial disparity map for the scene may be found based upon stereo registration, ignoring the difference in depth of field. These disparities may be used with the calibration to determine the initial depth hypothesis.
The method continue at 320 and a blurred set of images are generated based on the second image at the specified hypothesis depths. In one or more embodiments, generating the blurred set of images involves applying a blur to the image captured by the second camera to artificially create a set of images based on what the second image would look like blurred at the specified hypothesis depths. In one or more embodiments, the blur may be determined based on a lens optical model. Any method may be used to determine the amount of blur. For example, deconvolution or learned blur-size detectors may be used.
In one or more embodiments, a blur may also be applied to the warped image to compensate for the difference in focus between the first camera and the second camera at the plurality of specified depths. This may occur, for example, if there are points in the second image that are out of the DOF of the first image. Thus, the warped images may also have to be blurred to simulate the blur in the second image for the depth.
The method continues at 325, and a set of differential images is generated. The differential images are generated by determining, for each specified hypothesis depth, how far off the warped image from the first camera is compared to the blurred image of the second camera.
The method continues at 330, and the depth map is generated based on the differential images. In one or more embodiments, for each pixel in the image, a determination is made regarding which differential image is the closest. That is, at what hypothesis depth is the best guess, or closest match, based on the warped image from the first camera and the blurred image from the second camera.
In one or more embodiments, additional process may be incorporated to ensure a better guess of depth at a particular point. For example, a regularization or smoothing process may be applied to any of the generated sets of images in order to clean the resulting depth map.
Referring now to
The flow chart begins at 405, and a set of images are captured from a first camera. The images may be captured at a variety of focus settings. In one or more embodiments, a focal stack of images is captured by one camera, such as the camera with the telephoto lens.
The method continues at 410, and a sharpness metric is determined for each image in the set of images captured in 405. In one or more embodiments, the sharpness metric may be determined in any number of ways. For example, edge detection methods may be used. Any method may be used to determine the amount of blur. For example, deconvolution or learned blur-size detectors may be used.
In one or more embodiments, determining the sharpness metric for each image also includes determining (415) a relative degree of blur, or sharpness. Any method may be used to determine the amount of blur. For example, deconvolution or learned blur-size detectors may be used. In one or more embodiments, the relative degree of blur is based on comparing blur between consecutive images in the stack.
The method continues at 420, and the depth map is generated based on the determined sharpness metrics. As an example, for each pixel in the mage, a depth at which the sharpness metric indicated the image was sharpest is selected for use in the depth map.
Referring now to
Processor 605 may execute instructions necessary to carry out or control the operation of many functions performed by device 600 (e.g., such as the generation and/or processing of images and single and multi-camera calibration as disclosed herein). Processor 605 may, for instance, drive display 610 and receive user input from user interface 615. User interface 615 may allow a user to interact with device 600. For example, user interface 615 can take a variety of forms, such as a button, keypad, dial, a click wheel, keyboard, display screen and/or a touch screen. Processor 605 may also, for example, be a system-on-chip such as those found in mobile devices and include a dedicated graphics processing unit (GPU). Processor 605 may be based on reduced instruction-set computer (RISC) or complex instruction-set computer (CISC) architectures or any other suitable architecture and may include one or more processing cores. Graphics hardware 620 may be special purpose computational hardware for processing graphics and/or assisting processor 605 to process graphics information. In one embodiment, graphics hardware 620 may include a programmable GPU.
Image capture circuitry 650 may include two (or more) lens assemblies 680A and 680B, where each lens assembly may have a separate focal length. For example, lens assembly 680A may have a short focal length relative to the focal length of lens assembly 680B. Each lens assembly may have a separate associated sensor element 690. Alternatively, two or more lens assemblies may share a common sensor element. Image capture circuitry 650 may capture still and/or video images. Output from image capture circuitry 650 may be processed, at least in part, by video codec(s) 665 and/or processor 605 and/or graphics hardware 620, and/or a dedicated image processing unit or pipeline incorporated within circuitry 665. Images so captured may be stored in memory 660 and/or storage 655.
Sensor and camera circuitry 650 may capture still and video images that may be processed in accordance with this disclosure, at least in part, by video codec(s) 655 and/or processor 605 and/or graphics hardware 620, and/or a dedicated image processing unit incorporated within circuitry 650. Images so captured may be stored in memory 660 and/or storage 665. Memory 660 may include one or more different types of media used by processor 605 and graphics hardware 620 to perform device functions. For example, memory 660 may include memory cache, read-only memory (ROM), and/or random access memory (RAM). Storage 665 may store media (e.g., audio, image and video files), computer program instructions or software, preference information, device profile information, and any other suitable data. Storage 665 may include one more non-transitory, computer readable media including, for example, magnetic disks (fixed, floppy, and removable) and tape, optical media such as CD-ROMs and digital video disks (DVDs), and semiconductor memory devices such as Electrically Programmable Read-Only Memory (EPROM), and Electrically Erasable Programmable Read-Only Memory (EEPROM). Memory 660 and storage 665 may be used to tangibly retain computer program instructions or code organized into one or more modules and written in any desired computer programming language. When executed by, for example, processor 605 such computer program code may implement one or more of the methods described herein.
In one or more embodiments, the features described above may be helpful in generating a depth map in situation where the scene, or an object in the scene, does not provide enough variety such that a depth map may be generated by traditional means. For example, a depth map may otherwise be difficult to calculate if there are not enough edges, or if there are too many edges. In addition, in one or more embodiments, only a single image by each of two cameras may be necessary in generating a depth map. Further, in one or more embodiments, a single camera, with known quantities related to a second camera in a stereo camera system, may be necessary in generating a depth map.
Finally, variations of the above-described embodiments may be used in combination with each other. Many other embodiments will be apparent to those of skill in the art upon reviewing the above description. Further, in the case of flow charts described above, the various steps may be depicted in a particular order, but the order in which the features are depicted should not be considered limiting. That is, the various features of the flow chart may occur in a different order, or some may be omitted, or occur concurrently, according to one or more embodiments. The scope of the disclosed subject matter therefore should be determined with reference to the appended claims, along with the full scope of equivalents to which such claims are entitled. In the appended claims, the terms “including” and “in which” are used as the plain-English equivalents of the respective terms “comprising” and “wherein.”
Claims
1. A method of generating a depth map, comprising:
- capturing a first plurality of images of a scene from a first image capture unit having a first depth of field, wherein each of the first plurality of images is associated with a different depth;
- determining a sharpness metric for each of the first plurality of images; and
- generating a depth map comprising a plurality of pixels, wherein generating the depth map comprises selecting, for each pixel in the depth map, a depth associated with one of the first plurality of images, based on a comparison of the sharpness metrics for the first plurality of images.
2. The method of claim 1, further comprising:
- capturing a preview image of the scene from a second image capture unit having a second depth of field.
3. The method of claim 2, wherein:
- the capturing of the preview image is done concurrently with the capture of the first plurality of images.
4. The method of claim 2, further comprising:
- estimating a relative blur between each image in the first plurality of images and the preview image,
- wherein each pixel in the depth map is further based on the estimated relative blurs.
5. The method of claim 2, wherein the first image capture unit comprises a telephoto lens, and wherein the second image capture unit comprises a wide-angle lens.
6. The method of claim 1, wherein determining the sharpness metric further comprises determining a relative degree of blur between at least two consecutively captured images of the first plurality of images.
7. The method of claim 1, wherein selecting, for each pixel in the depth map, a depth associated with one of the first plurality of images, based on a comparison of the sharpness metrics for the first plurality of images further comprises:
- selecting, for each pixel in the depth map, the depth associated with a sharpest image from the first plurality of images at the respective pixel location.
8. A non-transitory computer readable medium comprising computer code for generating a depth map, the computer code executable by one or more processors to:
- obtain a first plurality of images of a scene from a first image capture unit having a first depth of field, wherein each of the first plurality of images is associated with a different depth;
- determine a sharpness metric for each of the first plurality of images; and
- generate a depth map comprising a plurality of pixels, wherein generating the depth map comprises selecting, for each pixel in the depth map, a depth associated with one of the first plurality of images, based on a comparison of the sharpness metrics for the first plurality of images.
9. The non-transitory computer readable medium of claim 8, wherein the computer code further comprises computer code executable by the one or more processors to:
- obtain a preview image of the scene from a second image capture unit having a second depth of field.
10. The non-transitory computer readable medium of claim 9, wherein:
- the preview image is captured concurrently with a capture of the first plurality of images.
11. The non-transitory computer readable medium of claim 9, wherein the computer code further comprises computer code executable by the one or more processors to:
- estimate a relative blur between each image in the first plurality of images and the preview image,
- wherein each pixel in the depth map is further based on the estimated relative blurs.
12. The non-transitory computer readable medium of claim 9, wherein the first image capture unit comprises a telephoto lens, and wherein the second image capture unit comprises a wide-angle lens.
13. The non-transitory computer readable medium of claim 8, wherein the computer code executable by the one or more processors to determine the sharpness metric further comprises computer code executable by the one or more processors to:
- determine a relative degree of blur between at least two consecutively captured images of the first plurality of images.
14. The non-transitory computer readable medium of claim 8, wherein the computer code executable by the one or more processors to select, for each pixel in the depth map, a depth associated with one of the first plurality of images, based on a comparison of the sharpness metrics for the first plurality of images further comprises computer code executable by the one or more processors to:
- select, for each pixel in the depth map, the depth associated with a sharpest image from the first plurality of images at the respective pixel location.
15. A system for generating a depth map, comprising:
- a first image capture unit having a first depth of field; a second image capture unit having a second depth of field; and a memory comprising computer code configured to cause one or more processors to: capture a first plurality of images of a scene from the first image capture unit, wherein each of the first plurality of images is associated with a different depth; determine a sharpness metric for each of the first plurality of images; and generate a depth map comprising a plurality of pixels, wherein generating the depth map comprises selecting, for each pixel in the depth map, a depth associated with one of the first plurality of images, based on a comparison of the sharpness metrics for the first plurality of images.
16. The system of claim 15, wherein the computer code further comprises computer code executable by the one or more processors to:
- capture a preview image of the scene from the second image capture unit.
17. The system of claim 16, wherein the computer code further comprises computer code executable by the one or more processors to:
- estimate a relative blur between each image in the first plurality of images and the preview image,
- wherein each pixel in the depth map is further based on the estimated relative blurs.
18. The system of claim 15, wherein the first image capture unit comprises a telephoto lens, and wherein the second image capture unit comprises a wide-angle lens.
19. The system of claim 15, wherein the computer code executable by the one or more processors to determine the sharpness metric further comprises computer code executable by the one or more processors to:
- determine a relative degree of blur between at least two consecutively captured images of the first plurality of images.
20. The system of claim 15, wherein the computer code executable by the one or more processors to select, for each pixel in the depth map, a depth associated with one of the first plurality of images, based on a comparison of the sharpness metrics for the first plurality of image further comprises computer code executable by the one or more processors to:
- select, for each pixel in the depth map, the depth associated with a sharpest image from the first plurality of images at the respective pixel location.
Type: Application
Filed: Mar 11, 2019
Publication Date: Jul 4, 2019
Inventors: Claus Molgaard (Los Gatos, CA), Thomas E. Bishop (San Francisco, CA)
Application Number: 16/298,272