This application is the National Stage of International Application No. PCT/EP2006/004316, filed on Apr. 12, 2006. The contents of which are hereby incorporated by reference in their entirety.
The present invention relates generally to the processing of video images and more particularly to techniques for converting video sequence formats with scaling. The multiplicity of video formats requires to adapt the format of an incoming video to the format required by a display device or for transmission. In an interlaced video, each successive image, also called field, provide alternatively in time even and odd lines. Simple Definition television (SDTV) such as NTSC, PAL and SECAM television format, are interlaced. An interlaced monitor such as a cathode ray tube (CRT) is designed to display these fields, with an interlaced scanning of even and odd lines. Progressive video image formats incorporate all lines (even and odd) in each image. LCD video monitors are designed to display progressive videos. For an input interlaced video it is thus necessary to perform a deinterlacing that compute respectively the missing odd and even lines in each field of the interlaced video sequence, to output a progressive video. Several High Definition Television formats have also been adopted, with a progressive format 720 p of 720 lines or an interlaced format 1080 i of 1080 lines. Converting an SDTV video format to an HDTV video format typically requires to perform a deinterlacing and change the number of lines from say 486 for NTSC to 720 for 720 p HDTV.
Deinterlacing and changing the number of lines of a video sequences is a scaling operation that converts an input video defined on an interlaced sampling grid to an output video defined on a output sampling grid. A deinterlacing is a scaling where the output sampling grid include both even and odd lines. A further modification of the number of lines further modifies the output sampling grid. Scaling videos requires to compute pixel values on a prescribed output sampling grid from the pixel values of the input video defined on a different input sampling grid.
A first approach is to compute each output video image at a time t from the input video image at t using an FIR filtering to perform a spatial interpolation that computes samples on the output grid from the input sample values. When the input image is interlaced, it is sampled much below the Shannon sampling rate, and interpolations thus produce artifacts that are highly visible in the resulting video. Directional interpolations can partly reduce these artifacts but not completely because the information necessary to perform the interpolation is not available. If the input image is progressive, increasing the sampling density also produce a blurred image. U.S. Pat. No. 6,614,489 provides an example of this approach.
A second approach called “motion adaptive” performs a time interpolation if no motion is locally detected in the image or a spatial interpolation if a significant motion is detected. In presence of significant motion, these techniques implement a spatial interpolations and thus produce the same type of artifacts as spatial interpolation techniques. U.S. Pat. No. 5,428,398 provides an example of this approach.
A third approach called “motion compensated,” measures the displacement in the image and perform an interpolation in time that takes into account the measure motion. By combining the information of several images in time, such techniques can improve the spatial resolution of the image after scaling and restore finer details. This is called a super-resolution processing. Yet, existing motion compensated techniques are unstable and introduce visible artifacts. Indeed, computing precisely the displacement of image pixels is difficult, specially with interlaced images that are undersampled. Motion discontinuities at occlusions or fine scale motions such as produced by dust, or motion transparencies produce motion estimation errors that yield artifacts when using these motion vectors for time interpolation. To reduce these artifacts, motion compensated scaling procedures perform a spatial interpolation when the confidence in the measured motion is not sufficient. The reduction of motion artifacts is then performed at the cost of introducing artifacts introduced by the spatial scaling. U.S. Pat. No. 6,940,557 provides an example of this approach.
None of the state of the art procedures for video scaling fully takes fully advantage of the space-time information provided by an input-video sequence in order to perform a super-resolution scaling of high quality. Therefore, it is an object of the present invention to obviate or mitigate at least some of the above-mentioned disadvantages to convert video sequences with a scaling procedure.
It is a primary object of this invention to devise a method and means to perform a robust super-resolution scaling of an input video, that may include a deinterlacing.
The method according to the invention processes a video signal with input images defined on a spatio-temporal input grid. It outputs a video on a predefined spatio-temporal output grid. Calculations are performed on a spatio-temporal new grid of new points that are points of the output grid that are not in the input grid.
The invention applies a predefined family of parameterized interpolators which are linear operators that implement a parameterized weighted averaging of the input video values in spatio temporal neighborhoods of each new point of the new grid, to output a parameterized interpolation at each new point. As opposed to motion adaptive or motion compensated techniques that estimate the motion and make a decision between spatial or time interpolation along the estimated motion to compute an interpolation, no motion estimation is required in this invention and errors commonly generated by such motion estimation are thus alleviated. Instead of estimating a motion to optimize an interpolation, a whole family of possible interpolators are computed and a best interpolator is selected with a robust maximum likelihood technique, which minimizes a loss defined from a negative log-likelihood.
At each new point, the method estimates a conditional probability distribution of the new point value given the input video values in a spatio-temporal neighborhood. Because of the limited amount of data available in such a neighborhood and the large variability of the video values, an interval insensitive probability distribution is used to obtain robust results. For each new point, an interval is estimated from input image values in a spatio-temporal neighborhood of this new point, such that the probability density of the output image value at this new point is estimated to have its maximum within this interval of values.
For each new point, the invention computes for each parameterized interpolation an insensitive loss value based on an second probability distribution, which is constant and maximum within the interval of values associated with said new point. The second probability distribution is also referred to herein as “interval-insensitive”. This insensitive loss can be representative of a negative log-likelihood of said interpolated value relatively to the interval-insensitive probability distribution defined from the interval of values associated with said new point.
For each parameterized interpolator, the insensitive loss is filtered spatially in order to be regularized with a weighted sum in a spatial neighborhood of each new point and this regularized loss is provided in input of a minimum loss selection process.
For each new point of said new grid, the invention selects a best parameterized interpolation which minimizes the regularized loss among all parameterized interpolations at this new point. It then outputs a video whose value at each output point of the output grid is either equal to the input video value if this output point is in the input grid or is equal to the best parameterized interpolation at this output point if this output point is a new point.
In this invention, for each new point the insensitive interval can be estimated with a robust process that divides the spatio-temporal neighborhood of the new point into a plurality of sub-neighborhoods. For each sub-neighborhood a partial insensitive interval is estimated from two values of specified rank obtained by sorting input image values in this sub-neighborhood, and a single insensitive interval is obtained by combining this plurality of partial insensitive intervals.
In this invention, the interval-insensitive probability distribution can be the Vapnik interval insensitive probability distribution that has an exponential decay outside the insensitive interval.
The method according to the invention can further comprise a penalization of the insensitive loss by a total variation increment. This penalization provides a control over the oscillations introduced by the selected best interpolation. For each parameterized interpolator and for each new point the method can include the computation of a total variation increment resulting from an aggregation of input image values and interpolated values calculated by the parameterized interpolator, in a one-dimensional neighborhood of the new point. This one-dimensional neighborhood can be chosen to be horizontal or vertical. For each parameterized interpolator this total variation increment is filtered spatially with a weighted sum in a spatial neighborhood of each new point and this regularized total variation increment is provided in input of the minimum loss selection process. For each new point, the regularized insensitive loss can be penalized by the regularized total variation increment at said new point so that the selected best parameterized directional interpolation minimizes this penalized regularized insensitive loss among all parameterized interpolations at the new point.
In this invention, the parameterized interpolators can be parameterized directional interpolators that compute linear interpolations along parameterized spatio-temporal directions of the input grid.
The method according to the invention can further comprise a penalization of the insensitive loss by a directional matching error. For directional penalized interpolators, this penalization ensures that input image values have little variations in the spatio-temporal direction of the selected best interpolation. For each parameterized directional interpolator along a parameterized spatio-temporal direction and for each new point, a directional matching error is computed from the difference of interpolated input video values aligned with the new point along the spatio-temporal direction. For each parameterized directional interpolator, the directional matching error is filtered with a weighted sum in a spatial neighborhood of each new point and this regularized matching error is provided in input of the minimum loss selection process. For each new point the regularized insensitive loss is penalized by the regularized matching error to select a best parameterized directional interpolation which minimizes this penalized regularized insensitive loss among all parameterized interpolations at this new point. For each new point the regularized insensitive loss can also be penalized both by the regularized total variation increment and by the regularized matching error at this new point, to select a best parameterized directional interpolation.
The method of the present invention applies in particular to input video which are interlaced in order to output a video that is progressive. For such a deinterlacing, the method according to the invention can further comprise a classification of the input image into “Telecined Film Type”, or “Interlaced Video Type” and which specifies if the input image is mostly similar to the “Previous” input image or to the “Next” input image. It then modifies the selection of the best parameterized directional interpolation at each new point, which either minimizes the penalized regularized insensitive loss at this new point or which is a copy from the “Next” or “Previous” image value at this new point location, depending upon the image class.
Another aspect of the invention relates to a digital video scaling method for processing an input video signal having respective input image values at points of a space-time input grid to deliver an output video signal having respective output image values at points of a space-time output grid including points of said input grid and new points. The method comprises the following steps for each of these new points. Applying a predefined family of parameterized linear interpolators to the input images values in a respective space-time neighborhood of the new point to provide an interpolated value at the new point for each interpolator of the family. For each interpolator of the family, computing a total variation increment resulting from an aggregation of input image values and interpolated values calculated with the interpolator in a one-dimensional spatial neighborhood of the new point. For each interpolator of the family, filtering spatially the total variation increment in a spatial neighborhood of the new point. Selecting an interpolator of the family which fulfills a minimization criterion depending on the filtered total variation increment, wherein the interpolated value for the selected interpolator is taken as the output image value at the new point. Such minimization criterion typically combines the filtered total variation increment with another cost or loss value which advantageously consists of the filtered loss value derived from the interval-insensitive probability distribution as described hereabove. However, other cost or loss functions can also be used in alternative embodiments of the invention.
The invention also includes a television system for displaying images on a television display comprising means for receiving an input video signal, means for processing the input video signal in accordance with a method as disclosed above, and means for displaying an output video signal produced by the processing means.
The invention also includes a video scaling apparatus, comprising computer means arranged to carry out a method as disclosed above.
The invention also includes a computer program product, comprising instructions to carry out a method as disclosed above, when the program is run in a computer processing unit.
The foregoing and other objects of this invention, the various features thereof, as well as the invention itself, may be more fully understood from the following description, when read together with the accompanying drawings in which:
The image value is typically a multicomponent value. For example, in the YCbCr colorspace, each grid point has a Y component that specifies the luminance and two chroma component Cb and Cr that together specify the color. The processing is described herein on a single component and thus the image value v(n1, n2, t) is used to specify any single component value. However, several alternatives that process simultaneously all the components are possible and are described further below.
The super-resolution system of
At each time t, the super-resolution scaling system takes in input an image v(n, t+d) and it outputs an image {circumflex over (v)}(n, t) with a delay d that is typically between 1 and 5. A new grid {tilde over (G)} is defined as the set of all points of the output grid Ĝ which do not belong to G. A new point is a point of the new grid.
The calculation of {circumflex over (v)}(n, t) is performed with a maximum likelihood approach. A family of interpolators that is defined a priori provides a family of image values at each new point. A conditional probability distribution for the unknown new point values is estimated from the observed input image values in the neighborhood of each new point.
The apparatus includes a parameterized interpolation module (101) which takes in input the input video and apply a family of linear interpolators {Eγ}γεΓ, indexed by a multiparameter γ in a predefined parameter set Γ. The module (101) outputs at each new grid point {circumflex over (x)}(n, t)ε{tilde over (G)} a family of interpolated values {{circumflex over (v)}γ(n, t)}γεΓ. A linear interpolator Eγ computes {circumflex over (v)}γ(n, t) in {circumflex over (x)}(n, t)ε{tilde over (G)} with a parameterized weighted averaging of the input image values v(n′, t−s) for |s|≦d:
The two-dimensional interpolation kernel Kγ(x) has a finite support so the sum (1) is evaluated on a finite number of terms where x(n′, t−s)) is sufficiently close to {circumflex over (x)}(n, t). Any state of the art interpolators may be used in the present invention. An exemplary embodiment of directional spatio-temporal interpolators is described later. The interpolations are implemented with separable one-dimensional linear interpolations along different directions. A one-dimensional linear interpolation at u from values f(p) can be calculated with an FIR linear filtering:
where the interpolation kernel K has a support included in [−Δ, Δ] and satisfies Σp=−ΔΔK(u−p)=1 for all uε[0, 1]. Typically, Δ is between 1 and 8.
Insensitive Log-Likelihood
The choice of a best interpolation at each new point {circumflex over (x)}(n, t) is advantageously performed by minimizing a negative log-likelihood calculated from the neighborhood input video values v(p, t). The conditional probability distribution of a new point image value knowing neighborhood input image values is estimated with an insensitive interval inside which this probability distribution is estimated to be maximum and constant because of a lack of data that can discriminate the probability distribution value inside this interval. The distance between a point x and an interval I=[a, b] is written:
An interval insensitive probability distribution pI(u) is defined for I=[a, b] and ε=b−a by
where for any fixed ε, f(0, ε)=1 and f(u, ε) is a monotonically decreasing function of u, and η is adjusted so that ∫pI(u)dx=1. Any choice of f(u, ε) is possible. Vapnik robust interval insensitive probability distribution is defined by
which corresponds to f(ε, u)=exp(−u). One may also choose f(ε, u)=exp(−u/ε).
The apparatus has an insensitive interval estimation module (102) to compute for each new point {circumflex over (x)}(n, t)ε{tilde over (G)} an insensitive interval I(n, t)=[a(n, t), b(n, t)] in which the output image value at {circumflex over (x)}(n, t) is likely to be located but inside which there is no significant information to discriminate the probability of different values. The interval I(n, t) is calculated from input image values v(n′, t′) where x(n′, t′) is in a specified neighborhood N(n, t) of {circumflex over (x)}(n, t). Let C(n, t) be the number of points in this neighborhood. In an exemplary embodiment, a neighborhood N(n, t) of {circumflex over (x)}(n, t) is defined as a set of input grid points x(n′, t′) with |t−t′|≦d and where the spatial coordinates of x(n′, t′) are in a spatial square of width 2Δ centered in the spatial coordinates of {circumflex over (x)}(n, t), where Δ is a predefined parameter. Typically, Δ is between 1 and 5.
In an exemplary embodiment, an insensitive interval is computed from the mean m(n, t) and the standard deviation σ(n, t) of all points in the neighborhood
The module (102) sets I(n, t)=[m(n, t)−βσ(n, t), m(n, t)+βσ(n, t)] where β is a constant typically smaller than 3. In another embodiment, the module (102) estimates an insensitive interval from the ranked statistics of the points in N(n, t). We denote by {vk}1≦k≦C(n,t) the C(n, t) ranked values of N(n, t) with vk≧vk+1. Let p be a positive integer with p<C(n, t)/2. If C(n, t) is even then k1=C(n, t)/2−p+1 and k2=C(n, t)/2+p and if C(n, t) is odd then k1=(C(n, t)+1)/2−p and k2=(C(n, t)+1)/2+p. A ranked statistics insensitive interval I(n, t)=[a(n, t), b(n, t)] is defined by a(n, t)=vk
In yet another exemplary embodiment, the insensitive interval estimation is implemented by partitioning N(n, t) into a plurality of disjoint subsets N(n, t)=∪i=1kNi(n,t). An insensitive interval Ii(n, t) is calculated from each Ni(n, t) with any procedure such as a mean and standard-deviation procedure or a ranked statistics procedure. These insensitive intervals are then combined to form a single insensitive interval. In an exemplary embodiment, N(n, t) is separated into the set N1(n, t) of all points x(n′, t′)εN(n, t) for t′=t and the set N2(n, t) of all points x(n′, t′)εN(n, t) for t′≠t. If the two insensitive intervals I1(n, t) and I2(n, t) have a non-empty intersection the final insensitive interval I(n, t) is defined as this intersection, otherwise the interval I(n, t) can be set as the union of the two intervals.
The apparatus further includes an insensitive loss calculation module (103) which outputs for each interpolator Eγ and each new point {circumflex over (x)}(n, t)ε{tilde over (G)} the negative log likelihood of {circumflex over (v)}γ(n, t) relatively to the interval insensitive probability distribution calculated for I(n, t)=[a(n, t), b(n, t)]. The goal is to minimize this loss so additive constants can be removed from the log-likelihood. As a result of (2), this loss becomes for ε(n, t)=b(n, t)−a(n, t):
For Vapnik robust interval insensitive probability distribution (3), this loss becomes
A spatial regularization module (104) takes in input the insensitive loss lγ(n, t) calculated at each new point {circumflex over (x)}(n, t)ε{tilde over (G)} and for each γεΓ and performs a spatial low-pass filtering to compute a regularized loss over a spatial neighborhood Ñ1(n, t) by making a weighted sum over this neighborhood. In an exemplary embodiment, Ñ1(n, t) is a rectangle centered at {circumflex over (x)}(n, t) which contains a fixed number C1 of new grid point, and all weights are set to 1. The regularization is thus calculated as a sum over these C1 points, typically between 16 and 256,
Any state of the art fast algorithm can be used to evaluate this sum. In another exemplary embodiment this sum is replaced by a weighted sum where the sum of all weights in Ñ1(n, t) is equal to a constant that remains the same for all new points {circumflex over (x)}(n, t)ε{tilde over (G)}.
The apparatus shown in
The loss selection module (105) outputs for each new point the minimum loss interpolation {circumflex over (v)}φ(n,t)(n, t).
The input/new grids aggregation module (106) takes in input the minimum loss interpolation {circumflex over (v)}φ(n,t)(n, t) at each new point {circumflex over (x)}(n, t)ε{tilde over (G)} and the input video values v(p, t) and it outputs a super-resolution video defined over the output grid Ĝ. For each new point {circumflex over (x)}(n, t)ε{tilde over (G)}, the aggregation module (106) outputs the minimum loss interpolation {circumflex over (v)}(n, t)={circumflex over (v)}φ(n,t)(n, t). For each output point that is in the input grid {circumflex over (x)}(n, t)=x(p, t)εG, the aggregation module (106) outputs the corresponding input video value {circumflex over (v)}(n, t)=v(p, t).
While a detailed description of exemplary embodiments of
The apparatus described above process a single component of the video image. For multicomponents image, all components can be processed independently. Another possibility included in this invention is to process simultaneously all the components and define the insensitive loss of module (103) as a weighted sum of the insensitive loss obtained for each component, and thus choose the same best interpolator Et for all components at any given new grid point.
Total Variation Penalization
The method according to the invention can further comprise a penalization of the insensitive loss by a total variation increment. This penalization provides a control over the oscillations introduced by the selected best interpolation.
The apparatus illustrated in
A vertical one-dimensional neighborhood of {circumflex over (x)}(n, t)ε{tilde over (G)} is a vertical segment of size L centered at {circumflex over (x)}(n, t). The value of L is a parameter that is typically between 1 and 15. From top to bottom, we denote by {ĥl}l the vertical coordinates of the new points of {tilde over (G)} that are in the vertical neighborhood of {circumflex over (x)}(n, t), and by {{circumflex over (v)}l}l the corresponding interpolated values calculated with Eγ.
For each new point in the vertical neighborhood of vertical coordinate ĥl, either there are two consecutive input image points of coordinates hk and hk+1 such that hk>hl≧hk+1 or this points corresponds to the bottom-most or top-most point in the vertical segment. If the first condition is satisfied, the total variation increment produced by the insertion of {circumflex over (v)}l between vk and vk+1 is equal to the distance between {circumflex over (v)}l and the interval Ik=[min(vk, vk+1), max(vk, vk+1)], written |{circumflex over (v)}l−Ik|. This distance is calculated for each new points in the vertical neighborhood located between two input image points values.
Conversely, for each input point in the vertical neighborhood of vertical coordinate hk, either there are two consecutive new points of coordinates ĥl′ and ĥl′+1 such that ĥl′>hk≧ĥl′+1 or this points corresponds to the bottom-most or top-most point in the vertical segment. The total variation increment produced by the insertion of vk between {circumflex over (v)}l′−1 and {circumflex over (v)}′l is equal to the distance between vk and the interval Îl′=[min({circumflex over (v)}l′, {circumflex over (v)}l′−1), max({circumflex over (v)}l′, {circumflex over (v)}l′−1)], written |vk−Îl′|. This distance is calculated for each vk located between two new point image values {circumflex over (v)}l′−1 and {circumflex over (v)}′l.
The resulting total variation increment measure of the estimator Eγ in the vertical neighborhood of {circumflex over (x)}(n, t) is written wγ(n, t). It is calculated by aggregating the total variation increments obtained for all input points vk located between two new point image values {circumflex over (v)}l′−1 and {circumflex over (v)}′l and all interpolated values {circumflex over (v)}l located between two input image points values vk and vk+1 in this vertical neighborhood. In an exemplary embodiment, wγ(n, t) is a weighted average of all these total variation increments. In yet another exemplary embodiment it is obtained from a ranked statistics over all these total variations increments. The wγ(n, t) value is obtained as the p value in the ranked list of all total variations increments with p a fixed positive integer.
The spatial regularization module (206) shown in
In another exemplary embodiment this sum is replaced by a weighted sum where the sum of all weights in Ñ2(n, t) is equal to a constant that remains the same for all new points {circumflex over (x)}(n, t)ε{tilde over (G)}.
The minimum loss selection module (207) takes in input for each new point {circumflex over (x)}(n, t)ε{tilde over (G)} and for each interpolator Eγ the regularized interval insensitive loss {circumflex over (l)}γ(n, t) and the regularized total variation ŵγ(n, t) and computes a penalized loss
where λ is a predefined penalization constant, typically between 1 and 10. The module (207) finds the parameter φ(n, t)εΓ of the best interpolator which minimizes the penalized loss
and it outputs for each new point the minimum loss estimation {circumflex over (v)}φ(n,t)(n, t).
The total variation penalization can be applied to a loss measure that is different from the interval insensitive loss described with reference to
As in the apparatus described in
Parameterized Directional Interpolations
The parameterized directional interpolators module (301) takes in input the input video and computes at each new grid point {circumflex over (x)}(n, t)ε{tilde over (G)} a family of interpolation values {{circumflex over (v)}γ(n, t)}γε/Γ obtained by applying a family of linear interpolators {Eγ}γεΓ, indexed by a multiparameter γ, that includes a direction parameter. In a preferred embodiment, these parameterized directional interpolators are calculated with one-dimensional interpolations along the rows or columns of the input image and with directional interpolations along parameterized spatio-temporal directions. Any state of the art procedure may be used for the one-dimensional interpolations.
The directional matching error module (307) receives the input video and computes at each new grid point {circumflex over (x)}(n, t)ε{tilde over (G)} a family of directional matching errors {eγ(n, t)}γεΓ associated to the parameterized directional interpolators {Eγ}γεΓ. In a preferred embodiment, these matching errors are calculated from differences between input image values along each parameterized direction. These directional matching errors quantify the input video variations in the spatio-temporal direction of each directional interpolator.
In a preferred implementation, interpolators are parameterized by a spatio-temporal direction that is specified by a spatial vector w=w1τ1+w2τ2=(w1, w2, 0) and a time increment which specifies input images v(p, t−s) and v(p, t+s) from which the interpolated value at {circumflex over (x)}(n, t) is calculated. These interpolators are thus specified by the multiparameter value γ=(w1, w2, s) that is chosen among a predefined family of r of spatio-temporal parameters.
The maximum value of the time-shift s over Γ is the delay d of the super-resolution system. The images x(n, t+s) up to s=d are needed to estimate the new point values vγ(n, t) and we must keep in memory the 2d+1 images x(n, t′) for t−d≦t′≦t+d to perform these estimations.
If s=0 then {circumflex over (v)}γ(n, t) is calculated with a spatial interpolator from the input image v(n′, t). This spatial interpolation is performed with a separable interpolations along first a preferential orientation that is either horizontal or vertical, and then along the spatial direction w=(w1, w2, 0). If the input video is interlaced, the preferential interpolation direction is chosen to be horizontal because the sampling distribution is twice larger along rows than columns. If the input video is progressive, the preferential interpolation direction can be chosen to be vertical if the angle of (w1, w2) with the horizontal (1, 0) is smaller than π/4 in which case we normalize w1=1, and the preferential interpolation direction is horizontal if the angle of (w1, w2) with the horizontal is bigger than π/4, in which case we normalize w2=1.
Suppose that the preferential interpolation direction is horizontal at {circumflex over (x)}(n, t) and hence that w=(w1, 1). If {circumflex over (x)}(n, t) is located on a row of the input grid, then vγ(n, t) can be calculated with a one-dimensional linear interpolation along this row at {circumflex over (x)}(n, t). If {circumflex over (x)}(n, t) is not located on a row of the input grid then its position can be written {circumflex over (x)}(n, t)=x1τ1+αx2τ2+τ4(t)+tτ3, and let n2 be the unique integer such that n2<x2<n2+1. Let y={circumflex over (x)}(n, t)+α(n2+1−x2)w and z={circumflex over (x)}(n, t)−α(x2−n2)w be the projection of {circumflex over (x)}(n, t) in the direction of w, on the input image row just above and just below. The image values vy at y is obtained by interpolating the input image value along the row v(n′, t) for n′=(p, n2) with a one-dimensional interpolation along the variable p, and the image value vz at z is obtained by with a one-dimensional interpolation of the input image values along the row v(n′, t) for n′=(p, n2+1). In an exemplary embodiment, the image interpolation at {circumflex over (x)}(n, t) is defined with a first order linear interpolation between vy and vz:
{circumflex over (v)}γ(n,t)=(n2+1−x2)vy+(x2−n2)vz. (6)
The directional matching error calculated by the module (307) for the interpolator Eγ at {circumflex over (x)}(n, t) is the directional variation in the direction of w, between vy and vz:
eγ(n,t)=|vy−vz|η (7)
where η>0 is a fixed exponent that is chosen a priori, typically equal to 1 or 2. In the particular case of a deinterlacing with unit scale then x2=n2+½ and hence {circumflex over (v)}γ(n, t)=(vy+vz)/2. This case is illustrated in
When the preferential interpolation direction is vertical rather than horizontal, w=(1, w2) and the same computations apply for the interpolators, by exchanging the roles of the horizontal and vertical coordinate axes, as well as of the input image rows and columns and by replacing α by 1.
If s>0, the spatio-temporal projection of {circumflex over (x)}(n, t) in the images at t−s and t+s are located at y={circumflex over (x)}(n, t)−w−sτ3 and z={circumflex over (x)}(n, t)+w+sτ3. The image value vy at the position y is calculated with a separable interpolations along the rows and columns of the input image values v(n′, t−s) at the grid points x(n′, t−s). Similarly the image value vz at the position z is calculated with separable interpolations along the rows and columns of the input image values v(n′, t+s) at the grid points x(n′, t−s). The estimated image value at {circumflex over (x)}(n, t) is {circumflex over (v)}65(n, t)=(vy+vz)/2 and the directional matching error is eγ(n, t)=|vy−vz|η.
In a preferred embodiment, the set of all possible directions w are chosen so that for each new point {circumflex over (x)}(n, t) the projected positions y and z at t−s and t+s are located on a uniform grid that is precalculated by oversampling the input images v(n′, t−s) and v(n′, t+s) by fixed factors along their rows and columns.
For a deinterlacing system, the preferential spatial interpolation direction is horizontal. In an exemplary embodiment, with unit scale, for s=0 the family of spatial direction vectors w is {(k/q, 1, 0)}−K≦k≦K where q is a fixed integer.
The spatial regularization module (308) shown in
In another exemplary embodiment this sum is replaced by a weighted sum where the sum of all weights in Ñ3 (n, t) is equal to a constant that remains the same for all new points {circumflex over (x)}(n, t)ε{tilde over (G)}.
For a deinterlacing system with unit scale, to incorporate the case of deinterlacing input videos that are in a telecined film format, two simple interpolators that perform a copy from a previous and a next image are incorporated. We write Eγ
For a deinterlacing system, the scaling system can include a global video/film classifier (309) which outputs for each input image v(n, t) an image class c(t), which specifies if the image belongs to an “Interlaced Video Type” sequence or a “Telecined Film Type” sequence. The “Interlaced Video Type” category indicates that the image is a field of an interlaced video. The “Telecined Film Type” category indicates that the input image is a telecined film field. Each of these classes are refined by specifying if the image v(n, t) is mostly similar to the “Previous” input image or to the “Next” input image. The four classes are thus “Telecined Film Type, Next”, “Telecined Film Type, Previous”, “Interlaced Video, Next” and “Interlaced Video, Previous”.
In a first embodiment, the global video/film classifier (309) has a user interface that allows a user to specify if the image is an “Interlaced Video Type” image or a “Telecined film Type” image. In an automatic embodiment of the module (309), the classification is performed with global total variation increment measures. For each new point {circumflex over (x)}(n, t) the total variation increment module (305) outputs the total variation increment wγ(n, t) corresponding to each interpolator Eγ and in particular for γ=γp and γ=γn, which correspond to copy from previous and next images The module (309) takes in input these total variation increments Eγ
with η1>1 typically smaller than 10 and with η2>1 typically smaller than 10, then the image class c(t) is set to be a “Telecined Type” image. Otherwise, for a threshold T, that is set a priori typically between 1 and 50 for 1 byte images, if
then c(t) is also set to be “Telecined Film Type”. Otherwise c(t) is set to be an “Interlaced Video Type” image. In either cases, if Wγ
The minimum loss selection module (310) takes in input for each new point {circumflex over (x)}(n, t)ε{tilde over (G)} and for each interpolator Eγ the regularized interval insensitive loss {circumflex over (l)}γ(n, t), the regularized total variation increment ŵγ(n, t) and the regularized directional matching error êγ(n, t). It computes a penalized loss and given the image class c(t) it performs a conditional minimization that finds the parameter φ(n, t) of the best interpolator. The module (310) outputs for each new point the minimum loss estimation {circumflex over (v)}φ(n,t)(n, t).
If the scaling system is not a deinterlacing system with unit scale, then for each new point {circumflex over (x)}(n, t) the regularized insensitive loss is penalized by the input total variation increment and the directional matching error:
where λ and μ are two penalization constants. Typical choices for λ and μ is between 1 and 10. The minimum loss selection module (310) finds the parameters ξ which minimizes this penalized loss excluding the two copy interpolators:
and it sets φ(n, t)=ξ.
If the scaling system is a deinterlacing system with unit scale, then the best interpolator choice depends upon the output of the global video/film classifier (309). If the image class c(t) is “Telecined Film Type, Next” then it sets φ(n, t)=γn an which corresponds to a copy from the next image. If the image class c(t) is “Telecined Film Type, Previous” then φ(n, t)=γp which corresponds to a copy from the previous image. If the image class is “Interlaced Video Type” then the minimum loss interpolator index ξ is calculated as in (9). If the image class c(t) is “Interlaced Video Type, Next” then this best interpolator is compared with a copy from the next image interpolator for locally telecined sequence. If
{circumflex over (l)}ξ(n,t)+λ′ŵξ(n,t)<{circumflex over (l)}γ
where λ′ is a penalization constant then φ(n, t)=ξ, otherwise φ(n, t)=γn. A typical choice for λ′ is between 1 and 10. In a similar way, if the image class c(t) is “Interlaced Video Type, Previous” then if
{circumflex over (l)}ξ(n,t)+λ′ŵξ(n,t)<{circumflex over (l)}γp(n,t)+λ′ŵγ
where λ′ is a penalization constant then φ(n, t)=ξ and otherwise φ(n, t)=γp.
As in the apparatus described in
For multicomponents image, all components can be processed independently. Another possibility included in this invention is to process simultaneously all the components and define the penalized loss of module (310) as a weighted sum of the penalized loss obtained for each component, and thus choose the same best interpolator Eγ for all components at any given new grid point.
The present invention may be embodied as software run by general-purpose micro-processor or digital signal processor, in which case the modules described above with reference to
While a detailed description of exemplary embodiments of the invention has been given above, various alternative, modifications, and equivalents will be apparent to those skilled in the art. For example, while different components of the parameterized interpolator module or the minimum loss selection modules of the present invention are described herein as performing certain specific functions, one skilled in the art will appreciate that other components or circuits in the service module may perform some or all of such functions without varying from the spirit of the invention. Therefore the above description should not be taken as limiting the scope of the invention which is defined by the appended claims.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/EP2006/004316 | 4/12/2006 | WO | 00 | 12/16/2008 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2007/115583 | 10/18/2007 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
5428398 | Faroudja et al. | Jun 1995 | A |
5661525 | Kovacevic et al. | Aug 1997 | A |
5936676 | Ledinh et al. | Aug 1999 | A |
6181382 | Kieu et al. | Jan 2001 | B1 |
6577345 | Lim et al. | Jun 2003 | B1 |
6614489 | McIntyre et al. | Sep 2003 | B1 |
6940557 | Handjojo et al. | Sep 2005 | B2 |
7190406 | Ji et al. | Mar 2007 | B2 |
7567294 | Lu et al. | Jul 2009 | B2 |
7613364 | Kang et al. | Nov 2009 | B2 |
7982799 | Niedermeier | Jul 2011 | B2 |
Number | Date | Country | |
---|---|---|---|
20090278981 A1 | Nov 2009 | US |