The present invention relates in general to processing of digital color images and more particularly to a method and system of adaptively applying filters to obtain a high-quality estimate of a missing pixel color at a pixel within the image.
Digital cameras are steadily increasing in popularity due to their declining costs, which make them well within the reach of the average consumer. In order to keep costs low, many color digital cameras are single-sensor digital cameras in which only a single image sensor is used to capture color information for each pixel in a color image. Each image sensor in a single-sensor digital camera, which is typically a charge-coupled device (CCD) or a complementary metal oxide semiconductor (CMOS), is part of a sensor array that represent the pixels of a color image. Each image sensor can only generate information about a single color at a given pixel. A color image, however, is represented by combining three separate monochromatic images. In order to display a color image, all of the red, blue and green (RGB) color values are needed at each pixel. In an ideal (and expensive) camera system, each pixel in the sensor array would be provided with three image sensors, each one measuring a red, green or blue pixel color. In a single-sensor digital camera, however, only a single red, blue or green color value can be determined at a given pixel. In order to obtain the other two missing colors, a technique must be used to estimate or interpolate the missing colors from surrounding pixels in the image.
Estimating or interpolating missing colors as discussed above is called “demosaicing”. The “demosaicing” term is derived from the fact that a color filter array (CFA) is used in front of the image sensors, with the CFA being arranged in a mosaic pattern. This mosaic pattern has only one color value for each of the pixels in the image. In order to obtain the full-color image, the mosaic pattern must be “demosaiced”. Thus, demosaicing is the technique of interpolating back from the image captured with a mosaic-pattern CFA, so that a full RGB value can be associated with every pixel. More specifically, a single-sensor digital camera captures the image using an image sensor array that is preceded in the optical path by a CFA. A highly common mosaic CFA is called the Bayer mosaic pattern. The Bayer mosaic pattern (or Bayer filter) is shown in
There are multitudes of demosaicing techniques available. One of the simplest approaches to demosaicing is bilinear interpolation. In general, bilinear interpolation uses three color planes that are independently interpolated using symmetric bilinear interpolation. This interpolation uses a pixel's nearest neighbors having the same color as the color that is being interpolated. In particular, referring again to
Equation (1) corresponds to estimating the green value at the pixel marked ‘X’ (also called the “current pixel”) in
Bilinear techniques typically use a small region of support. The region of support is the size of a pixel neighborhood whose values are considered for the interpolation of any given pixel. The region of support for the bilinear interpolation techniques described below typically is a 3×3 pixel region of support. Using this small of a region of support keeps memory usage and computational complexity to a minimum.
One problem, however, with many bilinear interpolation techniques is that they generate significant artifacts in the color image. This is especially true across edges and other high-frequency content in the image, since bilinear interpolation does not consider the statistical correlation among RGB values. Thus, while bilinear interpolation techniques are fast, computationally non-intensive, and easy to implement, they are also notorious for producing low-quality images due to the significant artifacts (mainly blurriness and color fringing) that they generate.
Better, though more complex, interpolation techniques take the correlation among RGB values into account. One group of interpolation techniques consider such correlation by using improved linear filters. For example, such a technique is described in a paper by S.-C. Pei and I.-K. Tam entitled “Effective color interpolation in CCD color filter array using signal correlation,” in Proc. ICIP, pp. 488-491, September 2000 [4]. Another group of interpolation techniques consider such correlation by using nonlinear filters. These nonlinear filters essentially adapt interpolation smoothness to a measure of image activity or edginess. For example, these nonlinear interpolation techniques are discussed in the following papers: (1) P. Longére, X. Zhang, P. B. Delahunt, and D. H. Brainard, “Perceptual assessment of demosaicing algorithm performance,” Proc. IEEE, vol. 90, pp. 123-132, January 2002 [1]; and (2) R. Ramanath, W. E. Snyder, and G. L. Bilbro, “Demosaicking methods for Bayer color arrays,” J. Electronic Imaging, vol. 11, pp. 306-315, July 2002 [2].
Exploiting correlation among RGB channels is the main idea behind improving demosaicing performance in nonlinear interpolation techniques. Specifically, it can be assumed that in a luminance/chrominance decomposition, the chrominance components do not vary much across pixels. In a constant-hue approach described in U.S. Pat. No. 4,724,395 to Freeman entitled, “Median filter for reconstructing missing color samples”, the green channel is bilinearly interpolated and then the red and blue channels are interpolated so as to maintain a constant hue, defined as the R/G and B/G ratios. However, one problem with this technique by Freeman is that even at the expense of computing these ratios, the technique still produces visible artifacts. Moreover, using complex operations (such as division and multiplication) in the computing of interpolations greatly increases the computational complexity, processing overhead, and implementation cost.
Improved results for nonlinear interpolation techniques can be obtained by starting with bilinearly interpolated green pixels and then applying median filters to the interpolated values of the color differences R−G and B−G. Improved performance can be obtained by using gradient-based nonlinear techniques, which typically estimate edge directions and adjust the interpolation formulas so that filtering is performed preferentially along edge directions, and not across them. For example, one gradient-based nonlinear technique is described in U.S. Pat. No. 5,373,322 to C. A. Laroche and M. A. Prescott entitled “Apparatus and method for adaptively interpolating a full color image utilizing chrominance gradients”. The Laroche and Prescott technique first interpolates the green channel by using both the red and blue channels to determine edge directions, which determine unequal weights to the terms in equation (1) for the green channel. The color differences R−G and B−G then are interpolated. This technique is disadvantageous in that two computational passes are required to compute the missing color data in the image. A technique described in U.S. Pat. No. 5,506,619 to J. E. Adams and J. F. Hamilton, Jr., entitled “Adaptive color plane interpolation in a single color electronic camera” improves on the Laroche and Prescott technique by considering both first and second order pixel differences (see also J. E. Adams, “Design of practical color filter array interpolation algorithms for digital cameras,” Proc. SPIE, vol. 3028, pp. 117-125, February 1997) [7]. Again, Adams and Hamilton's technique, and most other non-linear interpolation methods, interpolate the green pixel values first and then use these green values to interpolate the blue and red values. This requires two passes of the image in order to interpolate all red, green and blue color values which greatly increases the time necessary to interpolate the missing colors in an image.
A technique described in a paper by E. Chang, S. Cheung, and D. Y. Pan, entitled “Color filter array recovery using a threshold-based variable number of gradients,” in Proc. SPIE, vol. 3650, pp. 36-43, Jan. 1999 [8], is an improvement on the above techniques by considering a variable number of gradients. A simpler but efficient algorithm that uses soft decision rules to combine interpolation results from horizontal and vertical directions is presented in a paper by X. Wu and N. Zhang, entitled “Primary-consistent soft-decision color demosaic for digital cameras,” in Proc. ICIP, vol. I, pp. 477-480, September 2003 [9].
Iterative methods can lead to further improvement by using results from blue and red interpolations to correct the green interpolation, and vice-versa. That is the basis of a technique described in a paper by R. Kimmel, “Demosaicing: image reconstruction from color CCD samples,” IEEE Trans. on Image Processing, vol. 8, pp. 1221-1228, September 1999 [3]. In Kimmel's approach, the interpolation steps are based on a combination of the constant-hue and gradient-based methods. A more recent technique introduced by Lukac et. al [11] also uses correction steps. A technique based on iterative projections is presented in a paper by B. K. Gunturk, Y. Altunbasak, and R. M. Mersereau, entitled “Color plane interpolation using alternating projections”, in IEEE Trans. on Image Processing, vol. 11, pp. 997-1013, September 2002 [6]. The Gunturk technique has the best performance to date on a popular set of standard test images. One problem, however with the Gunturk technique is that it has a very high complexity (as many as 480 operations per input pixel). Additionally, more than one pass across the image is required to interpolate the red, green and blue pixel values, making this technique slow and computationally inefficient.
The above-described nonlinear interpolation techniques typically use a larger region of support that is used in bilinear interpolation techniques. For example, a 5×5 pixel region of support is typical for these nonlinear techniques. A 5×5 region of support yields good correlation between RGB values and produce high-quality images. A smaller region of support greatly reduces the image quality, while larger regions of support require more memory and greatly increase computational complexity.
In a paper by H. S. Malvar, L.-W. He, and R. Cutler entitled “High-quality linear interpolation for demosaicing of Bayer-patterned color images”, Proc. ICASSP, Montreal, Canada, vol. 3, pp. III-485-488, May 2004 [10] and in a co-pending patent application entitled “HIGH-QUALITY GRADIENT-CORRECTED LINEAR INTERPOLATION FOR DEMOSAICING OF COLOR IMAGES” filed on Mar. 15, 2004 and assigned Ser. No. 10/801,450, an interpolation approach was defined that linearly combines a correction term with an interpolation to obtain a high-quality estimate of a missing pixel color at a pixel within the image. This interpolation technique for demosaicing color images is simple and has a speed similar to that of bilinear interpolation, while producing the high-quality images of more complex techniques. However, the interpolated image quality sometime suffers when interpolation takes place across horizontal and vertical edges, and resulting interpolated images are still subject to artifacts at these points. The artifacts are much attenuated when compared to straight bilinear interpolation, but they can still be noticed in some cases.
Therefore, what is needed is a high-quality interpolation technique that considers correlation among RGB values to improve performance and that is computationally efficient and fast. What is also needed is an interpolation technique that utilizes a larger region of support than bilinear techniques (where the region of support is comparable to that used in nonlinear techniques) for improved quality. What is further needed is an interpolation technique that optimizes the interpolated image, regardless of any edges present in the image. Additionally, what is needed is an interpolation technique that allows for all the color data to be interpolated in one computational pass across the data thereby increasing speed and minimizing computational complexity.
The invention disclosed herein includes a high-quality adaptive filter interpolation method and system for demosaicing of digital color images. The present invention overcomes the above-mentioned deficiencies of current interpolation techniques by providing a high-quality interpolation that is computationally efficient, fast, nearly optimal in a statistical sense, and provides superior image quality. Namely, the adaptive filter interpolation method and system disclosed herein uses color information from a current pixel and surrounding gradients to determine what type of interpolation filters should be used for each pixel in an image. This adaptive filter interpolation system and method is extremely efficient in that it allows all pixel colors in an image to be interpolated in one pass.
The adaptive filter method and system can operate on color images captured by digital cameras. Prior to display, the image is demosaiced using the adaptive filter interpolation method and system. Alternatively, a captured digital color image can be stored in a computing device in a compressed mosaiced form. If an application on the computing device needs to access the image, the application typically calls an appropriate application programming interface (API) to obtain the decompressed data. Most applications expect data in the RGB format, so the demosaicing must be performed before the image data is sent to the requesting application.
This invention extends the ideas in a paper by H. S. Malvar, L.-W. He, and R. Cutler entitled “High-quality linear interpolation for demosaicing of Bayer-patterned color images”, Proc. ICASSP, Montreal, Canada, vol. 3, pp. III-485-488, May 2004 [10] and a co-pending patent application entitled “HIGH-QUALITY GRADIENT-CORRECTED LINEAR INTERPOLATION FOR DEMOSAICING OF COLOR IMAGES” filed on Mar. 15, 2004 and assigned Ser. No. 10/801,450, that described a set of linear demosaicing filters. One main advantage of the adaptive filter interpolation system and method over the previous invention is that in this invention the set of filters has been extended to include those described in the aforementioned paper [10] and the co-pending application plus additional ones targeted at interpolation along horizontal and vertical edges. The filters selected are fast-computable close approximations to those that would be statistically optimal, considering the statistics of a representative set of color images. For each pixel to be interpolated, first directional gradients are computed, and the interpolation filters to be used depend on the relative values of such directional gradients.
The adaptive filter interpolation method and system is an efficient new method to perform high-quality demosaicing. The coefficients of the filters used approximate statistically-optimal Wiener filters, and allow fast implementations that use no multiplication operations, just additions and shifts (although multiplications can be used if the processing hardware supports fast multiplications). The interpolated images generated with the adaptive filter interpolation system and method surpass the fidelity of most algorithms currently in use. Compared to other nonlinear interpolation algorithms, this adaptive interpolation system and method has the advantage that only a single pass is made over the image; all colors are interpolated during that pass. The better performing algorithms described in the references require two passes, one to interpolate green values, and another to interpolate red and blue values. A second pass is needed because the filters for red and blue interpolation use the interpolated green values. Plus, more passes may be needed to achieve a desirable quality level.
Additionally, the adaptive filter interpolation system and method essentially removes artifacts such as zipper effects by choosing the interpolation filters so that they are aligned with edges in the image. For example, in a region near a horizontal edge (a large gradient in the pixel values in the vertical direction), interpolation filters with coefficients mostly in a horizontal pattern are chosen. That way one avoids interpolating across an edge. Analogously, in a region near a vertical edge one interpolates in the vertical direction. The adaptive filter interpolation method above requires that the magnitude of the gradient delta Gd (the difference between the pixel-value gradients in the horizontal and vertical directions) reaches a threshold T for directional filtering to take place. That has a significant impact on improving mean square error (MSE), and reduces the generation of artifacts in some textured areas and diagonal edges. Furthermore, the adaptive filter interpolation system uses near-optimal linear filters that are not directionally oriented for pixels in which |Gd| is below the threshold T.
The operation of the adaptive filter interpolation system and method can be described as follows. In general, input pixels are input in a Bayer-mosaiced pattern (only one color per pixel), and output pixels are in full RGB mode (three color values per pixel). For each pixel location, in raster scan order, the processing steps can be summarized as follows. For each pixel location horizontal and vertical gradients are first computed (whose computation depends on the available color for that pixel and the location of that pixel in the mosaic pattern), and these gradients are used to select the appropriate interpolation filters from a small set of predetermined filters. Then, the chosen filters are applied to interpolate the missing data. The gradient computations, filter selection and color interpolation are performed for each pixel before computing the same for the next pixel (that is, in one pass).
More specifically, an image in Bayer format is input. A pixel location is selected based on raster scan order and its pixel color is extracted. Next, for the given pixel location, the horizontal and vertical gradients are computed by employing a region of support around the given current pixel location in the color image. The region of support is defined as a size of a pixel neighborhood whose color values are considered for computations associated with any given pixel, such as the current pixel. A gradient differential, Gd, based on the relative values of horizontal and vertical gradients and dependent on the pixel location is then computed. This gradient differential is computed using the current pixel and pixels within the region of support. For each pixel, the system decides on which filter to use based on the relative values of the horizontal and vertical gradients. To this end, the gradient-differential is compared to a threshold T and the interpolation filters are selected based on how the gradient differential compares to threshold T.
Bayer patterns such as that in
It is noted that in this section and the remainder of this specification, the description refers to various individual publications identified by a numeric designator contained within a pair of brackets. For example, such a reference may be identified by reciting, “reference [1]” or simply “[1]”. A listing of the publications corresponding to each designator can be found at the end of the Detailed Description section.
The present invention can be further understood by reference to the following description and attached drawings that illustrate aspects of the invention. Other features and advantages will be apparent from the following detailed description of the invention, taken in conjunction with the accompanying drawings, which illustrate, by way of example, the principles of the present invention.
The file of this patent or application contains at least one drawing executed in color. Copies of this patent or patent application publication with color drawing(s) will be provided by the U.S. Patent and Trademark Office upon request and payment of the necessary fee.
Referring now to the drawings in which like reference numbers represent corresponding parts throughout:
In the following description of the invention, reference is made to the accompanying drawings, which form a part thereof, and in which is shown by way of illustration a specific example whereby the invention may be practiced. It is to be understood that other embodiments may be utilized and structural changes may be made without departing from the scope of the present invention.
I. Introduction
This invention comprises a new algorithm for adaptive interpolation of images produced by digital cameras using a set of linear filters. To reduce cost, almost all digital cameras use a single CCD (charge-coupled device) sensor. To capture the three RGB (red, green, blue) color components, a mosaic-patterned filter is superimposed to the CCD image array, as shown in
The adaptive filter interpolation system and method of the invention describes an efficient new method to perform high-quality demosaicing. The coefficients of these filters approximate statistically-optimal Wiener filters, and allow fast implementations that use no multiplication operations, just additions and shifts (although multiplications can be used if the processing hardware supports fast multiplications). The interpolated images generated with the algorithm described in the invention surpass the fidelity of most algorithms currently in use. In most general terms, for each pixel to be interpolated, first directional gradients are computed, and the interpolation filters to be used depend on the relative values of such directional gradients.
The adaptive filter interpolation system and method extends the ideas in of a set of linear demosaicing filters described in [10]. One main advantage of this new invention over the previous one is that in this invention the set of filters has been extended to include those in the former invention plus additional ones targeted at interpolation along horizontal and vertical edges. Compared to other nonlinear interpolation algorithms, this adaptive filter interpolation system and method has the advantage that only a single pass is made over the image; all colors are interpolated during that pass. The better performing algorithms described in the references require two passes, one to interpolate green values, and another to interpolate red and blue values. A second pass is needed because the filters for red and blue interpolation use the interpolated green values.
In general, several basic advantageous ideas underlying the adaptive filter interpolation system and method of the invention are:
Referring to
The image sensor array 215 includes a sensor substrate 230, a color filter array (CFA) 240, and a microlens array 250. It should be noted that typically the microlens array 250 is disposed over the CFA 240, which in turn is disposed over the substrate 230, as indicated in
Each pixel in the image sensor array 215 is the output of a red, green or blue sensor. Thus, the sensor output is an electrical signal from each sensor that corresponds to a single color value for each pixel in the image sensor array 215. The output is raw, mosaic-patterned pixel data 260. As mentioned above, in order to display the full color image, color information for red, green and blue colors must be obtained at each pixel. This is achieved by demosaicing, or the interpolating the missing color values in the mosaic-patterned pixel data 260.
The adaptive filter interpolation system 200 use a novel demosaicing technique to interpolate a high-quality estimate of the missing color values. The adaptive filter interpolation system 200 resides on a processing device 270 located on the digital camera system 210. As detailed below, the adaptive filter interpolation system 200 uses the adaptive filter interpolation method to obtain the missing color values at each pixel 220 in the image sensor array 215.
Referring now to
III. Operational Overview
The operation of the adaptive filter interpolation system 200 and method used therein shown in
IV. Operational Details and Working Example
With respect to the interpolation filters chosen, as mentioned above, if |Gd|<T, the linear filters described [10] and in the aforementioned co-pending patent application are used. This third case will now briefly be described. Specifically, in this third case, this gradient-corrected linear interpolation method described in [10] and the co-pending patent application includes computing an interpolation of a desired color at a current pixel having a current color, where the desired color is used in the interpolation. Next, a correction term is computed using the current color. The correction term then is linearly combined with the interpolation to obtain a corrected interpolation of the desired color at the current pixel. Preferably, in order to simplify computation and preserve computing resources, the interpolation is a bilinear interpolation. However, the interpolation may be virtually any one of the available prior art demosaicing techniques, including linear and nonlinear interpolations. The correction term is preferably a gradient correction term computed from the current color of the current pixel. The gradient-corrected linear interpolation method computes a gradient at each pixel by using the color value of that pixel and the values of the neighboring pixels. A fixed portion (preferably controlled by a gain factor) of that gradient value then is added to the interpolated value of the missing colors. The gradient correction term is linearly combined with the interpolation. Preferably, the gradient correction term is added to the interpolation to improve the estimate of the desired color. The gradient-corrected linear interpolation method also includes applying a gradient-correction gain to the gradient correction term. This gradient-correction gain affects the amount of gradient correction that is applied to the interpolation. The gradient-correction gain can be selected in a variety of ways. The optimal gradient-correction gain is computed by minimization a mean-squared error. An approximation to this optimal value allows computations using integer arithmetic, no division operations, or both. The gradient-correction may also be selected based on characteristics of the color image sensor or characteristics of an entire digital camera system. The gradient-correction gain may also be varied within the image, if so desired, based on statistics of the color image. These statistics may include the global statistics of the image, the local statistics of the image, or both.
In order to more fully understand the adaptive filter interpolation method and system disclosed herein, the operational details of an exemplary working example are presented. It should be noted that this working example is only one way in which the adaptive filter interpolation method and system may be implemented.
The previous demosaicing algorithm [10] was aimed at fast computation. It defines a set a near-optimal linear (fixed) filters, in the sense of approximating closely optimal linear Bayesian estimators (i.e. Wiener filters). While performing better than most non-linear algorithms in terms of mean-square error (MSE, measured with respect to the reference 3-CCD image), the linear demosaicing in [10] still has color fringing artifacts (“zipper” effects [2]) near edges. In the adaptive filter interpolation system and method of the present invention, the adaptive filter interpolation system and method essentially removes the zipper effects by choosing the interpolation filters so that they are aligned with edges in the image. For example, in a region near a horizontal edge (a large gradient in the pixel values in the vertical direction), one chooses interpolation filters with coefficients mostly in a horizontal pattern. That way one avoids interpolating across an edge. Analogously, in a region near a vertical edge, one interpolates in the vertical direction.
Specifically, the adaptive filter interpolation system and method scans the pixels in raster-scan order, and for each pixel it performs two steps: 1) gradient differential computation; and 2) interpolation, as described below.
1) Step 1: Gradient Differential Computation
First, a gradient differential Gd is computed, where
Gd=|ΔH|−|ΔV|
where ΔH denotes the gradient in the horizontal direction and ΔV denotes the gradient in the vertical direction, and |·| denotes magnitude (or absolute value). The formulas for computing the gradients depend on which pixel location within the Bayer pattern is being computed, as described below.
2) Step 2: Interpolation
Then, interpolation for the two missing colors is computed via linear filters, but the choice of filters is dependent on Gd, according to the following rule:
Parameter T is a threshold that controls how aggressive is the decision to interpolate along an edge. The smaller the value of T, the more likely one is to switch from a non-directional filter to a horizontally- or vertically-aligned filter.
The main advantages of this process over the well-known Hamilton-Adams method [7] (and others) are reduced computational complexity and better filtering performance. The differentiating aspects are:
To completely specify the interpolation process, the interpolation formulas for each of the four possible pixel positions in a Bayer array are now defined. For each case, one must specify four formulas: one for the gradient computation, and one for each of the horizontal, vertical, and non-directional filters.
Note: by non-directional we mean filters that do not put more weight in either horizontal or vertical directions; thus, they are useful for diagonal edges and also for generic textures where no edge is present.
1. Interpolation at Red Locations
Red locations are the locations such as the one marked with an X in the top left of
First, the gradient computation formulas are defined as:
ΔH=G2−G1
ΔV=G4−G3
Now, one defines the horizontal interpolation filter for Green:
G0=½[G1+G2]+a1[2R0−R3−R4]
where the first term is a bilinear interpolation for the horizontal direction only, and the second term is a horizontal correction based on a Red gradient. In a preferred embodiment, a good value for the first correction gain parameter is a1=¼.
The horizontal interpolation filter for Blue is given by:
B0=G0+CB−G
where the correction factor CB−G is computed as
CB−G=¼[B1+B2−G3−½(G5+G6)]+¼[B3+B4−G4−½(G7+G8)]
Note that the formula above is written in a way as to clearly identify two delta-color gradient terms: the first term corresponding to a horizontal gradient operator for pixels above the center pixel, and the second term corresponding to a horizontal gradient operator for pixels below the center pixel. By regrouping terms, an equivalent formula can be used for faster computation, for example
CB−G=¼[B1+B2+B3+B4−G3−G4−½(G5+G6+G7+G8)]
Now the vertical interpolation filter for Green is defined as:
G0=½[G3+G4]+a2[2R0−R1−R2]
In a preferred embodiment, a good value for the second correction gain parameter is a2=¼.
The vertical interpolation filter for Blue is given by:
B0=G0+CB−G
with
CB−G=¼[B1+B3−G1−½(G9+G11)]+¼[B2+B4−G2−½(G10+G12)]
or, equivalently,
CB−G=¼[B1+B2+B3+B4−G1−G2−½(G9+G10+G11+G12)]
Now the diagonal or non-directional interpolation filter for Green is defined as:
G0=¼[G1+G2+G3+G4]+a3[4R0−R1−R2−R3−R4]
and the diagonal or non-directional interpolation filter for Blue:
B0=¼[B1+B2+B3+B4]+a4[R0−¼(R1+R2+R3+R4)]
In a preferred embodiment, good values for the third and fourth correction gain parameters are a3=⅛ and a4=¾.
Note that the interpolated values G0 and B0 complement the known value R0 to determine the full RGB values for the current pixel of interest, i.e. the pixel at the center in
2. Interpolation at Blue Locations
The blue locations are the locations such as the one marked with an X in the bottom left of
First, the gradient computation formulas are defined:
ΔH=G2−G1
ΔV=G4−G3
Now the horizontal interpolation filter for Green is defined:
G0=½[G1+G2]+b1[2B0−B3−B4]
where the first term is a bilinear interpolation for the horizontal direction only, and the second term is a horizontal correction based on a Red gradient. In a preferred embodiment, a good value for the first correction gain parameter is b1=¼.
The horizontal interpolation filter for Red is given by:
R0=G0+CR−G
where the correction factor CR−G is computed as
CR−G=¼[R1+R2−G3−½(G5+G6)]+¼[R3+R4−G4−½(G7+G8)]
or, equivalently as
CR−G=¼[R1+R2+R3+R4−G3−G4−½(G5+G6+G7+G8)]
Now the vertical interpolation filter for Green is defined as:
G0=½[G3+G4]+b2[2B0−B1−B2]
In a preferred embodiment, a good value for the second correction gain parameter is b2=¼.
The vertical interpolation filter for Red is given by:
R0=G0+CR−G
with
CR−G=¼[R1+R3−G1−½(G9+G11)]+¼[R2+R4−G2−½(G10+G12)]
or, equivalently,
CR−G=¼[R1+R2+R3+R4−G1−G2−½(G9+G10+G11+G12)]
Now the diagonal or non-directional interpolation filter for Green is defined as:
G0=¼[G1+G2+G3+G4]+b3 [4B0−B1−B2−B3−B4]
and the diagonal or non-directional interpolation filter for Red:
R0=¼[R1+R2+R3+R4]+b4[B0−¼(B1+B2+B3+B4)]
In a preferred embodiment, good values for the third and fourth correction gain parameters are b3=⅛ and b4=¾.
Note that the interpolated values G0 and R0 complement the known value B0 to determine the full RGB values for the current pixel of interest, i.e. the pixel at the center in
Using the preferred values for the correction gain parameters, for the cases I and II one gets the interpolation filters shown in
3. Interpolation at Green Locations in a Red Row and Blue Column
The green locations are the locations such as the one marked with an X in the top left of
First, the gradient computation formulas are defined. There are three options: the first is to use just the two immediate pixels in each direction, as in the previous two cases, namely:
ΔH=R2−R1
ΔV=B2−B1
The formulas above are simple, but have the disadvantage of measuring the gradient via Red and Blue pixel values. In the first two cases (Interpolation at Red and Blue locations), gradients were computed from Green pixels. That is appropriate because in most cases edges are more defined in the Green channel.
A second alternative formula for computing the horizontal and vertical gradients around G0, using only Green pixel values, is
ΔH=½[(G2−G1)+(G4−G3)]
ΔV=½[(G3−G1)+(G4−G2)]
The formula above produces better results, because it uses only Green pixel values.
A third alternative formula for computing the horizontal and vertical gradients around G0, using only Green pixel values, considers the fact that one needs only the magnitude of the gradients to compute the gradient differential GD:
|ΔH|=½[|G2−G1|+|G4−G3|]
|ΔV|=½[|G3−G1+|G4−G2|]
This third formula produces even better results in practice.
Now the horizontal interpolation filter for Red is defined as:
R0=½[R1+R2]+c1[2G0−G5−G6]
where the first term is a bilinear interpolation for the horizontal direction only, and the second term is a horizontal correction based on a Green gradient. In a preferred embodiment, a good value for the first correction gain parameter is c1=¼.
The horizontal interpolation filter for Blue is given by:
B0=G0+CB−G
(note that G0 is a known value, not an interpolated one) where the correction factor CB−G is computed as
CB−G=¼[2B1−G1−G2]−¼[2B2−G3−G4]
An alternative formula for CB-G that leads to better results is
CB-G=¼[B1+½(B3+B5)−G1−G2]+¼[B2+½(B4+B6)−G3−G4]
or, equivalently,
CB−G=¼[B1+B2+½(B3+B5+B4+B6)−(G1+G2+G3+G4)]
Now the vertical interpolation filter for Red is defined as:
R0=G0+CR−G
where the correction factor CR−G is computed as
CR−G=¼[2R1−G1−G3]−¼[2R2−G2−G4]
An alternative formula for CB−G that leads to better results is
CR−G=¼[R1+½(R3+R5)−G1−G3]+¼[R2+½(R4+R6)−G2−G4]
or, equivalently,
CR−G=¼[R1+R2+½(R3+R5+R4+R6)−(G1+G2+G3+G4)]
The vertical interpolation filter for Blue is given by:
B0=½[B1+B2]+c2[2G0−G7−G8]
In a preferred embodiment, a good value for the second correction gain parameter is c2=¼.
Now the diagonal or non-directional interpolation filter for Red is defined as:
R0=½[R1+R2]+⅛[c3G0−c4(G1+G2+G3+G4+G5+G6)+c5(G7+G8)]
and the diagonal or non-directional interpolation filter for Blue:
B0=½[B1+B2]+⅛[c3G0−c4(G1+G2+G3+G4+G7+G8)+c5(G5+G6)]
In a preferred embodiment, good values for the third, fourth, and fifth correction gain parameters are c3=5, c4=1, and c5=½.
Note that the interpolated values R0 and B0 complement the known value G0 to determine the full RGB values for the current pixel of interest, i.e. the pixel at the center in
4. Interpolation at Green Locations in a Blue Row and Red Column
Green locations in a blue row and a red column are the locations such as the one marked with an X in the top left of
First the gradient computation formulas are defined. There are three options: the first is to use just the two immediate pixels in each direction, as in the previous two cases, namely:
ΔH=B2−B1
ΔV=R2−R1
A second alternative formula for computing the horizontal and vertical gradients around G0 is:
ΔH=½[(G2−G1)+(G4−G3)]
ΔV=½[(G3−G1)+(G4−G2)]
The formula above produces better results, because it uses only Green pixel values.
A third alternative formula for computing the horizontal and vertical gradients around G0, using only Green pixel values, considers the fact that we need only the magnitude of the gradients to compute the gradient differential GD:
|ΔH|=½[|G2−G1|+|G4−G3|]
|ΔV|=½[|G3−G1|+|G4−G2|]
This third formula produces even better results in practice.
Now the horizontal interpolation filter for Blue is defined as:
B0=½[B1+B2]+d1[2G0−G5−G6]
where the first term is a bilinear interpolation for the horizontal direction only, and the second term is a horizontal correction based on a Green gradient. In a preferred embodiment, a good value for the first correction gain parameter is d1=¼.
The horizontal interpolation filter for Red is given by:
R0=G0+CR−G
where the correction factor CR−G is computed as
CR−G=¼[2R1−G1−G2]−¼[2R2−G3−G4]
An alternative formula for CR−G that leads to better results is
CR−G=¼[R1+½(R3+R5)−G1−G2]−¼[R2+½(R4+R6)−G3−G4]
or, equivalently,
CR−G=¼[R1+R2+½(R3+R5+R4+R6)−(G1+G2+G3+G4)]
Now the vertical interpolation filter for Blue is defined as:
B0=G0+CB−G
where the correction factor CR−G is computed as
CB−G=¼[2B1−G1−G3]−¼[2B2−G2−G4]
An alternative formula for CB−G that leads to better results is
CB−G=¼[B1+½(B3+B5)−G1−G3]−¼[B2+½(B4+B6)−G2−G4]
or, equivalently,
CB−G=¼[B1+B2+½(B3+B5+B4+B6)−(G1+G2+G3+G4)]
The vertical interpolation filter for Red is given by:
R0=½[R1+R2]+d2[2G0−G7−G8]
In a preferred embodiment, a good value for the second correction gain parameter is d2=¼.
Now the diagonal interpolation filter for Blue is defined as:
B0=½[B1+B2]+⅛[d3G0−d4(G1+G2+G3+G4+G5+G6)+d5(G7+G8)]
and the diagonal or non-directional interpolation filter for Red:
R0=½[R1+R2]+⅛[d3G0−d4(G1+G2+G3+G4+G7+G8)+d5(G5+G6)]
In a preferred embodiment, good values for the third, fourth, and fifth correction gain parameters are d3=5, d4=1, and d5=½.
Note that the interpolated values R0 and B0 complement the known value G0 to determine the full RGB values for the current pixel of interest, i.e. the pixel at the center in
Using the preferred values for the correction gain parameters, for the cases III and IV one gets the interpolation filters shown in
V. System Components
The adaptive filter interpolation system 200 shown in
In general, referring to
V. Exemplary Operating Environment
The adaptive filter interpolation method and system are designed to operate in a computing environment and on a computing device, such as the processing device 270 contained in the digital camera system 210 or in the computing device 280. The computing environment in which the adaptive filter interpolation method and system operates will now be discussed. The following discussion is intended to provide a brief, general description of a suitable computing environment in which the adaptive filter interpolation method and system may be implemented.
The adaptive filter interpolation method and system is operational with numerous other general purpose or special purpose computing system environments or configurations. Examples of well known computing systems, environments, and/or configurations that may be suitable for use with the adaptive filter interpolation method and system include, but are not limited to, personal computers, server computers, hand-held, laptop or mobile computer or communications devices such as cell phones and PDA's, multiprocessor systems, microprocessor-based systems, set top boxes, programmable consumer electronics, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like.
The adaptive filter interpolation method and system may be described in the general context of computer-executable instructions, such as program modules, being executed by a computer. Generally, program modules include routines, programs, objects, components, data structures, etc., that perform particular tasks or implement particular abstract data types. The gradient-corrected linear interpolation method and system may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in both local and remote computer storage media including memory storage devices. With reference to
Components of the computer 1210 may include, but are not limited to, a processing unit 1220, a system memory 1230, and a system bus 1221 that couples various system components including the system memory to the processing unit 1220. The system bus 1221 may be any of several types of bus structures including a memory bus or memory controller, a peripheral bus, and a local bus using any of a variety of bus architectures. By way of example, and not limitation, such architectures include Industry Standard Architecture (ISA) bus, Micro Channel Architecture (MCA) bus, Enhanced ISA (EISA) bus, Video Electronics Standards Association (VESA) local bus, and Peripheral Component Interconnect (PCI) bus also known as Mezzanine bus.
The computer 1210 typically includes a variety of computer readable media. Computer readable media can be any available media that can be accessed by the computer 1210 and includes both volatile and nonvolatile media, removable and non-removable media. By way of example, and not limitation, computer readable media may comprise computer storage media and communication media. Computer storage media includes volatile and nonvolatile removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules or other data.
Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by the computer 1210. Communication media typically embodies computer readable instructions, data structures, program modules or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any information delivery media.
Note that the term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared and other wireless media. Combinations of any of the above should also be included within the scope of computer readable media.
The system memory 1230 includes computer storage media in the form of volatile and/or nonvolatile memory such as read only memory (ROM) 1231 and random access memory (RAM) 1232. A basic input/output system 1233 (BIOS), containing the basic routines that help to transfer information between elements within the computer 1210, such as during start-up, is typically stored in ROM 931. RAM 1232 typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by processing unit 1220. By way of example, and not limitation,
The computer 1210 may also include other removable/non-removable, volatile/nonvolatile computer storage media. By way of example only,
Other removable/non-removable, volatile/nonvolatile computer storage media that can be used in the exemplary operating environment include, but are not limited to, magnetic tape cassettes, flash memory cards, digital versatile disks, digital video tape, solid state RAM, solid state ROM, and the like. The hard disk drive 1241 is typically connected to the system bus 1221 through a non-removable memory interface such as interface 1240, and magnetic disk drive 1251 and optical disk drive 1255 are typically connected to the system bus 1221 by a removable memory interface, such as interface 1250.
The drives and their associated computer storage media discussed above and illustrated in
Other input devices (not shown) may include a microphone, joystick, game pad, satellite dish, scanner, radio receiver, or a television or broadcast video receiver, or the like. These and other input devices are often connected to the processing unit 1220 through a user input interface 1260 that is coupled to the system bus 1221, but may be connected by other interface and bus structures, such as, for example, a parallel port, game port or a universal serial bus (USB). A monitor 1291 or other type of display device is also connected to the system bus 1221 via an interface, such as a video interface 1290. In addition to the monitor, computers may also include other peripheral output devices such as speakers 1297 and printer 1296, which may be connected through an output peripheral interface 1295.
The computer 1210 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 1280. The remote computer 1280 may be a personal computer, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computer 1210, although only a memory storage device 981 has been illustrated in
When used in a LAN networking environment, the computer 1210 is connected to the LAN 1271 through a network interface or adapter 1270. When used in a WAN networking environment, the computer 1210 typically includes a modem 1272 or other means for establishing communications over the WAN 1273, such as the Internet. The modem 1272, which may be internal or external, may be connected to the system bus 1221 via the user input interface 1260, or other appropriate mechanism. In a networked environment, program modules depicted relative to the computer 1210, or portions thereof, may be stored in the remote memory storage device. By way of example, and not limitation,
The foregoing description of the invention has been presented for the purposes of illustration and description. It is not intended to be exhaustive or to limit the invention to the precise form disclosed. Many modifications and variations are possible in light of the above teaching. It is intended that the scope of the invention be limited not by this detailed description of the invention, but rather by the claims appended hereto.
This is a continuation-in-part of application Ser. No. 10/801,450, filed Mar. 15, 2004 now U.S. Pat. No. 7,502,505 and entitled “HIGH-QUALITY GRADIENT-CORRECTED LINEAR INTERPOLATION FOR DEMOSAICING OF COLOR IMAGES”.
Number | Name | Date | Kind |
---|---|---|---|
3971065 | Bayer | Jul 1976 | A |
4724395 | Freeman | Feb 1988 | A |
5373322 | Laroche et al. | Dec 1994 | A |
5506619 | Adams, Jr. et al. | Apr 1996 | A |
5805217 | Lu et al. | Sep 1998 | A |
5822465 | Normile et al. | Oct 1998 | A |
6654492 | Sasai | Nov 2003 | B1 |
6771828 | Malvar | Aug 2004 | B1 |
6781626 | Wang | Aug 2004 | B1 |
7236191 | Kalevo et al. | Nov 2004 | B2 |
6847396 | Lin | Jan 2005 | B1 |
20020015447 | Zhou | Feb 2002 | A1 |
20020167602 | Nguyen | Nov 2002 | A1 |
Number | Date | Country | |
---|---|---|---|
20050200733 A1 | Sep 2005 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10801450 | Mar 2004 | US |
Child | 11046324 | US |