[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.17, Sat Feb 15 15:22:19 2003 UTC revision 1.17.2.5, Sat Jun 28 15:48:08 2003 UTC
# Line 1  Line 1 
1  /**************************************************************************  /*****************************************************************************
2   *   *
3   *  Modifications:   *  XVID MPEG-4 VIDEO CODEC
4     *  - MB related header  -
5   *   *
6   *  29.03.2002 removed MBFieldToFrame - no longer used (transfers instead)   *  Copyright(C) 2001 Michael Militzer <isibaar@videocoding.de>
  *  26.03.2002 interlacing support  
  *  02.12.2001 motion estimation/compensation split  
  *  16.11.2001 const/uint32_t changes to MBMotionEstComp()  
  *  26.08.2001 added inter4v_mode parameter to MBMotionEstComp()  
7   *   *
8   *  Michael Militzer <isibaar@videocoding.de>   *  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
10     *  the Free Software Foundation ; either version 2 of the License, or
11     *  (at your option) any later version.
12   *   *
13   **************************************************************************/   *  This program is distributed in the hope that it will be useful,
14     *  but WITHOUT ANY WARRANTY ; without even the implied warranty of
15     *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16     *  GNU General Public License for more details.
17     *
18     *  You should have received a copy of the GNU General Public License
19     *  along with this program ; if not, write to the Free Software
20     *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
21     *
22     * $Id$
23     *
24     ****************************************************************************/
25    
26  #ifndef _ENCORE_BLOCK_H  #ifndef _ENCORE_BLOCK_H
27  #define _ENCORE_BLOCK_H  #define _ENCORE_BLOCK_H
# Line 18  Line 29 
29  #include "../encoder.h"  #include "../encoder.h"
30  #include "../bitstream/bitstream.h"  #include "../bitstream/bitstream.h"
31    
   
   
32  /** MotionEstimation **/  /** MotionEstimation **/
33    
34  bool MotionEstimation(MBParam * const pParam,  bool MotionEstimation(MBParam * const pParam,
# Line 28  Line 37 
37                                            const IMAGE * const pRefH,                                            const IMAGE * const pRefH,
38                                            const IMAGE * const pRefV,                                            const IMAGE * const pRefV,
39                                            const IMAGE * const pRefHV,                                            const IMAGE * const pRefHV,
40                                            const IMAGE * const pGMC,
41                                            const uint32_t iLimit);                                            const uint32_t iLimit);
42    
43    
44  bool SMP_MotionEstimation(MBParam * const pParam,  
45                                            FRAMEINFO * const current,  void
46                                            FRAMEINFO * const reference,  GMEanalysis(const MBParam * const pParam,
47                            const FRAMEINFO * const current,
48                            const FRAMEINFO * const reference,
49                                            const IMAGE * const pRefH,                                            const IMAGE * const pRefH,
50                                            const IMAGE * const pRefV,                                            const IMAGE * const pRefV,
51                                            const IMAGE * const pRefHV,                          const IMAGE * const pRefHV);
52                                            const uint32_t iLimit);  
53    WARPPOINTS
54    GlobalMotionEst(MACROBLOCK * const pMBs,
55                                    const MBParam * const pParam,
56                                    const FRAMEINFO * const current,
57                                    const FRAMEINFO * const reference,
58                                    const IMAGE * const pRefH,
59                                    const IMAGE * const pRefV,
60                                    const IMAGE * const pRefHV);
61    
62    int
63    GlobalMotionEstRefine(
64                                    WARPPOINTS *const startwp,
65                                    MACROBLOCK * const pMBs,
66                                    const MBParam * const pParam,
67                                    const FRAMEINFO * const current,
68                                    const FRAMEINFO * const reference,
69                                    const IMAGE * const pCurr,
70                                    const IMAGE * const pRef,
71                                    const IMAGE * const pRefH,
72                                    const IMAGE * const pRefV,
73                                    const IMAGE * const pRefHV);
74    
75    int
76    globalSAD(const WARPPOINTS *const wp,
77                      const MBParam * const pParam,
78                      const MACROBLOCK * const pMBs,
79                      const FRAMEINFO * const current,
80                      const IMAGE * const pRef,
81                      const IMAGE * const pCurr,
82                      uint8_t *const GMCblock);
83    
84    
85    
86    
# Line 64  Line 107 
107  /** MBTransQuant.c **/  /** MBTransQuant.c **/
108    
109    
110  void MBTransQuantIntra(const MBParam * pParam,  void MBTransQuantIntra(const MBParam * const pParam,
111                                             FRAMEINFO * frame,                                          const FRAMEINFO * const frame,
112                                             MACROBLOCK * pMB,                                          MACROBLOCK * const pMB,
113                                             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 */
   
                                            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 */  
         );  
   
   
 void MBTransQuantIntra2(const MBParam * pParam,  
                                            FRAMEINFO * frame,  
                                            MACROBLOCK * pMB,  
                                            const uint32_t x_pos,        /* <-- The x position of the MB to be searched */  
   
114                                             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 */
   
115                                             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 */
116                                            int16_t qcoeff[6 * 64]);        /* <-> the quantized DCT coefficients */
117    
118                                             int16_t qcoeff[6 * 64]       /* <-> the quantized DCT coefficients */  uint8_t MBTransQuantInter(const MBParam * const pParam,
119          );                                                  const FRAMEINFO * const frame,
120                                                    MACROBLOCK * const pMB,
   
 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,  
121                                                    const uint32_t x_pos,                                                    const uint32_t x_pos,
122                                                    const uint32_t y_pos,                                                    const uint32_t y_pos,
123                                                    int16_t data[6 * 64],                                                    int16_t data[6 * 64],
# Line 110  Line 126 
126  uint8_t MBTransQuantInterBVOP(const MBParam * pParam,  uint8_t MBTransQuantInterBVOP(const MBParam * pParam,
127                                                    FRAMEINFO * frame,                                                    FRAMEINFO * frame,
128                                                    MACROBLOCK * pMB,                                                    MACROBLOCK * pMB,
                                                   int16_t data[6 * 64],  
                                                   int16_t qcoeff[6 * 64]);  
   
 void MBTrans(const MBParam * pParam,  
                                                   FRAMEINFO * frame,  
                                                   MACROBLOCK * pMB,  
129                                                    const uint32_t x_pos,                                                    const uint32_t x_pos,
130                                                    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,  
131                                                   int16_t data[6 * 64],                                                   int16_t data[6 * 64],
132                                                   int16_t qcoeff[6 * 64]);                                                   int16_t qcoeff[6 * 64]);
133    
 void MBQuantDeQuantIntra(const MBParam * pParam,  
                                                  FRAMEINFO * frame,  
                                                  MACROBLOCK *pMB,  
                                                  int16_t qcoeff[6 * 64],  
                                                  int16_t data[6*64]);  
   
 void MBQuantIntra(               const MBParam * pParam,  
                                                  FRAMEINFO * frame,  
                                                  MACROBLOCK *pMB,  
                                                  int16_t qcoeff[6 * 64],  
                                                  int16_t data[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);  
   
   
   
 /** interlacing **/  
   
 uint32_t MBDecideFieldDCT(int16_t data[6 * 64]);        /* <- decide whether to use field-based DCT  
                                                                                                            for interlacing */  
134    
135  typedef uint32_t (MBFIELDTEST) (int16_t data[6 * 64]);  /* function pointer for field test */  typedef uint32_t (MBFIELDTEST) (int16_t data[6 * 64]);  /* function pointer for field test */
136  typedef MBFIELDTEST *MBFIELDTEST_PTR;  typedef MBFIELDTEST *MBFIELDTEST_PTR;
# Line 188  Line 147 
147    
148  /** MBCoding.c **/  /** MBCoding.c **/
149    
 /* void MBSkip(Bitstream * bs);  just the bitstream. Since MB is skipped, no info is needed */  
   
   
150  void MBCoding(const FRAMEINFO * const frame,    /* <-- the parameter for coding of the bitstream */  void MBCoding(const FRAMEINFO * const frame,    /* <-- the parameter for coding of the bitstream */
   
151                            MACROBLOCK * pMB,     /* <-- Info of the MB to be coded */                            MACROBLOCK * pMB,     /* <-- Info of the MB to be coded */
   
152                            int16_t qcoeff[6 * 64],       /* <-- the quantized DCT coefficients */                            int16_t qcoeff[6 * 64],       /* <-- the quantized DCT coefficients */
   
153                            Bitstream * bs,       /* <-> the bitstream */                            Bitstream * bs,       /* <-> the bitstream */
154                            Statistics * pStat);    /* <-> statistical data collected for current frame */
                           Statistics * pStat    /* <-> statistical data collected for current frame */  
         );  
155    
156  #endif  #endif

Legend:
Removed from v.1.17  
changed lines
  Added in v.1.17.2.5

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