[cvs] / xvidcore / src / utils / mbfunctions.h Repository:
ViewVC logotype

Diff of /xvidcore/src/utils/mbfunctions.h

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

revision 1.13, Mon Oct 7 08:11:06 2002 UTC revision 1.17.2.4, Mon Jun 9 13:55:34 2003 UTC
# Line 1  Line 1 
1  /*****************************************************************************  /*****************************************************************************
2   *   *
3   *  XVID MPEG-4 VIDEO CODEC   *  XVID MPEG-4 VIDEO CODEC
4   *  - Motion estimation fuctions header file -   *  - MB related header  -
5   *   *
6   *  Copyright(C) 2002 Michael Militzer   *  Copyright(C) 2001 Michael Militzer <isibaar@videocoding.de>
  *  
  *  This program is an implementation of a part of one or more MPEG-4  
  *  Video tools as specified in ISO/IEC 14496-2 standard.  Those intending  
  *  to use this software module in hardware or software products are  
  *  advised that its use may infringe existing patents or copyrights, and  
  *  any such use would be at such party's own risk.  The original  
  *  developer of this software module and his/her company, and subsequent  
  *  editors and their companies, will have no liability for use of this  
  *  software or modifications or derivatives thereof.  
7   *   *
8   *  This program is free software; you can redistribute it and/or modify   *  This program is free software; you can redistribute it and/or modify
9   *  it under the terms of the GNU General Public License as published by   *  it under the terms of the GNU General Public License as published by
# Line 32  Line 23 
23   *   *
24   ****************************************************************************/   ****************************************************************************/
25    
26  #ifndef _MBFUNCTIONS_H  #ifndef _ENCORE_BLOCK_H
27  #define _MBFUNCTIONS_H  #define _ENCORE_BLOCK_H
28    
29  #include "../encoder.h"  #include "../encoder.h"
30  #include "../bitstream/bitstream.h"  #include "../bitstream/bitstream.h"
31    
32  /*****************************************************************************  /** MotionEstimation **/
  * Prototypes  
  ****************************************************************************/  
   
   
 /* MotionEstimation */  
