AU678926C - Method and apparatus for preventing overflow and underflow of an encoder buffer in a video compression system - Google Patents
Method and apparatus for preventing overflow and underflow of an encoder buffer in a video compression systemInfo
- Publication number
- AU678926C AU678926C AU45200/96A AU4520096A AU678926C AU 678926 C AU678926 C AU 678926C AU 45200/96 A AU45200/96 A AU 45200/96A AU 4520096 A AU4520096 A AU 4520096A AU 678926 C AU678926 C AU 678926C
- Authority
- AU
- Australia
- Prior art keywords
- buffer
- encoder
- predetermined
- decoder buffer
- underflow
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Ceased
Links
Description
METHOD AND APPARATUS FOR PREVENTING OVERFLOW AND UNDERFLOW OF AN ENCODER BUFFER IN A VIDEO COMPRESSION
SYSTEM
Field of the Invention
The invention relates generally to the field of video compression, and in particular, to the control of an encoder buffer used to store compressed video data.
Background of the Invention
Video systems are known to include a plurality of communication devices and communication channels, which provide the communication medium for the communication devices. For example, the communication channel may be wireline connections or RF frequency carriers. To increase the efficiency of the video system, video that needs to be communicated over the communication medium is digitally compressed. The digital compression reduces the number of bits needed to represent the video while maintaining perceptual quality of the video. The reduction in bits allows more efficient use of channel bandwidth and reduces storage requirements. To achieve digital video compression, each communication device may include an encoder and a decoder. The encoder allows a communication device to compress video before transmission over a communication channel. The decoder enables the
communication device to receive and process compressed video from a communication channel. Communication devices that may use digital video compression include high definition television transmitters and receivers, cable television transmitters and receivers, video telephones, computers and portable radios.
Several standards for digital video compression have emerged, including International Telecommunications Union ITU-T Recommendation H.261, the International Standards Organization/ International Electrotechnical Committee, ISO/IEC, 11172-2 International Standard , MPEG- 1. and the forthcoming ISO/IEC 13818-2 standard, MPEG-2. These standards designate the requirements for a decoder by specifying the syntax of a bit stream that the decoder must decode. This allows some flexibility in the creation of the encoder, but the encoder must be capable of producing a bit stream that meets the specified syntax.
To maximize usage of the available channel bandwidth and the quality of the video, the encoder seeks to match the number of bits it produces to the available channel bandwidth. This is often accomplished by selecting a target number of bits to be used for the representation of a video frame or picture. The target number of bits is referred to as the target bit allocation. The target bit allocation may be substantially different from picture to picture, based upon picture type and other considerations. A further consideration for the encoder in generating bits is the capacity of any buffers in the system. Generally, since the bitrates of the encoder and decoder are not constant, there are buffers placed at both ends of the channel, one
following the encoder prior to the channel and one at the end of the channel preceding the decoder. The buffers absorb the fluctuation in bitrates. The encoder often must insure that the buffers at the encoder and decoder will not overflow or underflow as a result of the bit stream generated.
Generally, and in particular in the case of emerging video compression standards, more than one picture type is used for encoding the pictures. For example, MPEG uses intracoded pictures, predicted pictures, and bidirectionally predicted pictures. Intracoded pictures use only the information contained within the current picture itself for encoding. Predicted pictures use the current picture and a previously encoded picture as a reference to encode the current picture. By using the previously encoded picture as a reference, fewer bits are generally generated since only differences between the current picture and the previously encoded picture need to be encoded. Similarly, bidirectionally encoded pictures may use a past and or previously encoded picture as a reference in addition to the current picture to encode the current picture. The different picture types inherently generate a varying number of bits. Since intracoded pictures do not use a reference picture for creating the current picture, they inherently use more bits than a bidirectionally encoded picture. Also, predicted pictures generally produce more bits than bidirectionally encoded pictures but less bits than intracoded pictures. The different picture types add a level of complexity to the problem of matching the encoder rate to the channel rate since different pictures inherently need to use more or less bits. In addition, the use of different picture types further complicates the control of underflow and overflow of any buffers resident in the system.
Therefore, a need exists for a method and apparatus to prevent overflow and underflow of an encoder buffer in a video compression systems and yet maintain visual quality.
Brief Description of the Drawings
FIG. 1 is a flow diagram of one embodiment of a method for preventing overflow and underflow of an encoder buffer in a video compression system in accordance with the present invention.
FIG. 2 is a block diagram of one embodiment of an apparatus which contains a rate controller for preventing overflow and underflow of an encoder buffer in a video compression system in accordance with the present invention.
FIG. 3 is a graphical representation of an encoder buffer fullness and a virtual buffer fullness in accordance with the present invention.
Description of a Preferred Embodiments
The present invention is method and apparatus for preventing overflow and underflow of an encoder buffer in a video compression system. A virtual buffer is
created in a rate controller to model the decoder buffer fullness. A sequence of bits is generated by an encoder. The encoder is controlled by the rate controller to prevent a decoder buffer underflow and overflow. Then, the sequence of bits is received by the encoder buffer to produce a bitstream. The bitstream corresponds to an instantaneous channel bitrate. The bitstream is transmitted from the encoder buffer to a decoder buffer following a delay. The delay is controlled by a rate controller to synchronize an encoder buffer fullness with a virtual buffer fullness. The synchronization prevents overflow and underflow of the encoder buffer.
The compression algorithm scheme of the present invention uses pictures of different types with different statistical properties. In order to maximize the overall encoding picture quality, the number of bits targeted to encode the different picture types is predetermined. This number can be substantially different from picture to picture, based upon picture type and other considerations. To achieve good encoding picture quality, the number of bits generated is kept close to the target bit allocation.
During encoding, a video picture is divided into successive blocks. For example, in MPEG-1 and MPEG-2, each block consists of pixels. As each block is encoded, the number of bits generated is tabulated in the virtual buffer, and the bits flow into the encoder buffer. The encoder buffer then outputs bits through a channel into the decoder buffer.
The number of bits generated from block to block generally differ substantially, whereas the number of bits output to the channel is kept constant. The
number of bits generated per block is controlled in a relative way by adjusting the amount in which each block is quantized. The exact number of bits generated with a particular quantization stepsize varies depending upon the picture content, and is not known until after the block has been compressed using the chosen quantization stepsize. However, in general, the higher the quantization stepsize, the fewer the number of bits that are generated.
The present invention can be more fully described with reference to FIGs. 1 -3. FIG. 1, numeral 100, is a flow diagram of a method for preventing overflow and underflow of an encoder buffer in a video compression system in accordance with the present invention. A virtual buffer is created in a rate controller to model the decoder buffer fullness (102). A sequence of bits is generated by an encoder (104). The encoder is controlled by the rate controller to prevent a decoder buffer underflow and overflow. Then, the sequence of bits is received by the encoder buffer to produce a bitstream (106). The bitstream corresponds to an instantaneous channel bitrate. The bitstream is transmitted from the encoder buffer to a decoder buffer following a delay (108). The delay is controlled by the rate controller to synchronize an encoder buffer fullness with a virtual buffer fullness (110). The synchronization prevents overflow and underflow of the encoder buffer.
The encoder buffer is designed to have a larger storage capacity than the decoder buffer. The delay of the switch τ is determined by:
where β is the predetermined decoder buffer size, -B(7")is the initial decoder buffer fullness, R is the predetermined average channel bitrate, andE is the predetermined frame rate. The instantaneous channel bitrate may be monitored by the rate controller to update the predetermined average channel bitrate.
FIG. 2, numeral 200, is a block diagram of an apparatus which contains a rate controller for preventing overflow and underflow of an encoder buffer in a video compression system in accordance with the present invention. The apparatus comprises an encoder (202), an encoder buffer (204), a switch (206), a decoder buffer (208), and a rate controller (210). The rate controller further comprises a virtual buffer (212).
The encoder (202) generates a sequence of bits (216) based on an input video frame (214). The encoder buffer (204) receives the sequence of bits (216) to produce a bitstream (218). The switch (206) delays the transmission of the bitstream (218) to produce a delayed bitstream (220). The delayed bitstream (220) corresponds to an instantaneous channel bitrate (222). The decoder buffer (208) receives the delayed bitstream (220). The rate controller (210) containing the virtual buffer (212) controls the encoder (202) and therefore, prevents the decoder buffer (208) from underflowing and overflowing. The rate controller (210) containing the virtual buffer (212) also
controls the delay of the switch (206) to prevent overflow and underflow of the encoder buffer (204).
The encoder buffer is designed to have a larger storage capacity than the decoder buffer. The delay of the switch r is determined by:
where β is the predetermined decoder buffer size (224), B(T )is the initial decoder buffer fullness (226), R is the predetermined average channel bitrate (230), and F is the predetermined frame rate (228). The instantaneous channel bitrate (222) corresponding to the delayed bitstream (220) may be monitored by the rate controller (210) to update the predetermined average channel bitrate (230).
FIG. 3, numeral 300, is a graphical representation of an encoder buffer fullness (310) and a virtual buffer fullness (306) in accordance with the present invention. The buffer fullness (302) is displayed as a function of time expressed in frames (304). The difference (308) between the predetermined decoder buffer size (224) and the initial decoder buffer fullness (226) is depicted at time zero and is expressed as:
β- B(D
The difference δ (314) between the encoder buffer fullness (310) and the virtual buffer fullness (306) is updated by the delay of the switch (206) to match the difference between the encoder buffer storage capacity and the decoder buffer storage capacity.
The present invention provides a robust method for preventing overflow and underflow of an encoder buffer in a video compression system when overflow and underflow of the decoder buffer is prevented. Other methods for rate control such as TM5 of MPEG-2 and SM3 of MPEG- 1 do not address overflow and underflow of a buffer.
Although exemplary embodiments are described above, it will be obvious to those skilled in the art that many alterations and modifications may be made without departing from the invention. Accordingly, it is intended that all such alterations and modifications be included within the spirit and scope of the invention as defined in the appended claims.
Claims (9)
1. A method for preventing overflow and underflow of an encoder buffer in a video compression system, the method comprising the steps of:
a) creating a virtual buffer, in a rate controller, to model a decoder buffer fullness;
b) generating a sequence of bits by an encoder, wherein the encoder is controlled by the rate controller to prevent a decoder buffer underflow and overflow;
c) receiving the sequence of bits by the encoder buffer to produce a bitstream;
d) transmitting the bitstream from the encoder buffer to a decoder buffer following a delay to produce a delayed bitstream, wherein the delayed bitstream corresponds to an instantaneous channel bitrate; and
e) controlling the delay by the rate controller to synchronize an encoder buffer fullness with a virtual buffer fullness, wherein the synchronization prevents overflow and underflow of the encoder buffer. 1 1
2. The method of claim 1, wherein a predetermined encoder buffer size is larger than a predetermined decoder buffer size.
3. The method of claim 2, wherein the delay is based on the predetermined decoder buffer size, an initial decoder buffer fullness, a predetermined average channel bitrate , and a predetermined frame rate.
4. The method of claim 3, wherein the delay is determined utilizing an equation of a form:
where β is the predetermined decoder buffer size, B(T~ ) is the initial decoder buffer fullness, R is the predetermined average channel bitrate, and F is the predetermined frame rate.
5. The method of claim 3, wherein the method further comprises monitoring the instantaneous channel bitrate by the rate controller to update the predetermined average channel bitrate.
6. A apparatus for preventing overflow and underflow of an encoder buffer in a video compression system, the apparatus comprising:
an encoder, operably coupled to a rate controller, for generating a sequence of bits based on an input video frame;
the encoder buffer, operably coupled to the encoder, for receiving the sequence of bits to produce a bitstream;
a switch, operably coupled to the encoder buffer and to the rate controller, for providing a delay and preventing the transmission of the bitstream from the encoder buffer to a decoder buffer to produce a delayed bitstream, wherein the delayed bitstream corresponds to an instantaneous channel bitrate;
the decoder buffer, operably coupled to the switch, for receiving the bitstream: and
the rate controller, operably coupled to the switch, for controlling the encoder to prevent a decoder buffer underflow and overflow and for controlling the delay of the switch to prevent overflow and underflow of the encoder buffer.
7. The apparatus of claim 6, wherein a predetermined encoder buffer size is larger than a predetermined decoder buffer size.
8. The apparatus of claim 7, wherein the delay is based on the predetermined decoder buffer size, an initial decoder buffer fullness, a predetermined average channel bitrate, and a predetermined frame rate, and where selected, at least one of 8A-8B:
8A) the delay is determined utilizing an equation of a form:
(β - B(T)).F τ =
R
where β is the predetermined decoder buffer size, B(T~) is the initial decoder buffer fullness, R is the predetermined average channel bitrate, and F is the predetermined frame rate; and
8B) the instantaneous channel bitrate is monitored by the rate controller to update the predetermined average channel bitrate.
9. The apparatus of claim 6, wherein the rate controller comprises a virtual buffer for modeling a decoder buffer fullness.
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US392583 | 1995-02-23 | ||
US08/392,583 US5619341A (en) | 1995-02-23 | 1995-02-23 | Method and apparatus for preventing overflow and underflow of an encoder buffer in a video compression system |
PCT/US1995/016358 WO1996026595A1 (en) | 1995-02-23 | 1995-12-14 | Method and apparatus for preventing overflow and underflow of an encoder buffer in a video compression system |
Publications (3)
Publication Number | Publication Date |
---|---|
AU4520096A AU4520096A (en) | 1996-09-11 |
AU678926B2 AU678926B2 (en) | 1997-06-12 |
AU678926C true AU678926C (en) | 1997-11-27 |
Family
ID=
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP0758509B1 (en) | Method and apparatus for preventing overflow and underflow of an encoder buffer in a video compression system | |
US5677969A (en) | Method, rate controller, and system for preventing overflow and underflow of a decoder buffer in a video compression system | |
EP0954927B1 (en) | Video buffer for seamless splicing of mpeg streams | |
US6643327B1 (en) | Statistical multiplexer and remultiplexer that accommodates changes in structure of group of pictures | |
US5719632A (en) | Motion video compression system with buffer empty/fill look-ahead bit allocation | |
US6188700B1 (en) | Method and apparatus for encoding MPEG signals using variable rate encoding and dynamically varying transmission buffers | |
US6859496B1 (en) | Adaptively encoding multiple streams of video data in parallel for multiplexing onto a constant bit rate channel | |
AU650219B2 (en) | Statistical multiplexer for a multichannel image compression system | |
EP0740882B1 (en) | Method and device for determining bit allocation in a video compression system | |
US7266133B2 (en) | Methods and apparatus for statistical multiplexing with distributed multiplexers | |
WO2001080570A2 (en) | Rate control and buffer protection for variable bit rate video programs over a constant rate channel | |
KR0127329B1 (en) | Buffer control apparatus for intraframe using tct | |
EP0708566B1 (en) | Method and system for controlling a video data encoder buffer | |
EP0971542A2 (en) | Readjustment of bit rates when switching between compressed video streams | |
GB2365240A (en) | Control of amount of data used for image transmission | |
AU678926C (en) | Method and apparatus for preventing overflow and underflow of an encoder buffer in a video compression system | |
GB2341745A (en) | Image encoding | |
Sostawa et al. | DSP-based transcoding of digital video signals with MPEG-2 format | |
AU678927C (en) | Method, rate controller, and system for preventing overflow and underflow of a decoder buffer | |
JPH11234671A (en) | Signal processing unit | |
EP0891673A1 (en) | Buffer control in a coded data transmission system | |
KR100236822B1 (en) | Method for determining multiplex rate of variable bit rate signal | |
JP2000041250A (en) | Method and system for processing multiple stream of video frame |