[svn] / branches / dev-api-4 / xvidcore / src / utils / mbfunctions.h Repository:
ViewVC logotype

Diff of /branches/dev-api-4/xvidcore/src/utils/mbfunctions.h

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

trunk/xvidcore/src/utils/mbfunctions.h revision 384, Mon Aug 19 19:19:40 2002 UTC branches/dev-api-4/xvidcore/src/utils/mbfunctions.h revision 965, Sun Mar 30 13:16:42 2003 UTC
# Line 18  Line 18 
18  #include "../encoder.h"  #include "../encoder.h"
19  #include "../bitstream/bitstream.h"  #include "../bitstream/bitstream.h"
20    
   
   
21  /** MotionEstimation **/  /** MotionEstimation **/
22    
23  bool MotionEstimation(MBParam * const pParam,  bool MotionEstimation(MBParam * const pParam,
# Line 30  Line 28 
28                                            const IMAGE * const pRefHV,                                            const IMAGE * const pRefHV,
29                                            const uint32_t iLimit);                                            const uint32_t iLimit);
30    
   
 bool SMP_MotionEstimation(MBParam * const pParam,  
                                           FRAMEINFO * const current,  
                                           FRAMEINFO * const reference,  
                                           const IMAGE * const pRefH,  
                                           const IMAGE * const pRefV,  
                                           const IMAGE * const pRefHV,  
                                           const uint32_t iLimit);  
   
   
   
