source: 3DVCSoftware/branches/HTM-4.0.1-VSP-dev0/source/Lib/TLibCommon/TComDepthMapGenerator.h @ 1417

Last change on this file since 1417 was 213, checked in by mitsubishi-htm, 12 years ago

A final release, as planned

  • Migrate to HTM 5.1
  • For VC project files, only VC9 file is updated
  • To be used as an additional anchor for CE1.h for 3rd JCTVC meeting at Geneva
  • Property svn:eol-style set to native
File size: 12.3 KB
Line 
1/* The copyright in this software is being made available under the BSD
2 * License, included below. This software may be subject to other third party
3 * and contributor rights, including patent rights, and no such rights are
4 * granted under this license.
5 *
6 * Copyright (c) 2010-2011, ISO/IEC
7 * All rights reserved.
8 *
9 * Redistribution and use in source and binary forms, with or without
10 * modification, are permitted provided that the following conditions are met:
11 *
12 *  * Redistributions of source code must retain the above copyright notice,
13 *    this list of conditions and the following disclaimer.
14 *  * Redistributions in binary form must reproduce the above copyright notice,
15 *    this list of conditions and the following disclaimer in the documentation
16 *    and/or other materials provided with the distribution.
17 *  * Neither the name of the ISO/IEC nor the names of its contributors may
18 *    be used to endorse or promote products derived from this software without
19 *    specific prior written permission.
20 *
21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
22 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS
25 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
26 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
27 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
28 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
29 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
30 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
31 * THE POSSIBILITY OF SUCH DAMAGE.
32 */
33
34
35
36/** \file     TComDepthMapGenerator.h
37    \brief    depth map generator class (header)
38*/
39
40
41#ifndef __TCOM_DEPTH_MAP_GENERATOR__
42#define __TCOM_DEPTH_MAP_GENERATOR__
43
44
45#include "CommonDef.h"
46#include "TComPic.h"
47#include "TComPrediction.h"
48#include "TComSlice.h"
49
50
51#if DEPTH_MAP_GENERATION
52#if VIDYO_VPS_INTEGRATION
53class TComVPSAccess // would be better to have a real VPS buffer
54{
55public:
56  TComVPSAccess ()  { clear(); }
57  ~TComVPSAccess()  {}
58
59  Void      clear   ()                                { ::memset( m_aacVPS, 0x00, sizeof( m_aacVPS ) ); m_uiActiceVPSId = 0;}
60  Void      addVPS  ( TComVPS* pcVPS )                { m_aacVPS[ pcVPS->getVPSId() ] = pcVPS; }
61  TComVPS*  getVPS  ( UInt uiVPSId )                  { return m_aacVPS[ uiVPSId ]; }
62  TComVPS*  getActiveVPS  ( )                         { return m_aacVPS[ m_uiActiceVPSId ]; }
63  Void      setActiveVPSId  ( UInt activeVPSId )      { m_uiActiceVPSId = activeVPSId; }
64private:
65  TComVPS*  m_aacVPS[ MAX_NUM_VPS ];
66  UInt      m_uiActiceVPSId;
67};
68#endif
69
70class TComSPSAccess // would be better to have a real SPS buffer
71{
72public:
73  TComSPSAccess ()  { clear(); }
74  ~TComSPSAccess()  {}
75
76  Void      clear   ()                            { ::memset( m_aacActiveSPS, 0x00, sizeof( m_aacActiveSPS ) ); }
77  Void      addSPS  ( TComSPS* pcSPS    )         { m_aacActiveSPS[ pcSPS->isDepth() ? 1 : 0 ][ pcSPS->getViewId() ] = pcSPS; }
78  TComSPS*  getSPS  ( UInt     uiViewId, 
79                      Bool     bIsDepth = false ) { return m_aacActiveSPS[ bIsDepth ? 1 : 0 ][ uiViewId ]; }
80
81  UInt      getPdm  ()                            { if( m_aacActiveSPS[0][1] ) { return m_aacActiveSPS[0][1]->getPredDepthMapGeneration(); } return 0; }
82#if HHI_INTER_VIEW_RESIDUAL_PRED
83  UInt      getResPrd ()                          { if( m_aacActiveSPS[0][1] ) { return m_aacActiveSPS[0][1]->getMultiviewResPredMode  (); } return 0; }
84#endif
85
86private:
87  TComSPS*  m_aacActiveSPS[ 2 ][ MAX_VIEW_NUM ];
88};
89
90
91
92class TComAUPicAccess // would be better to have a real decoded picture buffer
93{
94public:
95  TComAUPicAccess () : m_iLastPoc( 0 ), m_uiMaxViewId( 0 ) { clear(); }
96  ~TComAUPicAccess()                   {}
97
98  Void      clear   ()                            { ::memset( m_aacCurrAUPics, 0x00, sizeof( m_aacCurrAUPics ) ); }
99  Void      addPic    ( TComPic* pcPic    )         { if( m_iLastPoc != pcPic->getPOC() ) 
100                                                      { 
101                                                        clear(); 
102                                                        m_iLastPoc = pcPic->getPOC(); 
103                                                      } 
104                                                      m_aacCurrAUPics[ pcPic->getSPS()->isDepth() ? 1 : 0 ][ pcPic->getSPS()->getViewId() ] = pcPic; 
105                                                      if( pcPic->getSPS()->getViewId() > m_uiMaxViewId )
106                                                      {
107                                                        m_uiMaxViewId = pcPic->getSPS()->getViewId();
108                                                      }
109                                                    }
110  TComPic*  getPic  ( UInt     uiViewId,
111                      Bool     bIsDepth = false ) { return m_aacCurrAUPics[ bIsDepth ? 1 : 0 ][ uiViewId ]; }
112  UInt      getMaxVId ()                            { return m_uiMaxViewId; }
113
114private:
115  Int       m_iLastPoc;
116  UInt      m_uiMaxViewId;
117  TComPic*  m_aacCurrAUPics[ 2 ][ MAX_VIEW_NUM ];
118};
119
120
121
122class TComDepthMapGenerator
123{
124public:
125  TComDepthMapGenerator ();
126  ~TComDepthMapGenerator();
127
128  Void  create                ( Bool bDecoder, UInt uiPicWidth, UInt uiPicHeight, UInt uiMaxCUDepth, UInt uiMaxCUWidth, UInt uiMaxCUHeight, UInt uiOrgBitDepth, UInt uiSubSampExpX, UInt uiSubSampExpY );
129  Void  destroy               ();
130
131#if VIDYO_VPS_INTEGRATION
132  Void  init( TComPrediction* pcPrediction, TComVPSAccess* pcVPSAccess, TComSPSAccess* pcSPSAccess, TComAUPicAccess* pcAUPicAccess );
133#endif
134  Void  init                  ( TComPrediction* pcPrediction, TComSPSAccess* pcSPSAccess, TComAUPicAccess* pcAUPicAccess );
135  Void  uninit                ();
136
137  Void  initViewComponent     ( TComPic*      pcPic );
138#if !QC_MULTI_DIS_CAN_A0097
139  Bool  predictDepthMap       ( TComPic*      pcPic );
140  Void  updateDepthMap        ( TComPic*      pcPic );
141  Void  dumpDepthMap          ( TComPic*      pcPic, char* pFilenameBase );
142#if VSP_N
143  Void  clearDepthMap         ( TComPic*      pcPic, Int   iVal  = PDM_UNDEFINED_DEPTH);
144#endif
145#endif
146
147#if HHI_INTER_VIEW_MOTION_PRED
148  Void  covertOrgDepthMap     ( TComPic*      pcPic );
149#endif
150
151  UInt  getBaseViewId         ( UInt          uiIdx ) { AOF( uiIdx < m_auiBaseIdList.size() );  return m_auiBaseIdList[uiIdx]; }
152  UInt  getSubSampExpX        ()                      { return m_uiSubSampExpX; }
153  UInt  getSubSampExpY        ()                      { return m_uiSubSampExpY; }
154  Int   getDisparity          ( TComPic*      pcPic, Int iPosX, Int iPosY, UInt uiRefViewId );
155#if HHI_INTER_VIEW_MOTION_PRED
156#if QC_MULTI_DIS_CAN_A0097
157  Int   getPdmMergeCandidate ( TComDataCU*   pcCU, UInt uiPartIdx, Int* paiPdmRefIdx, TComMv* pacPdmMv, DisInfo* pDInfo
158#if QC_MRG_CANS_B0048
159    , Int* iPdm
160#endif
161    );
162
163  Bool  getPdmMvPredDisCan    ( TComDataCU*   pcCU, UInt uiPartIdx, RefPicList eRefPicList, Int iRefIdx, TComMv& rcMv, DisInfo* pDInfo, Bool bMerge );
164  Bool  getDisCanPdmMvPred    ( TComDataCU*   pcCU, UInt uiPartIdx, RefPicList eRefPicList, Int iRefIdx, TComMv& rcMv, DisInfo* pDInfo, Bool bMerge );
165#else
166  Int   getPdmMergeCandidate  ( TComDataCU*   pcCU, UInt uiPartIdx, Int* paiPdmRefIdx, TComMv* pacPdmMv );
167  Bool  getPdmMvPred          ( TComDataCU*   pcCU, UInt uiPartIdx, RefPicList eRefPicList, Int iRefIdx, TComMv& rcMv, Bool bMerge );
168#endif
169  Bool  getIViewOrgDepthMvPred( TComDataCU*   pcCU, UInt uiPartIdx, RefPicList eRefPicList, Int iRefIdx, TComMv& rcMv );
170#endif
171
172  TComPrediction*   getPrediction ()  { return m_pcPrediction;  }
173#if VIDYO_VPS_INTEGRATION
174  TComVPSAccess*    getVPSAccess  ()  { return m_pcVPSAccess;   }
175#endif
176  TComSPSAccess*    getSPSAccess  ()  { return m_pcSPSAccess;   }
177  TComAUPicAccess*  getAUPicAccess()  { return m_pcAUPicAccess; }
178
179private:
180  // picture operations
181#if !QC_MULTI_DIS_CAN_A0097
182  Bool  xConvertDepthMapCurr2Ref  ( TComPic*    pcRef, TComPic* pcCur );
183  Bool  xConvertDepthMapRef2Curr  ( TComPic*    pcCur, TComPic* pcRef );
184  Bool  xPredictDepthMap          ( TComPic*    pcPic );
185  Bool  xFillDepthMapHoles        ( TComPic*    pcPic );
186  Void  xClearDepthMap            ( TComPic*    pcPic, Int      iVal  = PDM_UNDEFINED_DEPTH
187#if PDM_REMOVE_DEPENDENCE
188  ,
189  Int forFirstNonBaseView = 0
190#endif
191  );
192  Void  xSetChroma                ( TComPicYuv* pcPic, Int      iVal  );
193
194  // CU operations 
195  Void  xPredictCUDepthMap        ( TComDataCU* pcCU, UInt uiDepth, UInt uiAbsPartIdx );                            // CU depth map prediction
196  Void  xIntraPredictCUDepthMap   ( TComDataCU* pcCU, TComYuv* pcCUDepthMap );                                      // CU intra prediction
197  Void  xInterPredictCUDepthMap   ( TComDataCU* pcCU, TComYuv* pcCUDepthMap );                                      // CU inter prediction
198 
199  // PU and block operations 
200  Void  xIntraPredictBlkDepthMap  ( TComDataCU* pcCU, TComYuv* pcCUDepthMap, UInt uiAbsPartIdx, UInt uiTrDepth );   // block intra prediction
201  Void  xInterPredictPUDepthMap   ( TComDataCU* pcCU, TComYuv* pcCUDepthMap, UInt uiPartIdx );                      // PU inter prediction/update
202  Void  xIViewPUDepthMapUpdate    ( TComDataCU* pcCU, TComYuv* pcCUDepthMap, UInt uiPartIdx );                      // PU interview update
203  Void  xInterPUDepthMapUpdate    ( TComDataCU* pcCU, TComYuv* pcCUDepthMap, UInt uiPartIdx );                      // PU inter update
204  Void  xInterPUDepthMapPrediction( TComDataCU* pcCU, TComYuv* pcCUDepthMap, UInt uiPartIdx );                      // PU inter prediction
205  Bool  xGetPredDepth             ( TComDataCU* pcCU, UInt uiPartIdx, Int& riPrdDepth, Int* piPosX = 0, Int* piPosY = 0 );
206#endif
207  // conversion functions
208  Int   xGetVirtDepthFromDisparity( UInt uiBaseId, Int iDisparity )
209  {
210    AOF( uiBaseId < m_uiCurrViewId );
211    Int*   pPar = m_aaiConvParsDisparity2VirtDepth[ uiBaseId ];
212    Int    iRes = ( pPar[ 0 ] * iDisparity + pPar[ 1 ] ) >> pPar[ 2 ];
213    return iRes;
214  }
215  Int   xGetDisparityFromVirtDepth( UInt uiBaseId, Int iVirtDepth )
216  {
217    AOF( uiBaseId < m_uiCurrViewId );
218    Int*   pPar = m_aaiConvParsVirtDepth2Disparity[ uiBaseId ];
219    Int    iRes = ( pPar[ 0 ] * iVirtDepth + pPar[ 1 ] ) >> pPar[ 2 ];
220    return iRes;
221  }
222  Int   xGetVirtDepthFromOrigDepth( UInt uiViewId, Int iOrigDepth )
223  {
224    AOF( uiViewId <= m_uiCurrViewId );
225    Int*   pPar = m_aaiConvParsOrigDepth2VirtDepth[ uiViewId ];
226    Int    iRes = ( pPar[ 0 ] * iOrigDepth + pPar[ 1 ] ) >> pPar[ 2 ];
227    return iRes;
228  }
229  Int   xGetOrigDepthFromVirtDepth( UInt uiViewId, Int iVirtDepth )
230  {
231    AOF( uiViewId <= m_uiCurrViewId );
232    Int*   pPar = m_aaiConvParsVirtDepth2OrigDepth[ uiViewId ];
233    Int    iRes = ( pPar[ 0 ] * iVirtDepth + pPar[ 1 ] ) >> pPar[ 2 ];
234    return iRes;
235  }
236
237
238private:
239  // general parameters
240  Bool              m_bCreated;
241  Bool              m_bInit;
242  Bool              m_bDecoder;
243  TComPrediction*   m_pcPrediction;
244#if VIDYO_VPS_INTEGRATION|QC_MVHEVC_B0046
245  TComVPSAccess*    m_pcVPSAccess;
246#endif
247  TComSPSAccess*    m_pcSPSAccess;
248  TComAUPicAccess*  m_pcAUPicAccess;
249  UInt              m_uiMaxDepth;
250  UInt              m_uiOrgDepthBitDepth;
251  UInt              m_uiSubSampExpX;
252  UInt              m_uiSubSampExpY;
253  TComYuv**         m_ppcYuv;
254  TComDataCU**      m_ppcCU;
255  TComPicYuv        m_cTmpPic;
256
257  // conversion parameters
258  UInt              m_uiCurrViewId;
259  Bool              m_bPDMAvailable;
260  std::vector<UInt> m_auiBaseIdList;
261  Int               m_aaiConvParsDisparity2VirtDepth[ MAX_VIEW_NUM ][ 3 ];  // disparity      ==> virtual  depth   (0:scale, 1:add, 2:shift)
262  Int               m_aaiConvParsVirtDepth2Disparity[ MAX_VIEW_NUM ][ 3 ];  // virtual  depth ==> disparity        (0:scale, 1:add, 2:shift)
263  Int               m_aaiConvParsOrigDepth2VirtDepth[ MAX_VIEW_NUM ][ 3 ];  // original depth ==> virtual  depth   (0:scale, 1:add, 2:shift)
264  Int               m_aaiConvParsVirtDepth2OrigDepth[ MAX_VIEW_NUM ][ 3 ];  // virtual  depth ==> original depth   (0:scale, 1:add, 2:shift)
265
266  // temporary arrays
267  Bool              m_aabDepthSet[ MAX_CU_SIZE >> 2 ][ MAX_CU_SIZE >> 2 ];
268  Int               m_aai4x4Depth[ MAX_CU_SIZE >> 2 ][ MAX_CU_SIZE >> 2 ];
269};
270
271
272#endif // DEPTH_MAP_GENERATION
273
274#endif // __TCOM_DEPTH_MAP_GENERATOR__
275
276
277
278
Note: See TracBrowser for help on using the repository browser.