The present invention relates to a video coding/decoding scheme, and more particularly, to a method for encoding a video sequence based on motion compensated temporal filtering (MCTF) using intelligently-divided group of pictures (GOP) and a method for decoding an encoded bitstream.
There is an existing MCTF-based video coding scheme by performing a wavelet transform along temporal axis, with motion information, to improve coding efficiency. The existing MCTF-based video coding is performed in a unit of a GOP, which has the fixed size of nth power of 2.
As in the motion prediction process of the existing video coding schemes, there inherently exists a domain where no motion can be predicted in the prediction process of the MCTF. In the case of the video coding scheme using a wavelet transform for a spatial domain transform, coding efficiency is lowered due to the effect of an unpredictable domain, i.e., an intra domain, because the spatial domain transform should be performed on the entire picture. Various methods of solving this problem have been proposed, but no effective solution has been yet found. When the spatial domain is transformed not by the wavelet transform but by a block-based video coding scheme, which is used in the existing international video standards such as MPEG-1, MPEG-2, MPEG-4 Part 2 Visual, MPEG-4 Part 10 AVC (Advanced Video Coding), or ITU-T H.264, the MCTF can be carried out in units of blocks so that the encoding can be separately performed for the intra blocks and inter blocks. When the block-based MCTF is performed, the Haar wavelet transform is used for motion prediction in one direction, and the 5/3 spline wavelet transform is used for motion prediction in both directions. Intra coding is performed when motion prediction cannot be performed or the efficiency of the motion prediction is lower than that of the intra coding.
In the process of performing MCTF, the higher the decomposition level, the farther a reference picture is temporally located, wherein the reference picture is referred to during motion prediction in the prediction process. Therefore, there is a high possibility of low correlation with a currently predicted picture.
Prediction efficiency is associated with motion variation in the video sequence.
Meanwhile,
On the basis of the fact that, in a dynamic video sequence, the larger the GOP size, the lower the prediction efficiency of the prediction picture, experiments have been performed while varying the GOP size.
In contrast, with regard to the static “Forman” QCIF 15 Hz video sequence, the graphs representing the coding results with different GOP sizes 8, 4, 2 and 1 are shown in
Although the foregoing descriptions explains the relationship between the GOP size and coding efficiency, by giving examples of a dynamic video sequence with a lot of motion variations and a static video sequence having little motion variations, it is general for one video sequence to include various degrees of motion variations. For example, there are the various degrees of motion variations in “Foreman” video sequence, as can be seen in
In view of the PSNR results for 97th to 112th frames for “Foreman” QCIF 15 Hz sequence of
Accordingly, when performing the MCTF-based coding of a video sequence, it is possible to achieve a high coding efficiency by intelligently selecting the GOP size.
It is an object of the present invention to provide a method of performing MCTF-based encoding in a unit of a 2N frame-sized GOP by adaptively dividing the GOP.
It is another object of the present invention to provide a method for decoding an encoded video bitstream, which is encoded based on the adaptive GOP structure.
It is yet another object of the present invention to provide a method of decoding an encoded video bitstream based on an adaptive GOP structure, which can support temporal scalability.
In order to accomplish these objectives, according to an aspect of the present invention, there is provided a method for performing motion compensated temporal filtering (MCTF)-based encoding on a video sequence. The method comprises the steps of: for each predefined 2N frame-sized group of pictures (GOP) of the video sequence, (a) encoding the 2N frame-sized GOP of the video sequence based on each of the different GOP sizes from the maximum size, 2N, to the minimum size, 2M (M is an integer between 1 and N) and obtaining different values between frames reconstructed after the encoding is performed and frames after the MCTF is performed, based on each of the different GOP sizes; (b) selecting at least one sub-GOP based on the difference values obtained by encoding the 2N frame-sized GOP of the video sequence based on each of the different GOP sizes; and (c) generating a bitstream by encoding the 2N-frame-sized GOP based on the at least one selected sub-GOP.
In one embodiment, the step (b) includes the sub-steps of (b1) comparing the difference values obtained from the encoding based on each of the different GOP sizes from 2N to 2M and, if the difference value obtained from the encoding based on the 2N-sized GOP unit is the smallest, selecting the 2N-sized GOP as a sub-GOP; and (b2) if the difference value obtained from the encoding based on the 2N-sized GOP is not the smallest, after decreasing N by 1 (i.e., N=N−1), i) selecting two 2M-sized GOPs as the sub-GOPs if N has the same value as M, and ii) repeating steps (b1) and (b2) for each of the front 2N frames and the rear 2N frames, if N does not have the same value as M.
In one embodiment, the difference value may be selected from a group of MSE (Mean Square Error), SAD (Sum of Absolute Differences), SSE (Sum of Squared Errors), SAD+λSADR (R is the number of bits of the GOP unit), and SSE+λSSER.
In another embodiment, the step b) includes the sub-steps of: (b1) comparing the difference values obtained from the encoding based on each of the different GOP sizes from 2N to 2M and, if the difference value obtained from the encoding based on the 2N-sized GOP unit is the smallest, selecting the 2N-sized GOP as a sub-GOP and setting a GOP divide bit inserted before the GOP bitstream as “0”; (b2) if the difference value obtained from the encoding based on the 2N-sized GOP is not the smallest, setting the GOP divide bit inserted before the GOP bitstream as “0” and, after decreasing N by 1 (i.e., N=N−1), i) selecting two 2M-sized GOPs as the sub-GOPs if N has the same value as M, and ii) repeating steps (b1) and (b2) for each of the front 2N frames and the rear 2N frames, if N does not have the same value as M.
In another embodiment, the at least one selected sub-GOP information is set in the first frame header information of the GOP to transmit to a decoder.
According to another aspect of the present invention, there is provided a method for performing MCTF-based coding on a video sequence. The method comprises the steps of: (a) for each predetermined 2N-frame-sized GOP of the video sequence, (a1) encoding the 2N frame-sized GOP of the video sequence based on each of the different GOP sizes from the maximum size, 2N, to the minimum size, 2M (M is an integer between 1 and N) and selecting at least one sub-GOP based on the encoding result, and (a2) generating a bitstream by encoding the 2N-frame-sized GOP based on the at least one selected sub-GOP; and (b) inserting temporal scalability range information in the generated bitstream.
In one embodiment, the range of temporal scalability is based on a minimum size (2M) of the selected sub-GOP.
According to yet another aspect of the present invention, there is provided a method for decoding a MCTF-based encoded bitstream. The method comprises the steps of: for each predetermined 2N-sized GOP bitstream, (a) determining whether the GOP is divided; (b) when the GOP is determined not to be divided, decoding the GOP bitstream; (c) when the GOP is determined to be divided, dividing the GOP bitstream; and (d) decoding the divided GOP bitstreams.
According to yet another aspect of the present invention, there is provided a method for decoding a MCTF-based encoded bitstream. The method comprises the steps of: for each predetermined 2N-sized GOP bitstream, reading adaptively-divided GOP structure information from the GOP bitstream; and decoding the GOP bitstream based on the adaptively-divided GOP structure information.
According to yet another aspect of the present invention, there is provided a method for decoding a MCTF-based encoded bitstream. The method comprises the steps of: for a predetermined-sized GOP bitstream, reading variable GOP structure information from the GOP bitstream; and decoding the GOP bitstream based on the variable GOP structure information.
According to yet another aspect of the present invention, there is provided a method for providing 1/L temporal scalability upon decoding an MCTF-based encoded bitstream, the method comprises the steps of: for each predetermined 2N-frame-sized GOP bitstream, (a) initializing “k” to 0 (k is an integer); (b) initializing “FrameNum” to 2N; (c) detecting whether there is a low-frequency frame in a bitstream from FrameNumth frame to Lth frame in the reverse direction, and decreasing FrameNum by L; (d) based on the result of detecting in step (c), (d-1) increasing the value of k by 1, if there is no low-frequency frame, and (d-2) selecting the low-frequency frame detected first in the reverse direction if there is a low-frequency picture and, if the value of k is not 0, further selecting subsequent k number of high-frequency frames and then re-initializing k to 0; and (e) repeating steps (c) and (d) until FramNum reaches 0, and finally selecting 2N/L number of frames.
According to the present invention, the MCTF-based video coding is performed by adaptively dividing the GOP size based on the performance and thereby obtaining high coding efficiency.
Hereinafter, the present invention will be described in detail with reference to
(1) For one GOP of the video frame sequence, encoding is performed on the basis of each different GOP sizes, from the maximum 2N-sized GOP to the minimum 2M-sized GOP and, for each of the different GOP sizes, MSE (Mean Square Error) between each frame reconstructed per sub-band after the MCTF is performed and each frame reconstructed per sub-band after the encoding is performed are obtained (S1610, S1620 and S1630). MSE is just an example and not limited thereto and any one of SAD (Sum of Absolute Differences), SSE (Sum of Squared Errors), SAD+λSADR (R: the bit number of one GOP), SSE+λSSER may be used as the reference. This will be described below.
(2) At least one sub-GOP is selected to divide the 2N-sized GOP on the basis of MSE of each GOP size obtained in process (1) (S1640). In this specification, a process of dividing the 2N-sized GOP by selecting the sub-GOPs that produce minimum MSE in the GOP is referred to as a “mode decision” procedure.
(3) The video sequence having a 2N frame size is encoded on the basis of the selected sub-GOP structure to generate a bitstream thereof (S1650).
(4) Processes (1) to (3) are repeated for the next GOP of the video frame sequence.
In the above embodiment, in the mode decision procedure, the MSE of each frame can be calculated by the following equation.
In the above Equation, k indicates the number of pixels of one frame, F(i) is the pixel value of per-subband frame generated after the MCTF procedure is performed and G(i) is the pixel value of per-subband frame reconstructed after the encoding is performed.
(1) With regard to 16 frames, encoding is performed based on the various sub-GOP sizes of 16 (N=4), 8 (N=3), 4 (N=2) and 2 (N=M=1), respectively, and the MSE values of sub-GOPs are calculated based on the encoding results and then compared with each other (S1702).
Based on the comparison results:
A. When the MSE obtained from the encoding results of 16 frame-sized GOP is the smallest, the 16-frame GOP is selected, and the mode decision process is terminated (S1704).
B. When the MSE obtained from the encoding results of a 16-frame GOP is not the smallest, the front 8 frames are subjected to the following process (2) (S1706), and the rear 8 frames are subjected to the following process (3) (S1708).
(2) The front 8 frames are encoded based on the different GOP sizes and each of the MSE values of the encoding results are compared with each other:
A. When the MSE obtained from the encoding result of the 8 frame-sized GOP is the smallest, the 8 frame-sized GOP is selected (S1710).
B. When the MSE obtained from the encoding result of the 8-frame GOP is not the smallest, the front 4 frames are subjected to the following process (4) (S1714), and the rear 4 frames are subjected to the following process (5) (S1716).
(3) The rear 8 frames are encoded based on the different GOP sizes and each of the MSE values of the encoding results are compared with each other:
A. When the MSE obtained from the encoding result of the 8 frame-sized GOP is the smallest, the 8 frame-sized GOP is selected, and the mode decision process is terminated (S1712).
B. When the MSE obtained from the encoding result of the 8 frame-sized GOP is not the smallest, the front 4 frames are subjected to the following process (6) (S1718), and the rear 4 frames are subjected to the following process (7) (S1720).
(4) The front 4 frames are encoded based on the different GOP sizes and each of the MSE values of the encoding results are compared with each other:
A. When the MSE obtained from the encoding result of 4-sized GOP is the smallest, the 4 frame-sized GOP is selected (S1722).
B. When the MSE obtained from the encoding result of the 4-sized GOP is not the smallest, two 2-sized GOPs are selected (S1724).
(5) The rear 4 frames are encoded based on the different GOP sizes and each of the MSE values of the encoding results are compared with each other:
A. When the MSE obtained from the encoding result of 4-sized GOP is the smallest, the 4-sized GOP is selected (S1726).
B. When the MSE obtained from the encoding result of the 4-sized GOP is not the smallest, two 2-sized GOPs are selected (S1728).
(6) The front 4 frames are encoded based on the different GOP sizes and each of the MSE values of the encoding results are compared with each other:
A. When the MSE obtained from the encoding result of 4-sized GOP is the smallest, the 4 frame-sized GOP is selected (S1730).
B. When the MSE obtained from the encoding result of the 4-sized GOP is not the smallest, two 2-sized GOPs are selected (S1732).
(7) The rear 4 frames are encoded based on the different GOP sizes and each of the MSE values of the encoding results are compared with each other:
A. When the obtained from the encoding result of 4-sized GOP is the smallest, the 4 frame-sized GOP is selected and the mode decision process is terminated (S1734).
B. When the MSE obtained from the encoding result of the 4-sized GOP is not the smallest, two 2-frame GOPs are selected, and the process is terminated (S1736).
The foregoing algorithm of
(1) First, in comparison of the MSE values obtained from the 16 frame encoding, since the MSE value of 16 frame-sized GOP is not the smallest, the comparison of the MSE values for the front 8 frames and the rear 8 frames, respectively, is performed.
(2) In comparison of the MSE values obtained from the front 8 frame encoding, since the MSE value of 8 frame-sized GOP is the smallest, the 8 frame-sized GOP is selected.
(3) In comparison of the MSE values obtained from the rear 8 frame encoding, since the MSE value of 8 frame-sized GOP is not the smallest, the comparison of the MSE values for the front 4 frames and the rear 4 frames, respectively, is performed.
(4) In comparison of the MSE values obtained from the front 4 frame encoding, since the MSE value of 4 frame-sized GOP is the smallest, the 4 frame-sized GOP is selected.
(5) In comparison of the MSE values obtained from the rear 4 frame encoding, since the MSE value of 4 frame-sized GOP is not the smallest, two 2-frame GOPs are selected, and the process is terminated.
Otherwise, N is decreased by 1 (S2140). The decreased N is compared with M (S2150). As a result of the comparison, if the two values are identical, two 2M-sized GOPs are selected (S2160).
If the decreased N is not identical to M, the front 2N-sized sequence and the rear 2N-sized sequence are subjected to repetition of the foregoing processes S2110 to S2160.
In the above embodiment, the MSE is used in the comparison of the mode decision process. Alternatively, SAD (Sum of Absolute Difference) or SSE (Sum of Squared Error) between the image frames of the input sequence and the image frames reconstructed after the encoding may be used. They may be used in case that the calculation complexity of the mode decision is a lot considered.
In another embodiment, in the mode decision process, Lagrangian optimization scheme used in the AVC (Advanced Video Coding), the basic international video standard, may be used. This scheme is to use a value represented by the sum of the product of the number of bits and a Lagrangian coefficient, together with the SAD or SSE. The Lagrangian coefficient is defined based on a quantization coefficient (Qp) value as follows:
λSAD=0.92×2Qp/6−2
λSSE=0.85×2Qp/3−4 Equation 2
The comparison value, J, can be obtained by the following equations:
In the case of using the SAD,
J=SAD+λSADR Equation 3
J=SSE+λSSER Equation 4
(In Equations 3 and 4, R indicates the number of bits in one GOP when the GOP is encoded.)
That is, the mode decision may be made, (a) considering the calculation complexity, (2) using an optimizing method that considers calculation complexity to a certain degree in predicting the bit amounts to be transmitted, or (3) predicting or obtaining the actual bit amounts.
In one embodiment, in order to decode a bitstream encoded by the adaptive GOP structure-based encoding method in accordance with one embodiment of the present invention, the corresponding GOP size and decomposition stage information may be encoded and transmitted to a decoder using “gop_size” and “decomposition_stage”, which are specified as slice header information in SVM 3.0 codec of SVC. The SVM 3.0 codec is currently undergoing international standardization. Then, the encoded bitstream is decoded using the corresponding GOP size in the existing SVC decoder without any additional bit.
In another example, the GOP size information may be encoded and transmitted into a GOP header, and thereby the adaptively-divided GOP may be decoded. As one example, 1 bit for “variable-GOP-Size” is allocated in a header of a bitstream to indicate the use of the variable GOP size to the decoder, and then decoding can be performed suitably in the corresponding conditions.
According to another embodiment of the present invention, in order to decode the encoded bitstream at a decoder, an encoder can add a “gop_divide_bit” as one bit flag to the front of each GOP-based bitstream and then transmits it to the decoder, wherein the “gop_divide_bit” indicates whether to divide a GOP. This may be performed by slightly modifying the mode decision process shown in
A decoding algorithm for an encoded bitstream, which the flag “gop_divide_bit” is added thereto, is explained below. In this case, a value of N, which is a power of the original (non-divided) GOP size, will be transmitted together.
(1) The flag “gop_divide_bit” in the bitstream corresponding to the 2N-frame size is examined.
A. If the flag is ‘0’, the 2N-frame GOP is decoded, and
B. If the flag is ‘1’, N is decreased by 1 (here, N=N−1).
(2) With respect to the front 2N-frame GOP and the rear 2N-frame GOP, the process (1) is performed respectively.
(1) The flag “gop_divide_bit” is decoded and read out in the bitstream. As a result, because the flag has a value of ‘1’, it is determined that the 16-sized GOP has been divided. Accordingly, the front 8 frames are subjected to the following process (2), and the rear 8 frames are subjected to the following process (3).
(2) The flag “gop_divide_bit” is decoded and read out in the bitstream of the front 8 frames. As a result, because the flag has a value of ‘1’, it is determined that the 8-sized GOP has been divided. Thus, the front 4 frames are subjected to the following process (4), and the rear 4 frames are subjected to the following process (5).
(3) The flag “gop_divide_bit” is decoded and read out in the rear bitstream of 8 frames. As a result, because the flag has a value of ‘0’, an 8-frame GOP bitstream is decoded, and the decoded image frames may be obtained.
(4) The flag “gop_divide_bit” is decoded and read out in the bitstream of the front 4 frames. As a result, because the flag has a value of ‘1’, it is determined that the 4-sized GOP has been divided. Thus, the front 2 frames are subjected to the following process (6), and the rear 2 frames are subjected to the following process (7):
(5) The flag “gop_divide_bit” is decoded and read out in the bitstream of the rear 4 frames. As a result, because the flag has a value of ‘0’, the 4-frame GOP bitstream is decoded, and the decoded image frames may be obtained.
(6) The flag “gop_divide_bit” is decoded and read out in the bitstream of the front 2 frames. As a result, because the flag has a value of ‘0’, the 2-frame GOP bitstream is decoded, and the decoded image frames may be obtained.
(7) The flag “gop_divide_bit” is decoded and read out in the bitstream of the rear 2 frames. As a result, because the flag has a value of ‘0’, the 2-frame GOP bitstream is decoded, and the decoded image frames may be obtained.
According to yet another embodiment of the present invention, an encoder of performing the adaptive GOP structure-based video coding according to the present invention can encode information on sub-GOPs, which are adaptively divided within the constant GOP size, and then transmit it to a decoder.
In one example, when the encoding is performed based on 16 frame-sized GOP (i.e., N=4 and M=1), the original GOP size information is encoded in a sequence header and the information on sub-GOPs, which are adaptively divided within the 16 frame-sized GOP, is encoded in the slice header of a first frame of each GOP. The sub-GOP information is represented by the sub-GOP size divided by “N” of the original GOP size, 2N, i.e., 4. Then, each of the divided information is encoded in two fixed bits. For example, if the 16-sized GOP is selected as the sub-GOP, the information is encoded in “00b”. If the 8-sized GOP is selected as the sub-GOP, the information is encoded in “01b”. If the 4-sized GOP is selected as the sub-GOP, the information is encoded in “10b”. If the 2-sized GOP is selected as the sub-GOP, the information is encoded in “11b”. When the sum of the GOP sizes selected as the sub-GOPs within the 16 frame size is 16, the encoding of the selected GOP information is terminated. For example, if the sub-GOPs are determined as the sizes of 8, 4, 4, a total of 6 bits, 01-10-10, are needed. If the sub-GOPs are determined as the sizes of 16, a total of 2 bits, 00, are needed. If the sub-GOPs are determined as the sizes of 4, 2, 2, 8, a total of 8 bits, 10-11-11-01, are needed. If the sub-GOPs are determined as the sizes of 2, 2, 2, 2, 2, 2, 2, 2, 2, a total of 16 bits, 11-11-11-11-11-11-11-11, are needed. In this manner, the sub-GOP information can be expressed. In the case of transmitting the sub-GOP information on the encoder side together with the bitstream, the decoder decodes each GOP on the basis of the received sub-GOP information.
In an embodiment of the present invention, the decoder may provide temporal scalability upon decoding a bitstream encoded based on the adaptively divided GOP structure. According to an embodiment of the present invention, the bitstream encoded based on the adaptively divided GOP structure should be decoded according the order of frames because it is different in a structure from a bitstream encoded based on the fixed GOP size.
For example, as shown in
Total resolution: L3(0), H3(1), H2(2), H2(3), H1(4), H1(5), H1(6), H1(7), L2(8), H2(9), H1(10), H2(11), L1(12), H1(13), L1(14) and H1(15).
½ resolution: L3(0), H3(1), H2(2), H2(3), L2(8), H2(9), L1(12) and L1(14).
¼ resolution: L3(0), H3(1), L2(8) and L1(14).
⅛ resolution: L3(0) and L1(14).
1/16 resolution: L1(14).
(The symbol “L” denotes a low-frequency image frame, and the symbol “H” denotes a high-frequency image frame.)
(1) A value of k is initially set to 0 (here, k is an integer) (S3810).
(2) A value of FrameNum is initially set to 2N (S3820).
(3) It is detected whether or not there is a low-frequency frame in the bitstream from the FrameNumth frame to the Lth frame in a reverse direction (S3830), and FrameNum is decreased by L (S3840).
(4) Based on the detecting result in step (3) (S3850),
(i) if there is no low-frequency frame, the value of k is increased by 1 (S3870), and
(ii) if there is a low-frequency frame, the low-frequency frame detected first in the inverse direction is selected, and if the value of k is not 0, k number of subsequent high-frequency frames are also selected, and then the value of k is set to 0 again (S3860).
(5) Steps (3) and (4) are repeated until FramNum reaches 0 (S3880), and 2N/L number of frames are finally selected.
For example, the above-mentioned algorithm for supporting the ⅛ resolution of the encoded bitstream where the sub-GOP sizes are selected as (8, 4, 2, 2) in the 16-frame GOP is executed as follows. Provided that the entire bitstream is configured of “L3(0), H3(1), H2(2), H2(3), H1(4), H1(5), H1(6), H1(7), L2(8). H2(9), H1(10), H2(11), L1(12), H1(13), L1(14) and H1(15)”:
(1) A parameter k is initially set to 0.
(2) FrameNum is initially set to 16.
(3) A low-frequency frame is detected from the FrameNum (=16)th bitstream B1(15) in a reverse direction, and FrameNum is decreased by 8 (i.e., FrameNum=FrameNum−8).
(4) Based on the detecting result in step (3), the low-frequency frame, L1(14), is selected.
(5) The low-frequency frame is detected from the FrameNum (=8)th bitstream H1(7) in a reverse direction, and FrameNum is decreased by 8 (FrameNum=FrameNum−8).
(6) Based on the detecting result in step (5), the low-frequency frame, L3(0), is selected.
(7) Since FrameNum is 0, the algorithm is terminated. As a result of executing the algorithm, it can be seen that two frames L3(0) and L1(14) are selected in order to support the ⅛ resolution.
An example of supporting a ¼ resolution is as follows:
(1) A parameter k is initially set to 0.
(2) FrameNum is initially set to 16.
(3) A low-frequency frame is detected from a FrameNum (=16)th bitstream H1(15) in a reverse direction, and FrameNum is decreased by 4 (FrameNum=FrameNum−4).
(4) Based on the detecting result in step (3), the low frequency frame L1(14) is selected.
(5) Since FrameNum(=12) is not ‘0’ the low-frequency frame is detected from the 12th bitstream H2(10) in a reverse direction, and FrameNum is decreased by 4 (FrameNum=FrameNum−4).
(6) Based on the detecting result in step (5), L2(8) is selected.
(7) Since FrameNum(=8) is not ‘0’ the low-frequency frame is detected from the 8th bitstream H1(7) in a reverse direction, and FrameNum is decreased by 4 (FrameNum=FrameNum−4).
(8) Based on the detecting result in step (7), k is increased by 1 because there is no low-frequency frame.
(9) Since FrameNum(=4) is not ‘0’ the low-frequency frame is detected from the 4th bitstream H2(3) in a reverse direction, and FrameNum is decreased by 4 (FrameNum=FrameNum−4).
(10) Based on the detecting result in step (9), the low-frequency frame L3(0) is selected. Then, because k is 1, the next frame H3(1) is selected, and k is set to 0 again.
(11) Since FrameNum is 0, the algorithm is terminated. As a result of executing the algorithm, it can be seen that four frames L3(0), H3(1), L2(8), and L1(14) are selected in order to support the ¼ resolution.
According to another embodiment of the present invention, the encoder may provide desired temporal scalability upon encoding a video based on the adaptive GOP structure, by adjusting a level of a sub-GOP (i.e., a selectable minimum size of the sub-GOP) selected in the mode decision process. For example, when the GOP size is 2N (generally, N≧4), mode decision performed by comparing the encoding results based on 2N sized sub-GOP, 2N sized sub-GOP, 2N-2 sized sub-GOP, and 2N-3 sized sub-GOP units to each other to provide 1/2N-3 or more temporal scalability is defined to as “Level—1”, mode decision performed by comparing the encoding results based on 2N sized sub-GOP, 2N-1 sized sub-GOP, and 2N-2 sized sub-GOP units to each other to provide 1/2N-2 or more temporal scalability is defined to as “Level—2”, and mode decision performed by comparing encoding result values based on 2N sized sub-GOP and 2N-1 sized sub-GOP units to each other to provide 1/2N-1 or more temporal scalability is defined to as “Level—3”. The encoder may encode level information of the mode decision and transmit it to a decoder (extractor), in order to notify a supportable range of the temporal scalability. The following Table 1 shows the range of the temporal scalability that can be provided depending on levels of the mode decision.
An example of the above-described method will be described. In case that the encoding of a video sequence at 15 Hz is performed based on 24 frame-sized GOP, the level information is encoded and transmitted. The level information is defined as follows.
When the comparison of the encoding results based on 24 frame-sized GOP, 23 frame-sized GOP, 22 frame-sized GOP, and 21 frame-sized GOP to each other is performed to provide 7.5 Hz (1/24−3=½) or more temporal scalability, the level information is defined as Level—1. When the comparison of the encoding results based on 24 frame-sized GOP, 23 frame-sized GOP, and 22 frame-sized GOP units to each other is performed to provide 3.75 Hz (1/24−2=¼) or more temporal scalability, it is defined as Level—2, and when the comparison of the encoding results based on 24 frame-sized GOP and 23 frame-sized GOP units to each other is performed to provide 1.875 Hz (1/24−1=⅛) or more temporal scalability, it is defined as Level—3.
That is, in order to provide a certain temporal scalability among the three temporal scalability modes, the encoder encodes the corresponding level information transmits it to the decoder (e.g., for SVC, in order to provide the specific temporal scalability among the three temporal scalability modes, the encoder encodes the corresponding level information and transmits it to the extractor). In one instance, the encoder may encode Level—1 into “0”, Level—2 into “10”, and Level—1 into “11”. In another instance, the encoder may encode Level—1 into “1”, Level—2 into “010”, and Level—3 into “011”. It will be appreciated by those skilled in the art that the level information may be encoded by any other manners and the present invention is not limited to the above-mentioned manners.
To transmit the supportable temporal scalability level information to the extractor of the decoder as described above, a flag may be added to the scalability Information, SEI message, of JSVM (Joint Scalable Video Model) 2.0, as shown in
A flag “use_adaptive_gop_structure_flag” in a hatched area of
The present invention described above may be provided as one or more computer-readable mediums that are implemented on at least one manufactured object. The manufactured object may be a floppy disc, a hard disc, a CD ROM, a flash memory card, a PROM, a RAM, a ROM, or a magnetic tape. Generally, computer-readable programs may be implemented by any programming language. The language includes C, C++, or JAVA.
Although exemplary embodiments of the present invention have been described with reference to the attached drawings, the present invention is not limited to these embodiments, and it should be appreciated to those skilled in the art that a variety of modifications and changes can be made without departing from the spirit and scope of the present invention.
Number | Date | Country | Kind |
---|---|---|---|
10-2004-0083333 | Oct 2004 | KR | national |
10-2005-0002247 | Jan 2005 | KR | national |
10-2005-0031712 | Apr 2005 | KR | national |
10-2005-0068494 | Jul 2005 | KR | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/KR2005/003467 | 10/18/2005 | WO | 00 | 12/10/2008 |