The present invention relates to super resolution processing and more specifically to super resolution processes that determine pixel depth using multiple images of a scene captured from different viewpoints, where the captured images of the scene include aliasing.
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 that generate signals upon receiving light via the optical element. Commonly used image sensors include charge-coupled device image sensors (CCDs) and complementary metal-oxide semiconductor (CMOS) sensors.
Conventional digital cameras typically achieve color separation by performing color separation in the optical path and using a separate image sensor for the wavelengths of light corresponding to each of the primary colors (i.e. RGB), using an image sensor with color separation and multiple signal collection capability within each pixel, or by applying filters over a single sensor so that individual pixels detect wavelengths of light corresponding to one of the primary colors. Use of filters is particularly common in cameras that have a small form factor, such as cameras incorporated in mobile phone handsets and other consumer electronics devices including but not limited to, laptop computers and televisions. A common filter that is formed on image sensors is the Bayer filter, the pattern of which includes 50% green filters, 25% red filters, and 25% blue filters. The output of an image sensor to which a Bayer filter is applied can be reconstructed as a color image using interpolation techniques.
Image sensors are subject to various performance constraints including, among others, dynamic range, signal to noise (SNR) ratio and low light sensitivity. The dynamic range is defined as the ratio of the maximum possible signal that can be captured by a pixel to the total noise signal. The SNR of a captured image is, to a great extent, a measure of image quality. In general, as more light is captured by the pixel, the higher the SNR. The light sensitivity of an image sensor is typically determined by the intensity of light incident upon the sensor pixels. At low light levels, each pixel's light gathering capability is constrained by the low signal levels incident upon each pixel.
A challenge associated with increasing the number of pixels in an image sensor is that the lens system is dimensioned to span the image sensor. The problem is most acute with mobile cameras, such as those used in mobile phones and consumer electronics devices, where the form factor of the lens system can significantly impact the overall form factor of the mobile device.
In response to the constraints placed upon a traditional digital camera based upon the camera obscura, a new class of cameras that can be referred to as array cameras have been proposed. Array cameras are characterized in that they include multiple arrays of pixels, each having a separate lens system. Examples of 2, 3 and 4 array cameras in which each array of pixels captures light from a different band of the visible spectrum and the captured images are combined to create a full color image are disclosed in U.S. Pat. No. 7,199,348 to Olsen et al., the disclosure of which is incorporated by reference herein in its entirety. U.S. Pat. No. 7,262,799 to Suda, the disclosure of which is incorporated herein by reference in its entirety, discloses a 2×2 array camera including one sensor used to sense a red (R) image signal, one sensor used to sense a blue (B) image signal and, two sensors used to sense green (G) image signals.
Array cameras in accordance with embodiments of the invention perform super resolution processing using images of a scene that contain aliasing. In several embodiments, the depth of pixels is determined by fusing portions of a higher resolution image at a number of hypothesized depths and determining the depth at which the portion of the higher resolution image best matches the scene captured in the lower resolution images used to fuse the higher resolution image. One embodiment of the method of the invention includes fusing portions of the set of low resolution images to form a portion of a higher resolution image at each of a plurality of hypothesized depths, where the resolution of the portion of the higher resolution image is higher than the resolutions of the portions of the set of low resolution images used to fuse the portion of the higher resolution image, comparing the portion of the fused higher resolution image obtained at each hypothesized depth to the scene captured in the set of low resolution images, and selecting the hypothesized depth at which the portion of the fused higher resolution image is most similar to the scene captured in the set of low resolution images as the depth of at least one point in the scene captured by the set of low resolution images.
In a further embodiment of the method of the invention, comparing the portion of the fused higher resolution image to the scene captured in the set of low resolution images includes generating a set of forward mapped low resolution image portions by forward mapping the portion of the fused higher resolution image using a mapping based upon the characteristics of the cameras utilized to capture the set of low resolution images, and comparing the forward mapped low resolution image portions with corresponding portions of corresponding images in the set of low resolution images.
In another embodiment of the method of the invention, comparing the portion of the fused higher resolution image to the scene captured in the set of low resolution images includes determining the similarity of pixels in pixel stacks in the portion of the fused higher resolution image.
In a still further embodiment of the method of the invention, comparing the portion of the fused higher resolution image at a specific hypothesized depth to the scene captured in the set of low resolution images includes comparing the portion of the fused higher resolution image at the specific hypothesized depth to a portion of at least a second fused higher resolution image formed by fusing a second set of low resolution images at the specific hypothesized depth.
In still another embodiment of the method of the invention, at least one low resolution image is common to said set of low resolution images and said second set of low resolution images.
One embodiment of the invention includes a machine readable medium containing processor instructions, where execution of the instructions by a processor causes the processor to perform a process including: fusing portions of the set of low resolution images to form a portion of a higher resolution image at each of a plurality of hypothesized depths, where the resolution of the portion of the higher resolution image is higher than the resolutions of the portions of the set of low resolution images used to fuse the portion of the higher resolution image; comparing the portion of the fused higher resolution image obtained at each hypothesized depth to the scene captured in the set of low resolution images; and selecting the hypothesized depth at which the portion of the fused higher resolution image is most similar to the scene captured in the set of low resolution images as the depth of at least one point in the scene captured by the set of low resolution images.
A yet further embodiment of the method of the invention includes fusing portions of a first subset of a set of low resolution images to form a portion of a first higher resolution image at each of a plurality of hypothesized depths, where the resolution of the portion of the first higher resolution image is higher than the resolutions of the portions of the first subset of the set of low resolution images used to fuse the portion of the first higher resolution image, fusing portions of a second subset of the set of low resolution images to form a portion of a second higher resolution image at each of the plurality of hypothesized depths, where the resolution of the portion of the second higher resolution image is higher than the resolutions of the portions of the second subset of the set of low resolution images used to fuse the portion of the second higher resolution image, comparing at least the portions of the first and second higher resolution images fused at each of the plurality of hypothesized depths, and selecting the hypothesized depth at which the portions of the compared higher resolution images are most similar as the depth of at least one point in the scene imaged by pixels within portions of the first and second subsets of the set of low resolution images.
In yet another embodiment of the method of the invention, at least one low resolution image in the set of low resolution images is common to both the first and second subsets of the set of low resolution images.
In a further embodiment again of the method of the invention, the viewpoint of one of the low resolution images in the set of low resolution images is selected as the reference viewpoint used to fuse the portions of the first and second high resolution images at each of the plurality of hypothesized depths, and the low resolution image selected as the reference viewpoint is common to both the first and second subsets of the set of low resolution images.
In another embodiment again of the method of the invention, low resolution images captured from viewpoints above, below, to the left, and to the right of the reference viewpoint are common to both the first and second subsets of the set of low resolution images.
In a further additional embodiment of the method of the invention, the viewpoint of one of the low resolution images in the set of low resolution images is selected as the reference viewpoint used to fuse the portions of the first and second high resolution images at each of the plurality of hypothesized depths.
In another additional embodiment of the method of the invention, fusing portions of a subset of the set of low resolution images to form a portion of a higher resolution image at a hypothesized depth includes: identifying pixels within the subset of the set of low resolution images based upon the hypothesized depth and the viewpoints of the low resolution images; fusing the identified pixels onto a higher resolution grid generated from a chosen reference viewpoint using known calibration information; and performing hole filing to fill holes in locations in the higher resolution grid.
In a still yet further embodiment of the method of the invention, comparing at least the portions of the first and second higher resolution images fused at each of the plurality of hypothesized depths comprises comparing the portions of the first and second higher resolution images for matching error at each of the plurality of hypothesized depths.
In still yet another embodiment of the method of the invention, matching error is determined using at least one selected from the group of the L1-norm and the L2-norm of the difference of the portions of the first and second higher resolution image.
A still further embodiment again of the method of the invention also includes fusing portions of a third subset of the set of low resolution images to form a portion of a third higher resolution image at each of a plurality of hypothesized depths, where the resolution of the portion of the third higher resolution image is higher than the resolutions of the portions of the third subset of the set of low resolution images used to fuse the portion of the first higher resolution image. In addition, comparing at least the portions of the first and second higher resolution images fused at each of the plurality of hypothesized depths further comprises comparing the portions of the first, second, and third higher resolution images fused at each of the plurality of hypothesized depths.
Another embodiment includes an array camera module, including: an imager array, including a plurality of focal planes, where each focal plane comprises a two dimensional arrangement of pixels having at least two pixels in each dimension and each focal plane is contained within a region of the imager array that does not contain pixels from another focal plane, control circuitry configured to control the capture of image information by the pixels within the focal planes, and sampling circuitry configured to convert pixel outputs into digital pixel data, interface circuitry configured to transmit digital pixel data; and an optic array of lens stacks, where an image including aliasing is formed on each focal plane by a separate lens stack in the optic array of lens stacks. In addition, the array camera also includes a processor configured to receive digital pixel data from the array camera module via the interface circuitry, and memory containing an image processing pipeline application and a controller application. Furthermore, the processor is configured via the controller application to read digital pixel data from the imager array, and the image processing pipeline application configures the processor to: obtain a set of low resolution images of a scene that include aliasing by reading digital pixel data from the imager array; and synthesize a higher resolution image of the scene from a reference viewpoint using the set of low resolution images.
In a further embodiment the image processing pipeline application configures the processor to determine a depth of at least one pixel in the synthesized higher resolution image by: fusing portions of the set of low resolution images to form a portion of a higher resolution image at each of a plurality of hypothesized depths, where the resolution of the portion of the higher resolution image is higher than the resolutions of the portions of the set of low resolution images used to fuse the portion of the higher resolution image; comparing the portion of the fused higher resolution image obtained at each hypothesized depth to the scene captured in the set of low resolution images; and selecting the hypothesized depth at which the portion of the fused higher resolution image is most similar to the scene captured in the set of low resolution images as the depth of at least one point in the scene captured by the set of low resolution images.
In a still yet further embodiment, the image processing pipeline application configures the processor to compare the portion of the fused higher resolution image to the scene captured in the set of low resolution images by: generating a set of forward mapped low resolution image portions by forward mapping the portion of the fused higher resolution image using a mapping based upon the characteristics of the array camera module; and comparing the forward mapped low resolution image portions with corresponding portions of corresponding images in the set of low resolution images.
In still another embodiment, the image processing pipeline application configures the processor to compare the portion of the fused higher resolution image to the scene captured in the set of low resolution images by determining the similarity of pixels in pixel stacks in the portion of the fused higher resolution image.
In a yet further embodiment, the image processing pipeline application configures the processor to determine a depth of at least one pixel in the synthesized higher resolution image by: comparing portions of fused higher resolution images formed by fusing at least two subsets of the set of low resolution images at a plurality of hypothesized depths; and selecting the depth of at least one pixel in the synthesized higher resolution image based upon the hypothesized depth at which the compared portions of fused higher resolution images are most similar.
In yet another embodiment, at least one low resolution image in the set of low resolution images is common to the at least two subsets of the set of low resolution images.
In a further embodiment again, the at least two subsets of the set of low resolution images include a common low resolution image having a viewpoint that is the reference viewpoint.
In another embodiment again, the at least two subsets of the set of low resolution images include common low resolution images captured from viewpoints above, below, to the left, and to the right of the reference viewpoint.
In a further additional embodiment, the reference viewpoint is the viewpoint of one of the low resolution images in the set of low resolution images.
In another additional embodiment, the image processing pipeline application configures the processor to fuse at least two subsets of the set of low resolution images at a hypothesized depth by: identifying pixels within the subset of the set of low resolution images based upon the hypothesized depth and the viewpoints of the low resolution images; fusing the identified pixels onto a higher resolution grid generated from a chosen reference viewpoint using known calibration information; and performing hole filing to fill holes in locations in the higher resolution grid.
In a still yet further embodiment, the image processing pipeline application configures the processor to compare portions of fused higher resolution images by comparing matching error of the portions of the fused higher resolution images.
In still yet another embodiment, matching error is determined using at least one selected from the group of the L1-norm and the L2-norm of the difference of the portions of the first and second higher resolution image.
In a still further embodiment again, the pixels in the plurality of focal planes in the imager array comprise a pixel stack including a microlens and an active area, where light incident on the surface of the microlens is focused onto the active area by the microlens and the active area samples the incident light to capture image information, and the pixel stack defines a pixel area and includes a pixel aperture, where the size of the pixel apertures is smaller than the pixel area.
In still another embodiment again, the pixel aperture is formed by a microlens that is smaller than the pixel area.
In a still further additional embodiment, gaps exist between adjacent microlenses in the pixel stacks of adjacent pixels in a focal plane.
In still another additional embodiment, light is prevented from entering the pixel stacks through the gaps between the microlenses by a light blocking material.
In a yet further embodiment again, the pixel stack includes a color filter.
In yet another embodiment again, the color filters in the pixel stacks of the two dimensional arrangement of pixels within a focal plane are the same.
In a yet further additional embodiment, the color filters in the pixel stacks of the two dimensional arrangement of pixels within at least one focal plane form a Bayer filter pattern.
In yet another additional embodiment, at least one of the plurality of lens stacks includes a color filter and the pixel stacks of the two dimensional arrangement of pixels within the focal plane on which said at least one of the plurality of lens stacks forms an image do not include color filters.
In a still yet further embodiment again, the pixel aperture is formed using at least one light blocking material.
In still yet another embodiment again, the optic array of lens stacks is constructed using wafer level optics.
In a still yet further additional embodiment, the plurality of lens stacks include polymer optical components.
In still yet another additional embodiment, the plurality of lens stacks include glass optical components.
Turning now to the drawings, systems and methods for controlling the amount of aliasing in images captured by an array camera and for synthesizing higher resolution images from the captured images using super resolution (SR) processing in accordance with embodiments of the invention are illustrated. Images exhibit aliasing when they are sampled at too low a sampling frequency, resulting in visible steps on diagonal lines or edges (also referred to as “jaggies”) and artificial low frequency patterns (often referred to as Moiré). These artifacts are a product of the incorrect sampling of higher frequencies, which results in the higher frequencies folding back (being aliased) into lower frequencies. Aliasing is generally undesirable, however, array cameras in accordance with embodiments of the invention can utilize the high frequency information folded into the lower frequencies during SR processing. In a SR process, low resolution (LR) images that include sampling diversity (i.e. represent sub-pixel offset shifted views of a scene) are used to synthesize one or more higher resolution (HR) images. Each LR image samples a slightly different part of the scene and the SR process utilizes the sampling diversity to synthesize a HR image by fusing the multiple low-resolution images together on a higher resolution grid. Various SR processes are discussed in detail in U.S. patent application Ser. No. 12/967,807, entitled “Systems and Methods for Synthesizing High Resolution Images Using Super-Resolution Processes”, to Lelescu et al., the disclosure of which is incorporated by reference herein in its entirety. Due to the fact that each LR image includes a sub-pixel shifted view of the scene, aliasing present in each of the LR images is slightly different. Therefore, the aliasing in each of the images provides useful information about high frequency image content that can be exploited by the SR process to increase the overall resolution of the synthesized image.
In a number of embodiments, increasing the amount of aliasing in the LR images captured by an array camera can increase the resolution achieved through SR processing. The amount of aliasing in the captured images can be controlled in any of a variety of ways including (but not limited to) using pixel apertures, reducing pixel pitch, and/or increasing the optical resolution of the optical channels used to form images on the pixels of a focal plane. Using pixel apertures to increase aliasing can improve the resolution increase achieved through SR processing without fundamentally changing the pixel size or design, or array configuration of an imager array in any way. Therefore, using pixel apertures to increase aliasing can be a very cost effective architectural enhancement. A pixel aperture can be created in any of a variety of different ways including by using a microlens that is smaller than the pixel pitch of a focal plane and/or by using light blocking materials.
Increasing aliasing in captured LR images can complicate parallax detection and correction when performing SR processing. Aliasing is a result of insufficient spatial sampling frequency in each camera, and can manifest itself differently in the images captured by the different cameras. In a number of embodiments, pixel correspondence in the presence of aliasing is determined using an approach that can be referred to as “hypothesized fusion”. Since aliasing effects are varied in the different images, at incorrect depths, a fused image is likely to be considerably different from the scene. At the correct depth, high resolution information obtained from the aliasing in the LR images increases the similarity between the synthesized HR image and the scene. Accordingly, hypothesized fusion processes in accordance with embodiments of the invention fuse HR images or portions of HR images using a set of LR images at a number of different hypothesized depths. The highest similarity between a fused HR image or HR image portion and a scene captured in a set of LR images is likely to be observed when correct depth hypotheses are utilized. The similarity between a fused HR image and a scene captured in a set of LR images can be determined in any of a variety of different ways. In several embodiments, similarity is determined by using a forward mapping to compare forward mappings of the fused HR image at a hypothesized depth to the captured LR images. In many embodiments, the similarity of pixels in pixel stacks of a portion of a fused HR image are used to indicate the likely similarity of the portion of the fused HR image to the scene captured by the LR images. In a number of embodiments, multiple fused HR images or HR image portions are generated using different subsets of the captured LR images at different hypothesized depths and the multiple fused HR images or HR image portions are compared to determine the hypothesized depth at which the fused HR images or HR image portions are best matched. In several embodiments, the sets of focal planes used to fuse the HR images utilized during hypothesized fusion include focal planes that are common to two or more of the sets. In a number of embodiments, the viewpoint of one of the focal planes is used as the reference viewpoint for synthesizing an HR image and the reference focal plane is common to the sets of focal planes used during hypothesized fusion. In other embodiments, disjoint sets of focal planes are utilized.
By analyzing the similarity of a fused HR image or image portion to the scene captured in a set of LR images at different hypothesized depths, depth information can be obtained that can be used to perform parallax correction and complete the SR processing of the LR images. Although much of the discussion that follows refers to determining depths based upon portions of fused HR images, it should be appreciated that analysis using fused HR images is computationally efficient and that additional processing can be utilized to refine the fused HR images during analysis up to an including synthesizing HR images. Accordingly, references to fused HR images in the discussion of hypothesized fusion should be understood as encompassing images obtained by simply performing raw fusion, which places captured image samples onto a higher resolution grid (possibly resulting in overlaps and missing sample positions), and encompassing images obtained by performing additional processing beyond the raw fusion. The distinctions between obtaining an HR image through raw fusion and synthesizing an HR image using super resolution processing are explored more completely in U.S. patent application Ser. No. 12/967,807 incorporated by reference above.
Array cameras that control the amount of aliasing introduced into captured low resolution images using a variety of techniques including (but not limited) to using pixel apertures and SR processes that utilize hypothesized fusion to determine pixel correspondence in the presence of aliasing in accordance with embodiments of the invention are discussed further below.
An array camera architecture that can be used in a variety of array camera configurations in accordance with embodiments of the invention is illustrated in
The array camera module 110 includes two or more cameras, each of which receives light using a separate optical channel. The array camera module can also include other circuitry to control imaging parameters and sensors to sense physical parameters. The control circuitry can control imaging parameters such as exposure times, gain, and black level offset. In several embodiments, the circuitry for controlling imaging parameters may trigger each camera independently or in a synchronized manner. The array camera module can include a variety of other sensors, including but not limited to, dark pixels to estimate dark current at the operating temperature. Array camera modules that can be utilized in array cameras in accordance with embodiments of the invention are disclosed 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., the disclosure of which is incorporated herein by reference in its entirety.
The image processing pipeline module 120 is hardware, firmware, software, or a combination for processing the images received from the array camera module 110. In many embodiments, the image processing pipeline module 120 is implemented using an image processing pipeline application that is stored in memory and used to configure a microprocessor. The image processing pipeline module 120 processes the multiple LR images captured by the array camera module and produces a synthesized HR image. In a number of embodiments, the image processing pipeline module 120 provides the synthesized image data via an output 122.
The controller 130 is hardware, software, firmware, or a combination thereof for controlling various operational parameters of the imager array 110. In a number of embodiments, the controller 130 is implemented using a controller application stored in memory and used to configure a microprocessor. The controller 130 receives inputs 132 from a user or other external components and sends operation signals to control the array camera module 110. The controller 130 can also send information to the image processing pipeline module 120 to assist processing of the LR images captured by the array camera module 110.
Although a specific array camera architecture is illustrated in
U.S. patent application Ser. No. 12/935,504 (incorporated by reference above) discloses a variety of array camera modules that can be utilized in array cameras. An exploded view of an array camera module formed by combining an optic array of lens stacks with a monolithic sensor that includes a corresponding array of focal planes is illustrated in
An optic array of lens stacks may employ wafer level optics (WLO) technology. WLO is a technology that encompasses a number of processes, including, for example, molding of lens arrays on glass wafers, stacking of those wafers (including wafers having lenses replicated on either side of the substrate) with appropriate spacers, followed by packaging of the optics directly with the imager into a monolithic integrated module.
The WLO procedure may involve, among other procedures, using a diamond-turned mold to create each plastic lens element on a glass substrate. More specifically, the process chain in WLO generally includes producing a diamond turned lens master (both on an individual and array level), then producing a negative mould for replication of that master (also called a stamp or tool), and then finally forming a polymer replica on a glass substrate, which has been structured with appropriate supporting optical elements, such as, for example, apertures (transparent openings in light blocking material layers), and filters. Although the construction of optic arrays of lens stacks using specific WLO processes is discussed above, any of a variety of techniques can be used to construct optic arrays of lens stacks, for instance those involving precision glass molding, polymer injection molding or wafer level polymer monolithic lens processes. Any of a variety of well known techniques for designing lens stacks used in conventional cameras can be utilized to increase aliasing in captured images by improving optical resolution. Accordingly, the level of aliasing present in images captured by an array camera module in accordance with embodiments of the invention can be determined through selection of aspects of lens stacks including (but not limited to) adding lens surfaces, changing the F# of the lens stack, and selection of materials used in construction of lens stack. Imager arrays that can capture images formed by optic arrays of lens stacks in accordance with embodiments of the invention are discussed further below.
Imager arrays can be implemented using any of a variety of configurations in which an array of focal planes is formed on one or more sensors. A variety of imager array architectures are disclosed in U.S. patent application Ser. No. 13/106,797, entitled “Architectures for Imager Arrays and Array Cameras” to Pain et al., the disclosure of which is incorporated by reference herein in its entirety. An imager array including multiple focal planes having independent read-out control and pixel digitization, where each focal plane has dedicated peripheral circuitry, in accordance with embodiments of the invention is illustrated in
In a device including M×N focal planes, the read-out control logic includes M sets of column control outputs per row of focal planes (N). Each column sampling/read-out circuit 308 can also have dedicated sampling circuitry for converting the captured image information into digital pixel data. In many embodiments, the sampling circuitry includes an Analog Signal Processor (ASP), which includes an Analog Front End (AFE) amplifier circuit and an Analog to Digital Converter (ADC) 310. In other embodiments, any of a variety of analog circuitry can be utilized to convert captured image information into digitized pixel information. An ASP can be implemented in a number of ways, including but not limited to, as a single ASP operating at X pixel conversion per row period, where X is the number of pixels in a row of the focal plane served by the column sampling circuit (e.g. with a pipe-lined or SAR ADC), as X ASPs operating in parallel at 1 pixel conversion per row period or P ASPs operating in parallel at X/P conversions per row (see discussion below). A common read-out control circuit 312 controls the read-out of the columns in each imager.
In the illustrated embodiment, the master control logic circuitry 314 controls independent read-out of each imager. The master control logic circuitry 314 includes high-level timing control logic circuitry to control the image capture and read-out process of the individual focal plane. In a number of embodiments, the master control portion of this block can implement features including but not limited to: staggering the start points of image read-out such that each focal plane has a controlled temporal offset with respect to a global reference; controlling integration times of the pixels within specific focal planes to provide integration times specific to the spectral bandwidths being imaged; the horizontal and vertical read-out direction of each imager; the horizontal and vertical sub-sampling/binning/windowing of the pixels within each focal plane; the frame/row/pixel rate of each focal plane; and the power-down state control of each focal plane.
The master control logic circuitry 314 can also handle collection of pixel data from each of the imagers. In a number of embodiments, the master control logic circuitry packs the image data into a structured output format. Given that fewer than M×N output ports are typically used to output the image data (e.g. there are 2 output ports), the image data is time multiplexed onto these output ports. In a number of embodiments, a small amount of memory (FIFO) is used to buffer the data from the pixels of the imagers until the next available time-slot on the output port 316 and the master control logic circuitry 314 or other circuitry in the imager array periodically inserts codes into the data stream providing information including, but not limited to, information identifying a focal plane, information identifying a row and/or column within a focal plane, and/or information identifying the relative time at which the capture or read-out process began/ended for one or more of the focal planes. Relative time information can be derived from an on-chip timer or counter, whose instantaneous value can be captured at the start/end of read-out of the pixels from each imager either at a frame rate or a line rate. Additional codes can also be added to the data output so as to indicate operating parameters such as (but not limited to) the integration time of each focal plane, and channel gain. As is discussed further below, the host controller can fully re-assemble the data stream back into the individual images captured by each focal plane. In several embodiments, the imager array includes sufficient storage to buffer at least a complete row of image data from all focal planes so as to support reordering and or retiming of the image data from all focal planes such that the data is always packaged with the same timing/ordering arrangement regardless of operating parameters such as (but not limited to) integration time and relative read-out positions. In a number of embodiments, the imager array includes sufficient storage to buffer at least a complete line of image data from all focal planes so as to support reordering and or retiming of the image data from all focal planes such that the data is packaged in a convenient manner to ease the host's reconstruction of the image data, for example retiming/reordering the image data to align the data from all focal planes to a uniform row start position for all focal planes irrespective of relative read-out position.
Although specific imager array implementations are discussed above with reference to
Introducing Aliasing into Images Captured by an Array Camera
From sampling theory it is known that the Nyquist frequency of the image sensor is simply one half the reciprocal of the pixel pitch. Frequencies above the Nyquist frequency cannot be sampled correctly by the image sensor and result in aliasing. Sampling theorem indicates that a judicious choice of pixel pitch (i.e. sampling rate) when sampling a bandlimited function can completely avoid aliasing, but it cannot avoid aliasing when sampling inherently non-bandlimited functions. Therefore, increasing the pixel pitch of an imager can increase the aliasing in images captured by the imager. As is discussed further below, aliasing can also be introduced into a captured image without increasing pixel pitch.
In many embodiments, the optical channel of each camera in the array camera is designed so that a predetermined amount of aliasing is present in the image resolved on the focal plane of the camera by the optical channel. As noted above, the extent to which the aliasing in the resolved image is captured by the pixels of the focal plane depends on a number of factors including the pixel pitch. In a number of embodiments, the pixels in the focal plane include pixel apertures that reduce pixel blur thereby increasing the extent to which aliasing is present in the captured image. In several embodiments, pixel apertures are created using microlenses. In many embodiments, pixel apertures are created using light blocking materials. Various techniques for increasing the aliasing present in captured images through the use of pixel apertures in accordance with embodiments of the invention are discussed further below.
In several embodiments, the aliasing present in images captured by an imager array is increased using microlenses that act as pixel apertures to reduce pixel blur. The manner in which microlenses can be used to increase aliasing can be appreciated with reference to
The main task of a microlens 402 is to gather the light incident on its surface and focus that light onto the small active area 414. The top oxide layer 404 separates the microlens layer from the color filter layer 406 and provides a suitable surface for effective microlens formation. The nitride passivation layer 408 and bottom oxide layer 410 provide support and isolation for the metal interconnects that are used to connect the various parts of the sensor. The active area 414 represents a small part of the pixel stack and is responsible for sampling the light incident on it. The pixel aperture (416) is determined by the spread of the microlens, which collects the light and focuses it on the active area 414. Due to the fact that the microlens spans the pixel area, the microlens 402 can be referred to as a gapless microlens.
The blur of the light field incident on a microlens array can be reduced by reducing the spread of the microlenses used in the pixel stacks of the focal plane. Thus, altering the microlenses in this fashion can be used to control the degree of aliasing present in captured images. The microlens acts like a low pass filter on the portion of the image resolved onto the pixel area by a lens stack.
A microlens that results in increased aliasing in a captured image relative to the image that would be captured using the gapless microlens 402 illustrated in
An advantage of decreased pixel aperture can be increasing the amount of aliasing present in captured images and, therefore, the increase in resolution that can be recovered through SR processing. Decreasing pixel apertures can come at the expense of decreased sensitivity. Although specific pixel stacks are described above, any of a variety of pixel stacks having pixel apertures that are smaller than the pitch of the pixels within a focal plane can be utilized as appropriate to the requirements of specific application in accordance with embodiments of the invention. As is discussed further below, decreasing the size of the pixel apertures within a focal plane can increase aliasing, which can be utilized during SR processing to recover information concerning high frequency components of the image.
Reducing the size of microlenses within the pixel stacks of the pixels in a focal plane can increase aliasing in images captured by the focal plane. However, reducing the size of the microlenses can also impact pixel sensitivity and crosstalk in the sensor. Any reduction in the size of the microlens relative to pixel pitch directly reduces the amount of light that is gathered (i.e. the sensitivity of the pixel). In many embodiments, each sensor in the focal plane is sensitive to only one color (e.g.: red, green, or blue). Therefore, the color filters on the pixel stack are all the same color. The absence of the ubiquitous Bayer filter implies that the pixels in a focal plane are not subject to inter-color crosstalk. This allows the use of color filters that are thinner than those in sensors with the Bayer filter, leading to correspondingly higher transmissivities. Therefore, the imagers in an array camera can have increased sensitivity compared to the sensors of a conventional camera outfitted with a Bayer color filter, which can offset the reduction in sensitivity associated with the pincushion microlens (i.e. a microlens that is smaller than the pixel pitch). In many embodiments, however, at least one focal plane in an imager array utilizes a Bayer color filter and the pixel stacks within the focal plane are configured accordingly.
When light entering the microlens/filter of one pixel stack is directed toward a neighboring pixel, the light that is passed from one pixel stack to another is referred to as crosstalk or more specifically as optical crosstalk. Finite difference time domain simulations have shown that the amount of crosstalk in a pixel stack is directly proportional to the height of the pixel stack. Removing or reducing the thickness of the color filter in the pixel stack reduces the overall height of the pixel stack and reduces optical crosstalk. In many embodiments rearranging the color filters from the pixel stack to the optic array of lens stacks can mitigate any increase in crosstalk associated with use of a microlens in the pixel stack.
When gaps are introduced between microlenses in a focal plane, the possibility exists that stray light can enter the pixel stack through the gaps and fall on the active area of the pixel stack, increasing the crosstalk and diminishing signal to noise ratio. In several embodiments, a light blocking material such as (but not limited to) a photoresist can be utilized to fill the gaps between the microlenses to reduce the likelihood that stray light will enter the pixel stack.
Although specific techniques are discussed above for increasing aliasing in the LR images through use of pixel apertures, other techniques including but not limited to techniques that utilize light blocking materials to create pixel apertures can also be utilized. Processes that can be used to recover higher resolution content from aliasing in LR images in accordance with embodiments of the invention are discussed below.
The processing of LR images to obtain an SR image in accordance with embodiments of the invention typically occurs in an array camera's image processing pipeline. In many embodiments, the image processing pipeline performs processes that register the LR images prior to performing SR processes on the LR images. In several embodiments, the image processing pipeline also performs processes that eliminate problem pixels and compensate for parallax.
An image processing pipeline incorporating a SR module for fusing information from LR images to obtain one or more synthesized HR images in accordance with an embodiment of the invention is illustrated in
Prior to performing SR processing, the image processing pipeline detects parallax that becomes more apparent as objects in the scene captured by the imager array approach the imager array. In the illustrated embodiment, parallax (or disparity) detection is performed using the parallax detection module 508. In several embodiments, the parallax detection module 508 generates an occlusion map for the occlusion zones around foreground objects. In many embodiments, the occlusion maps are binary maps created for pairs of LR images. In many embodiments, occlusion maps are generated to illustrate whether a point in the scene is visible in the field of view of a reference imager and/or whether points in the scene visible within the field of view of the reference imager are visible in the field of view of other imagers. In order to determine parallax, the parallax detection module 508 performs scene independent geometric corrections to the photometrically normalized LR images using geometric calibration data 506 obtained via an address conversion module 502. The parallax detection module can then compare the geometrically and photometrically corrected LR images to detect the presence of scene dependent geometric displacements between LR images. Information concerning these scene dependent geometric displacements can be referred to as parallax information and can be provided to the super resolution module 514 in the form of scene dependent parallax corrections and occlusion maps. Processes for performing parallax detection are discussed in U.S. Provisional Patent Application Ser. No. 61/691,666 entitled “Systems and Methods for Parallax Detection and Correction in Images Captured Using Array Cameras” to Venkataraman et al., the disclosure of which is incorporated by reference herein in its entirety. Designing a camera module to increase aliasing in captured LR images can complicate the process of determining the scene dependent parallax corrections. Processes that can be utilized to determine appropriate scene dependent parallax corrections in the presence of aliasing are discussed further below.
Geometric calibration (or scene-independent geometric correction) data 506 can be generated using an off line calibration process or a subsequent recalibration process. The scene-independent correction information, along with the scene-dependent geometric correction information (parallax) and occlusion maps, form the geometric correction information for the LR images. Once the parallax information has been generated, the parallax information and the photometrically normalized LR images can be provided to a super resolution module 314 for use in the synthesis of one or more HR images 316.
In many embodiments, the super resolution module 314 performs scene independent and scene dependent geometric corrections (i.e. geometric corrections) using the parallax information and geometric calibration data 306 obtained via the address conversion module 302. The photometrically normalized and geometrically registered LR images are then utilized in the synthesis of a HR image. The synthesized HR image 516 may then be fed to a downstream color processing module 564, which can be implemented using any standard color processing module configured to perform color correction and/or chroma level adjustment. In several embodiments, the color processing module performs operations including but not limited to one or more of white balance, color correction, gamma correction, and RGB to YUV correction.
In a number of embodiments, image processing pipelines in accordance with embodiments of the invention include a dynamic refocus module. The dynamic refocus module enables the user to specify a focal plane within a scene for use when synthesizing a HR image. In several embodiments, the dynamic refocus module builds an estimated HR depth map for the scene. The dynamic refocus module can use the HR depth map to blur the synthesized image to make portions of the scene that do not lie on the focal plane appear out of focus. In many embodiments, the SR processing is limited to pixels lying on the focal plane and within a specified Z-range around the focal plane.
In several embodiments, the synthesized high resolution image 516 is encoded using any of a variety of standards based or proprietary encoding processes including but not limited to encoding the image in accordance with the JPEG standard developed by the Joint Photographic Experts Group. The encoded image can then be stored in accordance with a file format appropriate to the encoding technique used including but not limited to the JPEG Interchange Format (JIF), the JPEG File Interchange Format (JFIF), or the Exchangeable image file format (Exif).
Processing pipelines similar to the processing pipeline illustrated in
In a SR process, the images that are captured by the cameras that have fields of view that are at a sub-pixel offset relative to each other are used to synthesize a higher resolution image. When aliasing is introduced, the sub-pixel offsets in the fields of view of each of the cameras means that the aliasing is slightly different in each captured LR image. Therefore, the aliasing in each of the LR images provides useful information about high frequency image content that is exploited by the SR process to increase the overall resolution of the synthesized HR image. However, increasing the aliasing in the LR images can complicate parallax detection and correction.
As is discussed in U.S. Provisional Patent Application Ser. No. 61/691,666, disparity between captured LR images can be determined by searching, in some robust manner, for similar pixels in pairs of images. However, such searches can be quickly confused in flat regions and in regions with repeating patterns or textures, as the pixel (or groups of pixels) under consideration in one camera can have multiple matches in another. Such spurious matches can be disambiguated to some extent by the use of scene information (prior) and/or pyramidal search techniques. However, such techniques typically fail in the presence of aliasing effects. Aliasing is a result of insufficient spatial sampling frequency in each camera, and can manifest itself differently in the images captured by the different cameras. As a result, pixel or patch matching (i.e. matching portions of images) using pyramidal techniques can also fail. Image processing pipelines and parallax detection processes in accordance with embodiments of the invention utilize the differences in high frequency information in each of the captured LR images, to establish pixel correspondence between the captured LR images in a way that accommodates the aliasing in each captured image. In a number of embodiments, pixel correspondence in the presence of aliasing is determined using an approach that can be referred to as “hypothesized fusion”. Hypothesized fusion in accordance with embodiments of the invention is discussed further below.
In many embodiments, hypothesized fusion processes are utilized to determine pixel correspondences in the presence of aliasing. Based upon the pixel correspondences, super resolution processes (such as those described in U.S. patent application Ser. No. 12/967,807) can be performed that extract higher frequency content from the aliased frequencies in the images. However, in the absence of sub-pixel registration information, this can be non-trivial. As mentioned earlier, in the presence of aliasing, it is difficult to recover the depth of each pixel to obtain pixel correspondences among the various images. To circumvent this problem, multiple HR images or HR image patches can be obtained by fusing some or all of the captured LR images at various hypothesized depths. Only at the correct depth, will the fused HR image (or part of it) represent an image of the captured scene. Therefore, the depth of a point in a scene can be determined by fusing portions of LR images that contain the point in the scene at different hypothesized depths and selecting the depth of the point in the scene as the hypothesized depth at which the fused HR image most closely matches the scene. As is discussed further below, an array camera typically does not possess a baseline or ground truth concerning the scene. Therefore, the extent to which the fused HR image corresponds to the scene can be determined in any of a variety of ways. In several embodiments, the fused HR image is forward mapped using a process similar to that utilized using SR processing and the resulting LR forward mapped images compared to the captured LR images. In many embodiments, the variance in pixel stacks in the fused HR image is used to indicate the similarity of the fused HR image to the scene. In a number of embodiments, multiple subsets of the captured LR images are fused to create multiple fused HR images or HR image portions and the multiple fused HR images or HR image portions are compared. In other embodiments, any of variety of techniques can be used to evaluate the similarity of one or more fused HR images or fused HR image portions to the scene captured in the LR images.
A process for performing hypothesized fusion in accordance with an embodiment of the invention is illustrated in
An alternative to performing forward mapping of a fused or super-resolved HR image at different hypothesized depths to determine the extent to which the fused or super-resolved HR image corresponds with the scene captured by a set of LR images is to instead look at the characteristics of the pixels that are fused to create a portion of the HR image. In many embodiments, the number of captured LR images is sufficiently large so as to result in pixel stacks in the fused HR image. At the correct depth, the same or very similar pixels should be fused onto the same pixel locations in the higher resolution grid. Therefore, the similarity of the pixels in pixel stacks can be utilized as a measure of the similarity of a portion of a fused HR image to the scene captured in a set of LR images. In many embodiments, the extent to which a portion of a fused HR image at a specific hypothesized depth matches the scene captured in a set of LR images is determined based upon the variance of pixels within pixels stacks in the portion of the fused HR image.
A process for determining the depth of a point in a scene captured by a set of LR images by fusing portions of HR images at different hypothesized depths and selecting a depth based upon the variance in the pixel stacks of the fused HR image portions at each hypothesized depth in accordance with an embodiment of the invention is illustrated in
Although a specific processes are illustrated in
When performing hypothesized fusion, determining the “correctness” of the fused image would be greatly assisted by knowledge of the scene content or a ground truth aliasing-free image as reference. In the absence of either, array cameras in accordance with many embodiments of the invention partition the focal planes in the imager array into at least two sets, and form a separate fused HR image using the LR images captured by each set of focal planes. Since aliasing effects are varied in the different images, at incorrect depths, the fused HR images are likely to be considerably different. At the correct depth, high resolution information obtained from the aliasing in the LR images increases the similarity between a synthesized HR image and the scene. Accordingly, two or more HR images fused using correct depths will have a significantly higher level of similarity relative to sets of HR images fused using incorrect depth assumptions. By comparing HR images formed at various depths from the LR images captured by each set of focal planes, their mutual similarities form a good measure of “correctness” of the fused images, thus providing a depth estimate for the aliased regions.
A process for performing hypothesized fusion involving the generation of two fused images in accordance with embodiments of the invention is illustrated in
Although specific processes for determining the most likely hypothesized depth of a pixel in a HR image are discussed above with reference to
In an array camera module, cameras can be partitioned into two or more groups of cameras (irrespective of the particular frequency range captured by the cameras). In a number of embodiments, cameras capturing information in a particular frequency range (color) can be partitioned into two or more groups of cameras for the purpose of performing hypothesized fusion. In many embodiments, the complexity of hypothesized fusion can be reduced by only considering the Green cameras. The spatial shift between cameras causes phase shifts in the aliased frequencies resulting in aliased regions in images that appear considerably different between captured LR images of a scene. As discussed earlier, the goal of selecting two or more sets of cameras is to exploit these dissimilarities to fuse similar images at the correct depth hypothesis for each pixel or region within a HR image. That is to say, when pixels from each of the sets of LR images are placed on a higher resolution grid, the reduction in aliasing effects enables the reconstruction of very similar images for each set (assuming the correct depth hypotheses are used). The difference between the fused images is typically primarily related to the errors in the depth hypotheses.
In many embodiments, each set of LR images is used to generate a HR image from the viewpoint of a common reference camera. Depending upon the specific imager array used to capture the LR images, the reference camera may be located at the center of the camera or in a location offset from the center of the camera. In many embodiments, the HR images can be synthesized from a virtual viewpoint. The manner in which the focal planes in an array camera module are partitioned typically depends upon the number of focal planes in the array camera module. In many embodiments, the hypothesized fusion process attempts to construct fused images that are as similar as possible. Since the fusion step attempts to achieve sub-pixel accuracy, errors in camera calibration can lead to differences between the HR images created by fusing the LR images captured by the sets of focal planes. In many embodiments, the partitioning is performed so that a number of focal planes are common to each set.
Hypothesized fusion can be performed by partitioning the focal planes in an array camera module into two disjoint sets. In a number of embodiments, the focal planes are partitioned into two sets that divide the focal planes in the camera array horizontally, vertically or in any of the diagonal directions. Forming two disjoint sets of cameras, however, is likely to result in a smaller number of focal planes in each set of focal planes (compared to forming overlapping sets of focal planes). With few cameras, a smaller level of magnification can be achieved without leaving large holes that need to be interpolated. Therefore, depending upon the number of focal planes in the imager array, partitioning the focal planes into disjoint sets can result in retaining much of the aliasing effects.
The location of the reference camera or viewpoint can also be an important consideration when partitioning the focal planes in an imager array. Since the fused images are formed using the reference camera as the viewpoint, it is useful to select the viewpoint of an actual camera (as opposed to a virtual viewpoint) as the reference the reference camera in both sets. Additionally, advantages can be obtained by selecting the sets of focal planes such that each set has considerable coverage on any given side (above, below, left and right) of the reference camera. Therefore, in many embodiments each set includes a focal plane above, below, to the left, and to the right of the reference camera. This increases the likelihood that the pixels placed on the higher resolution grid are similarly distributed in either set. At the same time, selecting the sets in this way can minimize errors associated with occlusion zones and increase the likelihood that whatever errors remain are present in each of the fused HR images.
The selection of cameras based on the above considerations, typically depends upon the number and grid configuration of the focal planes in an imager array (including the location of color filters within the array camera module), the scene being imaged, and the requirements of specific applications. In several embodiments, a determination is made dynamically concerning the manner in which to partition the focal planes based upon sensor information, and/or the captured LR images. In other embodiments, predetermined partitions are utilized.
The partitioning of focal planes in an array camera module in accordance with embodiments of the invention is illustrated in
Although the partitioned sets illustrated in
Fusion with Depth Hypothesis
Based upon the partitioning of focal planes, the LR images captured by the focal planes in each set can be fused onto a high resolution grid. The process of fusing the LR images onto the high resolution grid utilizes camera calibration data determined a priori. Placing pixels from a focal plane to a high resolution grid from the viewpoint of the reference camera involves accounting for the relative baselines of the focal planes, the focal length (can be assumed fixed) as well as the depth of the point whose projected pixel is being considered. Initially, the actual depth or distance of the point from the camera plane is unknown. To solve for depth, a list of possible depth hypotheses can be utilized. For each depth d in the list, pixels from each LR image in the appropriate set can be placed onto the higher resolution grid taking into account the magnification amount being considered. Since the focal planes within each set capture the same image from a slightly shifted viewpoint, the pixels may be sub-pixel shifted and, hence, may be placed at a slightly different location in the HR grid. The final fused image is then formed by some form of interpolation that produces a regularly sampled grid from the randomly sampled observations. Given enough samples arising out of a sufficient number of LR images in each set, simple interpolation schemes such as kernel regression can be employed.
Performing fusion using each set of LR images provides HR images or portions of HR images for each hypothesized depth. At incorrect depths, the pixel placements can be expected to be erroneous. As a result, images are obtained that are not really representative of the captured scenes. This is especially true of regions including higher levels of aliasing. As mentioned earlier, the measure of “correctness” is calculated by the similarity of the HR images produced by each of the sets of LR images. Where focal planes are common to both sets, the LR images captured by the common focal planes contribute equally to both the HR images at the correct as well as incorrect hypothesized depths. However, at incorrect depths, a sufficiently large number of distinct cameras with quite varied aliasing effects produce a lower match between image regions obtained from different sets of images. Since each of these cameras sample differently shifted images, the samples at any given incorrect depth hypothesis are inaccurately placed on the HR grid, increasing the differences between the fused HR images created using each set. At the correct depth hypothesis for any given region, when the samples can be expected to be placed correctly, both sets produce images that are sufficiently free of aliasing to achieve a threshold level of similarity. Employing a proper measure of similarity over the entire hypothesized depths, it is possible to estimate the actual depth of an aliased region in the captured LR images. Different locations in the image may produce best matches at different depth hypotheses. Choosing the best matches at each location allows the production of a depth estimate for each pixel, and, hence, a depth map for the entire image. In many embodiments, the computational complexity of performing hypothesized fusion can be reduced by only performing hypothesized fusion in regions where a threshold level of aliasing is present. In several embodiments, the computational complexity of performing hypothesized fusion can also be reduced by utilizing information concerning the depth of an adjacent region or pixel to commence the search for a correct depth. When a threshold level of similarity is achieved, a depth can be selected. In this way, the number of depth hypotheses tested by the process can be reduced in regions having similar depths. Processes for determining the similarity of regions of fused HR images when performing hypothesized fusion in accordance with embodiments of the invention are discussed further below.
Estimating the correct depth at any given location during hypothesized fusion relies on an ability to accurately measure the similarity between fused HR images. In a number of embodiments, image patches are used to determine local similarities. Comparisons of portions or patches of images provide robustness to the presence of noise, which can be expected to corrupt the captured LR images. Further, uses of small image portions can account for the local content surrounding a pixel under consideration when comparing fused HR images, thereby avoiding spurious matches. For each pixel (or a selection of pixels) in the HR grid where a pixel from the reference camera is positioned, a M×N patch can be formed with the pixel of interest at its center. This is done for images from each set. Where the focal planes are partitioned into two sets, these image portions p1,i and p2,i are then compared using a measure of their difference. In a number of embodiments, an L1 or an L2 norm is used to measure the difference although other measures appropriate to the requirements of a specific application can also be utilized. Note that this can be done for each portion in the HR image, and for each hypothesized depth. Mathematically, the cost C(i, d) is obtained using the following expression:
C(i,d)=∥p1,i−p2,i∥2 (2)
Once such a cost is computed for all hypothesized depths, the depth at each location of interest (e.g. each pixel from the reference camera) can be computed as
Although there exists many cost functions that may be utilized to compare two image portions or patches for similarity, the L2 norm provides a simple yet effective measure of similarity appropriate to many applications. Experimental evidence that illustrates the recovery of high frequency information from LR images in which aliasing is introduced using pixel apertures using hypothesized fusion processes, similar to the hypothesized fusion processes described above, is discussed below.
SR processes in accordance with embodiments of the invention can utilize aliasing within captured images of a scene to recover high frequency information. The increase in resolution of the resulting synthesized images can be appreciated by comparing images synthesized from images captured using imager arrays constructed to minimize aliasing and images synthesized from images captured using imager arrays constructed to introduce aliasing into the captured image (e.g. by using microlenses that create pixel apertures).
A simulation of the resolution improvement that can be obtained by introducing aliasing into captured images in accordance with embodiments of the invention is illustrated in
The size of the microlenses and therefore the implied sizes of the gaps between the microlenses is a tradeoff between increased aliasing and decreased sensitivity. Assuming square pixels and therefore square microlenses the area covered by the microlenses is proportional to the square of the pixel pitch. An additional consideration is the reduction of the pixel stack and therefore a concomitant reduction in the cross-talk between adjacent pixels. The removal of the color filter from the pixel stack has the potential of reducing the pixel stack height by 30%. In many embodiments, the consequent reduction in cross-talk through pixel stack height reduction results in increased sensitivity and can be traded-off for increased aliasing. Similar issues are faced by pixels including microlenses that are not square.
Although specific imager resolutions and pixel sizes are described above, as can readily be appreciated the imager resolution, the pixel sizes, and the apertures used to introduce aliasing into the captured images can be selected as appropriate to the requirements of a specific application in accordance with embodiments of the invention.
While the above description contains many specific embodiments of the invention, these should not be construed as limitations on the scope of the invention, but rather as an example of one embodiment thereof. Accordingly, the scope of the invention should be determined not by the embodiments illustrated, but by the appended claims and their equivalents.
This application claims priority to U.S. Provisional Application 61/536,500 filed Sep. 19, 2011, the disclosure of which is incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
61536500 | Sep 2011 | US |