The present invention relates to an image processing technology which reduces noise when an image is taken and a deterioration of a deteriorated image.
Priority is claimed on Japanese Patent Application No. 2011-051443, filed Mar. 9, 2011, the content of which is incorporated herein by reference.
Terms used in the present description are defined as follows.
“Search shape”: an aggregate of search points around a target pixel of template matching, or the shape formed by the aggregate.
“Template shape”: a group of pixels used for calculating the degree of similarity between the target pixel and each search point when the template matching is performed, or the shape formed by the group of pixels. The same shape is used for a group of pixels around the target pixel and for a group of pixels around each search point, and the values of pixels at positions having the same relative positional relationship are compared with each other.
In the field of image processing, as a technique of reducing noise when an image is taken and a deterioration of a deteriorated image, various denoising filters have been proposed. Among other things, it is known that denoising filters in accordance with a non-local means method (refer to Non-Patent Document 1) demonstrate a high denoising effect. Hereinafter, denoising filters in accordance with the non-local means method are referred to as NLM filters.
In the NLM filter, corresponding pixels in the template shape T0 of the comparison source and the template shape Ts of the search target are compared with each other, and the degree of similarity between the templates is calculated. In general, calculation of the degree of similarity between templates uses a sum of square difference (SSD) or a sum of absolute difference (SAD).
The NLM filter execution unit 1000 calculates a denoised pixel value for each pixel as follows. In the following, an example which uses SSD for calculating the degree of similarity between templates will be described.
(2) The following processes are repeated for all the search points within a search shape.
(denoised pixel value)=sum of pixel values SP/sum of weights SW
The NLM filter execution unit 1000 performs a denoising process using a single value and a single shape for all the pixels of a denoising target image when a single value is given as each of the input denoising coefficient, the input search shape, and the input template shape, and performs a denoising process while switching a value and shapes for each corresponding point when a group of pieces of data corresponding to each pixel is given.
Moreover, in order to remove coding distortion, a denoising filter with a deblocking filter is installed in the “HM”, which is a test model of “High Efficiency Video Coding” of next-generation video coding standards, for which international standardization activities are currently being performed by the “Moving Picture Experts Group (MPEG)” and the Video Coding Experts Group (VCEG)” (refer to Non-Patent Document 2).
Non-Patent Document 1: A. Buades, B. Coll, and J. M. Morel, “A non-local algorithm for image denoising”, Proc. IEEE Int. Conf. on Computer Vision and Pattern Recognition, vol. 2, pp. 60-65, June, 2005.
Non-Patent Document 2: Thomas Wiegand, Woo-Jin Han, Benjamin Bross, Jens-Rainer Ohm, and Gary J. Sullivan, “WD1: Working Draft 1 of High-Efficiency Video Coding”, ITU-T SG16 WP3 and ISO/IEC JTC1/SC29/WG11 3rd Meeting: Guangzhou, CN, 7-15 October, 2010.
As described above, in order to remove coding distortion, a denoising filter with a deblocking filter is installed in the “HM” of the “High Efficiency Video Coding” of the next-generation video coding standards, but it is conceivable that the coding efficiency be increased compared to conventional deblocking filters if the above NLM filter is introduced into the HM.
However, the computational complexity of the NLM filter is enormous, so that there is a possibility that a computation time required for decoding is greatly increased if a decoding apparatus calculates NLM filters for all the pixels.
As described above, template matching is performed on each denoising target pixel and each search point within an arbitrary search shape using an arbitrary template shape to calculate the degree of similarity between templates. As a result, assuming that, for example, the template shape is an N×N block and the search shape is M×M, the computational complexity of the order of N2×M2 is required for performing a denoising calculation for one pixel. Therefore, in order to use the NLM filter in a decoding apparatus and so on, a technology of reducing the computational complexity is required.
An object of the present invention is to solve the above problems and provide a technology of reducing the computational complexity of a denoising filter while suppressing a reduction in coding efficiency. It is to be noted that as the coding efficiency, for example, a BD-rate, which is one of international evaluation techniques and is calculated from the image quality and the amount of bits, is used herein.
In order to solve the above problems, the present invention executes the following processes in image processing which performs template matching between a template which is a comparison source for a denoising target pixel in a denoising target image and a template for each of search points which are search targets within a search shape in the denoising target image and removes noise of the target pixel using weights in accordance with the degrees of similarity between the templates and the weighted sum of pixel values at the search points.
Moreover, the present invention applies the above image processing to a loop filter (corresponding to a conventional deblocking filter) in video encoding or decoding.
Furthermore, in the present invention, the following processes may be executed in addition to the above processes (1) to (3) when the above image processing is applied to the loop filter in the video encoding or decoding.
Moreover, the following process (6) may be further added.
As described above, the process (1) detects the edge direction in the denoising target image, and the process (2) limits the search shape for each pixel in the denoising target image so as to maintain the search points along the edge direction of the process (1) and reduce the search points along the direction perpendicular to the edge direction. As a result, it is possible to reduce the computational complexity of a denoising filter.
Moreover, it is possible to reduce the computational complexity of a loop filter while suppressing a reduction in coding efficiency by combining the above image processing with video encoding/decoding processing and applying them to the loop filter. Furthermore, although conventionally a template shape is uniquely given for the entire frame as a fixed value, it is possible to reduce the computational complexity of template matching by introducing a process of limiting a template shape for each pixel with the above processes (4) and (5). Additionally, it is possible to further reduce the computational complexity by further executing the process (6).
The following are advantageous effects of the present invention.
The present invention limits a search shape and reduces the number of search points which are targets for template matching, so that the number of calculations for the template matching is reduced and it is possible to reduce the computational complexity.
Moreover, it is possible to realize a reduction in computational complexity while suppressing a reduction in coding efficiency by applying the present invention to a loop filter in the video encoding/decoding.
Furthermore, introduction of a process of limiting a template shape to reduce the number of pixels in templates between which comparison is performed results in a reduction in the number of comparisons between the pixels, so that it is possible to reduce the computational complexity. That is, since template matching is performed at each search point, a combination of a technique of limiting a search region with a technique of limiting the template shape makes it possible to synergistically reduce the computational complexity because calculation of a further limited template shape is performed within the limited search shape.
Hereinafter, embodiments of the present invention will be described with reference to drawings.
In this image processing apparatus 10, the denoising filter processing unit 101 inputs four pieces of information including a denoising coefficient, a search shape, a template shape, and a denoising target image and outputs a filtered image, from which noise has been removed.
The edge direction detection unit 102 detects edge directions of the denoising target image and outputs a group of edge directions corresponding to pixels in the denoising target image. As an example of the edge directions, there is a group of numbers or a group of angles that are numbered in accordance with the directions.
The search shape setting unit 103 inputs the search shape, sets the input search shape as the maximum shape, and outputs a group of search shapes corresponding to the pixels in the denoising target image. The group of search shapes for the pixels has a shape in which the number of search points along the edge direction is maintained and search points along the direction perpendicular to the edge direction are reduced.
The NLM filter execution unit 104 inputs the denoising target image, the denoising coefficient, the template shape, and the group of search shapes for the pixels set by the search shape setting unit 103 and outputs a denoised image. The processing performed by this NLM filter execution unit 104 is similar to that of a conventional NLM filter disclosed in Non-Patent Document 1.
In step S102, the edge direction detection unit 102 detects edge directions of the denoising target image and outputs a group of edge directions. Subsequently, in step S103, the search shape setting unit 103 limits the input search shape in accordance with the edge directions detected by the edge direction detection unit 102 and outputs a group of search shapes for pixels. When the input search shape is treated as the maximum shape, the output group of search shapes has search shapes that are smaller than that of the input search shape. Finally, in step S104, the NLM filter execution unit 104 executes an NLM filter in accordance with the set information and outputs a resultant filtered image.
Conventionally, for example, as shown in
It is to be noted that in the template matching, the denoising target pixel P0 is excluded from calculation targets. This is because SSD and SAD, which are indices for the degree of similarity between templates, necessarily become 0 and W that is equal to 1.0 is necessarily output as a weight in the NLM filter process described with reference to
This image processing apparatus 11 is different from the image processing apparatus 10 in accordance with the first embodiment in that the denoising coefficient calculation unit 115, which inputs an original image, to which no noise is applied, and calculates a denoising coefficient, is provided. The configuration of the denoising filter processing unit 111 is the same as that of the denoising filter processing unit 101 of the first embodiment.
In step S112, the denoising coefficient calculation unit 115 calculates a denoising coefficient from variances of the input original image and the denoising target image and notifies the NLM filter execution unit 114 of the calculated denoising coefficient. In step S113, the edge direction detection unit 112 detects edge directions of the denoising target image and outputs a group of edge directions. Subsequently, in step S114, the search shape setting unit 113 limits the input search shape in accordance with the edge directions detected by the edge direction detection unit 112 and outputs a group of search shapes for pixels. When the input search shape is treated as the maximum shape, the output group of search shapes has search shapes that are smaller than that of the input search shape. Finally, in step S115, the NLM filter execution unit 114 executes an NLM filter in accordance with the set information and outputs a resultant filtered image.
This image processing apparatus 12 is different from the above-described image processing apparatus 10 in accordance with the first embodiment in that only a denoising coefficient and a denoising target image are input and fixed values retained in the denoising filter processing unit 121 are used as a search shape and a template shape.
That is, the denoising filter processing unit 121 uses the fixed search shape and the fixed template shape stored in the search shape storage unit 125 and the template shape storage unit 126, respectively, instead of a search shape and a template shape which are input from the outside. The configurations of the edge direction detection unit 122, the search shape setting unit 123, and the NLM filter execution unit 124 are the same as those described in the first embodiment.
In the above-described third embodiment, the denoising filter processing unit 121 retains both the search shape and the template shape as the fixed values, but an implementation in which only one of the search shape and the template shape is retained as a fixed value and the other is made variable by inputting it from the outside is also possible. In addition, an implementation in which a denoising coefficient calculation unit is further provided in the third embodiment, like the second embodiment, and a denoising coefficient is calculated from an original image can be employed. Since the basic flow of the processing is similar to those of the examples described in the first embodiment and the second embodiment, a detailed description of the processing is omitted.
As one of examples of the edge direction detection methods in the edge direction detection units 102, 112, and 122, an example in which a Sobel filter is applied to a decoded image to detect an edge direction and a number allocated in accordance with the direction is output will be given.
If |dx|+|dy|<Th, VecIndex=0.
In order to reduce the influence of mosquito noise due to a discrete cosine transform (DCT) and noise at the time of taking an image and to reduce the computational complexity, it is also effective to apply a Sobel filter to an image obtained by scaling-down an input denoising target image to 1/N in the vertical direction and the horizontal direction instead of the input denoising target image, which is not scaled down.
When the Sobel filter is applied to the image scaled down to 1/N, an output calculation result of the Sobel filter is treated as a typical value of a group of a plurality of pixels used in the scaling-down.
As one of examples of the search shape setting methods in the search shape setting units 103, 113, and 123, an example of a search shape reduction method for all the points of a reference search shape of a 5×5 block that is given from an apparatus using the group of edge directions having the edge direction numbers VecIndices described with reference to
The search shape setting units 103, 113, and 123 set search points shown in
The reason for doing so is as follows. As a calculation technique of an NLM filter, a mechanism which calculates SSD or SAD, which is an index for the degree of similarity between templates, using template matching and sets weights having exponential gains for the index is employed. Therefore, in the surroundings of a sharp edge, it is possible to effectively find a position where the degree of similarity is high by performing sampling along the direction of the edge. In contrast, the degree of similarity is greatly reduced at a position distant from the edge, and thus the weights become small values and an influence on calculation of a weighted sum is small. Therefore, the sampling is intensively performed along the direction of the edge, so that it is possible to reduce the computational complexity while suppressing a deterioration in the denoising effect.
It is to be noted that in the example of
The following are results obtained by calculating an edge direction for each 2×2 block of a target image that has been reduced to ½ in the vertical direction and the horizontal direction and performing a simulation with the setting shown below using the techniques recited in the example 1 of the edge direction detection method and the example 1 of the search shape setting method. It is to be noted that the denoising coefficient is the best value obtained by a repetitive calculation that repeats an NLM filter a plurality of times so as to maximize a peak signal-to-noise ratio (PSNR).
With respect to denoising target images, random noise in the range from +5 to −5 was added to a luminance signal of each of sequences shown below, and evaluation was performed in terms of the average of PSNR-Ys and the average of processing times after filtering.
It can be seen from Table 1 that a delay is generated due to influences of detection of an edge direction and conditional branches as a result of application of the direction generated for each 2×2 block in a target image that has been reduced to ½ in the vertical direction and the horizontal direction, but the time required for all the filters can be reduced to approximately 45% on average without greatly reducing the PSNR. Among the sequences, there are sequences in which a PSNR is further increased on average by intensively performing sampling along an edge direction.
As another example of the edge direction detection methods in the edge direction detection units 102, 112, and 122, an example which applies a Sobel filter to a denoising target image to detect an edge direction and outputs an angle in radians (Radian) will be given. The above-described Sobel operator shown in
That is, the angle in radians (Radian) is defined as follows.
If|dx|+|dy|<Th, Radian=EXatan.
As another example of the search shape setting methods in the search shape setting units 103, 113, and 123, an exemplary method for reducing a search shape of an N×N block given from an apparatus for all the points of the search shape using a group of edge directions in units of an angle in radians described in the example 2 of the edge direction detection method will be described.
If the angle in radians (Radian) is EXatan, the search points within the circle are set as a search shape in which the diameter of the set shape is (N-1), as shown in FIG. 9A.
Moreover, if the angle in radians (Radian) is other than EXatan, search points within an ellipse are set as a search shape in which the major axis of the set shape is (N×21/2) and the minor axis of the set shape is (N×2−1/2), as shown in
The fifth embodiment illustrates an example of the image processing apparatus 13 which is used as a loop filter in a video encoding apparatus or a video decoding apparatus. The fundamental functions of the edge direction detection unit 132, the search shape setting unit 133, the NLM filter execution unit 134, the search shape storage unit 135, and the template shape storage unit 136 in the denoising filter processing unit 131 are the same as those of the above-described first to fourth embodiments.
The denoising coefficient setting unit 137 generates denoising coefficients which correspond to pixel positions of a denoising target image using a reference denoising coefficient and encoding information, which are given from the outside. In general, in a medium rate to a low rate, block noise begins to be noticeable at unit boundaries of a prediction processing unit PredictionUnit and a transform processing unit TransformUnit, and thus denoising coefficients at pixel positions in the vicinity of these boundaries are set so as to be higher than those inside a block, using the encoding information.
The deviation degree detection unit 138 and the template shape setting unit 139 are provided for the purpose of introducing a process of limiting a template shape on a pixel-by-pixel basis. In conventional NLM filters, a template shape is generally given as a fixed value for the entire frame. In contrast, in the present embodiment, as pre-processing of an NLM filter by the NLM filter execution unit 134, the deviation degree detection unit 138 detects the degrees of deviation from surrounding pixels for each of pixels of the denoising target image, and the template shape setting unit 139 classifies the degrees of deviation detected by the deviation degree detection unit 138 into multiple levels and sets the template shape (large to small) of each of the pixels in accordance with the degree of deviation (high to low).
In step S132, the denoising coefficient setting unit 137 sets denoising coefficients which correspond to pixel positions of the denoising target image from the input reference denoising coefficient and the input encoding information.
Next, in step 5133, the edge direction detection unit 132 detects edge directions of the denoising target image and outputs a group of edge directions. In step S134, the search shape setting unit 133 limits a search shape input from the search shape storage unit 135 in accordance with the edge directions detected by the edge direction detection unit 132 and sets a group of search shapes for pixels. When the input search shape is treated as the maximum shape, the set group of search shapes has search shapes that are smaller than that of the input search shape.
In step S135, the deviation degree detection unit 138 inputs the denoising target image, calculates the degrees of deviation between a target pixel and surrounding pixels, and outputs a group of degrees of deviation which corresponds to each pixel. In step S136, the template shape setting unit 139 sets and outputs a limited template shape which corresponds to each pixel using the group of degrees of deviation and a predetermined template shape stored in the template shape storage unit 136. When the template shape is limited, the input template shape is treated as the maximum shape, and a limitation is applied so that the lower the degree of deviation is, the smaller the template shape is.
Finally, in step S137, the NLM filter execution unit 134 executes an NLM filter in accordance with the set information and outputs a resultant filtered image.
The processing by the denoising filter processing unit 131 aims at removal of noise due to coding, and it does not assume removal of noise that is uniformly applied to the entirety of a frame from the frame like general image processing. Noise due to coding (coding distortion) can be roughly classified into the following types.
Of these, the present embodiment does not aim at restoring a pattern lost by smoothing because it is very difficult to do so. If an NLM filter is applied to such a smoothed region, in which there is no change in pixel value, the computational complexity therefor is required despite there is almost no change between a pixel signal before the calculation and a pixel signal after the calculation. The present embodiment calculates the degrees of deviation from surrounding pixels to reduce the computational complexity that is also allocated to such a smoothed region.
This image processing apparatus 14 is different from the image processing apparatus 13 in the fifth embodiment in that the template shape resetting unit 1410 is provided. The template shape resetting unit 1410 performs resetting for further limiting a template shape that has been excessively allocated by the template shape setting unit 149 with reference to a group of edge directions, a group of degrees of deviation, and encoding information. Specifically, a template shape that is prone to be excessively allocated to the surroundings of block noise, which is prone to be generated at unit boundaries of PredictionUnit and TransformUnit, is further limited.
An example of the deviation degree detection methods in the deviation degree detection units 138 and 148 will be described.
A to E in the equation are coefficients determined in advance in accordance with the distances between the target pixel and the surrounding pixels, and they are set arbitrarily. For example, a Gaussian distribution depending on distance and so on can be applied to the setting of these coefficients A to E. It is to be noted that not all of A to E are necessarily targets, and it is possible to reduce the computational complexity of the filter by, for example, setting D to 0.
Upon completion of calculation for all DiffIntensities, the deviation degree detection units 138 and 148 output a group of degrees of deviation to the subordinate template shape setting units 139 and 149.
Alternatively, it is contemplated that the absolute value of a Laplacean filter, a sum of square difference (SSD), a variance, and so on can be applied to the calculation of the degrees of deviation.
In order to further reduce the computational complexity, a technique of setting several sampling points as calculation targets for each N×N block having an arbitrary size for a decoded image and using the degrees of deviation as typical values at pixel positions thereof is also contemplated.
DiffIntensity2×2=(DiffIntensity at pixel position of A+DiffIntensity at pixel position of D)/2
The above DiffIntensity2×2 is used as a typical value when reference to the degrees of deviation at the pixel positions of A to D is requested. In this example, the computational complexity required for calculating the degrees of deviation is reduced to approximately half.
As one of examples of the template shape setting methods in the template shape setting units 139 and 149, an example of a reduction in template shape for all the points of a reference template shape of a 3×3 block that is given from an apparatus using a group of degrees of deviation calculated by the deviation degree detection units 138 and 148 will be given.
The template shape setting units 139 and 149 create a histogram of an input group of degrees of deviation, divide the histogram into four so that the ratios between areas thereof are equal to each other, and set template shapes TmpShape for regions α to δ as follows. The value of a boundary between the regions α and β is denoted as Thα, the value of a boundary between the regions β and γ is denoted as Thβ, and the value of a boundary between the regions γ and δ is denoted as Thγ.
When TmpShape is None, template matching is not performed.
When TmpShape is Point, only SSD for a target pixel and a pixel of a search point is calculated.
When TmpShape is Cross, matching is performed using a template shape of five pixels including the target pixel and four (top, bottom, left, and right) pixels.
When TmpShape is Block3×3, matching is performed for all the points of a template shape of a 3×3 block.
Compared to a technique of performing matching for all the points of a template shape of a 3×3 block and for all the search points, the following computational complexities are obtained by introducing the present technique.
Since each region occupies ¼ of the entire frame, the total computational complexity is 5/12, and the theoretical value of the computational complexity can be reduced to approximately a little less than ½.
The following is the reason why the template shape is determined in accordance with the size of the degree of deviation in this manner. A signal having a high degree of deviation tends to appear in the surroundings of a strong edge, and then a weak edge, mosquito noise due to DCT, noise at the time of taking an image, and so on appear as a signal having a low degree of deviation to a medium degree of deviation. Since an NLM filter has a property that it is effective particularly in the surroundings of an edge, the present embodiment allocates a large template shape to a region (region δ) where the degree of deviation is high, thereby suppressing a deterioration in the denoising effect.
As another example of the template shape setting methods in the template shape setting units 139 and 149, an example of a reduction in template shape for all the points of a reference template shape of an N×N block that is given from an apparatus using a group of degrees of deviation calculated by the deviation degree detection units 138 and 148 will be given.
That is, when the reference template shape is given as an N×N block as shown in
Set shape (diameter)=N×[{integrated value of f (DiffIntensity) from 0 to ThIntensity}/{integrated value of f (DiffIntensity) from 0 to maximum value Max}]
Accordingly, it is possible to perform effective template matching by using a small template shape when the degree of deviation is low and using a large template shape when the degree of deviation is high.
As one of examples of the template shape resetting method in the template shape resetting unit 1410, an example in which the template shape set by the template shape setting unit 149 shown in
When a group of edge directions is used, as shown in
That is, in a medium rate region to a low rate region where a quantization parameter QP is large, if the feature as shown in
As a specific solving technique, for example, the following technique is conceivable. The following setting is performed on each pixel position using predetermined thresholds Th1QP and Th2QP (where Th1QP<Th2QP) for the quantization parameter QP and predetermined thresholds Th1Diff and Th2Diff (where Th1Diff<Th2Diff) for the degree of deviation DiffIntensity. By doing so, it is possible to reduce the computational complexity while suppressing a deterioration in the denoising effect. It is to be noted that it is assumed that Th1Diff and Th2Diff vary in accordance with the quantization parameter QP.
If the following condition is satisfied, a template shape TmpShape is set in accordance with a resetting branch algorithm described below.
Since VecIndices generated by block noise cannot be predicted for regions E, F, G, and H at four corners in
The present embodiment demonstrates an example in which the computational complexity is reduced for a group of pixels at block boundaries; to the contrary, an implementation in which TmpShape is set to None for the entire group of pixels inside a block, template matching is not performed on that portion, and a denoising filter is applied to only block boundaries to thereby greatly reduce the computational complexity is also possible.
It is to be noted that the fifth embodiment and the sixth embodiment describe examples in which the denoising filter processing units 131 and 141 retain a reference search shape and a reference template shape as fixed values, but an implementation which supplies one or both of them from the outside is also possible.
Hereinafter, the video encoding apparatus shown in
A block size determination unit 302 determines a block size, with which a predetermined CodingUnit is divided and encoding is executed, and outputs a target block and the block size. A prediction size determination unit 303 determines a block prediction size, with which pixel values of the target block are predicted, and outputs a target block and the prediction size. A prediction technique determination unit 304 determines a technique that provides the highest coding efficiency among techniques including intra-frame prediction and inter-frame prediction when the pixel values of the target block are predicted, and outputs a prediction block and prediction information when that technique is used. The difference between the target block output by the prediction size determination unit 303 and the prediction block is calculated to generate a difference block.
A transform size determination unit 305 determines a transform size, with which the difference block is divided, and outputs divided difference blocks having the transform size as well as the transform size. A discrete cosine transform unit 306 applies a discrete cosine transform to the difference blocks and outputs DCT coefficients. A quantization unit 307 quantizes the DCT coefficients and outputs quantized DCT coefficients.
An inverse quantization unit 308 performs inverse quantization on the quantized DCT coefficients to restore the DCT coefficients. An inverse discrete cosine transform unit 309 applies an inverse discrete cosine transform to the DCT coefficients and outputs a decoded difference block. The decoded difference block is added to the prediction block to generate a partial decoded image. A decoded image storage unit 310 is a storage unit for storing the partial decoded image and images that can also be referred to in the decoding apparatus. An intra-frame prediction unit 311 refers to the partial decoded image stored in the decoded image storage unit 310 and outputs a prediction block and prediction information.
A denoising coefficient determination unit 312 determines a denoising coefficient that provides the optimum coding efficiency with reference to a decoded image and the original image, and outputs the denoising coefficient. The denoising filter processing unit 313 performs a filter process for reducing coding distortion described in the above-described first to sixth embodiments and so on with reference to the decoded image to generate a filtered decoded image.
An adaptive loop filter (ALF) processing unit 314 performs a filter process on the filtered decoded image so as to be close to the original image, and outputs an ALF-ed decoded image and ALF coefficients. A frame buffer 315 is a storage unit for storing the ALF-ed decoded image. An inter-frame prediction unit 316 refers to the frame buffer 315 and outputs a prediction block and prediction information.
A sequence information encoding unit 317 encodes information unique to the input sequence, such as the numbers of pixels in the vertical direction and the horizontal direction of video, and then outputs a sequence-information overhead to a bitstream storage unit 325. A block size encoding unit 318 receives the block size from the block size determination unit 302, performs encoding, and then outputs a block-size overhead. A prediction size encoding unit 319 receives the prediction size from the prediction size determination unit 303, performs encoding, and then outputs a prediction-size overhead. A prediction information encoding unit 320 receives the prediction information from the prediction technique determination unit 304, performs encoding, and then outputs a prediction-information overhead.
A transform size encoding unit 321 receives the transform size from the transform size determination unit 305, performs encoding, and then outputs a transform-size overhead. A quantized DCT coefficient encoding unit 322 receives the quantized DCT coefficients from the quantization unit 307, performs encoding, and then outputs a DCT overhead. A denoising coefficient encoding unit 323 receives the denoising coefficient determined by the denoising coefficient determination unit 312, performs encoding, and then outputs a denoising-coefficient overhead. An ALF coefficient encoding unit 324 receives the ALF coefficients, performs encoding, and then outputs an ALF overhead. The bitstream storage unit 325 is a storage unit for storing each overhead, and outputs a bitstream as an encoding result upon completion of encoding of the entire sequence.
An encoding information storage unit 326 is a storage unit for storing encoding information which can also be referred to in the decoding apparatus. This encoding information stored in the encoding information storage unit 326 is referred to and used by the denoising filter processing unit 313 and other units.
Hereinafter, the video decoding apparatus shown in
A block size decoding unit 403 receives the block-size overhead, and decodes information indicating a block size, with which a predetermined CodingUnit is divided and encoded. A prediction size decoding unit 404 receives the prediction-size overhead and outputs a prediction size applied in the video encoding apparatus.
A prediction information decoding unit 405 receives the prediction-information overhead and outputs prediction information. A transform size decoding unit 406 receives the transform-size overhead and outputs a transform size applied in the video encoding apparatus. A quantized DCT coefficient decoding unit 407 receives the transform size and the DCT overhead and outputs quantized DCT coefficients. A denoising coefficient encoding unit 408 receives the denoising-coefficient overhead and outputs a denoising coefficient. An ALF coefficient decoding unit 409 receives the ALF overhead and outputs ALF coefficients.
An inverse quantization unit 410 performs inverse quantization on the quantized DCT coefficients to restore the DCT coefficients. An inverse discrete cosine transform unit 411 applies an inverse discrete cosine transform to the DCT coefficients and outputs a decoded difference signal. A prediction block generation unit 412 receives the prediction information, a partial decoded image, and a reference frame, and generates a prediction block. A partial decoded image generation unit 413 adds the prediction block to the decoded difference signal to generate the partial decoded image. A decoded image storage unit 414 is a storage unit for storing the partial decoded image.
The denoising filter processing unit 415 performs a filter process for reducing coding distortion described in the above-described first to sixth embodiments and so on with reference to the decoded image to generate a filtered decoded image.
An ALF processing unit 416 receives the ALF coefficients, performs a filter process on the filtered decoded image so as to be close to the original image, and outputs an ALF-ed decoded image. It is to be noted that this ALF-ed decoded image becomes a final decoded image in the decoding. A frame buffer 417 is a storage unit for storing the ALF-ed decoded image. An encoding information storage unit 418 is a storage unit for storing encoding information, and this encoding information stored in the encoding information storage unit 418 is referred to and used by the denoising filter processing unit 415 and other units.
It was confirmed that when a denoising filter in accordance with the present technique is applied to encoding of standard video, it is possible to reduce the computational complexity required for the above filter by approximately 50 to 75% while suppressing a deterioration in PSNR, compared to a technique which incorporates a conventional NLM filter (a denoising filter in accordance with the non-local means method) into the next-generation video coding standards.
The processes of the above image processing, video encoding, and video decoding can also be realized by a computer and a software program, the program can be recorded on a computer-readable recording medium, and the program can be provided through a network.
The present system is configured such that a central processing unit (CPU) 50 which executes a program, a memory 51, such as a random access memory (RAM), which stores the program and data accessed by the CPU 50, a video signal storage unit 52 which stores denoising target image signals, an encoding target video signal, or a video signal of decoded images, a program storage unit 53 which stores the program for making the CPU 50 execute the processes described in the embodiments of the present invention, and an encoded stream storage unit 54 which stores a bitstream as an encoding result or a decoding target bitstream are connected to each other through a bus.
The program storage unit 53 stores one of an image processing program 531 for removing noise of an image signal using an embodiment of the present invention, a video encoding program 532 for encoding a video signal using an embodiment of the present invention, and a video decoding program 533 for decoding an encoded bitstream using an embodiment of the present invention. The program storage unit 53 does not necessarily store all of these programs.
When the present system is used for removing noise of an image signal, the image processing program 531 is loaded on the memory 51, the CPU 50 sequentially fetches and executes instructions of the image processing program 531 loaded on the memory 51, inputs images of a video signal stored in the video signal storage unit 52, removes noise using the technique described in an embodiment of the present invention, and storage in the video signal storage unit 52 is performed.
Moreover, when the present system is used as a video encoding apparatus, the video encoding program 532 is loaded on the memory 51, the CPU 50 sequentially fetches and executes instructions of the video encoding program 532 loaded on the memory 51, encodes a video signal stored in the video signal storage unit 52 using the technique described in an embodiment of the present invention, and stores a bitstream as an encoding result in the encoded stream storage unit 54. Alternatively, the bitstream may be output to an external apparatus through an interface such as a network adapter.
Moreover, when the present system is used as a video decoding apparatus, the video decoding program 533 is loaded on the memory 51, the CPU 50 sequentially fetches and executes instructions of the video decoding program 533 loaded on the memory 51, decodes a bitstream stored in the encoded stream storage unit 54 using the technique described in an embodiment of the present invention, and stores a video signal as a decoding result in the video signal storage unit 52. Alternatively, the video signal as the decoding result is output to an external reproduction apparatus.
In particular, an embodiment of the present invention is used in a loop filter process in the video encoding program 532 and the video decoding program 533, and the program portion of this loop filter process can be shared by the video encoding program 532 and the video decoding program 533.
Although embodiments of the present invention have been described above in detail with reference to the drawings, the specific configuration is not limited to these embodiments, and designs and so on (addition, omission, replacement, and other modifications of configuration) that do not depart from the gist of the present invention are also included. The present invention is not restricted by the above description, and is restricted only by the attached claims.
For example, the present invention can be used for reducing noise at the time of taking an image and a deterioration of a deteriorated image. The present invention can reduce the computational complexity of a denoising filter while suppressing a reduction in coding efficiency.
Number | Date | Country | Kind |
---|---|---|---|
2011-051443 | Mar 2011 | JP | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/JP2012/055748 | 3/7/2012 | WO | 00 | 9/3/2013 |