33    
34  bool MotionEstimation(MBParam * const pParam,  bool MotionEstimation(MBParam * const pParam,
35                                            FRAMEINFO * const current,                                            FRAMEINFO * const current,
# Line 53  Line 39 
39                                            const IMAGE * const pRefHV,                                            const IMAGE * const pRefHV,
40                                            const uint32_t iLimit);                                            const uint32_t iLimit);
41    
42    /** MBMotionCompensation **/
43    
44  bool SMP_MotionEstimation(MBParam * const pParam,  void
45                                                    FRAMEINFO * const current,  MBMotionCompensation(MACROBLOCK * const mb,
                                                   FRAMEINFO * const reference,  
                                                   const IMAGE * const pRefH,  
                                                   const IMAGE * const pRefV,  
                                                   const IMAGE * const pRefHV,  
                                                   const uint32_t iLimit);  
   
   
   
 /* MBMotionCompensation */  
   
 void MBMotionCompensation(MACROBLOCK * const pMB,  
                                                   const uint32_t j,  
46                                                    const uint32_t i,                                                    const uint32_t i,
47                                                    const IMAGE * const pRef,                                          const uint32_t j,
48                                                    const IMAGE * const pRefH,                                          const IMAGE * const ref,
49                                                    const IMAGE * const pRefV,                                          const IMAGE * const refh,
50                                                    const IMAGE * const pRefHV,                                          const IMAGE * const refv,
51                                                    IMAGE * const pCurrent,                                          const IMAGE * const refhv,
52                                                    int16_t dct_codes[6 * 64],                                          const IMAGE * const refGMC,
53                                            IMAGE * const cur,
54                                            int16_t * dct_codes,
55                                                    const uint32_t width,                                                    const uint32_t width,
56                                                    const uint32_t height,                                                    const uint32_t height,
57                                                    const uint32_t edged_width,                                                    const uint32_t edged_width,
58                                                    const uint32_t rounding);                                          const int32_t quarterpel,
59                                            const int reduced_resolution,
60                                            const int32_t rounding);
 /* MBTransQuant.c */  
   
 void MBTransQuantIntra(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 */  
61    
62    /** MBTransQuant.c **/
63    
64    
65  void MBTransQuantIntra2(const MBParam * pParam,  void MBTransQuantIntra(const MBParam * const pParam,
66                                                  FRAMEINFO * frame,                                          const FRAMEINFO * const frame,
67                                                  MACROBLOCK * pMB,                                          MACROBLOCK * const pMB,
68                                                  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 */
69                                                  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 */
70                                                  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 */
71                                                  int16_t qcoeff[6 * 64]); /* <-> the quantized DCT coefficients */                                                  int16_t qcoeff[6 * 64]); /* <-> the quantized DCT coefficients */
72    
73    uint8_t MBTransQuantInter(const MBParam * const pParam,
74                                                    const FRAMEINFO * const frame,
75  uint8_t MBTransQuantInter(const MBParam * pParam,                                                  MACROBLOCK * const pMB,
                                                   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,  
76                                                     const uint32_t x_pos,                                                     const uint32_t x_pos,
77                                                     const uint32_t y_pos,                                                     const uint32_t y_pos,
78                                                     int16_t data[6 * 64],                                                     int16_t data[6 * 64],
# Line 123  Line 81 
81  uint8_t MBTransQuantInterBVOP(const MBParam * pParam,  uint8_t MBTransQuantInterBVOP(const MBParam * pParam,
82                                                            FRAMEINFO * frame,                                                            FRAMEINFO * frame,
83                                                            MACROBLOCK * pMB,                                                            MACROBLOCK * pMB,
                                                           int16_t data[6 * 64],  
                                                           int16_t qcoeff[6 * 64]);  
   
 void MBTrans(const MBParam * pParam,  
                          FRAMEINFO * frame,  
                          MACROBLOCK * pMB,  
84                           const uint32_t x_pos,                           const uint32_t x_pos,
85                           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,  
86                                           int16_t data[6 * 64],                                           int16_t data[6 * 64],
87                                           int16_t qcoeff[6 * 64]);                                           int16_t qcoeff[6 * 64]);
88    
 void MBQuantDeQuantIntra(const MBParam * pParam,  
                                                  FRAMEINFO * frame,  
                                                  MACROBLOCK *pMB,  
                                                  int16_t qcoeff[6 * 64],  
                                                  int16_t data[6*64]);  
89    
90  void MBQuantIntra(const MBParam * pParam,  typedef uint32_t (MBFIELDTEST) (int16_t data[6 * 64]);  /* function pointer for field test */
91                                    FRAMEINFO * frame,  typedef MBFIELDTEST *MBFIELDTEST_PTR;
                                   MACROBLOCK *pMB,  
                                   int16_t data[6*64],  
                                   int16_t qcoeff[6 * 64]);  
   
 void MBDeQuantIntra(const MBParam * pParam,  
                                         const int iQuant,  
                                         int16_t qcoeff[6 * 64],  
                                         int16_t data[6*64]);  
   
 void MBDeQuantInter(const MBParam * pParam,  
                                         const int iQuant,  
                                         int16_t data[6 * 64],  
                                         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);  
92    
93    /* global field test pointer for xvid.c */
94    extern MBFIELDTEST_PTR MBFieldTest;
95    
96    /* field test implementations */
97  /* interlacing */  MBFIELDTEST MBFieldTest_c;
98    MBFIELDTEST MBFieldTest_mmx;
 uint32_t MBDecideFieldDCT(int16_t data[6 * 64]); /* <- decide whether to use field-based DCT for interlacing */  
99    
100  void MBFrameToField(int16_t data[6 * 64]);       /* de-interlace vertical Y blocks */  void MBFrameToField(int16_t data[6 * 64]);       /* de-interlace vertical Y blocks */
101    
102    
103  /* MBCoding.c */  /** MBCoding.c **/
   
 void MBSkip(Bitstream * bs); /* just the bitstream. Since MB is skipped, no info is needed */  
   
104    
105  void MBCoding(const FRAMEINFO * frame, /* <-- the parameter for coding of the bitstream */  void MBCoding(const FRAMEINFO * const frame,    /* <-- the parameter for coding of the bitstream */
106                            MACROBLOCK * pMB,        /* <-- Info of the MB to be coded */                            MACROBLOCK * pMB,        /* <-- Info of the MB to be coded */
107                            int16_t qcoeff[6 * 64],  /* <-- the quantized DCT coefficients */                            int16_t qcoeff[6 * 64],  /* <-- the quantized DCT coefficients */
108                            Bitstream * bs,          /* <-> the bitstream */                            Bitstream * bs,          /* <-> the bitstream */

Legend:
Removed from v.1.13  
changed lines
  Added in v.1.17.2.4

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