1. Field of the Invention
The present invention relates to processing of digital images. More particularly, the present invention relates to methods for adjusting digital camera image processing parameters in order to achieve improved performance of a digital camera image processing pipeline.
2. The Prior Art
It is quite common that the main camera image processing parameters, particularly, those used to control the noise reduction process, are linked to the ISO sensitivity setting. The quality of images taken at various ISO settings depends greatly on the quality of the algorithm used for noise reduction.
Since noise increases with the increase of ISO sensitivity, as usually demonstrated in terms of the signal-to-noise ratio measurements, it is often necessary to use more aggressive noise reduction at higher ISO sensitivities. However, since aggressive noise reduction smoothes out fine details and blurs the edges in the image, it is also possible to leave more noise in the processed images taken at high ISO settings compared to the processed images taken at low ISO settings.
Unfortunately, the ISO setting is a global parameter which does not address the problem of excessive highlights, deep shadows, and uneven illumination in the scene, and also does not account for overexposure and underexposure effects introduced through the automatic camera capture process or by the user. To avoid this problem, a different solution is needed.
According to one aspect of the present invention, capture parameters are employed to adjust predetermined ISO-dependent image processing parameters for images captured by a digital camera.
According to another aspect of the present invention, image statistics are employed to adjust predetermined ISO-dependent image processing parameters for images captured by a digital camera.
According to another aspect of the present invention, both capture parameters and image statistics are employed to adjust predetermined ISO-dependent image processing parameters for images captured by a digital camera.
Persons of ordinary skill in the art will realize that the following description of the present invention is illustrative only and not in any way limiting. Other embodiments of the invention will readily suggest themselves to such skilled persons.
The present invention provides methods for adjusting image processing parameters to achieve improved performance of a given digital camera image processing pipeline. This invention is not limited to the specific examples presented below.
According to the present invention methods are disclosed that estimate the ISO setting using the capture parameters and image statistics. This setting, which is an estimation of camera sensitivity, is used to adjust the image processing parameters which are typically determined in calibration according to certain numerical image quality criteria and subjective evaluation of processed images.
Formally, each standard ISO setting in a digital camera, expressed as uε U, for U={100, 200, 400, 800, 1600, 3200, 6400, 12800, . . . }, can be associated with a set of image processing parameters that are stored as a vector expressed as β(u)=[β1(u), β2(u), . . . , βN(u)], where N denotes the number of ISO-dependent parameters. The parameter u denotes the ISO sensitivity setting in the camera.
Once the estimated camera sensitivity, denoted herein as v, is obtained using the available capture parameters and/or actual image statistics, the final image processing parameters should be set as a function of v, that may be expressed as β(v)=[β1(v), β2(v), . . . , βN(v)], in order to produce the processed image with the best possible quality. Since v can be an arbitrary positive number, final image processing parameters should be obtained as a function of at least one of vectors β predetermined in calibration for all standard ISO settings or their subset.
In one example, the estimated camera sensitivity v is updated by rounding it to the nearest ISO setting in the set U for which the predetermined parameters are available. In another example, the value of v is rounded to the nearest larger or smaller ISO setting in U. In yet another example, the final value of v is calculated as a combination (e.g., average or weighted average) of the two nearest ISO values in U. In yet another example, the final value of v is calculated as a combination of two or more ISO values in U. In such weighted calculations, the weights can be set inversely proportional to the difference between the estimated camera sensitivity and selected ISO values in U, and then normalized in a way so that their summation is equal to unity.
The following presents example solutions for calculating the estimated camera sensitivity value which may be subsequently updated according to the above rounding and combination operations in order to obtain optimal image processing parameters.
The estimated camera sensitivity v can be obtained as a function of the camera ISO setting and the capture parameter indicating the exposure deviation from the optimal exposure. In the following example, the estimated camera sensitivity value v can be obtained as follows:
v=u/2E (1)
where u denotes the camera ISO setting, and E denotes the exposure deviation (as determined by the camera during the image capture process) in exposure units from the optimal exposure.
Referring first to
Alternatively, the estimated camera sensitivity can be obtained using the camera capture parameters, as a function of the difference between the camera exposure value and the exposure value calculated using the parameters characterizing ambient illumination.
The so-called reference or camera exposure value is calculated as a function of a camera's shutter speed and an aperture. In the following example, the reference exposure value EVref is calculated as follows,
EVref=log2(A2/t)−log2(u/100) (2)
where A refers to the aperture, t refers to the shutter speed, and u refers to the camera ISO setting.
The actual exposure value EVact, is calculated as a function of the parameters characterizing ambient illumination. Such parameters are usually arranged in an array, with each array value corresponding to a block in a captured image. Each ambient illumination array value can be associated with the weight, resulting in the weighted average-like calculations of the actual exposure value EVact, as follows:
where N denotes the total number of available ambient illumination values, and wi is the weight associated with the ambient illumination value αi. The function T(·) denotes the relationship between the camera exposure value (or image sensor response) and α values (or ambient illumination sensor response), this function is usually determined in the camera calibration phase. For example, T(·) can be defined as T(x)=(x−48)/8+5.
In one example, all the weights can be set to the same value to obtain the average ambient illumination value. In another example, the weights associated with αi values corresponding to blocks in focus (either indicated by the camera or automatically detected using the captured image data) are set to one, whereas all other weights are set to zero. In yet another example, only the weight associated with the image block of interest (for example, as determined via spot metering or selected by the user in the camera menu or through a PC interface) is set to a nonzero value.
In another example (e.g., corresponding to the center area and center weighted averaging modes) the weight value reduces with the increasing distance from the sensor center. In another example, the weight value reduces with the increasing distance from the image block of interest. In yet another example, the nonzero weight(s) are associated with the samples close to the target ambient value, for instance either predetermined or calculated using an arbitrary function (for example, median, maximum minimum, average of maximum and minimum, etc.) of the acquired ambient illumination values. In yet another example, the weight values or the captured a values can be compared to a predetermined threshold in order to set the weights to zero for those weights or a values which do not satisfied the predetermined thresholding criterion.
Once both the reference exposure value EVref and the actual reference value EVact are determined, the estimated camera sensitivity can be obtained as a function of these two values. In one example, the estimated camera sensitivity value v is calculated as follows:
v=u/2(E+(EVref−EVact)sign) if (EVref−EVact)sign>Δ (4)
whereas in yet another example
v=u/2(E+(EVref−EVact)sign) if (EVref−EVact)sign>Δand EVact<η (5)
where Δ and η are predetermined parameters and the sign term denotes a parameter set to 1 or −1 in calibration. In yet another example, the estimated camera sensitivity value can be calculated using either Equation (4) or Equation (5) if the corresponding condition is satisfied, otherwise Equation (1) is used.
Referring now to
In addition to using the camera capture parameters, the estimated camera sensitivity can be calculated using the actual image statistics. In one example, the estimated camera sensitivity is a function of the average, median, or maximum value L of the image under consideration and the intensity value I predetermined for certain ISO setting uε U. More specifically, the estimated camera sensitivity value v can be calculated as
In another example, L denotes the combination of the average, median, and maximum image values. In another example, the estimated camera sensitivity value is a function of the reference histogram obtained in calibration and the actual image histogram. More specifically, using the accumulated histograms the estimated camera sensitivity value v can be calculated as follows:
where {Ii} and {Li} denote the intensity levels corresponding to predetermined percentages of samples in the accumulated histograms with M levels. The term wi denotes the weights associated with the ith histogram measurement. The weights can be predetermined or adaptively determined through statistical analysis, for example, in order to reject outlying measurements by setting the corresponding weights to zero. In one example, determining the weights adaptively includes setting the weights as a function of the difference (e.g., absolute or Euclidean) between the reference histogram obtained in calibration and a histogram of the actual image. Suitable functions include the exponential or sigmoidal function, the weights calculated as inversely proportional to the differences between the two histograms, or the weights obtained by thresholding the histogram differences.
In another example, the actual image statistics, that is L in Equation (6) and Li in Equation (7) are calculated from one or more image regions of interest. Such region(s) of interest can be determined as regions which are in focus or determined via object detection/pattern recognition (for example, human faces). In yet another example, the image is divided into regular blocks, then the camera sensitivity is estimated in each of these blocks using the concepts behind Equation (6) or Equation (7), and then intermediate results are combined using weighted average with predetermined weights or weights set to follow the strategy in Equation (3) to obtain the estimated camera sensitivity of the actual image.
Referring now to
According to another aspect of the present invention, the two approaches, one based on capture parameters and another based on image statistics, can be combined. In example implementations, the estimated camera sensitivity can be obtained as the minimum, maximum, average, or weighted average of the two intermediate estimated camera sensitivity values obtained using these two approaches.
Referring now to
It should be appreciated that in the foregoing description of exemplary embodiments of the invention, various features of the invention are sometimes grouped together in a single embodiment, figure, or description thereof for the purpose of streamlining the disclosure and aiding in the understanding of one or more of the various inventive aspects. Inventive aspects lie in less than all features of a single foregoing disclosed embodiment, and each embodiment described herein may contain more than one inventive feature.
While embodiments and applications of this invention have been shown and described, it would be apparent to those skilled in the art that many more modifications than mentioned above are possible without departing from the inventive concepts herein. The invention, therefore, is not to be restricted except in the spirit of the appended claims.
This application claims priority from U.S. Provisional Patent Application Ser. No. 61/487,876, filed May 19, 2011.
Number | Name | Date | Kind |
---|---|---|---|
5959670 | Tamura | Sep 1999 | A |
6330345 | Russo | Dec 2001 | B1 |
20030052991 | Stavely | Mar 2003 | A1 |
20030067551 | Venturino | Apr 2003 | A1 |
20070071424 | Poon | Mar 2007 | A1 |
20070206113 | Nakamura | Sep 2007 | A1 |
20100118048 | Terry et al. | May 2010 | A1 |
20100208105 | Kubota | Aug 2010 | A1 |
20110193990 | Pillman | Aug 2011 | A1 |
Number | Date | Country | |
---|---|---|---|
20130128075 A1 | May 2013 | US |
Number | Date | Country | |
---|---|---|---|
61487876 | May 2011 | US |