AU2014202978B2 - Method and system for context-based adaptive binary arithmetic coding - Google Patents
Method and system for context-based adaptive binary arithmetic coding Download PDFInfo
- Publication number
- AU2014202978B2 AU2014202978B2 AU2014202978A AU2014202978A AU2014202978B2 AU 2014202978 B2 AU2014202978 B2 AU 2014202978B2 AU 2014202978 A AU2014202978 A AU 2014202978A AU 2014202978 A AU2014202978 A AU 2014202978A AU 2014202978 B2 AU2014202978 B2 AU 2014202978B2
- Authority
- AU
- Australia
- Prior art keywords
- coefficient values
- block
- zero
- context
- array
- 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.)
- Expired
Links
Landscapes
- Compression Or Coding Systems Of Tv Signals (AREA)
- Compression, Expansion, Code Conversion, And Decoders (AREA)
Abstract
METHOD AND SYSTEM FOR CONTEXT-BASED ADAPTIVE BINARY ARITHMETIC Abstract Disclosed is a method of image coding, in which an image is divided into a plurality of blocks having a plurality of pixels, each pixel having a pixel value, and a transform coding operation is performed on a block of pixels to produce a corresponding block of transform coefficient values, and the block of transform coefficient values is scanned in a given scanning order to produce a scanned array of coefficient values. The method comprises providing a number indicative of a number of non-zero coefficient values in the array of coefficient values, and assigning the number to a context representative of the number. 5705464-1
Description
METHOD AND SYSTEM FOR CONTEXT-BASED ADAPTIVE BINARY ARITHMETIC CODING FIELD OF THE INVENTION 5 The present invention relates generally to the compression of still images and video sequences and, more particularly, to a method and system for context-based adaptive binary arithmetic coding. BACKGROUND OF THE INVENTION 10 A digital image in uncompressed form comprises an array of image pixels or picture elements. For example, in a commonly used digital image format, known as the Quarter Common Interchange Format (QCIF), an image, or frame, comprises 25,344 pixels arranged in an array of 176x 144 pixels. Each pixel, in turn, is represented by a certain number of bits, which carry information about the brightness (luminance) and/or 15 color (chrominance) of the pixel. Different schemes exist for representing the luminance and/or chrominance of pixels in a digital image. Commonly, a so-called YUV color model is used. The luminance, or Y, component represents the luminance of the pixel, while the color of the pixel is represented by two chrominance or color difference components, labelled U and V. Other color models, such as RGB (Red, Green, Blue) 20 color models, which are based on components representing the three primary colors of light, are also commonly used. However, color models based on a luminance/chrominance representation provide advantages compared with color models based on primary colors. These stem from the nature of the human visual system, which is more sensitive to intensity variations than it is to color variations. YUV color models 25 typically exploit this property by using a lower spatial resolution for the chrominance components (U, V) than for the luminance component (Y). Inthis way the amount of information needed to represent the color information in an image can be reduced without a noticeable reduction in perceived image quality. The lower spatial resolution of the chrominance components is usually attained by 30 sub-sampling. Typically, a block of 16x16 image pixels is represented by four blocks of 8x8 pixels comprising luminance information and the corresponding chrominance components are each represented by one block of 8x8 pixels representing an area of the image equivalent to that of the 16x16 pixels in the luminance component. The chrominance components are thus spatially sub-sampled by a factor of 2 in the x and y directions. The resulting assembly of four 8x8 pixel luminance blocks and two spatially corresponding 8x8 pixel chrominance blocks is commonly referred to as a YUV 5 macroblock, or macroblock, for short. A QCIF image comprises II x9 such macroblocks. If the luminance blocks and chrominance blocks are represented with 8 bit resolution (that is by numbers in the range 0 to 255), the total number of bits required to represent the luminance and chrominance information associated with each macroblock is 6x(8x8x8) = 3072 bits. Thus, the number of bits needed to represent an image in QCIF 10 format is 99x3072= 304,128 bits. It should be appreciated that even in the situation described above, where both chrominance components of a digital color image are sub-sampled by a factor of two, an uncompressed image of only moderate size (e.g. 176x144 pixels) requires a large number of bits for its representation. This means that the amount of memory required to store 15 digital images in uncompressed form is excessive. Furthermore, if still images are to be transferred, for example over a data communications network having a moderate or low available bandwidth, transmission times may become lengthy, or the network may become congested. Bandwidth requirements are even more severe if it is desired to transmit a series of images as a digital video sequence in real time. For example, 20 transmission of a digital video sequence comprising a series of images in uncompressed QCIF format, represented using a YUV color model, at a rate of 30 frames per second, requires more than 9 Mbits/s (million bits per second). Such a high data rate is generally impractical for use in video recording, transmission and display applications because of the very large storage capacity, transmission channel capacity and hardware performance -- 25- required-f-a-video-sequence is-to -be-transmitted in -real-time over-a-fixed -line network such as an ISDN (Integrated Services Digital Network) or a PSTN (Public Service Telephone Network), the available data transmission bandwidth is typically of the order of 64kbits/s. In mobile video-telephony, where transmission takes place at least in part over a radio communications link, the available bandwidth can be as low as 20kbits/s. 30 This means that a significant reduction in the amount of information used to represent video data must be achieved in order to enable transmission of digital images or video sequences over low bandwidth communication networks. It is nevertheless desirable that this reduction should be achieved without significantly degrading the quality of the images/video sequence. Over the past years, a considerable amount of research work has been directed 5 towards reducing the amount of data required to represent digital images and video sequences, resulting in the development of numerous different schemes and international standards for compressing digital still images and digital video. The basic approach to image compression used in almost all still image and video encoders existing today involves block-based transform coding. Typically, transform coding translates image data 10 from a representation comprising pixel values to a form comprising a set of coefficient values, each of which is a weighting factor (multiplier) for a basis function of the transform in question. It can be shown that there is a considerable degree of spatial redundancy within a typical digital image. In practical terms, this means that in general the value of any pixel within an image is substantially the same as the value of other 15 pixels in its immediate vicinity; that is, there is a significant degree of correlation between pixel values. It is further known that when certain mathematical transformations, such as the two-dimensional Discrete Cosine Transform (DCT), are performed on image data, this spatial redundancy is reduced significantly, thereby producing a more compact representation of the image data. 20 Block-based Transform Coding as Used in JPEG Still Image Coding In still image compression, such as that performed according to the baseline mode of the widely-used JPEG standard, an image to be coded is first divided into an array of non-overlapping square blocks, each block comprising, for example, an 8 x 8 array of 25 image pixels. In the case of the JPEG baseline, a two-dimensional Discrete Cosine Transfonn (DCT) is then applied independently to each of the image blocks. This has the effect of converting the image data from the pixel value domain to the spatial frequency domain and to produce a corresponding set of coefficient values, each of which is a weighting factor for a basis function of the two-dimensional DCT. The coefficient values 30 thus produced are quantized and then coded in a lossless manner using entropy coding to further reduce the amount of data (i-e. number of bits) required for their representation. 3 According to the JPEG baseline, the entropy coder employs only Huffinan coding to produce a compressed bit-stream, although in other modes arithmetic coding may alternatively be used. Finally, data describing image and coding parameters (e.g. type of compression, quantization and coding tables, image size, etc.) is embedded in the bit 5 stream produced by the entropy encoder. As the JPEG standard comprises four alternative coding modes and places few constraints on the quantization and coding tables that can be used, this is necessary in order to enable JPEG compressed bit-streams to be interchanged among different platforms and for images to be reconstructed without any ambiguity. A digital video sequence, like an ordinary motion picture recorded on film, 10 comprises a sequence of still images (often referred to as 'frames'), the illusion of motion being created by displaying the frames one after the other at a relatively fast rate, typically 15 to 30 frames per second. As in any still image, the pixel values of an individual frame within a digital video sequence exhibit considerable spatial redundancy. Therefore, the frames of a digital video sequence are amenable to block-based transform 15 coding, just like individual still images. Images in the consecutive frames of a video sequence also tend to be quite similar and thus the overall change between one video frame and the next is rather small. This means that there is considerable temporal redundancy within a typical digital video sequence. For example, a scene may comprise some stationary elements, such as 20 background scenery, and some moving areas, for example the face of a newsreader. In consecutive frames of the sequence, it is likely that the background will remain unaltered and the only movement in the scene will be due to changes in facial expression of the newsreader. Thus, when forming a compressed representation of a video sequence there is also a possibility to use techniques which reduce the temporal redundancy of the image 25 data of the sequence in addition to methods that reduce spatial redundancy, thereby allowing further data compression to be achieved. Hybrid Video Encoder/Decoder State of the art video coding systems make use of a technique known as 'motion 30 compensated prediction', to reduce the temporal redundancy in video sequences. Using motion-compensated prediction, the image content of some (often many) frames in a 4 digital video sequence is 'predicted' from one or more other frames in the sequence, known as 'reference frames'. Prediction of image content is achieved by tracing the motion of objects or regions of an image between a frame to be coded (compressed) and the reference frame(s) using 'motion vectors'. In general, the reference frame(s) may 5 precede the frame to be coded or may follow it in the video sequence. However, as will become apparent from discussions later in the text, it is not appropriate (or possible) to apply motion-compensated prediction to all frames of a video sequence and thus at least two types of encoding are used in state of the art video coding systems. Frames of a video sequence which are compressed using motion-compensated 10 prediction are generally referred to as INTER-coded or P-frames. Motion-compensated prediction alone rarely provides a sufficiently precise representation of the image content of a video frame and therefore it is typically necessary to provide a so-called 'prediction error' (PE) frame with each INTER-coded frame. As will be explained in greater detail later in the text, the prediction error frame represents the difference between a decoded 15 version of the INTER-coded frame and the image content of the frame to be coded. More specifically, the prediction error frame comprises values that represent the difference between pixel values in the frame to be coded and corresponding reconstructed pixel values formed on the basis of a predicted (INTER-coded) version of the frame in question. Consequently, the prediction error frame has characteristics similar to a still 20 image and block-based transform coding can be applied in order to reduce the amount of data (number of bits) required to represent it. Frames of a video sequence which are not compressed using motion-compensated prediction are referred to as INTRA-coded or I-frames. Generally, INTRA-coded frames are produced by applying block-based transform coding directly to the pixel values of the 25 frame to be coded. Additionally, where possible, blocks of INTRA-coded frames are predicted from previously coded blocks within the same frame. This technique, known as INTRA-prediction, has the effect of further reducing the amount of data required to represent an INTRA-coded frame. In order to illustrate principles of block-based transform coding and motion 30 compensated prediction in greater detail, reference will now be made to Figure 1, which is a schematic of a generic hybrid video encoder that employs a combination of INTRA 5 and INTER-coding to produce a compressed (encoded) video bit-stream. A corresponding decoder is illustrated in Figure 2 and will be described later in the text. The video encoder 300 comprises an input 301 for receiving a digital video signal from a camera or other video source (not shown). It also comprises a transformation unit 5 304 which is arranged to perform a block-based discrete cosine transform (DCT), a quantizer 306, an inverse quantizer 308, an inverse transformation unit 310, arranged to perform an inverse block-based discrete cosine transform (IDCT), combiners 312 and 316, and a frame store 320. The encoder further comprises a motion estimator 330, a motion field coder 340 and a motion compensated predictor 350. Switches 302 and 314 10 are operated co-operatively by control manager 360 to switch the encoder between an INTRA-mode of video encoding and an INTER-mode of video encoding. The encoder 300 also comprises a video multiplex coder 370 which forms a single bit-stream 335 from the various types of information produced by the encoder 300 for further transmission to a remote receiving terminal or, for example, for storage on a mass storage medium, such as 15 a computer hard drive (not shown). Encoder 300 operates as follows. Each frame of uncompressed video provided from the video source to input 301 is received and processed macroblock-by-macroblock, preferably in raster-scan order. When the encoding of a new video sequence starts, the first frame of the sequence is encoded as an INTRA-coded frame. Subsequently, the 20 encoder is programmed to code each frame in INTER-coded format, unless one of the following conditions is met: 1) it is judged that the current frame being coded is so dissimilar from the reference frame used in its prediction that excessive prediction error information is produced; 2) a predefined INTRA frame repetition interval has expired; or 3) feedback is received from a receiving terminal indicating a request for a frame to be 25 provided in INTRA-coded format. The occurrence of condition 1) is detected by monitoring the output of the combiner 316. The combiner 316 forms a difference between the current macroblock of the frame being coded and its prediction, produced in the motion compensated prediction block 350. If a measure of this difference (for example a sum of absolute differences of 30 pixel values) exceeds a predetermined threshold, the combiner 316 informs the control manager 360 via a control line 319 and the control manager 360 operates the switches 6 302 and 314 via control line 313 so as to switch the encoder 300 into INTRA-coding mode. Occurrence of condition 2) is monitored by means of a timer or frame counter implemented in the control manager 360, in such a way that if the timer expires, or the frame counter reaches a predetermined number of frames, the control manager 360 5 operates the switches 302 and 314 via control line 313 to switch the encoder into INTRA coding mode. Condition 3) is triggered if the control manager 360 receives a feedback signal from, for example, a receiving terminal, via control line 321 indicating that an INTRA frame refresh is required by the receiving terminal. Such a condition may arise, for example, if a previously transmitted frame is badly corrupted by interference during 10 its transmission, rendering it impossible to decode at the receiver. In this situation, the receiving decoder issues a request for the next frame to be encoded in INTRA-coded format, thus re-initialising the coding sequence. Operation of the encoder 300 in INTRA-coding mode will now be described. In INTRA-coding mode, the control manager 360 operates the switch 302 to accept video 15 input from input line 318. The video signal input is received macroblock by macroblock from input 301 via the input line 318. As they are received, the blocks of luminance and chrominance values which make up the macroblock are passed to the DCT transformation block 304, which performs a 2-dimensional discrete cosine transform on each block of values, producing a 2-dimensional array of DCT coefficients for each block. In a situation 20 such as that described earlier, where each macroblock comprises four 8x8 pixel blocks of luminance values and two spatially corresponding 8x8 pixel blocks of chrominance values, DCT transformation block 304 produces an 8x8 array of coefficient values for each block. The DCT coefficients for each block are passed to the quantizer 306, where they 25 are quantized using a quantization parameter QP. Selection of the quantization paramet-er QP is controlled by the control manager 360 via control line 315. Quantization introduces a loss of information, as the quantized coefficients have a lower numerical precision than the coefficients originally generated by the DCT transformation block 304. This provides a further mechanism by which the amount of data required to represent each image of the 30 video sequence can be reduced. However, unlike the DCT transformation, which is essentially lossless, the loss of information introduced by quantization causes an 7 irreversible degradation in image quality. The greater the degree of quantization applied to the DCT coefficients, the greater the loss of image quality. The quantized DCT coefficients for each block are passed from the quantizer 306 to the video multiplex coder 370, as indicated by line 325 in Figure 1. The video 5 multiplex coder 370 orders the transform coefficients for each block using a zigzag scanning procedure. This operation converts the two-dimensional array of quantized transform coefficients into a one-dimensional array. Typical zigzag scanning orders, such as that shown in Figure 3, order the coefficients approximately in ascending order of spatial frequency. This also tends to order the coefficients according to their values, such 10 that coefficients positioned earlier in the one-dimensional array are more likely to have larger absolute values than coefficients positioned later in the array. This is because lower spatial frequencies tend to have higher amplitudes within the image blocks. Consequently, the last values in the one-dimensional array of quantized transform coefficients are commonly zeros. 15 Run-Level Coding of DCT Transform Coefficients Typically, the video multiplex coder 370 represents each non-zero quantized coefficient in the one dimensional array by two values, referred to as level and run. Level is the value of the quantized coefficient and run is the number of consecutive zero-valued 20 coefficients preceding the coefficient in question. The run and level values for a given coefficient are ordered such that the level value precedes the associated run value. A level value equal to zero is used to indicate that there are no more non-zero coefficient values in the block. This 0-level value is referred to as an EOB (end-of-block) symbol. 25 Entropy Coding The run and level values are further compressed in the video multiplex coder 370 using entropy coding. Entropy coding is a lossless operation, which exploits the fact that symbols within a data set to be coded generally have different probabilities of occurrence. Therefore, instead of using a fixed number of bits to represent each symbol, a variable 30 number of bits is assigned such that symbols which are more likely to occur are represented by code-words having fewer bits. For this reason, entropy coding is often 8 referred to as Variable Length Coding (VLC). Since certain values of levels and runs are more likely than other values to occur, entropy coding techniques can be used effectively to reduce the number of bits required to represent the run and level values. A number of different methods can be used to implement entropy coding. For example, entropy coding 5 of the run and level parameters may be implemented by means of look-up tables which define the mapping between each possible symbol in the data set to be coded and its corresponding variable length code. Such look-up tables are often defined by statistical analysis of training material comprising symbols identical to those to be coded and having similar statistical properties. An alternative technique, known as arithmetic 10 coding, can also be used to convert the run and level values into variable length code words. In arithmetic coding a group of symbols, for example the run and level values for a block of quantized transform coefficients, are coded as a floating point decimal number. Once the run and level values have been entropy coded using an appropriate method, the video multiplex coder further combines them with control information, also 15 entropy coded using a variable length coding method appropriate for the kind of information in question, to form a single compressed bit-stream of coded image information 335. A locally decoded version of the macroblock is also formed in the encoder 300. This is done by passing the quantized transform coefficients for each block, output by 20 quantizer 306, through inverse quantizer 308 and applying an inverse DCT transform in inverse transformation block 310. In this way a reconstructed array of pixel values is constructed for each block of the macroblock. The resulting decoded image data is input to combiner 312. In INTRA-coding mode, switch 314 is set so that the input to the combiner 312 via switch 314 is zero. In this way, the operation performed by combiner 25 312 is equivalent to passing the decoded image data unaltered. As subsequent macroblocks of the current frame are received and undergo the previously described encoding and decoding steps in blocks 304, 306, 308, 310 and 312, a decoded version of the INTRA-coded frame is built up in frame store 320. When the last macroblock of the current frame has been INTRA-coded and subsequently decoded, the 30 frame store 320 contains a completely decoded frame, available for use as a prediction reference frame in coding a subsequently received video frame in INTER-coded format. 9 Operation of the encoder 300 in INTER-coding mode will now be described. In INTER-coding mode, the control manager 360 operates switch 302 to receive its input from line 317, which comprises the output of combiner 316. The combiner 316 receives the video input signal macroblock by macroblock from input 301. As combiner 316 5 receives the blocks of luminance and chrominance values which make up the macroblock, it forms corresponding blocks of prediction error information. The prediction error information represents the difference between the block in question and its prediction, produced in the motion compensated prediction block 350. More specifically, the prediction error information for each block of the macroblock comprises a two 10 dimensional array of values, each of which represents the difference between a pixel value in the block of luminance or chrominance information being coded and a decoded pixel value obtained by forming a motion-compensated prediction for the block, according to the procedure described below. Thus, in a situation where each macroblock comprises four 8x8 pixel blocks of luminance values and two spatially corresponding 8x8 15 pixel blocks of chrominance values, the prediction error information for the macroblock similarly comprises four 8x8 blocks of luminance prediction error values and two spatially corresponding 8x8 blocks of chrominance prediction error values. The prediction error information for each block of the macroblock is passed to DCT transformation block 304, which performs a two-dimensional discrete cosine 20 transform on each block of prediction error values to produce a two-dimensional array of DCT transform coefficients for each block. Thus, in a situation where the prediction error information for each macroblock comprises four 8x8 blocks of luminance prediction error values and two spatially corresponding 8x8 blocks of chrominance prediction error values, DCT transformation block 304 produces an 8x8 array of transform coefficient 25 values for each prediction error block. The transform coefficients for each prediction error block are passed to quantizer 306 where they are quantized using a quantization parameter QP, in a manner analogous to that described above in connection with operation of the encoder in INTRA-coding mode. Again, selection of the quantization parameter QP is controlled by the control manager 360 via control line 315. 30 The quantized DCT coefficients representing the prediction error information for each block of the macroblock are passed from quantizer 306 to video multiplex coder 10 370, as indicated by line 325 in Figure 1. As in INTRA-coding mode, the video multiplex coder 370 orders the transform coefficients for each prediction error block using the previously described zigzag scanning procedure (see Figure 3) and then represents each non-zero quantized coefficient as a level and a run value. It further compresses the run 5 and level values using entropy coding, in a manner analogous to that described above in connection with INTRA-coding mode. Video multiplex coder 370 also receives motion vector information (described in the following) from motion field coding block 340 via line 326 and control information from control manager 360. It entropy codes the motion vector information and forms a single bit-stream of coded image information 335 10 comprising the entropy coded motion vector, prediction error and control information. The quantized DCT coefficients representing the prediction error information for each block of the macroblock are also passed from quantizer 306 to inverse quantizer 308. Here they are inverse quantized and the resulting blocks of inverse quantized DCT coefficients are applied to inverse DCT transform block 310, where they undergo inverse 15 DCT transformation to produce locally decoded blocks of prediction error values. The locally decoded blocks of prediction error values are then input to combiner 312. In INTER-coding mode, switch 314 is set so that the combiner 312 also receives predicted pixel values for each block of the macroblock, generated by motion-compensated prediction block 350. The combiner 312 combines each of the locally decoded blocks of 20 prediction error values with a corresponding block of predicted pixel values to produce reconstructed image blocks and stores them in frame store 320. As subsequent macroblocks of the video signal are received from the video source and undergo the previously described encoding and decoding steps in blocks 304, 306, 308, 310, 312, a decoded version of the INTER-coded frame is built up in frame store 25 320. When the last macroblock of the frame has been INTER-coded and subsequently decoded, the frame store 320 contains a completely decoded frame, available for use as a prediction reference frame in encoding a subsequently received video frame in INTER coded format. Formation of a prediction for a macroblock of the current frame will now be 30 described. Any frame encoded in INTER-coded format requires a reference frame for motion-compensated prediction. This means, necessarily, that when encoding a video 11 sequence, the first frame to be encoded, whether it is the first frame in the sequence, or some other frame, must be encoded in INTRA-coded format. This, in turn, means that when the video encoder 300 is switched into INTER-coding mode by control manager 360, a complete reference frame, formed by locally decoding a previously encoded frame, 5 is already available in the frame store 320 of the encoder. In general, the reference frame is formed by locally decoding either an INTRA-coded frame or an INTER-coded frame. The first step in forming a prediction for a macroblock of the current frame is performed by motion estimation block 330. The motion estimation block 330 receives the blocks of luminance and chrominance values which make up the current macrobiock of 10 the frame to be coded via line 328. It then performs a block matching operation in order to identify a region in the reference frame, which corresponds substantially with the current macroblock. In order to perform the block matching operation, motion field estimation block accesses reference frame data stored in frame store 320 via line 327. More specifically, motion estimation block 330 performs block-matching by calculating 15 difference values (e.g. sums of absolute differences) representing the difference in pixel values between the macroblock under examination and candidate best-matching regions of pixels from a. reference frame stored in the frame store 320. A difference value is produced for candidate regions at all possible offsets within a predefined search region of the reference frame and motion estimation block 330 determines the smallest calculated 20 difference value. The offset between the macroblock in the current frame and the candidate block of pixel values in the reference frame that yields the smallest difference value defines the motion vector for the macroblock in question. -Once the motion estimation block 330 has produced a motion vector for the macroblock, it outputs the motion vector to the motion field coding block 340. The 25 motion field coding block 340 approximates the motion vector received from motion estimation block 330 using a motion model comprising a set of basis functions and motion coefficients. More specifically, the motion field coding block 340 represents the motion vector as a set of motion coefficient values which, when multiplied by the basis functions, form an approximation of the motion vector. Typically, a translational motion 30 model having only two motion coefficients and basis functions is used. 12 The motion coefficients are passed from motion field coding block 340 to motion compensated prediction block 350. Motion compensated prediction block 350 also receives the best-matching candidate region of pixel values identified by motion estimation block 330 from frame store 320. Using the approximate representation of the 5 motion vector generated by motion field coding block 340 and the pixel values of the best-matching candidate region of pixels from the reference frame, motion compensated prediction block 350 generates an array of predicted pixel values for each block of the macroblock. Each block of predicted pixel values is passed to combiner 316 where the predicted pixel values are subtracted from the actual (input) pixel values in the 10 corresponding block of the current macroblock. In this way a set of prediction error blocks for the macroblock is obtained. Operation of the video decoder 400, shown in Figure 2 will now be described. The decoder 400 comprises a video multiplex decoder 470, which receives an encoded video bit-stream 335 from the encoder 300 and demultiplexes it into its constituent parts, an 15 inverse quantizer 410, an inverse DCT transformer 420, a motion compensated prediction block 440, a frame store 450, a combined 430, a control manager 460, and an output 480. The control manager 460 controls the operation of the decoder 400 in response to whether an INTRA- or an INTER-coded frame is being decoded. An INTRA / INTER trigger control signal, which causes the decoder to switch between decoding modes is 20 derived, for example, from picture type information provided in a header portion of each compressed video frame received from the encoder. The INTRA / INTER trigger control signal is extracted from the encoded video bit-stream by the video multiplex decoder 470 and is passed to control manager 460 via control line 422. Decoding of an INTRA-coded frame is performed on a macroblock-by 25 -macroblock basis, each macroblock being decoded substantially as soon as encoded information relating to it is identified in the received video bit-stream 335. The video multiplex decoder 470 first separates the encoded information for the blocks of the macroblock from possible control information relating to the macroblock in question. The encoded information for each block of an INTRA-coded macroblock comprises variable 30 length code-words. These code-words represent the entropy coded level and run values for the non-zero quantized DCT coefficients of the block. The video multiplex decoder l'jt 410 decodes the variable length code-words using a variable length decoding method corresponding to the encoding method used in the encoder 300 and thereby recovers the level and run values. It then reconstructs the array of quantized transform coefficient values for each block of the macroblock and passes them to inverse quantizer 410. Any 5 control information relating to the macroblock is also decoded in the video multiplex decoder using an appropriate variable length decoding method and is passed to control manager 460. In particular, information relating to the level of quantization applied to the transfonn coefficients is extracted from the encoded bit-stream by video multiplex decoder 470 and is provided to control manager 460 via control line 424. The control 10 manager, in turn, conveys this information to inverse quantizer 420 via control line 415. Inverse quantizer 410 inverse quantizes the quantized DCT coefficients for each block of the macroblock according to the control information and provides the now inverse quantized DCT coefficients inverse DCT transformer 420. Inverse DCT transformer 420 performs an inverse DCT transform on the inverse 15 quantized DCT coefficients for each block of the macroblock to form a decoded block of image information comprising reconstructed pixel values. As motion-compensated prediction is not used in the encoding/decoding of INTRA-coded macroblocks, control manager 460 controls combiner 430 in such a way as to prevent any reference information being used in the decoding of the INTRA-coded macroblock. The 20 reconstructed pixel values for each block of the macroblock are passed to the video output 480 of the decoder where, for example, they can be provided to a display device (not shown). The reconstructed pixel values for each block of the macroblock are also stored in frame store 450. As subsequent macroblocks of the INTRA-coded frame are decoded and stored, a decoded frame is progressively assembled in the frame store 450 and thus 25 becomes available for use as a reference frame for motion compensated prediction in connection with the decoding of subsequently received INTER-coded frames. INTER-coded frames are also decoded macroblock by macroblock, each INTER coded macroblock being decoded substantially as soon as encoded information relating to it is identified in the received bit-stream. The video multiplex decoder 470 separates the 30 encoded prediction error information for each block of the INTER-coded macroblock from encoded motion vector information and possible control information relating to the 1 A macroblock in question. As explained in the foregoing, the encoded prediction error information for each block of the macroblock comprises variable length codewords which represent the entropy coded level and run values for the non-zero quantized transform coefficients for the prediction error block in question. The video multiplex decoder 470 5 decodes the variable length code-words using a variable length decoding method corresponding to the encoding method used in the encoder 300 and thereby recovers the level and run values. It then reconstructs an array of quantized transform coefficient values for each prediction error block and passes them to inverse quantizer 410. Control information relating to the INTER-coded macroblock is also decoded in the video 10 multiplex decoder using an appropriate variable length decoding method and is passed to control manager 460. Information relating to the level of quantization applied to the transform coefficients of the prediction error blocks is extracted from the encoded bit stream and provided to control manager 460 via control line 424. The control manager, in turn, conveys this information to inverse quantizer 420 via control line 415. Inverse 15 quantizer 410 inverse quantizes the quantized DCT coefficients representing the prediction error information for each block of the macroblock according to the control information and provides the now inverse quantized DCT coefficients to inverse DCT transformer 420. The inverse quantized DCT coefficients representing the prediction error information for each block are then inverse transformed in the inverse DCT transformer 20 420 to yield an array of reconstructed prediction error values for each block of the macroblock. The encoded motion vector information associated with the macroblock is extracted from the encoded video bit-stream 335 by video multiplex decoder 470 and is decoded using an appropriate variable length decoding method. The decoded motion 25 vector information thus obtained is passed via data line 426 to motion compensated prediction block 440, which reconstructs a motion vector for the macroblock using the same motion model as that used to encode the INTER-coded macroblock in encoder 300. The reconstructed motion vector approximates the motion vector originally detennined by motion estimation block 330 of the encoder. The motion compensated prediction block 30 440 of the decoder uses the reconstructed motion vector to identify the location of a region of reconstructed pixels in a prediction reference frame stored in frame store 450.
The reference frame may be, for example, a previously decoded IiNTRA-coded frame, or a previously decoded INTER-coded frame. In either case, the region of pixels indicated by the reconstructed motion vector is used to form a prediction for the macroblock in question. More specifically, the motion compensated prediction block 440 forms an array 5 of pixel values for each block of the macroblock by copying corresponding pixel values from the region of pixels identified in the reference frame. The prediction, that is the blocks of pixel values derived from the reference frame, are passed from motion compensated prediction block 440 to combiner 430 where they are combined with the decoded prediction error information. In practice, the pixel values of each predicted block 10 are added to corresponding reconstructed prediction error values output by inverse DCT transformer 420. In this way an array of reconstructed pixel values for each block of the macroblock is obtained. The reconstructed pixel values are passed to the video output 480 of the decoder and are also stored in frame store 450. As subsequent macroblocks of the INTER-coded frame are decoded and stored, a decoded frame is progressively assembled 15 in the frame store 450 and thus becomes available for use as a reference frame for motion-compensated prediction of other INTER-coded frames. H.26L Video Coding Standard ITU-T recommendation H.26L is the latest in a family of video coding standards 20 developed by the International Telecommunications Union. It is intended in particular for video coding at very low bit rates, typically below 64kbits/s, which makes it especially suitable for the coding of digital video for transmission via radio communication networks or any fixed line communication network in which optimal use of available bandwidth is a priority. The video encoding system defined by ITU-T H.26L is a hybrid 25 video coding system, which operates according to the general principles described above in connection with the generic video encoder 300 and decoder 400 illustrated in Figures 1 and 2. In particular, a video encoding system implemented according to H.26L employs a combination of block-based transform coding and motion-compensated prediction to reduce the spatial and temporal redundancy within video sequences. 30 The latest version of the H.26L recommendation, known as Test Model 8 (TML8) and described in "H.26L Test Model Long Term Number 8 (TML-8) draftO" (ITU-T Telecommunications Standardization Section, Study Group 16, Video Coding Experts Group), specifies two alternative entropy coding modes. In the first (default) mode a so called Universal Variable Length Coding (UVLC) method is used to encode all syntax elements. The UVLC coding mode is a look-up table method in which the same set of 5 variable length code-words is used to represent all the different kinds of information produced by the video encoder, regardless of the type of information in question. The alternative entropy coding method, specified for use in the so-called 'high complexity profile' of H.26L, is a technique known as Context-based Adaptive Binary Arithmetic Coding (CABAC). This is a form of binary arithmetic coding which continually adapts to 10 the statistical properties of the information being coded and is known in the art to be one of the most efficient forms of entropy coding (see H. Witten, R. M. Neal, and J. G. Cleary, "Arithmetic coding for data compression," Commur. A CM, vol. 30, pp. 520-540, June 1987). Because UVLC entropy coding uses the same set of variable length code-words to 15 represent all types of information produced by the video encoder, in general the statistical properties of the code-words do not match optimally with the characteristics of the information to be encoded. For example, the frequency of occurrence of particular run and level values used to represent the quantized DCT coefficients for an INTRA-coded image block is likely to be different from the occurrence of values in control information 20 relating to quantization parameter values. The CABAC entropy coding method was introduced into the H.26L recommendation in order to overcome the inherently sub optimal nature of the UVLC entropy coding method. As explained earlier in the text, arithmetic coding represents a group of symbols to be coded with a single variable length code (a floating-point number). This provides particular advantages compared with 25 entropy coding methods, which encode each symbol independently. Specifically, entropy coding methods which encode each symbol independently require at least one bit to represent each symbol. Because arithmetic coding represents groups of symbols with a single code-word, it is possible to achieve data compression rates of less than one bit per symbol. Thus the CABAC method provided in H.26L also provides the possibility of 30 improved data compression. Furthermore, because it is an adaptive method, it is also able to take into account changes in the statistical characteristics'of the information being coded, ensuring that data compression performance is maintained even if the nature of the data being encoded changes to some extent. Context-Based Arithmetic Coding 5 As explained above, CABAC arithmetic coding is an entropy coding method, which is able to adapt to changing statistics of the information to be encoded. In this way it is capable of providing improved compression efficiency compared with entropy coding techniques which assume fixed statistical properties. Figure 4 illustrates an exemplary context-based binary arithmetic encoder 700. CABAC is a binary arithmetic 10 coding method and thus data symbols to be coded which have non-binary values are first converted to binary values ('binarized') in binary mapping block 710. The binarization process involves mapping a symbol to be coded to a sequence of bins, each of which has a corresponding bin number and can be assigned a value of either 0 or 1. An example of such a mapping is given below in Table 1. In principle other binarization schemes can be 15 envisaged. value Bin Sequence 0 1 0 1 2 0 0 1 3 0 0 0 1 4 010 0 0 1 5 0--~OTTT 6 0 0 0 0 0 0 1 binnr. 1 2 3 4 5 6 7 Table 1 20 In the CABAC method each of the bins is assigned to a so-called 'context' (hence the name context-based arithmetic coding). A context can be thought of as grouping together bins, which have similar statistical characteristics. In other words, each bin assigned to a particular context is assumed to have a similar probability of containing the value 1 or0 as the other bins belonging to that context. In this way, the probability 1 Q estimates used to generate code-words in the arithmetic coder are defined for each context rather than for each possible bin to be encoded. Each context is defined according to a 'context model', established in advance and based on information about the statistical characteristics of the data symbols (and thus the bins) to be encoded. Generally, the data 5 compression ratio achieved by a binary arithmetic encoder is enhanced if the difference between the probability of occurrence of a 0 and probability of occurrence of a I is maximised. In a similar way, the performance of a context-based arithmetic coding also depends on the choice of context model. This means that, in general, context models should be chosen so as to maximise the difference between the probability of occurrence 10 of 0's and 1's for the bins assigned to each context. In the exemplary context-based arithmetic coder illustrated in Figure 4, once a symbol to be coded has been binarized in binary mapping block 710 it is assigned to a corresponding context in context assignment block 720. The value assigned to the corresponding bin (i.e., I or 0) is then passed to the arithmetic coder 730. The coding 15 engine 750 of arithmetic coder 730 then encodes the bin value using a probability estimate for the context to which the bin is assigned. The performance, that is the data compression ratio achieved by the arithmetic encoder, depends on the accuracy of the probability estimates. In principle, the estimates may be fixed or adaptive. If fixed probability estimates are used, the probability estimates for each context are assigned to 20 predefined values and remain unchanged during the encoding process. Fixed probability estimates are typically obtained in advance by analysing training material having statistical properties similar to those of the actual data to be encoded. If adaptive probability estimates are used, fixed values are used to initialise the probability estimates for each context and the probabilities are then updated throughout the encoding process 25 based on the actual statistical properties of the data (bins) encoded so far. Adaptive probability estimates generally perform better since they can adjust to the material being encoded. The exemplary context-based arithmetic coder illustrated in Figure 4 employs adaptive probability estimates and comprises a probability estimation block 740 where 30 updated probability estimates are calculated. The probability estimates for each context are updated by keeping a record of the number of occurrences of 1 and 0 for each of the bins assigned to each context. For example, if the bins assigned to an arbitrary context k have been assigned the value 0 m times and the value I n times, then the probability estimate for I in context k is n/(n(m+1)) and the probability estimate for 0 is (m+±I)/(n(m+ 1)). 5 Figure 5 illustrates a context-based arithmetic decoder 800 corresponding to the encoder described in connection with Figure 4. A bit-stream representing arithmetic coded data symbols is received by the context-based arithmetic decoder at input 810. Initially, based on the previously decoded symbols, a context is calculated in a context assignment block 850 and the probability estimates of the bin values are updated. 10 Context assignment, as carried out in the context assignment block 850, and calculation of probability estimates, as carried out in the probability estimation block 830, are done in the same manner as the encoder. The received bits are then fed into an arithmetic decoding engine 840 of the arithmetic decoder 820, where they are converted to decoded bin values, using the calculated context and the current probability estimates of the bin 15 values. Decoded bins are mapped to the values of the runs and levels in a bin-to-value mapping block 860. CABAC Method as Used in H.26L The details of the CABAC arithmetic coding method adopted for use in the high 20 complexity profile of ITU-T recommendation H.26L will now be described in detail. According to H.26L TML8, the contexts for run and level values depend on the type of block being encoded and the bin number of the binarized level or run value. Different block types are defined according to the scanning mode (single/double) used to order the coefficient values, the component type (luminance/chrominance, AC/DC), or the coding 25 mode (INTER/INTRA). However, for a given block type, the context depends only on the bin number. More specifically, according to H.26L TML8 four contexts are defined for level encoding. The first one is for the first bin, the second is for the second bin, while the third context is for the rest of the bins representing the magnitude of the level. The remaining context is used for the sign of the level. A similar approach is used to assign 30 run values to contexts. For runs there are three contexts, the first one for the first bin, the second for the second bin and the third for all remaining bins. As run values are always ?n equal to or greater than zero, there is no need for an additional context to represent sign information. Thus, for a block of a given type, the assignment of bins to contexts for transform coefficient bins (for both level and run encoding) can be summarised as follows: 5 if (bin nr > MAX BIN_VAL) binnr = MAXBIN_ VAL; (1) end context = bin nr 10 where bin nr is the bin number and context is the context number. According to H.26L TML8, the value of MAXBIN_ VAL is set equal to 3, but in principle another MAX_BIN VAL could be used instead. A run-level pair is encoded as follows: The runs and levels are first classified 15 according to block / coefficient type: scanning mode, coefficient type (DC/AC), and coding mode (INTERILNTRA or 16x16 INTRA). The levels and runs are then binarized by mapping them onto a sequence of bins and each bin is assigned to a context based on its bin number. Figures 6a-6d illustrate this process in detail with reference to an exemplary 4x4 20 array of quantized DCT coefficients. It also demonstrates the adaptive nature of the CABAC method, by illustrating the way in which the statistical properties of run and level values for quantized DCT coefficients are tracked. The two-dimensional array of quantized DCT coefficient values is first zigzag scanned to produce a one-dimensional array of values, as indicated in Figure 6a. The non-zero coefficient values in the one 25 dimensional array are then represented as pairs of run and level values. As previously explained, each level value represents the value of a non-zero quantized DCT coefficient, while the associated run value corresponds to the number of zero-valued coefficients preceding the coefficient in question. The run- level pairs derived from the exemplary array of quantized DCT coefficients are presented in Figure 6b. In each pair the level 30 value precedes the associated run value and a level value equal to zero is used as an endof-block symbol to indicate that there are no more non-zero coefficient values in the block. Next, each run and level value is converted into a binary value. According to H.26L TML8, the binarization scheme used to convert the run and level values for 5 quantized DCT transform coefficient values is identical to that shown above in Table 1. Figure 6c shows the result of applying the binarization scheme presented in Table I to the run and level values in the exemplary array. Figure 6c also shows the assignment of bins to contexts according to H.26L. As described above, only three contexts are used to describe the magnitudes of the run and level values. The first context corresponds to bin 10 1, the second to bin 2, while the third context comprises all the remaining bins. In Figure 6c, the contexts are delineated by bold horizontal lines. By examining Figure 6c it can be seen that the majority of level values are mapped to bins which are assigned to context 3, while the majority of run values are mapped to bins which are assigned to context 1. The probability estimates for each assigned context are updated after the encoding 15 of the bins. Probability estimates for the run and level contexts are updated independently. As previously described, the probability estimate for a given context represents the statistical characteristics of the bins assigned to the context in question. More specifically, the probability estimate describes the likelihood of a bin assigned to the context containing a I or a 0. Figure 6d describes, in an exemplary manner, the way in 20 which the probability estimates are updated for runs and levels. The figure illustrates the probability of a bin assigned to a given run or level context containing a 1 or a 0 before and after the runs and levels representing the 4x4 block of quantized DCT coefficients shown in Figure 6a are binarized and assigned to contexts and encoded in the arithmetic encoder. Figure 6d takes the form of a table, which records the occurrence of l's and O's 25 in the bins assigned to each context. Thus, the probability estimate for a given context is given by: probability of 0 = no. of O's / (no. of O's + no. of l's) probability of I = no. of l's / (no. of 0's + no. of l's) 30 In the figure it is assumed that the 4x4 block of quantized DCT coefficients shown in Figure 6a is the first such block to be processed. This means that there are no previous occurrences of l's and O's to record in the table. To overcome this problem it is assumed that before the block is processed, each context has an equal probability of containing a I 5 or a 0. This is indicated by entering identical values in the columns that record the occurrence of O's and l's. In Figure 6d, I's are used to initialize the probability estimate. Alternatively, a probability estimate derived from analysis of training data could be used to intialize the probability estimates for each context. The probability estimates are then updated by counting the number of I's and O's which occur in the bins of each context as 10 the run and level values for the block of quantized DCT transform coefficients are binarized and assigned to contexts. The right-hand column of Figure 6d shows the situation after processing the 4x4 block of quantized DCT shown in Figure 6a. Although the CABAC arithmetic encoding method adopted in the high complexity profile of ITU-T recommendation H.26L TML8 provides an improvement in data 15 compression compared with the UVLC entropy coding method, it is still not optimal with regard to coding efficiency. It is therefore an object of the invention to provide a method and system for context-based arithmetic coding, wherein coding efficiency is further improved. 20 SUMMARY OF THE INVENTION The present invention is based on the realization that when coding a given data symbol using context-based arithmetic coding, an improvement in coding efficiency can be achieved by using context models which take into account the contexts to which other data symbols are assigned. With specific reference to the CABAC method used in the 25 high complexity profile of H.26L TML8, the inventors of the present invention have determined that certain relationships exist between the run and level values associated with DCT transform coefficients. They have further determined that these relationships can be used to construct improved context models which enable the CABAC method to operate with improved coding efficiency when applied to the run and level values. In 30 particular, the inventors have determined that consecutive level values exhibit a significant similarity. More specifically, within a given block of transform coefficients, the level of a coefficient to be encoded has, in general, a magnitude substantially similar to the level of the previously encoded coefficient. The inventors have also determined an inverse relationship between the level and run values. In particular, larger level values are more likely to be preceded by smaller run values. The converse is also true, namely 5 smaller level values are likely to be preceded by larger runs. Consequently, the present invention proposes the creation of new context models for the coding of DCT transform coefficients, which take into account these relationships between level and run values. In a first such context model, intended for implementation in a context-based arithmetic encoder, the context assigned to the bins of a binarized coefficient level value 10 depends on the previously encoded coefficient level. In a second such context model, intended for implementation in a context-based arithmetic decoder, the context assigned to the bins of a binarized coefficient level value depends on the previously decoded coefficient level. In a third context model, implemented in either a context-based arithmetic encoder or a context-based arithmetic decoder, the context assigned to the bins 15 of a binarized coefficient run value depends on the coefficient's level value. The inventors have also determined that certain similarities exist between the transfonn coefficient values associated with different image blocks. These similarities are greater between image blocks which reside close to each other and tend to be strongest between immediately neighbouring image blocks. More specifically, the 20 number Ne of non-zero transform coefficient values representing a particular image block tends to be similar to the number of non-zero transform coefficient values in an image block close to, or neighbouring, the image block in question. Thus, the present invention further introduces the concept of providing an indication of the number of non-zero transform coefficients for a transform coded image block and encoding this value using 25 entropy coding. Furthermore, if context-based arithmetic coding is used to encode the Nc value, the inventors have determined that it is advantageous to assign the Nc value of a block to a context by taking into account the context assigned to the Ne value for at least one other transform coded image block. In this way the similarity between Ne values between image blocks which reside close to each other can be taken advantage of in the 30 context-based arithmetic coding procedure. According to ITU-T recommendation H.26L TML8, the number of non-zero transform coefficients in an image block is not encoded.
Instead, and as previously explained, an end-of-block (EOB) indication is provided. The EOB indication signals that the last run-level pair corresponding to a non-zero coefficient has been encoded. The inventors have determined that the proposed method, in which an explicit indication of the number of non-zero coefficients in a block is provided and S coded using context-based arithmetic coding leads to an increase in the coding efficiency compared with the method of providing an EOB indication as currently employed in H.26L TML8. Although the motivation behind the present invention and its basic concepts have been presented in the context of video encoding/decoding and more specifically with 10 respect to H.26L TML8, it should be appreciated that invention may be applied in other video coding systems and also to still image coding. In principle the invention can be applied in any image coding system in which block-based transform coding and context based arithmetic coding are used. According to a first aspect of the present invention, there is provided a method of 15 image coding in which an image is divided into a plurality of blocks having a plurality of pixels, each pixel having a pixel value, and a transform coding operation is performed on a block of pixel values to produce a corresponding block of transform coefficient values. The block of transform coefficient values is scanned in a given scanning order to produce a scanned array of coefficient values, and the coefficient values in the scanned array are 20 represented by a plurality of number pairs, the number pairs having a first number and a second number. The first number and the second number are assigned to one of a plurality of contexts representative of the number pairs. According to the first aspect of the invention, the first value of a number pair is assigned to a context based on a first number of another number pair. 25 Preferably, the step of assigning the first number of a number pair to a context based on the first number of another number pair takes into account the context to which the first number of the other number pair is assigned. Advantageously, the first number of a number pair is indicative of a non-zero coefficient value. Preferably, the first number of a number pair is equal to the magnitude 30 of a non-zero coefficient value.
Advantageously, the second number of a number pair is indicative of a number of consecutive zero coefficient values preceding a non-zero coefficient value. Preferably, the contexts are contexts of a context-based arithmetic coder. More preferably, the contexts are contexts of a context-based binary arithmetic 5 coder. Advantageously, the first and second numbers are mapped to a set of bins, each of the bins having an associated bin number and each capable of taking one of either a first value or a second value. Preferably, each of the first and second numbers is mapped to one of the set of 10 bins, mapping of a number to a given one of the set of bins being indicated by assigning the value of the bin to the first value. Preferably, the first value is 1 and the second value is 0. Preferably, each of the set of bins is assigned to a context. Advantageously, the step of assigning the first number of a number pair to a 15 context based on the first number of another number pair, taking into account the context to which the first number in the other number pair is assigned, is implemented by examining the bin number of the bin to which the first number of the other number pair is mapped. Advantageously, the method further comprises maintaining a probability estimate 20 describing the statistical properties of each context. Preferably, for each context, the probability estimate is indicative of the statistical likelihood of a number having a predetermined value being assigned to the context. Preferably, for each context, the probability estimate is maintained by keeping a record of occurrences of the first value and the second value in the bins assigned to the 25 context in question. According to a second aspect of the present invention, there is provided a method of image coding in which an image is divided into a plurality of blocks having a plurality of pixels, each pixel having a pixel value, and a transform coding operation is performed on a block of pixel values to produce a corresponding block of transform coefficient 30 values. The block of transform coefficient values is scanned in a given scanning order to produce a scanned array of coefficient values, and the coefficient values in the scanned array are represented by a plurality of number pairs, the number pairs having a first number and a second number. The first number and the second number are assigned to one of a plurality of contexts representative of the number pairs. According to the second aspect of the invention, the second number of a number pair is assigned to a context based 5 on the first number of the number pair. Preferably, the step of assigning the second number of a number pair to a context based on the first number of the number pair takes into account the context to which the second number of the number pair is assigned. Advantageously, the first number of a number pair is indicative of a non-zero 10 coefficient value. Preferably, the first number of a number pair is equal to the magnitude of a non-zero coefficient value. Advantageously, the second number of a number pair is indicative of a number of consecutive zero coefficient values preceding a non-zero coefficient value. Preferably, the contexts are contexts of a context-based arithmetic coder. 15 More preferably, the contexts are contexts of a context-based binary arithmetic coder. Advantageously, the first and second numbers are mapped to a set of bins, each of the bins having an associated bin number and being capable of taking one of either a first value or a second value. 20 Preferably, each of the first and second numbers is mapped to one of the set of bins, mapping of a number to a given one of the set of bins being indicated by assigning the value of the bin to the first value. Preferably the first value is I and the second value is 0. Preferably each of the set of bins is assigned to a context. 25 Advantageously, the step of assigning the second number of a number pair to a context based on the first number of the number pair, taking into account the context to which the second number in the one of the number pairs is assigned, is implemented by examining the bin number of the bin to which the second number is mapped. Advantageously, the method further comprises maintaining a probability estimate 30 describing the statistical properties of each context.
Preferably, for each context, the probability estimate is indicative of the statistical likelihood of a number having a predetermined value being assigned to the context. Preferably, for each context, the probability estimate is maintained by keeping a record of occurrences of the first value and the second value in the bins assigned to the 5 context in question. Preferably, the methods, according to the first and the second aspect of the invention, are both applied to a block of transform coefficient values. According to a third aspect of the present invention there is provided an encoder comprising means for dividing an image into a plurality of blocks having a plurality of 10 pixels, each pixel having a pixel value and means for performing a transform coding operation on a block of pixels to produce a corresponding block of transform coefficient values. The encoder further comprises means for scanning the block of transform coefficient values in a given scanning order to-produce a scanned array of coefficient values, means for representing the coefficient values in the scanned array are represented 15 by a plurality of number pairs, the number pairs having a first number and a second number, and means for assigning the first and the second numbers to one of a plurality of contexts representative of the number pairs. According to the third aspect of the invention, the encoder comprises means for assigning the first number of a number pair to a context based on a first number of another number pair. 20 According to a fourth aspect of the present invention, there is provided an encoder comprising means for dividing an image into a plurality of blocks having a plurality of pixels, each pixel having a pixel value, and means for performing a transform coding operation on a block of pixels to produce a corresponding block of transform coefficient values. The encoder further comprises means for scanning a block of transform 25 coefficient values in a given scanning order to produce a scanned array of coefficient values means for representing the coefficient values in the scanned array by a plurality of number pairs, the number pairs having a first number and a second number, and means for assigning the first and the second numbers to one of a plurality of contexts representative of the number pairs. According to the fourth aspect of the invention, the 30 encoder comprises means for assigning the second number of a number pair to a context based on the first number of the number pair. 28 According to a fifth aspect of the present invention, there is provided a method of image coding in which an image is divided into a plurality of blocks having a plurality of pixels, each pixel having a pixel value, and a transform coding operation is performed on a block of pixels to produce a corresponding block of transform coefficient values. 5 According to the fifth aspect of the invention, the method comprises the step of providing a number indicative of a number of non-zero coefficient values in the block of transform coefficient values and assigning the number to a context representative of the number. Advantageously, the step of assigning the number indicative of the number of non-zero transform coefficient values in the block of transform coefficient values to a 10 context takes into account the context to which another such number indicative of the number of non-zero coefficient values in another block of transform coefficients is assigned. Advantageously, the block of transform values is scanned in a given scanning order to produce a scanned array of coefficient values and the coefficient values in the 15 scanned array are represented by a plurality of number pairs having a first number and a second number. Advantageously, the first number of a number pair is indicative of a non-zero coefficient value. Preferably, the first number of a number pair is equal to the magnitude of a non 20 zero coefficient value. More preferably, the first number of a number pair is equal to the magnitude of a non-zero coefficient value minus 1. Advantageously, the second number of a number pair is indicative of a number of consecutive zero coefficient values preceding a non-zero coefficient value. 25 Preferably, an end-of-block indication, indicative of the last non-zero coefficient value in the scanned array of coefficient values, is not provided. Preferably, the methods according to the first, second and fifth aspects of the invention are each applied to a blpck of transform coefficient values. According to a sixth aspect of the present invention there is provided an encoder 30 comprising means for dividing an image into a plurality of blocks having a plurality of pixels, each pixel having a pixel value, and means for performing a transform coding operation on a block of pixels to produce a corresponding block of transform coefficient values. The encoder comprises means for providing a number indicative of the number of non-zero coefficient values in the block of transform coefficient values and means for assigning the number to a context representative of the number. 5 Advantageously, the encoder further comprises means for assigning the number indicative of the number of non-zero transform coefficient values in the block of transform coefficient values, taking into account the context to which another such number indicative of the number of non-zero transform coefficient values in another block of transform coefficient is assigned. 10 According to a seventh aspect of the present invention there is provided a computer program comprising a code for dividing an image into a plurality of blocks having a plurality of pixels, each pixel having a pixel value, and a code for performing a transform coding operation on a block of pixel values to produce a corresponding block of transform coefficient values. The computer program further comprises a code for 15 scanning the block of transform coefficient values in a given scanning order to produce a scanned array of coefficient values, a code for representing the coefficient values in the scanned array by a plurality of number pairs, the number pairs having a first number and a second number, and a code for assigning the first and the second numbers to one of a plurality of contexts representative of the number pairs. According to the seventh aspect 20 of the invention, the computer program also comprises a code for assigning the first number in one of the number pairs to a context based on a first number of another number pair. Advantageously, the first number of a number pair is indicative of a non-zero coefficient value. 25 Preferably, the first number of a number pair is equal to the magnitude of a non zero coefficient value. Advantageously, the second number of a number pair is indicative of a number of consecutive zero coefficient values preceding a non-zero coefficient value. According to an eighth aspect of the present invention, there is provided a 30 computer program comprising a code for dividing an image into a plurality of blocks having a plurality of pixels, each pixel having a pixel value, and a code for performing a 30 transform coding operation on a block of pixel values to produce a corresponding block of transform coefficient values. The computer program further comprises a code for scanning the block of transform coefficient values in a given scanning order to produce a scanned array of coefficient values, a code for representing the coefficient values in the 5 scanned array by a plurality of number pairs, the number pairs having a first number and a second number, and a code for assigning the first and the second numbers to one of a plurality of contexts indicative of the number pairs. According to the eighth aspect of the invention, the computer program also comprises a code for assigning the second number of a number pair to a context based on the first number of the number pair. 10 Advantageously, the first number of a number pair is indicative of a non-zero coefficient value. Preferably, the first number of a number pair is equal to the magnitude of a non zero coefficient value. Advantageously, the second number of a number pair is indicative of a number of 15 consecutive zero coefficient values preceding a non-zero coefficient value. According to a ninth aspect of the present invention there is provided a computer program comprising a code for dividing an image into a plurality of blocks having a plurality of pixels, each pixel having a pixel value, and a code for performing a transform coding operation on a block of pixels to produce a corresponding block of transform 20 coefficient values. According to the ninth aspect of the invention, the computer program further comprises a code for providing a number indicative of the number of non-zero coefficient values in the block of transform coefficient values and a code for assigning the number to a context representative of the number. Advantageously, the computer program further comprises a code for assigning the 25 number indicative of the number of non-zero transform coefficient values in the block of transform coefficient values to a context, taking into account the context to which another such number indicative of the number of non-zero transform coefficient values in another block of transform coefficient is assigned. According to a tenth aspect of the invention, there is provided a computer program 30 according to the seventh, eighth and ninth aspects of the invention. '. 1 According to an eleventh aspect of the invention, there is provided a method of context-based arithmetic encoding in which an array of data symbols is represented with a code-word. The data symbols in said array are number pairs comprising a first number and a second number. The first number of a number pair is assigned to a context selected 5 from a plurality of contexts representative of the first numbers, and the second number of a number pair is assigned to a context selected from a plurality of contexts representative of the second numbers. According to the eleventh aspect of the invention, the first number of a number pair is assigned to a context based on a first number of another of said number pairs. 10 According to a twelfth aspect of the invention, there is provided a method of context-based arithmetic decoding in which an array of data symbols is decoded from a code-word representative of the array. The data symbols in said array are number pairs comprising a first number and a second number. The first number of a number pair is assigned to a context selected from a plurality of contexts representative of the first 15 numbers, and the second number of a number pair is assigned to a context selected from a plurality of contexts representative of the second numbers. According to the twelfth aspect of the invention, the first number of a number pair is assigned to a context based on a first number of another of said number pairs. According to a thirteenth aspect of the invention, there is provided a method of 20 context-based arithmetic encoding in which an array of data symbols is represented with a code-word. The data symbols in the array are number pairs comprising a first number and a second number. The first number of a number pair is assigned to a context selected from a plurality of contexts representative of the first numbers, and the second number of a number pair is assigned to a context selected from a plurality of contexts representative of 25 the second numbers. According to the thirteenth aspect of the invention, the second number of a number pair is assigned to a context based on the first number of the number pair. According to a fourteenth aspect of the invention, there is provided a method of context-based arithmetic decoding in which an array of data symbols is decoded from a 30 code-word representative of the array. The data symbols in the array are number pairs comprising a first number and a second number. The first number of a number pair is 329 assigned to a context selected from a plurality of contexts representative of the first numbers, and the second number of a number pair is assigned to a context selected from a plurality of contexts representative of the second numbers. According to the fourteenth aspect of the invention, the second number of a number pair is assigned to a context based 5 on the first number of the number pair. According to a fifteenth aspect of the invention, there is provided a method of context-based arithmetic encoding in which an array of data symbols is represented with a code-word, and a number indicative of a number of non-zero data symbols in the array is provided and assigned to a context representative of the number. 10 According to a sixteenth aspect of the invention, there is provided a context-based arithmetic encoder comprising means for representing an array of data symbols with a code-word. The data symbols in said array are number pairs comprising a first number and a second number, and the encoder further comprises means for assigning the first number of a number pair to a context selected from a plurality of contexts representative 15 of the first numbers and means for assigning the second number of a number pair to a context selected from a plurality of contexts representative of the second numbers. According to the sixteenth aspect of the invention, the encoder comprises means for assigning the first number of a number pair to a context based on a first number of another of said number pairs. 20 According to a seventeenth aspect of the invention, there is provided a context based arithmetic decoder comprising means for decoding an array of data symbols from a code-word representative of the array. The data symbols in the array are number pairs comprising a first number and a second number, and the decoder further comprises means for assigning the first number of a number pair to a context selected from a plurality of 25 contexts representative of the first numbers and means for assigning the second number of a number pair to a context selected from a plurality of contexts representative of the second numbers. According to the seventeenth aspect of the invention, the decoder comprises means for assigning the first number of a number pair to a context based on a first number of another of said number pairs. 30 According to an eighteenth aspect of the invention, there is provided a context based arithmetic encoder comprising means for representing an array of data symbols 34 with a code-word. The data symbols in said array are number pairs comprising a first number and a second number, and the encoder further comprises mans for assigning the first number of a number pair to a context selected from a plurality of contexts representative of the first numbers and means for assigning the second number of a number pair to a context selected from a plurality of contexts representative of the second numbers. According to the eighteenth aspect of the invention, the encoder comprises means for assigning the second number of a number pair to a context based on the first number of the number pair. According to a nineteenth aspect of the invention, there is provided a context-based arithmetic decoder comprising means for decoding an array of data symbols from a code word representative of the array. The data symbols in the array are number pairs comprising a first number and a second number, and the decoder further comprises means for assigning the first number of a number pair to a context selected from a plurality of contexts representative of the first numbers and means for assigning the second number of a number pair to a context selected from a plurality of contexts representative of the second numbers. According to the nineteenth aspect of the invention, the decoder comprises means for assigning the second number of a number pair to a context based on the first number of the number pair. According to a twentieth aspect of the invention, there is provided a context-based arithmetic encoder comprising means for representing an array of data symbols with a code word, further comprising means for providing a number indicative of a number of non-zero data symbols in the array and means for assigning said number to a context representative of the number. According to an aspect of the present disclosure, there is provided a method of image coding, in which an image is divided into a plurality of blocks having a plurality of pixels, each pixel having a pixel value, and a transform coding operation is performed on a block of pixels to produce a corresponding block of transform coefficient values, the block of quantized transform coefficient values is scanned in a given scanning order to produce a scanned array of coefficient values, the method comprising: quantizing the scanned array of coefficient values to produce an array of quantized transform coefficient values; determining a number indicative of a number of non-zero coefficient values in the array of quantized transform coefficient values; determining a context for encoding said number based on a number of non-zero coefficient values for one other image block which has already been encoded; and encoding said number in a bitstream based on the determined context. 898481D4/10946676 34a According to an aspect of the present disclosure, there is provided an encoder, comprising means for dividing an image into a plurality of blocks having a plurality of pixels, each pixel having a pixel value, and means for performing a transform coding operation on a block of pixels to produce a corresponding block of transform coefficient values, means for scanning the block of transform coefficient values in a given scanning order to produce a scanned array of coefficient values, and wherein the encoder further comprises: means for quantizing the scanned array of coefficient values to produce an array of quantized transform coefficient values; means for determining a number indicative of the number of non-zero coefficient values in the array of quantized transform coefficient values, means for determining a context for encoding said number based on a number of non-zero coefficient values for one other image block which has already been encoded; and means for encoding said number in a bitstream based on the determined context. According to an aspect of the present disclosure, there is provided a computer program comprising code for dividing an image into a plurality of blocks having a plurality of pixels, each pixel having a pixel value, and code for performing a transform coding operation on a block of pixels to produce a corresponding block of transform coefficient values, wherein the block of transform coefficients is scanned in a given scanning order to produce a scanned array of coefficient, and wherein the computer program comprises a code for quantizing the scanned array of coefficient values to produce an array of quantized transform coefficient values; a code for determining a number indicative of the number of non-zero coefficient values in the array of quantized transform coefficient values; a code for determining a context for encoding said number based on a number of non-zero coefficient values for one other image block which has already been encoded; and a code encoding said number in a bitstream based on the determined context. According to an aspect of the present disclosure, there is provided a method of context-based arithmetic encoding in which an image is divided into a plurality of blocks having a plurality of pixels, each pixel having a pixel value, and a transform coding operation is performed on a block of pixels to produce a corresponding block of transform coefficient values, the block of transform coefficient values is scanned in a given scanning order and quantized to produce a scanned array of quantized transform coefficient values, wherein the quantized transform coefficient values are represented by an array of data symbols represented with a code-word, the method comprising determining a number indicative of a number of non-zero data symbols in said array of data symbols, determining a context for 898481D4/10946676 34b encoding said number based on a number of non-zero data symbols for one other array of data symbols which has already been encoded; and encoding said number in a bitstream based on the determined context. According to an aspect of the present disclosure, there is provided a context-based arithmetic encoder comprising means for dividing an image into a plurality of blocks having a plurality of pixels, each pixel having a pixel value; means for performing a transform coding operation on a block of pixels to produce a corresponding block of transform coefficient values; means for scanning the block of transform coefficient values in a given scanning order and quantizing to produce a scanned array of quantized transform coefficient values, and means for representing the quantized transform coefficient values by an array of data symbols represented with a code-word, wherein the encoder further comprises means for determining a number indicative of a number of non-zero data symbols in said array of data symbols, determining a context for encoding said number based on a number of non-zero data symbols for one other array of data symbols which has already been encoded; and encoding said number in a bitstream based on the determined context. According to an aspect of the present disclosure, there is provided a method of image decoding, in which an image is divided into a plurality of blocks having a plurality of pixels, the method comprising: receiving from a bitstream a number indicative of a number of non zero coefficient values in a block of transform coefficient values representing an image block of pixels; and determining a context in decoding a number of non-zero coefficient values for another block of transform coefficient values based on said number of non-zero coefficient values in the block. According to an aspect of the present disclosure, there is provided a decoder for image coding, wherein an image is divided into a plurality of blocks having a plurality of pixels, the decoder comprises: means for receiving from a bitstream a number indicative of a number of non-zero coefficient values in a block of transform coefficient values representing an image block of pixels; and means for determining a context in decoding a number of non-zero coefficient values for another block of transform coefficient values based on said number of non-zero coefficient values in the block. According to an aspect of the present disclosure, there is provided a computer program for performing image decoding, comprising: a code for dividing an image into a plurality of blocks having a plurality of pixels, each pixel having a pixel value; a code for receiving from 898481D4/10946676 34c a bitstream a number indicative of a number of non-zero coefficient values in a block of transform coefficient values representing an image block of pixels; and a code for determining a context in decoding a number of non-zero coefficient values for another block of transform coefficient values based on said number of non-zero coefficient values in the block. According to an aspect of the present disclosure, there is provided a method of context-based arithmetic decoding in which an array of data symbols is represented with a code-word, the method comprising: receiving from a bitstream a number indicative of a number of non-zero data symbols in said array; determining a context of the values based on a previous number indicative of a number of non-zero coefficient values in a block of another transform coefficient values, when the previous number is provided before the number is provided; and decoding an image block based from transform coefficient values based on said number of non-zero data symbols. According to an aspect of the present disclosure, there is provided a context-based arithmetic decoder comprising means for representing an array of data symbols with a code word, characterized in that the encoder comprises: means for receiving from a bitstream a number indicative of a number of non-zero data symbols in said array; means for determining a context of the values based on a previous number indicative of a number of non-zero coefficient values in a block of another transform coefficient values, when the previous number is provided before the number is provided; and means for decoding an image block based from transform coefficient values based on said number of non-zero data symbols. The present invention will become apparent upon reading the description taken in conjunction with Figures 7a to 12. BRIEF DESCRIPTION OF THE DRAWINGS Figure 1 is a block diagram illustrating the structure of an exemplary video encoder, which employs block-based transform coding and motion-compensated prediction. 898481D4/10946676 Figure 2 is a block diagram of an exemplary video decoder corresponding to the encoder of Figure 1. Figure 3 is a diagrammatic representation showing an exemplary zigzag scan. Figure 4 is a block diagram showing an encoder in a prior art context-based 5 arithmetic coding scheme. Figure 5 is a block diagram showing a decoder in a prior art context-based arithmetic coding scheme. Figure 6a is a diagrammatic representation showing an exemplary two dimensional array of quantized DCT coefficient values scanned in a zigzag manner. 10 Figure 6b is a table showing the level and run values derived from the array of Figure 6a. Figure 6c is a table showing the binarized level and run values resulting from the application of the binarization scheme of Table 1 to the level and run values of Figure 6b. Figure 6d is a table showing a way in which the probability estimates are updated 15 from runs and levels. Figure 7a is a table showing a way in which contexts are assigned to bins based on level values. Figure 7b is a table showing the way in which contexts are assigned to level values according to a first embodiment of the present invention. 20 Figure 8a is a table showing a way in which contexts are assigned to bins based on run values. Figure 8b is a table showing the way in which contexts are assigned to run values according to a second embodiment of the present invention. Figure 9 is a block diagram illustrating an encoder in a context-based arithmetic 25 coding scheme, according to the present invention. Figure 10 is a block diagram illustrating a decoder, according to the present invention. Figure 11 is a flowchart illustrating a method of image coding, according to a preferred embodiment of the present invention. 30 Figure 12 is a flowchart illustrating a method of image coding, according to another embodiment of the present invention.
BEST MODE TO CARRY OUT THE INVENTION Embodiments of the invention will now be discussed in detail. As described above, the present invention provides a number of related mechanisms by which an 5 improvement in the coding efficiency (data compression) of a context-based arithmetic coder, can be attained. This improvement is achieved by using context models, which take into account the contexts to which other data symbols are assigned. A first embodiment of the invention, described in detail in section 1.1 below, relates to a context-based binary arithmetic coder suitable for use in an image coding 10 system such as that defined by ITU-T recommendation H.26L. In this embodiment, level values generated by run-level coding the quantized transform coefficients of a transform coded block of image pixels are assigned to contexts taking into account the level of another transform coefficient belonging to the same block. A second embodiment of the invention, described in detail in section 1.2, also 15 relates to a context-based binary arithmetic coder for an image coding system such as that defined by ITU-T recommendation H.26L. In the second embodiment, run values produced by run-level coding the quantized DCT transform coefficients of a transform coded block of image pixels are assigned to contexts taking into account the level value of the run-level pair to which the run value belongs. 20 A third embodiment of the invention is described in section 1.3 and also relates to a context-based arithmetic coder for an image coding system such as that defined by ITU T recommendation H.26L. According to the third embodiment, the number of non-zero transform coefficients Nc for a transform coded image block is determined and assigned to a context taking into account the context assigned to the N. value for at least one other 25 transform coded image block. A preferred embodiment of the invention combines the functionality of the three above-mentioned embodiments. As explained earlier in the text, the high complexity profile of ITU-T recommendation H.26L TML8 employs a form of context-based arithmetic coding known 30 as CABAC. In a video encoder implemented according to H.26L, the CABAC method is used to encode a variety of different. types of information produced by the encoder, 36 including the transform coefficients generated by transform coding blocks of image pixels (in INTRA-coding mode) or prediction error values (in INTER-coding mode). The two dimensional array of transform coefficients produced by transform coding a block of image pixels is scanned according to a particular scanning mode to produce a one 5 dimensional array. Two such scanning modes are defined in H.26L. The first is known as 'single-scanning mode' while the other is referred to as 'double-scanning mode'. Whichever scanning mode is used, scanning of the transform coefficients converts the two-dimensional array of coefficient values into a one-dimensional array in which the coefficients are ordered -in a predetermined manner. The ordered transform coefficient 10 values in the one-dimensional array are converted to run and level values. The last entry in the ordered one-dimensional array is an end-of-block symbol, which according to H.26L TML8, takes the form of a level value equal to zero. This indicates that the last non-zero coefficient value in the ordered array has been converted into a run-level pair. The run and level values are converted to binary numbers (binarized), by mapping 15 them to a series of bins, each of which can be assigned the value 0 or I (see Table 1). The binarized run and level values are then assigned to contexts, a separate set of contexts being defined for the runs and the levels. According to H.26L TML8, for a given block type, the set of contexts defined for levels depends only on the bin number to which the levels are assigned. More specifically, according to H.26L TML8 four contexts are 20 defined for level encoding. The first one is for the first bin, the second is for the second bin, while the third context is for the rest of the bins representing the magnitude of the level. The remaining context is used for the sign of the level. For runs there are three contexts, the first one for the first bin, the second for the second bin and the third for all remaining bins. As run values are always equal to or greater than zero, there is no need 25 for an additional context to represent sign information. 11. Context Model for Levels According to a first embodiment of the present invention, when assigning a binarized level value to a context, in addition to considering the bin to which the level 30 value itself is mapped, the level value of the preceding run-level pair is also taken into account. In this context, the term 'preceding run-level pair' peans the run-level pair 37 corresponding to the preceding coefficient in the ordered one-dimensional array of coefficient values. The following pseudo code presents an exemplary procedure for assigning a context to a level value of a run-level pair, taking into account both the bin to which the level itself is mapped and the level value of the preceding run-level pair: 5 if (bin nr > MAX BIN LEVEL) binnr = MAXBIN_LEVEL; end if(prevlevel > MAX LEVEL) (2) 10 prev level =MAX LEVEL; end context =(binnr-I) *MAX LEVEL + preylevel In expression (2) prey level is ihe magnitude of the level value of the previous run-level 15 pair. preylevel is initialized to zero at the beginning of each block. In double scanning mode, prevlevel is initialized at the beginning of each scan, twice per block. Parameter MAXBINLEVEL provides a means of controlling the way in which the bin number to which the level value is mapped affects the assignment of a context. More specifically, and in a manner similar to the present assignment of contexts according to H.26L TML8, 20 MAXBINLEVEL effectively defines a context to which all bin numbers greater than or equal to MAXBINLEVEL are assigned. In an similar fashion parameter MAXLEVEL provides a means of controlling the way in which the level value of the previous run-level pair affects the assignment of a context. Figures 7a and 7b illustrate the way in which contexts are assigned to level values according to the first embodiment of the invention by 25 applying the pseudo code of expression (2) with MAX_BIN_LEVEL = 3 and MAXLEVEL = 5. In principle, any combination of MAX_BIN_LEVEL and MAXLEVEL can be used to define a set of contexts appropriate for the statistical characteristics of the level values to be coded. 30 1.2. Context Model for Runs 38 According to a second embodiment of the invention an approach is similar to that described in section 1.1 is used to assign run values to contexts. More specifically, when assigning a binarized run value to a context, in addition to considering the bin to which the run value itself is mapped, the level of the run-level pair to which the run value 5 belongs is also taken into account. The following pseudo code presents an exemplary procedure for assigning a context to a run value of a run-level pair, taking into account both the bin to which the run itself is mapped and the level value of the run-level pair to which the run value belongs: 10 if (bin-nr > MAX BIN RUN) bin nr = MAXBhVRUN; end if (level > MAX_RUATL) (3) level = MAX RUNL; 15 end context = (bin nr-1) *MAX_R UNL + level In expression (3) level is the magnitude of the level value of the run-level pair. Parameter MAXBIN RUN provides a means of controlling the way in which the bin number to 20 which the run value is mapped affects the assignment of a context. More specifically, and in a manner similar to the present assignment of contexts according to H.26L TML8, MAXBINRUN effectively defines a context to which all bin numbers greater than or equal to MAX_BIN_RUN are assigned. in an similar fashion parameter MAXRUNL provides a means of controlling the way in which the level value of run-level pair affects 25 the assignment of a context. Figures 8a and 8b illustrates the way in which contexts are assigned to level values according to the second embodiment of the invention by applying the pseudo code of expression (3) with MAX_BINRUN= 3 and MAXRUNL = 4. In principle, any combination of MAXBINRUN and MAXRUNL can be used to define a set of contexts appropriate for the statistical characteristics of the run values to be 30 coded.
1.3 Contexts for Number of Non-Zero Coefficients A third embodiment of the invention relates in particular to the way in which an ordered array of transform coefficient values is converted into run and level values and the way in which the number of run-level pairs corresponding to an array of quantized 5 transform coefficient values is signaled. More specifically, after a block of image pixels or prediction error values has been transform coded to form a two-dimensional array of transform coefficient values and each of the coefficient values has been quantized, the number of non-zero quantized coefficient values in the array is determined. A value, referred to as Nc, is assigned to that number and is used to signal explicitly the number of 10 non-zero coefficient values in the array. Thus, according to this embodiment of the invention, an EOB symbol, for example a level value equal to zero, is no longer required. The quantized transform coefficients are further scanned according to a predetermined scanning order to produce an ordered one-dimensional array. Alternatively, Ne may be determined after ordering the quantized coefficient values. Each 15 of the non-zero quantized coefficients in the ordered array is then converted into a run level pair. According to this embodiment of the invention, the level value of the run-level pair denotes the magnitude of the value of the quantized coefficient minus I and the run value corresponds to the number of consecutive zero-valued quantized coefficients preceding the coefficient in question. The level values are assigned to the magnitude of 20 the value of the quantized coefficient minus 1 because a level value equal to zero is no longer used as an end-of-block indicator. This gives rise to a saving in the amount of data (e.g. number of bits) required to represent the level information. The level and run values are then encoded using entropy coding, as is the N, value. In a situation where a context-based arithmetic coding method such as the CABAC 25 technique implemented in H.26L TMLS is used, the run and level values may be encoded according to the first and / or second embodiments of the invention, as described above. Alternatively any other appropriate context models may be used for the run and level values. Additionally a separate context model is defined for No. According to this embodiment of the invention, the N. value representing the number of non-zero quantized 30 transform coefficients in a given block is first binarized by mapping it to a series of bins, each of which has a corresponding bin number. The context for N, is then determined on
AO
the basis of the bin number to which N, is mapped and the Ne of at least one other image block or macroblock which has already been assigned an Nc value. The following pseudo code presents an exemplary procedure for assigning a context to an Ne value, taking into account both the bin to which the Nc itself is mapped and the preceding Nc value: 5 if (bin nr > MAX_BINNc) bin nr = MAX_BIN Nc; end if(prev nc > MAX Nc) (4) 10 prev nc = MAX Nc; end context = (binnr-1)*MAX nc + prev nc In expression (4) prevnc is the previous Nc value. 15 When encoded level and run values for a given block of quantized transform coefficents are transmitted from an encoder to a decoder, the entropy coded Ne value is transmitted before the encoded run and level values. At the decoder, the Ne value is decoded, followed by the run-level pairs corresponding to the quantized transform coefficient values for the block in question. The value of +1 is added to each of the 20 magnitude of the level values as they are decoded in order to compensate for the corresponding subtraction made at the encoder. To demonstrate the improvement in coding efficiency using the method of image coding, according to the present invention, the average bitrate difference is calculated using results for QP=28, 24, 20, 16. Table 2 shows the bitrate reduction in percentage, as 25 compared to TML8, where MAXLEVEL=5 and MAXRUN=4. All frames are encoded as I-frames in CABAC mode. As shown in Table 2, the reduction in bitrate ranges from 0.95 to 4.74%. The improvement is more pronounced when the QP values are small. QP Container Foreman News Silent Tempete Mobile Paris 5 3.19 3.92 3.11 4.74 4.01 3.63 3.34 10 3.10 3.39 2.85 4.32 , 3.88 3.73 3.04 A I 16 2.64 2.67 2.26 3.17 3.37 3.37 2.55 20 2.20 2.14 1.76 2.38 2.79 2.90 2.20 24 1.30 1.51 1.35 2.28 1.89 2.01 1.54 28 1.16 0.95 0.99 1.76 1.55 1.57 1.18 Ave.Bitrate 1.79 1.83 1.58 2.37 2.49 2.40 1.87 Diff.* (%) Table 2 In Tables 2, the names appearing on the first row of the table are pictures used in 5 Gisle Bjontegaard "Recommended Simulation Conditions for H.26L" (VCG-M75, ITU-T Video Coding Experts Group, Austin, Texas, USA, 2-4 April, 2001). Referring now to Figure 9, an encoder 10 in the transmit side, according to the present invention, includes a unit 16 for storing previous levels and runs. As shown in Figure 9, the run-level pairs 102 for a given block are provided to a mapping unit 12, 10 which maps the pairs to a sequence of bins, each bin having a value of 0 or 1. The location of the bin in the sequence representing a run-level pair is called a bin number. The bin numbers are represented by signals 104. Based on the signals 104 and a previously encoded level value 108 provided by unit 16, an assignment unit 14 assigns a context to a bin number. The contexts, denoted by signals 106, are provided to an 15 adaptive arithmetic coder 20. The probability of occurrence of I and the probability of occurrence of 0 are estimated by a probability estimation module 22. Based on the probability estimates 120, an arithmetic encoding unit 24 encodes the bins. A feedback signal 124 is provided from the encoder 24 to the probability estimation module 22 to update the probability estimation. The encoded information is made into a bit-stream 122 20 to be conveyed to a decoder or stored in a storage device for later use. Preferably, the encoder 10 also includes a unit 18, which is capable of providing the number, Nc, of non-zero coefficients in the block to the arithmetic encoder 20 before the run-level pairs are provided to the arithmetic encoder 20, so that Nc is also encoded and included into the bit-stream 122. Nc is represented by signals 110. By using Nc, there 25 is no need to send an End-of-Block (EOB) symbol to the decoder. In prior art, the level value of 0 is used for the EOB symbol. More specifically, Nc is found after transform and quantization and it is encoded using entropy encoding. It should be noted that with the number of non-zero coefficients known, it is no longer necessary to use the 04evel value to signal the end of the block. Thus, it is possible to modify the level value by subtracting 1 from the value of the quantized coefficient. 5 On the receive side, as shown in Figure 10, a decoder 50 is used to receive the bit stream 122 provided by the encoder 10. The received bit-stream, which represents arithmetic coded data symbols, is denoted by reference numeral 202. Initially, based on the previously decoded symbols, a context is calculated in a context assignment block 66 and the probability estimates of the bin values are updated in a probability estimation 10 block 62. The previously decoded symbols based on which the probability estimates are updated are denoted by reference numeral 205. Context assignment, as carried out in the context assignment block 66, and calculation of probability estimates, as carried out in the probability estimation block 62, are similar to those in the encoder 10. The received bits 202 are then fed into an arithmetic decoding engine 64 in an arithmetic coder 60, where 15 they are converted into decoded bin values 206, using the calculated context and the current probability estimates of the bin values 204. Decoded bins 208 are mapped to the values of the runs and levels in block 68. If the number, Nc, of non-zero coefficients in the block is encoded in the encoder 10 and provided in the received bit-stream 202, then a signal 214 is provided to the bin-to-value mapping module 68 whereby the quantized 20 coefficient is restored by adding to the level value by 1. Figure 11 is a flowchart illustrating a method of image coding, according to the preferred embodiment of the present invention. As shown, the method 500 starts at step 510 where an image is received by an encoder. The received image is divided into a plurality of blocks at step 520. Each block is scanned at step 530 and the levels and runs 25 of the quantized coefficients in the block are obtained at step 540. In contrast to prior art coding schemes, the present invention also uses the previous levels in the assignment of contexts at step 550. In particular, the assignment of contexts to the bins representing the level values of the quantized coefficients takes into account the value of the previously encoded level, as described in section 1.1. Likewise, the assignment of contexts to the 30 bins representing the run values of the quantized coefficients takes into account the level value, as described in section 1.2. The assigned contexts are conveyed to an arithmetic coder for encoding at step 560. Additionally, Nc, or the number of non-zero quantized coefficients, is determined during or after the block is scanned at step 53_and.Neis_ encoded at step 560 prior to Nc and the contexts being provided to a decoder, as described in section 1.3. 5 Alternatively, the image coding method can be improved solely by conveying signals indicative of Nc to the receive side, without considering the value of the previously encoded level or run when the contexts are assigned, as shown in Figure 11. As shown in Figure 12, instead of obtaining the previously encoded levels and runs at step 540 for assigning the contexts at step 550, Ne is obtained and provided at step 542. 10 Nc is conveyed, before the contexts assigned at step 550 are sent, to an arithmetic coder for encoding at step 560. By sending Nc, there is no need to send the EOB symbol to the decoder. Although the invention has been described with respect to a preferred. embodiment thereof, it will be understood by those skilled in the art that the foregoing and various 15 other changes, omissions and deviations in the form and detail thereof may be made without departing from the scope of this invention.
AA
Claims (29)
1. A method of image coding, in which an image is divided into a plurality of blocks having a plurality of pixels, each pixel having a pixel value, and a transform coding operation is performed on a block of pixels to produce a corresponding block of transform coefficient values, the block of quantized transform coefficient values is scanned in a given scanning order to produce a scanned array of coefficient values, the method comprising: quantizing the scanned array of coefficient values to produce an array of quantized transform coefficient values; determining a number indicative of a number of non-zero coefficient values in the array of quantized transform coefficient values; determining a context for encoding said number based on a number of non-zero coefficient values for one other image block which has already been encoded; and encoding said number in a bitstream based on the determined context.
2. A method according to claim 1, wherein the number indicative of the number of non-zero coefficient values in said array of quantized transform coefficient values is assigned to a context taking into account the context to which another such number indicative of the number of non zero coefficient values in another array of quantized transform coefficients is assigned.
3. A method according to claim 1 or 2, wherein: representing the coefficient values in the array of quantized transform coefficients by a plurality of number pairs having a first number and a second number.
4. A method according to claim 3, wherein said first number is indicative of a non-zero coefficient value; and that said second number is indicative of a number of consecutive zero coefficient values preceding said non-zero coefficient value in the array of quantized transform coefficients.
5. A method according to claim 3 or 4, wherein the number indicative of a number of non zero coefficient values in the array of quantized transform coefficient values is provided so as to 898481D11/10946190 46 avoid sending an end-of-block indication, indicative of the last non-zero coefficient value in the array of quantized transform coefficients.
6. A method according to claim 3, 4, or 5, wherein the first number is equal to the magnitude of a non-zero coefficient value minus 1.
7. An encoder, comprising means for dividing an image into a plurality of blocks having a plurality of pixels, each pixel having a pixel value, and means for performing a transform coding operation on a block of pixels to produce a corresponding block of transform coefficient values, means for scanning the block of transform coefficient values in a given scanning order to produce a scanned array of coefficient values, and wherein the encoder further comprises: means for quantizing the scanned array of coefficient values to produce an array of quantized transform coefficient values; means for determining a number indicative of the number of non-zero coefficient values in the array of quantized transform coefficient values, means for determining a context for encoding said number based on a number of non zero coefficient values for one other image block which has already been encoded; and means for encoding said number in a bitstream based on the determined context.
8. An encoder according to claim 7, wherein said means for assigning the number indicative of the number of non-zero transform coefficient values in said array of quantized transform coefficient values to a context is arranged to take into account the context to which another such number indicative of the number of non-zero transform coefficient values in another array of quantized transform coefficients is assigned.
9. An encoder according to claim 7 or 8, further comprising means for representing the coefficient values in the array of quantized transform coefficients by a plurality of number pairs having a first number and a second number.
10. A method according to claim 9, wherein said first number is indicative of a non-zero coefficient value, and that said second number is indicative of a number of consecutive zero 898481D1/10946190 47 coefficient values preceding said non-zero coefficient value in the array of quantized transform coefficients.
11. A computer program comprising code for dividing an image into a plurality of blocks having a plurality of pixels, each pixel having a pixel value, and code for performing a transform coding operation on a block of pixels to produce a corresponding block of transform coefficient values, wherein the block of transform coefficients is scanned in a given scanning order to produce a scanned array of coefficient, and wherein the computer program comprises: a code for quantizing the scanned array of coefficient values to produce an array of quantized transform coefficient values; a code for determining a number indicative of the number of non-zero coefficient values in the array of quantized transform coefficient values; a code for determining a context for encoding said number based on a number of non zero coefficient values for one other image block which has already been encoded; and a code encoding said number in a bitstream based on the determined context.
12. A method of context-based arithmetic encoding in which an image is divided into a plurality of blocks having a plurality of pixels, each pixel having a pixel value, and a transform coding operation is performed on a block of pixels to produce a corresponding block of transform coefficient values, the block of transform coefficient values is scanned in a given scanning order and quantized to produce a scanned array of quantized transform coefficient values, wherein the quantized transform coefficient values are represented by an array of data symbols represented with a code-word, the method comprising: determining a number indicative of a number of non-zero data symbols in said array of data symbols, determining a context for encoding said number based on a number of non-zero data symbols for one other array of data symbols which has already been encoded; and encoding said number in a bitstream based on the determined context. 898481D11/10946190 48
13. A context-based arithmetic encoder comprising means for dividing an image into a plurality of blocks having a plurality of pixels, each pixel having a pixel value; means for performing a transform coding operation on a block of pixels to produce a corresponding block of transform coefficient values; means for scanning the block of transform coefficient values in a given scanning order and quantizing to produce a scanned array of quantized transform coefficient values, and means for representing the quantized transform coefficient values by an array of data symbols represented with a code-word, wherein the encoder further comprises: means for determining a number indicative of a number of non-zero data symbols in said array of data symbols, determining a context for encoding said number based on a number of non-zero data symbols for one other array of data symbols which has already been encoded; and encoding said number in a bitstream based on the determined context.
14. A method of image decoding, in which an image is divided into a plurality of blocks having a plurality of pixels, the method comprising: receiving from a bitstream a number indicative of a number of non-zero coefficient values in a block of transform coefficient values representing an image block of pixels; and determining a context in decoding a number of non-zero coefficient values for another block of transform coefficient values based on said number of non-zero coefficient values in the block.
15. A method according to claim 14, further comprises: determining a context for receiving said number from the bitstream based on number of non-zero coefficient values for one other image block which has already been decoded.
16. The method according to claim 14, further comprising: receiving from the bitstream transform coefficient values according to the number of non zero coefficient values in said block; representing the received transform coefficient values by a plurality of number pairs having a first number and a second number; 898481D11/10946190 49 producing an array of transform coefficient values from the received transform coefficient values represented by the first number and the second number being scanned in a given scanning order.
17. The method according to claim 16, wherein said first number is indicative of a non-zero transform coefficient value, and that said second number is indicative of the number of consecutive zero transform coefficient values preceding said non-zero transform coefficient value in the scanned array.
18. The method according to claim 16 or 17, wherein the number indicative of the number of non-zero transform coefficient values in the block of transform coefficient values is provided so as to avoid receiving an end-of-block indication, indicative of the last non-zero transform coefficient value in the scanned array of transform coefficient values.
19. The method according to claim 17, wherein the first number is equal to the magnitude of a non-zero transform coefficient value minus 1.
20. A decoder for image coding, wherein an image is divided into a plurality of blocks having a plurality of pixels, the decoder comprises: means for receiving from a bitstream a number indicative of a number of non-zero coefficient values in a block of transform coefficient values representing an image block of pixels; and means for determining a context in decoding a number of non-zero coefficient values for another block of transform coefficient values based on said number of non-zero coefficient values in the block.
21. A decoder according to claim 20, further comprises: means for determining a context for receiving said number from the bitstream based on number of non-zero coefficient values for one other image block which has already been decoded.
22. The decoder according to claim 20, further comprises: 898481D1/10946190 50 means for receiving from the bitstream transform coefficient values according to the first number indicative of the number of non-zero coefficient values in said block; means for representing the received transform coefficient values by a plurality of number pairs having a first number and a second number; means for producing an array of transform coefficient values from the received transform coefficient values represented by the first number and the second number being scanned in a given scanning order.
23. The decoder according to claim 22, wherein said first number is indicative of a non-zero transform coefficient value, and that said second number is indicative of the number of consecutive zero transform coefficient values preceding said non-zero transform coefficient value in the scanned array.
24. The decoder according to claim 20, wherein the number indicative of the number of non zero transform coefficient values in the block of transform coefficient values is provided so as to avoid receiving an end-of-block indication, indicative of the last non-zero transform coefficient value in the scanned array of transform coefficient values.
25. The decoder according to claim 23, wherein the first number is equal to the magnitude of a non-zero transform coefficient value minus 1.
26. A computer program for performing image decoding, comprising: a code for dividing an image into a plurality of blocks having a plurality of pixels, each pixel having a pixel value; a code for receiving from a bitstream a number indicative of a number of non-zero coefficient values in a block of transform coefficient values representing an image block of pixels; and a code for determining a context in decoding a number of non-zero coefficient values for another block of transform coefficient values based on said number of non-zero coefficient values in the block. 898481D1/10946190 51
27. A method of context-based arithmetic decoding in which an array of data symbols is represented with a code-word, the method comprising: receiving from a bitstream a number indicative of a number of non-zero data symbols in said array; determining a context of the values based on a previous number indicative of a number of non-zero coefficient values in a block of another transform coefficient values, when the previous number is provided before the number is provided; and decoding an image block based from transform coefficient values based on said number of non-zero data symbols.
28. A context-based arithmetic decoder comprising means for representing an array of data symbols with a code-word, wherein the decoder comprises: means for receiving from a bitstream a number indicative of a number of non-zero data symbols in said array; means for determining a context of the values based on a previous number indicative of a number of non-zero coefficient values in a block of another transform coefficient values, when the previous number is provided before the number is provided; and means for decoding an image block based from transform coefficient values based on said number of non-zero data symbols.
29. An encoder according to claim 9, wherein the first number is equal to the magnitude of a non-zero coefficient value minus 1. Nokia Corporation Patent Attorneys for the Applicant SPRUSON & FERGUSON 898481D1/10946190
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
AU2014202978A AU2014202978B2 (en) | 2001-09-14 | 2014-06-02 | Method and system for context-based adaptive binary arithmetic coding |
Applications Claiming Priority (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US60/322,112 | 2001-09-14 | ||
US09/995,240 | 2001-11-27 | ||
AU2011244880A AU2011244880A1 (en) | 2001-09-14 | 2011-10-28 | Method and system for context-based adaptive binary arithmetic coding |
AU2014202978A AU2014202978B2 (en) | 2001-09-14 | 2014-06-02 | Method and system for context-based adaptive binary arithmetic coding |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
AU2011244880A Division AU2011244880A1 (en) | 2001-09-14 | 2011-10-28 | Method and system for context-based adaptive binary arithmetic coding |
Publications (2)
Publication Number | Publication Date |
---|---|
AU2014202978A1 AU2014202978A1 (en) | 2014-06-26 |
AU2014202978B2 true AU2014202978B2 (en) | 2016-03-24 |
Family
ID=45442350
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
AU2011244880A Abandoned AU2011244880A1 (en) | 2001-09-14 | 2011-10-28 | Method and system for context-based adaptive binary arithmetic coding |
AU2014202978A Expired AU2014202978B2 (en) | 2001-09-14 | 2014-06-02 | Method and system for context-based adaptive binary arithmetic coding |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
AU2011244880A Abandoned AU2011244880A1 (en) | 2001-09-14 | 2011-10-28 | Method and system for context-based adaptive binary arithmetic coding |
Country Status (1)
Country | Link |
---|---|
AU (2) | AU2011244880A1 (en) |
Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2000054511A2 (en) * | 1999-03-09 | 2000-09-14 | Conexant Systems, Inc. | Error resilient still image packetization method and packet structure |
-
2011
- 2011-10-28 AU AU2011244880A patent/AU2011244880A1/en not_active Abandoned
-
2014
- 2014-06-02 AU AU2014202978A patent/AU2014202978B2/en not_active Expired
Patent Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2000054511A2 (en) * | 1999-03-09 | 2000-09-14 | Conexant Systems, Inc. | Error resilient still image packetization method and packet structure |
Non-Patent Citations (2)
Title |
---|
H.26L Test Model Long Term Number 8. INTERNATIONAL ORGANISATION FOR STANDARDISATION; ORGANISATION INTERNATIONALE DE NORMALISATION; ISO/IEC JTC1/SC29/WG11; CODING OF MOVING PICTURES AND AUDIO ISO/IEC JTC1/SC29/WG11 MPEG2001/M7512July 2001 * |
ITU - Telecommunications Standardization Sector STUDY GROUP 16 Question 6. Video Coding Experts Group (VCEG) .Twelfth Meeting: Eibsee, Germany, 9-12 January, 2001 * |
Also Published As
Publication number | Publication date |
---|---|
AU2014202978A1 (en) | 2014-06-26 |
AU2011244880A1 (en) | 2011-11-24 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
AU2002334271B9 (en) | Method and system for context-based adaptive binary arithmetic coding | |
AU2002334271A1 (en) | Method and system for context-based adaptive binary arithmetic coding | |
EP1391121B1 (en) | Variable length coding | |
KR100953677B1 (en) | Coding transform coefficients in image/video encoders and/or decoders | |
KR100969645B1 (en) | Adaptive variable length coding | |
EP1490975B1 (en) | Coding transform coefficients in image / video encoder and/or decoders | |
US7957600B2 (en) | Methods and systems for rate-distortion optimized quantization of transform blocks in block transform video coding | |
CN1874509B (en) | Method and system for context-based adaptive binary arithmetic coding | |
AU2014202978B2 (en) | Method and system for context-based adaptive binary arithmetic coding | |
EP1933568A2 (en) | Method and system for context-based adaptive binary arithmetic coding | |
AU2008202981B2 (en) | Method and system for context-based adaptive binary arithmetic |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PC1 | Assignment before grant (sect. 113) |
Owner name: NOKIA TECHNOLOGIES OY Free format text: FORMER APPLICANT(S): NOKIA CORPORATION |
|
FGA | Letters patent sealed or granted (standard patent) | ||
MK14 | Patent ceased section 143(a) (annual fees not paid) or expired |