[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.1, Fri Mar 8 02:44:58 2002 UTC revision 1.17.2.4, Mon Jun 9 13:55:34 2003 UTC
# Line 1  Line 1 
1  /**************************************************************************  /*****************************************************************************
2   *   *
3   *  Modifications:   *  XVID MPEG-4 VIDEO CODEC
4     *  - MB related header  -
5   *   *
6   *  02.12.2001 motion estimation/compensation split   *  Copyright(C) 2001 Michael Militzer <isibaar@videocoding.de>
  *  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 16  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(  bool MotionEstimation(MBParam * const pParam,
35                          MACROBLOCK * const pMBs,                                          FRAMEINFO * const current,
36                          MBParam * const pParam,                                          FRAMEINFO * const reference,
                     const IMAGE * const pRef,  
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,
                     IMAGE * const pCurrent,  
40                          const uint32_t iLimit);                          const uint32_t iLimit);
41    
   
42  /** MBMotionCompensation **/  /** MBMotionCompensation **/
43  void MBMotionCompensation(  
44                          MACROBLOCK * const pMB,  void
45                      const uint32_t j,  MBMotionCompensation(MACROBLOCK * const mb,
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[][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);
61    
62  /** MBTransQuant.c **/  /** MBTransQuant.c **/
63    
64    
65  void MBTransQuantIntra(const MBParam *pParam,  void MBTransQuantIntra(const MBParam * const pParam,
66                                            const FRAMEINFO * const frame,
67                                            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[][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[][64],     /* <-> the quantized DCT coefficients */                                          int16_t qcoeff[6 * 64]);        /* <-> the quantized DCT coefficients */
                        IMAGE * const pCurrent         /* <-> the reconstructed image ( function will update one  
                                                                             MB in it with data from data[] ) */  
 );  
72    
73    uint8_t MBTransQuantInter(const MBParam * const pParam,
74                                                    const FRAMEINFO * const frame,
75                                                    MACROBLOCK * const pMB,
76                                                    const uint32_t x_pos,
77                                                    const uint32_t y_pos,
78                                                    int16_t data[6 * 64],
79                                                    int16_t qcoeff[6 * 64]);
80    
81    uint8_t MBTransQuantInterBVOP(const MBParam * pParam,
82                                                      FRAMEINFO * frame,
83                                                      MACROBLOCK * pMB,
84                                                      const uint32_t x_pos,
85                                                      const uint32_t y_pos,
86                                                      int16_t data[6 * 64],
87                                                      int16_t qcoeff[6 * 64]);
88    
89    
90    typedef uint32_t (MBFIELDTEST) (int16_t data[6 * 64]);  /* function pointer for field test */
91    typedef MBFIELDTEST *MBFIELDTEST_PTR;
92    
93    /* global field test pointer for xvid.c */
94    extern MBFIELDTEST_PTR MBFieldTest;
95    
96    /* field test implementations */
97    MBFIELDTEST MBFieldTest_c;
98    MBFIELDTEST MBFieldTest_mmx;
99    
100  uint8_t MBTransQuantInter(const MBParam *pParam, /* <-- the parameter for DCT transformation  void MBFrameToField(int16_t data[6 * 64]);      /* de-interlace vertical Y blocks */
                                                                                                    and Quantization */  
                            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[][64],   /* <-> the data of the MB to be coded */  
                            int16_t qcoeff[][64], /* <-> the quantized DCT coefficients */  
                            IMAGE * const pCurrent                /* <-> the reconstructed image ( function will  
                                                                     update one MB in it with data from data[] ) */  
 );  
101    
102    
103  /** MBCoding.c **/  /** MBCoding.c **/
104    
105  void MBCoding(const MBParam *pParam,             /* <-- 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[][64],              /* <-- the quantized DCT coefficients */                          int16_t qcoeff[6 * 64], /* <-- the quantized DCT coefficients */
108                Bitstream * bs,                    /* <-> the bitstream */                Bitstream * bs,                    /* <-> the bitstream */
109                Statistics * pStat                 /* <-> statistical data collected for current frame */                          Statistics * pStat);    /* <-> statistical data collected for current frame */
     );  
110    
111  #endif  #endif

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

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