Embodiments described relate to video encoding, and examples include performing joint optimization of quantized transform coefficients including use of sign data hiding techniques.
Video or other media signals may be used by a variety of devices, including televisions, broadcast systems, mobile devices, and both laptop and desktop computers. Typically, devices may display video in response to receipt of video or other media signals, often after decoding the signal from an encoded form. Video signals provided between devices are often encoded using one or more of a variety of encoding and/or compression techniques, and video signals are typically encoded in a manner to be decoded in accordance with a particular standard, such as HEVC, MPEG-2, MPEG-4, and H.264/MPEG-4 Part 10. By encoding video or other media signals, and later decoding the received signals, the amount of data transmitted between devices may be reduced.
Video encoding typically proceeds by encoding units of video data. Prediction coding may be used to generate predictive blocks and residual blocks, where the residual blocks represent a difference between a predictive block and the block being coded. Prediction coding may include spatial and/or temporal predictions to remove redundant data in video signals, thereby reducing the amount of data. Intracoding for example, is directed to spatial prediction and reducing the amount of spatial redundancy between blocks in a frame or slice. Intercoding, on the other hand, is directed toward temporal prediction and reducing the amount of temporal redundancy between blocks in successive frames or slices. Intercoding may make use of motion prediction to track movement between corresponding blocks of successive frames or slices.
Typically, in encoder implementations, including intracoding and interceding based implementations, residuals (e.g., difference between actual and predicted blocks) may be transformed, quantized, and encoded using one of a variety of encoding techniques (e.g., entropy encoding) to generate a set of coefficients. It is these coefficients that may be transmitted between the encoding device and the decoding device. Quantization may be determinative of the amount of loss that may occur during the encoding of a video stream. That is, the amount of data that is removed from a bitstream may be dependent on a quantization parameter generated by and/or provided to an encoder.
Video encoding techniques typically perform some amount of rate-distortion optimization. Generally a trade-off exists between an achievable data rate and the amount of distortion present in a decoded signal. Many encoders utilize quantization for rate-distortion optimization of a video signal in accordance with one or more coding standards. In doing so, however, costs, including rate costs and distortion costs, must be calculated so that coefficients of each residual may be optimized for the selected coding standard. This cost measurement requires not only transformation and quantization of coefficients, but encoding of the coefficients as well.
HEVC, short for High Efficiency Video Coding (HEVC) is a video compression standard that encodes macroblocks within a frame using one or more coding modes. In HEVC and many video encoding standards, a macroblock denotes a square region of pixels. HEVC replaces 16×16 pixel macroblocks, which were used with previous standards, with Coding Tree Units which can use larger block structures to improve better sub-partition the picture into variable sized structures.
HEVC has an optional feature referred to as sign data hiding. When enabled and assuming that there are enough coefficients in the group, one of the sign data bits may not be coded, but rather inferred. The missing sign may be inferred to be equal to the least significant bit of the sum of all the coefficient's absolute values. If the inferred sign proved to be in incorrect, the encoder will adjust one of the coefficients up or down to compensate. Sign data represent a substantial proportion of a compressed bitstream and can be difficult to directly compress this information.
Examples of methods and apparatuses for performing joint optimization of quantized transform coefficients and using sign data hiding techniques are described herein. Certain details are set forth below to provide a sufficient understanding of embodiments of the disclosure. However, it will be clear to one having skill in the art that embodiments of the disclosure may be practiced without these particular details, or with additional or different details. Moreover, the particular embodiments described herein are provided by way of example and should not be used to limit the scope of the disclosure to these particular embodiments. In other instances, well-known video components, encoder or decoder components, circuits, control signals, timing protocols, and software operations have not been shown in detail in order to avoid unnecessarily obscuring the disclosure.
The encoder 110 may include one or more logic circuits, control logic, logic gates, processors, memory, and/or any combination or sub-combination of the same, and may encode and/or compress a video signal using one or more encoding techniques. The encoder 110 may encode in accordance with one or more encoding techniques, such as HEVC. In at least one embodiment, the encoder 110 may include an entropy encoder, such as a context-adaptive binary arithmetic coding (CABAC) encoder. Encoding in accordance with HEVC may, for instance, allow the encoder 110 to provide a CABAC bitstream in real-time without the use of a transcoder. The encoder 110 may further encode data, for instance, at a coding tree unit level. Each coding tree unit may be encoded in intra-coded mode, inter-coded mode, bidirectionally, or in any combination or subcombination of the same.
In an example operation of the apparatus 100, the encoder 110 may receive and encode a video signal to provide an encoded bitstream. The encoded bitstream may be provided to external circuitry. By way of example, the encoder 110 may provide the encoded bitstream to a decoder, which may subsequently provide (e.g., generate) a reconstructed video signal based on the encoded bitstream. The video signal provided to the encoder 110 may differ from the video signal provided by a decoder due to lossy encoding operations performed by the encoder 110, such as quantization.
The encoder 200 may include a forward encoding path including a mode decision block 230, a prediction block 220, a delay buffer block 202, a transform block 206, a quantization block 250, an entropy encoder block 208, an inverse quantization block 210, an inverse transform block 212, a filter block 216, and a decoded picture buffer block 218. The mode decision block 230 may determine an appropriate coding mode based, at least in part, on the incoming video signal and decoded picture buffer signal, and/or may determine an appropriate coding mode on a per frame, coding tree unit, and/or subblock basis. Additionally, the mode decision block 230 may employ motion and/or disparity estimation of the video signal. The mode decision may include intra modes, inter modes, motion vectors, and quantization parameters. In some examples of the present invention, the mode decision block 230 may provide lambda that may be used by the optimized quantization block 250, described further below. The mode decision block 230 may also utilize lambda in making mode decisions in accordance with examples of the present invention.
The output of the mode decision block 230 may be utilized by the prediction block 220 to generate a predictor in accordance with a coding standard, such as the HEVC coding standard. The predictor may be subtracted by a delayed version of the video signal at the subtractor block 204. Using the delayed version of the video signal may provide time for the mode decision block 230 to act. The output of the subtractor block 204 may be a residual, e.g., the difference between a block and a predicted block, and the residual may be provided to the transform block 206.
The transform block 206 may perform a transform, such as a discrete cosine transform (DCT) or a discrete sine transform (DST), to transform the residual to the frequency domain. As a result, the transform block 206 may provide a coefficient block corresponding to spectral components of data in the video signal. The quantization block 250 may receive the coefficient block and quantize the coefficients of the coefficient block to produce a quantized coefficient block. The quantization employed by the quantization block 250 may be lossy, but may adjust and/or optimize one or more coefficients of the quantized coefficient block, for instance, based on a Lagrangian cost function. By way of example, the quantization block 250 may utilize a rate factor lambda to optimize rate-distortion. Lambda may be received from the mode decision block 230 or may be specified by a user. Lambda may vary, e.g. per coding tree unit or subblock, and may be based on information encoded by the video signal. For example, video signals encoding advertising may utilize a generally smaller lambda than video signals encoding detailed scenes.
In turn, the entropy encoder block 208 may encode the quantized coefficient block to provide an encoded bitstream. The entropy encoder block 208 may be any entropy encoder known by those having ordinary skill in the art, such as a context-adaptive binary arithmetic coding (CABAC) encoder. Sign data hiding may be performed by the entropy encoder block 208. The quantized coefficient block may also be inverse scaled and quantized by the inverse quantization block 210. The inverse scaled and quantized coefficients may be inverse transformed by the inverse transform block 212 to provide a reconstructed residual signal. The reconstructed residual signal may be added to the predictor at the adder block 214 to provide a reconstructed video signal that may be provided to the filter block 216. The filter block 216 may be a deblocking filter and/or a sample adaptive offset (SAO) filter in accordance with the HEVC coding standard. The filter block 216 may filter the reconstructed video signal and the filtered signal may be written to the picture buffer block 218 for use in future frames, and may be fed back to the mode decision block 230 for further prediction or other mode decision operations.
The quantization block 250 may provide a quantized coefficient block having optimized coefficients such that a cost (e.g., rate-distortion cost) associated with each coefficient is optimized. In one embodiment, for example, this optimization may be based on a Lagrangian cost function, such as lambda, that may be provided by the mode decision block 230. In another embodiment, the optimization may be based on the inverse of lambda, or inverse lambda. Lambda may be a rate factor for determining a cost (e.g., rate-distortion cost) for a signal. As described, lambda may be generated by the mode decision block 230 based on the incoming video signal, and may be fixed or adjusted in real-time.
The encoder 200 may operate in accordance with any known coding standard, including the HEVC coding standard. Thus, because the HEVC, coding standard employs motion prediction and/or motion compensation, the encoder 200 may further include a feedback path that includes an inverse quantization block 210, an inverse transform 212, a reconstruction adder block 214, and a filter block 216. These elements may mirror elements of a decoder (not shown) that is configured to reverse, at least in part, the encoding process employed by the encoder 200. The feedback path of the encoder may further include a decoded picture buffer block 218 and a prediction block 220.
In an example operation of the encoder 200, a video signal (e.g. a base band video signal) may be provided to the encoder 200. The video signal may be provided to the delay buffer block 202 and the mode decision block 230. The subtractor 204 may receive the video signal from the delay buffer block 202 and may subtract a prediction signal from the video signal to generate a residual signal. The residual signal may be provided to the transform block 206 and processed using a forward transform, such as a DCT. As described, the transform block 206 may generate a coefficient block that may be provided to the quantization block 250, and the quantization block 250 may quantize and/or optimize the coefficient block such that a cost of coefficients in the coefficient block are optimized. Quantization of the coefficient block may be based on lambda or inverse lambda. The quantized coefficient block may be provided to the entropy encoder block 208 and the entropy encoder block 208 may encode the quantized coefficient block to provide an encoded bitstream.
The quantized coefficient block may further be provided to the feedback path of the encoder 200. That is, the quantized coefficient block may be inverse quantized, inverse transformed, and added to the prediction signal by the inverse quantization block 210, the inverse transform 212, and the reconstruction adder block 214, respectively, to provide a reconstructed video signal. Both the prediction block 220 and the filter block 216 may receive the reconstructed video signal. Because the filter block 216 may operate in accordance with the HEVC standard, the filter block 216 may include a deblocking filter, a sample adaptive offset (SAO) filter, and/or an adaptive loop filter (ALF). The decoded picture buffer block 218 may receive a filtered video signal from the filter block 216. Based on the reconstructed and filtered video signals, the prediction block 220 may provide a prediction signal to the adder block 214.
Accordingly, the encoder of
In an example operation of the quantization block 300, a coefficient block may be provided to a forward ordering block 302 from a transform such as the transform block 206 of
Accordingly, the coefficient vector c[ ] may be indexed by the forward index block 306, for instance, to reduce the number of possible coefficient values and/or the amount of data required to represent each coefficient value. The indexed coefficient vector may then be provided to the block optimization circuit 350, such that coefficients may be received one at a time.
The inverter 370 may receive lambda, and may provide inverse lambda to the optimization block 350. Based on inverse lambda and a context (e.g., CABAC context) received from the context register 330, the optimization block 350 may receive the coefficient vector and provide an optimized quantized coefficient vector. In some embodiments, the optimization block 350 may receive lambda directly from a mode decision block and may optimize the coefficients based, at least in part, on lambda or inverse lambda. Moreover, the context received by the optimization block 350 from the context register 330 may be an initial context, and in selecting the coefficients, the block optimization circuit 350 may iteratively provide the context register 330 with an updated context as each coefficient is quantized and/or optimized. The updated context provided to the context register 330 may be used in quantizing and/or optimizing the next coefficient of the coefficient vector, and/or may be used as an initial context for other coefficient vectors, as will be described further below.
The reverse index block 308 may subsequently rescale the optimized quantized coefficient vector, and the inverse ordering block 312 may convert the vector to a quantized coefficient block by performing an inverse scan operation. The quantized coefficient block may be provided to an entropy encoder, such as the entropy encoder block 208 of
In this manner, examples of optimized quantization blocks described herein may process coefficients using one cycle per coefficient, resulting in a bounded time optimization. Any number of coefficients may be processed per block, however generally a fixed number of coefficients are provided per block, such as, but not limited to, 16 coefficients per block.
For example, the candidate generation block 405 may be configured to receive sequentially provided coefficients from the index 306 of
The minimum cost blocks 415, which may correspond in number to the node cost blocks 410 and may also correspond to the unique node states, may each receive a plurality of arcs and determine which arc has a lowest cost. The particular node cost blocks 410 coupled to the minimum cost blocks 415 may be determined by allowable state transitions of the encoding method as described further herein. Each of the minimum cost blocks 415 may further provide the lowest cost arc that was input to the minimum cost block 415 to a node cost block 410 having a same node state. Each node cost block 415 may update the received arc by adding respective costs of the arc to costs of new candidates as well as append each candidate to a path of the arc. The final minimum cost block 420 may receive the lowest cost arcs for each node state and identify an arc having the overall lowest cost, and may further provide the corresponding context, cost, rate cost, distortion cost, and path of the arc from the optimization block 400. The context may, for example, be provided to a context register, such as the context register 330 of
In an example operation of the optimization block 400, a first coefficient of a coefficient vector may be received at the candidate generation block 405, and the candidate generation block 405 may provide a plurality of candidates corresponding to the coefficient. In at least one embodiment, the candidates may be based, at least in part, on a quantization parameter Qp and/or inverse lambda, as will be described further below. The quantization parameter may be indicative of a resolution factor for quantization. In addition to providing the plurality of candidates, the candidate generation block 405 may further provide a plurality of distortion costs corresponding to the plurality of candidates respectively. The candidate generation block 405 may provide four candidates and/or distortion costs for each coefficient, but embodiments of the invention should not be limited to a particular number, as other implementations may be used without departing from the scope and spirit of the invention.
Each candidate and distortion cost, in addition to an initial context and a respective node state, may be provided from the candidate generation block 405 to each of a plurality of node cost blocks 410. An arc for each candidate may be generated by each of the plurality of node cost blocks 410 based on the node state of each node cost block 410, the initial context, and the distortion cost of each candidate.
Each arc may be provided to one or more of a plurality of minimum cost blocks 415 based on the node state of each node cost block 410 and each minimum cost block 415. For example, to reduce the number of potential paths, the node cost blocks 410 may provide arcs to particular minimum cost blocks 415 based on a state transition diagram, such as a state transition diagram according to the HEVC standard. Once each minimum cost block 415 has received its respective arc(s) from one or more of the node cost blocks 410, each minimum cost block 415 may determine which received arc has the lowest cost.
Each minimum cost block 415 may provide its lowest cost arc to the node cost block 410 of the same node state. New candidates and distortion costs corresponding to the next coefficient may also be received by the node cost blocks 410. Based, at least in part, on the received arcs, new candidates, and distortion costs, updated arcs may be provided to respective minimum cost blocks 415. The updated arcs may include a cost for the current candidate added to a previous fed-back cost, a next state for the candidate, and the candidate coefficient appended to a list of coefficients from the fed-back arc. Again, each minimum cost block 415 may determine which arc has the lowest cost and provide the lowest cost arc to the node cost block 410 having the same node state. This process may be iteratively repeated until candidates for all coefficients of a coefficient vector have been considered. The final minimum cost arcs for each node cost block 410 may be provided to the final minimum cost block 420, which may determine which arc has the lowest cost. The final list of appended coefficients in the selected lowest cost arc may be output (e.g. u[n] in
In an example operation of the candidate generation block 500, each coefficient of a coefficient vector may be sequentially provided to the candidate generation block 500, and in particular to the forward quantization block 502. As known, the forward quantization block 502 may quantize each coefficient based, at least in part, on the quantization parameter Qp, to generate a quantized coefficient in accordance with one or more quantization methods. A plurality of candidates may be generated based, at least in part, on the quantized coefficient and provided from the candidate generation block 500, for instance, to a plurality of node cost blocks as described above. In one embodiment, the plurality of candidates may include the quantized coefficient as well as the quantized coefficient having increased and decreased quantization levels, respectively. The increased and decreased quantization level candidates may be provided by the candidate generation blocks 504, and 506, respectively.
A distortion cost for each candidate may also be generated by the candidate generation block 500. By way of example, an inverse quantization block 512 may be used to inverse quantize each of the candidates, respectively. Each candidate may further be scaled with an inverse weight at respective inverse weight blocks 514 to produce reconstructed candidates, which may subsequently be subtracted (e.g. using block 516) from the coefficient to generate a residual error between the coefficient and reconstructed candidate. Each error may be squared (e.g. using block 518), forward weighted (e.g. using block 520), and multiplied by inverse lambda (e.g. using block 522) to provide respective distortion costs for each candidate. The bit width for each distortion cost may be truncated by a clamp 530. Generally any number of bits may be set by the clamp, e.g. 25 bits in one example. As described, a zero coefficient and associated distortion cost may also be provided. In some examples, inverse lambda may vary by coefficient, and utilizing candidate generation as described and shown with reference to
The plurality of arc cost blocks 702 may correspond in number to the number of candidates generated for each coefficient, for instance, by a candidate generation block, and accordingly, each of the plurality arc cost blocks 702 may receive a candidate and distortion cost. Each arc cost block 702 may receive the initial context or arc from the node register 704 and may provide an updated arc for each respective candidate.
As an example, during an initialization, an initial context may be provided to the multiplexer 706, which may in turn selectively provide the initial context to the register 704. Candidates and distortion costs for a first coefficient may be generated, for example, by a candidate generation block 405 of
As described above with respect to
Once arcs have been generated for the first candidates, each of the arcs may be provided to one or more minimum cost blocks 415, and an arc having the lowest cost for each node state may be provided to the node cost block 410 having the same node state, as described. Thus, in at least one embodiment, an arc determined to have the lowest cost for a particular node state may be provided to a node cost block 700, and in particular to the multiplexer 706. The multiplexer 706 may selectively provide the arc to the register 704, which may in turn provide the arc to the arc cost blocks 702. The arc cost blocks 702 may receive new respective candidates and distortion costs for a subsequent coefficient, and again provide updated arcs. The arc cost blocks 702 may receive lowest cost arcs, new candidates and distortion costs, and responsively provide updated arcs until candidates for all coefficients of a coefficient vector have been considered.
In an example operation of the arc cost block 800, a candidate, and a state and context of an arc may be provided to the rate block 802. The state may be based, for instance, on a state transition diagram in accordance with the HEW coding standard, and the rate block 802 may determine a next state based on the state and/or the candidate. The rate block 802 may further determine a rate cost of the candidate and/or context for a new arc. In one embodiment, for example, the rate block 802 may determine the rate cost of the candidate and/or context using estimation tables for one or more coding standards, such as the HEW coding standard.
The rate cost of the candidate may be combined with the rate cost of the arc by the adder 806. Moreover, the distortion cost may be combined with the distortion cost included in the arc by the adder 808. An adder 810 may combine the combined distortion cost and the combined rate cost to generate a cost for the updated arc. Finally, the candidate path block 804 may receive the path of the arc and the candidate, and append the current candidate to the path. This may, for example, maintain a complete list of the candidates used in a path, and should a particular arc have the overall lowest cost, the candidates included in the path may be provided as optimized quantized coefficients as described above.
The state transition block 902 may generate a new state responsive to receipt of a state and a candidate. The new state may be generated in accordance with a state transition diagram, and/or the candidate value. The binarization block 904 may receive the candidate and perform a binarization on the candidate in accordance with binarization of the HEM coding standard. As known, this binarization process may derive a bypass bitcount and a bincount. The bypass bitcount is a number bypass bits represented by the coefficient, while the bincount provides a number of bins represented by the coefficient. The bins may each have a particular number of bits.
The estimation table 910 and the update table 920 may receive the bincount and a context for an arc and further may be implemented using look-up tables. Given a context and a bin, the estimation table 910 may provide an estimated CABAC rate and the update table 920 may provide an updated context. Use of look-up tables may allow for rates to be estimated fractionally.
Rates provided by the estimation table 910 may be combined with the bypass bitcount by the adder 914 to obtain the rate. That is, rate cost estimations (e.g., fractional bit rate cost estimations in the estimation table 910 may be combined with the bypass bitcount at the adder 914 to provide a rate cost for a candidate. In at least one embodiment, estimating the rate costs for CABAC encoding may mitigate and/or eliminate the need for arithmetic encoding to determine the rate cost for each candidate. This may decrease the time required to determine a rate cost for a candidate, and accordingly may allow for operation within tighter performance tolerances. Utilization of the look-up tables described may facilitate real-time operation of the systems and methods described herein. Techniques utilizing arithmetic encoding may not be able to implement real-time operation.
The state transition block 902 can be coded to perform this pseudocode. In this pseudocode example, ‘s’ may be a state, ‘u’ may be an absolute value of a candidate value, ‘r’ may be an HEVC Rice parameter, and ‘c’ may be a CABAC context variable (e.g., greater1ctx). The state may be represented by the value of HEVC Rice Parameter ‘r’ (if applicable) and CABAC context variable ‘c’. If the state is equal to [r,c] and the absolute value of the candidate ‘u’ is greater than the value of the HEVC Rice Parameter bitwise left shifted by 3, then state may transition to [min(4, r+1),0]. If the state is [0,c] and the absolute value of the candidate is greater than 1, then the state transitions to [0,0]. If the state is [0,c], the absolute value of the candidate is equals 1, and the CABAC context variable is greater than 1, then the state transitions to [0,min(3,c+1]. It will be appreciated, however, that other state transition diagrams may be specified and used to govern state transitions without departing from the scope and spirit of the invention.
Moreover, as explained with respect to
In HEVC, the coding of the magnitude of a coefficient (e.g. absLevel) may including the coding of at least three syntax elements—a first coefficient syntax element including a flag indicating if the coefficient has an absolute value greater than one (e.g. gr1 flag), a second coefficient syntax element including a flag indicating if the coefficient has an absolute value greater than 2 (e.g. gr2 flag), and a level remaining syntax element indicating a level remaining. In coding mode 1101, both the first coefficient syntax element and the second coefficient syntax element are coded, and if the magnitude of the coefficient is 3, the level remaining syntax element would be bypass-coded using Golomb-Rice codes and Exp-Golomb codes. To improve the throughput, the first coefficient syntax element and the second coefficient syntax element flag may not be always coded for all coefficients in a sub-block. In coding mode 1102 only the first coefficient syntax element and the level remaining syntax element (magnitude of the coefficient is 2) are coded. After eight first coefficient syntax elements in a sub-block are coded, coding mode 1103 may be used where no first coefficient syntax element are coded for the rest of the coefficients and the level remaining syntax element (magnitude of the coefficient is 1).
The implementation of three coding modes in
Rather than tracking the number of non-zero coefficients with the state machine, the first coefficient syntax element coding mode switches depending on whether the path has 8 or more non-zero coefficients (g>7). Therefore, a possible simplification is to merge those states for which g<=7 but sharing the same r and c. This reduces the triplet (r, c, g) to (r, c), where c is 0, 1, 2, 3, with indicating the condition g>7 is met and the first coefficient syntax element is no longer coded. As with
The sign data hiding (SDH) feature in the HEVC coding standard may allow for the reduction of the number of bits required to transmit the quantized coefficients. When enabled, SDH allows the encoder to omit transmission of the sign of the first non-zero coefficient. On the receiving side, the decoder may maintain a count of the number of coefficients between the first non-zero coefficient and the last non-zero coefficient along the scanning path. Once that count exceeds a certain predefined threshold, the sign of the aforementioned first non-zero coefficient can be inferred from the parity of the sum of all non-zero coefficients (e.g. positive if the sum is even, negative if odd). SDH generally requires the encoder to maintain a similar coefficient count and ensure that the parity of the sum of non-zero coefficients matches the sign of the first non-zero coefficient if the sign is to be inferred by the decoder. When there is a mismatch, the encoder needs to modify at least one of the coefficients to ensure the correct parity. Which coefficient is modified, however, is generally left for the encoder to decide and leaves room for potential optimization. Other sign data hiding techniques may be used in other examples to implement omission of one or more coefficient signs in a transmitted bitstream and infer those signs at a decoder.
The rate-distortion optimized coefficient quantization as described above can be combined with SDH techniques.
When traversing the trellis diagram in
The media source data 2002 may be any source of media content, including but not limited to, video, audio, data, or combinations thereof. The media source data 2002 may be, for example, audio and/or video data that may be captured using a camera, microphone, and/or other capturing devices, or may be generated or provided by a processing device. Media source data 2002 may be analog and/or digital. When the media source data 2002 is analog data, the media source data 2002 may be converted to digital data using, for example, an analog-to-digital converter (ADC). Typically, to transmit the media source data 2002, some technique for compression and/or encryption may be desirable. Accordingly, an apparatus 2010 may be provided that may filter and/or encode the media source data 2002 using any methodologies in the art, known now or in the future, including encoding methods in accordance with standards such as, but not limited to, MPEG-2, MPEG-4, H.263, MPEG-4 AVC/H.264, HEVC, VC-1, VP8 or combinations of these or other encoding standards. The apparatus 2010 may be implemented with embodiments of the present invention described herein. For example, the apparatus 2010 may be implemented using the apparatus 100 of
The encoded data 2012 may be provided to a communications link, such as a satellite 2014, an antenna 2015, and/or a network 2018. The network 2018 may be wired or wireless, and further may communicate using electrical and/or optical transmission. The antenna 2015 may be a terrestrial antenna, and may, for example, receive and transmit conventional AM and FM signals, satellite signals, or other signals known in the art. The communications link may broadcast the encoded data 2012, and in some examples may alter the encoded data 2012 and broadcast the altered encoded data 2012 (e.g. by re-encoding, adding to, or subtracting from the encoded data 2012). The encoded data 2020 provided from the communications link may be received by a receiver 2022 that may include or be coupled to a decoder. The decoder may decode the encoded data 2020 to provide one or more media outputs, with the media output 2004 shown in
The media delivery system 2000 of
A production segment 2110 may include a content originator 2112. The content originator 2112 may receive encoded data from any or combinations of the video contributors 2105, The content originator 2112 may make the received content available, and may edit, combine, and/or manipulate any of the received content to make the content available. The content originator 2112 may utilize apparatuses described herein, such as the apparatus 100 of
The digital broadcast system 2121 may include an apparatus, such as the apparatus 2010 described with reference to
The cable local headend 2132 may include an apparatus, such as the apparatus 100 of
Accordingly, embodiments of the present invention include systems and methods that may optimize coefficients using a lambda-weighted rate-distortion cost equation. Embodiments may be used for real-time encoders, such as real-time CAVLC and/or CABAC encoders, and may employ fractional bit estimations and inverse lambda.
From the foregoing it will be appreciated that, although specific embodiments of the invention have been described herein for purposes of illustration, various modifications may be made without deviating from the spirit and scope of the invention. Accordingly, the invention is not limited except as by the appended claims.