Systems and Methods for Generating Compressed Light Field Representation Data using Captured Light Fields, Array Geometry, and Parallax Information
Systems and methods for the generating compressed light field representation data using captured light fields in accordance embodiments of the invention are disclosed. In one embodiment, an array camera includes a processor and a memory connected configured to store an image processing application, wherein the image processing application configures the processor to obtain image data, wherein the image data includes a set of images including a reference image and at least one alternate view image, generate a depth map based on the image data, determine at least one prediction image based on the reference image and the depth map, compute prediction error data based on the at least one prediction image and the at least one alternate view image, and generate compressed light field representation data based on the reference image, the prediction error data, and the depth map.
Latest Pelican Imaging Corporation Patents:
- Extended Color Processing on Pelican Array Cameras
- Systems and Methods for Synthesizing Images from Image Data Captured by an Array Camera Using Restricted Depth of Field Depth Maps in which Depth Estimation Precision Varies
- Thin Form Factor Computational Array Cameras and Modular Array Cameras
- Array Camera Configurations Incorporating Constituent Array Cameras and Constituent Cameras
- Array Cameras Incorporating Independently Aligned Lens Stacks
The current application is a continuation of U.S. patent application Ser. No. 14/186,871, entitled “Systems and Methods for Generating Compressed Light Field Representation Data using Captured Light Fields, Array Geometry, and Parallax Information” to Venkataraman et al., filed on Feb. 21, 2014, which claims priority to U.S. Provisional Patent Application Ser. No. 61/767,520, filed Feb. 21, 2013, and to U.S. Provisional Patent Application Ser. No. 61/786,976, filed Mar. 15, 2013, the disclosures of which are hereby incorporated by reference in their entirety.
FIELD OF THE INVENTIONThe present invention relates to systems and methods for capturing light fields and more specifically to the efficient representation of captured light fields using compressed light field representation data.
BACKGROUNDImaging devices, such as cameras, can be used to capture images of portions of the electromagnetic spectrum, such as the visible light spectrum, incident upon an image sensor. For ease of discussion, the term light is generically used to cover radiation across the entire electromagnetic spectrum. In a typical imaging device, light enters through an opening (aperture) at one end of the imaging device and is directed to an image sensor by one or more optical elements such as lenses. The image sensor includes pixels or sensor elements that generate signals upon receiving light via the optical element. Commonly used image sensors include charge-coupled device (CCDs) sensors and complementary metal-oxide semiconductor (CMOS) sensors.
Image sensors are devices capable of converting an image into a digital signal. Image sensors utilized in digital cameras are typically made up of an array of pixels. Each pixel in an image sensor is capable of capturing light and converting the captured light into electrical signals. In order to separate the colors of light and capture a color image, a Bayer filter is often placed over the image sensor, filtering the incoming light into its red, blue, and green (RGB) components that are then captured by the image sensor. The RGB signal captured by the image sensor using a Bayer filter can then be processed and a color image can be created.
SUMMARY OF THE INVENTIONSystems and methods for the generating compressed light field representation data using captured light fields in accordance embodiments of the invention are disclosed. In one embodiment, an array camera includes a processor and a memory connected to the processor and configured to store an image processing application, wherein the image processing application configures the processor to obtain image data, wherein the image data includes a set of images including a reference image and at least one alternate view image and each image in the set of images includes a set of pixels, generate a depth map based on the image data, where the depth map describes the distance from the viewpoint of the reference image with respect to objects imaged by pixels within the reference image, determine at least one prediction image based on the reference image and the depth map, where the prediction images correspond to at least one alternate view image, compute prediction error data based on the at least one prediction image and the at least one alternate view image, where a portion of prediction error data describes the difference in photometric information between a pixel in a prediction image and a pixel in at least one alternate view image corresponding to the prediction image, and generate compressed light field representation data based on the reference image, the prediction error data, and the depth map.
In an additional embodiment of the invention, the array camera further includes an array camera module including an imager array having multiple focal planes and an optics array configured to form images through separate apertures on each of the focal planes, wherein the array camera module is configured to communicate with the processor and wherein the obtained image data includes images captured by the imager array.
In another embodiment of the invention, the reference image corresponds to an image captured using one of the focal planes within the image array.
In yet another additional embodiment of the invention, the at least one alternate view image corresponds to the image data captured using the focal planes within the image array separate from the focal planes associated with the reference image.
In still another additional embodiment of the invention, the reference image corresponds to a virtual image formed based on the images in the array.
In another embodiment of the invention, the depth map describes the geometrical linkage between the pixels in the reference image and the pixels in the other images in the image array.
In yet still another additional embodiment of the invention, the image processing application configures the processor to perform a parallax detection process to generate the depth map, where the parallax detection process identifies variations in the position of objects within the image data along epipolar lines between the reference image and the at least one alternate view image.
In yet another embodiment of the invention, the image processing application further configures the processor to compress the generated compressed light field representation data.
In still another embodiment of the invention, the generated compressed light field representation data is compressed using JPEG-DX.
In yet still another embodiment of the invention, the image processing application configures the processor to determine prediction error data by identifying at least one pixel in the at least one alternative view image corresponding to a reference pixel in the reference image, determining fractional pixel locations within the identified at least one pixel, where a fractional pixel location maps to a plurality of pixels in at least one alternative view image, and mapping fractional pixel locations to a specific pixel location within the alternate view image having a determined fractional pixel location.
In yet another additional embodiment of the invention, the mapping fractional pixel locations is determined as the pixel being nearest neighbor within the alternative view image.
In still another additional embodiment of the invention, the image processing application configures the processor to map the fractional pixel locations based on the depth map, where the pixel in the alternate view image is likely to be similar based on its proximity to the corresponding pixel location determined using the depth map of the reference image.
In yet still another additional embodiment of the invention, the image processing application further configures the processor to identify areas of low confidence within the computed prediction images based on the at least one alternate view image, the reference image, and the depth map and an area of low confidence indicate areas where the information stored in a determined prediction image indicate areas in the reference viewpoint where the pixels in the determined prediction image may not photometrically correspond to the corresponding pixels in the alternate view image.
In another embodiment of the invention, the depth map further comprises a confidence map describing areas of low confidence within the depth map.
In yet another embodiment of the invention, the image processing application further configures the processor to disregard identified areas of low confidence.
In still another embodiment of the invention, the image processing application further configures the processor to identify at least one additional reference image within the image data, where the at least one additional reference image is separate from the reference image, determine at least one supplemental prediction image based on the reference image, the at least one additional reference image, and the depth map, and compute the supplemental prediction error data based on the at least one alternate additional reference image and the at least one supplemental prediction image, and the generated compressed light field representation data further includes the supplemental prediction error data.
In yet still another embodiment of the invention, the generated compressed light field representation data further includes the at least one additional reference image.
In yet another additional embodiment of the invention, the image processing application configures the processor to identify the at least one additional reference image by generating an initial additional reference image based on the reference image and the depth map, where the initial additional reference image includes pixels projected from the viewpoint of the reference image based on the depth map and forming the additional reference image based on the initial additional reference image and the prediction error data, where the additional reference image comprises pixels based on interpolations of pixels propagated from the reference image and the prediction error data.
In another embodiment of the invention, the prediction error data is decoded based on the reference image prior to the formation of the additional reference image.
Still another embodiment of the invention includes a method for generating compressed light field representation data including obtaining image data using an array camera, where the image data includes a set of images including a reference image and at least one alternate view image and the images in the set of images include a set of pixels, generating a depth map based on the image data using the array camera, where the depth map describes the distance from the viewpoint of the reference image with respect to objects imaged by pixels within the reference image based on the alternate view images, determining a set of prediction images based on the reference image and the depth map using the array camera, where a prediction image in the set of prediction images is a representation of a corresponding alternate view image in the at least one alternate view image, computing prediction error data by calculating the difference between a prediction image in the set of prediction images and the corresponding alternate view image that describes the difference in photometric information between a pixel in the reference image and a pixel in an alternate view image using the array camera, and generating compressed light field representation data based on the reference image, the prediction error data, and the depth map using the array camera.
In yet another additional embodiment of the invention, the reference image is a virtual image interpolated from a virtual viewpoint within the image data.
In still another additional embodiment of the invention, determining the set of predicted images further includes identifying at least one pixel in the at least one alternative view image corresponding to a reference pixel in the reference image using the array camera, determining fractional pixel locations within the identified at least one pixel using the array camera, where a fractional pixel location maps to a plurality of pixels in at least one alternative view image, and mapping fractional pixel locations to a specific pixel location within the alternate view image having a determined fractional pixel location using the array camera.
In yet still another embodiment of the invention, the method further includes identifying areas of low confidence within the computed prediction images based on the at least one alternate view image, the reference image, and the depth map using the array camera, where an area of low confidence indicate areas where the information stored in a determined prediction image indicate areas in the reference viewpoint where the pixels in the determined prediction image may not photometrically correspond to the corresponding pixels in the alternate view image.
In yet another additional embodiment of the invention, the method further includes identifying at least one additional reference image within the image data using the array camera, where the at least one additional reference image is separate from the reference image, determining at least one supplemental prediction image based on the reference image, the at least one additional reference image, and the depth map using the array camera, and computing the supplemental prediction error data based on the at least one alternate additional reference image and the at least one supplemental prediction image using the array camera, where the generated compressed light field representation data further includes the supplemental prediction error data.
In still another additional embodiment of the invention, identifying the at least one additional reference image includes generating an initial additional reference image based on the reference image and the depth map using the array camera, where the initial additional reference image includes pixels projected from the viewpoint of the reference image based on the depth map and forming the additional reference image based on the initial additional reference image and the prediction error data using the array camera, where the additional reference image comprises pixels based on interpolations of pixels propagated from the reference image and the prediction error data.
Turning now to the drawings, systems and methods for generating compressed light field representation data using captured light fields in accordance with embodiments of the invention are illustrated. Array cameras, such as those described in U.S. patent application Ser. No. 12/935,504, entitled “Capturing and Processing of Images using Monolithic Camera Array with Heterogeneous Imagers” to Venkataraman et al., can be utilized to capture light fields and store the captured light fields. Captured light fields contain image data from an array of images of a scene captured from multiple points of view so that each image samples the light field of the same region within the scene (as opposed to a mosaic of images that sample partially overlapping regions of a scene). It should be noted that any configuration of images, including two-dimensional arrays, non-rectangular arrays, sparse arrays, and subsets of arrays of images could be utilized as appropriate to the requirements of specific embodiments of the invention. In a variety of embodiments, image data for a specific image that forms part of a captured light field describes a two-dimensional array of pixels. Storing all of the image data for the images in a captured light field can consume a disproportionate amount of storage space, limiting the number of light field images that can be stored within a fixed capacity storage device and increasing the amount of data transfer involved in transmitting a captured light field. Array cameras in accordance with many embodiments of the invention are configured to process captured light fields and generate data describing correlations between the images in the captured light field. Based on the image correlation data, some or all of the image data in the captured light field can be discarded, affording more efficient storage of the captured light fields as compressed light field representation data. Additionally, this process can be decoupled from the capturing of light fields to enable the efficient use of the hardware resources present in the array camera.
In many embodiments, each image in a captured light field is from a different viewpoint. Due to the different viewpoint of each of the images, parallax results in variations in the position of objects within the images of the scene. The disparity between corresponding pixels in images in a captured light field can be utilized to determine the distance to an object imaged by the corresponding pixels. Conversely, distance can be used to estimate the location of a corresponding pixel in another image. Processes that can be utilized to detect parallax and generate depth maps in accordance with embodiments of the invention are disclosed in U.S. patent application Ser. No. 13/972,881 entitled “Systems and Methods for Parallax Detection and Correction in Images Captured Using Array Cameras that Contain Occlusions using Subsets of Images to Perform Depth Estimation” to Venkataraman et al. In many embodiments, a depth map is metadata describing the distance from the viewpoint from which an image is captured (or, in the case of super-resolution processing, synthesized) with respect to objects imaged by pixels within the image. Additionally, the depth map can also describe the geometrical linkage between pixels in the reference image and pixels in all other images in the array.
Array cameras in accordance with several embodiments of the invention are configured to process the images in a captured light field using a reference image selected from the captured array of images. In a variety of embodiments, the reference image is a synthetic image generated from the captured images, such as a synthetic viewpoint generated from a focal plane (e.g. a camera) that does not physically exist in the imager array. The remaining images can be considered to be images of alternate views of the scene relative to the viewpoint of the reference image. Using the reference image, array cameras in accordance with embodiments of the invention can generate a depth map using processes similar to those described above in U.S. patent application Ser. No. 13/972,881 and the depth map can be used to generate a set of prediction images describing the pixel positions within one or more of the alternate view images that correspond to specific pixels within the reference image. The relative locations of pixels in the alternate view images can be predicted along epipolar lines projected based on the configuration of the cameras (e.g. the calibration of the physical properties of the imager array in the array camera and their relationship to the reference viewpoint of the array camera) that captured the images. The predicted location of the pixels along the epipolar lines is a function of the distance from the reference viewpoint to the object imaged by the corresponding pixel in the reference image. In a number of embodiments, the predicted location is additionally a function of any calibration parameters intrinsic to or extrinsic to the physical imager array. The prediction images exploit the correlation between the images in the captured light field by describing the differences between the value of a pixel in the reference image and pixels adjacent to corresponding disparity-shifted pixel locations in the other alternate view images in the captured light field. The disparity-shifted pixel positions are often determined with fractional pixel precision (e.g. an integer position in the reference image is mapped to a fractional position in the alternate view image) based on a depth map of the reference image in the alternate view images. Significant compression of the image data forming the images of a captured light field can be achieved by selecting one reference image, generating prediction images with respect to the reference image using the depth map information relating the reference and alternate view images, generating prediction error data describing the differences between the predicted images and the alternate view images, and discarding the alternate view images. In a variety of embodiments, multiple reference images are utilized to generate prediction error data that describes the photometric differences between pixels in alternate view images adjacent to corresponding disparity-shifted pixel locations and pixels in one or more of the reference images.
It should also be noted that that while, in a variety of embodiments, the reference image corresponds to an image in the captured array of images, virtual (e.g. synthetic) images corresponding to a virtual viewpoint within the captured light field can also be utilized as the reference image in accordance with embodiments of the invention. For example, a virtual red image, a virtual green image, and/or a virtual blue image can be used to form a reference image for each respective color channel and used as a starting point for forming predicted images for the alternate view images of each respective color channel. In many embodiments, a color channel includes a set of images within the image array corresponding to a particular color, potentially as captured by the focal planes within the imager array. However, in accordance with embodiments of the invention, the reference image for a particular color channel can be taken from a different color channel; for example, an infrared image can be used as the reference image for the green channel within the captured light field.
The reference image(s) and the set of prediction error data stored by an array camera can be referred to as compressed light field representation data. The compressed light field representation data can also include the depth map utilized to generate the prediction error data and/or any other metadata related to the creation of the compressed light field representation data and/or the captured light field. The prediction error data can be compressed using any compression technique, such as discrete cosine transform (DCT) techniques, as appropriate to the requirements of specific embodiments of the invention. The compressed light field representation data can be compressed and stored in a variety of formats. One such file format is the JPEG-DX extension to ISO/IEC 10918-1 described in U.S. patent application Ser. No. 13/631,731, titled “Systems and Methods for Encoding Light Field Image Files” to Venkataraman et al. As can readily be appreciated, the prediction error data can be stored in a similar manner to a depth map as compressed or uncompressed layers and/or metadata within an image file. In a variety of embodiments, array cameras are configured to capture light fields separate from the generation of the compressed light field representation data. For example, the compressed light field representation data can be generated when the array camera is no longer capturing light fields or in the background as the array camera captures additional light fields. Any variety of decoupled processing techniques can be utilized in accordance with the requirements of embodiments of the invention. Many array cameras in accordance with embodiments of the invention are capable of performing a variety of processes that utilize the information contained in the captured light field using the compressed light field representation data.
In many instances, a captured light field contains image data from an array of images of a scene that sample an object space within the scene in such a way as to provide sampling diversity that can be utilized to synthesize higher resolution images of the object space using super-resolution processes. Systems and methods for performing super-resolution processing on image data captured by an array camera in accordance with embodiments of the invention are disclosed in U.S. patent application Ser. No. 12/967,807 entitled “System and Methods for Synthesizing High Resolution Images Using Super-Resolution Processes” to Lelescu et al. Synthesized high resolution images are representations of the scene captured in the captured light field. In many instances, the process of synthesizing a high resolution image may result in a single image, a stereoscopic pair of images that can be used to display three dimensional (3D) information via an appropriate 3D display, and/or a variety of images from different viewpoints. The process of synthesizing high resolution images from lower resolution image data captured by an array camera module in an array camera typically involves performing parallax detection and correction to reduce the effects of disparity between the images captured by each of the cameras in the array camera module. By using the reference image(s), the set of prediction error data, and/or the depth map contained in compressed light field representation data, high resolution images can be synthesized separately from the parallax detection and correction process, thereby alleviating the need to store and process the captured light field until the super-resolution process can be performed. Additionally, the parallax detection process can be optimized to improve speed or efficiency of compression. Once the compressed data is decoded, a parallax process can be re-run at a different (i.e. higher) precision using the reconstructed images. In this way, an initial super-resolution process can be performed in an efficient manner (such as on an array camera, where the processing power of the device limits the ability to perform a high precision parallax process in real-time) and, at a later time, a higher resolution parallax process can be performed to generate any of a variety of data, including a second set of compressed light field representation data and/or other captured light field image data, or perform any processing that relies on the captured light field. Later times include, but are not limited to, times when the array camera is not capturing light fields and/or when the compressed light field representation data has been transmitted to a separate image processing device with more advanced processing capabilities.
The disclosures of each of U.S. patent application Ser. Nos. 12/935,504, 12/967,807, 13/631,731, and 13/972,881 are hereby incorporated by reference in their entirety. Although the systems and methods described are with respect to array cameras configured to both capture and process captured light fields, devices that are configured to obtain captured light fields captured using a different device and process the received data can be utilized in accordance with the requirements of a variety of embodiments of the invention. Additionally, any of the various systems and processes described herein can be performed in sequence, in alternative sequences, and/or in parallel (e.g. on different computing devices) in order to achieve similar results in a manner that is more appropriate to the requirements of a specific application of the invention. Systems and methods for capturing light fields and generating compressed light field representation data using the captured light fields in accordance with embodiments of the invention are described below.
Array Camera ArchitecturesAs described above, array cameras are capable of capturing and processing light fields and can be configured to generate compressed light field representation data using captured light fields in accordance with many embodiments of the invention. An array camera including an imager array in accordance with an embodiment of the invention is illustrated in
In the illustrated embodiment, the focal planes are configured in a 5×5 array. In other embodiments, any of a variety of array configurations can be utilized including linear arrays, non-rectangular arrays, and subsets of an array as appropriate to the requirements of specific embodiments of the invention. Each focal plane 104 of the imager array is capable of capturing image data from an image of the scene formed through a distinct aperture. Typically, each focal plane includes a plurality of rows of pixels that also forms a plurality of columns of pixels, and each focal plane is contained within a region of the imager that does not contain pixels from another focal plane. The pixels or sensor elements utilized in the focal planes can be individual light sensing elements such as, but not limited to, traditional CIS (CMOS Image Sensor) pixels, CCD (charge-coupled device) pixels, high dynamic range sensor elements, multispectral sensor elements, and/or any other structure configured to generate an electrical signal indicative of light incident on the structure. In many embodiments, the sensor elements of each focal plane have similar physical properties and receive light via the same optical channel and color filter (where present). In other embodiments, the sensor elements have different characteristics and, in many instances, the characteristics of the sensor elements are related to the color filter applied to each sensor element. In a variety of embodiments, a Bayer filter pattern of light filters can be applied to one or more of the focal planes 104. In a number of embodiments, the sensor elements are optimized to respond to light at a particular wavelength without utilizing a color filter. It should be noted that any optical channel, including those in non-visible portions of the electromagnetic spectrum (such as infrared) can be sensed by the focal planes as appropriate to the requirements of particular embodiments of the invention.
In several embodiments, information captured by one or more focal planes 104 is read out of the imager array 102 as packets of image data. In many embodiments, a packet of image data contains one or more pixels from a row of pixels captured from each of one or more of the focal planes 104. Packets of image data may contain other groupings of captured pixels, such as one or more pixels captured from a column of pixels in each of one or more focal planes 104 and/or a random sampling of pixels. Systems and methods for reading out image data from array cameras that can be utilized in array cameras configured in accordance with embodiments of the invention are described in U.S. Pat. No. 8,305,456, entitled “Systems and Methods for Transmitting and Receiving Array Camera Image Data” to McMahon, the entirety of which is hereby incorporated by reference. In several embodiments, the packets of image data are used to create a two-dimensional array of images representing the light field as captured from the one or more focal planes 104. In many embodiments, one or more of the images in the array of images are associated with a particular color; this color can be the same color associated with the focal plane 104 corresponding to the viewpoint of the image or a different color. The processor 108 can be configured to immediately process the captured light field from the one or more focal planes and/or the processor 108 can store the captured light field and later process the captured light field. In a number of embodiments, the processor 108 is configured to offload the captured light fields to an external device for processing.
The processing of captured light fields includes determining correspondences between pixels in the captured light field. In several embodiments, the pixels in the packets of image data are geometrically correlated based on a variety of factors, including, but not limited to, the characteristics of one or more of the focal planes 104. The calibration of imager arrays to determine the characteristics of focal planes are disclosed in U.S. patent application Ser. No. 12/967,807 incorporated by reference above. In several embodiments, processor 108 is configured (such as by an image processing application) to perform parallax detection on the captured light field to determine corresponding pixel locations along epipolar lines between a reference image and alternate view images within the captured light field. The process of performing parallax detection also involves generating a depth map with respect to the reference image (e.g. a reference viewpoint that may include synthesized ‘virtual’ viewpoints where a physical camera in the array does not exist). In a variety of embodiments, the captured packets of image data are associated with image packet timestamps and geometric calibration and/or photometric calibration between pixels in the packets of image data utilize the associated image packet timestamps. Corresponding pixel locations and differences between pixels in the reference image and the alternate view image(s) can be utilized by processor 108 to determine a prediction for at least some of the pixels of the alternate view image(s). In many embodiments, the corresponding pixel locations are determined with sub-pixel precision.
The prediction image can be formed by propagating pixels from the reference image(s) to the corresponding pixel locations in the alternate view grid. In many embodiments, the corresponding pixel locations in the alternate view grid are fractional positions (e.g. sub-pixel positions). Once the pixels from the reference image(s) are propagated to the corresponding positions in the alternate view grid, a predicted image (from the same perspective as the alternate view image) is formed by calculating prediction values for the integer grid points in the alternate view grid based on propagated pixel values from the reference image. The predicted image values in the integer grid of the alternate view image can be determined by interpolating from multiple pixels propagated from the reference image in the neighborhood of the integer pixel grid position in the predicted image. In many embodiments, the predicted image values on the integer grid points of the alternate view image are interpolated through an iterative interpolation schemes (e.g. a combination of linear or non-linear interpolations) that progressively fill in ‘holes’ or missing data at integer positions in the predicted alternate view image grid. In a variety of embodiments, integer grid locations in the predicted image can be filled using set selection criteria. In several embodiments, pixels propagated from the reference image within a particular radius of the integer pixel position can form a set, and the pixel in the set closest to the mean of the distribution of pixels in the region can be selected as the predictor. In a number of embodiments, within the same set, the pixel that lands nearest to the integer grid point may be used as the predictor (i.e. nearest neighbor interpolation). In another embodiment, an average of the N nearest neighbors may be used as the predicted image value at the integer grid point. However, it should be noted that the predicted value can be any function (linear or non-linear) that interpolates or inpaints values in the predicted image based on reference pixel values in some relationship of the integer grid position in the predicted image.
The prediction error data itself can be determined by performing a photometric comparison of the pixel values from the predicted image (e.g. the predicted alternate view image based on the reference image and the depth map) and the corresponding alternate view image. The prediction error data represents the difference between the predicted alternate view image based on the reference image and the depth map, and the actual alternate view image that must be later reproduced in the decoding process.
Due to variations in the optics and the pixels used to capture the image data, sampling diversity, and/or aliasing, the processor 108 is configured to anticipate photometric differences between corresponding pixels. These photometric differences may be further increased in the compared pixels because the nearest neighbor does not directly correspond to the pixel in the reference image. In many embodiments, the compression is lossless and the full captured light field can be reconstructed using the reference image, the depth map, and the prediction error data. In other embodiments, a lossy compression is used and an approximation of the full captured light field can be reconstructed. In this way, the pixel values of the alternate view images are available for use in super-resolution processing, enabling the super-resolution processes to exploit the sampling diversity and/or aliasing that may be reflected in the alternate view images. In a number of embodiments, the prediction images are sparse images. In several embodiments, sparse images contain predictions for some subset of points (e.g. pixels) in the space of the alternate view images. Processor 108 is further configured to generate compressed light field representation data using prediction error data, the reference image, and the depth map. Other data, such as one or more image packet timestamps, can be included as metadata associated with the compressed light field representation data as appropriate to the requirements of specific array cameras in accordance with embodiments of the invention. In several embodiments, the prediction error data and the reference image are compressed via lossless and/or lossy image compression techniques. In a variety of embodiments, an image processing application configures processor 108 to perform a variety of operations using the compressed light field representation data, including, but not limited to, synthesizing high resolution images using a super-resolution process. Other operations can be performed using the compressed light field representation data in accordance with a variety of embodiments of the invention.
Although a specific array camera configured to capture light fields and generate compressed light field representation data is illustrated in
Processing and Interacting with Captured Light Fields
A captured light field, as an array of images, can consume a significant amount of storage space. Generating compressed light field representation data using the captured light field while reducing the storage space utilized can be a processor-intensive task. A variety of array cameras in accordance with embodiments of the invention lack the processing power to simultaneously capture and process light fields while maintaining adequate performance for one or both of the operations. Array cameras in accordance with several embodiments of the invention are configured to separately obtain a captured light field and generate compressed light field representation data using the captured light field, allowing the array camera to quickly capture light fields and efficiently process those light fields as the processing power becomes available and/or the compressed light field representation data is needed. A process for processing and interacting with captured light fields in accordance with an embodiment of the invention is illustrated in
In many embodiments, a captured light field is obtained (210) using an imager array and a processor in the array camera generating (212) the compressed light field representation data. In a number of embodiments, a captured light field is obtained (210) from a separate device. In several embodiments, the captured light field is obtained (210) and compressed light field representation data is generated (212) as part of a single capture operation. In a variety of embodiments, obtaining (210) the captured light field and generating (212) the compressed light field representation data occurs at disparate times.
Generating (212) the compressed light field representation data includes normalizing the obtained (210) captured light field and generating a depth map for the obtained (210) captured light field using geometric calibration data and photometric calibration data. In many embodiments, parallax detection processes, such as those disclosed in U.S. patent application Ser. No. 13/972,881, are utilized to generate a depth map and prediction error data describing correlation between pixels in the captured light field from the perspective of one or more reference images. Processes other than those disclosed in U.S. patent application Ser. No. 13/972,881 can be utilized in accordance with many embodiments of the invention. The generated (212) compressed light field representation data includes the prediction error data, the reference images, and the depth map. Additional metadata, such as timestamps, location information, and sensor information, can be included in the generated (212) compressed light field representation data as appropriate to the requirements of specific applications in accordance with embodiments of the invention. In many embodiments, the generated (212) compressed light field representation data is compressed using lossy and/or non-lossy compression techniques. The generated (212) compressed light field representation data can be stored in a variety of formats, such as the JPEG-DX standard. In several embodiments, the alternate view images in the obtained (210) captured light field are not stored in the generated (212) compressed light field representation data.
In a number of embodiments, synthesizing (214) a high resolution image utilizes the reference image(s), the prediction error data, and the depth map in the generated (212) compressed light field representation data. In a variety of embodiments, the reference images, the prediction error data, and the depth map are utilized to reconstruct the array of images (or an approximation of the images) to synthesize (214) a high resolution image using a super-resolution process. A high resolution image can be synthesized (214) using the array of images representing the captured light field reconstructed based on the compressed light field representation data (212). However, in a number of embodiments synthesizing (214) a high resolution image using the generated (212) compressed light field representation data includes reconstructing (e.g. decoding) the array of images using the compressed light field representation data once the captured light field is to be viewed, such as in an image viewing application running on an array camera or other device. Techniques for decoding compressed light field representation data that can be utilized in accordance with embodiments of the invention are described in more detail below. In several embodiments, high resolution images are synthesized (214) at a variety of resolutions to support different devices and/or varying performance requirements. In a number of embodiments, the synthesis (214) of a number of high resolution images is part of an image fusion process such as the processes described in U.S. patent application Ser. No. 12/967,807, the disclosure of which is incorporated by reference above.
Many operations can be performed while interacting (216) with synthesized high resolution images, such as, but not limited to, modifying the depth of field of the synthesized high resolution image, changing the focal plane of the synthesized high resolution image, recoloring the synthesized high resolution image, and detecting objects within the synthesized high resolution image. Systems and methods for interacting (216) with compressed light field representation data and synthesized high resolution images that can be utilized in accordance with embodiments of the invention are disclosed in U.S. patent application Ser. No. 13/773,284 to McMahon et al., the entirety of which is hereby incorporated by reference.
Although a specific process processing and interacting with captured light fields in accordance with an embodiment of the invention is described above with respect to
A process for generating compressed light field representation data in accordance with an embodiment of the invention is illustrated in
In a variety of embodiments, the array of images is obtained (310) from a captured light field. In several embodiments, the obtained (310) array of images is packets of image data captured using an imager array. In many embodiments, the determined (312) reference image corresponds to the reference viewpoint of the array of images. Furthermore, the determined (312) reference image can be an arbitrary image (or synthetic image) in the obtained (310) array of images. In a number of embodiments, each image in the obtained (310) array of images is associated with a particular color channel, such as, but not limited to, green, red, and blue. Other colors and/or portions of the electromagnetic spectrum can be associated with each image in the array of images in accordance with a variety of embodiments of the invention. In several embodiments, the determined (312) reference image is a green image in the array of images. Parallax detection is performed (314) with respect to the viewpoint of the determined (312) reference image to locate pixels corresponding to pixels in a reference image by searching along epipolar lines in the alternate view images in the array of images. In a number of embodiments, the parallax detection uses correspondences between cameras that are not co-located with the viewpoint of the reference image(s). In many embodiments, the search area need not be directly along an epipolar line, but rather a region surrounding the epipolar line; this area can be utilized to account for inaccuracies in determining imager calibration parameters and/or the epipolar lines. In several embodiments, parallax detection can be performed (314) with a fixed and/or dynamically determined level of precision; this level of precision can be based on performance requirements and/or desired compression efficiency, the array of images, and/or on the desired level of precision in the result of the performed (314) parallax detection. Additional techniques for performing parallax processes with varying levels of precision are disclosed in U.S. Provisional Patent Application Ser. No. 61/780,974, filed Mar. 13, 2013, the entirety of which is hereby incorporated by reference.
Disparity Information From a Single Reference ImageTurning now to
In a variety of embodiments, performing (314) parallax detection includes generating a depth map describing depth information in the array of images. In many embodiments, the depth map is metadata describing the distance from the reference camera (i.e. viewpoint) to the portion of the scene captured in the pixels (or a subset of the pixels) of an image determined using the corresponding pixels in some or all of the alternate view images. In several embodiments, candidate corresponding pixels are those pixels in alternate view images that appear along epipolar lines from pixels in the reference image. In a number of embodiments, a depth map is generated using only images in the array of images that are associated with the same color (for example, green) as the reference image. In several embodiments, the depth map is generated using images of the same color but a different color than the reference camera. For example, with a green reference image, a depth map can be generated using only the images associated with the color red (or blue) in the array of images. In many embodiments, depth information is determined with respect to multiple colors and combined to generate a depth map; e.g. depth information is determined separately for the subsets of green, red, and blue images in the array of images and a final depth map is generated using a combination of the green depth information, the red depth information, and the blue depth information. In a variety of embodiments, the depth map is generated using information from any set of cameras in the array. In a variety of embodiments, the depth map is generated without respect to colors associated with the images and/or with a combination of colors associated with the images. In several embodiments, performing (314) parallax detection can be performed utilizing techniques similar to those described in U.S. patent application Ser. No. 13/972,881, incorporated by reference above. Additionally, non-color images (such as infrared images) can be utilized to generate the depth map as appropriate to the requirements of specific embodiments of the invention.
Although a specific example of a 4×4 array of images that can be utilized to determine disparity information and a depth map from a reference image in the 4×4 array of images is described above with respect to
Returning now to
In a variety of embodiments, virtual red, virtual green, and/or virtual blue reference images can be utilized as a reference image. For example, a depth map can be determined for a particular reference viewpoint that may not correspond to the location of a physical camera in the array. This depth map can be utilized to form a virtual red image, virtual green, and/or virtual blue image from the captured light field. These virtual red, virtual green, and and/or virtual blue images can then be utilized as the reference image(s) from which to create the prediction images for the alternate view(s) utilized in the processes described above. By way of a second example, one or more virtual red, virtual green, and/or virtual blue images and/or physical red, green, and/or blue images within the array of images can be used as reference images. When forming the prediction error, the depth map can be utilized to form a prediction image from virtual and/or actual reference image(s) and calculate the prediction error with respect to the corresponding alternate view images.
Turning now to
Returning now to
Prediction error data for the alternate view is computed (318) using the determined (312) reference image, the determined (316) prediction images, and depth map. For the reference image pref and alternate view images pk,l where k,l represents the location of the alternate view image in the array of images p, the depth information provides a subset of images pk,l where
pref(x,y):=pk,l(i,j)
where (x,y) is the location of a pixel in pref and (i,j) is the location of a pixel at a fractional location in pk,l corresponding to a pixel in pref(x,y) based on the depth information. Using these mappings of subsets of pixels to the alternate viewpoint pk,l a prediction image is calculated from the reference pixels mapping to pk,l. (316). The prediction error data Ek,l can be computed (318) between pref and the prediction image for viewpoint pk,l described above. In a variety of embodiments, the determined (316) prediction images include sparse images. The missing values for the sparsely populated images can be interpolated using populated values within a neighborhood of the missing pixel value. For example, a kernel regression may be applied to the populated values to fill in the missing prediction values. In these cases, the prediction error data Ek,l is a representation of the error induced by the interpolation of the missing values.
In many embodiments, the determined (316) initial prediction image is a sparsely populated grid of fractionally-positioned points from the reference frame pref that includes “holes” that are locations or regions on the alternate view integer grid that are not occupied by any of the pixels mapped from the reference frame pref. The presence of “holes” can be particularly prevalent in occluded areas but may occur in non-occlusion regions due to non-idealities in the depth map or due to the fact that many pixels in the reference camera correspond to fractional positions in the alternate view image. In several embodiments, holes in the prediction error data can be filled using the absolute value of the pixel location in the alternate view image pk,l. This is similar to filling the predicted image with a value of zero (i.e. any null value or default value) to ensure that the coded error is equal to the value of the pixel in the alternate view image at that position. In a variety of embodiments, “holes” in a predicted image can be filled using interpolation with predicted values from neighboring pixels to create additional predictions for the holes based on the pixels from the predicted image. As can be readily appreciated, any interpolator can be utilized to create interpolated predicted image pixels from pixels propagated from the reference image. The details of the interpolation scheme used is a parameter of the encoding and decoding process and should be applied in both the encoder and decoder to ensure lossless output. In a variety of embodiments, residuals can provide more efficient compression than encoding holes with absolute values. In several embodiments, the pixels from the reference image pref do not map to exact grid locations within the prediction image and a mapping that assigns a single pixel value to multiple adjacent pixel locations on the integer grid of the prediction image is used. In this way, there is a possibility that multiple pixels from the reference image pref may map to the same integer grid location in the prediction image. In this case, pixel stacking rules can be utilized to generate multiple prediction images in which different stacked pixels are used in each image. In many embodiments, if N pixels exist in a pixel stack, then the resulting predicted value could be the mean of the N pixel values in the stack. However, any number of prediction images can be computed and/or any other techniques for determining prediction images where multiple pixels map to the same location (e.g. a pixel stack exists) as appropriate to the requirements of specific embodiments of the invention. In a variety of embodiments, holes can remain within the predicted images after the initial interpolation; additional interpolation processes can be performed until every location on the integer grid of the predicted image (or a predetermined number of locations) is assigned a pixel value. Any interpolation technique, such as kernel regression or inpainting, can be used to fill the remaining holes as described. In other embodiments, a variety of techniques can be utilized to achieve compression of raw data that involve creating multiple prediction images and/or pieces of prediction error data. Furthermore, any variety of interpolation techniques known to those skilled in the art can be utilized to fill holes in a prediction image as appropriate to the requirements of a specific application in accordance with embodiments of the invention.
Prediction Error Data From Multiple Reference ImagesIn a variety of embodiments, performing (314) parallax detection does not return accurate disparity information for pixels in alternate view images that are occluded, appear in featureless (e.g. textureless) areas relative to the reference image, or where the depth map exhibits other non-idealities such as photometric mismatch. Using the determined (316) prediction error data and/or the depth map and/or a confidence map describing areas of low confidence in the depth map, areas of low confidence can be identified (320). Areas of low confidence indicate areas in the reference viewpoint where the depth measurement may be inaccurate or the pixels may otherwise not photometrically correspond (for example due to defects in the reference image), leading to potential inefficiencies in compression and/or performance. Low confidence can be determined in a variety of ways, such as identifying areas having a parallax cost function exceeding a threshold value. For example, if the parallax cost function indicates a low cost (e.g. low mismatch), this indicates that the focal planes agree on a particular depth and the pixels appear to correspond. Similarly, a high cost indicates that not all focal planes agree with respect to the depth, and therefore the computed depth is unlikely correctly represent the locations of objects within the captured light field. However, any of a variety of techniques for identifying areas of low confidence can be utilized as appropriate to the requirements of specific embodiments of the invention, such as those disclosed in U.S. patent application Ser. No. 13/972,881, incorporated by reference above. In many embodiments, these potential inefficiencies are disregarded and no additional action is taken with respect to the identified (320) areas of low confidence. In several embodiments, potential inefficiencies are disregarded by simply encoding the pixels from the alternate view images rather than computing the prediction error. In a number of embodiments, if an area of low confidence (e.g. correspondence mismatch) is identified (320), one or more additional reference images are selected and supplemental prediction images (or portions of supplemental prediction image(s)) are computed (322) from the additional reference images. In several embodiments, additional reference images or portions of additional reference images are utilized when detected objects in the array of images for areas where the determined (316) prediction error data would be large using a single reference image; for example, in an occlusion zone). A large prediction error rate can be predicted when objects in a captured light field are close to the imager array, although any situation where a large prediction error rate is (316) determined can be the basis for selecting additional reference images in accordance with embodiments of the invention.
Turning now to
In several embodiments, the alternate view images that are utilized in performing (314) parallax detection are clustered around the respective reference image that is utilized in performing (314) parallax detection. In a variety of embodiments, the images are clustered in a way to reduce the disparity and/or improve pixel correspondence between the clustered images, thereby reducing the number of pixels from the alternate view images that are occluded from the viewpoints of both the reference image and the secondary reference image. In many embodiments, the alternate view images are clustered to the primary reference image 460, the secondary reference image 466, and/or together based on the color associated with the images. For example, if reference image 460 and secondary reference image 466 are green, only the green alternate view images 462 are associated with the reference image 460 and/or the secondary reference image 466. Likewise, the red alternate view images 461 (or the blue alternate view images 463) are associated with each other for the purposes of computing (322) supplemental prediction images and/or performing (314) parallax detection.
In many embodiments, particularly those embodiments employing lossless compression techniques, the secondary reference image 466 is predicted using the reference image 460 and the baseline 468 that describes the distance between the optical centers of the reference image and the secondary reference image. In several embodiments, the secondary reference image 466 is selected to reduce the size of the occlusion zones (and thus predictability of pixels); that is, parallax detection is performed and error data is determined as described above using the secondary reference image 466. In many embodiments, the secondary reference image 466 is associated with the same color channel as the reference image 460. A specific example of a two-dimensional array of images with two reference images that can be utilized to compute (322) supplemental prediction images is conceptually illustrated in
In a variety of embodiments, particularly those utilizing lossy compression techniques, a variety of coding techniques can be utilized to account for the effects of lossy compression in the reference images when predicting an alternate view image. In several embodiments, before the prediction image and prediction error data for the alternate view image are formed, the reference image is compressed using a lossy compression algorithm. The compressed reference image is then decompressed to form a lossy reference image. The lossy reference image represents the reference image that the decoder will have in the initial stages of decoding. The lossy reference image is used along with the depth map to form a lossy predicted image for the alternate view image. The prediction error data for the alternate view image is then calculated by comparing the lossy reference image with the alternate view image (e.g. by taking the signed difference of the two images). In this way, when using lossy compression, the prediction error data will take into account the lossy nature of the encoding of the reference image when forming the prediction error data.
In a variety of embodiments, the alternative reference images are based on the reference image. In several embodiments, the reference image used to predict the viewpoint of the alternate reference image undergoes a lossy compression. A lossy compression is applied to the prediction error data for the alternate reference image. The reference image is then decompressed to generate a lossy reference image. A lossy predicted image is generated from the decompressed reference image for the alternate reference image. The compressed prediction error data is decompressed to form the lossy prediction error data. The lossy prediction error data is added to the lossy predicted image to form the lossy predicted alternate reference image. The prediction image and prediction error data for any subsequent alternate view image that depends on the alternate reference image will be formed using the lossy predicted alternate reference image. In a number of embodiments, this forms the alternate view image that can be reconstructed utilizing lossy reconstruction techniques as described below. This process can be repeated for each alternate view image as necessary. In this way, prediction error data can be accurately computed (relative to the uncompressed light field data) using the lossy compressed image data.
Returning now to
In a variety of embodiments, supplemental depth information is incorporated into the depth map and/or as metadata associated with the compressed light field representation data. In a number of embodiments, supplemental depth information is encoded with the additional reference viewpoint(s). In many embodiments, the depth information used for each reference viewpoint is calculated using any sets of cameras during the encoding process that may be similar or may be different depending on the viewpoint. In many embodiments, depth for an alternate reference viewpoint is calculated for only sub-regions of the alternate reference viewpoint so that an entire depth map does not need to be encoded for each viewpoint. In many embodiments, a depth map for the alternate reference viewpoint is formed by propagating pixels from the depth map from a primary reference viewpoint. If there are holes in the depth map propagated to the alternate reference viewpoint they can be filled by interpolating from nearby propagated pixels in the depth map, or through direct detection from the alternate viewpoint. In many embodiments, the depth map from the alternate reference viewpoint can be formed by a combination of propagating depth values from another reference viewpoint, interpolating for missing depth values in the alternate reference viewpoint, or directly detecting regions of particular depth values in the alternative reference viewpoint. In this way, the depth map created by performing (314) parallax detection above can be augmented with depth information generated from alternate reference images.
A specific process for generating compressed light field representation data in accordance with an embodiment of the invention is described above with respect to
As described above, compressed light field representation data can be utilized to efficiently store captured light fields. However, in order to utilize the compressed light field representation data to perform additional processed on the captured light field (such as parallax processes), the compressed light field representation data need be decoded to retrieve the original (or an approximation of the) captured light field. A process for decoding compressed light field representation data is conceptually illustrated in
In a variety of embodiments, decompressing (611) the captured light field representation data includes decompressing the reference image, depth map, and/or prediction error data compressed utilizing techniques described above. In several embodiments, the reference image (612) corresponds to a viewpoint (e.g. a focal plane in an imager array) image in the compressed light field representation data; however, it should be noted that reference images from virtual viewpoints (e.g. viewpoints that do not correspond to a focal plane in the imager array) can also be utilized as appropriate to the requirements of specific embodiments of the invention. In a number of embodiments, the alternate view images are formed (614) by computing prediction images using the determined (612) reference image and the depth map, then applying the prediction error data to the computed prediction images. However, any technique for forming (614) the alternate view images, including directly forming the alternate view images using the determined (612) reference image and the prediction error data, can be utilized as appropriate to the requirements of specific embodiments of the invention. Additionally, metadata describing the interpolation techniques utilized in the creation of the compressed light field representation data can be utilized in computing the prediction images. In this way, the decoding process results in prediction images that, once the prediction error data is applied to the prediction images, correct (or an approximation to correct) alternate view images are formed (614). This allows for multiple interpolation techniques to be utilized in the encoding of compressed light field representation data, e.g. adaptive interpolation techniques can be utilized based on the requirements of specific embodiments of the invention. The captured light field is reconstructed (620) using the alternative view images and the reference image. In many embodiments, the captured light field also includes the depth map, the prediction error data, and/or any other metadata included in the compressed light field representation data.
In a variety of embodiments, multiple reference images (e.g. a primary reference image and one or more secondary reference images) exist within the compressed light field representation data. The alternate reference images can be directly included in the compressed light field representation data and/or formed utilizing techniques similar to those described above. Using (618) an alternative reference image further includes recursively (and/or iteratively) forming alternate view images from the viewpoint of each reference image utilizing techniques described above. In this way, the alternative view images are mapped back to the viewpoint of the (primary) reference image and allowing the captured light field to be reconstructed (620).
In those embodiments utilizing lossy compression techniques, information critical to determining (612) the reference image and/or an alternative reference image can be lost. However, this loss can be compensated for by storing the lost information as metadata within the compressed light field representation data and/or as part of the prediction error data. Then, when determining (612) the reference image and/or the alternate reference image, the metadata and/or prediction error data can be applied to the compressed image in order to reconstruct the original, uncompressed image. Using the uncompressed reference image, the decoding of the compressed captured light field representation data can proceed utilizing techniques similar to those described above to reconstruct (320) the captured light field. In a variety of embodiments, predicting the alternative reference image from the reference image, if lossy compression is used, includes reconstructing the alternate reference image by coding and decoding (losslessly) the prediction error data then adding the decoded prediction error to the reference image. In this way, the original alternate reference image can be reconstructed and used to predict specific alternate views as described above.
A specific process for decoding compressed light field representation data in accordance with an embodiment of the invention is described above with respect to
Although the present invention has been described in certain specific aspects, many additional modifications and variations would be apparent to those skilled in the art. It is therefore to be understood that the present invention can be practiced otherwise than specifically described without departing from the scope and spirit of the present invention. Thus, embodiments of the present invention should be considered in all respects as illustrative and not restrictive. Accordingly, the scope of the invention should be determined not by the embodiments illustrated, but by the appended claims and their equivalents.
Claims
1. An array camera, comprising:
- a processor; and
- a memory connected to the processor and configured to store an image processing application;
- wherein the image processing application configures the processor to: obtain image data, wherein: the image data comprises a set of images comprising a reference image and at least one alternate view image; and each image in the set of images comprises a set of pixels; generate a depth map based on the image data, where the depth map describes the distance from the viewpoint of the reference image with respect to objects imaged by pixels within the reference image; determine at least one prediction image based on the reference image and the depth map, where the prediction images correspond to at least one alternate view image; compute prediction error data based on the at least one prediction image and the at least one alternate view image, where a portion of prediction error data describes the difference in photometric information between a pixel in a prediction image and a pixel in at least one alternate view image corresponding to the prediction image; and generate compressed light field representation data based on the reference image, the prediction error data, and the depth map.
Type: Application
Filed: Aug 31, 2016
Publication Date: Feb 23, 2017
Applicant: Pelican Imaging Corporation (Santa Clara, CA)
Inventors: Kartik Venkataraman (San Jose, CA), Dan Lelescu (Morgan Hill, CA), Gabriel Molina (Sunnyvale, CA)
Application Number: 15/253,605