Efficient Implementation of H.264 4 By 4 Intra Prediction on a VLIW Processor
This invention is useful in video compression standards support a rich set of intra prediction modes. This invention a unique table creation and lookup approach to software pipeline the prediction process for all pixels within a block. The table stores constant data and pointer data into a neighbor pixel table. Indexing into the table based upon the current intra prediction mode for each pixel of a block recalls constant data and other pixel data for calculation of an intra prediction value.
The technical field of this invention is video data compression.
BACKGROUND OF THE INVENTIONThe H.264 video coding standard jointly developed by ITUT and MPEG provides the state-of-the-art video coding techniques to achieve high coding efficiency. It includes an enhanced Intra-prediction technique. Intra-prediction exploits spatial redundancy in picture. A macroblock or block is predicted from earlier decoded adjacent pixels. The H.264 standard supports a rich set of prediction patterns for intra-prediction. These include nine prediction modes for 4 by 4 luminance blocks and four prediction modes for 16 by 16 blocks. This increased number of intra-prediction modes increases decoding complexity. The decoding modes for 4 by 4 blocks involves many conditional branch statements for prediction mode selection within a macroblock. This is not suitable for very long instruction word (VLIW) processors, which perform best on parallel code without conditional branches.
The encoder can may use a 4 by 4 intra prediction mode at 16 by 16 macroblock (MB) level. There are sixteen 4 by 4 luminance sub-blocks in a 16 pixel by 16 pixel macroblock.
Decoding a macroblock encoded with 4 by 4 intra prediction is as follows. The macroblock is scanned in order illustrated in
Table 1 shows the interface of the 4 by 4 intra prediction decoder function just described.
The top_pixels, left_pixels and corner_pixels arrays contain the neighbor pixels of the current macroblock. If any neighbor pixel is not available, the array entry has a value of 128. The values in these arrays are updated while processing 4 by 4 blocks which are the neighbor pixels for subsequent blocks. For example: the reconstructed pixels d, h, 1 and p of block 0 are left neighbor pixels I, J, K and L for block 1; the reconstructed pixels m, n, o and p of block 0 are top neighbor pixels A, B, C and D for block 2; the reconstructed pixel p of block 0 is the top left corner neighbor M for block 3; and the reconstructed pixels m, n, o and p of block 1 are top right pixels E, F, G and H for block 2.
The DC prediction value in the DC mode is calculated as follows. If top and left neighbor pixels are available, then:
dc=(A+B+C+D+I+J+K+L+4)/8 (1).
If only top neighbor pixels are available, then:
dc=(A+B+C+D+2)/4 (2).
If only left neighbor pixels are available, then:
dc=(I+J+K+L+2)/4 (3).
If no neighboring pixels are available, then:
dc=128 (4).
Note that because unavailable neighboring pixels in the pixels arrays have a value of 128, the DC calculations are identical for the first and last cases above.
The neighbor, prediction and reconstructed pixels are all 8-bit unsigned values from 0 to 255. The residual error data is a 16 bit signed value. Addition between prediction buffer and residual error involves bit shifting and saturation in the standard.
A typical implementation of the 4 by 4 intra prediction function on a VLIW processor such as the Texas Instruments TMS3206400 would include the following optimization techniques. This typical implementation would use packed storage data placing four 8-bit values in 32 bit registers. This typical implementation would use of single instruction multiple data (SIMD) instructions such as DOTPU4 which calculates the dot product of four 8-bit values for efficient prediction values. This typical implementation would use registers instead of read/write memory for the prediction buffer.
Generally maximum utilization of a VLIW processor uses software-pipelining of a loop to achieve parallelism and maximum utilization of processing units of the processor. Software-pipelining is feasible only when loop does not have conditional branch statements. Software pipelining of intra prediction function of the prior art even using above optimizations is not feasible. This is because there are conditional branching based upon selection from the 9 prediction modes. Thus the prior art techniques under utilize a VLIW processor.
SUMMARY OF THE INVENTIONThis invention is an efficient software-pipelined technique for luminance intra prediction of 4 by 4 blocks. The technique is described in connection with a decoder but is extensible and also applicable for encoding. This invention may be implemented on a Texas Instruments TMS320C6400 digital signal processor providing 30 to 40% improvement over the prior art H.264 decoder.
This invention uses a table creation and lookup technique that eliminates branching for the different prediction modes within a macroblock. The function is software pipelined for each macroblock for maximum utilization of VLIW architecture. The technique uses a static prediction table, which contains information on the nine prediction modes. For a given 4 by 4 block, a neighbor table containing neighbor pixels packed in a unique form is created. The constants from the prediction table indexed using prediction mode are multiplied with neighbor table entries to create a prediction values without any branching.
These and other aspects of this invention are illustrated in the drawings, in which:
Digital signal processor system 100 includes a number of cache memories.
Level two unified cache 130 is further coupled to higher level memory systems. Digital signal processor system 100 may be a part of a multiprocessor system. The other processors of the multiprocessor system are coupled to level two unified cache 130 via a transfer request bus 141 and a data transfer bus 143. A direct memory access unit 150 provides the connection of digital signal processor system 100 to external memory 161 and external peripherals 169.
Central processing unit 1 has a 32-bit, byte addressable address space. Internal memory on the same integrated circuit is preferably organized in a data space including level one data cache 123 and a program space including level one instruction cache 121. When off-chip memory is used, preferably these two spaces are unified into a single memory space via the external memory interface (EMIF) 4.
Level one data cache 123 may be internally accessed by central processing unit 1 via two internal ports 3a and 3b. Each internal port 3a and 3b preferably has 32 bits of data and a 32-bit byte address reach. Level one instruction cache 121 may be internally accessed by central processing unit 1 via a single port 2a. Port 2a of level one instruction cache 121 preferably has an instruction-fetch width of 256 bits and a 30-bit word (four bytes) address, equivalent to a 32-bit byte address.
Central processing unit 1 includes program fetch unit 10, instruction dispatch unit 11, instruction decode unit 12 and two data paths 20 and 30. First data path 20 includes four functional units designated L1 unit 22, S1 unit 23, M1 unit 24 and D1 unit 25 and 16 32-bit A registers forming register file 21. Second data path 30 likewise includes four functional units designated L2 unit 32, S2 unit 33, M2 unit 34 and D2 unit 35 and 16 32-bit B registers forming register file 31. The functional units of each data path access the corresponding register file for their operands. There are two cross paths 27 and 37 permitting access to one register in the opposite register file each pipeline stage. Central processing unit 1 includes control registers 13, control logic 14, and test logic 15, emulation logic 16 and interrupt logic 17.
Program fetch unit 10, instruction dispatch unit 11 and instruction decode unit 12 recall instructions from level one instruction cache 121 and deliver up to eight 32-bit instructions to the functional units every instruction cycle. Processing occurs in each of the two data paths 20 and 30. As previously described above each data path has four corresponding functional units (L, S, M and D) and a corresponding register file containing 16 32-bit registers. Each functional unit is controlled by a 32-bit instruction. The data paths are further described below. A control register file 13 provides the means to configure and control various processor operations.
The fetch phases of the fetch group 610 are: Program address generate phase 611 (PG); Program address send phase 612 (PS); Program access ready wait stage 613 (PW); and Program fetch packet receive stage 614 (PR). Digital signal processor core 110 uses a fetch packet (FP) of eight instructions. All eight of the instructions proceed through fetch group 610 together. During PG phase 611, the program address is generated in program fetch unit 10. During PS phase 612, this program address is sent to memory. During PW phase 613, the memory read occurs. Finally during PR phase 614, the fetch packet is received at CPU 1.
The decode phases of decode group 620 are: Instruction dispatch (DP) 621; and Instruction decode (DC) 622. During the DP phase 621, the fetch packets are split into execute packets. Execute packets consist of one or more instructions which are coded to execute in parallel. During DP phase 622, the instructions in an execute packet are assigned to the appropriate functional units. Also during DC phase 622, the source registers, destination registers and associated paths are decoded for the execution of the instructions in the respective functional units.
The execute phases of the execute group 630 are: Execute 1 (E2) 631; Execute 2 (E2) 632; Execute 3 (E3) 633; Execute 4 (E4) 634; and Execute 5 (E5) 635. Different types of instructions require different numbers of these phases to complete. These phases of the pipeline play an important role in understanding the device state at CPU cycle boundaries.
During E1 phase 631, the conditions for the instructions are evaluated and operands are read for all instruction types. For load and store instructions, address generation is performed and address modifications are written to a register file. For branch instructions, branch fetch packet in PG phase 611 is affected. For all single-cycle instructions, the results are written to a register file. All single-cycle instructions complete during the E1 phase 631.
During the E2 phase 632, for load instructions, the address is sent to memory. For store instructions, the address and data are sent to memory. Single-cycle instructions that saturate results set the SAT bit in the control status register (CSR) if saturation occurs. For single cycle 16×16 multiply instructions, the results are written to a register file. For M unit non-multiply instructions, the results are written to a register file. All ordinary multiply unit instructions complete during E2 phase 622.
During E3 phase 633, data memory accesses are performed. Any multiply instruction that saturates results sets the SAT bit in the control status register (CSR) if saturation occurs. Store instructions complete during the E3 phase 633.
During E4 phase 634, for load instructions, data is brought to the CPU boundary. For multiply extensions instructions, the results are written to a register file. Multiply extension instructions complete during the E4 phase 634.
During E5 phase 635, load instructions write data into a register. Load instructions complete during the E5 phase 635.
Note that “z” in the z bit column refers to the zero/not zero comparison selection noted above and “x” is a don't care state. This coding can only specify a subset of the 32 registers in each register file as predicate registers. This selection was made to preserve bits in the instruction coding.
The dst field (bits 23 to 27) specifies one of the 32 registers in the corresponding register file as the destination of the instruction results.
The scr2 field (bits 18 to 22) specifies one of the 32 registers in the corresponding register file as the second source operand.
The scr1/cst field (bits 13 to 17) has several meanings depending on the instruction opcode field (bits 3 to 12). The first meaning specifies one of the 32 registers of the corresponding register file as the first operand. The second meaning is a 5-bit immediate constant. Depending on the instruction type, this is treated as an unsigned integer and zero extended to 32 bits or is treated as a signed integer and sign extended to 32 bits. Lastly, this field can specify one of the 32 registers in the opposite register file if the instruction invokes one of the register file cross paths 27 or 37.
The opcode field (bits 3 to 12) specifies the type of instruction and designates appropriate instruction options. A detailed explanation of this field is beyond the scope of this invention except for the instruction options detailed below.
The s bit (bit 1) designates the data path 20 or 30. If s=0, then data path 20 is selected. This limits the functional unit to L1 unit 22, S1 unit 23, M1 unit 24 and D1 unit 25 and the corresponding register file A 21. Similarly, s=1 selects data path 20 limiting the functional unit to L2 unit 32, S2 unit 33, M2 unit 34 and D2 unit 35 and the corresponding register file B 31.
The p bit (bit 0) marks the execute packets. The p-bit determines whether the instruction executes in parallel with the following instruction. The p-bits are scanned from lower to higher address. If p=1 for the current instruction, then the next instruction executes in parallel with the current instruction. If p=0 for the current instruction, then the next instruction executes in the cycle after the current instruction. All instructions executing in parallel constitute an execute packet. An execute packet can contain up to eight instructions. Each instruction in an execute packet must use a different functional unit.
Video encoding standards typically permit two types of predictions. In inter-frame prediction, data is compared with data from the corresponding location of another frame. In intra-frame prediction, data is compared with data from another location in the same frame.
For inter prediction, data from n−1 th frame Fn-1 810 and data from the current frame Fn 801 supply motion estimation block 811. Motion estimation block 811 determines the positions and motion vectors of moving objects within the picture. This motion data is supplied to motion compensation block 812 along with data from frame Fn-1 810. The resulting motion compensated frame data is selected by switch 813 for application to subtraction unit 806. Subtraction unit 806 subtracts the inter prediction data from switch 813 from the input frame data from current frame Fn 801. Thus frequency transform block 802, quantization block 803, reorder block 804 and entropy encoding block 805 encode the differential data rather than the original frame data. Assuming there is relatively little change from frame to frame, this differential data has a smaller magnitude than the raw frame data. Thus this can be expressed in fewer bits contributing to data compression. This is true even if motion estimation block 811 and motion compensation block 812 find no moving objects to code. If the current frame Fn and the prior frame Fn-1 are identical, the subtraction unit 806 will produce a string of zeros for data. This data string can be encoded using few bits.
The second type of prediction is intra prediction. Intra prediction predicts a macroblock of the current frame from another macroblock of that frame. Inverse quantization block 820 receives the quantized data from quantization block 803 and substantially recovers the original frequency domain data. Inverse frequency transform block 821 transforms the frequency domain data from inverse quantization block 820 back to the spatial domain. This spatial domain data supplies one input of addition unit 822, whose function will be further described. Encoding process 800 includes choose intra predication unit 814 to determine whether to implement intra prediction. Choose intra prediction unit 814 receives data from current frame Fn 801 and the output of addition unit 822. Choose intra prediction unit 814 signals intra prediction intra predication unit 815, which also receives the output of addition unit 822. Switch 813 selects the intra prediction output for application to the subtraction input of subtraction units 806 and an addition input of addition unit 822. Intra prediction is based upon the recovered data from inverse quantization block 820 and inverse frequency transform block 821 in order to better match the processing at decoding. If the encoding used the original frame, there might be drift between these processes resulting in growing errors.
Video encoders typically periodically transmit unpredicted frames. In such an event the predicted frame is all 0's. Subtraction unit 806 thus produces data corresponding to the current frame Fn 801 data. Periodic unpredicted or I frames limits any drift between the transmitter coding and the receive decoding. In video such a movies a scene change may produce such a large change between adjacent frames that differential coding provides little advantage. Video coding standards typically signal whether a frame is a predicted frame and the type of prediction in the transmitted data stream.
Encoding process 800 includes reconstruction of the frame based upon this recovered data. The output of addition unit 822 supplies deblock filter 823. Deblock filter 823 smoothes artifacts created by the block and macroblock nature of the encoding process. The result is reconstructed frame F′n 824. As shown schematically in
Switch 909 may also select intra prediction. The intra prediction is signaled in the encoded data stream. If this is selected, intra prediction unit 908 forms the predicted data from the output of adder 905 and then applies the intra prediction computed by intra prediction block 815 of the encoding process 800. Addition unit 905 recovers the predicted frame. As previously discussed in conjunction with encoding, it is possible to transmit an unpredicted or I frame. If the data stream signals that a received frame is an I frame, then the predicted frame supplied to addition unit 905 is all 0's.
The output of addition unit 905 supplies the input of deblock filter 910. Deblock filter 910 smoothes artifacts created by the block and macroblock nature of the encoding process. The result is reconstructed frame F′n 911. As shown schematically in
The deblocking filtering of deblock filter 823 and deblock 910 must be the same. This enables the decoding process to accurately reflect the input frame Fn 801 without error drift. The H.264 standard has a specific, very detailed decision matrix and corresponding filter operations for this process. The standard deblock filtering is applied to every macroblock in raster scan order. This deblock filtering smoothes artifacts created by the block and macroblock nature of the encoding. The filtered macroblock is used as the reference frame in predicted frames in both encoding and decoding. The encoding and decoding apply the identical processing the reconstructed frame to reduce the residual error after prediction.
This invention is based upon the following observations are made for 8 directional prediction types (except DC). Calculation of each predictor pixel in the prediction buffer involves a dot product of a set of neighbor pixels with some constants. The neighbors used for calculation of a given prediction value are 4 or fewer adjacent pixels, with neighbor pixels placed as a continuous set in order of left to top right neighbors as LKJIMABCDEFGH. All pixels for the prediction buffer (except DC prediction) can be calculated using following formula:
pred=(n0*k0+n1*k1+n2*k2+n3*k3+2)/4 (5)
where: n0 to n3 are neighbor pixels A to M having 8-bit unsigned values; k0 to k3 are 8-bit unsigned constant values; and pred is the calculated predictor value which is an 8-bit unsigned value.
This formula can be implemented using SIMD dot product DOTPU4 on a Texas Instruments TMS320C6400 digital signal processor followed by an add and shift by 2.
pred=(dotpu4(n3210,k3210)+2)>>2 (6)
This invention includes creation of a neighbor table ngbr_tbl[0:5]. Table 3 illustrates the data of such a table using the convention of
As shown in Table 3, the entry at each index is four 8-bit pixels packed into a 32-bit data word. These entries supply the data n3n2n1n0 of equation 6. The table is preferably stored in a scratch memory area independent of the prediction mode. Some of the entries in the ngbr_tbl table are available directly from neighbor pixels. For example DCBA is the top ngbr array shown in Table 3. Some of entries must be created by packing of neighbor pixel values as appropriate.
This invention also creates a static two dimensional prediction table pred_tbl. Table 4 shows the data in this pred_tbl.
The prediction mode table of Table 4 is divided into two sections. The first section stores constants k3k2k1k0 of the predicted value calculation. The first index into this section of pred_tbl is from 0 to 8 selected by the prediction mode. This is shown in the first column of Table 4. The entry for a given prediction mode contains the following information for 16 pixels a to p (
Block 1103 sets flags and pointers. These flags and pointers include those noted in Table 1. The pixel data to be coded or the compressed data to be decoded is preferably stored in a known location and the known location of the current block enables calculation of these flags and pointers. Block 1104 reads the current intra prediction mode. In the case of decoding, this intra prediction mode must be transmitted together with the residual data. In the case of coding, this mode is determined in a manner known in the art. Determining the intra prediction mode generally includes an estimate of the mode yielding the best data compression.
Step 1105 generates the neighbor table ngbr_tbl as shown in Table 3. This process preferably uses the flags and pointers initialized in block 1103. In particular the pixels A to M are determined as follows:
A=top_ngbr[0];
B=top_ngbr[1];
C=top_ngbr[2];
D=top_ngbr[3];
I=left_ngbr[0];
J=left_ngbr[1];
K=left_ngbr[2];
L=left_ngbr[3]; and
M=corner_nbr. (7)
The neighbor pixels E, F, G and H are determined as follows. If topright_avail indicates that the top right pixel is available, then:
E=top_ngbr[4];
F=top_ngbr[5];
G=top_ngbr[6]; and
H=top_ngbr[7]. (8)
Otherwise, if topright_avail indicates the top right pixel is not available, then:
E=F=G=H=D (9).
Once these pixel values are determined, then they are packed four into each data word as shown in Table 3.
Block 1106 calculates the DC prediction mode value. This process is described above. In general, this calculation involved checking the availability of top and left neighbor pixels. This calculation uses one of equations 1 to 4 depending on pixel availability as previously described. This calculation preferably is preformed as follows. If left neighbors I to L are available and top neighbors A to D are not, then the packed word DCBA is set to the packed word LKJI. If left neighbors I to L are not available and top neighbors A to D are, then the packed word LKJI is set to the packed word DCBA. DC prediction value is then calculated as follows. The dot product of DCBA and the constant 0x1010101 is added to the dot product of LKJI and the constant 0x01010101. This preferably uses the DOTPU4 instruction. Note the constant 0x01010101 makes each product equal to the other term. Thus each dot product is effectively the sum of the four packed pixel values. The constant 4 is then added to the sum of dot products. The resultant is right shifted three bits to divide by 8. This process performs equation 1. Note that following the copying of LKJI into DCBA, these steps perform equation 3. Following copying of DCBE into LKJI, these steps perform equation 2. Following this calculation, two copies of the resultant are packed into a 32-bit data word.
Block 1107 accesses data in the prediction mode table shown in Table 4. The first dimension index into the prediction mode table is the intra prediction mode. The second dimension index into the prediction mode table is the pixel position a to p. These indices into the prediction mode table yield a 32-bit word with four 8-bit packed constants k3k2k1k0 and a 4-bit word index into the neighbor table (Table 3). These specify the constants and data for the intra prediction calculation.
Block 1108 calculates intermediate intra prediction values for the 16 pixels a to p. As previously described, the intra prediction mode and pixel location enable recall of the constant k3k2k1k0 form the prediction mode table. The intra prediction mode and pixel location enable recall of a neighbor table pointer. This neighbor table pointer permits recall of the corresponding neighbor pixels from the neighbor table. The intermediate intra prediction value is the dot product of these quantities. Thus the intermediate value pr is calculated as:
pr=DOTPU4(k3k2k1k0,n3n2n1n0) (10).
The result of the 8-bit by 8-bit multiplies are 16-bit products. The sum of these four products appears in the least significant bits of the 32-bit resultant data word. The following description assumes that the sum does not carry over to the 17th bit. These sixteen calculations are preferably performed as in-line code rather than as one or more loops. Note that for the DC mode the constant data stored in the prediction mode table is dummy data. The results of this and later calculations will be replaced later.
Block 1109 completes calculation of the intra mode prediction values. The sixteen dot products are packed into eight 32-bit data words via a PACK2 instruction. Next 2 is added to the sixteen dot products packed into eight 32-bit data words using an ADD2 instruction. This ADD2 instruction separately adds two 16-bit parts of a 32-bit data word. One operand of the ADD2 instruction is a corresponding packed intermediate value. The other operand is a constant 0x00020002 which places the constant 2 in both 16-bit halves of the 32-bit data word. A final division is accomplished by a right shift. This preferably uses a SHR2 command which separately right shifts the two 16-bit halves of the 32-bit data word. The results of these calculates are 16 intra prediction mode values packed into eight 32-bit data words.
Block 1110 overwrites the just calculated eight 32-bit prediction values if the prediction mode is the DC mode (mode 2). This is preferably accomplished using predicated register to register move instructions. Eight such register to register move instructions have the corresponding register storing the DC mode prediction values calculated in block 1106 as the source operand. The registers storing the corresponding just described intra prediction mode values are the destination operands. Each register to register move instruction is predicated upon the value in an instruction designated predicate register. A value indicating the mode is the DC mode, allows the register to register move. This causes the calculated DC mode values to be stored in the destination registers. A value indicating a mode other than the DC mode aborts the register to register move. This causes the previous values calculated as described above to remain in the destination registers. This speculative calculation and conditional overwrite technique is used to avoid a conditional branch to the much different manner of calculating the DC mode prediction value. During decoding, the resultant intra mode prediction data can be added to the residual error data to produce the output pixels.
Test block 1111 determines if the current block is the last block in the current macroblock. If not (No at test block 1111), then method 1100 returns to block 1102 to perform the prediction value calculations for the next block. If the current block was the last block in the current macroblock (Yes at test block 1111), then method 1100 ends with end block 1112. A practical implementation will include outer loops for other macroblocks and other processes in the video processing.
Table 5 shows a comparison of this invention used in decoding with the conventional approach. Table 5 shows a comparison of the cycle count for decoding of a macroblock on a Texas Instruments TMS320C6400 digital signal processor as measured on a cycle accurate simulator. Table 5 lists a comparison for each prediction mode and for an average case. The comparison Table 5 assumes for numbers 1 to 9 that all sixteen 4 by 4 blocks of a particular macroblock have the same prediction mode. In a real-time decoder, different blocks in a macroblock may have different prediction modes. Number 10 showing the average case assumes that the blocks in a macroblock may have different prediction modes. Table 5 shows an improvement in range of 30 to 40% with and average improvement of about 35%.
This invention is a novel approach for intra prediction mode encoding and decoding on a pipelined VLIW processor. This invention uses table creation and lookup. This invention handles the 9 prediction modes within a macroblock without any conditional branches in the code. This enables optimal utilization of a pipelined VLIW processor through software pipelining. The improvement of this invention is in range of 30 to 40% for a H.264 decoder on a Texas Instruments TMS320C6400 data signal processor.
Claims
1. A method of calculating intra prediction values in video encoding and decoding for pixels in a block for a selected intra prediction mode comprising the steps of:
- constructing a table storing constant data related to calculation of an intra prediction value for a first dimension set by said selected intra prediction mode and a second dimension selected by a current pixel;
- for each pixel in the block of pixels recalling constant data corresponding to the current pixel and the selected intra prediction mode, recalling other pixel data corresponding to the current pixel and the selected intra prediction mode, and arithmetically combining said recalled constant data and said recalled other pixel data to form an intra prediction value.
2. The method of claim 1, wherein:
- said step of constructing a table includes generating multiple fixed length constants packed into predetermined portions of a single data word.
3. The method of claim 2, wherein:
- each of said fixed length constants is 8 bits; and
- said single data word is 32 bits.
4. The method of claim 1, wherein:
- said step of constructing a table further includes storing pointer data for a first dimension set by said selected intra prediction mode and a second dimension selected by a current pixel, and storing other pixel data for a first dimension corresponding to pointer data;
- constructing a table storing other pixel data at plural pointer locations;
- said step of recalling other pixel data includes recalling pointer data corresponding to the current pixel and the selected intra prediction mode, and recalling other pixel data corresponding to the recalled pointer data.
5. The method of claim 4, wherein:
- said step of constructing a table includes generating multiple fixed length pointer data packed into predetermined portions of a single data word.
6. The method of claim 5, wherein:
- each of said pointer is 4 bits; and
- said single data word is 32 bits.
7. The method of claim 4, wherein:
- said step of constructing a table storing other pixel data includes generating multiple fixed length constants packed into predetermined portions of a single data word.
8. The method of claim 7, wherein:
- each of said other pixel data is 8 bits; and
- said single data word is 32 bits.
9. The method of claim 1, wherein:
- said step of arithmetically combining said recalled constant data and said recalled other pixel data includes multiplying each other pixel data by corresponding constant data thereby forming plural products, adding said plural products thereby forming a sum, and scaling said sum.
10. The method of claim 9, wherein:
- said step of constructing a table includes generating multiple fixed length constants packed into predetermined portions of a single data word;
- said step of recalling other pixel data includes recalling multiple fixed length other pixel data of said fixed length packed into a single data word; and
- said step of multiplying each other pixel data by corresponding constant data and adding said plural products includes performing a multiple dot product instruction on a digital signal processor.
11. The method of claim 9, wherein:
- said step of scaling said sum includes adding a predetermined constant to said sum thereby forming a further sum, and right shifting said further sum a predetermined number of bits.
12. The method of claim 11, wherein:
- said step of constructing a table includes generating multiple fixed length constants packed into predetermined portions of a single data word;
- said step of recalling other pixel data includes recalling multiple fixed length other pixel data of said fixed length packed into a single data word;
- said method further comprises storing multiple instances of said sum into a single data word; and
- wherein said step of adding a predetermined constant to said sum includes performing a multiple add instruction on a digital signal processor.
13. The method of claim 12, wherein:
- said step of right shifting said further sum a predetermined number of bits includes performing a multiple shift instruction on a digital signal processor.
14. The method of claim 1, further comprising:
- separately calculating an intra prediction value for each pixel of the block for a predetermined one of said intra prediction modes;
- following arithmetically combining said recalled constant data and said recalled other pixel data determining if the intra prediction mode is said predetermined one of said intra prediction modes, and overwriting said arithmetic combination of said recalled constant data and said recalled other pixel data with said separately calculated intra prediction value for said predetermined one of said intra prediction mode for each pixel if the intra prediction mode is said predetermined one of said intra prediction modes.
Type: Application
Filed: Mar 19, 2007
Publication Date: Sep 25, 2008
Patent Grant number: 8233537
Inventors: Sunand Mittal (Ghaziabad), Ratna M.V. Reddy (Bangalore)
Application Number: 11/687,926
International Classification: H04N 7/12 (20060101);