The present invention relates generally to video image processing and, more particularly, to encoding and decoding video image data.
Video compression uses block processing for many operations. In block processing, a block of neighboring pixels is grouped into a coding unit and compression operations treat this group of pixels as one unit to take advantage of correlations among neighboring pixels within the coding unit. Block-based processing often includes prediction coding and transform coding. Transform coding with quantization is a type of data compression that is commonly “lossy” as the quantization of a transform block taken from a source picture often discards data associated with the transform block in the source picture, thereby lowering its bandwidth requirement but often also resulting in quality loss in reproduction of the original transform block from the source picture.
MPEG-4 AVC, also known as H.264, is an established video compression standard that uses transform coding in block processing. In H.264, a picture is divided into macroblocks (MBs) of 16×16 pixels. Each MB is often further divided into smaller blocks. Blocks equal in size to or smaller than a MB are predicted using intra-/inter-picture prediction, and a spatial transform along with quantization is applied to the prediction residuals. The quantized transform coefficients of the residuals are commonly encoded using entropy coding methods (i.e., variable length coding or arithmetic coding). Context Adaptive Binary Arithmetic Coding (CABAC) was introduced in H.264 to provide a substantially lossless compression efficiency by combining an adaptive binary arithmetic coding technique with a set of context models. Context model selection plays a role in CABAC in providing a degree of adaptation and redundancy reduction. H.264 specifies two kinds of scan patterns over 2D blocks. A zigzag scan is used for pictures coded with progressive video compression techniques and an alternative scan is for pictures coded with interlaced video compression techniques.
HEVC (High Efficiency Video Coding), an international video coding standard developed to succeed H.264, extends transform block sizes to 16×16 and 32×32 pixels to benefit high definition (HD) video coding.
Various embodiments of the present invention will be described below in more detail, with reference to the accompanying drawings.
It is to be noted, however, that the appended drawings illustrate embodiments of this invention and are therefore not to be considered limiting of its scope, for the invention may admit to other equally effective embodiments.
Various embodiments and features of the invention will now be described. In one embodiment of the invention, a significance map of a matrix of video data coefficients is encoded or decoded using context-based adaptive binary arithmetic coding (CABAC). More specifically, a significance map for a matrix of quantized and transformed coefficients is (either encoded or decoded) scanned line-by-line (referred to as scanning lines) along a scanning pattern. Each scanning line may be a vertical, horizontal, or diagonal section of the scanning pattern. Context models for each element processed in a particular scanning line are chosen based on values of neighboring elements that are not in the scanning line, but rather are in other scanning lines. In some embodiments, the neighboring elements are in no more than two other scanning lines. In other embodiments, the neighboring elements are only in one other scanning line.
Avoiding reliance on neighbors that are in the same scanning line facilitates parallel processing. For example, a first encoder could process a binary number along a scanning line while a second encoder could, in parallel, process another binary number in the same scanning line. This simultaneous processing is facilitated by the fact that the context models for each of the two binary numbers are not interdependent. That is to say, the binary number being processed by the first encoder does not depend, for selection of its context model, on the binary number being processed by the second encoder.
In another embodiment of the invention, given a block in the transform domain, the associated significance map is coded following a scanning pattern. The scanning pattern is pre-determined for a current block, a current slice, a current picture or a current sequence, or it can be one of a few possible scanning patterns available for a current block, a current slice, a current picture or a current sequence.
In yet another embodiment of the invention, the context model for an element in the significance map is selected based upon the element's frequency position in the transform domain. An element in the low frequency position in the transform domain may share the same context model with other elements in other transform blocks, but in the same frequency position, because of possible high correlation among those elements at the same frequency position. An element in high frequency position in the transform domain may be determined based upon the values (0 or 1) of the element's coded neighbors within the same block, excluding the coded neighbors along the same scanning line.
An example of a video system in which an embodiment of the invention may be used will now be described. It is understood that elements depicted as function blocks in the figures may be implemented as hardware, software, or a combination thereof. Furthermore, embodiments of the invention may also be employed on other systems, such as on a personal computer. smartphone or tablet computer.
Referring to
The head end 100 is also communicatively linked to a hybrid fiber cable (HFC) network 122. The HFC network 122 is communicatively linked to a plurality of nodes 124, 126, and 128. Each of the nodes 124, 126, and 128 is linked by coaxial cable to one of the neighborhoods 129, 130 and 131 and delivers cable television signals to that neighborhood. One of the neighborhoods 130 of
During operation, head end 100 receives local and nonlocal programming video signals from the satellite dish 112 and the local station 114. The nonlocal programming video signals are received in the form of a digital video stream, while the local programming video signals are received as an analog video stream. In some embodiments, local programming may also be received as a digital video stream. The digital video stream is decoded by the decoder 104 and sent to the switcher 102 in response to customer requests. The head end 100 also includes a server 108 communicatively linked to a mass storage device 110. The mass storage device 110 stores various types of video content, including video on demand (VOD), which the server 108 retrieves and provides to the switcher 102. The switcher 102 routes local programming directly to the modulators 118, which modulate the local programming, and routes the non-local programming (including any VOD) to the encoders 116. The encoders 116 digitally encode the non-local programming. The encoded non-local programming is then transmitted to the modulators 118. The combiner 120 receives the modulated analog video data and the modulated digital video data, combines the video data and transmits it via multiple radio frequency (RF) channels to the HFC network 122.
The HFC network 122 transmits the combined video data to the nodes 124, 126 and 128, which retransmit the data to their respective neighborhoods 129, 130 and 131. The home 132 receives this video data at the set-top box 134, more specifically at the first decoder 138 and the second decoder 140. The first and second decoders 138 and 140 decode the digital portion of the video data and provide the decoded data to the user interface 142, which then provides the decoded data to the video display 136.
The encoders 116 and the decoders 138 and 140 of
A high-level description of how video data gets encoded and decoded by the encoders 116 and the decoders 138 and 140 in an embodiment of the invention will now be provided. In this embodiment, the encoders and decoders operate according to a High Efficiency Video Coding (HEVC) method. HEVC is a block-based hybrid spatial and temporal predictive coding method. In HEVC, an input picture is first divided into square blocks, called LCUs (largest coding units), as shown in
How a particular LCU is split into CUs can be represented by a quadtree. At each node of the quadtree, a flag is set to “1” if the node is further split into sub-nodes. Otherwise, the flag is unset at “0.” For example, the LCU partition of
Each CU can be further divided into predictive units (PUs). Thus, at each leaf of a quadtree, a final CU of 2N×2N can possess one of four possible patterns (N×N, N×2N, 2N×N and 2N×2N), as shown in
Each CU can also be divided into transform units (TUs) by application of a block transform operation. A block transform operation tends to decorrelate the pixels within the block and compact the block energy into the low order coefficients of the transform block. But, unlike other methods where only one transform of 8×8 or 4×4 is applied to a MB, in the present embodiment, a set of block transforms of different sizes may be applied to a CU, as shown in
The TUs and PUs of any given CU may be used for different purposes. TUs are typically used for transformation, quantizing and coding operations, while PUs are typically used for spatial and temporal prediction. There is not necessarily a direct relationship between the number of PUs and the number of TUs for a given CU.
The encoders 116 (
There are several possible spatial prediction directions that the spatial prediction module 129 can perform per PU, including horizontal, vertical, 45-degree diagonal, 135-degree diagonal, DC, Planar, etc. In one embodiment, the number of Luma intra prediction modes for 4*4, 8*8, 16*16, 32*32, and 64*64 blocks is 18, 35, 35, 35, and 4 respectively. Including the Luma intra prediction modes, an additional mode, called IntraFromLuma, may be used for the Chroma intra prediction mode. A syntax indicates the spatial prediction direction per PU.
The encoder 116 (
The prediction PU is then subtracted from the current PU, resulting in the residual PU, e. The residual PU, e, is then transformed by a transform module 116, one transform unit (TU) at a time, resulting in the residual PU in the transform domain, represented by transform coefficients, E. To accomplish this task, the transform module 116 uses either a square or a non-square block transform.
Referring back to
To facilitate temporal and spatial prediction, the encoder 116 also takes the quantized transform coefficients E and dequantizes them with a dequantizer module 122 resulting in the dequantized transform coefficients E′. The dequantized transform coefficients E′ are then inverse transformed by an inverse transform module 124, resulting in the reconstructed residual PU, e′. The reconstructed residual PU, e′, is then added to the corresponding prediction, PU, x′, either spatial or temporal, to form a reconstructed PU, x″.
Referring still to
In an embodiment of the invention, intra pictures (such as an I picture) and inter pictures (such as P pictures or B pictures) are supported by the encoder 116 (
The operation of the entropy coding module 120 (
Once the entropy coding module 120 has created the significance map, it codes the significance map. In one embodiment, this is accomplished by using a context-based adaptive binary arithmetic coding (CABAC) technique. In doing so, the entropy coding module 120 scans the significance map along a scanning line and, for each entry in the significance map, the coding module chooses a context model for that entry. The entropy coding module 120 then codes the entry based on the chosen context model. That is, each entry is assigned a probability based on the context model (the mathematical probability model) being used. The probabilities are accumulated until the entire significance map has been encoded.
The value output by the entropy coding module 120 as well as the entropy encoded signs, significance map and non-zero coefficients are inserted into the bitstream by the encoder 116 (
As has been described above, converting video pictures into a compressed bitstream on the encoder side and converting the bitstream back into video pictures on the decoder side is a multi-step process. Various embodiments of the invention described herein are generally directed to the part of the process in which the significance map is encoded and decoded.
To accommodate parallel processing according to an embodiment of the present invention, the context models for at least one of the elements of a significance map are chosen based on values of neighboring elements, excluding elements along the same scanning line. In this way, dependencies between elements along the same scanning line are eliminated.
Referring to
In each example, elements 602 and 604 are along the same scanning line within the scanning pattern, but can be processed in parallel with one another. This is because the context models for each of these two elements does not depend on the value of the other element. In other words, the context model for the first element 602 does not depend on the value of the second element 604.
A more specific example will now be provided. If the elements of the significance map are processed along a diagonal scanning pattern (as in
Rule A: For an element at position (0, 0), (0, 1) or (1, 0), the encoder or decoder assigns a unique context model. That is, an element at position (0, 0), (0, 1) or (1, 0) in a current block shares the same context model with other elements in significance maps of other blocks at the same position (0, 0), (0, 1) or (1, 0).
Rule B: For an element at position (0, x>1) the encoder or decoder chooses the context model based on the values (0 or 1) of the element's neighbors at positions (0, x−1), (0, x−2), and (1, x−2).
Rule C: For an element at position (y>1, 0), the encoder or decoder chooses the context model based on the values (0 or 1) of the element's neighbors at positions (y−1, 0), (y−2, 0) and (y−2, 1).
Rule D: For an element at position (y>0, x>0), the encoder or decoder chooses the context model based on the value (0 or 1) of the element's neighbors at positions (y−1, x−1), (y−1, x) and (y, x−1) as well as on:
Rule E: (y−1, x−2) and (y, x−2) if x>1,
Rule F: (y+1, x−2) if x is larger than 1 and y is smaller than the height−1,
Rule G: (y−2, x−1) and (y−2, x) if y is larger than 1, and
Rule H: (y−2, x+1) if y is larger than 1 and x is smaller than the width−1.
The total number of instances of a binary ‘1’ is calculated and the encoder or decoder uses a context model that corresponds to that number. For example, if Rules D, E, and F are applied to element (y,x), the encoder or decoder would calculate the number of instances of binary ‘1’ among the neighboring elements at (y−1,x−1), (y−1,x), (y,x−1), (y−1,x−2), (y,x−2) and (y+1,x−2). If there are three instances of binary ‘1’ among those neighboring elements, then the context model number three is used to encode or decode the element being processed. Each context model may yield a different probability for an element in a significance map.
Referring to the flowchart of
At step 706, the encoder or decoder determines whether the element is at position (0,x>1). If so, then the process continues to step 708, in which the encoder or decoder selects the context model based on the value (0 or 1) of the element's neighbors at positions (0,x−1), (0,x−2) and (1,x−2). Otherwise the process moves to step 710, at which the encoder or decoder determines whether the element is at position (y>1,0). If it is, then the process moves to step 712, at which the encoder or decoder selects the context model for the element based on the neighboring elements (y−1,0), (y−2,0) and (y−2,1).
At step 714, the encoder or decoder determines whether the element is at position (y>0,x>0). If it is, then the process moves to step 716, at which the encoder or decoder selects the context model for that element based on the value of the elements at positions (y−1,x−1), (y−1,x), and (y,x−1). If not, then the process moves to step 718, at which the encoder or decoder determines whether the x coordinate of the element is greater than 1. If it is, then the process moves to step 720, at which the encoder or decoder additionally considers the value of the elements at positions (y−1,x−2) and (y,x−2). If not, then the process moves to step 726.
At step 722, the encoder or decoder determines whether y is less than the height of the significance map minus 1. If it is, then the encoder or decoder additionally considers the value of the element at position (y+1,x−2) at step 724. At step 726, the encoder or decoder determines whether y is greater than 1. If it is, then the encoder or decoder additionally considers the values of the elements at positions (y−2,x−1) and (y−2, x) at step 728. At step 730, the encoder or decoder determines whether x is less than the width of the significance map minus 1. If it is, then the encoder or decoder additionally considers the value of the element at position (y−2,x+1).
Turning now to
The first decoder and the second decoder decode the significance map in a diagonal down-left scanning path (like the scanning path shown in
The first decoder selects the context model for the element at position (1,1) based on the values of elements at positions (0,0), (0,1) and (1,0). The second decoder simultaneously determines the context model for the element at position (2,0) by using the same group of elements—(0,0), (0,1) and (1,0). This process continues for each scanning line along the scanning pattern. Table 1 below lists the coordinates of the elements of the significance map being decoded along with the neighboring elements used to determine the context model used, the figure and reference number showing the grouping of neighbors, and the rules (from Rules A through H above) being used. Examples of multiple elements that can be encoded in parallel by a first decoder and a second decoder are indicated in the first column. For the sake of conciseness, not every element of the significance map is shown being decoded. The elements shown in Table 1 are intended to be examples only.
This example shows the context model selection for the zigzag scan pattern utilizing up to 5 coded neighbors. Specifically, given a significance map (
For an element at position (0, 0), (0, 1) or (1, 0) a unique context model is assigned. That is, an element at position (0, 0), (0, 1) or (1, 0) in a current block will share the same context model with other elements in other blocks at the same position (0, 0), (0, 1) or (1, 0) (Steps 1700 and 1702 of
For an element at position (0, x>1), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (0, x−1) and (0, x−2) (Steps 1704 and 1706 of
For an element at position (y>1, 0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y−1, 0) and (y−2, 0) (Steps 1708 and 1710 of
For an element at position (y>0, x>0), the context model is selected based on the value (0 or 1) of the element's neighbors at positions (y−1, x−1) and (y−1, x) and (y, x−1) (Steps 1712 and 1714 of
and (y+1, x−2) if x is larger than 1 and y is smaller than height−1 (Steps 1716 and 1718 of
and (y−2, x+1) if y is larger than 1 and x is smaller than width−1 (Steps 1720 and 1722 of
By using the scheme provided in this example, only the coefficients in two neighboring scanning lines need to be stored.
This example shows the context model selection for the zigzag scan pattern utilizing up to 4 coded neighbors. Specifically, given a significance map (
For an element at position (0, 0), (0, 1) or (1, 0), a unique context model is assigned. That is, an element at position (0, 0), (0, 1) or (1, 0) in a current block will share the same context model with other elements in other blocks at the same position (0, 0), (0, 1) or (1, 0) (Steps 1900 and 1902 of
For an element at position (0, x>1), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (0, x−1) and (0, x−2) (Steps 1904 and 1906 of
For an element at position (y>1, 0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y−1, 0) and (y−2, 0) (Steps 1908 and 1910 of
For an element at position (y>0, x>0), the context model is selected based on the value (0 or 1) of the element's neighbors at positions (y−1, x) and (y, x−1) (Steps 1912 and 1914 of
and (y+1, x−2) if x is larger than 1 and y is smaller than height−1 (Steps 1916 and 1918 of
and (y−2, x+1) if y is larger than 1 and x is smaller than width−1 (Steps 1920 and 1922 of
By using the scheme provided in this example, only the coefficients in one neighboring scanning line need to be stored.
This example shows the context model selection for the zigzag scan pattern utilizing up to 4 coded neighbors. Specifically, given a significance map (
For an element at position (0, 0), (0, 1) or (1, 0), a unique context model is assigned. That is, an element at position (0, 0), (0, 1) or (1, 0) in a current block will share the same context model with other elements in other blocks at the same position (0, 0), (0, 1) or (1, 0) (Steps 2100 and 2102 of
For an element at position (0, x>1), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (0, x−1) and (1, x−2) (Steps 2104 and 2106 of
For an element at position (y>1, 0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y−1, 0) and (y−2, 1) (Steps 2108 and 2110 of
For an element at position (y>0, x>0), the context model is selected based on the value (0 or 1) of the element's neighbors at positions (y−1, x) and (y, x−1) (Steps 2112 and 2114 of
and (y+1, x−2) if x is larger than 1 and y is smaller than height−1 (Steps 2116 and 2118 of
and (y−2, x+1) if y is larger than 1 and x is smaller than width−1 (Steps 2120 and 2122 of
By using the scheme provided in this example, only the coefficients in one neighboring scanning line need to be stored.
This example shows the context model selection for the zigzag scan pattern utilizing up to 3 coded neighbors. Specifically, given a significance map (
For an element at position (0, 0), (0, 1) or (1, 0), a unique context model is assigned. That is, an element at position (0, 0), (0, 1) or (1, 0) in a current block will share the same context model with other elements in other blocks at the same position (0, 0), (0, 1) or (1, 0) (Steps 2300 and 2302 of
For an element at position (0, x>1), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (0, x−1) and (0, x−2) (Steps 2304 and 2306 of
For an element at position (y>1, 0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y−1, 0) and (y−2, 0) (Steps 2308 and 2310 of
For an element at position (y>0, x>0), the context model is selected based on the value (0 or 1) of the element's neighbors at positions (y−1, x), (y, x−1) and (y−1, x−1) (Steps 2312 and 2314 of
By using the scheme provided in this example, only the coefficients in two neighboring scanning lines need to be stored.
This example shows the context model selection for the zigzag scan pattern utilizing up to 2 coded neighbors. Specifically, given a significance map (
For an element at position (0, 0), (0, 1) or (1, 0), a unique context model is assigned. That is, an element at position (0, 0), (0, 1) or (1, 0) in a current block will share the same context model with other elements in other blocks at the same position (0, 0), (0, 1) or (1, 0) (Steps 2500 and 2502 of
For an element at position (0, x>1), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (0, x−1) and (0, x−2) (Steps 2504 and 2506 of
For an element at position (y>1, 0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y−1, 0) and (y−2, 0) (Steps 2508 and 2510 of
For an element at position (y>0, x>0), the context model is selected based on the value (0 or 1) of the element's neighbors at positions (y−1, x) and (y, x−1) (Steps 2512 and 2514 of
By using the scheme provided in this example, only the coefficients in one neighboring scanning line need to be stored.
This example shows the context model selection for the zigzag scan pattern utilizing up to 2 coded neighbors. Specifically, given a significance map (
For an element at position (0, 0), (0, 1) or (1, 0), a unique context model is assigned. That is, an element at position (0, 0), (0, 1) or (1, 0) in a current block will share the same context model with other elements in other blocks at the same position (0, 0), (0, 1) or (1, 0) (Steps 2700 and 2702 of
For an element at position (0, x>1), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (0, x−1) and (1, x−2) (Steps 2704 and 2706 of
For an element at position (y>1, 0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y−1, 0) and (y−2, 1) (Steps 2708 and 2710 of
For an element at position (y>0, x>0), the context model is selected based on the value (0 or 1) of the element's neighbors at positions (y−1, x) and (y, x−1) (Steps 2712 and 2714 of
By using the scheme provided in this example, only the coefficients in one neighboring scanning line need to be stored.
This example shows the context model selection for the vertical scan pattern utilizing up to 5 coded neighbors. Specifically, given a significance map (
For an element at position (y, 0) or (0, 1), a unique or combined context model is assigned. That is, an element at position (y, 0), or (0, 1) in a current block will share the same context model with other elements in other blocks at the same position (y, 0), or (0, 1), n elements could be combined to share the same context while 0<N0, N1, . . . Nk<height and sum(N0, N1, . . . Nk)=height (Steps 2900 and 2902 of
For an element at position (0, x>1), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (0, x−1) and (1, x−1) (Steps 2904 and 2906 of
For an element at position (1, x>0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (0, x−1), (1, x−1) and (2, x−1) (Steps 2908 and 2910 of
For an element at position (y=height−1, x>0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y, x−1) and (y−1, x−1) (Steps 2912 and 2914 of
For an element at position (y=height−2, x>0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y, x−1) and (y+1, x−1), (y−1, x−1) (Steps 2916 and 2918 of
For an element at position (height−2>y>1, x>0), the context model is selected based on the value (0 or 1) of the element's neighbors at positions (y−2, x−1), (y−1, x−1), (y, x−1), (y+1, x−1) and (y+2, x−1) (Steps 2920 and 2922 of
By using the scheme provided in this example, only the coefficients in one neighboring scanning line need to be stored.
This example shows the context model selection for the vertical scan pattern utilizing up to 5 coded neighbors. Specifically, given a significance map (
For an element at position (y, 0), a unique or combined context model is assigned. That is, an element at position (y, 0) in a current block will share the same context model with other elements in other blocks at the same position (y, 0), n elements could be combined to share the same context while 0<N0, N1, . . . Nk<height and sum(N0, N1, . . . Nk)=height (Steps 3100 and 3102 of
For an element at position (0, x>0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (0, x−1) and (1, x−1) (Steps 3104 and 3106 of
For an element at position (1, x>0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (0, x−1), (1, x−1) and (2, x−1) (Steps 3108 and 3110 of
For an element at position (y=height−1, x>0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y, x−1) and (y−1, x−1) (Steps 3112 and 3114 of
For an element at position (y=height−2, x>0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y, x−1), (y+1, x−1) and (y−1, x−1) (Steps 3116 and 3118 of
For an element at position (height−2>y>1, x>0), the context model is selected based on the value (0 or 1) of the element's neighbors at positions (y−2, x−1), (y−1, x−1), (y, x−1), (y+1, x−1) and (y+2, x−1) (Steps 3120 and 3122 of
By using the scheme provided in this example, only the coefficients in one neighboring scanning line need to be stored and using position as the context only applies on the first column, which simplifies the algorithm.
This example shows the context model selection for the vertical scan pattern utilizing up to 4 coded neighbors. Specifically, given a significance map (
For an element at position (y, 0) or (0, 1), a unique or combined context model is assigned. That is, an element at position (y, 0), or (0, 1) in a current block will share the same context model with other elements in other blocks at the same position (y, 0), or (0, 1), n elements could be combined to share the same context while 0<N0, N1, . . . Nk<height and sum(N0, N1, . . . Nk)=height (Steps 3300 and 3302 of
For an element at position (0, x>1), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (0, x−1) and (1, x−1) (Steps 3304 and 3306 of
For an element at position (1, x>0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (0, x−1), (1, x−1) and (2, x−1) (Steps 3308 and 3310 of
For an element at position (y=height−1, x>0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y, x−1) and (y−1, x−1) (Steps 3312 and 3314 of
For an element at position (height−2>y>1, x=1), the context model is selected based on the value (0 or 1) of the element's neighbors at positions (y−1, x−1), (y, x−1) and (y+1, x−1) (Steps 3316 and 3318 of
For an element at position (height−2>y>1, x>1), the context model is selected based on the value (0 or 1) of the element's neighbors at positions (y, x−2), (y−1, x−1), (y, x−1) and (y+1, x−1) (Steps 3320 and 3322 of
By using the scheme provided in this example, only the coefficients in two neighboring scanning lines need to be stored.
This example shows the context model selection for the vertical scan pattern utilizing up to 4 coded neighbors. Specifically, given a significance map (
For an element at position (y, 0), a unique or combined context model is assigned. That is, an element at position (y, 0) in a current block will share the same context model with other elements in other blocks at the same position (y, 0), n elements could be combined to share the same context while 0<N0, N1, . . . Nk<height and sum(N0, N1, . . . Nk)=height (Steps 3500 and 3502 of
For an element at position (0, x>0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (0, x−1) and (1, x−1) (Steps 3504 and 3506 of
For an element at position (1, x>0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (0, x−1), (1, x−1) and (2, x−1) (Steps 3508 and 3510 of
For an element at position (y=height−1, x>0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y, x−1) and (y−1, x−1) (Steps 3512 and 3514 of
For an element at position (height−2>y>1, 1), the context model is selected based on the value (0 or 1) of the element's neighbors at positions (y−1, x−1), (y, x−1) and (y+1, x−1) (Steps 3516 and 3518 of
For an element at position (height−2>y>1, x=1), the context model is selected based on the value (0 or 1) of the element's neighbors at positions (y−1, x−1), (y, x−1) and (y+1, x−1) (Steps 3520 and 3522 of
For an element at position (height−2>y>1, x>1), the context model is selected based on the value (0 or 1) of the element's neighbors at positions (y, x−2), (y−1, x−1), (y, x−1) and (y+1, x−1) (Steps 3524 and 3526 of
By using the scheme provided in this example, only the coefficients in two neighboring scanning lines need to be stored and using position as the context only applies on the first column, which simplifies the algorithm.
This example shows the context model selection for the vertical scan pattern utilizing up to 3 coded neighbors. Specifically, given a significance map (
For an element at position (y, 0) or (0, 1), a unique or combined context model is assigned. That is, an element at position (y, 0), or (0, 1) in a current block will share the same context model with other elements in other blocks at the same position (y, 0), or (0, 1), n elements could be combined to share the same context while 0<N0, N1, . . . Nk<height and sum(N0, N1, . . . Nk)=height (Steps 3700 and 3702 of
For an element at position (0, x>1), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (0, x−1) and (1, x−1) (Steps 3704 and 3706 of
For an element at position (y=height−1, x>0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y, x−1) and (y−1, x−1) (Steps 3708 and 3710 of
For an element at position (height−2>y>1, x>0), the context model is selected based on the value (0 or 1) of the element's neighbors at positions (y−1, x−1), (y, x−1) and (y+1, x−1) (Steps 3712 and 3714 of
By using the scheme provided in this example, only the coefficients in one neighboring scanning line need to be stored.
This example shows the context model selection for the vertical scan pattern utilizing up to 3 coded neighbors. Specifically, given a significance map (
For an element at position (y, 0), a unique or combined context model is assigned. That is, an element at position (y, 0) in a current block will share the same context model with other elements in other blocks at the same position (y, 0), n elements could be combined to share the same context while 0<N0, N1, . . . Nk<height and sum(N0, N1, . . . Nk)=height (Steps 3900 and 3902 of
For an element at position (0, x>0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (0, x−1) and (1, x−1) (Steps 3904 and 3906 of
For an element at position (y=height−1, x>0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y, x−1) and (y−1, x−1) (Steps 3908 and 3910 of
For an element at position (height−2>y>1, x>0), the context model is selected based on the value (0 or 1) of the element's neighbors at positions (y−1, x−1), (y, x−1) and (y+1, x−1) (Steps 3912 and 3914 of
By using the scheme provided in this example, only the coefficients in one neighboring scanning line need to be stored and using position as the context only applies on the first column, which simplifies the algorithm.
This example shows the context model selection for the horizontal scan pattern utilizing up to 5 coded neighbors. Specifically, given a significance map (
For an element at position (0, x) or (1, 0), a unique or combined context model is assigned. That is, an element at position (0, x), or (1, 0) in a current block will share the same context model with other elements in other blocks at the same position (0, x), or (1, 0), m elements could be combined to share the same context while 0<M0, M1, . . . Mp<width and sum(M0, M1, . . . Mp)=width (Steps 4100 and 4102 of
For an element at position (y>1, 0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y−1, 0) and (y−1, 1) (Steps 4104 and 4106 of
For an element at position (y>0, 1), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y−1, 0), (y−1, 1) and (y−1, 2) (Steps 4108 and 4110 of
For an element at position (y>0, x=width−1), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y−1, x) and (y−1, x−1) (Steps 4112 and 4114 of
For an element at position (y>0, x=width−2), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y−1, x−1), (y−1, x) and (y−1, x+1) (Steps 4116 and 4118 of
For an element at position (y>0, width−2>x>1), the context model is selected based on the value (0 or 1) of the element's neighbors at positions (y−1, x−2), (y−1, x−1), (y−1, x), (y−1, x+1) and (y−1, x+2) (Steps 4118 and 4120 of
By using the scheme provided in this example, only the coefficients in one neighboring scanning line need to be stored.
This example shows the context model selection for the horizontal scan pattern utilizing up to 5 coded neighbors. Specifically, given a significance map (
For an element at position (0, x), a unique or combined context model is assigned. That is, an element at position (0, x) in a current block will share the same context model with other elements in other blocks at the same position (0, x), m elements could be combined to share the same context while 0<M0, M1, . . . Mp<width and sum(M0, M1, . . . Mp)=width (Steps 4300 and 4302 of
For an element at position (y>0, 0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y−1, 0) and (y−1, 1) (Steps 4304 and 4306 of
For an element at position (y>0, 1), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y−1, 0), (y−1, 1) and (y−1, 2) (Steps 4308 and 4310 of
For an element at position (y>0, x=width−1), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y−1, x) and (y−1, x−1) (Steps 4312 and 4314 of
For an element at position (y>0, x=width−2), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y−1, x−1), (y−1, x) and (y−1, x+1) (Steps 4316 and 4318 of
For an element at position (y>0, width−2>x>1), the context model is selected based on the value (0 or 1) of the element's neighbors at positions (y−1, x−2), (y−1, x−1), (y−1, x), (y−1, x+1) and (y−1, x+2) (Steps 4320 and 4322 of
By using the scheme provided in this example, only the coefficients in one neighboring scanning line need to be stored and using position as the context only applies on the first row which simplifies the algorithm.
This example shows the context model selection for the horizontal scan pattern utilizing up to 4 coded neighbors. Specifically, given a significance map (
For an element at position (0, x) or (1, 0), a unique or combined context model is assigned. That is, an element at position (0, x), or (1, 0) in a current block will share the same context model with other elements in other blocks at the same position (0, x), or (1, 0), m elements could be combined to share the same context while 0<M0, M1, . . . Mp<width and sum(M0, M1, . . . Mp)=width (Steps 4500 and 4502 of
For an element at position (y>1, 0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y−1, 0) and (y−1, 1) (Steps 4504 and 4506 of
For an element at position (y>0, 1), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y−1, 0), (y−1, 1) and (y−1, 2) (Steps 4508 and 4510 of
For an element at position (y>0, x=width−1), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y−1, x) and (y−1, x−1) (Steps 4512 and 4514 of
For an element at position (y=1, width−2>x>1), the context model is selected based on the value (0 or 1) of the element's neighbors at positions (y−1, x−1), (y−1, x) and (y−1, x+1) (Steps 4516 and 4518 of
For an element at position (y>1, width−2>x>1), the context model is selected based on the value (0 or 1) of the element's neighbors at positions (y−2, x), (y−1, x−1), (y−1, x) and (y−1, x+1) (Steps 4520 and 4522 of
By using the scheme provided in this example, only the coefficients in two neighboring scanning lines need to be stored.
This example shows the context model selection for the horizontal scan pattern utilizing up to 4 coded neighbors. Specifically, given a significance map (
For an element at position (0, x), a unique or combined context model is assigned. That is, an element at position (0, x) in a current block will share the same context model with other elements in other blocks at the same position (0, x), m elements could be combined to share the same context while 0<M0, M1, . . . Mp<width and sum(M0, M1, . . . Mp)=width (Steps 4700 and 4702 of
For an element at position (y>0, 0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y−1, 0) and (y−1, 1) (Steps 4704 and 4706 of
For an element at position (y>0, 1), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y−1, 0), (y−1, 1) and (y−1, 2) (Steps 4708 and 4710 of
For an element at position (y>0, x=width−1), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y−1, x) and (y−1, x−1) (Steps 4712 and 4714 of
For an element at position (y=1, width−2>x>1), the context model is selected based on the value (0 or 1) of the element's neighbors at positions (y−1, x−1), (y−1, x) and (y−1, x+1) (Steps 4716 and 4718 of
For an element at position (y>1, width−2>x>1), the context model is selected based on the value (0 or 1) of the element's neighbors at positions (y−2, x), (y−1, x−1), (y−1, x) and (y−1, x+1) (Steps 4720 and 4722 of
By using the scheme provided in this example, only the coefficients in two neighboring scanning lines need to be stored and using position as the context only applies on the first row, which simplifies the algorithm.
This example shows the context model selection for the horizontal scan pattern utilizing up to 3 coded neighbors. Specifically, given a significance map (
For an element at position (0, x) or (1, 0), a unique or combined context model is assigned. That is, an element at position (0, x), or (1, 0) in a current block will share the same context model with other elements in other blocks at the same position (0, x), or (1, 0), m elements could be combined to share the same context while 0<M0, M1, . . . Mp<width and sum(M0, M1, . . . Mp)=width (Steps 4900 and 4902 of
For an element at position (y>1, 0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y−1, 0) and (y−1, 1) (Steps 4904 and 4906 of
For an element at position (y>0, x=width−1), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y−1, x) and (y−1, x−1) (Steps 4908 and 4910 of
For an element at position (y>0, width−2>x>1), the context model is selected based on the value (0 or 1) of the element's neighbors at positions (y−1, x−1), (y−1, x) and (y−1, x+1) (Steps 4912 and 4914 of
By using the scheme provided in this example, only the coefficients in one neighboring scanning line need to be stored.
This example shows the context model selection for the horizontal scan pattern utilizing up to 3 coded neighbors. Specifically, given a significance map (
For an element at position (0, x), a unique or combined context model is assigned. That is, an element at position (0, x) in a current block will share the same context model with other elements in other blocks at the same position (0, x), m elements could be combined to share the same context while 0<M0, M1, . . . Mp<width and sum(M0, M1, . . . Mp)=width (Steps 5100 and 5102 of
For an element at position (y>0, 0), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y−1, 0) and (y−1, 1) (Steps 5104 and 5106 of
For an element at position (y>0, x=width−1), the context model is selected based on the values (0 or 1) of the element's neighbors at positions (y−1, x) and (y−1, x−1) (Steps 5108 and 5110 of
For an element at position (y>0, width−2>x>1), the context model is selected based on the value (0 or 1) of the element's neighbors at positions (y−1, x−1), (y−1, x) and (y−1, x+1) (Steps 5112 and 5114 of
Although described specifically throughout the entirety of the instant disclosure, representative examples have utility over a wide range of applications, and the above discussion is not intended and should not be construed to be limiting. The terms, descriptions and figures used herein are set forth by way of illustration only and are not meant as limitations. Those skilled in the art recognize that many variations are possible within the spirit and scope of the examples. While the examples have been described with reference to examples, those skilled in the art are able to make various modifications to the described examples without departing from the scope of the examples as described in the following claims, and their equivalents.
The present application claims the benefit of priority to U.S. Provisional Patent Application Ser. No. 61/443,700, filed on Feb. 16, 2011, entitled “Low Complexity and Parallel Processing Friendly Context Selection for Adaptive Scanning Pattern,” by Lou, et al., which is hereby incorporated by reference in its entirety. The present application is related to U.S. patent application Ser. No. 13/253,385 filed on Oct. 5, 2011, entitled “Coding and Decoding Utilizing Adaptive Context Model Selection with Zigzag Scan,” by Lou, et al., U.S. patent application Ser. No. 13/253,933 filed on Oct. 5, 2011, entitled “Coding and Decoding Utilizing Context Model Selection with Adaptive Scan Pattern,” by Lou, et al., and U.S. patent application Ser. No. 13/345,784 filed on Jan. 9, 2012, entitled “Method and System for Processing Video Data,” by Lou, et al.
Number | Name | Date | Kind |
---|---|---|---|
20090175332 | Karczewicz et al. | Jul 2009 | A1 |
Entry |
---|
“Overview of the H.264/AVC Video Coding Standard”, Thomas Wiegand, Gary J. Sullivan, Gisle Bjontegaard, and Ajay Luthra, IEEE Transactions on Circuits and Systems for Video Technology, p. 1-19, Jul. 2003. |
“Parallel Context Processing for the significance map in high coding efficiency”, Joel Sole, JCTVC—D262, ver 1, Jan. 16, 2011. |
“Context-Based Adaptive Binary Arithmetic Coding in the H.264/AVC Video Compression Standard”, Detlev Marpe, IEEE Transactions on Circuits and Systems for Video Technology, vol. 13, No. 7, Jul. 2003. |
PCT Search Report & Written Opinion, Re: Application #PCT/US2012/024608; Jun. 5, 2012. |
Auyeung C, et al, “Parallel processing friendly simplified context selection of significance map”, JCT-VC Meeting ; Jan. 16, 2011. |
Lou J, et al, “On context selection for significant—coeff—flag coding”, MPEG Meeting, Mar. 18, 2011. |
Sze V, et al, “CE11: Simplified context selection for significant—coeff—flag(JCTVC-C227)”, JCT-VC Meeting, Jan. 15, 2011. |
J-R Ohm, et al, “Report of the 4th JCT-VC Meeting”, JCT-VC Meeting, Jan. 24, 2011. |
Number | Date | Country | |
---|---|---|---|
20120207222 A1 | Aug 2012 | US |
Number | Date | Country | |
---|---|---|---|
61433700 | Feb 2011 | US |