This disclosure generally relates to systems and methods for digital video processing including but not limited to signaling syntax and pixel prediction in accordance with such digital video processing.
Communication systems that operate to communicate digital media (e.g., images, video, data, graphical data, etc.) have been under continual development for many years. With respect to such communication systems, a number of digital images are provided to a device for output or display at a frame rate (e.g., frames per second) to effectuate a video signal suitable for output and/or viewing. Within certain communication systems, digital media can be transmitted from a first location to a second location at which such media can be output or displayed. Within many devices that use digital media such as digital video, respective images thereof, being digital in nature, are represented using pixels.
Various objects, aspects, features, and advantages of the disclosure will become more apparent and better understood by referring to the detailed description taken in conjunction with the accompanying drawings, in which like reference characters identify corresponding elements throughout. In the drawings, like reference numbers generally indicate identical, functionally similar, and/or structurally similar elements.
Digital communications systems, including those that operate to communicate digital video, generally attempt to transmit digital data from one location, or subsystem, to another either error free or with an acceptably low error rate in some embodiments. Certain communication systems that use video data operate according to a balance between throughput limitations (e.g., number of bits that may be transmitted) and video and/or image quality of the signal eventually to be output or displayed.
Referring generally to the Figures, various systems and methods are provided that may be used to provide transmit data with an adequate or acceptable video and/or image quality, using a relatively low amount of overhead associated with the communications, using relatively low complexity of the communication devices at respective ends of communication links, etc. according to some embodiments. In some embodiments, the data may be transmitted over a variety of communications channels in a wide variety of communication systems: magnetic media, wired, wireless, fiber, copper, and/or other types of media.
Referring now to
In some embodiments, the communication system 100 may be configured to enable a uni-directional communication. Either of the communication devices 110 and 120 may only include a transmitter or a receiver. For example, if the communication device 110 is at a receiving end of the communication system 100, the communication device 110 may include only receiver 116 with the decoder 118 in some embodiments. If the communication device 120 is at a transmitting end of the communication system 100, the communication device 120 may include only transmitter 126 with the encoder 128 in some embodiments. In some embodiments, the communication system 100 may be configured to enable a bi-directional communication and the communication devices 110 and 120 may include both of the transmitters 112, 126 and receivers 116, 122, respectively.
The communication channel 199 may be any type of medium that enables communication between the devices 110 and 120 according to some embodiments. For example, the communication channel 199 may be one or more of a satellite communication channel 130 using satellite dishes 132 and 134, a wireless communication channel 140 using towers 142 and 144 and/or local antennae 152 and 154, a wired communication channel 150, and/or a fiber-optic communication channel 160 using electrical to optical (E/O) interface 162 and optical to electrical (O/E) interface 164. According to some embodiments, the communication channel 199 may be formed by implementing and interfacing together more than one type of media.
The communication devices 110 and/or 120 may be stationary or mobile devices according to some embodiments. For example, either one or both of the communication devices 110 and 120 can be implemented in a fixed location or can be a mobile communication device with capability to associate with and/or communicate with more than one network access point. According to some embodiments, the communication devices 110 and 120 may be any type of mobile devices, such as cellular phones, lap top computers, set top boxes, tablet computers, television sets, servers, monitors, desk top computers, work stations, etc.
Referring to
The video encoding system 200 receives an input video signal 202, which corresponds to raw frame (or picture) image data in some embodiments. The input video signal 202 is partitioned uniformly into coding units or macroblocks by the partitioner 201 which is a software routine operating on a processor or other device for partitioning as explained below. In some embodiments, the size of such coding units may vary and include a number of pixels typically arranged in a square shape. Such coding units may have any desired size such as N×N pixels, where N is an integer. For example, the input video signal 202 may be a frame composed of coding units, and each coding unit may have 64×64 pixels. In some embodiments, the input video signal 202 may include one or more non-square shaped coding units.
The input video signal 202 may undergo compression along a compression pathway according to some embodiments. In some embodiments, the input video signal 202 may be provided via the compression pathway to undergo transform and/or quantization operations via a transformer and quantizer 206 without undergoing inter-prediction or intra-prediction. In some embodiments, the transformer and quantizer 206 may be one of a transformer or a quantizer or both a transformer and a quantizer. The transformer and quantizer 206 may be configured to perform discrete cosine transform (DCT) on the input video signal 202. The transformer and quantizer 206 may include any type and/or form of suitable hardware, software, or combination of hardware and software to operate on the input video signal 202 as explained below in some embodiments.
According to some embodiments, the transformer and quantizer 206 may be configured to compute coefficient values for each of a predetermined number of basis patterns and quantize the coefficient values. The transformer and quantizer 206 may be configured to eliminate coefficient values that are below a predetermined value (e.g., a threshold) by converting less relevant coefficient values to a value of zero in some embodiments. The transformer and quantizer 206 may be also configured to convert significant coefficient values (i.e., above a predetermined value) into values that can be coded more efficiently in some embodiments. For example, the transformer and quantizer 206 may be configured to divide each respective coefficient by an integer value and discarding any remainder.
In some embodiments, the input video signal 202 may undergo intra/inter mode selection by the intra/inter mode selector 228 so that the input video signal 202 may selectively undergo intra and/or inter-prediction processing. The intra/inter mode selector 228 may include any type and/or form of suitable hardware, software, or combination of hardware and software to select between an intra-prediction mode and an inter-prediction mode to process the input video signal 202. According to some embodiments, the intra/inter mode selector 228 may be configured to select inter-prediction mode processing when sufficient pixels are not available within a neighborhood of a coding unit. In some embodiments, the intra/inter mode selector 228 may be configured to select intra-prediction mode processing when sufficient pixels are available within a neighborhood of a coding unit.
The video encoding system 200 may be configured to determine a prediction of the current coding unit based on previously coded data in some embodiments. The previously coded data may be from the current frame (or picture) itself (e.g., such as in accordance with intra-prediction) or from one or more other frames (or pictures) that have already been coded (e.g., such as in accordance with inter-prediction). In some embodiments, the input video signal 202 may undergo a motion estimation operation by the motion estimation module 224 and a motion compensation operation by the motion compensation module 226 for the inter-prediction operation in some embodiments.
According to some embodiments, the motion estimation module 224 and motion compensation module 226 may be configured to perform inter-predictive coding of the received input video signal 202 relative to one or more blocks in one or more reference frames to provide temporal compression. According to some embodiments, the motion estimation module 224 may be configured to compare a set of coding units (e.g., 16×16) from a current frame to a respective buffered counterparts in a picture buffer 220 in one or more previously coded frames (or pictures) within the stream of frames. According to some embodiments, the motion estimation module 224 may further determine the closest matching area and motion vectors based on the comparisons. According to some embodiments, the closest matching area may be used as a prediction reference. According to some embodiments, the motion compensation module 226 may be configured to generate a prediction of the current coding unit based on the motion vectors determined by motion estimation module 224. In some embodiments, the motion estimation module 224 and motion compensation module 226 may be integrated. The video encoding system 200 may be configured to subtract the prediction data from the current coding unit to form a residual using the summer 204 in some embodiments.
In some embodiments, an intra-prediction operation may be selected by the intra/inter mode selector 228. In some embodiments, an intra-prediction module may be configured to employ block sizes of one or more particular sizes (e.g., 16×16, 8×8, or 4×4) to predict a current block from spatially adjacent previously coded pixels within the same frame (or picture). In some embodiments, the video input signal 202 may undergo both inter and intra predictions. For example, the encoding system 200 may employ an intra-prediction operation via an intra-prediction module 222 to the coding units of the input video signal 202 that have encoded units as neighbors. The encoding system 200 may employ an inter-prediction operation to the coding units that do not have all the neighbors as encoded units in some embodiments.
In some embodiments, a set of residuals determined by inter and/or intra-prediction operations may undergo transform operations via the transformer and quantizer 206 (e.g., in accordance with discrete cosine transform (DCT)). According to some embodiments, the transform operations may output a group of coefficients such that each respective coefficient corresponds to a respective weighting value of one or more basis functions associated with a transform. According to some embodiments, after undergoing transformation, a block of transform coefficients may be quantized. For example, each respective coefficient may be divided by an integer value, referred to as quantization step size and any associated remainder may be discarded, or they may be multiplied by an integer value. The quantization operation is generally inherently lossy, and it can reduce the precision of the transform coefficients according to a quantization parameter (QP). In some embodiments, many of the coefficients associated with a given transform block may be zero, and only some non-zero coefficients may remain. In some embodiments, a relatively high QP setting may be operative to result in a greater proportion of zero-valued coefficients and smaller magnitudes of non-zero coefficients, resulting in relatively high compression (e.g., relatively lower coded bit rate) at the expense of relatively poorly decoded image quality; a relatively low QP setting is operative to allow more non-zero coefficients to remain after quantization and larger magnitudes of non-zero coefficients, resulting in relatively lower compression (e.g., relatively higher coded bit rate) with relatively better decoded image quality.
In some embodiments, the encoding system 200 may include a feedback path which enables the output of the transformer and quantizer 206 to undergo inverse quantization and inverse transform operations via an inverse transformer and quantizer 212. The inverse transformer and quantizer 212 may be configured to apply an inverse transform (e.g., an inverse DCT, an inverse integer transform, or a conceptually similar inverse transform process) to the transform coefficients in order to produce residual blocks in the pixel domain in some embodiments. The inverse transformer and quantizer 212 may be one of an inverse transformer or an inverse quantizer or both an inverse transformer or an inverse quantizer in some embodiments.
According to some embodiments, the output residuals from the inverse transformer and quantizer 212 may be combined with predictions generated by the inter prediction and/or intra prediction operation via the summer 214. According to some embodiments, the combined residuals and prediction may be provided to a de-blocking filter 216. The de-blocking filter 216 may be configured to filter block boundaries to remove blockiness artifacts from reconstructed video signal in some embodiments. The output from the de-blocking filter 216 may be provided to one or more in-loop filters 218 (e.g., implemented in accordance with adaptive loop filter (ALF), sample adaptive offset (SAO) filter, and/or any other filter type) implemented to process the output from the inverse transform block in some embodiments. For example, in some embodiments, an ALF may be applied to the decoded picture before it is stored in the picture buffer 220 (again, sometimes alternatively referred to as a DPB, digital picture buffer). In some embodiments, the ALF may be implemented to reduce coding noise of the decoded picture, and the filtering thereof may be selectively applied on a slice-by-slice basis, respectively, for luminance and chrominance, whether or not the ALF is applied either at slice level or at block level. In some embodiments, two-dimensional (2-D) finite impulse response (FIR) filtering may be used in application of the ALF. According to some embodiments, the coefficients of the filters may be designed slice by slice at the encoding system 200, and such information may be then signaled to the decoder (e.g., signaled from a transmitter communication device including a video encoder to a receiver communication device including a video decoder. According to some embodiments, the output of the in loop filters 218 may be stored in the picture buffer 220. The data stored in the picture buffer 220 may be used for further inter and/or intra-predictions in some embodiments.
According to some embodiments, the video encoding system 200 may be configured to produce a number of values that are encoded to form the compressed bit stream 210. Examples of such values include the quantized transform coefficients, information to be employed by a decoder to re-create the appropriate intra or inter-prediction, information regarding the structure of the compressed data and compression tools employed during encoding, information regarding a complete video sequence, etc. In some embodiments, such values and/or parameters (also known as syntax elements) undergo encoding within the entropy encoder 208 operating in accordance with context-adaptive binary arithmetic coding (CABAC), context-adaptive variable-length coding (CAVLC), or some other entropy coding schemes, to produce an output bit stream that may be stored, transmitted, etc.
Various modules and components described in
As shown in
In terms of luma pixels, each CU may be 64×64, 32×32, 16×16, or 8×8 pixels according to some embodiments. Each CU may consist of one or more non-overlapping prediction units (PU) in some embodiments. Prediction units may be used to define the motion vectors used for motion compensation or the intra-modes used for spatial prediction in some embodiments.
According to some embodiments, instead of traversing the syntax elements in the depth-first approach, all syntax elements in a CTB 300 may be organized into syntax planes. Each plane may group at least one type of syntax element across the whole CTB 300 according to some embodiments. When an input video signal (i.e., current frame or picture) undergoes entropy coding, all CTB syntax elements may be encoded plane by plane in some embodiments.
In some embodiments, various syntax planes may be created by grouping the corresponding types of syntax elements across the CTB 300. According to some embodiments, the various syntax planes may include split flag plane, prediction mode plane, partitioning mode plane, reference index plane, motion vector plane, spatial prediction direction plane, quantization parameter plane, coded block flag plane, and coefficient plane. Each syntax plane includes at least one type of syntax elements. For example, as shown in
In some embodiments, the CTB syntax elements may be encoded plane by plane and the information therefrom may be used to derive better context model for the following syntax planes. For example, the CTB split flag plane may provide some indication on the degree of difficulty to compress the current CTB. If the number of quad-tree split levels is large (i.e., many depths) and/or many CUs are determined to be split into smaller CUs, a different context model from CTBs with less quad-tree split levels and/or more coding units with larger block sizes may be used. There may be several ways to estimate the difficulty to compress, alternatively referred to as activity measure according to some embodiments. After each syntax plane is coded, the activity measure may be updated by feeding new available information. The updated activity measure may be used for coding the following syntax planes. In this way, a cross-syntax dependency may be effectually exploited in some embodiments.
In some embodiments, the CTB syntax elements may be transmitted plane by plane. For example, the output syntax elements from an encoding system may be transmitted to a decoding system by transmitting a partitioning mode plane including all the partitioning information of all the coding units in the CTB, then transmitting a prediction mode plane including all the information regarding prediction mode selection of all the coding units in the CTB.
In some embodiments, this syntax plane approach may also be extended to sub-pictures such as tiles, slices, or a whole picture. In this case, each syntax plane may include the corresponding syntax element(s) of all CTBs in a sub-picture. According to some embodiments, the encoding system may be configured to group the same syntax across the whole syntax plane, instead of encoding each syntax element one-by-one. The grouping of syntax into syntax plane improves coding efficiency.
In some embodiments, instead of traversing the whole quad-tree, only the root unit's status may be signaled. If the root unit's number is 1, it means the whole CTB under the root unit uses inter prediction. If the root unit's number is 0, the status of each leaf unit under the root unit may be signaled individually and all intermediate units between the root to the leaves maybe bypassed. In a case where all CUs in a CTB use inter prediction, the root node's number is 1 and that is the only information needed to be signaled for the prediction modes of the whole CTB.
In some embodiments, the same idea may be applied to other syntax planes such as coded block flag (CBF) plane. In the traditional approach without using syntax plane, residual quad-trees start from leaf CU units and they do not cross CU boundaries. Using the syntax plane approach, residual quad-trees can start from any unit of the CTB, including the root unit.
Referring to
According to some embodiments, a TU 400 may be determined to be split into TUs 402, 404, 406, and 408. Each TU may further undergo determination of whether to be split or not. The TUs 402 and 408 are determined to be not split. The TU 404 is determined to be split into 410, 412, 414, and 416. The TU 406 is determined to be split into 418, 420, 422, and 424. The TU 412 is further determined to be split into 426, 428, 430, and 432. The TU 418 is further determined to be split into 434, 436, 438, and 440. According to some embodiments, the TUs 426, 428, 430, 432, 434, 436, 438, and 440 may reach a desired TU size, so that the partitioning is stopped. According to some embodiments, the partitioning may be repeated recursively until a smaller desired size is reached.
Referring to
According to some embodiments, in regards to intra-prediction, the TU may define an intra-prediction block size, not the prediction unit (PU). According to some embodiments, the PU may specify an intra-prediction mode for all blocks within the PU. According to some embodiments, the actual intra-prediction block size within each PU may be defined by the transform residual quad-tree. So, for example a 16×16 PU would not necessarily use a single 16×16 intra predicted block. This PU might contain several 8×8 and 4×4 transform blocks. In this case, the intra prediction process is performed sequentially for each of these smaller transform blocks within the PU, not the entire 16×16 PU.
According to some embodiments, for the inter coded CUs, each prediction unit (PU) and transform unit (TU) can be defined independently. According to some embodiments, the TU size may be larger than the PU size. For example, two 16×8 motion vectors may be used with a single 16×16 transform block.
According to some embodiments, Luma coded block flags (CBF) may be coded at each TU in the TU partitioning quad-tree. These CBFs may indicate whether the luma transform unit at that position in the tree has any non-zero coefficients or not in some embodiments. When the CBF is set as 0, the residual coefficient syntax is skipped for the corresponding TU.
pred[M−1,y]=w·pred0[M−1,y]+(1−w)·p[M,y]
pred[x,N−1]=w·pred0[x,N−1]+(1−w)·p[x,N]
where w is a weighting parameter in [0,1]. The variable w can use a default value such as 0.5 or it can be calculated based on rate-distortion optimization and signaled in a picture header, in a slice header or at a block level. The above weighted averaging may not be limited to the right and bottom boundary pixels. It can be applied to the interior pixels also, where the weighting parameters are pixel location dependent. In some embodiments, intra prediction of a coding unit is represented by:
pred[x,y]=w0,x,y·pred0[x,y]+w1,x,y·p[M,y]+w2,x,y·p[x,N]
where w0,x,y, w1,x,y, w2,x,y are location dependent weighting parameters, and can be represented by:
It is advantageous to combine the syntax plane structure and the sequential inter-intra processing order for intra predicted blocks and inter predicted block so that the neighborhood of an intra block is known in advance and intra-prediction direction may cover 360 degree in some embodiments. For example, after parsing the syntax plane corresponding to prediction modes in a CTB, the decoder may determine the locations of intra blocks and inter blocks before paring any syntax related to spatial prediction direction.
The number of possible intra-prediction directions may adapt to the neighborhood situation in some embodiments. If an intra block's all neighboring pixels are available, spatial predictions may be omnidirectional as shown in
To further enhance intra-prediction performance, an intra-prediction algorithm called Decoder Side Intra-Prediction (DSIP) is illustrated in
The shaded pixels shown in
In some embodiments, to keep the line buffer size small, only one row may be accessible. If there is only one row above the current block, vertical prediction may be used initially as the prediction direction from row −1 to row 0 in some embodiment.
This row-by-row or column-by-column line prediction approach can be applied to traditional intra angular prediction as well. In the traditional intra prediction, each intra-block is predicted from previously decoded pixels in neighboring blocks and predicted pixels for the current block are generated by using those decoded pixels in neighboring blocks instead of pixels from the current block.
After the line prediction, 1-D transform may be applied to the residual of each line according to some embodiments. Coefficients for the 1-D transform of each line may be first quantized and then reconstructed for predicting the next line according to some embodiments. The quantized coefficients may be further coded by an entropy coder. According to some embodiments, the coefficients for the coding units at each line may be treated as a coefficient group (CG). For example, for a 16×16 transform block, there are 16 CGs. Because of the dependency between two neighboring lines, the quality of the previous line may impact the prediction of the current coded line according to some embodiments. It will be beneficial to jointly optimize the quantization of CGs of a transform block to achieve a desirable balance of rate and distortion. The optimization problem is to find the minimal Lagrangian cost function J(λ) defined as
where D(Ci,Q) is the distortion of the CG Ci when quantized to quality level Q, λ is a Lagrange multiplier, and R(Ci,Q) is a bit cost to encode Ci,Q. The distortion metric may be a mean-squared-error (MSE) distortion, an activity-weighted MSE, or another distortion metric according to some embodiments. The quality level may be a quantization parameter (QP) which is widely used in H.264 and H.265 standards according to some embodiments. According to some embodiments, a truncation may be applied to the coefficients. According to some other embodiments, the quality level may correspond to coefficient truncation positions. For example, a 1×16 1-D transform may generate 16 coefficients from low frequency to high frequency. For example, a coefficient may be selected as a truncation position, so that a truncation may be applied to set the truncation coefficient and all the coefficients that are higher than the truncation coefficient to zero. According to some embodiments, truncating at different coefficients corresponds to different quality levels and therefore different tradeoff between rate and distortion.
Referring to
According to some embodiments, a path through the trellis may represent a sequence of quantization decision on all the CGs in a block. According to some embodiments, various dynamic programming algorithms may be used to find the surviving path through the trellis, such as the Viterbi's algorithm. In each stage of the trellis, cost (e.g., according to the Lagrangian cost function) may be computed for each of the candidate quality level based on each surviving path up to the current CG. For the CGs in the current stage and the past stages along each surviving path, coding cost can be calculated.
At the second stage of the trellis, for example, which corresponds with C2, coding cost for each combination of candidate quality levels associated with CG C1 and C2 may be calculated in some embodiments. According to some embodiments, three coding costs may be calculated for each quality level of stage C2, such as Q1C2, Q2C2, and Q3C2. For example, for Q1C2 (i.e., candidate quality level 1 associated with CG C2), a first coding cost is calculated using quality level 1 for C1, a second coding cost is calculated using quality level 2 for C1, a third coding cost is calculated using quality level 3 for C1. The path having the lowest coding cost is selected as the surviving path for Q1C2. After selecting the surviving paths for each quality level of CG C2 (e.g., Q1C2, Q2C2, and Q3C2), the same process is applied to the next CG, e.g., C3. The selection of surviving paths of quality levels may be conducted for each CG according to some embodiments. A surviving path through the whole trellis may be provided by connecting the selected surviving paths for each CG according to some embodiments. The surviving path represents a sequence of quantization or quality level selection decision on all the CGs in a block.
To efficiently represent all CGs in a block, for each CG, the entropy coder may use a one-bit flag CG_all_zero to indicate whether the CG's coefficients are all zero or not according to some embodiments. For example, the entropy coder may scan CGs backwardly, starting from the last CG corresponding to the last row/column of the block. After encountering a CG_all_zero=0 (false), the entropy coder may code another one-bit flag Last_nonzero_CG to indicate whether this CG is the last CG having nonzero coefficient. If Last_nonzero_CG is equal to 1(true), the one-bit flag of the remaining CGs may be inferred to be 1(true) and the CG_all_zero flags may be not sent to the remaining CGs according to some embodiments. If Last_nonzero_CG is equal to 0 (false), there is at least one CG having a one-bit flag CG_all_zero that is equal to 0 (false) according to some embodiments.
According to some embodiment, instead of sending Last_nonzero_CG flags, the entropy coder may signal the location (row/column index) of the last CG that has nonzero coefficients in the previously mentioned scan order before signaling any CG_all_zero. According to some embodiments, the entropy code may scan CGs forwardly starting from the first CG corresponding to the first row/column.
According to embodiments, during the line prediction, for some pixels, their reference pixels in the previous line used for prediction may be located outside the previous coded row. There are two ways to solve this problem. One is padding the outside reference pixels with the closest reference pixels within the previous row. The other one is predicting those pixels by using the decoded pixels in the neighboring blocks (i.e., intra prediction).
The inter CU 740 is partitioned into multiple TUs. Each TU has a CBF indicating whether the TU is selected for complementary prediction. When the CBF equals to 1, the corresponding TU is selected for complementary prediction. When the CBF equals to 0, the corresponding TU is not selected for complementary prediction. According to some embodiments, the complementary prediction may be either inter prediction or intra prediction. If the complementary prediction works jointly with the original prediction, the weight sum of the original prediction and the complementary prediction will be the final prediction for the TU. If the complementary prediction is inter prediction, a different motion vector from the original motion vector may be used. The original motion vector may be used to predict the complementary motion vector according to some embodiments.
In the context of complementary prediction, the semantics of CBF is expanded. When the CBF is 0, it indicates the corresponding TU is not selected for complementary prediction and all coefficients within the corresponding TU are zero. When CBF is 1, it indicates the corresponding TU is selected for complementary prediction, but does not indicate whether the complementary is applied or not. A first separate flag may be introduced to indicate whether complementary prediction is used or not according to some embodiments. If the first separate flag is 0, it indicates complementary prediction is not applied to the TU and there is at least one nonzero coefficient in the TU. If the first separate flag is 1, it indicates complementary prediction is used. When complementary prediction is used, a second separate flag is introduced to indicate whether there is any non-zero coefficient remaining after the complementary prediction.
In some embodiments, when complementary prediction is applied to a TU, all coefficients of the TU are set to be zero and the residual coefficient syntax is skipped for the TU. In some embodiments, TUs without using complementary prediction may be reconstructed first, followed by TUs using complementary prediction. Changing the processing order can provide better prediction because non-causal neighbors may be available for prediction. For example, as shown in
In some embodiments, the spatial prediction mode or motion vector associated with the complementary prediction may be generated by using decoder-side motion vector derivation or decoder-side intra prediction derivation. In some embodiments, complementary prediction may be applied to TUs at TU depths larger than 0. In this case, the semantics of CBF are different at different TU depths. At TU depth equal to 0, the semantics of CBF are the same as the traditional CBF. At TU depths larger than 0, the CBF is set to 1 indicating complementary prediction may be applied.
One benefit to arranging syntax elements into syntax planes is that the previous coded syntax planes are used to derive a better context model for the following syntax planes in some embodiments. For example, the CTB split flag plane provides some information on the degree of difficulty to compress the current CTB. If the number of quad-tree split levels is large and/or if many leaf nodes have small block sizes, a different context model from CTBs with little or no quad-tree split and/or with coding units using larger block sizes is used in some embodiments. There are several ways to estimate the difficulty to compress, alternatively referred to as activity measure. In some embodiments, the activity measure is represented as follows:
activity_measure=max_depth,
where max_depth is the maximum quad-tree split level of the CTB. The context model of syntax elements in the following syntax planes such as prediction mode can be selected based on the value of activity_measure. For example,
F(z)=activity_measure
For each value of activity_measure, there could be a separate probability model.
After each syntax plane is coded, the probability model is updated by feeding new coded bins in some embodiments. If multiple syntax planes are encoded, the context model for the bins of the following syntax plane(s) are selected based on the previously coded syntax planes jointly in some embodiments. In some embodiments, cross-syntax dependency is used.
In some embodiments, the entropy decoder 902 (e.g., which may be implemented in accordance with CABAC, CAVLC, etc.) may be configured to process the input bitstream in accordance with performing the complementary prediction of encoding as performed within a video encoder system. According to some embodiments, the input encoded bitstream may include a plurality of CUs. According to some embodiments, each CU may include a plurality of TUs. The TUs may be encoded by the encoder using different coding modes. According to some embodiments, each encoded TU may be associated with a coding mode information. Each coding mode may correspond to a prediction method. For example, a complementary coding mode may correspond to a complementary prediction. According to some embodiments, the input bitstream may include coding information indicating a coding mode for each TU. For example, for TU that undergoes complementary prediction, a complementary coding mode information may be included in the input bitstream. According to some embodiments, the entropy decoder 902 may be configured to receive the coding mode information associated with each TU. For example, the entropy decoder 902 may receive a CU with a first coding mode information associated with a first set of TUs of the CU and a second coding mode information associated with a second set of TUs of the CU. According to some embodiments, the entropy decoder 902 may be configured to use the first coding mode information and the second coding mode information to decode the CU. According to some embodiments, the entropy decoder 902 may be configured to use the first coding mode information to decode the first set of TUs, and user the second coding mode information to decode the second set of TUs. According to some embodiments, the entropy decoder 902 may be configured to decode the first set of TUs before decoding the second set of TUs. According to some embodiments, the entropy decoder 902 may be configured to decode TUs that are not associated with a complementary coding mode before decoding TUs that are associated with a complementary coding mode.
The entropy decoder 902 may be configured to process the input bitstream and extract appropriate coefficients from the input bitstream, such as the DCT coefficients and provides such coefficients to the inverse quantizer and transformer 904. In the event that a DCT transform is employed, the inverse quantizer and transformer 904 may be implemented to perform an inverse DCT (IDCT) operation. Subsequently, the inverse transform output is added into the output from the motion compensated module 910 (e.g., a motion compensated inter-prediction module) or the intra-prediction module 912 to form the reconstructed data. The de-blocking filter 906 and other loop filters 908 are applied to generate pictures corresponding to an output video signal. These pictures may be provided into a picture buffer 914, or a digital picture buffer (DPB) for use in performing other operations including motion compensated prediction 910. The output video signal can be provided to a display associated with communication device 120 (
Various modules and components described in
The present invention has been described above with the aid of method steps illustrating the performance of specified functions and relationships thereof. The boundaries and sequence of these functional building blocks and method steps have been arbitrarily defined herein for convenience of description. Alternate boundaries and sequences can be defined so long as the specified functions and relationships are appropriately performed. Any such alternate boundaries or sequences are thus within the scope and spirit of the claimed invention. Further, the boundaries of these functional building blocks have been arbitrarily defined for convenience of description. Alternate boundaries could be defined as long as the certain significant functions are appropriately performed. Similarly, flow diagram blocks may also have been arbitrarily defined herein to illustrate certain significant functionality. To the extent used, the flow diagram block boundaries and sequence could have been defined otherwise and still perform the certain significant functionality. Such alternate definitions of both functional building blocks and flow diagram blocks and sequences are thus within the scope and spirit of the claimed invention. One of average skill in the art will also recognize that the functional building blocks, and other illustrative blocks, modules and components herein, can be implemented as illustrated or by discrete components, application specific integrated circuits, processors executing appropriate software and the like or any combination thereof.
The present invention may have also been described, at least in part, in terms of one or more embodiments. An embodiment of the present invention is used herein to illustrate the present invention, an aspect thereof, a feature thereof, a concept thereof, and/or an example thereof. A physical embodiment of an apparatus, an article of manufacture, a machine, and/or a process that embodies the present invention may include one or more of the aspects, features, concepts, examples, etc. described with reference to one or more of the embodiments discussed herein. Further, from figure to figure, the embodiments may incorporate the same or similarly named functions, steps, modules, etc. that may use the same or different reference numbers and, as such, the functions, steps, modules, etc. may be the same or similar functions, steps, modules, etc. or different ones.
Unless specifically stated to the contrary, signals to, from, and/or between elements in a figure of any of the figures presented herein may be analog or digital, continuous time or discrete time, and single-ended or differential. For instance, if a signal path is shown as a single-ended path, it also represents a differential signal path. Similarly, if a signal path is shown as a differential path, it also represents a single-ended signal path. While one or more particular architectures are described herein, other architectures can likewise be implemented that use one or more data buses not expressly shown, direct connectivity between elements, and/or indirect coupling between other elements as recognized by one of average skill in the art.
While particular combinations of various functions and features of the present invention have been expressly described herein, other combinations of these features and functions are likewise possible. The present invention is not limited by the particular examples disclosed herein and expressly incorporates these other combinations.
This application claims the benefit of and priority to U.S. Provisional Patent Application No. 62/251,423, filed on Nov. 5, 2015, the contents of which is incorporated herein by reference in its entirety for all purposes.
Number | Date | Country | |
---|---|---|---|
62251423 | Nov 2015 | US |