31  /** MBMotionCompensation **/  /** MBMotionCompensation **/
32  void MBMotionCompensation(MACROBLOCK * const pMB,  
33                                                    const uint32_t j,  void
34    MBMotionCompensation(MACROBLOCK * const mb,
35                                                    const uint32_t i,                                                    const uint32_t i,
36                                                    const IMAGE * const pRef,                                          const uint32_t j,
37                                                    const IMAGE * const pRefH,                                          const IMAGE * const ref,
38                                                    const IMAGE * const pRefV,                                          const IMAGE * const refh,
39                                                    const IMAGE * const pRefHV,                                          const IMAGE * const refv,
40                                                    IMAGE * const pCurrent,                                          const IMAGE * const refhv,
41                                                    int16_t dct_codes[6 * 64],                                          const IMAGE * const refGMC,
42                                            IMAGE * const cur,
43                                            int16_t * dct_codes,
44                                                    const uint32_t width,                                                    const uint32_t width,
45                                                    const uint32_t height,                                                    const uint32_t height,
46                                                    const uint32_t edged_width,                                                    const uint32_t edged_width,
47                                                    const uint32_t rounding);                                          const int32_t quarterpel,
48                                            const int reduced_resolution,
49                                            const int32_t rounding);
50    
51  /** MBTransQuant.c **/  /** MBTransQuant.c **/
52    
53    
54  void MBTransQuantIntra(const MBParam * pParam,  void MBTransQuantIntra(const MBParam * const pParam,
55                                             FRAMEINFO * frame,                                          FRAMEINFO * const frame,
56                                             MACROBLOCK * pMB,                                          MACROBLOCK * const pMB,
57                                             const uint32_t x_pos,        /* <-- The x position of the MB to be searched */                                             const uint32_t x_pos,        /* <-- The x position of the MB to be searched */
   
58                                             const uint32_t y_pos,        /* <-- The y position of the MB to be searched */                                             const uint32_t y_pos,        /* <-- The y position of the MB to be searched */
   
59                                             int16_t data[6 * 64],        /* <-> the data of the MB to be coded */                                             int16_t data[6 * 64],        /* <-> the data of the MB to be coded */
60                                            int16_t qcoeff[6 * 64]);        /* <-> the quantized DCT coefficients */
61    
62                                             int16_t qcoeff[6 * 64]       /* <-> the quantized DCT coefficients */  uint8_t MBTransQuantInter(const MBParam * const pParam,
63          );                                                  FRAMEINFO * const frame,
64                                                    MACROBLOCK * const pMB,
   
 void MBTransQuantIntra2(const MBParam * pParam,  
                                            FRAMEINFO * frame,  
                                            MACROBLOCK * pMB,  
                                            const uint32_t x_pos,        /* <-- The x position of the MB to be searched */  
   
                                            const uint32_t y_pos,        /* <-- The y position of the MB to be searched */  
   
                                            int16_t data[6 * 64],        /* <-> the data of the MB to be coded */  
   
                                            int16_t qcoeff[6 * 64]       /* <-> the quantized DCT coefficients */  
         );  
   
   
 uint8_t MBTransQuantInter(const MBParam * pParam,  
                                                   FRAMEINFO * frame,  
                                                   MACROBLOCK * pMB,  
                                                   const uint32_t x_pos,  
                                                   const uint32_t y_pos,  
                                                   int16_t data[6 * 64],  
                                                   int16_t qcoeff[6 * 64]);  
   
   
 uint8_t MBTransQuantInter2(const MBParam * pParam,  
                                                   FRAMEINFO * frame,  
                                                   MACROBLOCK * pMB,  
65                                                    const uint32_t x_pos,                                                    const uint32_t x_pos,
66                                                    const uint32_t y_pos,                                                    const uint32_t y_pos,
67                                                    int16_t data[6 * 64],                                                    int16_t data[6 * 64],
# Line 106  Line 70 
70  uint8_t MBTransQuantInterBVOP(const MBParam * pParam,  uint8_t MBTransQuantInterBVOP(const MBParam * pParam,
71                                                    FRAMEINFO * frame,                                                    FRAMEINFO * frame,
72                                                    MACROBLOCK * pMB,                                                    MACROBLOCK * pMB,
                                                   int16_t data[6 * 64],  
                                                   int16_t qcoeff[6 * 64]);  
   
 void MBTrans(const MBParam * pParam,  
                                                   FRAMEINFO * frame,  
                                                   MACROBLOCK * pMB,  
73                                                    const uint32_t x_pos,                                                    const uint32_t x_pos,
74                                                    const uint32_t y_pos,                                                    const uint32_t y_pos,
                                                   int16_t data[6 * 64]);  
   
 void MBfDCT(const MBParam * pParam,  
                         FRAMEINFO * frame,  
                         MACROBLOCK * pMB,  
                         int16_t data[6 * 64]);  
   
 uint8_t MBQuantInter(    const MBParam * pParam,  
                                                  const int iQuant,  
75                                                   int16_t data[6 * 64],                                                   int16_t data[6 * 64],
76                                                   int16_t qcoeff[6 * 64]);                                                   int16_t qcoeff[6 * 64]);
77    
 void MBQuantDeQuantIntra(const MBParam * pParam,  
                                                  FRAMEINFO * frame,  
                                                  MACROBLOCK *pMB,  
                                                  int16_t qcoeff[6 * 64],  
                                                  int16_t data[6*64]);  
78    
79  void MBQuantIntra(               const MBParam * pParam,  typedef uint32_t (MBFIELDTEST) (int16_t data[6 * 64]);  /* function pointer for field test */
80                                                   FRAMEINFO * frame,  typedef MBFIELDTEST *MBFIELDTEST_PTR;
                                                  MACROBLOCK *pMB,  
                                                  int16_t qcoeff[6 * 64],  
                                                  int16_t data[6*64]);  
81    
82  void MBDeQuantIntra(const MBParam * pParam,  /* global field test pointer for xvid.c */
83                                          const int iQuant,  extern MBFIELDTEST_PTR MBFieldTest;
                                         int16_t qcoeff[6 * 64],  
                                         int16_t data[6*64]);  
84    
85  void MBDeQuantInter(const MBParam * pParam,  /* field test implementations */
86                                          const int iQuant,  MBFIELDTEST MBFieldTest_c;
87                                          int16_t data[6 * 64],  MBFIELDTEST MBFieldTest_mmx;
                                         int16_t qcoeff[6 * 64],  
                                         const uint8_t cbp);  
   
   
 void MBiDCT(            int16_t data[6 * 64],  
                                         const uint8_t cbp);  
   
   
 void MBTransAdd(        const MBParam * pParam,  
                                         FRAMEINFO * frame,  
                                         MACROBLOCK * pMB,  
                                         const uint32_t x_pos,  
                                         const uint32_t y_pos,  
                                         int16_t data[6 * 64],  
                                         const uint8_t cbp);  
   
   
   
 /** interlacing **/  
   
 uint32_t MBDecideFieldDCT(int16_t data[6 * 64]);        /* <- decide whether to use field-based DCT  
                                                                                                            for interlacing */  
88    
89  void MBFrameToField(int16_t data[6 * 64]);      /* de-interlace vertical Y blocks */  void MBFrameToField(int16_t data[6 * 64]);      /* de-interlace vertical Y blocks */
90    
91    
92  /** MBCoding.c **/  /** MBCoding.c **/
93    
94  void MBSkip(Bitstream * bs);  /* just the bitstream. Since MB is skipped, no info is needed */  void MBCoding(const FRAMEINFO * const frame,    /* <-- the parameter for coding of the bitstream */
   
   
 void MBCoding(const FRAMEINFO * frame,  /* <-- the parameter for coding of the bitstream */  
   
95                            MACROBLOCK * pMB,     /* <-- Info of the MB to be coded */                            MACROBLOCK * pMB,     /* <-- Info of the MB to be coded */
   
96                            int16_t qcoeff[6 * 64],       /* <-- the quantized DCT coefficients */                            int16_t qcoeff[6 * 64],       /* <-- the quantized DCT coefficients */
   
97                            Bitstream * bs,       /* <-> the bitstream */                            Bitstream * bs,       /* <-> the bitstream */
98                            Statistics * pStat);    /* <-> statistical data collected for current frame */
                           Statistics * pStat    /* <-> statistical data collected for current frame */  
         );  
99    
100  #endif  #endif

Legend:
Removed from v.384  
changed lines
  Added in v.965

No admin address has been configured
ViewVC Help
Powered by ViewVC 1.0.4