me_subpel.h
上传用户:xjjlds
上传日期:2015-12-05
资源大小:22823k
文件大小:4k
源码类别:

多媒体编程

开发平台:

Visual C++

  1. /* ***** BEGIN LICENSE BLOCK *****
  2. *
  3. * $Id: me_subpel.h,v 1.2 2005/01/30 05:11:42 gabest Exp $ $Name:  $
  4. *
  5. * Version: MPL 1.1/GPL 2.0/LGPL 2.1
  6. *
  7. * The contents of this file are subject to the Mozilla Public License
  8. * Version 1.1 (the "License"); you may not use this file except in compliance
  9. * with the License. You may obtain a copy of the License at
  10. * http://www.mozilla.org/MPL/
  11. *
  12. * Software distributed under the License is distributed on an "AS IS" basis,
  13. * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for
  14. * the specific language governing rights and limitations under the License.
  15. *
  16. * The Original Code is BBC Research and Development code.
  17. *
  18. * The Initial Developer of the Original Code is the British Broadcasting
  19. * Corporation.
  20. * Portions created by the Initial Developer are Copyright (C) 2004.
  21. * All Rights Reserved.
  22. *
  23. * Contributor(s): Thomas Davies (Original Author)
  24. *
  25. * Alternatively, the contents of this file may be used under the terms of
  26. * the GNU General Public License Version 2 (the "GPL"), or the GNU Lesser
  27. * Public License Version 2.1 (the "LGPL"), in which case the provisions of
  28. * the GPL or the LGPL are applicable instead of those above. If you wish to
  29. * allow use of your version of this file only under the terms of the either
  30. * the GPL or LGPL and not to allow others to use your version of this file
  31. * under the MPL, indicate your decision by deleting the provisions above
  32. * and replace them with the notice and other provisions required by the GPL
  33. * or LGPL. If you do not delete the provisions above, a recipient may use
  34. * your version of this file under the terms of any one of the MPL, the GPL
  35. * or the LGPL.
  36. * ***** END LICENSE BLOCK ***** */
  37. #ifndef _ME_SUBPEL_H_
  38. #define _ME_SUBPEL_H_
  39. #include <libdirac_common/common.h>
  40. #include <libdirac_common/motion.h>
  41. #include <libdirac_motionest/block_match.h>
  42. namespace dirac
  43. {
  44.     class FrameBuffer;
  45.     class MvData;
  46.     class PicArray;
  47.     
  48.     //! The SubpelRefine class takes pixel-accurate motion vectors and refines them to 1/8-pixel accuracy
  49.     /*!
  50.         The SubpelRefine class takes pixel-accurate motion vectors and refines
  51.         them to 1/8-pixel accuracy. It uses references upconverted by a factor
  52.         of 2 in each dimension, with the remaining precision gained by doing
  53.         linear interpolation between values on-the-fly.
  54.      */
  55.     class SubpelRefine
  56.     {
  57.     
  58.     public:
  59.         //! Constructor
  60.         /*!
  61.             The constructor initialises the encoder parameters.
  62.             param    cp    the parameters used for controlling encoding
  63.          */
  64.         SubpelRefine(const EncoderParams& cp);
  65.     
  66.         //! Destructor
  67.         ~SubpelRefine(){}
  68.     
  69.         //! Does the actual sub-pixel refinement
  70.         /*!
  71.             Does the actual sub-pixel refinement.
  72.             param    my_buffer    the buffer of pictures being used
  73.             param    frame_num    the frame number on which motion estimation is being performed
  74.             param    me_data    the motion vector data, into which the results will be written
  75.          */
  76.         void DoSubpel( const FrameBuffer& my_buffer , int frame_num , MEData& me_data );
  77.     
  78.     private:
  79.         //! Private, body-less copy constructor: this class should not be copied
  80.         SubpelRefine( const SubpelRefine& cpy );
  81.     
  82.         //! Private, body-less assignment=: this class should not be assigned
  83.         SubpelRefine& operator=( const SubpelRefine& rhs );
  84.     
  85.         //! Match a picture from its (upconverted) reference, and record the block mvs
  86.         void MatchPic(const PicArray& pic_data , const PicArray& refup_data , MEData& me_data ,
  87.                                  int ref_id);
  88.     
  89.         //! Match an individual block
  90.         void DoBlock( const int xblock , const int yblock , 
  91.                       BlockMatcher& my_bmatch, MEData& me_data , const int ref_id );
  92.     
  93.         //! Get a prediction for a block MV from the neighbouring blocks
  94.         MVector GetPred( int xblock , int yblock , const MvArray& mvarray );
  95.     
  96.         //member variables
  97.     
  98.         //! A local reference to the encoder params
  99.         const EncoderParams& m_encparams;
  100.     
  101.         //! The list of candidate vectors being tested
  102.         CandidateList m_cand_list;
  103.     
  104.         //! The relative coords of the set of neighbours used to generate MV predictions
  105.         OneDArray<ImageCoords> m_nshift;
  106.     
  107.     
  108.     
  109.     };
  110. } // namespace dirac
  111. #endif