The embodiments discussed herein are related to a video encoding device, a video encoding method, a video decoding device, a video decoding method, and a video encoding system.
In high efficiency video coding (HEVC) that is the latest video encoding standard, two prediction methods of inter prediction and intra prediction are adopted as prediction methods for encoding a block to be encoded using information of an encoded block. The inter prediction is a prediction method using a pixel value of a block located temporally close to a block to be encoded, and the intra prediction is a prediction method using a pixel value of a block located at close distance to the block to be encoded.
Japanese Laid-open Patent Publication No. 2012-135033, Japanese Laid-open Patent Publication No. 2013-078161, and Japanese Laid-open Patent Publication No. 2017-143542 are disclosed as related art.
According to an aspect of the embodiments, an information processing device includes: a memory; and a processor coupled to the memory and configured to: determine an angle of intra prediction for a block to be encoded in an image included in a video, and encode the block to be encoded using the angle of intra prediction; generate a bit value indicating an estimation result of the angle using a locally decoded pixel value of an encoded pixel adjacent to the block to be encoded; generate a bit string indicating the angle of intra prediction and generate flag information indicating whether a partial bit value of the bit string matches the bit value indicating an estimation result of the angle; and encode the flag information by a first encoding method and encode a remaining bit value of the bit string by a second encoding method.
The object and advantages of the invention will be realized and attained by means of the elements and combinations particularly pointed out in the claims.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory and are not restrictive of the invention.
Furthermore, in HEVC, context-adaptive binary arithmetic coding (CABAC) with high compression efficiency is adopted as a variable-length encoding method.
In standardization activity of future video coding (FVC) that is a next-generation video encoding standard, further improvement in compression efficiency is being studied.
In HEVC, prediction mode information indicating an angle of intra prediction is encoded by CABAC. However, a code amount of the prediction mode information indicating an angle is not sufficiently compressed.
Note that such a problem occurs not only in video encoding using HEVC but also in other video encoding using intra prediction.
In one aspect, a code amount of prediction mode information indicating an angle of intra prediction in video encoding may be reduced.
Hereinafter, embodiments will be described in detail with reference to the drawings.
In the example in
In HEVC, three types of prediction modes of a direct current (DC) mode, a planar mode, and an angular mode are defined as intra prediction modes. Among the prediction modes, in the angular mode, one angle is selected for each block to be encoded, and a prediction pixel value of each pixel the block to be encoded 101 is generated using the reference pixel located in a direction indicated by the selected angle. In HEVC, thirty-three angles are defined as angles in the angular mode, but in FVC, it is expected that the angle is extended to sixty-five angles.
In the case where intra prediction in the angular mode is performed, prediction mode information indicating the angle used in the intra prediction is encoded. To efficiently encode the prediction mode information indicating the angle, a most probable mode (MPM) table is used.
The most probable mode for the block to be encoded is predicted from the angular mode of a surrounding encoded block, and in HEVC, three types of prediction methods are defined. By encoding a difference between the predicted most probable mode and the actual angular mode, the amount of prediction mode information indicating the angle may be reduced.
In the case of HEVC, a 5-bit bit string is used to express thirty-two angles except for the most probable mode out of thirty-three angles. Meanwhile, in the case of FVC, it is expected to use a 6-bit bit string to express sixty-four angles except for the most probable mode out of sixty-five angles.
A quantized coefficient and the prediction mode information of the block to be encoded are encoded by CABAC. The processing procedure of CABAC adopted in HEVC is as follows.
(1) Binarization
A multi-level syntax element in syntax elements to be encoded is converted into a binary signal (bin) that is to be a signal to be arithmetic-encoded.
(2) Context Modeling
In a context mode, an occurrence probability model used for arithmetic coding is determined according to a value of another syntax element, a value of a syntax element adjacent to a region to be encoded, or the like, for each bin of a syntax element. In this case, the occurrence probability of each value of logic “0” and logic “1” is variable.
On the other hand, for bins for which estimation of the occurrence probability is difficult, a bypass mode in which the occurrence probability of each value of logic “0” and logic “1” is fixed to 0.5 is selected.
(3) Arithmetic Encoding
A real number line from 0 to less than 1 is sequentially divided into sections on the basis of the occurrence probability of an occurring symbol, and a codeword in binary notation is generated from a real number indicating a finally divided section.
In the arithmetic coding in the bypass mode, the code amount is not compressed. However, since probability estimation processing is skipped and an arithmetic amount in the real number linear division processing is reduced, the encoding processing is speeded up and a storage area of a memory for storing the occurrence probability is reduced.
However, since the prediction mode information indicating angles except for the most probable mode is encoded in the bypass mode of CABAC, the compression efficiency of the prediction mode information is low.
Next, the generation unit 413 generates a bit string indicating the angle of intra prediction (step 504) and generates flag information indicating whether a partial bit value of a bit string matches the bit value indicating an estimation result of the angle (step 505). Then, the second encoding unit 414 encodes the flag information by a first encoding method and encodes a remaining bit value of the bit string by a second encoding method (step 506).
Next, the estimation unit 612 generates the bit value indicating an estimation result of the angle using a decoded pixel value of a decoded pixel adjacent to the block to be decoded (step 702). Next, the generation unit 613 generates the partial bit value of a bit string from the bit value indicating an estimation result of the angle on the basis of the flag information, and obtains the angle of intra prediction using the partial bit value of the bit string and the remaining bit value of the bit string (step 703). Then, the second decoding unit 614 decodes coefficient information of the block to be decoded using the angle of intra prediction (step 704).
According to the video encoding device 401 in
The prediction error generation unit 812, the orthogonal transform unit 813, the quantization unit 814, the intra-frame prediction unit 817, the inter-frame prediction unit 818, the selection unit 819, the inverse quantization unit 820, the inverse orthogonal transform unit 821, the reconstruction unit 822, and the in-loop filter 823 correspond to the first encoding unit 411 in
The video encoding device 801 can be implemented as, for example, a hardware circuit. In this case, each constituent element of the video encoding device 801 may be implemented as an individual circuit or may be implemented as one integrated circuit.
The video encoding device 801 encodes an input video to be encoded and outputs an encoded video as an encoded stream. The video encoding device 801 can transmit the encoded stream to the video decoding device 601 in
The video to be encoded includes a plurality of images respectively corresponding to a plurality of times. The image at each time corresponds to an image to be encoded and is sometimes called picture or frame. Each image may be a color image or a monochrome image. In the case of a color image, the pixel values may be in RGB format or in YUV format.
The block division unit 811 divides the image to be encoded into a plurality of blocks and outputs an original image of the block to be encoded to the prediction error generation unit 812, the intra-frame prediction unit 817, and the inter-frame prediction unit 818.
The intra-frame prediction unit 817 performs intra prediction for the block to be encoded, outputs a predicted image of the intra prediction to the selection unit 819, and outputs prediction mode information indicating a prediction method of the intra prediction to the arithmetic encoding unit 815. In the case of intra prediction in the angular mode, any one of N prediction directions indicated by N different angles is selected. The inter-frame prediction unit 818 performs inter prediction for the block to be encoded and outputs a predicted image of the inter prediction to the selection unit 819.
The selection unit 819 selects a predicted image output by either the intra-frame prediction unit 817 or the inter-frame prediction unit 818 and outputs the selected predicted image to the prediction error generation unit 812 and the reconstruction unit 822. The prediction error generation unit 812 outputs a difference between the predicted image output by the selection unit 819 and the original image of the block to be encoded to the orthogonal transform unit 813 as a prediction error.
The orthogonal transform unit 813 performs orthogonal transform for the prediction error output by the prediction error generation unit 812 and outputs a transform coefficient to the quantization unit 814. The quantization unit 814 quantizes the transform coefficient and outputs a quantized coefficient to the arithmetic encoding unit 815 and the inverse quantization unit 820.
The estimation unit 825 generates a bit value indicating an estimation result of the angle of intra prediction for the block to be encoded using a locally decoded pixel value of an encoded pixel adjacent to the block to be encoded, and outputs the generated bit value to the arithmetic encoding unit 815.
The arithmetic encoding unit 815 encodes the quantized coefficient output by the quantization unit 814 and the prediction mode information output by the intra-frame prediction unit 817 by CABAC, and outputs the encoded stream. Then, the arithmetic encoding unit 815 outputs an information amount generated by CABAC to the encoding control unit 816.
The inverse quantization unit 820 performs inverse quantization for the quantized coefficient output by the quantization unit 814 to generate an inversely quantized coefficient, and outputs the generated inversely quantized coefficient to the inverse orthogonal transform unit 821. The inverse orthogonal transform unit 821 performs inverse orthogonal transform for the inversely quantized coefficient to generate a prediction error, and outputs the generated prediction error to the reconstruction unit 822.
The reconstruction unit 822 adds the predicted image output by the selection unit 819 and the prediction error output by the inverse orthogonal transform unit 821 to generate a reconstructed image, and outputs the generated reconstructed image to the in-loop filter 823. The in-loop filter 823 performs filter processing of a deblocking filter or the like for the reconstructed image output by the reconstruction unit 822 to generate a locally decoded image, and outputs the generated locally decoded image to the memory 824.
The memory 824 stores the locally decoded image output by the in-loop filter 823. The locally decoded image stored in the memory 824 is output to the intra-frame prediction unit 817, the inter-frame prediction unit 818, and the estimation unit 825. The intra-frame prediction unit 817 uses a locally decoded pixel value included in the locally decoded image as a reference pixel value for a subsequent block, and the inter-frame prediction unit 818 uses the locally decoded image as a reference image for a subsequent image. The estimation unit 825 uses the locally decoded pixel value included in the focally decoded image as the locally decoded pixel value of the encoded pixel.
The encoding control unit 816 determines a quantization parameter (QP) so that the information amount output by the arithmetic encoding unit 815 becomes a target information amount, and outputs the determined QP to the quantization unit 814.
The generation unit 901 binarizes the prediction mode information output by the intra-frame prediction unit 817 and generates a bit string indicating the angle of intra prediction. Then, the generation unit 901 compares a partial bit value of the bit string with the bit value output by the estimation unit 825, thereby generating flag information indicating whether these bit values match each other. As the partial bit value of the bit string, a bit value of upper M bits (M is an integer of 1 or larger) of the bit string can be used.
The encoding unit 902 encodes the flag information generated by the generation unit 901 and the quantized coefficient output by the quantization unit 814 using a variable occurrence probability in a CABAC context mode. Then, the encoding unit 902 encodes a remaining bit value of the bit string generated by the generation unit 901 using a fixed occurrence probability in a CABAC bypass mode. The context mode corresponds to the first encoding method, and the bypass mode corresponds to the second encoding method.
0th angle: 0000
1st angle: 0001
2nd angle: 0010
3rd angle: 0011
4th angle: 0100
5th angle: 0101
6th angle: 0110
7th angle: 0111
8th angle: 1000
9th angle: 1001
10th angle: 1010
11th angle: 1011
12th angle: 1100
13th angle: 1101
14th angle: 1110
15th angle: 1111
For example, in the case where a partial bit value of the bit string is the most significant bit (MSB), the estimation unit 825 estimates the MSB of the bit string and generates a bit value (estimated value) indicating an estimation result of the MSB.
In the example in
Then, the generation unit 901 calculates an exclusive OR (XOR) of the MSB of the bit string indicating the angle of intra prediction and the estimated value of the MSB, and outputs a value of the XOR to the encoding unit 902 as flag information. Furthermore, the generation unit 901 outputs a bit value other than the MSB of the bit string indicating the angle of intra prediction to the encoding unit 902 as a remaining bit value. In this case, the flag information indicates whether the MSB of the bit string matches the estimated value.
For example, in the case where the angle of intra prediction is the 11th angle, the XOR of “1” that is the MSB of the bit string “1011” and the estimated value of the MSB is output as the flag information, and the bit string “011” excluding the MSB is output as the remaining bit value.
As described above, the flag information does not directly indicate the angle of intra prediction but indicates the difference between the partial bit value of the bit string indicating the angle of intra prediction and the estimated value. Therefore, it is possible to make the occurrence probability of the value “0” indicating that the two bit values are the same higher than the occurrence probability of the value “1” indicating that the two bit values are different. Therefore, the flag information can be encoded in the context mode of CABAC, and the code amount of the prediction mode information indicating the angle of intra prediction is reduced.
Next, the prediction error generation unit 812, the orthogonal transform unit 813, and the quantization unit 814 encode the block to be encoded using the predicted image output by either the intra-frame prediction unit 817 or the inter-frame prediction unit 818 to generate the quantized coefficient (step 1303). Then, the estimation unit 825 estimates the angle of intra prediction (step 1304) and the generation unit 901 of the arithmetic encoding unit 815 generates the flag information for the estimation result (step 1305).
Next, the video encoding device 801 determines whether encoding of the image to be encoded has been completed (step 1306). In the case where an unprocessed block remains (step 1306, NO), the video encoding device 801 repeats the processing in step 1301 and subsequent steps for the next block.
On the other hand, in the case where the encoding of the image to be encoded has been completed (step 1306, YES), the encoding unit 902 of the arithmetic encoding unit 815 performs variable-length encoding for the quantized coefficient and the prediction mode information (step 1307). The prediction mode information includes the remaining bit value of the bit string indicating the angle of intra prediction and the flag information.
Next, the video encoding device 801 determines whether encoding of the video to be encoded has been completed (step 1308). In the case where an unprocessed image remains (step 1308, NO), the video encoding device 801 repeats the processing in step 1301 and subsequent steps for the next image. Then, in the case where the encoding of the video to be encoded has been completed (step 1308, YES), the video encoding device 801 terminates the processing.
First, the estimation unit 825 checks whether the upper adjacent block is referable in intra prediction for the block to be encoded (step 1401). For example, in the case where the block to be encoded is in contact with an upper end of an image, a slice, or a tile, it is determined that the upper adjacent block is not referable.
In the case where the upper adjacent block is referable (step 1401, YES), the estimation unit 825 checks whether the left adjacent block is referable in intra prediction for the block to be encoded (step 1402). For example, in the case where the block to be encoded is in contact with a left end of an image, a slice, or a tile, it is determined that the left adjacent block is not referable.
In the case where the left adjacent block is referable (step 1402, YES), the estimation unit 825 calculates an index A1 indicating the magnitude of a change in a locally decoded pixel value of an upper adjacent pixel in the upper adjacent block (step 1403). Next, the estimation unit 825 calculates an index A2 indicating the magnitude of a change in a locally decoded pixel value of a left adjacent pixel in the left adjacent block (step 1404) and compares the index A1 with the index A2 (step 1405).
In the case where the index A1 is larger than the index A2 (step 1405, YES), the estimation unit 825 sets an estimated value P1 of the MSB to “1” (step 1406). Meanwhile, in the case where the index A1 is equal to or smaller than the index A2 (step 1405, NO), the estimation unit 825 sets the estimated value P1 to “0” (step 1407).
In the case where the upper adjacent block is not referable (step 1401, NO), the estimation unit 825 sets the estimated value P1 to “0” (step 1407). Furthermore, In the case where the left adjacent block is not referable (step 1402, NO), the estimation unit 825 sets the estimated value P1 to “1” (step 1406).
As the index A1, a weighted sum of frequency coefficients obtained by converting the locally decoded pixel value of the upper adjacent pixel into a frequency domain can be used. In this case, the index A1 is calculated by the following expression, for example.
In the expression (1), n represents a width of the block to be encoded and D represents a bit depth of the image. dct1(i) represents an i-th transform coefficient among n transform coefficients obtained by applying one-dimensional discrete cosine transform (DCT) to the locally decoded pixel values of n upper adjacent pixels. A spatial frequency of the component represented by the transform coefficient increases as i increases. w(i) represents a predetermined weight for the i-th transform coefficient and satisfies the following constraint.
The index A1 increases as a high-frequency component in the n upper adjacent pixels increase. Therefore, the larger the index A1, the higher the possibility that the edge direction of the upper adjacent pixel is the vertical direction.
Meanwhile, as the index A2, a weighted sum of frequency coefficients obtained by converting the locally decoded pixel value of the left adjacent pixel into a frequency domain can be used. In this case, the index A2 is calculated by the following expression, for example.
In the expression (3), m represents the height of the block to be encoded, dct2(i) represents an i-th transform coefficient among m transform coefficients obtained by applying one-dimensional DCT to the locally decoded pixel values of m left adjacent pixels. w(i) represents a predetermined weight for the i-th transform coefficient and satisfies the following constraint.
The index A2 increases as a high-frequency component in the m left adjacent pixels increase. Therefore, the larger the index A2, the higher the possibility that the edge direction of e left adjacent pixel is the horizontal direction.
For example, in the case where n is a power of 2 and n≥8, the weight w(i) in the expression (1) can be defined by the following expressions.
floor(p) in expressions (5) and (6) represents a largest integer equal to or less than a real number p. In this case, w(i) is a reciprocal of a power of 2, and w(i)<w(i+1). Therefore, w(i) increases as i increases, and the weight can be increased as the spatial frequency increases.
According to the estimation processing in
The estimation unit 1621 corresponds to the estimation unit 612 in
The video decoding device 1601 can be implemented as, for example, a hardware circuit. In this case, each constituent element of the video decoding device 1601 may be implemented as an individual circuit or may be implemented as one integrated circuit.
The video decoding device 1601 decodes an input encoded stream and outputs a decoded video. The video decoding device 1601 can receive the encoded stream from the video encoding device 801 in
The arithmetic decoding unit 1611 decodes the encoded stream according to a decoding method of CABAC, outputs a quantized coefficient of a block to be decoded in an image to be decoded to the inverse quantization unit 1612, and outputs prediction mode information for the block to be decoded to the selection unit 1616.
The inverse quantization unit 1612 performs inverse quantization for the quantized coefficient output by the arithmetic decoding unit 1611 to generate an inversely quantized coefficient, and outputs the generated inversely quantized coefficient to the inverse orthogonal transform unit 1613. The inverse orthogonal transform unit 1613 performs inverse orthogonal transform for the inversely quantized coefficient to generate a prediction error, and outputs the generated prediction error to the reconstruction unit 1614.
The selection unit 1616 outputs the prediction mode information of inter prediction to the inter-frame prediction unit 1617, and outputs the prediction mode information of intra prediction to the intra-frame prediction unit 1618.
The inter-frame prediction unit 1617 performs inter prediction for the block to be decoded using the prediction mode information of inter prediction and a reference image output by the memory 1620, generates a predicted image of inter prediction, and outputs the generated predicted image to the selection unit 1619.
The intra-frame prediction unit 1618 performs intra prediction for the block to be decoded using the prediction mode information of intra prediction and a decoded image of a decoded block output by the memory 1620, generates a predicted image of intra prediction, and outputs the generated predicted image to the selection unit 1619.
The selection unit 1619 selects the predicted image output by either the inter-frame prediction unit 1617 or the intra-frame prediction unit 1618, and outputs the selected predicted image to the reconstruction unit 1614.
The reconstruction unit 1614 adds the predicted image output by the selection unit 1619 and the prediction error output by the inverse orthogonal transform unit 1613 to generate a reconstructed image, and outputs the generated reconstructed image to the in-loop filter 1615.
The in-loop filter 1615 performs filtering processing of a deblocking filter, a sample adaptive offset filter, and the like for the reconstructed image output by the reconstruction unit 1614 to generate a decoded image. Then, the in-loop filter 1615 outputs the decoded image for one frame as a decoded video and outputs the decoded image to the memory 1620.
The memory 1620 stores the decoded image output by the in-loop filter 1615. The decoded image stored in the memory 1620 is output to the inter-frame prediction unit 1617, the intra-frame prediction unit 1618, and the estimation unit 1621. The inter-frame prediction unit 1617 uses the decoded image as a reference image for a subsequent image, and the intra-frame prediction unit 1618 uses the decoded pixel value included in the decoded image as a reference pixel value for a subsequent block. The estimation unit 1621 uses the decoded pixel value included in the decoded image as the decoded pixel value of the decoded pixel.
The estimation unit 1621 performs estimation processing similar to the estimation unit 825 in
The decoding unit 1701 decodes an encoded stream using a variable occurrence probability in the context mode of CABAC to restore the quantized coefficient of the block to be decoded and the prediction mode information including the flag information for the angle of intra prediction. Moreover, the decoding unit 1701 decodes the encoded stream using a fixed occurrence probability in the bypass mode of CABAC to restore the prediction mode information including the remaining bit value of the bit string indicating the angle of intra prediction. The context mode corresponds to the first decoding method, and the bypass mode corresponds to the second decoding method.
Then, the decoding unit 1701 outputs the flag information and the remaining bit value of the bit string to the generation unit 1702. The generation unit 1702 generates the partial bit value of the bit string indicating the angle of intra prediction from the bit value output by the estimation unit 1621 using the flag information. Then, the generation unit 1702 concatenates the partial bit value of the bit string and the remaining bit value of the bit string to generate the bit string indicating the angle of intra prediction.
For example, in the case where the partial bit value of the bit string is the MSB, the estimation unit 1621 estimates the MSB of the bit string and generates an estimated value of the MSB. Next, the generation unit 1702 calculates an XOR of the estimated value of the MSB and the bit value indicated by the flag information, and sets a value of the XOR as the MSB of the bit string indicating the angle of intra prediction. Then, the generation unit 1702 sets the remaining bit value output by the decoding unit 1701 as a bit other than the MSB of the bit string indicating the angle of intra prediction.
For example, in the case where the angle of intra prediction is the 11th angle, the XOR of the estimated value of the MSB and the bit value indicated by the flag information is “1”. Therefore, “1” is set as the MSB and is concatenated with the remaining bit value “011” to generate the bit string “1011” indicating the 11th angle, As described above, the entire bit string is restored from the estimated value of the MSB, the flag information, and the remaining bit value, and the angle of intra prediction can be obtained.
Next, the arithmetic decoding unit 1611 checks whether the prediction mode information of the block to be decoded indicates inter prediction or intra prediction (step 1802). The prediction mode information of intra prediction includes the remaining bit value of the bit string indicating the angle of intra prediction and the flag information.
In the case where the prediction mode information indicates intra prediction (step 1802, YES), the estimation unit 1621 estimates the angle of intra prediction (step 1803). Next, the arithmetic decoding unit 1611 obtains the angle of intra prediction using the estimation result, the flag information, and the remaining bit values (step 1804). Then, the intra-frame prediction unit 1618 performs intra prediction for the block to be decoded using the angle of intra prediction (step 1805).
Meanwhile, in the case where the prediction mode information indicates inter prediction (step 1802, NO), the inter-frame prediction unit 1617 performs inter prediction for the block to be decoded using the prediction mode information (step 1808).
Next, the inverse quantization unit 1612 and the inverse orthogonal transform unit 1613 decode the quantized coefficient of the block to be decoded to generate a prediction error (step 1806). Then, the selection unit 1619, the reconstruction unit 1614, and the in-loop filter 1615 generate the decoded image from the prediction error using the predicted image output by either the inter-frame prediction unit 1617 or the intra-frame prediction unit 1618.
Next, the video decoding device 1601 determines whether decoding of the encoded stream has been completed (step 1807). In the case where an unprocessed encoded string remains (step 1807, NO), the video decoding device 1601 repeats the processing in step 1801 and the subsequent steps for the next encoded string. Then, in the case where decoding of the encoded stream has been completed (step 1807, YES), the video decoding device 1601 terminates the processing.
Next, the video encoding processing and the video decoding processing in the case where a partial bit value of a bit string is upper two bits will be described with reference to
In the case of using the upper two-bit estimated value, the horizontal angle range can be divided into two angle ranges and the vertical angle range can be divided into two angle ranges to generate four angle ranges.
In the example illustrated in
In the angle range G1, the arrows indicating the angles point to lower left directions. In the angle range G2 and the angle range G3, the arrows indicating the angles point to upper left directions. In the angle range G4, the arrows indicating the angles point to upper right directions.
The estimation unit 825 sets the upper two-bit estimated value to “00” in the case of determining that the angle of intra prediction belongs to the angle range G1, and sets the upper two-bit estimated value to “01” in the case of determining that the angle of intra prediction belongs to the angle range G2. Furthermore, the estimation unit 825 sets the upper two-bit estimated value to “10” in the case of determining that the angle of intra prediction belongs to the angle range G3, and sets the upper two-bit estimated value to “11” in the case of determining that the angle of intra prediction belongs to the angle range G4.
Then, the generation unit 901 calculates an XOR of the upper two bits of the bit string indicating the angle of intra prediction and the upper two-bit estimated value, and outputs a value of the XOR to the encoding unit 902 as the flag information. Furthermore, the generation unit 901 outputs a bit value other than the upper two bits of the bit string indicating the angle of intra prediction to the encoding unit 902 as the remaining bit value.
In this case, the flag information includes a first flag and a second flag. The first flag indicates whether a first-bit (MSB) bit value of the upper two bits matches a first-bit bit value of the upper two-bit estimated value. Meanwhile, the second flag indicates whether a second-bit bit value of the upper two bits matches a second-bit bit value of the upper two-bit estimated value.
For example, in the case where the angle of intra prediction is the 11th angle, the XOR of each bit value of “10” that is the upper two bits of the bit string “1011” and each bit value of the upper two-bit estimated value is output as the flag information. Then, the bit string “11” excluding the upper two bits is output as the remaining bit value.
As described above, by using the upper two-bit estimated value of the bit string indicating the angle of intra prediction, the bit number of the remaining bit value is reduced as compared with the case of using an estimated value of only the MSB. Therefore, the bit number encoded in the bypass mode of CABAC can be reduced, and the code amount of the prediction mode information indicating the angle of intra prediction may be further reduced.
In step 1304 in
First, the estimation unit 825 calculates an index 81 indicating the magnitude of a change in a locally decoded pixel value in an oblique direction V1 from locally decoded pixel values of encoded pixels of two lines in an upper adjacent block or a left adjacent block (step 2001). Next, the estimation unit 825 calculates an index B2 indicating the magnitude of a change in a locally decoded pixel value in an oblique direction V2 intersecting with the oblique direction V1 from the locally decoded pixel values of the encoded pixels of the two lines (step 2002) and compares the index B1 with the index B2 (step 2003).
In the case where the index B1 is larger than the index B2 (step 2003, YES), the estimation unit 825 sets a second-bit estimated value P2 to “1” (step 2004). Meanwhile, in the case where the index B1 is equal to or smaller than the index B2 (step 2003, NO), the estimation unit 825 sets the estimated value P2 to “0” (step 2005).
As the index B1, a sum of absolute differences of locally decoded pixel values of pixels arranged in the oblique direction V1 among the pixels of two lines adjacent to the block to be encoded in the upper adjacent block or the left adjacent block can be used.
In the case where the first-bit estimated value is “0”, that is, the estimated angle belongs to the angle range G1 or the angle range G2, pixels of right-end two lines in the left adjacent block are used. Meanwhile, in the case where the first-bit estimated value is “1”, that is, the estimated angle belongs to the angle range G3 or the angle range G4, pixels of lower-end two lines in the upper adjacent block are used.
As the index B2, the sum of absolute differences of locally decoded pixel values of pixels arranged in the oblique direction V2 among the pixels of two lines used for calculating the index B1 can be used.
In the expression (7), m represents the height of the block to be encoded, and ref(x, y) represents the locally decoded pixel value of the pixel present at a position (x, y) in the left adjacent block. x and y are relative coordinates with an upper right pixel R1 of the left adjacent block as a reference position (0, 0), where x increases leftward and y increases downward.
In this case, the sum of absolute differences is calculated between the pixel of the line of x=0 and the pixel of the line of x=1, and the oblique direction V1 corresponds to a direction from the upper right to the lower left. The index B1 becomes larger as the sum of absolute differences is larger. Therefore, the change in the locally decoded pixel value in the oblique direction V1 is larger as the index B1 is larger, and the edge direction of the pixels of the two lines are highly likely to be the direction intersecting with the oblique direction V1.
Meanwhile, the index B2 is calculated by, for example, the following expression.
Even in this case, the sum of absolute differences calculated between the pixels in the line of x=0 and the pixel in the line of x=1. The oblique direction V2 corresponds to a direction from the lower right to the upper left, and is orthogonal to the oblique direction V1. The index B2 becomes larger as the sum of absolute differences is larger. Therefore, the change in the locally decoded pixel value in the oblique direction V2 is larger as the index B2 is larger, and the edge direction of the pixels of the two lines are highly likely to be the direction intersecting with the oblique direction V2.
In the expression (9), n represents the width of the block to be encoded, and ref(x, y) represents the locally decoded pixel value of the pixel present at the position (x, y) in the upper adjacent block. x and y are relative coordinates with a lower left pixel R2 of the upper adjacent block as the reference position (0, 0), where x increases rightward and y increases upward.
In this case, the sum of absolute differences is calculated between the pixel of the line of y=0 and the pixel of the line of y=1, and the oblique direction V1 corresponds to a direction from the lower right to the upper left. The change in the locally decoded pixel value in the oblique direction V1 is larger as the index B1 is larger, and the edge direction of the pixels of the two lines are highly likely to be the direction intersecting with the oblique direction V1.
Meanwhile, the index B2 is calculated by, for example, the following expression.
Even in this case, the sum of absolute differences is calculated between the pixels in the line of y=0 and the pixel in the line of y=1. The oblique direction V2 corresponds to a direction from the lower left to the upper right, and is orthogonal to the oblique direction V1. The change in the locally decoded pixel value in the oblique direction V2 is larger as the index B2 is larger, and the edge direction of the pixels of the two lines are highly likely to be the direction intersecting with the oblique direction V2.
According to the estimation processing in
The estimation unit 1621 of the video decoding device 1601 performs estimation processing similar to the estimation unit 825 to generate an upper two-bit estimated value. Then, the generation unit 1702 of the arithmetic decoding unit 1611 calculates an XOR of the upper two-bit estimated value and the two-bit bit value indicated by the flag information, and sets a value of the XOR as the upper two bits of the bit string indicating the angle of intra prediction. Then, the generation unit 1702 sets the remaining bit value output by the decoding unit 1701 as a bit other than the upper two bits of the bit string indicating the angle of intra prediction.
For example, in the case where the angle of intra prediction is the 11th angle, the XOR of the upper two-bit estimated value and the two-bit bit value indicated by the flag information is “10”. Therefore, “10” is set as the upper two bits and is concatenated with the remaining bit value “11” to generate the bit string “1011” indicating the 11th angle.
The configurations of the video encoding devices in
The configurations of the video decoding devices in
The configuration of the video encoding system 2301 in
The flowcharts illustrated in
For example, in steps 1403 and 1404 in
The block to be encoded 101, the upper adjacent pixel 102, and the left adjacent pixel 103 illustrated in
The upper adjacent block and the left adjacent block illustrated in
The weights w(i) illustrated in
The expressions (1) to (10) are merely examples, and other calculation expressions may be used to estimate the partial bit value of the bit string indicating the angle of intra prediction.
The video encoding device 401 in
The information processing apparatus in
The memory 2402 is, for example, a semiconductor memory such as a read only memory (ROM), a random access memory (RAM), a flash memory, or the like and stores programs and data used for processes. The memory 2402 can be used as the memory 824 in
The CPU 2401 (processor) operates as the first encoding unit 411, the estimation unit 412, the generation unit 413, and the second encoding unit 414 in
The CPU 2401 also operates as the first decoding unit 611, the estimation unit 612, the generation unit 613, and the second decoding unit 614 in
The CPU 2401 also operates as the block division unit 811, the prediction error generation unit 812, the orthogonal transform unit 813, the quantization unit 814, the arithmetic encoding unit 815, and the encoding control unit 816 in
The CPU 2401 also operates as the generation unit 901 and the encoding unit 902 in
The CPU 2401 also operates as the arithmetic decoding unit 1611, the inverse quantization unit 1612, the inverse orthogonal transform unit 1613, the reconstruction unit 1614, and the in-loop filter 1615 in
The CPU 2401 also operates as the decoding unit 1701 and the generation unit 1702 in
The input device 2403 is, for example, a keyboard or a pointing device and is used for inputting instructions and information from a user or an operator. The output device 2404 is, for example, a display device, a printer, or a speaker and is used for making an inquiry to the user or the operator and outputting a processing result. The processing result may be a decoded video.
The auxiliary storage device 2405 is, for example, a magnetic disk device, an optical disk device, a magneto-optical disk device, a tape device, or the like. The auxiliary storage device 2405 may be a hard disk drive. The information processing apparatus can store programs and data in the auxiliary storage device 2405 and load these programs and data into the memory 2402 for use.
The medium driving device 2406 drives a portable recording medium 2409 and accesses recorded contents of the portable recording medium 2409. The portable recording medium 2409 is a memory device, a flexible disk, an optical disk, a magneto-optical disk, or the like. The portable recording medium 2409 may be a compact disk read only memory (CD-ROM), a digital versatile disk (DVD), or a universal serial bus (USB) memory. The user or the operator can save programs and data in this portable recording medium 2409 and load these programs and data into the memory 2402 to use.
As described above, a computer-readable recording medium in which the programs and data used for processes are saved includes a physical (non-transitory) recording medium such as the memory 2402, the auxiliary storage device 2405, and the portable recording medium 2409.
The network connection device 2407 is a communication interface circuit that is connected to a communication network such as a local area network (LAN) and the Internet and performs data conversion involved in communication. The network connection device 2407 can transmit the encoded stream to the video decoding device and can receive the encoded stream from the video encoding device. The information processing apparatus can receive programs and data from an external device via the network connection device 2407 and load these programs and data into the memory 2402 for use.
Note that, the information processing apparatus does not need to include all the constituent elements in
While the disclosed embodiments and the advantages thereof have been described in detail, those skilled in the art will be able to make various modifications, additions, and omissions without departing from the scope of the embodiment as explicitly set forth in the claims.
All examples and conditional language provided herein are intended for the pedagogical purposes of aiding the reader in understanding the invention and the concepts contributed by the inventor to further the art, and are not to be construed as limitations to such specifically recited examples and conditions, nor does the organization of such examples in the specification relate to a showing of the superiority and inferiority of the invention. Although one or more embodiments of the present invention have been described in detail, it should be understood that the various changes, substitutions, and alterations could be made hereto without departing from the spirit and scope of the invention,
This application is a continuation application of International Application PCT/JP2018/002989 filed on Jan. 30, 2018 and designated the U.S., the entire contents of which are incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/JP2018/002989 | Jan 2018 | US |
Child | 16937689 | US |