The present invention relates generally to image scaling methods. Two-dimensional (2D) spatial scaling is more specifically addressed. In particular, the method is well suited to the processing of video sequences.
Upscaling a grayscale or color image is useful to display the image with a spatial resolution higher than the resolution of the image signal as received, for example for displaying a PAL or NTSC TV signal in a HDTV format. The upscaling operation, however, often leads to artifacts typical of scaling aliased images.
Upscaled edges have staircase effects (or “jaggies”), which have unnatural motion when such edges are moving in a video sequence. This is caused by aliasing, i.e. the frequency content of the original image has been folded by the sampling applied when acquiring or transforming the signal and the folded frequencies are not at appropriate locations in the 2D spectrum after upscaling. The generation process of an aliased image with an aliased spectrum is illustrated in
A standard way of upscaling an image is to apply an interpolation filter. This is illustrated in
On the other hand, if the subsampled image having an aliased spectrum is upscaled using a filter whose spectrum (
Directional interpolation methods have been proposed, for example in US 2009/0028464 A1. Similar (yet different) problems are addressed in U.S. Pat. No. 6,614,484 in the field of deinterlacing. An interpolation method consists in providing a set of directional interpolation filters, and performing the interpolation by choosing for each pixel an interpolator depending on the local image content. The underlying idea is that it is better to use a directional interpolation filter that is aligned with a contour whenever the current pixel is on a contour within the image.
Existing solutions for directional interpolation are usually based on very simple 2-tap filters. The metrics used to select a particular directional interpolation are usually simple gradient or correlation metrics. Such solutions are still prone to visual artifacts such as blurring of sharp edge patterns and detailed texture patterns in the image, ringing along edge contours, as well as jaggedness along edge contours.
There is thus a need for improved image processing methods in the field of directional interpolation or 2D scaling.
A method of scaling an input image having pixel values defined on an input sampling grid to provide an output image having pixel values defined on an output sampling grid is proposed. The method comprises, for a point of the output sampling grid which is not in the input sampling grid:
The set of interpolators mentioned above includes two-dimensional interpolators In of the form
for a plurality of values of a parameter n such that |n|≧. 1 and two-dimensional interpolators I′m of the form
for a plurality of values of a parameter m such that |m|≧1. Here, x and y are spatial indices identifying said point of the output sampling grid, j and k are integer spatial indices identifying points of the input sampling grid, f and g are one-dimensional interpolation functions, at least one of f and g having a support ]−p; p[ with p>1, and I(j, k) is the value of the pixel at coordinates (j, k) in the input grid.
The one-dimensional interpolation function which has the support ]−p; p[ with p>1 is advantageously the one applied along the horizontal direction, namely f. However, g too can have a support larger than ]−1; 1[ if sufficient line buffer capacity is available.
In an embodiment, applying an interpolator In for the point of the output sampling grid which is not in the input sampling grid is performed in two steps:
for a plurality of integer values of the spatial index k;
Likewise, applying an interpolator I′m for the point of the output sampling grid which is not in the input sampling grid can be performed in two steps:
for a plurality of integer values of the spatial index j; and
Another method disclosed herein is for analyzing an image signal having pixel values defined on a sampling grid. It comprises, for detecting at least one direction of regularity of the image signal in relation to a pixel of the sampling grid: computing a respective loss value associated with at least one direction in a set of directions; and selecting at least one direction of regularity by minimizing the loss value. The loss value associated with a direction (u, v), where u is a horizontal coordinate and v a vertical coordinate, has an axial loss component measuring variations of the pixel values in at least one linear array of pixels, said linear array being a horizontal array if |u/v|>1 and a vertical array if |u/v|<1.
This analysis method advantageously combines with the above-mentioned image scaling method. In this case, determining the loss value associated with an interpolated pixel value resulting from an interpolator In around a pixel of the input image for a parameter n such that |n|≧1 comprises computing an axial loss component measuring variations of the pixel values of the input image in at least one horizontal linear array of pixels, and determining the loss value associated with an interpolated pixel value resulting from an interpolator I′m around a pixel of the input image for a parameter m such that |m|≧1 comprises computing an axial loss component measuring variations of the pixel values of the input image in at least one vertical linear array of pixels.
In an embodiment, for a pixel of the input image having respective integer spatial indices j and k along the horizontal and vertical directions, the axial loss component for an interpolator In or I′m, where n or m is a non-zero integer, is a measure of variations of the pixel values of the input image in 2Q+1 linear arrays, where Q is a positive integer. For an interpolator In, the 2Q+1 arrays comprise, for each integer q such that ″Q≦q≦Q, a horizontal array of aq, n+aq, n+1 pixels including a pixel having respective integer spatial indices j+n·q and k+q, the numbers aq, n being positive integers. For an interpolator I′m, the 2Q+1 arrays comprise, for each integer q such that −Q≦q≦Q, a vertical array of aq, m+a−q, m+1 pixels including a pixel having respective integer spatial indices j·q and k+m·q.
In an embodiment, for a pixel of the input image having respective integer spatial indices j and k along the horizontal and vertical directions:
For q=0, each horizontal array of 2·a0, n+1 pixels and each vertical array of 2·a0, m+1 pixels are typically centered on the pixel of the input image having the respective integer spatial indices j and k along the horizontal and vertical directions. Advantageously, for each integer q such that −Q≦q≦Q, the positive integers aq, n are non-decreasing functions of |n| and the positive integers aq, m are non-decreasing functions of Imp.
Another aspect of the invention relates to an apparatus for implementing the above scaling method. The image scaling apparatus, comprises:
The set of interpolators includes two-dimensional interpolators In of the form
for a plurality of values of a parameter n such that |n|≧1 and two-dimensional interpolators I′m of the form
for a plurality of values of a parameter m such that |m|≧1, where x and y are spatial indices identifying said point of the output sampling grid, j and k are integer spatial indices identifying points of the input sampling grid, f and g are one-dimensional interpolation functions, at least one of f and g having a support ]−p; p[ with p>1, and I(j, k) is the value of the pixel at coordinates (j, k) in the input grid.
The interpolation processor may have first and second interpolation stages. For an interpolator In and said point of the output sampling grid, the first interpolation stage can be arranged for interpolating horizontally using the one-dimensional interpolation function f to compute
for a plurality of integer values of the spatial index k, while the second interpolation stage is arranged for interpolating vertically using the one-dimensional interpolation function g to compute the interpolated pixel value In(x, y) as
For an interpolator I′m and said point of the output sampling grid, the first interpolation stage can be arranged for interpolating vertically using the one-dimensional interpolation function g to compute
for a plurality of integer values of the spatial index j, while the second interpolation stage is arranged for interpolating horizontally using the one-dimensional interpolation function f to compute the interpolated pixel value I′m(x, y) as
In an embodiment of the image scaling apparatus, the optimizer for determining the loss value associated with an interpolated pixel value comprises a metrics computation unit for computing an axial loss component measuring variations of the pixel values of the input image in at least one linear array of pixels, the linear array of pixels being a horizontal array if said interpolated pixel value results from an interpolator In around a pixel of the input image for a parameter n such that |n|≧1, and a vertical linear if said interpolated pixel value results from an interpolator I′m around a pixel of the input image for a parameter m such that |m|≧1.
Other features and advantages of the method and apparatus disclosed herein will become apparent from the following description of non-limiting embodiments, with reference to the appended drawings.
The exemplary apparatus represented in
In the embodiment of
It will be appreciated that the nonlinear scaling process can also be applied to other color components, such as red (R), green (G) and blue (B) components.
The nonlinear scaling for a single channel image consists in this embodiment in considering for each output pixel (either individually or group by group) a candidate set of interpolators corresponding to various directions of regularity of the image, and to select the best interpolator depending on associated regularity measures (see WO 2007/115583 A1).
If needed, the three upscaled channels Y, Cb, and Cr are converted back to the original RGB format by a converter 15 to provide an output image Iout.
A one-dimensional interpolation function is a function φ(·) verifying:
φ(0)=1;
φ(j)=0 for any integer j other than 0; and
The convolution of such an interpolation function φ(·) with an input function having non-zero values for arguments that are integers (like a sequence of input pixels values) results in values that are the same as the input function for integer arguments, and interpolated values between them. The interpolation function φ(·) typically has a support ]−p, +p[ centered on 0, whose size is 2p with p being a positive integer. The simplest interpolation function φ(·) has p=1 and for −1<s<1, φ(s)=1−|s|. Other suitable interpolation functions φ(·) can be selected for their spectral properties. In particular, the number p can be greater than one, making it possible to use high-order filters such as Lanczos filters for example.
A source image (monochrome), such as the Y component in the block diagram of
A separable (i.e. linear) upscaling of the image I consists in computing interpolated pixel values I(x, y) for non-integer x and y indices as:
where f and g are one-dimensional interpolation functions of finite support ]−p, +p[. Here, x and y are non-integer points at which we want to interpolate the image, and j and k are integer indices. Because of this, only a finite (in practice small, at most 2p) number of terms are non-zero.
If the output grid of points x, y is regular, i.e. x=x0+a×dx and y=y0+b×dy, where a and b are integer numbers (which is the case for most applications), the upscaling process can be performed in two steps: a vertical scaling using filter g to compute I(j, y0+b×dy) for integers j and b, and an horizontal scaling using filter f to compute I(x0+a×dx, y0+b×dy) for integers a and b. Depending on optimization opportunities in an implementation of such conventional separable upscaling, the horizontal scaling can be performed before the vertical scaling or the converse.
The spectral effect of such a separable upscaling method is illustrated in
If we can use locally a different kind of 2D upscaling filter with a slanted spectrum as shown in
In the embodiment of
F(x, y)=f(x)·g(y) (2)
where f and g are 1D interpolation functions having finite supports, applying a slant of n along the horizontal (x) axis consists in replacing F(x, y) by:
G
n(x, y)=F(x−ny, y)=f(x·ny)·g(y) (3)
where n is a slant parameter such that |n|>1. The resulting filter is oriented along the direction Dn=(n, 1) in the spatial domain, closer to the horizontal axis than the vertical axis since |n|>1. Convolving an array of input pixels I(j, k) by the interpolation function Gn(x, y) yields, instead of (1), an interpolated image signal:
Likewise, to obtain filters oriented along direction D′m=(1, m) in the spatial domain with |m|>1, i.e. closer to the vertical axis than the horizontal axis, a slant of m is applied along the vertical (y) axis by replacing F(x, y) by:
H
m(x, y)=F(x, y−mx)=f(x)·g(y−mx) (5)
Convolving the array of input pixels I(j, k) by the interpolation function Hm(x, y) yields, instead of (1), an interpolated image signal:
The values of the slant parameters n, m can be integer or non-integer, positive or negative. At least some of them need to be of absolute value larger than 1. Choosing only integer values makes the implementation simpler.
The f and g functions can be Lanczos filters, for example. They can be identical or they can be filters of different sizes and/or shapes. Their support ]−p; p[ need not be the same. Good performance is obtained if, for at least one of f and g, in particular for f, the support ]−p; p[ is larger than ]−1; 1[.
The set of filters which can be used locally for upscaling consists of two subsets. One subset of filters constructed by slanting along the horizontal direction (with slant parameters n), and one subset of filters constructed by slanting along the vertical direction (with slant parameters m). For each of the subsets, filters are constructed using a family of slant parameter.
For example, we can construct a set of filters using always the same filter for both f and g: a Lanczos-4 interpolation filter (p=4). For the first subset (interpolators In slanted toward the horizontal direction), slanting parameters n such as −N, −N+1, . . . , −1, 0, +1, . . . , +N are used, where N is some integer. Other sets of slant parameters can used, integer or non integer, regularly spaced or not. For the second subset (interpolators I′m slanted toward the vertical direction), parameters m such as −M, −M+1, . . . , −1, 0, +1, . . . , +M are used, where M is some integer. The numbers M and N need not be identical. In particular, the value of N can be larger than that of M, in order to contain the vertical span of the processing, and thus the line buffer size necessary to realize the interpolation in an integrated circuit. If the values of the parameters m and n are not all integers, it is however necessary, to preserve good anti-aliasing properties, that whenever they are non-zero their absolute value is not less than 1.
The inclusion of non-slanted interpolation functions (with a 0 parameter) is motivated by the fact that the corresponding interpolators are standard separable interpolation functions. They are used as fallback interpolators in cases where a suitable direction of regularity cannot be detected.
One interesting aspect of the above-mentioned filters In and Im is that the resulting interpolation process is of same complexity as a separable interpolation process, even though the filters are not actually separable, i.e. cannot be written as a product f(x)·g(y).
The interpolation process for a given spatial direction of regularity D=(u, v) at a location x, y consists in computing I(x, y) where x and y are not both integers using values of I(j, k) for integer values of j and k only. Three cases are considered:
(ii) if |u|≦|v|, the direction (u, v) is parallel to the direction Du/v=(u/v, 1), and |u/v|≧1. In this case, the interpolation is performed using the slanted filter Gn(x, y) where n=u/v. This can be done by interpolating first along the horizontal direction and then along the vertical direction. The horizontal interpolation consists in using the interpolation function f to compute estimated pixel values IH, n(x, y, k) at positions (x′k, k)=(x−n(y−k), k), where the vertical position index k is an integer and the horizontal position index x′ik=x−n(y−k) is generally not an integer, namely:
The interpolation process is particularly simple to implement when the upscaling ratio is constrained to be a factor of 2 in each direction (or an integer factor in {1, 2} in each direction, the scaling factor along x and y being chosen differently). If the considered directions of regularity are all of the form (n, 1) or (1, m) with integer values of n and m, interim horizontal or vertical interpolations as well as final interpolation only need to be done on a half-integer grid. This simplifies the architecture to a large extent.
In an embodiment, when an arbitrary scaling factor is required (scaling factor different from 1 and 2 in at least one of the two dimensions), part of the upscaling process is done using the above-mentioned upscaling stage, and the remaining of the scaling is done with a traditional scaler. This may be referred to as “split-scaling”. For example, to convert images of 720×576 pixels into high-definition images of 1920×1080 pixels, e.g. from PAL to 1080p, a 2D directional interpolation is first applied to scale the image by a factor of 2 using the above-described interpolators In(x, y) and I′m(x, y), to get an image of size 1440×1152, and the resulting image is then scaled by a factor of 1920/1140=1.333 along the horizontal dimension and by a factor of 1080/1152=0.9375 along the vertical dimension. The second scaling stage with ratios 1.333 and 0.9375 can be implemented using conventional separable 2D interpolation filters.
The metrics computation units 21, 22, 23 compute three components of loss values respectively associated with the pixels x, y of the output image and with respective candidate directions D. It will be appreciated that other types of metrics components or other combinations of such components can be considered when implementing a scaling apparatus using the interpolators In, I′m described above. It will further be appreciated that the structure of the metrics, in particular with the axial loss component computed by unit 22, is usable with directional interpolators other than those disclosed above.
The components computed by the metrics computation units 21, 22, respectively called directional loss and axial loss, do not require prior computation of the interpolated pixel values.
The directional loss LDir[x, y, D] for a direction D at a pixel position x, y is simply a measure of the local gradient of the input image signal along that direction D. By way of example, in the case of an upscaling factor of 2 in both the horizontal and vertical dimensions, each input pixel (j, k) has four corresponding output pixels (x, y)=(j+ε/2, k+ε′/2) where ε and ε′ are in {0, 1}, and for each candidate direction D, the same directional loss value LDir[x, y, D] is taken for each of the four associated output pixels as: LDir[x, y, Dn]=|I(j+n, k+1)−I(j−n, k−1)| and LDir[x, y, D′m]=|I(j+1, k+m)−I(j−1, k−m)|. Other expressions of the gradient can be considered.
A refinement consists in adding to the directional loss component LDir[x, y, D] another component called the interval insensitive loss LInt[x, y, D] computed by the metrics computation unit 23. This interval-insensitive loss is computed using the candidate interpolated values, obtained by the interpolation processor 20, whose likelihood compared to the pixel's neighborhood in the input image is evaluated using insensitivity intervals as described in detail in WO 2007/115583.
The directional loss LDir[x, y, D] computed by the metrics computation unit 21, the axial loss LAxi[x, y, D] computed by the metrics computation unit 22 and the interval-insensitive loss LInt[x, y, D] computed by the metrics computation unit 23 can be filtered spatially using respective averaging windows in the averaging units 24, 25 and 26. A window average for a value L[x, y, D] can be defined as
where W(α, β) is an averaging window of finite (usually small) support.
The averaged loss components
In the above example where the upscaling ratio is 2 in both directions, a loss value
For each output pixel (x, y), the selector 28 determines the candidate direction D for which the loss value
It is also possible that the selector 28 identifies a predefined number of directions D for which the loss value
The axial loss value for a direction D=(u, v) measures variations of the input pixel values in one or several linear arrays of pixels which extend horizontally |u/v|>1 and vertically if |u/v|<1.
For a linear array s of p samples, s=[s(1), s(2), . . . , s(p)], a variation energy E(s) is considered for measuring the variation of the p values s(1), s(2), . . . , s(p) of the array. The variation energy E(s) can have different expressions, for example:
or:
or else
In an embodiment, the axial loss LAxi[j, k, Dn] for a direction Dn=(n, 1) (n>1) at a pixel position (j, k) of the input grid is a sum of variation energies E0=E(s0), E−1=E(s−1) and E1=E(s1), computed for three horizontal arrays s0, s−1 and s1, i.e. LAx[j, k, Dn]=E0+E−1+E1. The first horizontal array s0 has 2·a0, n+1 pixels at the vertical position of the pixel being considered:
s
0
=└I(j−a0, n, k), I(j−a0, n+1, k), . . . , I(j, k), . . . , I(j+a0, n, k)┘ (14)
The second horizontal array s−1 has a−1, n+a1, n+1 pixels at the vertical position just below and shifted horizontally by −n pixel positions to account for the slant of the interpolator In:
s
−1
=└I(j−n−a−1, n, k−1), I(j−n−a−1, n+1, k−1), . . . , I(j−n, k−1), . . . , I(j−n+a1, n, k−1)┘ (15)
Symmetrically, the third horizontal array s1 has a−1, n+a1, n+1 pixels at the vertical position just above and shifted horizontally by +n pixel positions:
s
1
=└I(j+n−a1, n, k+1), I(j+n−a1, n+1, k+1), . . . , I(j+n, k+1), . . . , I(j+n+a−1, n, k+1)┘ (16)
In this embodiment, the axial loss LAxi[j, k, D′m] for a direction D′m=(1, m) (m>1) at the pixel position (j, k) is also a sum of three variation energies E′0=E(s′0), E′−1=E(s′−1) and E′1=E(s′1), computed for three vertical arrays s′0, s′−1 and s′1, i.e. LAxi[j, k, D′m]=E′0+E′−1+E′1. The first vertical array s′0 has 2·a0, n+1 pixels at the horizontal position of the pixel being considered:
s′
0
=└I(j, k−a0, m), I(j, k−a0, m+1), . . . , I(j, k), . . . , I(j, k+a0, m)┘ (17)
The second vertical array s′−1 has a−1, n+a1, n+1 pixels at the horizontal position just left and shifted vertically by −m pixel positions to account for the slant of the interpolator I′m:
s′
−1
=└I(j−1, k−m−a−1, m), I(j−1, k−m−a−1, m+1), . . . , I(j−1, k−m), . . . , I(j−1, k−m+a1, m)┘ (18)
Symmetrically, the third vertical array s′1 has a−1, n+a1, n+1 pixels at the horizontal position just right and shifted horizontally by +m pixel positions:
s′
1
=└I(j+1, k+m−a1, m), I(j+1, k+m−a1, m+1), . . . , I(j+1, k+m), . . . , I(j+1, k+m+a−1, m)┘ (19)
The lengths of the three arrays s0, s−1, s1 or s′0, s′−1, s′1 are given by the three positive integer values a−1, r, a0, r, a1, r where r=n for a direction Dn and r=m for a direction D′m. Preferably, the integers a−1, r, a0, r, a1, r are increasing, or at least non-decreasing functions of |r|. Thus, relatively long arrays are used for directions close to the horizontal or vertical axis (|n| or |m| large) while shorter arrays are used for directions closer to ±45°.
In the illustrative example of
The arrays used for computing the axial loss can, more generally, be in a number 2Q+1, where Q is a positive integer. Then, for a given pixel a the integer position (j, k), the axial loss component L[j, k, D] for a direction D=(u, v), with |u/v|=n≠0 or |v/u|=m≠0, is a measure of variations of the pixel values in the 2Q+1 arrays sq or s′q. For D=Dn, the 2Q+1 arrays sq are horizontal and comprise, for each integer q in the range −Q≦q≦Q, a horizontal array of aq, n+a−q, n+1 pixels including the pixel at position (j+n·q, k+q). For D=D′m, the 2Q+1 arrays s′q are vertical and comprise, for each integer q in the range −Q≦q≦Q, a vertical array of aq, m+a−q, m+1 pixels including the pixel at position (j·q, k+m·q). The numbers aq, n are positive integers which are advantageously non-decreasing functions of IN (the positive integers aq, m being likewise non-decreasing functions of Imp. For q=0, the linear array is centered on the pixel (j, k), while for q≠0, there can be some asymmetry (a−q, n≠aq, n and/or a−q, n≠aq, m) as shown in
The directional loss value for pixel 502 and direction D−3 is for example LDir[502, D−3]=|I(501)−I(503)|=0, where I(501) is the image value at pixel 501 located one row above and three columns left of pixel 502 in the input grid and I(503) is the image value at pixel 503 located one row above and three columns right of pixel 502 (
The axial loss component LAxi[x, y, D], for example computed with three linear arrays as described above, is useful to overcome artifacts due to such errors in the detection of the direction of regularity. With a variation energy computed using equation (11) and a3=2, b3=c3=1 as shown by the circles in
L
Axi[502, D−3]=E0+E−1+E+1=(0.5+0.5+0+0)+(0+0)+(0+1)=2,
and LAxi[502, D′3]=E′0+E′−1+E′+1=(0+0+0+0.5)+(0+0)+(0+0)=0.5.
The axial loss component for the right direction D′3 is significantly smaller than that for the wrong direction D−3 in this example. It will make it possible for the selector 28 to make the good decision for the interpolation to be retained. It is observed that interpolating along D−3 would give a very poor result in this case, which is not an uncommon case in real images having edges between objects.
The above-described methods of analyzing an image signal for detecting directions of regularity and of scaling the image can be implemented using different hardware platforms. They are applicable, in particular, to process video signals in application-specific integrated circuits (ASIC) or field-programmable gate arrays (FPGA). Use of a general-purpose computer running appropriate programs is also possible.
In this kind of architecture, the size of the internal line buffer 45 is an important factor in terms of hardware complexity and cost. When optimizing the nonlinear scaling process, some parameters can be adjusted to limit the increase of the internal line buffer 45. For example, the one-dimensional interpolation function f used along the horizontal direction to construct the slanted interpolators can have a larger support than the one-dimensional interpolation function g used along the vertical direction. If only one of f and g has a support ]−p; p[ with p>1, it should thus preferably be g. Also, the range of values for the parameter n can be broader than that for the parameter m as mentioned above.
It will be appreciated that the embodiments described above are illustrative of the invention disclosed herein and that various modifications can be made without departing from the scope as defined in the appended claims.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/EP2011/053508 | 3/9/2011 | WO | 00 | 11/2/2012 |
Number | Date | Country | |
---|---|---|---|
61333401 | May 2010 | US |