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

多媒体编程

开发平台:

Visual C++

  1. /* ***** BEGIN LICENSE BLOCK *****
  2. *
  3. * $Id: comp_compress.h,v 1.2 2005/01/30 05:11:41 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), Scott R Ladd
  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 _COMP_COMPRESS_H_
  38. #define _COMP_COMPRESS_H_
  39. #include "libdirac_common/arrays.h"
  40. #include "libdirac_common/wavelet_utils.h"
  41. #include "libdirac_common/common.h"
  42. namespace dirac
  43. {
  44.     //! Compress a frame component
  45.     /*!
  46.         This class compresses one of the three components (Y, U, or V) of a
  47.         frame according to a given set or parameters. CompCompressor is used
  48.         by FrameCompressor.
  49.     */
  50.     class CompCompressor
  51.     {
  52.     public:
  53.         //! Constructor
  54.         /*!
  55.             Create and initialize a component compressor with the given
  56.             characteristics.
  57.             param  encp    encoding parameters
  58.             param  fp      frame parameters
  59.         */
  60.         CompCompressor( EncoderParams & encp, const FrameParams& fp);
  61.         //! Compress a frame component
  62.         /*!
  63.             Compress a PicArray containing a frame component (Y, U, or V).
  64.             param  pic_data    the component data to be compressed
  65.         */
  66.         void Compress(PicArray & pic_data);
  67.     private:
  68.         //! Copy constructor is private and body-less. This class should not be copied.
  69.         CompCompressor(const CompCompressor& cpy);
  70.         //! Assignment = is private and body-less. This class should not be assigned.
  71.         CompCompressor& operator=(const CompCompressor& rhs);
  72.         void GenQuantList();
  73.         void SelectQuantisers( PicArray& pic_data , SubbandList& bands ,
  74.                                OneDArray<unsigned int>& est_counts );
  75.         int SelectQuant(PicArray& pic_data,SubbandList& bands,int band_num);
  76.         ValueType PicAbsMax(const PicArray& pic_data,int xp, int yp ,int xl ,int yl) const;
  77.         ValueType PicAbsMax(const PicArray& pic_data) const;
  78.         void SetToVal(PicArray& pic_data,const Subband& node,ValueType val);
  79.         void AddSubAverage(PicArray& pic_data,int xl,int yl,AddOrSub dirn);
  80.         //member variables
  81.         EncoderParams& m_encparams;
  82.         const FrameParams& m_fparams;
  83.         const FrameSort& m_fsort;    
  84.         const ChromaFormat& m_cformat;
  85.         CompSort m_csort;
  86.         OneDArray<int> m_qflist;
  87.         OneDArray<int> m_qfinvlist;
  88.         OneDArray<int> m_offset;
  89.         float m_lambda;
  90.     };
  91. } // namespace dirac
  92. #endif