Changeset 1209 in 3DVCSoftware


Ignore:
Timestamp:
13 May 2015, 15:16:14 (10 years ago)
Author:
hhi
Message:

Alignment and reactivation of DMM and depth encoder optimizations:

  • new macro NH_3D_DMM for DMM functionality, including several clean-ups.
  • new macro NH_3D_SDC for SDC functionality, currently only used for covering common SDC and DMM parts.
  • new macro NH_3D_ENC_DEPTH for encoder optimizations related to depth.
  • temporary macro TEMP_SDC_CLEANUP for covering several proposed cleanups related to SDC and DMM.
Location:
branches/HTM-14.1-update-dev1-HHI/source
Files:
34 edited

Legend:

Unmodified
Added
Removed
  • branches/HTM-14.1-update-dev1-HHI/source/App/TAppDecoder/TAppDecTop.cpp

    r1200 r1209  
    528528  // initialize global variables
    529529  initROM(); 
    530 #if H_3D_DIM_DMM
     530#if NH_3D_DMM
    531531  initWedgeLists();
    532532#endif
  • branches/HTM-14.1-update-dev1-HHI/source/App/TAppEncoder/TAppEncCfg.cpp

    r1200 r1209  
    17731773  // allocate slice-based dQP values
    17741774#if NH_MV
    1775   for (Int i = m_layerIdInNuh.size(); i < m_numberOfLayers; i++ )
     1775  for (Int i = (Int)m_layerIdInNuh.size(); i < m_numberOfLayers; i++ )
    17761776  {
    17771777    m_layerIdInNuh.push_back( i == 0 ? 0 : m_layerIdInNuh[ i - 1 ] + 1 );
  • branches/HTM-14.1-update-dev1-HHI/source/App/TAppEncoder/TAppEncTop.cpp

    r1200 r1209  
    811811  // initialize global variables
    812812  initROM();
    813 #if H_3D_DIM_DMM
     813#if NH_3D_DMM
    814814  initWedgeLists( true );
    815815#endif
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibCommon/ContextTables.h

    r1200 r1209  
    173173#define CNU                          154      ///< dummy initialization value for unused context models 'Context model Not Used'
    174174
    175 #if H_3D_DIM
    176 #define NUM_DEPTH_INTRA_MODE_CTX      1       ///< number of context models for depth intra modes
    177 #define NUM_DDC_FLAG_CTX              2       ///< number of context models for deltaDC flag (DMM or RBC)
    178 #define NUM_DDC_DATA_CTX              1       ///< number of context models for deltaDC data (DMM or RBC)
    179 #if H_3D_DIM_DMM
    180 #define NUM_DMM1_DATA_CTX             1       ///< number of context models for DMM1 data
    181 #endif
    182 #define NUM_ANGLE_FLAG_CTX            1
    183 #endif
    184 
     175#if NH_3D_DMM
     176#define NUM_NOTDMM_FLAG_CTX           1       ///< number of context models for not-DMM flag
     177#define NUM_DMM_MODE_CTX              1       ///< number of context models for DMM modes
     178#endif
     179#if NH_3D_DMM || NH_3D_SDC
     180#define NUM_DDC_DATA_CTX              1       ///< number of context models for deltaDC data (DMM or SDC)
     181#endif
    185182#if H_3D_DIM_SDC
    186183#define SDC_NUM_RESIDUAL_FLAG_CTX     1
    187184#define SDC_NUM_RESIDUAL_CTX          1
    188185#define NUM_SDC_FLAG_CTX              1      ///< number of context
     186#define NUM_DDC_FLAG_CTX              2       ///< number of context models for deltaDC flag (SDC only)
    189187#endif
    190188#if H_3D_DBBP
     
    562560
    563561#endif
    564 #if H_3D_DIM
    565 static const UChar
    566 INIT_DEPTH_INTRA_MODE[3][NUM_DEPTH_INTRA_MODE_CTX] =
    567 {
    568   { 154, },
    569   { 154, },
    570   { 154, }
    571 };
    572 
     562
     563#if NH_3D_DMM
    573564static const UChar
    574 INIT_ANGLE_FLAG[3][NUM_ANGLE_FLAG_CTX] =
     565INIT_NOTDMM_FLAG[3][NUM_NOTDMM_FLAG_CTX] =
    575566{
    576567  { 154 },
     
    578569  { 155 },
    579570};
    580 
     571static const UChar
     572INIT_DMM_MODE[3][NUM_DMM_MODE_CTX] =
     573{
     574  { CNU },
     575  { CNU },
     576  { CNU }
     577};
     578#endif
     579#if NH_3D_DMM || NH_3D_SDC
     580static const UChar
     581INIT_DDC_DATA[3][NUM_DDC_DATA_CTX] =
     582{
     583  { CNU },
     584  { CNU },
     585  { CNU },
     586};
     587#endif
     588#if H_3D_DIM_SDC
     589static const UChar
     590INIT_SDC_RESIDUAL_FLAG[3][SDC_NUM_RESIDUAL_FLAG_CTX] =
     591{
     592  { CNU },
     593  { CNU },
     594  { CNU },
     595};
     596static const UChar
     597INIT_SDC_RESIDUAL[3][SDC_NUM_RESIDUAL_CTX] =
     598{
     599  { 155 },
     600  { 155 },
     601  { 155 },
     602};
     603static const UChar
     604INIT_SDC_FLAG[3][NUM_SDC_FLAG_CTX] =
     605{
     606  { 154 }, 
     607  { 154 },
     608  { 154 },
     609};
    581610static const UChar
    582611INIT_DDC_FLAG[3][NUM_DDC_FLAG_CTX] =
     
    586615  {64, CNU}
    587616};
    588 static const UChar
    589 INIT_DDC_DATA[3][NUM_DDC_DATA_CTX] =
    590 {
    591   { 154 },
    592   { 154 },
    593   { 154 },
    594 };
    595 #if H_3D_DIM_DMM
    596 static const UChar
    597 INIT_DMM1_DATA[3][NUM_DMM1_DATA_CTX] =
    598 {
    599   { CNU },
    600   { CNU },
    601   { CNU },
    602 };
    603 #endif
    604 #if H_3D_DIM_SDC
    605 static const UChar
    606 INIT_SDC_RESIDUAL_FLAG[3][SDC_NUM_RESIDUAL_FLAG_CTX] =
    607 {
    608   { CNU },
    609   { CNU },
    610   { CNU },
    611 };
    612 static const UChar
    613 INIT_SDC_RESIDUAL[3][SDC_NUM_RESIDUAL_CTX] =
    614 {
    615   { 155 },
    616   { 155 },
    617   { 155 },
    618 };
    619 #endif
    620 #endif
    621 #if H_3D_DIM_SDC
    622 static const UChar
    623 INIT_SDC_FLAG[3][NUM_SDC_FLAG_CTX] =
    624 {
    625   { 154 }, 
    626   { 154 },
    627   { 154 },
    628 };
    629 #endif
    630 
     617#endif
    631618#if H_3D_DBBP
    632619static const UChar INIT_DBBP_FLAG[3][DBBP_NUM_FLAG_CTX] =
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibCommon/TComCodingStatistics.h

    r1200 r1209  
    9292  STATS__CABAC_BITS__ALIGNED_SIGN_BIT,
    9393  STATS__CABAC_BITS__ALIGNED_ESCAPE_BITS,
     94
     95#if NH_3D_DMM || H_3D_DIM_SDC || H_3D_INTER_SDC
     96  STATS__CABAC_BITS__DELTADC_SIGN_EP,
     97  STATS__CABAC_BITS__DELTADC_PREFIX,
     98  STATS__CABAC_BITS__DELTADC_SUFFIX_EP,
     99#endif
     100#if NH_3D_DMM
     101  STATS__CABAC_BITS__NOTDMM_FLAG,
     102  STATS__CABAC_BITS__DMMMODE,
     103  STATS__CABAC_BITS__DMM1_BITS_EP,
     104#endif
     105
    94106  STATS__NUM_STATS
    95107};
     
    142154    "CABAC_BITS__ALIGNED_SIGN_BIT",
    143155    "CABAC_BITS__ALIGNED_ESCAPE_BITS"
     156#if NH_3D_DMM || H_3D_DIM_SDC || H_3D_INTER_SDC
     157   ,"STATS__CABAC_BITS__DELTADC_SIGN_EP"
     158   ,"STATS__CABAC_BITS__DELTADC_PREFIX"
     159   ,"STATS__CABAC_BITS__DELTADC_SUFFIX_EP"
     160#endif
     161#if NH_3D_DMM
     162   ,"STATS__CABAC_BITS__NOTDMM_FLAG"
     163   ,"STATS__CABAC_BITS__DMMMODE"
     164   ,"STATS__CABAC_BITS__DMM1_BITS_EP"
     165#endif
    144166  };
    145167  assert(STATS__NUM_STATS == sizeof(statNames)/sizeof(Char *) && name < STATS__NUM_STATS);
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibCommon/TComDataCU.cpp

    r1200 r1209  
    104104  }
    105105
    106 #if H_3D_DIM
    107   for( Int i = 0; i < DIM_NUM_TYPE; i++ )
    108   {
    109     m_dimDeltaDC[i][0] = NULL;
    110     m_dimDeltaDC[i][1] = NULL;
    111   }
    112 #if H_3D_DIM_DMM
    113   for( Int i = 0; i < DMM_NUM_TYPE; i++ )
    114   {
    115     m_dmmWedgeTabIdx[i] = NULL;
    116   }
     106#if NH_3D_DMM
     107  for( Int i = 0; i < NUM_DMM; i++ )
     108  {
     109    m_dmmDeltaDC[i][0] = NULL;
     110    m_dmmDeltaDC[i][1] = NULL;
     111  }
     112  m_dmm1WedgeTabIdx = NULL;
    117113#endif
    118114#if H_3D_DIM_SDC
     
    120116  m_apSegmentDCOffset[0]  = NULL;
    121117  m_apSegmentDCOffset[1]  = NULL;
    122 #endif
    123118#endif
    124119
     
    255250    m_pbICFlag           = (Bool* )xMalloc(Bool,   uiNumPartition);
    256251#endif
    257 #if H_3D_DIM
    258     for( Int i = 0; i < DIM_NUM_TYPE; i++ )
    259     {
    260       m_dimDeltaDC[i][0] = (Pel* )xMalloc(Pel, uiNumPartition);
    261       m_dimDeltaDC[i][1] = (Pel* )xMalloc(Pel, uiNumPartition);
    262     }
    263 #if H_3D_DIM_DMM
    264     for( Int i = 0; i < DMM_NUM_TYPE; i++ )
    265     {
    266       m_dmmWedgeTabIdx[i]    = (UInt*)xMalloc(UInt, uiNumPartition);
    267     }
     252#if NH_3D_DMM
     253    for( Int i = 0; i < NUM_DMM; i++ )
     254    {
     255      m_dmmDeltaDC[i][0] = (Pel* )xMalloc(Pel, uiNumPartition);
     256      m_dmmDeltaDC[i][1] = (Pel* )xMalloc(Pel, uiNumPartition);
     257    }
     258    m_dmm1WedgeTabIdx    = (UInt*)xMalloc(UInt, uiNumPartition);
    268259#endif
    269260#if H_3D_DIM_SDC
     
    271262    m_apSegmentDCOffset[0]  = (Pel*)xMalloc(Pel, uiNumPartition);
    272263    m_apSegmentDCOffset[1]  = (Pel*)xMalloc(Pel, uiNumPartition);
    273 #endif
    274264#endif
    275265#if H_3D_DBBP
     
    475465#endif
    476466
    477 #if H_3D_DIM
    478     for( Int i = 0; i < DIM_NUM_TYPE; i++ )
    479     {
    480       if ( m_dimDeltaDC[i][0] ) { xFree( m_dimDeltaDC[i][0] ); m_dimDeltaDC[i][0] = NULL; }
    481       if ( m_dimDeltaDC[i][1] ) { xFree( m_dimDeltaDC[i][1] ); m_dimDeltaDC[i][1] = NULL; }
    482     }
    483 #if H_3D_DIM_DMM
    484     for( Int i = 0; i < DMM_NUM_TYPE; i++ )
    485     {
    486       if ( m_dmmWedgeTabIdx[i] ) { xFree( m_dmmWedgeTabIdx[i] ); m_dmmWedgeTabIdx[i] = NULL; }
    487     }
     467#if NH_3D_DMM
     468    for( Int i = 0; i < NUM_DMM; i++ )
     469    {
     470      if ( m_dmmDeltaDC[i][0] ) { xFree( m_dmmDeltaDC[i][0] ); m_dmmDeltaDC[i][0] = NULL; }
     471      if ( m_dmmDeltaDC[i][1] ) { xFree( m_dmmDeltaDC[i][1] ); m_dmmDeltaDC[i][1] = NULL; }
     472    }
     473    if ( m_dmm1WedgeTabIdx    ) { xFree( m_dmm1WedgeTabIdx );  m_dmm1WedgeTabIdx = NULL;  }
    488474#endif
    489475#if H_3D_DIM_SDC
     
    491477    if ( m_apSegmentDCOffset[0] ) { xFree(m_apSegmentDCOffset[0]);  m_apSegmentDCOffset[0]  = NULL; }
    492478    if ( m_apSegmentDCOffset[1] ) { xFree(m_apSegmentDCOffset[1]);  m_apSegmentDCOffset[1]  = NULL; }
    493 #endif   
    494479#endif   
    495480#if H_3D_DBBP
     
    659644
    660645
    661 #if H_3D_DIM
    662     for( Int i = 0; i < DIM_NUM_TYPE; i++ )
    663     {
    664       memset( m_dimDeltaDC[i][0] + firstElement, 0,                       numElements * sizeof( *m_dimDeltaDC[i][0] ) );
    665       memset( m_dimDeltaDC[i][1] + firstElement, 0,                       numElements * sizeof( *m_dimDeltaDC[i][1] ) );
    666     }
    667 #if H_3D_DIM_DMM
    668     for( Int i = 0; i < DMM_NUM_TYPE; i++ )
    669     {
    670       memset( m_dmmWedgeTabIdx[i] + firstElement, 0,                      numElements * sizeof( *m_dmmWedgeTabIdx[i] ) );
    671     }
     646
     647#if NH_3D_DMM
     648  for( Int i = 0; i < NUM_DMM; i++ )
     649  {
     650    memset( m_dmmDeltaDC[i][0], 0,                        m_uiNumPartition * sizeof( *m_dmmDeltaDC[i][0] ) );
     651    memset( m_dmmDeltaDC[i][1], 0,                        m_uiNumPartition * sizeof( *m_dmmDeltaDC[i][1] ) );
     652  }
     653  memset( m_dmm1WedgeTabIdx,    0,                        m_uiNumPartition * sizeof( *m_dmm1WedgeTabIdx   ) );
    672654#endif
    673655#if H_3D_DIM_SDC
     
    675657    memset( m_apSegmentDCOffset[0]  + firstElement,     0,                numElements * sizeof( *m_apSegmentDCOffset[0] ) );
    676658    memset( m_apSegmentDCOffset[1]  + firstElement,     0,                numElements * sizeof( *m_apSegmentDCOffset[1] ) );
    677 #endif
     659#if !TEMP_SDC_CLEANUP // PM: should be obsolete after cleanup
    678660    m_apDmmPredictor[0] = 0;
    679661    m_apDmmPredictor[1] = 0;
     662#endif
    680663#endif
    681664#if H_3D_DBBP
     
    820803
    821804
    822 #if H_3D_DIM
    823       for( Int i = 0; i < DIM_NUM_TYPE; i++ )
    824       {
    825         m_dimDeltaDC[i][0] [ui] = 0;
    826         m_dimDeltaDC[i][1] [ui] = 0;
    827       }
    828 #if H_3D_DIM_DMM
    829       for( Int i = 0; i < DMM_NUM_TYPE; i++ )
    830       {
    831         m_dmmWedgeTabIdx[i] [ui] = 0;
    832       }
     805#if NH_3D_DMM
     806    for( Int i = 0; i < NUM_DMM; i++ )
     807    {
     808      m_dmmDeltaDC[i][0] [ui] = 0;
     809      m_dmmDeltaDC[i][1] [ui] = 0;
     810    }
     811    m_dmm1WedgeTabIdx    [ui] = 0;
    833812#endif
    834813#if H_3D_DIM_SDC
     
    836815      m_apSegmentDCOffset[0][ui] = 0;
    837816      m_apSegmentDCOffset[1][ui] = 0;
    838 #endif
     817#if !TEMP_SDC_CLEANUP // PM: should be obsolete after cleanup
    839818      m_apDmmPredictor[0] = 0;
    840819      m_apDmmPredictor[1] = 0;
     820#endif
    841821#endif
    842822#if H_3D_DBBP
     
    929909  memset( m_pbICFlag,          0, iSizeInBool  );
    930910#endif
    931 #if H_3D_DIM
    932   for( Int i = 0; i < DIM_NUM_TYPE; i++ )
    933   {
    934     memset( m_dimDeltaDC[i][0], 0, sizeof(Pel ) * m_uiNumPartition );
    935     memset( m_dimDeltaDC[i][1], 0, sizeof(Pel ) * m_uiNumPartition );
    936   }
    937 #if H_3D_DIM_DMM
    938   for( Int i = 0; i < DMM_NUM_TYPE; i++ )
    939   {
    940     memset( m_dmmWedgeTabIdx[i], 0, sizeof(UInt) * m_uiNumPartition );
    941   }
     911#if NH_3D_DMM
     912  for( Int i = 0; i < NUM_DMM; i++ )
     913  {
     914    memset( m_dmmDeltaDC[i][0], 0, sizeof(Pel ) * m_uiNumPartition );
     915    memset( m_dmmDeltaDC[i][1], 0, sizeof(Pel ) * m_uiNumPartition );
     916  }
     917  memset( m_dmm1WedgeTabIdx,    0, sizeof(UInt) * m_uiNumPartition );
    942918#endif
    943919#if H_3D_DIM_SDC
     
    945921  memset( m_apSegmentDCOffset[0], 0, sizeof(Pel) * m_uiNumPartition   );
    946922  memset( m_apSegmentDCOffset[1], 0, sizeof(Pel) * m_uiNumPartition   );
    947 #endif
     923#if !TEMP_SDC_CLEANUP // PM: should be obsolete after cleanup
    948924  m_apDmmPredictor[0] = 0;
    949925  m_apDmmPredictor[1] = 0;
     926#endif
    950927#endif
    951928#if H_3D_DBBP
     
    989966      m_pbICFlag          [ui] = pcCU->m_pbICFlag[uiPartOffset+ui];
    990967#endif
    991 #if H_3D_DIM
    992       for( Int i = 0; i < DIM_NUM_TYPE; i++ )
    993       {
    994         m_dimDeltaDC[i][0] [ui] = pcCU->m_dimDeltaDC[i][0] [uiPartOffset+ui];
    995         m_dimDeltaDC[i][1] [ui] = pcCU->m_dimDeltaDC[i][1] [uiPartOffset+ui];
    996       }
    997 #if H_3D_DIM_DMM
    998       for( Int i = 0; i < DMM_NUM_TYPE; i++ )
    999       {
    1000         m_dmmWedgeTabIdx[i] [ui] = pcCU->m_dmmWedgeTabIdx[i] [uiPartOffset+ui];
    1001       }
     968#if NH_3D_DMM
     969  for( Int i = 0; i < NUM_DMM; i++ )
     970  {
     971    m_dmmDeltaDC[i][0] [ui] = pcCU->m_dmmDeltaDC[i][0] [uiPartOffset+ui];
     972    m_dmmDeltaDC[i][1] [ui] = pcCU->m_dmmDeltaDC[i][1] [uiPartOffset+ui];
     973  }
     974  m_dmm1WedgeTabIdx    [ui] = pcCU->m_dmm1WedgeTabIdx  [uiPartOffset+ui];
    1002975#endif
    1003976#if H_3D_DIM_SDC
     
    1005978      m_apSegmentDCOffset[0][ui] = pcCU->m_apSegmentDCOffset[0] [ uiPartOffset + ui ];
    1006979      m_apSegmentDCOffset[1][ui] = pcCU->m_apSegmentDCOffset[1] [ uiPartOffset + ui ];
    1007 #endif
    1008980#endif
    1009981#if H_3D_DBBP
     
    11121084    m_explicitRdpcmMode[comp]             = pcCU->getExplicitRdpcmMode(ComponentID(comp))             + uiPart;
    11131085  }
    1114 #if H_3D_DIM
    1115   for( Int i = 0; i < DIM_NUM_TYPE; i++ )
    1116   {
    1117     m_dimDeltaDC[i][0] = pcCU->getDimDeltaDC( i, 0 ) + uiPart;
    1118     m_dimDeltaDC[i][1] = pcCU->getDimDeltaDC( i, 1 ) + uiPart;
    1119   }
    1120 #if H_3D_DIM_DMM
    1121   for( Int i = 0; i < DMM_NUM_TYPE; i++ )
    1122   {
    1123     m_dmmWedgeTabIdx[i] = pcCU->getDmmWedgeTabIdx( i ) + uiPart;
    1124   }
     1086#if NH_3D_DMM
     1087  for( Int i = 0; i < NUM_DMM; i++ )
     1088  {
     1089    m_dmmDeltaDC[i][0] = pcCU->getDmmDeltaDC( (DmmID)i, 0 ) + uiPart;
     1090    m_dmmDeltaDC[i][1] = pcCU->getDmmDeltaDC( (DmmID)i, 1 ) + uiPart;
     1091  }
     1092  m_dmm1WedgeTabIdx    = pcCU->getDmm1WedgeTabIdx()  + uiPart;
    11251093#endif
    11261094#if H_3D_DIM_SDC
     
    11281096  m_apSegmentDCOffset[0]    = pcCU->getSDCSegmentDCOffset(0)  + uiPart;
    11291097  m_apSegmentDCOffset[1]    = pcCU->getSDCSegmentDCOffset(1)  + uiPart;
    1130 #endif 
    11311098#endif 
    11321099#if H_3D_DBBP
     
    13191286    memcpy( m_explicitRdpcmMode[comp]             + uiOffset, pcCU->getExplicitRdpcmMode(ComponentID(comp))            , iSizeInUchar );
    13201287  }
    1321 #if H_3D_DIM
    1322   for( Int i = 0; i < DIM_NUM_TYPE; i++ )
    1323   {
    1324     memcpy( m_dimDeltaDC[i][0] + uiOffset, pcCU->getDimDeltaDC( i, 0 ), sizeof(Pel ) * uiNumPartition );
    1325     memcpy( m_dimDeltaDC[i][1] + uiOffset, pcCU->getDimDeltaDC( i, 1 ), sizeof(Pel ) * uiNumPartition );
    1326   }
    1327 #if H_3D_DIM_DMM
    1328   for( Int i = 0; i < DMM_NUM_TYPE; i++ )
    1329   {
    1330     memcpy( m_dmmWedgeTabIdx[i] + uiOffset, pcCU->getDmmWedgeTabIdx( i ), sizeof(UInt) * uiNumPartition );
    1331   }
     1288#if NH_3D_DMM
     1289  for( Int i = 0; i < NUM_DMM; i++ )
     1290  {
     1291    memcpy( m_dmmDeltaDC[i][0] + uiOffset, pcCU->getDmmDeltaDC( (DmmID)i, 0 ), sizeof(Pel ) * uiNumPartition );
     1292    memcpy( m_dmmDeltaDC[i][1] + uiOffset, pcCU->getDmmDeltaDC( (DmmID)i, 1 ), sizeof(Pel ) * uiNumPartition );
     1293  }
     1294  memcpy( m_dmm1WedgeTabIdx    + uiOffset, pcCU->getDmm1WedgeTabIdx(),         sizeof(UInt) * uiNumPartition );
    13321295#endif
    13331296#if H_3D_DIM_SDC
     
    13351298  memcpy( m_apSegmentDCOffset[0]  + uiOffset, pcCU->getSDCSegmentDCOffset(0), sizeof( Pel ) * uiNumPartition);
    13361299  memcpy( m_apSegmentDCOffset[1]  + uiOffset, pcCU->getSDCSegmentDCOffset(1), sizeof( Pel ) * uiNumPartition);
    1337 #endif
    13381300#endif
    13391301#if H_3D_DBBP
     
    14471409  }
    14481410
    1449 #if H_3D_DIM
    1450   for( Int i = 0; i < DIM_NUM_TYPE; i++ )
    1451   {
    1452     memcpy( rpcCU->getDimDeltaDC( i, 0 ) + m_uiAbsIdxInLCU, m_dimDeltaDC[i][0], sizeof(Pel ) * m_uiNumPartition );
    1453     memcpy( rpcCU->getDimDeltaDC( i, 1 ) + m_uiAbsIdxInLCU, m_dimDeltaDC[i][1], sizeof(Pel ) * m_uiNumPartition );
    1454   }
    1455 #if H_3D_DIM_DMM
    1456   for( Int i = 0; i < DMM_NUM_TYPE; i++ )
    1457   {
    1458     memcpy( rpcCU->getDmmWedgeTabIdx( i ) + m_uiAbsIdxInLCU, m_dmmWedgeTabIdx[i], sizeof(UInt) * m_uiNumPartition );
    1459   }
     1411#if NH_3D_DMM
     1412  for( Int i = 0; i < NUM_DMM; i++ )
     1413  {
     1414    memcpy( pCtu->getDmmDeltaDC( (DmmID)i, 0 ) + m_absZIdxInCtu, m_dmmDeltaDC[i][0], sizeof(Pel ) * m_uiNumPartition );
     1415    memcpy( pCtu->getDmmDeltaDC( (DmmID)i, 1 ) + m_absZIdxInCtu, m_dmmDeltaDC[i][1], sizeof(Pel ) * m_uiNumPartition );
     1416  }
     1417  memcpy( pCtu->getDmm1WedgeTabIdx()           + m_absZIdxInCtu, m_dmm1WedgeTabIdx,  sizeof(UInt) * m_uiNumPartition );
    14601418#endif
    14611419#if H_3D_DIM_SDC
     
    14631421  memcpy( rpcCU->getSDCSegmentDCOffset(0) + m_uiAbsIdxInLCU, m_apSegmentDCOffset[0], sizeof( Pel ) * m_uiNumPartition);
    14641422  memcpy( rpcCU->getSDCSegmentDCOffset(1) + m_uiAbsIdxInLCU, m_apSegmentDCOffset[1], sizeof( Pel ) * m_uiNumPartition);
    1465 #endif
    14661423#endif
    14671424#if H_3D_DBBP
     
    15221479  memcpy( rpcCU->getSPIVMPFlag()        + uiPartOffset, m_pbSPIVMPFlag,        sizeof(Bool) * uiQNumPart );
    15231480#endif
    1524 #if H_3D_DIM
    1525   for( Int i = 0; i < DMM_NUM_TYPE; i++ )
    1526   {
    1527     memcpy( rpcCU->getDimDeltaDC( i, 0 ) + uiPartOffset, m_dimDeltaDC[i][0], sizeof(Pel ) * uiQNumPart );
    1528     memcpy( rpcCU->getDimDeltaDC( i, 1 ) + uiPartOffset, m_dimDeltaDC[i][1], sizeof(Pel ) * uiQNumPart );
    1529   }
    1530 #if H_3D_DIM_DMM
    1531   for( Int i = 0; i < DMM_NUM_TYPE; i++ )
    1532   {
    1533     memcpy( rpcCU->getDmmWedgeTabIdx( i ) + uiPartOffset, m_dmmWedgeTabIdx[i], sizeof(UInt) * uiQNumPart );
    1534   }
    1535 #endif
    15361481#if H_3D_DIM_SDC
    15371482  memcpy( rpcCU->getSDCFlag()             + uiPartOffset, m_pbSDCFlag,      iSizeInBool  );
    15381483  memcpy( rpcCU->getSDCSegmentDCOffset(0) + uiPartOffset, m_apSegmentDCOffset[0], sizeof( Pel ) * uiQNumPart);
    15391484  memcpy( rpcCU->getSDCSegmentDCOffset(1) + uiPartOffset, m_apSegmentDCOffset[1], sizeof( Pel ) * uiQNumPart);
    1540 #endif
    15411485#endif
    15421486#if H_3D_DBBP
     
    19521896  }
    19531897  iLeftIntraDir  = pcCULeft ? ( pcCULeft->isIntra( LeftPartIdx ) ? pcCULeft->getIntraDir( chType, LeftPartIdx ) : DC_IDX ) : DC_IDX;
    1954 #if H_3D_DIM
    1955   mapDepthModeToIntraDir( iLeftIntraDir );
     1898#if NH_3D_DMM
     1899  mapDmmToIntraDir( iLeftIntraDir );
    19561900#endif
    19571901
     
    19641908  }
    19651909  iAboveIntraDir = pcCUAbove ? ( pcCUAbove->isIntra( AbovePartIdx ) ? pcCUAbove->getIntraDir( chType, AbovePartIdx ) : DC_IDX ) : DC_IDX;
    1966 #if H_3D_DIM
    1967   mapDepthModeToIntraDir( iAboveIntraDir );
     1910#if NH_3D_DMM
     1911  mapDmmToIntraDir( iAboveIntraDir );
    19681912#endif
    19691913
     
    24602404Bool TComDataCU::getSDCAvailable( UInt uiAbsPartIdx )
    24612405{
     2406#if TEMP_SDC_CLEANUP // PM: consider this cleanup for DMM and SDC
     2407  if( getSlice()->getIsDepth() && isIntra(uiAbsPartIdx) && getPartitionSize(uiAbsPartIdx) == SIZE_2Nx2N )
     2408  {
     2409    UInt lumaPredMode = getIntraDir( CHANNEL_TYPE_LUMA, uiAbsPartIdx );
     2410    if( lumaPredMode < NUM_INTRA_MODE ) { return true; }
     2411#if NH_3D_DMM
     2412    if( isDmmMode( lumaPredMode )     ) { return true; }
     2413#endif
     2414  }
     2415  return false;
     2416#else
    24622417  // check general CU information
    24632418  if( !getSlice()->getIsDepth() || !isIntra(uiAbsPartIdx) || getPartitionSize(uiAbsPartIdx) != SIZE_2Nx2N )
     
    24662421  }
    24672422
    2468   if( isDimMode( getLumaIntraDir( uiAbsPartIdx ) ) )
     2423  if( isDmmMode( getLumaIntraDir( uiAbsPartIdx ) ) )
    24692424  {
    24702425    return true;
     
    24792434  // check prediction mode
    24802435  UInt uiLumaPredMode = getLumaIntraDir( uiAbsPartIdx ); 
    2481   if( uiLumaPredMode == PLANAR_IDX || ( getDimType( uiLumaPredMode ) == DMM1_IDX  ) )
     2436  if( uiLumaPredMode == PLANAR_IDX || ( getDmmType( uiLumaPredMode ) == DMM1_IDX  ) )
    24822437    return true;
    24832438 
    24842439  // else
    24852440  return false;
     2441#endif
    24862442}
    24872443#endif
     
    56375593
    56385594  UInt uiDirMode  = getIntraDir(toChannelType(compID), uiAbsPartIdx);
    5639 
    5640 #if H_3D_DIM
    5641     mapDepthModeToIntraDir( uiDirMode );
     5595#if NH_3D_DMM
     5596  mapDmmToIntraDir( uiDirMode );
    56425597#endif
    56435598
     
    56475602    const UInt partsPerMinCU = 1<<(2*(sps->getMaxTotalCUDepth() - sps->getLog2DiffMaxMinCodingBlockSize()));
    56485603    uiDirMode = getIntraDir(CHANNEL_TYPE_LUMA, getChromasCorrespondingPULumaIdx(uiAbsPartIdx, getPic()->getChromaFormat(), partsPerMinCU));
    5649 #if H_3D_DIM
    5650       mapDepthModeToIntraDir( uiDirMode );
     5604#if NH_3D_DMM
     5605    mapDmmToIntraDir( uiDirMode );
    56515606#endif
    56525607  }
     
    67326687}
    67336688#endif
    6734 #if H_3D_DIM_DMM
    6735 Void TComDataCU::setDmmWedgeTabIdxSubParts( UInt tabIdx, UInt dmmType, UInt uiAbsPartIdx, UInt uiDepth )
    6736 {
    6737   UInt uiCurrPartNumb = m_pcPic->getNumPartInCU() >> (uiDepth << 1);
    6738   for( UInt ui = 0; ui < uiCurrPartNumb; ui++ )
    6739   {
    6740     m_dmmWedgeTabIdx[dmmType][uiAbsPartIdx+ui] = tabIdx;
    6741   }
     6689#if NH_3D_DMM
     6690Void TComDataCU::setDmm1WedgeTabIdxSubParts( UInt tabIdx, UInt uiAbsPartIdx, UInt uiDepth )
     6691{
     6692  UInt uiCurrPartNumb = m_pcPic->getNumPartitionsInCtu() >> (uiDepth << 1);
     6693  for( UInt ui = 0; ui < uiCurrPartNumb; ui++ ) { m_dmm1WedgeTabIdx[uiAbsPartIdx+ui] = tabIdx; }
    67426694}
    67436695#endif
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibCommon/TComDataCU.h

    r1200 r1209  
    182182  Bool*         m_pbICFlag;           ///< array of IC flags
    183183#endif
    184 #if H_3D_DIM
    185   Pel*          m_dimDeltaDC[DIM_NUM_TYPE][2];
    186 #if H_3D_DIM_DMM
    187   UInt*         m_dmmWedgeTabIdx[DMM_NUM_TYPE];
     184#if NH_3D_DMM
     185  Pel*          m_dmmDeltaDC[NUM_DMM][2];
     186  UInt*         m_dmm1WedgeTabIdx;
    188187#endif
    189188#if H_3D_DIM_SDC
    190189  Bool*         m_pbSDCFlag;
    191190  Pel*          m_apSegmentDCOffset[2];
     191#if !TEMP_SDC_CLEANUP // PM: should be obsolete after cleanup
    192192  Pel           m_apDmmPredictor[2];
    193193#endif
     
    553553  Bool          isFirstAbsZorderIdxInDepth (UInt uiAbsPartIdx, UInt uiDepth);
    554554
    555 #if H_3D_DIM
    556   Pel*  getDimDeltaDC                 ( UInt dimType, UInt segId )                      { return m_dimDeltaDC[dimType][segId];        }
    557   Pel   getDimDeltaDC                 ( UInt dimType, UInt segId, UInt uiIdx )          { return m_dimDeltaDC[dimType][segId][uiIdx]; }
    558   Void  setDimDeltaDC                 ( UInt dimType, UInt segId, UInt uiIdx, Pel val ) { m_dimDeltaDC[dimType][segId][uiIdx] = val;  }
    559 #if H_3D_DIM_DMM
    560   UInt* getDmmWedgeTabIdx             ( UInt dmmType )                          { return m_dmmWedgeTabIdx[dmmType];          }       
    561   UInt  getDmmWedgeTabIdx             ( UInt dmmType, UInt uiIdx )              { return m_dmmWedgeTabIdx[dmmType][uiIdx];   }
    562   Void  setDmmWedgeTabIdx             ( UInt dmmType, UInt uiIdx, UInt tabIdx ) { m_dmmWedgeTabIdx[dmmType][uiIdx] = tabIdx; }
    563   Void  setDmmWedgeTabIdxSubParts     ( UInt tabIdx, UInt dmmType, UInt uiAbsPartIdx, UInt uiDepth );
    564 
     555#if NH_3D_DMM
     556  Pel*  getDmmDeltaDC                 ( DmmID dmmType, UInt segId )                      { return m_dmmDeltaDC[dmmType][segId];        }
     557  Pel   getDmmDeltaDC                 ( DmmID dmmType, UInt segId, UInt uiIdx )          { return m_dmmDeltaDC[dmmType][segId][uiIdx]; }
     558  Void  setDmmDeltaDC                 ( DmmID dmmType, UInt segId, UInt uiIdx, Pel val ) { m_dmmDeltaDC[dmmType][segId][uiIdx] = val;  }
     559
     560  UInt* getDmm1WedgeTabIdx            ()                                                { return m_dmm1WedgeTabIdx;          }       
     561  UInt  getDmm1WedgeTabIdx            ( UInt uiIdx )                                    { return m_dmm1WedgeTabIdx[uiIdx];   }
     562  Void  setDmm1WedgeTabIdx            ( UInt uiIdx, UInt tabIdx )                       { m_dmm1WedgeTabIdx[uiIdx] = tabIdx; }
     563  Void  setDmm1WedgeTabIdxSubParts    ( UInt tabIdx, UInt uiAbsPartIdx, UInt uiDepth );
    565564#endif
    566565#if H_3D_DIM_SDC
     
    574573  Pel           getSDCSegmentDCOffset( UInt uiSeg, UInt uiPartIdx ) { return m_apSegmentDCOffset[uiSeg][uiPartIdx]; }
    575574  Void          setSDCSegmentDCOffset( Pel pOffset, UInt uiSeg, UInt uiPartIdx) { m_apSegmentDCOffset[uiSeg][uiPartIdx] = pOffset; }
     575#if !TEMP_SDC_CLEANUP // PM: should be obsolete after cleanup
    576576  Void          setDmmPredictor ( Pel pOffset, UInt uiSeg) { m_apDmmPredictor[uiSeg] = pOffset; }
    577577  Pel           getDmmPredictor ( UInt uiSeg) { return m_apDmmPredictor[uiSeg]; }
     578#endif
    578579  UInt          getCtxSDCFlag          ( UInt   uiAbsPartIdx );
    579 #endif
    580580#endif
    581581 
     
    747747  UInt          getCoefScanIdx(const UInt uiAbsPartIdx, const UInt uiWidth, const UInt uiHeight, const ComponentID compID) const ;
    748748
    749 #if H_3D_DIM
     749#if !TEMP_SDC_CLEANUP // PM: should be obsolete after cleanup
     750#if NH_3D_DMM
    750751  Bool         isDMM1UpscaleMode       ( UInt uiWidth ){ Bool bDMM1UpsampleModeFlag = true; UInt uiBaseWidth = 16; if( uiBaseWidth >= uiWidth ){ bDMM1UpsampleModeFlag = false; } return bDMM1UpsampleModeFlag; };
    751752  UInt         getDMM1BasePatternWidth ( UInt uiWidth ){ UInt uiBaseWidth = 16; if( uiBaseWidth >= uiWidth ){ uiBaseWidth =  uiWidth; } return uiBaseWidth; }
    752753#endif
    753 
     754#endif
    754755};
    755756
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibCommon/TComPrediction.cpp

    r1200 r1209  
    530530}
    531531
    532 #if H_3D_DIM
    533 Void TComPrediction::predIntraLumaDepth( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiIntraMode, Pel* piPred, UInt uiStride, Int iWidth, Int iHeight, Bool bFastEnc, TComWedgelet* dmm4Segmentation )
     532#if NH_3D_DMM
     533Void TComPrediction::predIntraLumaDmm( TComDataCU* pcCU, UInt uiAbsPartIdx, DmmID dmmType, Pel* piPred, UInt uiStride, Int iWidth, Int iHeight )
    534534{
    535535  assert( iWidth == iHeight  );
    536   assert( iWidth >= DIM_MIN_SIZE && iWidth <= DIM_MAX_SIZE );
    537   assert( isDimMode( uiIntraMode ) );
    538 
    539   UInt dimType    = getDimType  ( uiIntraMode );
    540   Bool isDmmMode  = (dimType <  DMM_NUM_TYPE);
    541 
    542   Bool* biSegPattern  = NULL;
    543   UInt  patternStride = 0;
    544 
    545   // get partiton
    546 #if H_3D_DIM_DMM
    547   TComWedgelet* dmmSegmentation = NULL;
    548   if( isDmmMode )
    549   {
    550     switch( dimType )
    551     {
    552     case( DMM1_IDX ):
    553       {
    554         dmmSegmentation = pcCU->isDMM1UpscaleMode((UInt)iWidth) ?
    555             &(g_dmmWedgeLists[ g_aucConvertToBit[pcCU->getDMM1BasePatternWidth((UInt)iWidth)] ][ pcCU->getDmmWedgeTabIdx( dimType, uiAbsPartIdx ) ]) :
    556             &(g_dmmWedgeLists[ g_aucConvertToBit[iWidth] ][ pcCU->getDmmWedgeTabIdx( dimType, uiAbsPartIdx ) ]);
    557       } break;
    558     case( DMM4_IDX ):
    559       {
    560         if( dmm4Segmentation == NULL )
    561         {
    562           dmmSegmentation = new TComWedgelet( iWidth, iHeight );
    563           xPredContourFromTex( pcCU, uiAbsPartIdx, iWidth, iHeight, dmmSegmentation );
    564         }
    565         else
    566         {
    567           xPredContourFromTex( pcCU, uiAbsPartIdx, iWidth, iHeight, dmm4Segmentation );
    568           dmmSegmentation = dmm4Segmentation;
    569         }
    570       } break;
    571     default: assert(0);
    572     }
    573     assert( dmmSegmentation );
    574     if( dimType == DMM1_IDX && pcCU->isDMM1UpscaleMode((UInt)iWidth) )
    575     {
    576         biSegPattern = dmmSegmentation->getScaledPattern((UInt)iWidth);
    577         patternStride = iWidth;
    578     }
    579     else
    580     {
    581         biSegPattern  = dmmSegmentation->getPattern();
    582         patternStride = dmmSegmentation->getStride ();
    583     }
    584   }
    585 #endif
     536  assert( iWidth >= DMM_MIN_SIZE && iWidth <= DMM_MAX_SIZE );
     537#if H_3D_DIM_SDC
     538  assert( !pcCU->getSDCFlag( uiAbsPartIdx ) );
     539#endif
     540
     541  // get partition
     542  Bool* biSegPattern  = new Bool[ (UInt)(iWidth*iHeight) ];
     543  UInt  patternStride = (UInt)iWidth;
     544  switch( dmmType )
     545  {
     546  case( DMM1_IDX ): { (getWedgeListScaled( (UInt)iWidth )->at( pcCU->getDmm1WedgeTabIdx( uiAbsPartIdx ) )).getPatternScaledCopy( (UInt)iWidth, biSegPattern ); } break;
     547  case( DMM4_IDX ): { predContourFromTex( pcCU, uiAbsPartIdx, iWidth, iHeight, biSegPattern );                                                                 } break;
     548  default: assert(0);
     549  }
    586550
    587551  // get predicted partition values
    588   assert( biSegPattern );
    589   Int* piMask = NULL;
    590   piMask = pcCU->getPattern()->getAdiOrgBuf( iWidth, iHeight, m_piYuvExt ); // no filtering
    591   assert( piMask );
    592   Int maskStride = 2*iWidth + 1; 
    593   Int* ptrSrc = piMask+maskStride+1;
    594   Pel predDC1 = 0; Pel predDC2 = 0;
    595   xPredBiSegDCs( ptrSrc, maskStride, biSegPattern, patternStride, predDC1, predDC2 );
     552  Pel predDC1 = 0, predDC2 = 0;
     553  predBiSegDCs( pcCU, uiAbsPartIdx, iWidth, iHeight, biSegPattern, patternStride, predDC1, predDC2 );
    596554
    597555  // set segment values with deltaDC offsets
    598   Pel segDC1 = 0;
    599   Pel segDC2 = 0;
    600   if( !pcCU->getSDCFlag( uiAbsPartIdx ) )
    601   {
    602     Pel deltaDC1 = pcCU->getDimDeltaDC( dimType, 0, uiAbsPartIdx );
    603     Pel deltaDC2 = pcCU->getDimDeltaDC( dimType, 1, uiAbsPartIdx );
    604 #if H_3D_DIM_DMM
    605     if( isDmmMode )
    606     {
     556  Pel segDC1 = 0, segDC2 = 0;
     557  Pel deltaDC1 = pcCU->getDmmDeltaDC( dmmType, 0, uiAbsPartIdx );
     558  Pel deltaDC2 = pcCU->getDmmDeltaDC( dmmType, 1, uiAbsPartIdx );
    607559#if H_3D_DIM_DLT
    608       segDC1 = pcCU->getSlice()->getPPS()->getDLT()->idx2DepthValue( pcCU->getSlice()->getLayerIdInVps(), pcCU->getSlice()->getPPS()->getDLT()->depthValue2idx( pcCU->getSlice()->getLayerIdInVps(), predDC1 ) + deltaDC1 );
    609       segDC2 = pcCU->getSlice()->getPPS()->getDLT()->idx2DepthValue( pcCU->getSlice()->getLayerIdInVps(), pcCU->getSlice()->getPPS()->getDLT()->depthValue2idx( pcCU->getSlice()->getLayerIdInVps(), predDC2 ) + deltaDC2 );
     560  segDC1 = pcCU->getSlice()->getPPS()->getDLT()->idx2DepthValue( pcCU->getSlice()->getLayerIdInVps(), pcCU->getSlice()->getPPS()->getDLT()->depthValue2idx( pcCU->getSlice()->getLayerIdInVps(), predDC1 ) + deltaDC1 );
     561  segDC2 = pcCU->getSlice()->getPPS()->getDLT()->idx2DepthValue( pcCU->getSlice()->getLayerIdInVps(), pcCU->getSlice()->getPPS()->getDLT()->depthValue2idx( pcCU->getSlice()->getLayerIdInVps(), predDC2 ) + deltaDC2 );
    610562#else
    611       segDC1 = ClipY( predDC1 + deltaDC1 );
    612       segDC2 = ClipY( predDC2 + deltaDC2 );
    613 #endif
    614     }
    615 #endif
    616   }
    617   else
    618   {
    619     segDC1 = predDC1;
    620     segDC2 = predDC2;
    621   }
     563  segDC1 = ClipBD( predDC1 + deltaDC1, pcCU->getSlice()->getSPS()->getBitDepth(CHANNEL_TYPE_LUMA) );
     564  segDC2 = ClipBD( predDC2 + deltaDC2, pcCU->getSlice()->getSPS()->getBitDepth(CHANNEL_TYPE_LUMA) );
     565#endif
    622566
    623567  // set prediction signal
    624568  Pel* pDst = piPred;
    625   xAssignBiSegDCs( pDst, uiStride, biSegPattern, patternStride, segDC1, segDC2 );
     569  assignBiSegDCs( pDst, uiStride, biSegPattern, patternStride, segDC1, segDC2 );
     570#if !TEMP_SDC_CLEANUP // PM: should be obsolete after cleanup
     571#if H_3D_DIM_SDC 
    626572  pcCU->setDmmPredictor(segDC1, 0);
    627573  pcCU->setDmmPredictor(segDC2, 1);
    628 
    629 #if H_3D_DIM_DMM
    630   if( dimType == DMM4_IDX && dmm4Segmentation == NULL )
    631   {
    632     dmmSegmentation->destroy();
    633     delete dmmSegmentation;
    634   }
    635 #endif
     574#endif
     575#endif
     576  delete[] biSegPattern;
    636577}
    637578#endif
     
    24472388#endif
    24482389
    2449 #if H_3D_DIM
    2450 Void TComPrediction::xPredBiSegDCs( Int* ptrSrc, UInt srcStride, Bool* biSegPattern, Int patternStride, Pel& predDC1, Pel& predDC2 )
    2451 {
     2390#if TEMP_SDC_CLEANUP // PM: consider this cleanup for SDC
     2391#if NH_3D_SDC
     2392Void TComPrediction::predConstantSDC( Pel* ptrSrc, UInt srcStride, UInt uiSize, Pel& predDC )
     2393{
     2394  Pel* pLeftTop     =  ptrSrc;
     2395  Pel* pRightTop    =  ptrSrc                          + (uiSize-1);
     2396  Pel* pLeftBottom  = (ptrSrc+ (srcStride*(uiSize-1))              );
     2397  Pel* pRightBottom = (ptrSrc+ (srcStride*(uiSize-1))  + (uiSize-1));
     2398  predDC = (*pLeftTop + *pRightTop + *pLeftBottom + *pRightBottom + 2)>>2;
     2399}
     2400#endif
     2401#else // PM: should be obsolete after cleanup
     2402#if H_3D_DIM_SDC
     2403Void TComPrediction::analyzeSegmentsSDC( Pel* pOrig, UInt uiStride, UInt uiSize, Pel* rpSegMeans, UInt uiNumSegments, Bool* pMask, UInt uiMaskStride
     2404                                         ,UInt uiIntraMode
     2405                                         ,Bool orgDC
     2406                                        )
     2407{
     2408  Int iSumDepth[2];
     2409  memset(iSumDepth, 0, sizeof(Int)*2);
     2410  Int iSumPix[2];
     2411  memset(iSumPix, 0, sizeof(Int)*2);
     2412
     2413  for( Int i = 0; i < uiNumSegments; i++ )
     2414  {
     2415    rpSegMeans[i] = 0; 
     2416  }
     2417
     2418  if ( !orgDC )
     2419  {
     2420    Pel* pLeftTop = pOrig;
     2421    Pel* pRightTop = pOrig + (uiSize-1);
     2422    Pel* pLeftBottom = (pOrig+ (uiStride*(uiSize-1)));
     2423    Pel* pRightBottom = (pOrig+ (uiStride*(uiSize-1)) + (uiSize-1));
     2424
     2425    rpSegMeans[0] = (*pLeftTop + *pRightTop + *pLeftBottom + *pRightBottom + 2)>>2;
     2426    return;
     2427  }
     2428
     2429  Int subSamplePix;
     2430  if ( uiSize == 64 || uiSize == 32 )
     2431  {
     2432    subSamplePix = 2;
     2433  }
     2434  else
     2435  {
     2436    subSamplePix = 1;
     2437  }
     2438
     2439  for (Int y=0; y<uiSize; y+=subSamplePix)
     2440  {
     2441    for (Int x=0; x<uiSize; x+=subSamplePix)
     2442    {
     2443      UChar ucSegment = pMask?(UChar)pMask[x]:0;
     2444      assert( ucSegment < uiNumSegments );
     2445     
     2446      iSumDepth[ucSegment] += pOrig[x];
     2447      iSumPix[ucSegment]   += 1;
     2448    }
     2449   
     2450    pOrig  += uiStride*subSamplePix;
     2451    pMask  += uiMaskStride*subSamplePix;
     2452  }
     2453 
     2454  // compute mean for each segment
     2455  for( UChar ucSeg = 0; ucSeg < uiNumSegments; ucSeg++ )
     2456  {
     2457    if( iSumPix[ucSeg] > 0 )
     2458    {
     2459      rpSegMeans[ucSeg] = iSumDepth[ucSeg] / iSumPix[ucSeg];
     2460    }
     2461    else
     2462    {
     2463      rpSegMeans[ucSeg] = 0;  // this happens for zero-segments
     2464    }
     2465  }
     2466}
     2467#endif // H_3D_DIM_SDC
     2468#endif
     2469
     2470#if NH_3D_DMM
     2471Void TComPrediction::predContourFromTex( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiWidth, UInt uiHeight, Bool* segPattern )
     2472{
     2473  // get copy of co-located texture luma block
     2474  TComYuv cTempYuv;
     2475  cTempYuv.create( uiWidth, uiHeight, CHROMA_400 );
     2476  cTempYuv.clear();
     2477  Pel* piRefBlkY = cTempYuv.getAddr( COMPONENT_Y );
     2478  TComPicYuv* pcPicYuvRef = pcCU->getSlice()->getTexturePic()->getPicYuvRec();
     2479  assert( pcPicYuvRef != NULL );
     2480  Int  iRefStride = pcPicYuvRef->getStride( COMPONENT_Y );
     2481  Pel* piRefY     = pcPicYuvRef->getAddr  ( COMPONENT_Y, pcCU->getCtuRsAddr(), pcCU->getZorderIdxInCtu() + uiAbsPartIdx );
     2482
     2483  for( Int y = 0; y < uiHeight; y++ )
     2484  {
     2485    ::memcpy(piRefBlkY, piRefY, sizeof(Pel)*uiWidth);
     2486    piRefBlkY += uiWidth;
     2487    piRefY += iRefStride;
     2488  }
     2489
     2490
     2491  // find contour for texture luma block
     2492  piRefBlkY = cTempYuv.getAddr( COMPONENT_Y );
     2493  UInt iDC = 0;
     2494  iDC  = piRefBlkY[ 0 ];
     2495  iDC += piRefBlkY[ uiWidth - 1 ];
     2496  iDC += piRefBlkY[ uiWidth * (uiHeight - 1) ];
     2497  iDC += piRefBlkY[ uiWidth * (uiHeight - 1) + uiWidth - 1 ];
     2498  iDC = iDC >> 2;
     2499
     2500  piRefBlkY = cTempYuv.getAddr( COMPONENT_Y );
     2501  for( UInt k = 0; k < (uiWidth*uiHeight); k++ )
     2502  {
     2503    segPattern[k] = (piRefBlkY[k] > iDC) ? true : false;
     2504  }
     2505
     2506  cTempYuv.destroy();
     2507}
     2508
     2509Void TComPrediction::predBiSegDCs( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiWidth, UInt uiHeight, Bool* biSegPattern, Int patternStride, Pel& predDC1, Pel& predDC2 )
     2510{
     2511  assert( biSegPattern );
     2512  const Pel *piMask = getPredictorPtr( COMPONENT_Y, false );
     2513  assert( piMask );
     2514  Int srcStride = 2*uiWidth + 1;
     2515  const Pel *ptrSrc = piMask+srcStride+1;
     2516
    24522517  Int  refDC1, refDC2;
    24532518  const Int  iTR = (   patternStride - 1        ) - srcStride;
     
    24762541}
    24772542
    2478 Void TComPrediction::xAssignBiSegDCs( Pel* ptrDst, UInt dstStride, Bool* biSegPattern, Int patternStride, Pel valDC1, Pel valDC2 )
    2479 {
     2543Void TComPrediction::assignBiSegDCs( Pel* ptrDst, UInt dstStride, Bool* biSegPattern, Int patternStride, Pel valDC1, Pel valDC2 )
     2544{
     2545  assert( biSegPattern );
    24802546  if( dstStride == patternStride )
    24812547  {
    24822548    for( UInt k = 0; k < (patternStride * patternStride); k++ )
    24832549    {
    2484       if( true == biSegPattern[k] )
    2485       {
    2486         ptrDst[k] = valDC2;
    2487       }
    2488       else                         
    2489       {
    2490         ptrDst[k] = valDC1;
    2491       }
     2550      if( true == biSegPattern[k] ) { ptrDst[k] = valDC2; }
     2551      else                          { ptrDst[k] = valDC1; }
    24922552    }
    24932553  }
     
    24992559      for( UInt uiX = 0; uiX < patternStride; uiX++ )
    25002560      {
    2501         if( true == biSegPattern[uiX] )
    2502         {
    2503           piTemp[uiX] = valDC2;
    2504         }
    2505         else                           
    2506         {
    2507           piTemp[uiX] = valDC1;
    2508         }
     2561        if( true == biSegPattern[uiX] ) { piTemp[uiX] = valDC2; }
     2562        else                            { piTemp[uiX] = valDC1; }
    25092563      }
    25102564      piTemp       += dstStride;
     
    25132567  }
    25142568}
    2515 
    2516 #if H_3D_DIM_DMM
    2517 
    2518 Void TComPrediction::xPredContourFromTex( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiWidth, UInt uiHeight, TComWedgelet* pcContourWedge )
    2519 {
    2520   pcContourWedge->clear();
    2521 
    2522   // get copy of co-located texture luma block
    2523   TComYuv cTempYuv;
    2524   cTempYuv.create( uiWidth, uiHeight );
    2525   cTempYuv.clear();
    2526   Pel* piRefBlkY = cTempYuv.getLumaAddr();
    2527   xCopyTextureLumaBlock( pcCU, uiAbsPartIdx, piRefBlkY, uiWidth, uiHeight );
    2528   piRefBlkY = cTempYuv.getLumaAddr();
    2529 
    2530   // find contour for texture luma block
    2531   UInt iDC = 0;
    2532 
    2533   iDC  = piRefBlkY[ 0 ];
    2534   iDC += piRefBlkY[ uiWidth - 1 ];
    2535   iDC += piRefBlkY[ uiWidth * (uiHeight - 1) ];
    2536   iDC += piRefBlkY[ uiWidth * (uiHeight - 1) + uiWidth - 1 ];
    2537   iDC = iDC >> 2;
    2538 
    2539   piRefBlkY = cTempYuv.getLumaAddr();
    2540 
    2541   Bool* pabContourPattern = pcContourWedge->getPattern();
    2542   for( UInt k = 0; k < (uiWidth*uiHeight); k++ )
    2543   {
    2544     pabContourPattern[k] = (piRefBlkY[k] > iDC) ? true : false;
    2545   }
    2546 
    2547   cTempYuv.destroy();
    2548 }
    2549 
    2550 
    2551 Void TComPrediction::xCopyTextureLumaBlock( TComDataCU* pcCU, UInt uiAbsPartIdx, Pel* piDestBlockY, UInt uiWidth, UInt uiHeight )
    2552 {
    2553   TComPicYuv* pcPicYuvRef = pcCU->getSlice()->getTexturePic()->getPicYuvRec();
    2554   assert( pcPicYuvRef != NULL );
    2555   Int         iRefStride = pcPicYuvRef->getStride();
    2556   Pel*        piRefY = pcPicYuvRef->getLumaAddr( pcCU->getAddr(), pcCU->getZorderIdxInCU() + uiAbsPartIdx );
    2557 
    2558   for ( Int y = 0; y < uiHeight; y++ )
    2559   {
    2560     ::memcpy(piDestBlockY, piRefY, sizeof(Pel)*uiWidth);
    2561     piDestBlockY += uiWidth;
    2562     piRefY += iRefStride;
    2563   }
    2564 }
    2565 #endif
    2566 
    2567 
    2568 #if H_3D_DIM_SDC
    2569 Void TComPrediction::analyzeSegmentsSDC( Pel* pOrig, UInt uiStride, UInt uiSize, Pel* rpSegMeans, UInt uiNumSegments, Bool* pMask, UInt uiMaskStride
    2570                                          ,UInt uiIntraMode
    2571                                          ,Bool orgDC
    2572                                         )
    2573 {
    2574   Int iSumDepth[2];
    2575   memset(iSumDepth, 0, sizeof(Int)*2);
    2576   Int iSumPix[2];
    2577   memset(iSumPix, 0, sizeof(Int)*2);
    2578 
    2579   for( Int i = 0; i < uiNumSegments; i++ )
    2580   {
    2581     rpSegMeans[i] = 0; 
    2582   }
    2583 
    2584   if ( !orgDC )
    2585   {
    2586     Pel* pLeftTop = pOrig;
    2587     Pel* pRightTop = pOrig + (uiSize-1);
    2588     Pel* pLeftBottom = (pOrig+ (uiStride*(uiSize-1)));
    2589     Pel* pRightBottom = (pOrig+ (uiStride*(uiSize-1)) + (uiSize-1));
    2590 
    2591     rpSegMeans[0] = (*pLeftTop + *pRightTop + *pLeftBottom + *pRightBottom + 2)>>2;
    2592     return;
    2593   }
    2594 
    2595   Int subSamplePix;
    2596   if ( uiSize == 64 || uiSize == 32 )
    2597   {
    2598     subSamplePix = 2;
    2599   }
    2600   else
    2601   {
    2602     subSamplePix = 1;
    2603   }
    2604 
    2605   for (Int y=0; y<uiSize; y+=subSamplePix)
    2606   {
    2607     for (Int x=0; x<uiSize; x+=subSamplePix)
    2608     {
    2609       UChar ucSegment = pMask?(UChar)pMask[x]:0;
    2610       assert( ucSegment < uiNumSegments );
    2611      
    2612       iSumDepth[ucSegment] += pOrig[x];
    2613       iSumPix[ucSegment]   += 1;
    2614     }
    2615    
    2616     pOrig  += uiStride*subSamplePix;
    2617     pMask  += uiMaskStride*subSamplePix;
    2618   }
    2619  
    2620   // compute mean for each segment
    2621   for( UChar ucSeg = 0; ucSeg < uiNumSegments; ucSeg++ )
    2622   {
    2623     if( iSumPix[ucSeg] > 0 )
    2624     {
    2625       rpSegMeans[ucSeg] = iSumDepth[ucSeg] / iSumPix[ucSeg];
    2626     }
    2627     else
    2628     {
    2629       rpSegMeans[ucSeg] = 0;  // this happens for zero-segments
    2630     }
    2631   }
    2632 }
    2633 #endif // H_3D_DIM_SDC
    2634 #endif
    2635 
     2569#endif
    26362570//! \}
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibCommon/TComPrediction.h

    r1200 r1209  
    144144  Void xGetSubPUAddrAndMerge(TComDataCU* pcCU, UInt uiPartAddr, Int iSPWidth, Int iSPHeight, Int iNumSPInOneLine, Int iNumSP, UInt* uiMergedSPW, UInt* uiMergedSPH, UInt* uiSPAddr );
    145145#endif
    146 #if H_3D_DIM
    147   // depth intra functions
    148   Void xPredBiSegDCs            ( Int* ptrSrc, UInt srcStride, Bool* biSegPattern, Int patternStride, Pel& predDC1, Pel& predDC2 );
    149   Void xAssignBiSegDCs          ( Pel* ptrDst, UInt dstStride, Bool* biSegPattern, Int patternStride, Pel   valDC1, Pel   valDC2 );
    150 #if H_3D_DIM_DMM
    151   UInt xPredWedgeFromTex        ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiWidth, UInt uiHeight, UInt intraTabIdx );
    152   Void xPredContourFromTex      ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiWidth, UInt uiHeight, TComWedgelet* pcContourWedge );
    153   Void xCopyTextureLumaBlock    ( TComDataCU* pcCU, UInt uiAbsPartIdx, Pel* piDestBlockY, UInt uiWidth, UInt uiHeight );
    154 #endif
    155 #endif
    156146
    157147  Void destroy();
     
    174164  Void predIntraAng               ( const ComponentID compID, UInt uiDirMode, Pel *piOrg /* Will be null for decoding */, UInt uiOrgStride, Pel* piPred, UInt uiStride, TComTU &rTu, Bool bAbove, Bool bLeft, const Bool bUseFilteredPredSamples, const Bool bUseLosslessDPCM = false );
    175165
    176 #if H_3D_DIM
    177   // Depth intra
    178   Void predIntraLumaDepth         ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiIntraMode, Pel* piPred, UInt uiStride, Int iWidth, Int iHeight, Bool bFastEnc = false
    179     , TComWedgelet* dmm4Segmentation = NULL
    180     );
     166#if NH_3D_DMM
     167  Void predIntraLumaDmm           ( TComDataCU* pcCU, UInt uiAbsPartIdx, DmmID dmmType, Pel* piPred, UInt uiStride, Int iWidth, Int iHeight );
     168  Void predContourFromTex         ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiWidth, UInt uiHeight, Bool* segPattern );
     169  Void predBiSegDCs               ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiWidth, UInt uiHeight, Bool* biSegPattern, Int patternStride, Pel& predDC1, Pel& predDC2 );
     170  Void assignBiSegDCs             ( Pel* ptrDst, UInt dstStride, Bool* biSegPattern, Int patternStride, Pel valDC1, Pel valDC2 );
     171#endif
     172#if TEMP_SDC_CLEANUP // PM: consider this cleanup for SDC
     173#if NH_3D_SDC
     174  Void predConstantSDC            ( Pel* ptrSrc, UInt srcStride, UInt uiSize, Pel& predDC );
     175#endif
     176#else // PM: should be obsolete after cleanup
    181177#if H_3D_DIM_SDC
    182   Void analyzeSegmentsSDC         ( Pel* pOrig, UInt uiStride, UInt uiSize, Pel* rpSegMeans, UInt uiNumSegments, Bool* pMask, UInt uiMaskStride
    183                                     ,UInt uiIntraMode
    184                                     ,Bool orgDC=false
    185     );
     178  Void analyzeSegmentsSDC         ( Pel* pOrig, UInt uiStride, UInt uiSize, Pel* rpSegMeans, UInt uiNumSegments, Bool* pMask, UInt uiMaskStride, UInt uiIntraMode, Bool orgDC=false );
    186179#endif
    187180#endif
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibCommon/TComRdCost.cpp

    r1200 r1209  
    511511}
    512512
    513 #if H_3D_FAST_DEPTH_INTRA
    514 
    515 UInt TComRdCost::calcVAR (Pel* pi0, Int stride, Int width, Int height, Int cuDepth)
     513#if NH_3D_ENC_DEPTH
     514UInt TComRdCost::calcVAR (Pel* pi0, Int stride, Int width, Int height, Int cuDepth, UInt maxCuWidth)
    516515{
    517516  Int temp = 0;
     
    525524  }
    526525
    527   Int cuMaxLog2Size = g_aucConvertToBit[g_uiMaxCUWidth]+2;
     526  Int cuMaxLog2Size = g_aucConvertToBit[maxCuWidth]+2;
    528527 
    529528  if ( width == 4 )
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibCommon/TComRdCost.h

    r1200 r1209  
    212212  Distortion calcHAD(Int bitDepth, Pel* pi0, Int iStride0, Pel* pi1, Int iStride1, Int iWidth, Int iHeight );
    213213
    214 #if H_3D_FAST_DEPTH_INTRA
    215   UInt    calcVAR(Pel* pi0, Int stride, Int width, Int height, Int cuDepth);
     214#if NH_3D_ENC_DEPTH
     215  UInt    calcVAR(Pel* pi0, Int stride, Int width, Int height, Int cuDepth, UInt maxCuWidth );
    216216#endif 
    217217
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibCommon/TComRom.cpp

    r1200 r1209  
    253253    }
    254254  }
    255 #if H_3D_DIM_DMM
     255
     256#if NH_3D_DMM
    256257  if( !g_dmmWedgeLists.empty() )
    257258  {
    258     for( UInt ui = 0; ui < g_dmmWedgeLists.size(); ui++ )
    259     {
    260       g_dmmWedgeLists[ui].clear();
    261     }
     259    for( UInt ui = 0; ui < g_dmmWedgeLists.size(); ui++ ) { g_dmmWedgeLists[ui].clear(); }
    262260    g_dmmWedgeLists.clear();
    263261  }
    264   if( !g_dmmWedgeRefLists.empty() )
    265   {
    266     for( UInt ui = 0; ui < g_dmmWedgeRefLists.size(); ui++ )
    267     {
    268       g_dmmWedgeRefLists[ui].clear();
    269     }
    270     g_dmmWedgeRefLists.clear();
    271   }
    272262  if( !g_dmmWedgeNodeLists.empty() )
    273263  {
    274     for( UInt ui = 0; ui < g_dmmWedgeNodeLists.size(); ui++ )
    275     {
    276       g_dmmWedgeNodeLists[ui].clear();
    277     }
     264    for( UInt ui = 0; ui < g_dmmWedgeNodeLists.size(); ui++ ) { g_dmmWedgeNodeLists[ui].clear(); }
    278265    g_dmmWedgeNodeLists.clear();
    279266  }
     
    523510  //0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, DM
    524511  { 0, 1, 2, 2, 2, 2, 3, 5, 7, 8, 10, 12, 13, 15, 17, 18, 19, 20, 21, 22, 23, 23, 24, 24, 25, 25, 26, 27, 27, 28, 28, 29, 29, 30, 31, DM_CHROMA_IDX};
    525 #if H_3D_DIM_DMM
     512#if NH_3D_DMM
    526513// ====================================================================================================================
    527514// Depth coding modes
     
    539526{ //2x2   4x4   8x8 16x16 32x32 64x64
    540527     0,    7,   10,   9,    9,   13 };
    541 const UChar g_dmm3IntraTabIdxBits[6] =
    542 { //2x2   4x4   8x8 16x16 32x32 64x64
    543      0,    4,    7,    8,    8,    0 };
     528
    544529Bool g_wedgePattern[32*32];
    545530extern std::vector< std::vector<TComWedgelet> >   g_dmmWedgeLists;
    546 extern std::vector< std::vector<TComWedgeRef> >   g_dmmWedgeRefLists;
    547531extern std::vector< std::vector<TComWedgeNode> >  g_dmmWedgeNodeLists;
    548532#endif
     
    753737#endif
    754738#endif
    755 #if H_3D_DIM_DMM
     739#if NH_3D_DMM
    756740std::vector< std::vector<TComWedgelet>  > g_dmmWedgeLists;
    757 std::vector< std::vector<TComWedgeRef>  > g_dmmWedgeRefLists;
    758741std::vector< std::vector<TComWedgeNode> > g_dmmWedgeNodeLists;
     742
    759743Void initWedgeLists( Bool initNodeList )
    760744{
    761745  if( !g_dmmWedgeLists.empty() ) return;
    762   for( UInt ui = g_aucConvertToBit[DIM_MIN_SIZE]; ui < (g_aucConvertToBit[DIM_MAX_SIZE]); ui++ )
    763   {
    764     UInt uiWedgeBlockSize = ((UInt)DIM_MIN_SIZE)<<ui;
     746  for( UInt ui = g_aucConvertToBit[DMM_MIN_SIZE]; ui < (g_aucConvertToBit[DMM_MAX_SIZE]); ui++ )
     747  {
     748    UInt uiWedgeBlockSize = ((UInt)DMM_MIN_SIZE)<<ui;
    765749    std::vector<TComWedgelet> acWedgeList;
    766750    std::vector<TComWedgeRef> acWedgeRefList;
    767751    createWedgeList( uiWedgeBlockSize, uiWedgeBlockSize, acWedgeList, acWedgeRefList, g_dmmWedgeResolution[ui] );
    768752    g_dmmWedgeLists.push_back( acWedgeList );
    769     g_dmmWedgeRefLists.push_back( acWedgeRefList );
     753
    770754    if( initNodeList )
    771755    {
     
    827811  }
    828812}
     813
    829814Void createWedgeList( UInt uiWidth, UInt uiHeight, std::vector<TComWedgelet> &racWedgeList, std::vector<TComWedgeRef> &racWedgeRefList, WedgeResolution eWedgeRes )
    830815{
     
    867852  }
    868853}
     854
    869855Void addWedgeletToList( TComWedgelet cWedgelet, std::vector<TComWedgelet> &racWedgeList, std::vector<TComWedgeRef> &racWedgeRefList )
    870856{
     
    900886  if( bValid )
    901887  {
    902     cWedgelet.findClosestAngle();
    903888    racWedgeList.push_back( cWedgelet );
    904889    TComWedgeRef cWedgeRef;
     
    907892  }
    908893}
    909 #endif //H_3D_DIM_DMM
     894WedgeList* getWedgeListScaled( UInt blkSize )
     895{
     896  return &g_dmmWedgeLists[ g_aucConvertToBit[( 16 >= blkSize ) ? blkSize : 16] ];
     897}
     898WedgeNodeList* getWedgeNodeListScaled( UInt blkSize )
     899{
     900  return &g_dmmWedgeNodeLists[ g_aucConvertToBit[( 16 >= blkSize ) ? blkSize : 16] ];
     901}
     902#endif //NH_3D_DMM
    910903//! \}
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibCommon/TComRom.h

    r1200 r1209  
    3939#include<stdio.h>
    4040#include<iostream>
    41 #if H_3D_DIM
     41#if NH_3D_DMM
    4242#include "TComWedgelet.h"
    4343#endif
     
    9191extern const UChar  g_aucIntraModeNumFast_NotUseMPM[MAX_CU_DEPTH];
    9292extern const UChar  g_chroma422IntraAngleMappingTable[NUM_INTRA_MODE];
    93 #if H_3D_DIM
     93
    9494// ====================================================================================================================
    9595// Depth coding modes
    9696// ====================================================================================================================
    97 __inline Void mapDepthModeToIntraDir( UInt& intraMode ) { if( isDimMode( intraMode ) ) intraMode = DC_IDX; }
    98 __inline Void mapDepthModeToIntraDir(  Int& intraMode ) { if( isDimMode( intraMode ) ) intraMode = DC_IDX; }
    99 #if H_3D_DIM_SDC || H_3D_DIM_DLT
    100 __inline UInt numBitsForValue( UInt value ) { UInt bits = 0; while (value != 0) { value >>= 1; bits++; } return bits; };
    101 #endif
    102 #if H_3D_DIM_DMM
     97#if NH_3D_DMM
    10398extern const WedgeResolution                                 g_dmmWedgeResolution [6];
    10499extern const UChar                                           g_dmm1TabIdxBits     [6];
    105 extern const UChar                                           g_dmm3IntraTabIdxBits[6];
    106100extern Bool                                                  g_wedgePattern[32*32];
    107101extern       std::vector< std::vector<TComWedgelet> >        g_dmmWedgeLists;
    108 extern       std::vector< std::vector<TComWedgeRef> >        g_dmmWedgeRefLists;
    109102extern       std::vector< std::vector<TComWedgeNode> >       g_dmmWedgeNodeLists;
     103
    110104Void initWedgeLists( Bool initNodeList = false );
    111105Void createWedgeList( UInt uiWidth, UInt uiHeight, std::vector<TComWedgelet> &racWedgeList, std::vector<TComWedgeRef> &racWedgeRefList, WedgeResolution eWedgeRes );
    112106Void addWedgeletToList( TComWedgelet cWedgelet, std::vector<TComWedgelet> &racWedgeList, std::vector<TComWedgeRef> &racWedgeRefList );
    113 #endif
     107
     108WedgeList*     getWedgeListScaled    ( UInt blkSize );
     109WedgeNodeList* getWedgeNodeListScaled( UInt blkSize );
     110
     111__inline Void mapDmmToIntraDir( UInt& intraMode ) { if( isDmmMode( intraMode ) ) intraMode = DC_IDX; }
     112__inline Void mapDmmToIntraDir(  Int& intraMode ) { if( isDmmMode( intraMode ) ) intraMode = DC_IDX; }
     113#endif
     114#if H_3D_DIM_SDC || H_3D_DIM_DLT
     115__inline UInt numBitsForValue( UInt value ) { UInt bits = 0; while (value != 0) { value >>= 1; bits++; } return bits; };
    114116#endif
    115117// ====================================================================================================================
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibCommon/TComSlice.h

    r1200 r1209  
    27062706  Int                         getNumCurCmpLIds( )                      const         { return (Int) m_inCmpRefViewIdcs.size();                       }
    27072707  TComPic*                    getIvPic( Bool depthFlag, Int viewIndex) const         { return  m_ivPicsCurrPoc[ depthFlag ? 1 : 0 ][ viewIndex ];    }
    2708 #endif                                                                                                                                               
    2709 #if H_3D                                                                                                                                             
    27102708  TComPic*                    getTexturePic       ()                                 { return  m_ivPicsCurrPoc[0][ m_viewIndex ];                    }
    27112709#endif                                                                                                                                               
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibCommon/TComWedgelet.cpp

    r1196 r1209  
    4545using namespace std;
    4646
    47 #if H_3D_DIM_DMM
     47#if NH_3D_DMM
    4848TComWedgelet::TComWedgelet( UInt uiWidth, UInt uiHeight ) : m_uhXs     ( 0 ),
    4949                                                            m_uhYs     ( 0 ),
     
    6464                                                            m_eWedgeRes( rcWedge.m_eWedgeRes ),
    6565                                                            m_bIsCoarse( rcWedge.m_bIsCoarse ),
    66                                                             m_uiAng    ( rcWedge.m_uiAng     ),
    6766                                                            m_uiWidth  ( rcWedge.m_uiWidth   ),
    6867                                                            m_uiHeight ( rcWedge.m_uiHeight  ),
    69                                                             m_pbPattern( (Bool*)xMalloc( Bool, (m_uiWidth * m_uiHeight) ) )
    70                                                             ,m_pbScaledPattern( g_wedgePattern )
     68                                                            m_pbPattern( (Bool*)xMalloc( Bool, (m_uiWidth * m_uiHeight) ) ),
     69                                                            m_pbScaledPattern( g_wedgePattern )
    7170{
    7271  ::memcpy( m_pbPattern, rcWedge.m_pbPattern, sizeof(Bool) * (m_uiWidth * m_uiHeight));
     
    9796{
    9897  ::memset( m_pbPattern, 0, (m_uiWidth * m_uiHeight) * sizeof(Bool) );
    99 }
    100 
    101 Void TComWedgelet::findClosestAngle()
    102 {
    103   UInt uiAng=0,uiOptAng=0;
    104   UInt uiMinD=MAX_UINT;
    105   UInt uiTmpD=0;
    106   Int angTable[9]    = {0,    2,    5,   9,  13,  17,  21,  26,  32};
    107  
    108   UChar uhXs = m_uhXs;
    109   UChar uhYs = m_uhYs;
    110   UChar uhXe = m_uhXe;
    111   UChar uhYe = m_uhYe;
    112 
    113   for(uiAng=2; uiAng<=34; uiAng++)
    114   {
    115     Int iSign    = (uiAng<VER_IDX && uiAng>HOR_IDX ) ? -1 : 1;
    116     Int iVer     = uiAng>17 ? 32 : angTable[(uiAng>10) ? (uiAng-10) : (10-uiAng)];
    117     Int iHor     = uiAng<19 ? 32 : angTable[(uiAng>26) ? (uiAng-26) : (26-uiAng)];
    118 
    119     uiTmpD  = abs(iVer*iSign*(uhXs-uhXe) - iHor*(uhYe-uhYs));
    120    
    121     if( uiTmpD < uiMinD )
    122     {
    123       uiMinD = uiTmpD;
    124       uiOptAng = uiAng;
    125     }
    126   }
    127   m_uiAng = uiOptAng;
    12898}
    12999
     
    205175  m_eWedgeRes = rcWedge.m_eWedgeRes;
    206176  m_bIsCoarse = rcWedge.m_bIsCoarse;
    207   m_uiAng = rcWedge.m_uiAng;
    208177  m_uiWidth  = rcWedge.m_uiWidth;
    209178  m_uiHeight = rcWedge.m_uiHeight;
     
    295264}
    296265
    297 Bool* TComWedgelet::getScaledPattern(UInt uiDstSize)
     266Bool* TComWedgelet::getPatternScaled( UInt dstSize )
    298267{
    299268  Bool *pbSrcPat = this->getPattern();
    300269  UInt uiSrcSize = this->getStride();
    301270
    302   Int scale = (g_aucConvertToBit[uiDstSize] - g_aucConvertToBit[uiSrcSize]);
    303   assert(scale>=0);
    304   for (Int y=0; y<uiDstSize; y++)
    305   {
    306     for (Int x=0; x<uiDstSize; x++)
    307     {
    308       Int srcX = x>>scale;
    309       Int srcY = y>>scale;
    310       m_pbScaledPattern[y*uiDstSize + x] = pbSrcPat[ srcY*uiSrcSize + srcX ];
    311     }
    312   }
    313   return m_pbScaledPattern;
    314 }
     271  if( 16 >= dstSize )
     272  {
     273    assert( dstSize == uiSrcSize );
     274    return pbSrcPat;
     275  }
     276  else
     277  {
     278    Int scale = (g_aucConvertToBit[dstSize] - g_aucConvertToBit[uiSrcSize]);
     279    assert(scale>=0);
     280    for (Int y=0; y<dstSize; y++)
     281    {
     282      for (Int x=0; x<dstSize; x++)
     283      {
     284        Int srcX = x>>scale;
     285        Int srcY = y>>scale;
     286        m_pbScaledPattern[y*dstSize + x] = pbSrcPat[ srcY*uiSrcSize + srcX ];
     287      }
     288    }
     289    return m_pbScaledPattern;
     290  }
     291}
     292
     293Void TComWedgelet::getPatternScaledCopy( UInt dstSize, Bool* dstBuf )
     294{
     295  Bool *pbSrcPat = this->getPattern();
     296  UInt uiSrcSize = this->getStride();
     297
     298  if( 16 >= dstSize )
     299  {
     300    assert( dstSize == uiSrcSize );
     301    memcpy( dstBuf, pbSrcPat, (dstSize*dstSize) );
     302  }
     303  else
     304  {
     305    Int scale = (g_aucConvertToBit[dstSize] - g_aucConvertToBit[uiSrcSize]);
     306    assert(scale>=0);
     307    for (Int y=0; y<dstSize; y++)
     308    {
     309      for (Int x=0; x<dstSize; x++)
     310      {
     311        Int srcX = x>>scale;
     312        Int srcY = y>>scale;
     313        dstBuf[y*dstSize + x] = pbSrcPat[ srcY*uiSrcSize + srcX ];
     314      }
     315    }
     316  }
     317}
     318
    315319
    316320TComWedgeNode::TComWedgeNode()
    317321{
    318   m_uiPatternIdx = DMM_NO_WEDGEINDEX;
     322  m_uiPatternIdx = DMM_NO_WEDGE_IDX;
    319323  for( UInt uiPos = 0; uiPos < DMM_NUM_WEDGE_REFINES; uiPos++ )
    320324  {
    321     m_uiRefineIdx[uiPos] = DMM_NO_WEDGEINDEX;
     325    m_uiRefineIdx[uiPos] = DMM_NO_WEDGE_IDX;
    322326  }
    323327}
     
    341345  m_uiRefineIdx[uiPos] = uiIdx; 
    342346}
    343 #endif //H_3D_DIM_DMM
     347#endif //NH_3D_DMM
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibCommon/TComWedgelet.h

    r1196 r1209  
    4343#include <vector>
    4444
    45 #if H_3D_DIM
    46 #define DIM_OFFSET     (NUM_INTRA_MODE+1) // offset for DMM and RBC mode numbers (PM: not consistent with spec, but non-overlapping with chroma, see DM_CHROMA_IDX)
    47 #define DIM_MIN_SIZE                   4  // min. block size for DMM and RBC modes
    48 #define DIM_MAX_SIZE                  32  // max. block size for DMM and RBC modes
     45#if NH_3D_DMM
     46#define DMM_OFFSET     (NUM_INTRA_MODE+1) // offset for DMM and RBC mode numbers
     47#define DMM_MIN_SIZE                   4  // min. block size for DMM and RBC modes
     48#define DMM_MAX_SIZE                  32  // max. block size for DMM and RBC modes
    4949
    50 enum DIM_IDX
     50enum DmmID
    5151{
    5252  DMM1_IDX = 0,
    5353  DMM4_IDX = 1,
     54  NUM_DMM  = 2,
     55  DMM_NO_IDX = MAX_UINT
    5456};
    5557
    56 #define DMM_NUM_TYPE   2
    57 #define DIM_NUM_TYPE   (DMM_NUM_TYPE)
    58 #define DIM_NO_IDX     MAX_UINT
     58__inline DmmID getDmmType( Int intraMode )
     59{
     60    Int dmmType = intraMode-DMM_OFFSET;
     61    return (dmmType >= 0 && dmmType < NUM_DMM) ? (DmmID)dmmType : DMM_NO_IDX;
     62}
     63__inline Bool isDmmMode( Int intraMode ) { return ((UInt)getDmmType( intraMode ) < NUM_DMM); }
    5964
    60 __inline UInt getDimType  ( Int intraMode )
    61 {
    62     Int dimType = intraMode-DIM_OFFSET;
    63     return (dimType >= 0 && dimType < DIM_NUM_TYPE) ? (UInt)dimType : DIM_NO_IDX;
    64 }
    65 __inline Bool isDimMode   ( Int intraMode ) { return (getDimType( intraMode ) < DIM_NUM_TYPE); }
    66 #endif
    6765
    68 #if H_3D_DIM_DMM
    69 #define DMM_NO_WEDGEINDEX       MAX_UINT
     66// Wedgelets
     67#define DMM_NO_WEDGE_IDX       MAX_UINT
    7068#define DMM_NUM_WEDGE_REFINES   8
    7169
     
    9088  WedgeResolution m_eWedgeRes;                  // start/end pos resolution
    9189  Bool            m_bIsCoarse;
    92   UInt            m_uiAng;
    9390
    9491  UInt  m_uiWidth;
     
    121118  UChar           getOri     () { return m_uhOri; }
    122119  Bool            getIsCoarse() { return m_bIsCoarse; }
    123   UInt            getAng     () { return m_uiAng; }
    124   Bool*           getScaledPattern(UInt uiWidth);
    125120
    126121  Void  generateWedgePatternByRotate(const TComWedgelet &rcWedge, Int rotate);
    127122  Void  setWedgelet( UChar uhXs, UChar uhYs, UChar uhXe, UChar uhYe, UChar uhOri, WedgeResolution eWedgeRes, Bool bIsCoarse = false );
    128   Void  findClosestAngle();
    129123
    130124  Bool  checkNotPlain();
    131125  Bool  checkIdentical( Bool* pbRefPattern );
    132126  Bool  checkInvIdentical( Bool* pbRefPattern );
     127
     128  Bool* getPatternScaled    ( UInt dstSize );
     129  Void  getPatternScaledCopy( UInt dstSize, Bool* dstBuf );
    133130
    134131};  // END CLASS DEFINITION TComWedgelet
     
    162159};  // END CLASS DEFINITION TComWedgeRef
    163160
    164 // type definition wedgelet reference list
    165 typedef std::vector<TComWedgeRef> WedgeRefList;
    166161
    167162// ====================================================================================================================
     
    187182// type definition wedgelet node list
    188183typedef std::vector<TComWedgeNode> WedgeNodeList;
    189 #endif //H_3D_DIM_DMM
     184#endif //NH_3D_DMM
    190185
    191 
    192 // ====================================================================================================================
    193 // Function definition roftoi (mathematically correct rounding of float to int)
    194 // ====================================================================================================================
    195 __inline Int roftoi( Double value )
    196 {
    197   (value < -0.5) ? (value -= 0.5) : (value += 0.5);
    198   return ( (Int)value );
    199 }
    200186#endif // __TCOMWEDGELET__
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibCommon/TypeDef.h

    r1201 r1209  
    6969#if NH_3D
    7070#define NH_3D_VSO                         1
    71 #endif
     71#define NH_3D_DMM                         1   // Depth modeling modes
     72#define NH_3D_SDC                         1   // Segment-wise DC coding for intra and inter
     73#define NH_3D_ENC_DEPTH                   1   // Encoder optimizations for depth, incl.
     74                                              // HHI_DEPTH_INTRA_SEARCH_RAU_C0160
     75                                              // LG_ZEROINTRADEPTHRESI_A0087
     76                                              // HHI_DMM4_ENC_I0066
     77                                              // H_3D_FAST_DEPTH_INTRA
     78#endif
     79
     80#define TEMP_SDC_CLEANUP                  1   // PM: consider these cleanups for DMM and SDC
    7281
    7382#if H_3D
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibDecoder/TDecCAVLC.cpp

    r1200 r1209  
    33893389#endif
    33903390#if H_3D_INTER_SDC
    3391 Void TDecCavlc::parseDeltaDC( TComDataCU* /*pcCU*/, UInt /*uiAbsPartIdx*/, UInt /*uiDepth*/ )
    3392 {
    3393   assert(0);
    3394 }
    3395 
    33963391Void TDecCavlc::parseSDCFlag    ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth )
    33973392{
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibDecoder/TDecCAVLC.h

    r1200 r1209  
    123123  Void  parseICFlag         ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth );
    124124#endif
     125#if NH_3D_DMM || H_3D_DIM_SDC || H_3D_INTER_SDC
     126  Void  parseDeltaDC        ( TComDataCU* /*pcCU*/, UInt /*absPartIdx*/, UInt /*depth*/ ) { assert(0); };
     127#endif
    125128#if H_3D_INTER_SDC
    126   Void  parseDeltaDC        ( TComDataCU* pcCU, UInt absPartIdx, UInt depth );
    127129  Void  parseSDCFlag        ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth );
    128130#endif
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibDecoder/TDecCu.cpp

    r1200 r1209  
    10091009
    10101010  //===== get prediction signal =====
    1011 #if H_3D_DIM
    1012   if( isDimMode( uiLumaPredMode ) )
    1013   {
    1014     m_pcPrediction->predIntraLumaDepth( pcCU, uiAbsPartIdx, uiLumaPredMode, piPred, uiStride, uiWidth, uiHeight );
     1011#if NH_3D_DMM
     1012  if( bIsLuma && isDmmMode( uiChFinalMode ) )
     1013  {
     1014    m_pcPrediction->predIntraLumaDmm( pcCU, uiAbsPartIdx, getDmmType( uiChFinalMode ), piPred, uiStride, uiWidth, uiHeight );
    10151015  }
    10161016  else
    10171017  {
    10181018#endif
    1019 
    10201019  m_pcPrediction->predIntraAng( compID,   uiChFinalMode, 0 /* Decoder does not have an original image */, 0, piPred, uiStride, rTu, bAboveAvail, bLeftAvail, bUseFilteredPredictions );
    1021 #if H_3D_DIM
     1020#if NH_3D_DMM
    10221021  }
    10231022#endif
     
    10401039#endif
    10411040#if H_3D
    1042   Bool useDltFlag = (isDimMode( uiLumaPredMode ) || uiLumaPredMode == HOR_IDX || uiLumaPredMode == VER_IDX || uiLumaPredMode == DC_IDX) && pcCU->getSlice()->getIsDepth() && pcCU->getSlice()->getPPS()->getDLT()->getUseDLTFlag(pcCU->getSlice()->getLayerIdInVps());
     1041  Bool useDltFlag = (isDmmMode( uiLumaPredMode ) || uiLumaPredMode == HOR_IDX || uiLumaPredMode == VER_IDX || uiLumaPredMode == DC_IDX) && pcCU->getSlice()->getIsDepth() && pcCU->getSlice()->getPPS()->getDLT()->getUseDLTFlag(pcCU->getSlice()->getLayerIdInVps());
    10431042
    10441043  if ( pcCU->getCbf( uiAbsPartIdx, TEXT_LUMA, uiTrDepth ) || useDltFlag )
     
    11581157  }
    11591158}
    1160 #if H_3D_DIM
    1161       mapDepthModeToIntraDir( uiChromaPredMode );
    1162 #endif
    1163 
    11641159
    11651160Void
     
    11911186Void TDecCu::xReconIntraSDC( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth )
    11921187{
     1188#if TEMP_SDC_CLEANUP // PM: consider this cleanup for DMM and SDC
     1189  TComYuv* pcRecoYuv  = m_ppcYuvReco[uiDepth];
     1190  TComYuv* pcPredYuv  = m_ppcYuvReco[uiDepth];
     1191  TComYuv* pcResiYuv  = m_ppcYuvResi[uiDepth];
     1192
     1193  Bool bAboveAvail    = false;
     1194  Bool bLeftAvail     = false;
     1195  UInt uiWidth        = pcCU->getWidth ( 0 );
     1196  UInt uiHeight       = pcCU->getHeight( 0 );
     1197  UInt uiLumaPredMode = pcCU->getIntraDir( CHANNEL_TYPE_LUMA, uiAbsPartIdx );
     1198
     1199  UInt sdcDepth = 0;
     1200  UInt uiStride;
     1201  Pel* piReco;
     1202  Pel* piPred;
     1203  Pel* piResi;
     1204
     1205  UInt uiZOrder;       
     1206  Pel* piRecIPred;     
     1207  UInt uiRecIPredStride;
     1208 
     1209  Pel apDCPredValues[2];
     1210  UInt uiNumSegments;
     1211
     1212  Bool* pbMask = NULL;
     1213  UInt uiMaskStride = 0;
     1214
     1215#if NH_3D_DMM
     1216  TComWedgelet* dmm4Segmentation = NULL;
     1217  if( isDmmMode( uiLumaPredMode ) )
     1218  {
     1219    assert( uiWidth == uiHeight  );
     1220    assert( uiWidth >= DMM_MIN_SIZE && uiWidth <= DMM_MAX_SIZE );
     1221    assert( !((uiWidth >> pcCU->getSlice()->getSPS()->getQuadtreeTULog2MaxSize()) > 1) );
     1222
     1223    uiNumSegments     = 2;
     1224
     1225    uiStride          = pcRecoYuv->getStride( COMPONENT_Y );
     1226    piReco            = pcRecoYuv->getAddr  ( COMPONENT_Y, uiAbsPartIdx );
     1227    piPred            = pcPredYuv->getAddr  ( COMPONENT_Y, uiAbsPartIdx );
     1228    piResi            = pcResiYuv->getAddr  ( COMPONENT_Y, uiAbsPartIdx );
     1229
     1230    piRecIPred        = pcCU->getPic()->getPicYuvRec()->getAddr  ( COMPONENT_Y, pcCU->getCtuRsAddr(), pcCU->getZorderIdxInCtu() + uiAbsPartIdx );
     1231    uiRecIPredStride  = pcCU->getPic()->getPicYuvRec()->getStride( COMPONENT_Y );
     1232
     1233    //===== init availability pattern =====
     1234#if !TEMP_SDC_CLEANUP // PM: please migrate together with below "initPattern" and remove macro
     1235    pcCU->getPattern()->initPattern   ( pcCU, sdcDepth, uiAbsPartIdx );
     1236    pcCU->getPattern()->initAdiPattern( pcCU, uiAbsPartIdx, sdcDepth, m_pcPrediction->getPredicBuf(), m_pcPrediction->getPredicBufWidth(), m_pcPrediction->getPredicBufHeight(), bAboveAvail, bLeftAvail );
     1237#endif
     1238
     1239    // get partition
     1240    pbMask       = new Bool[ uiWidth*uiHeight ];
     1241    uiMaskStride = uiWidth;
     1242    switch( getDmmType( uiLumaPredMode ) )
     1243    {
     1244    case( DMM1_IDX ): { (getWedgeListScaled( uiWidth )->at( pcCU->getDmm1WedgeTabIdx( uiAbsPartIdx ) )).getPatternScaledCopy( uiWidth, pbMask ); } break;
     1245    case( DMM4_IDX ): { m_pcPrediction->predContourFromTex( pcCU, uiAbsPartIdx, uiWidth, uiHeight, pbMask );                                     } break;
     1246    default: assert(0);
     1247    }
     1248
     1249    // get predicted partition values
     1250    Pel predDC1 = 0, predDC2 = 0;
     1251    m_pcPrediction->predBiSegDCs( pcCU, uiAbsPartIdx, uiWidth, uiHeight, pbMask, uiMaskStride, predDC1, predDC2 );
     1252
     1253    // set prediction signal
     1254    Pel* pDst = piPred;
     1255    m_pcPrediction->assignBiSegDCs( pDst, uiStride, pbMask, uiMaskStride, predDC1, predDC2 );
     1256    apDCPredValues[0] = predDC1;
     1257    apDCPredValues[1] = predDC2;
     1258  }
     1259  else // regular HEVC intra modes
     1260  {
     1261#endif
     1262    uiNumSegments = 1;
     1263
     1264    UInt numParts = 1;
     1265    UInt uiSubPartIdx = uiAbsPartIdx;
     1266
     1267    if ((uiWidth >> pcCU->getSlice()->getSPS()->getQuadtreeTULog2MaxSize()) > 1)
     1268    {
     1269      numParts = uiWidth * uiWidth >> (2 * pcCU->getSlice()->getSPS()->getQuadtreeTULog2MaxSize());
     1270      sdcDepth = g_aucConvertToBit[uiWidth] + 2 - pcCU->getSlice()->getSPS()->getQuadtreeTULog2MaxSize();
     1271      uiWidth = uiHeight = (1 << pcCU->getSlice()->getSPS()->getQuadtreeTULog2MaxSize());
     1272    }
     1273
     1274    for ( Int i = 0; i < numParts; i++ )
     1275    {
     1276      uiStride    = pcRecoYuv->getStride  ();
     1277      piReco      = pcRecoYuv->getLumaAddr( uiSubPartIdx );
     1278      piPred      = pcPredYuv->getLumaAddr( uiSubPartIdx );
     1279      piResi      = pcResiYuv->getLumaAddr( uiSubPartIdx );
     1280
     1281      uiZOrder          = pcCU->getZorderIdxInCU() + uiSubPartIdx;
     1282      piRecIPred        = pcCU->getPic()->getPicYuvRec()->getLumaAddr( pcCU->getAddr(), uiZOrder );
     1283      uiRecIPredStride  = pcCU->getPic()->getPicYuvRec()->getStride  ();
     1284
     1285      AOF( uiWidth == uiHeight );
     1286
     1287      //===== init availability pattern =====
     1288      pcCU->getPattern()->initPattern   ( pcCU, sdcDepth, uiSubPartIdx );
     1289      pcCU->getPattern()->initAdiPattern( pcCU, uiSubPartIdx, sdcDepth, m_pcPrediction->getPredicBuf(), m_pcPrediction->getPredicBufWidth(), m_pcPrediction->getPredicBufHeight(), bAboveAvail, bLeftAvail );
     1290
     1291      m_pcPrediction->predIntraLumaAng( pcCU->getPattern(), uiLumaPredMode, piPred, uiStride, uiWidth, uiHeight, bAboveAvail, bLeftAvail );
     1292
     1293      if ( numParts > 1 )
     1294      {
     1295        for( UInt uiY = 0; uiY < uiHeight; uiY++ )
     1296        {
     1297          for( UInt uiX = 0; uiX < uiWidth; uiX++ )
     1298          {
     1299            piReco        [ uiX ] = ClipY( piPred[ uiX ] );
     1300            piRecIPred    [ uiX ] = piReco[ uiX ];
     1301          }
     1302          piPred     += uiStride;
     1303          piReco     += uiStride;
     1304          piRecIPred += uiRecIPredStride;
     1305        }
     1306      }
     1307      uiSubPartIdx += ( (uiWidth * uiWidth) >> 4 );
     1308    }
     1309
     1310    // reset to full block
     1311    uiWidth  = pcCU->getWidth( 0 );
     1312    uiHeight = pcCU->getHeight( 0 );
     1313
     1314    piReco            = pcRecoYuv->getLumaAddr( uiAbsPartIdx );
     1315    piPred            = pcPredYuv->getLumaAddr( uiAbsPartIdx );
     1316    piResi            = pcResiYuv->getLumaAddr( uiAbsPartIdx );
     1317
     1318    uiZOrder          = pcCU->getZorderIdxInCU() + uiAbsPartIdx;
     1319    piRecIPred        = pcCU->getPic()->getPicYuvRec()->getLumaAddr( pcCU->getAddr(), uiZOrder );
     1320    uiRecIPredStride  = pcCU->getPic()->getPicYuvRec()->getStride  ();
     1321
     1322    m_pcPrediction->predConstantSDC( piPred, uiStride, uiWidth, apDCPredValues[0] ); apDCPredValues[1] = 0;
     1323#if NH_3D_DMM
     1324  }
     1325#endif
     1326#else
    11931327  UInt uiWidth        = pcCU->getWidth  ( 0 );
    11941328  UInt uiHeight       = pcCU->getHeight ( 0 );
     
    12421376    TComWedgelet* dmm4Segmentation = new TComWedgelet( uiWidth, uiHeight );
    12431377    //===== get prediction signal =====
    1244     if( isDimMode( uiLumaPredMode ) )
     1378    if( isDmmMode( uiLumaPredMode ) )
    12451379    {
    12461380      m_pcPrediction->predIntraLumaDepth( pcCU, uiAbsPartIdx, uiLumaPredMode, piPred, uiStride, uiWidth, uiHeight, false, dmm4Segmentation  );
     
    12921426  UInt uiMaskStride = 0;
    12931427 
    1294   if( getDimType( uiLumaPredMode ) == DMM1_IDX )
     1428  if( getDmmType( uiLumaPredMode ) == DMM1_IDX )
    12951429  {
    12961430    Int uiTabIdx = pcCU->getDmmWedgeTabIdx(DMM1_IDX, uiAbsPartIdx);
     
    13041438    uiMaskStride = pcCU->isDMM1UpscaleMode( uiWidth ) ? uiWidth : pcWedgelet->getStride();
    13051439  }
    1306   if( getDimType( uiLumaPredMode ) == DMM4_IDX )
     1440  if( getDmmType( uiLumaPredMode ) == DMM4_IDX )
    13071441  {
    13081442    uiNumSegments = 2;
     
    13121446  // get DC prediction for each segment
    13131447  Pel apDCPredValues[2];
    1314   if ( getDimType( uiLumaPredMode ) == DMM1_IDX || getDimType( uiLumaPredMode ) == DMM4_IDX )
     1448  if ( getDmmType( uiLumaPredMode ) == DMM1_IDX || getDmmType( uiLumaPredMode ) == DMM4_IDX )
    13151449  {
    13161450    apDCPredValues[0] = pcCU->getDmmPredictor( 0 );
     
    13211455    m_pcPrediction->analyzeSegmentsSDC(piPred, uiStride, uiWidth, apDCPredValues, uiNumSegments, pbMask, uiMaskStride, uiLumaPredMode);
    13221456  }
     1457#endif
    13231458 
    13241459  // reconstruct residual based on mask + DC residuals
     
    13791514    pRecCr += uiStrideC;
    13801515  }
     1516#if NH_3D_DMM
     1517#if TEMP_SDC_CLEANUP // PM: consider this cleanup for DMM and SDC
     1518  if( pbMask ) { delete[] pbMask; }
     1519#else
    13811520  dmm4SegmentationOrg->destroy(); delete dmm4SegmentationOrg;
     1521#endif
     1522#endif
    13821523}
    13831524#endif
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibDecoder/TDecEntropy.cpp

    r1200 r1209  
    970970    assert( pcCU->getCbf(uiAbsPartIdx, TEXT_CHROMA_V) == 1 );
    971971}
     972#endif
    972973#if H_3D_INTER_SDC
    973974  if( pcCU->getSDCFlag( uiAbsPartIdx ) && !pcCU->isIntra( uiAbsPartIdx) )
     
    978979  }
    979980#endif
    980   if( pcCU->getSlice()->getIsDepth() && ( pcCU->getSDCFlag( uiAbsPartIdx ) || pcCU->isIntra( uiAbsPartIdx ) ) )
    981   {
    982     Int iPartNum = ( pcCU->isIntra( uiAbsPartIdx ) && pcCU->getPartitionSize( uiAbsPartIdx ) == SIZE_NxN ) ? 4 : 1;
    983     UInt uiPartOffset = ( pcCU->getPic()->getNumPartInCU() >> ( pcCU->getDepth( uiAbsPartIdx ) << 1 ) ) >> 2;
    984  
    985     if( !pcCU->getSDCFlag( uiAbsPartIdx ) )
    986     {
    987       for( Int iPart = 0; iPart < iPartNum; iPart++ )
    988       {
    989         if( getDimType( pcCU->getLumaIntraDir( uiAbsPartIdx + uiPartOffset*iPart ) ) < DIM_NUM_TYPE )
    990         {
    991           m_pcEntropyDecoderIf->parseDeltaDC( pcCU, uiAbsPartIdx + uiPartOffset*iPart, uiDepth + ( pcCU->getPartitionSize( uiAbsPartIdx ) == SIZE_NxN ) );
    992         }
    993       }
    994     }
    995     else
     981#if NH_3D
     982  if( pcCU->getSlice()->getIsDepth() )
     983  {
     984#if H_3D_DIM_SDC || H_3D_INTER_SDC
     985    if( pcCU->getSDCFlag( uiAbsPartIdx ) )
    996986    {
    997987      m_pcEntropyDecoderIf->parseDeltaDC( pcCU, uiAbsPartIdx, uiDepth );
    998988      return;
    999989    }
     990#endif
     991#if NH_3D_DMM
     992    if( pcCU->isIntra( uiAbsPartIdx ) )
     993    {
     994      Int iPartNum = ( pcCU->isIntra( uiAbsPartIdx ) && pcCU->getPartitionSize( uiAbsPartIdx ) == SIZE_NxN ) ? 4 : 1;
     995      UInt uiPartOffset = ( pcCU->getPic()->getNumPartitionsInCtu() >> ( pcCU->getDepth( uiAbsPartIdx ) << 1 ) ) >> 2;
     996      for( Int iPart = 0; iPart < iPartNum; iPart++ )
     997      {
     998        if( isDmmMode( pcCU->getIntraDir( CHANNEL_TYPE_LUMA, uiAbsPartIdx + uiPartOffset*iPart ) ) )
     999        {
     1000          m_pcEntropyDecoderIf->parseDeltaDC( pcCU, uiAbsPartIdx + uiPartOffset*iPart, uiDepth + ( pcCU->getPartitionSize( uiAbsPartIdx ) == SIZE_NxN ) );
     1001        }
     1002      }
     1003    }
     1004#endif
    10001005  }
    10011006#endif
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibDecoder/TDecEntropy.h

    r1200 r1209  
    9191  virtual Void parseICFlag        ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) = 0;
    9292#endif
     93#if NH_3D_DMM || H_3D_DIM_SDC || H_3D_INTER_SDC
     94  virtual Void  parseDeltaDC      ( TComDataCU* pcCU, UInt absPartIdx, UInt depth ) = 0;
     95#endif
    9396#if H_3D_INTER_SDC
    94   virtual Void parseDeltaDC       ( TComDataCU* pcCU, UInt absPartIdx, UInt depth ) = 0;
    9597  virtual Void parseSDCFlag       ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) = 0;
    9698#endif
     
    180182  Void decodeICFlag            ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth );
    181183#endif
     184
    182185#if H_3D_INTER_SDC
    183186  Void decodeSDCFlag           ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth );
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibDecoder/TDecSbac.cpp

    r1200 r1209  
    106106, m_ChromaQpAdjFlagSCModel                   ( 1,             1,                      NUM_CHROMA_QP_ADJ_FLAG_CTX           , m_contextModels + m_numContextModels, m_numContextModels)
    107107, m_ChromaQpAdjIdcSCModel                    ( 1,             1,                      NUM_CHROMA_QP_ADJ_IDC_CTX            , m_contextModels + m_numContextModels, m_numContextModels)
    108 #if H_3D_DIM
    109 , m_cDepthIntraModeSCModel    ( 1,             1,               NUM_DEPTH_INTRA_MODE_CTX      , m_contextModels + m_numContextModels, m_numContextModels)
    110 , m_cDdcFlagSCModel           ( 1,             1,               NUM_DDC_FLAG_CTX              , m_contextModels + m_numContextModels, m_numContextModels)
    111 , m_cDdcDataSCModel           ( 1,             1,               NUM_DDC_DATA_CTX              , m_contextModels + m_numContextModels, m_numContextModels)
    112 , m_cAngleFlagSCModel         ( 1,             1,               NUM_ANGLE_FLAG_CTX            , m_contextModels + m_numContextModels, m_numContextModels)
     108
     109#if NH_3D_DMM
     110, m_cNotDmmFlagSCModel                       ( 1,             1,                      NUM_NOTDMM_FLAG_CTX                  , m_contextModels + m_numContextModels, m_numContextModels)
     111, m_cDmmModeSCModel                          ( 1,             1,                      NUM_DMM_MODE_CTX                     , m_contextModels + m_numContextModels, m_numContextModels)
     112#endif
     113#if NH_3D_DMM || NH_3D_SDC
     114, m_cDdcDataSCModel                          ( 1,             1,                      NUM_DDC_DATA_CTX                     , m_contextModels + m_numContextModels, m_numContextModels)
     115#endif
    113116#if H_3D_DIM_SDC
    114 , m_cSDCResidualFlagSCModel     ( 1,             1,             SDC_NUM_RESIDUAL_FLAG_CTX     , m_contextModels + m_numContextModels, m_numContextModels)
    115 , m_cSDCResidualSCModel         ( 1,             1,             SDC_NUM_RESIDUAL_CTX          , m_contextModels + m_numContextModels, m_numContextModels)
    116 #endif
    117 #endif
    118 #if H_3D_DIM_SDC
    119 , m_cSDCFlagSCModel                  ( 1,             1,  NUM_SDC_FLAG_CTX                 , m_contextModels + m_numContextModels, m_numContextModels)
     117, m_cSDCResidualFlagSCModel                  ( 1,             1,                     SDC_NUM_RESIDUAL_FLAG_CTX             , m_contextModels + m_numContextModels, m_numContextModels)
     118, m_cSDCResidualSCModel                      ( 1,             1,                     SDC_NUM_RESIDUAL_CTX                  , m_contextModels + m_numContextModels, m_numContextModels)
     119, m_cSDCFlagSCModel                          ( 1,             1,                     NUM_SDC_FLAG_CTX                      , m_contextModels + m_numContextModels, m_numContextModels)
     120, m_cDdcFlagSCModel                          ( 1,             1,                     NUM_DDC_FLAG_CTX                      , m_contextModels + m_numContextModels, m_numContextModels)
    120121#endif
    121122#if H_3D_DBBP
    122 , m_cDBBPFlagSCModel             ( 1,             1,                 DBBP_NUM_FLAG_CTX           , m_contextModels + m_numContextModels, m_numContextModels)
     123, m_cDBBPFlagSCModel                         ( 1,             1,                     DBBP_NUM_FLAG_CTX                     , m_contextModels + m_numContextModels, m_numContextModels)
    123124#endif
    124125
     
    197198  m_ChromaQpAdjFlagSCModel.initBuffer             ( sliceType, qp, (UChar*)INIT_CHROMA_QP_ADJ_FLAG );
    198199  m_ChromaQpAdjIdcSCModel.initBuffer              ( sliceType, qp, (UChar*)INIT_CHROMA_QP_ADJ_IDC );
    199 #if H_3D_DIM
    200   m_cDepthIntraModeSCModel.initBuffer    ( sliceType, qp, (UChar*)INIT_DEPTH_INTRA_MODE );
    201   m_cDdcFlagSCModel.initBuffer           ( sliceType, qp, (UChar*)INIT_DDC_FLAG );
    202   m_cDdcDataSCModel.initBuffer           ( sliceType, qp, (UChar*)INIT_DDC_DATA );
    203   m_cAngleFlagSCModel.initBuffer         ( sliceType, qp, (UChar*)INIT_ANGLE_FLAG );
     200#if NH_3D_DMM
     201  m_cNotDmmFlagSCModel.initBuffer                 ( sliceType, qp, (UChar*)INIT_NOTDMM_FLAG );
     202  m_cDmmModeSCModel.initBuffer                    ( sliceType, qp, (UChar*)INIT_DMM_MODE );
     203#endif
     204#if NH_3D_DMM || NH_3D_SDC
     205  m_cDdcDataSCModel.initBuffer                    ( sliceType, qp, (UChar*)INIT_DDC_DATA );
     206#endif
    204207#if H_3D_DIM_SDC
    205   m_cSDCResidualFlagSCModel.initBuffer    ( sliceType, qp, (UChar*)INIT_SDC_RESIDUAL_FLAG );
    206   m_cSDCResidualSCModel.initBuffer        ( sliceType, qp, (UChar*)INIT_SDC_RESIDUAL );
    207 #endif
    208 #endif
    209 #if H_3D_DIM_SDC
    210   m_cSDCFlagSCModel.initBuffer            ( sliceType, qp, (UChar*)INIT_SDC_FLAG );
     208  m_cSDCResidualFlagSCModel.initBuffer            ( sliceType, qp, (UChar*)INIT_SDC_RESIDUAL_FLAG );
     209  m_cSDCResidualSCModel.initBuffer                ( sliceType, qp, (UChar*)INIT_SDC_RESIDUAL );
     210  m_cSDCFlagSCModel.initBuffer                    ( sliceType, qp, (UChar*)INIT_SDC_FLAG );
     211  m_cDdcFlagSCModel.initBuffer                    ( sliceType, qp, (UChar*)INIT_DDC_FLAG );
    211212#endif
    212213#if H_3D_DBBP
    213   m_cDBBPFlagSCModel.initBuffer              ( sliceType, qp, (UChar*)INIT_DBBP_FLAG );
     214  m_cDBBPFlagSCModel.initBuffer                   ( sliceType, qp, (UChar*)INIT_DBBP_FLAG );
    214215#endif
    215216
     
    247248  m_cCUICFlagSCModel.initBuffer          ( eSliceType, iQp, (UChar*)INIT_IC_FLAG );
    248249#endif
    249 #if H_3D_DIM
    250   m_cDepthIntraModeSCModel.initBuffer    ( eSliceType, iQp, (UChar*)INIT_DEPTH_INTRA_MODE );
    251   m_cDdcFlagSCModel.initBuffer           ( eSliceType, iQp, (UChar*)INIT_DDC_FLAG );
    252   m_cDdcDataSCModel.initBuffer           ( eSliceType, iQp, (UChar*)INIT_DDC_DATA );
    253   m_cAngleFlagSCModel.initBuffer         ( eSliceType, iQp, (UChar*)INIT_ANGLE_FLAG );
    254250#if H_3D_DIM_SDC
    255251  m_cSDCResidualFlagSCModel.initBuffer    ( eSliceType, iQp, (UChar*)INIT_SDC_RESIDUAL_FLAG );
    256252  m_cSDCResidualSCModel.initBuffer        ( eSliceType, iQp, (UChar*)INIT_SDC_RESIDUAL );
    257 #endif
    258 #endif
    259 #if H_3D_DIM_SDC
    260253  m_cSDCFlagSCModel.initBuffer            ( eSliceType, iQp, (UChar*)INIT_SDC_FLAG );
     254  m_cDdcFlagSCModel.initBuffer           ( eSliceType, iQp, (UChar*)INIT_DDC_FLAG );
    261255#endif
    262256#if H_3D_DBBP
     
    433427  }
    434428}
    435 
    436 #if H_3D_DIM
    437 Void TDecSbac::xReadExGolombLevel( UInt& ruiSymbol, ContextModel& rcSCModel  )
    438 {
    439   UInt uiSymbol;
    440   UInt uiCount = 0;
    441   do
    442   {
    443     m_pcTDecBinIf->decodeBin( uiSymbol, rcSCModel );
    444     uiCount++;
    445   }
    446   while( uiSymbol && ( uiCount != 3 ) );
    447   ruiSymbol = uiCount - 1;
    448 
    449   if( uiSymbol )
    450   {
    451     xReadEpExGolomb( uiSymbol, 0 );
    452     ruiSymbol += uiSymbol + 1;
    453   }
    454 
    455   return;
    456 }
    457 
    458 Void TDecSbac::xParseDimDeltaDC( Pel& rValDeltaDC, UInt uiNumSeg )
    459 {
    460   UInt absValDeltaDC = 0;
    461   xReadExGolombLevel( absValDeltaDC, m_cDdcDataSCModel.get(0, 0, 0) );
    462   rValDeltaDC = (Pel)absValDeltaDC + ( uiNumSeg > 1 ? 0 : 1 );
    463 
    464   if( rValDeltaDC != 0 )
    465   {
    466     UInt uiSign;
    467     m_pcTDecBinIf->decodeBinEP( uiSign );
    468     if ( uiSign )
    469     {
    470       rValDeltaDC = -rValDeltaDC;
    471     }
    472   }
    473 }
    474 
    475 
    476 #if H_3D_DIM_DMM
    477 Void TDecSbac::xParseDmm1WedgeIdx( UInt& ruiTabIdx, Int iNumBit )
    478 {
    479   UInt uiSymbol, uiIdx = 0;
    480   for( Int i = 0; i < iNumBit; i++ )
    481   {
    482     m_pcTDecBinIf->decodeBinEP( uiSymbol );
    483     uiIdx += uiSymbol << i;
    484   }
    485   ruiTabIdx = uiIdx;
    486 }
    487 #endif
    488 
    489 
    490 #endif
    491 
    492429
    493430/** Parse I_PCM information.
     
    1019956  for (j=0;j<partNum;j++)
    1020957  {
    1021 #if H_3D_DIM
     958#if NH_3D_DMM
    1022959    if( pcCU->getSlice()->getIntraSdcWedgeFlag() || pcCU->getSlice()->getIntraContourFlag() )
    1023960    {
    1024       parseIntraDepth( pcCU, absPartIdx+partOffset*j, depth );
    1025     }
    1026     if( pcCU->getLumaIntraDir( absPartIdx+partOffset*j ) < NUM_INTRA_MODE )
     961      xParseIntraDepthMode( pcCU, absPartIdx+partOffset*j, depth );
     962      xParseDmmData       ( pcCU, absPartIdx+partOffset*j, depth );
     963    }
     964    if( pcCU->getIntraDir( CHANNEL_TYPE_LUMA, absPartIdx+partOffset*j ) < NUM_INTRA_MODE )
    1027965    {
    1028966#endif
     
    1032970      DTRACE_CU("prev_intra_luma_pred_flag", symbol)
    1033971#endif
    1034 #if H_3D_DIM
     972#if NH_3D_DMM
    1035973    }
    1036974#endif
     
    1038976  for (j=0;j<partNum;j++)
    1039977  {
    1040 #if H_3D_DIM
    1041     if( pcCU->getLumaIntraDir( absPartIdx+partOffset*j ) < NUM_INTRA_MODE )
     978#if NH_3D_DMM
     979    if( pcCU->getIntraDir( CHANNEL_TYPE_LUMA, absPartIdx+partOffset*j ) < NUM_INTRA_MODE )
    1042980    {
    1043981#endif
     
    10841022    }
    10851023    pcCU->setIntraDirSubParts(CHANNEL_TYPE_LUMA, (UChar)intraPredMode, absPartIdx+partOffset*j, depth );
    1086 #if H_3D_DIM
     1024#if NH_3D_DMM
    10871025    }
    10881026#endif
     
    11201058  pcCU->setIntraDirSubParts( CHANNEL_TYPE_CHROMA, uiSymbol, uiAbsPartIdx, uiDepth );
    11211059}
    1122 
    1123 #if H_3D_DIM
    1124 Void TDecSbac::parseIntraDepth( TComDataCU* pcCU, UInt absPartIdx, UInt depth )
    1125 {
    1126   parseIntraDepthMode( pcCU, absPartIdx, depth );
    1127 
    1128   UInt dir     = pcCU->getLumaIntraDir( absPartIdx );
    1129   UInt dimType = getDimType( dir );
    1130 
    1131   switch( dimType )
    1132   {
    1133 #if H_3D_DIM_DMM
    1134   case( DMM1_IDX ):
    1135     {
    1136       UInt uiTabIdx = 0;
    1137       xParseDmm1WedgeIdx( uiTabIdx, g_dmm1TabIdxBits[pcCU->getIntraSizeIdx(absPartIdx)] );
    1138 
    1139       assert( uiTabIdx < g_dmmWedgeLists[ g_aucConvertToBit[ pcCU->getDMM1BasePatternWidth( pcCU->getWidth( absPartIdx ) )]].size());
    1140 
    1141       pcCU->setDmmWedgeTabIdxSubParts( uiTabIdx, dimType, absPartIdx, depth );
    1142     } break;
    1143   case( DMM4_IDX ): break;
    1144 #endif
    1145   default: break;
    1146   }
    1147 
    1148   pcCU->setLumaIntraDirSubParts( (UChar)dir, absPartIdx, depth );
    1149 }
    1150 
    1151 Void TDecSbac::parseIntraDepthMode( TComDataCU* pcCU, UInt absPartIdx, UInt depth )
    1152 {
    1153   UInt uiSymbol, uiIsDimMode;
    1154 
    1155   if( ( pcCU->getSlice()->getSPS()->getMaxCUWidth() >> pcCU->getDepth( absPartIdx ) ) < 64 ) //DMM and HEVC intra modes are both allowed
    1156   {
    1157     m_pcTDecBinIf->decodeBin( uiSymbol, m_cAngleFlagSCModel.get( 0, 0, 0 ) );
    1158   }
    1159   else
    1160   {
    1161     uiSymbol = 1;
    1162   }
    1163   uiIsDimMode = uiSymbol ? 0 : 1;
    1164   pcCU->setLumaIntraDirSubParts( 0, absPartIdx, depth );
    1165 
    1166   //decode DMM index
    1167   if( uiIsDimMode )
    1168   {
    1169     if( pcCU->getSlice()->getIntraSdcWedgeFlag() && pcCU->getSlice()->getIntraContourFlag() )
    1170     {
    1171       m_pcTDecBinIf->decodeBin( uiSymbol, m_cDepthIntraModeSCModel.get( 0, 0, 0 ) );
    1172       if( !uiSymbol )
    1173       {
    1174         pcCU->setLumaIntraDirSubParts( DIM_OFFSET, absPartIdx, depth );
    1175       }
    1176       else
    1177       {
    1178         pcCU->setLumaIntraDirSubParts( ( 1+ DIM_OFFSET ), absPartIdx, depth );
    1179       }
    1180     }
    1181     else if ( pcCU->getSlice()->getIntraSdcWedgeFlag() )
    1182     {
    1183       pcCU->setLumaIntraDirSubParts( DIM_OFFSET, absPartIdx, depth );
    1184     }
    1185     else if( pcCU->getSlice()->getIntraContourFlag() )
    1186     {
    1187       pcCU->setLumaIntraDirSubParts( ( 1+ DIM_OFFSET ), absPartIdx, depth );
    1188     }
    1189   }
    1190 }
    1191 #endif
    11921060
    11931061Void TDecSbac::parseInterDir( TComDataCU* pcCU, UInt& ruiInterDir, UInt uiAbsPartIdx )
     
    24722340#endif
    24732341
    2474 #if H_3D_INTER_SDC
     2342#if NH_3D_DMM || H_3D_DIM_SDC || H_3D_INTER_SDC
    24752343Void TDecSbac::parseDeltaDC( TComDataCU* pcCU, UInt absPartIdx, UInt depth )
    24762344{
    2477   if( ! ( pcCU->getSDCFlag( absPartIdx ) || ( pcCU->isIntra( absPartIdx ) && getDimType( pcCU->getLumaIntraDir( absPartIdx ) ) < DIM_NUM_TYPE ) ) )
    2478   {
     2345#if H_3D_DIM_SDC || H_3D_INTER_SDC
     2346  if( !(pcCU->getSDCFlag( absPartIdx )) )
     2347#endif
     2348#if NH_3D_DMM
     2349  if( !(pcCU->isIntra( absPartIdx ) && isDmmMode( pcCU->getIntraDir( CHANNEL_TYPE_LUMA, absPartIdx ) )) )
     2350#endif
    24792351    assert( 0 );
    2480   }
    24812352
    24822353  UInt symbol = 1;
    2483   UInt uiNumSegments = isDimMode( pcCU->getLumaIntraDir( absPartIdx ) ) ? 2 : 1;
    2484 
     2354#if H_3D_DIM_SDC
    24852355  if( pcCU->isIntra( absPartIdx ) && pcCU->getSDCFlag( absPartIdx ))
    24862356  {
    2487 
    24882357    m_pcTDecBinIf->decodeBin( symbol, m_cDdcFlagSCModel.get( 0, 0, 0 ) );
    24892358      assert( pcCU->getPartitionSize( absPartIdx ) == SIZE_2Nx2N );
     
    24912360      pcCU->setCbfSubParts( 1, 1, 1, absPartIdx, depth );
    24922361    }
     2362#endif
     2363  UInt uiNumSegments = 1;
     2364#if NH_3D_DMM
     2365  uiNumSegments = isDmmMode( pcCU->getIntraDir( CHANNEL_TYPE_LUMA, absPartIdx ) ) ? 2 : 1;
     2366#endif
    24932367
    24942368  for( UInt segment = 0; segment < uiNumSegments; segment++ )
     
    24972371    if( symbol )
    24982372    {
    2499       xParseDimDeltaDC( valDeltaDC, uiNumSegments );
     2373      xParseDeltaDC( valDeltaDC, uiNumSegments );
    25002374    }
    25012375
    25022376    if( pcCU->isIntra( absPartIdx ) )
    25032377    {
    2504       UInt dir     = pcCU->getLumaIntraDir( absPartIdx );
    2505 
     2378#if H_3D_DIM_SDC
    25062379      if( pcCU->getSDCFlag( absPartIdx ) )
    25072380      {
     
    25102383      else
    25112384      {
    2512         pcCU->setDimDeltaDC( getDimType( dir ), segment, absPartIdx, valDeltaDC );
    2513       }
    2514     }
     2385#endif
     2386#if NH_3D_DMM
     2387        pcCU->setDmmDeltaDC( getDmmType( pcCU->getIntraDir( CHANNEL_TYPE_LUMA, absPartIdx ) ), segment, absPartIdx, valDeltaDC );
     2388#endif
     2389#if H_3D_DIM_SDC
     2390      }
     2391#endif
     2392    }
     2393#if H_3D_INTER_SDC
    25152394    else
    25162395    {
    25172396      pcCU->setSDCSegmentDCOffset( valDeltaDC, segment, absPartIdx );
    25182397    }
    2519   }
    2520 }
    2521 
     2398#endif
     2399  }
     2400}
     2401
     2402Void TDecSbac::xParseDeltaDC( Pel& rValDeltaDC, UInt uiNumSeg )
     2403{
     2404  UInt absValDeltaDC = 0;
     2405  xReadExGolombLevelDdc( absValDeltaDC );
     2406  rValDeltaDC = (Pel)absValDeltaDC + ( uiNumSeg > 1 ? 0 : 1 );
     2407
     2408  if( rValDeltaDC != 0 )
     2409  {
     2410    UInt uiSign;
     2411    m_pcTDecBinIf->decodeBinEP( uiSign RExt__DECODER_DEBUG_BIT_STATISTICS_PASS_OPT_ARG(STATS__CABAC_BITS__DELTADC_SIGN_EP) );
     2412    if ( uiSign )
     2413    {
     2414      rValDeltaDC = -rValDeltaDC;
     2415    }
     2416  }
     2417}
     2418
     2419Void TDecSbac::xReadExGolombLevelDdc( UInt& ruiSymbol )
     2420{
     2421  UInt uiSymbol;
     2422  UInt uiCount = 0;
     2423  do
     2424  {
     2425    m_pcTDecBinIf->decodeBin( uiSymbol, m_cDdcDataSCModel.get(0, 0, 0) RExt__DECODER_DEBUG_BIT_STATISTICS_PASS_OPT_ARG(STATS__CABAC_BITS__DELTADC_PREFIX) );
     2426    uiCount++;
     2427  }
     2428  while( uiSymbol && ( uiCount != 3 ) );
     2429  ruiSymbol = uiCount - 1;
     2430
     2431  if( uiSymbol )
     2432  {
     2433    xReadEpExGolomb( uiSymbol, 0 RExt__DECODER_DEBUG_BIT_STATISTICS_PASS_OPT_ARG(STATS__CABAC_BITS__DELTADC_SUFFIX_EP) );
     2434    ruiSymbol += uiSymbol + 1;
     2435  }
     2436
     2437  return;
     2438}
     2439#endif
     2440#if NH_3D_DMM
     2441Void TDecSbac::xParseIntraDepthMode( TComDataCU* pcCU, UInt absPartIdx, UInt depth )
     2442{
     2443  pcCU->setIntraDirSubParts( CHANNEL_TYPE_LUMA, 0, absPartIdx, depth );
     2444
     2445  UInt uiSymbol;
     2446  if( ( pcCU->getSlice()->getSPS()->getMaxCUWidth() >> pcCU->getDepth( absPartIdx ) ) < 64 ) //DMM and HEVC intra modes are both allowed
     2447  {
     2448    m_pcTDecBinIf->decodeBin( uiSymbol, m_cNotDmmFlagSCModel.get( 0, 0, 0 ) RExt__DECODER_DEBUG_BIT_STATISTICS_PASS_OPT_ARG(STATS__CABAC_BITS__NOTDMM_FLAG) );
     2449  }
     2450  else
     2451  {
     2452    uiSymbol = 1;
     2453  }
     2454
     2455  //decode DMM mode index
     2456  if( !uiSymbol )
     2457  {
     2458    if( pcCU->getSlice()->getIntraSdcWedgeFlag() && pcCU->getSlice()->getIntraContourFlag() )
     2459    {
     2460      m_pcTDecBinIf->decodeBin( uiSymbol, m_cDmmModeSCModel.get( 0, 0, 0 ) RExt__DECODER_DEBUG_BIT_STATISTICS_PASS_OPT_ARG(STATS__CABAC_BITS__DMMMODE) );
     2461      if( !uiSymbol )
     2462      {
     2463        pcCU->setIntraDirSubParts( CHANNEL_TYPE_LUMA, DMM_OFFSET, absPartIdx, depth );
     2464      }
     2465      else
     2466      {
     2467        pcCU->setIntraDirSubParts( CHANNEL_TYPE_LUMA, ( 1+ DMM_OFFSET ), absPartIdx, depth );
     2468      }
     2469    }
     2470    else if( pcCU->getSlice()->getIntraSdcWedgeFlag() )
     2471    {
     2472      pcCU->setIntraDirSubParts( CHANNEL_TYPE_LUMA, DMM_OFFSET, absPartIdx, depth );
     2473    }
     2474    else if( pcCU->getSlice()->getIntraContourFlag() )
     2475    {
     2476      pcCU->setIntraDirSubParts( CHANNEL_TYPE_LUMA, ( 1+ DMM_OFFSET ), absPartIdx, depth );
     2477    }
     2478  }
     2479}
     2480
     2481Void TDecSbac::xParseDmmData( TComDataCU* pcCU, UInt absPartIdx, UInt depth )
     2482{
     2483  UInt dir = pcCU->getIntraDir( CHANNEL_TYPE_LUMA, absPartIdx );
     2484  switch( getDmmType( dir ) )
     2485  {
     2486  case( DMM1_IDX ):
     2487    {
     2488      UInt uiTabIdx = 0;
     2489      xParseDmm1WedgeIdx( uiTabIdx, g_dmm1TabIdxBits[pcCU->getIntraSizeIdx(absPartIdx)] );
     2490      assert( uiTabIdx < getWedgeListScaled( pcCU->getWidth( absPartIdx ) )->size() );
     2491      pcCU->setDmm1WedgeTabIdxSubParts( uiTabIdx, absPartIdx, depth );
     2492    } break;
     2493  case( DMM4_IDX ): break;
     2494  default: break;
     2495  }
     2496}
     2497
     2498Void TDecSbac::xParseDmm1WedgeIdx( UInt& ruiTabIdx, Int iNumBit )
     2499{
     2500  UInt uiSymbol, uiIdx = 0;
     2501  for( Int i = 0; i < iNumBit; i++ )
     2502  {
     2503    m_pcTDecBinIf->decodeBinEP( uiSymbol RExt__DECODER_DEBUG_BIT_STATISTICS_PASS_OPT_ARG(STATS__CABAC_BITS__DMM1_BITS_EP) );
     2504    uiIdx += uiSymbol << i;
     2505  }
     2506  ruiTabIdx = uiIdx;
     2507}
     2508#endif
     2509#if H_3D_INTER_SDC
    25222510Void TDecSbac::parseSDCFlag( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth )
    25232511{
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibDecoder/TDecSbac.h

    r1200 r1209  
    107107  Void  xReadCoefRemainExGolomb ( UInt &rSymbol, UInt &rParam, const Bool useLimitedPrefixLength, const Int maxLog2TrDynamicRange );
    108108#endif
    109 #if H_3D_DIM
    110   Void  xReadExGolombLevel   ( UInt& ruiSymbol, ContextModel& rcSCModel  );
    111   Void  xParseDimDeltaDC     ( Pel& rValDeltaDC, UInt uiNumSeg );
    112 #if H_3D_DIM_DMM
     109#if NH_3D_DMM || H_3D_DIM_SDC || H_3D_INTER_SDC
     110  Void  xReadExGolombLevelDdc( UInt& ruiSymbol );
     111  Void  xParseDeltaDC        ( Pel& rValDeltaDC, UInt uiNumSeg );
     112#endif
     113#if NH_3D_DMM
     114  Void  xParseIntraDepthMode ( TComDataCU* pcCU, UInt absPartIdx, UInt depth );
     115  Void  xParseDmmData        ( TComDataCU* pcCU, UInt absPartIdx, UInt depth );
    113116  Void  xParseDmm1WedgeIdx   ( UInt& ruiTabIdx, Int iNumBit );
    114117#endif
     
    116119  Void  xParseSDCResidualData     ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth, UInt uiPart );
    117120#endif
    118 #endif
    119121#if H_3D_INTER_SDC
    120   Void  parseDeltaDC         ( TComDataCU* pcCU, UInt absPartIdx, UInt depth );
    121122  Void  parseSDCFlag         ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth );
    122123#endif
     
    134135#if H_3D
    135136  Void parseDIS          ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth );
     137#endif
     138#if NH_3D_DMM || H_3D_DIM_SDC || H_3D_INTER_SDC
     139  Void  parseDeltaDC      ( TComDataCU* pcCU, UInt absPartIdx, UInt depth );
    136140#endif
    137141  Void parseCUTransquantBypassFlag( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth );
     
    150154  Void parseIntraDirLumaAng( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth );
    151155  Void parseIntraDirChroma( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth );
    152 
    153 #if H_3D_DIM
    154   Void parseIntraDepth     ( TComDataCU* pcCU, UInt absPartIdx, UInt depth );
    155   Void parseIntraDepthMode ( TComDataCU* pcCU, UInt absPartIdx, UInt depth );
    156 #endif
    157 
    158156  Void parseInterDir      ( TComDataCU* pcCU, UInt& ruiInterDir, UInt uiAbsPartIdx );
    159157  Void parseRefFrmIdx     ( TComDataCU* pcCU, Int& riRefFrmIdx, RefPicList eRefList );
     
    227225  ContextModel3DBuffer m_ChromaQpAdjFlagSCModel;
    228226  ContextModel3DBuffer m_ChromaQpAdjIdcSCModel;
    229 #if H_3D_DIM
    230   ContextModel3DBuffer m_cDepthIntraModeSCModel;
    231   ContextModel3DBuffer m_cDdcFlagSCModel;
     227#if NH_3D_DMM
     228  ContextModel3DBuffer m_cNotDmmFlagSCModel;
     229  ContextModel3DBuffer m_cDmmModeSCModel;
     230#endif
     231#if NH_3D_DMM || NH_3D_SDC
    232232  ContextModel3DBuffer m_cDdcDataSCModel;
    233   ContextModel3DBuffer m_cAngleFlagSCModel;
     233#endif
    234234#if H_3D_DIM_SDC 
    235235  ContextModel3DBuffer m_cSDCResidualFlagSCModel;
    236236  ContextModel3DBuffer m_cSDCResidualSCModel;
    237 #endif
    238 #endif
    239 #if H_3D_DIM_SDC 
    240237  ContextModel3DBuffer m_cSDCFlagSCModel;
     238  ContextModel3DBuffer m_cDdcFlagSCModel;
    241239#endif
    242240#if H_3D_DBBP
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibEncoder/TEncCavlc.cpp

    r1200 r1209  
    28872887   assert(0);
    28882888 }
    2889 
    28902889#if H_3D_INTER_SDC
    2891 Void TEncCavlc::codeDeltaDC( TComDataCU* pcCU, UInt uiAbsPartIdx )
     2890Void TEncCavlc::codeSDCFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx )
    28922891{
    28932892  assert(0);
    28942893}
    2895 
    2896 Void TEncCavlc::codeSDCFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx )
    2897 {
    2898   assert(0);
    2899 }
    2900 
    29012894#endif
    29022895   
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibEncoder/TEncCavlc.h

    r1200 r1209  
    126126  Void codeMergeFlag     ( TComDataCU* pcCU, UInt uiAbsPartIdx );
    127127  Void codeMergeIndex    ( TComDataCU* pcCU, UInt uiAbsPartIdx );
     128#if NH_3D_DMM || H_3D_DIM_SDC || H_3D_INTER_SDC
     129  Void  codeDeltaDC      ( TComDataCU* /*pcCU*/, UInt /*absPartIdx*/ ) { assert(0); };
     130#endif
    128131#if H_3D_ARP
    129132  Void codeARPW          ( TComDataCU* pcCU, UInt uiAbsPartIdx );
     
    132135  Void codeICFlag        ( TComDataCU* pcCU, UInt uiAbsPartIdx );
    133136#endif
     137
    134138#if H_3D_INTER_SDC
    135   Void codeDeltaDC       ( TComDataCU* pcCU, UInt uiAbsPartIdx );
    136139  Void codeSDCFlag       ( TComDataCU* pcCU, UInt uiAbsPartIdx );
    137140#endif
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibEncoder/TEncCu.cpp

    r1200 r1209  
    733733    }
    734734#endif
    735 #if H_3D_DIM_ENC
     735#if NH_3D_ENC_DEPTH
    736736    if( rpcBestCU->getSlice()->getIsDepth() && rpcBestCU->getSlice()->isIRAP() )
    737737    {
     
    10751075
    10761076        if((rpcBestCU->getSlice()->getSliceType() == I_SLICE)                                     ||
    1077             ((!m_pcEncCfg->getDisableIntraPUsInInterSlices()) && (
     1077           ((!m_pcEncCfg->getDisableIntraPUsInInterSlices()) && ( // avoid very complex intra if it is unlikely
    10781078           (rpcBestCU->getCbf( 0, COMPONENT_Y  ) != 0)                                            ||
    10791079          ((rpcBestCU->getCbf( 0, COMPONENT_Cb ) != 0) && (numberValidComponents > COMPONENT_Cb)) ||
    1080           ((rpcBestCU->getCbf( 0, COMPONENT_Cr ) != 0) && (numberValidComponents > COMPONENT_Cr)))
    1081  // avoid very complex intra if it is unlikely
    1082 #if H_3D_DIM_ENC
     1080          ((rpcBestCU->getCbf( 0, COMPONENT_Cr ) != 0) && (numberValidComponents > COMPONENT_Cr))
     1081 #if NH_3D_ENC_DEPTH
    10831082            || rpcBestCU->getSlice()->getIsDepth()
    10841083#endif
    1085             ))
     1084            )))
    10861085        {
    1087 #if H_3D_DIM
     1086#if NH_3D_ENC_DEPTH
    10881087            Bool bOnlyIVP = false;
    10891088            Bool bUseIVP = true;
    1090             if( rpcBestCU->getSlice()->getIsDepth() && !(rpcBestCU->getSlice()->isIRAP()) &&
    1091               rpcBestCU->getSlice()->getSliceType() != I_SLICE &&
    1092               rpcBestCU->getCbf( 0, TEXT_LUMA     ) == 0 &&
    1093               rpcBestCU->getCbf( 0, TEXT_CHROMA_U ) == 0 &&
    1094               rpcBestCU->getCbf( 0, TEXT_CHROMA_V ) == 0
    1095               )
     1089            if( (rpcBestCU->getSlice()->getSliceType() != I_SLICE) &&
     1090                !( (rpcBestCU->getCbf( 0, COMPONENT_Y  ) != 0)                                            ||
     1091                  ((rpcBestCU->getCbf( 0, COMPONENT_Cb ) != 0) && (numberValidComponents > COMPONENT_Cb)) ||
     1092                  ((rpcBestCU->getCbf( 0, COMPONENT_Cr ) != 0) && (numberValidComponents > COMPONENT_Cr))   ) &&
     1093                  (rpcBestCU->getSlice()->getIsDepth() && !(rpcBestCU->getSlice()->isIRAP())) )
    10961094            {
    10971095              bOnlyIVP = true;
     
    11001098            if( bUseIVP )
    11011099            {
    1102               xCheckRDCostIntra( rpcBestCU, rpcTempCU, SIZE_2Nx2N, bOnlyIVP );
     1100              xCheckRDCostIntra( rpcBestCU, rpcTempCU, intraCost, SIZE_2Nx2N DEBUG_STRING_PASS_INTO(sDebug), bOnlyIVP );
    11031101#else
    11041102          xCheckRDCostIntra( rpcBestCU, rpcTempCU, intraCost, SIZE_2Nx2N DEBUG_STRING_PASS_INTO(sDebug) );
     
    11221120            {
    11231121              Double tmpIntraCost;
    1124 #if H_3D_DIM
    1125               xCheckRDCostIntra( rpcBestCU, rpcTempCU, SIZE_NxN, bOnlyIVP );
     1122#if NH_3D_ENC_DEPTH
     1123              xCheckRDCostIntra( rpcBestCU, rpcTempCU, tmpIntraCost, SIZE_NxN DEBUG_STRING_PASS_INTO(sDebug), bOnlyIVP );
    11261124#else
    11271125              xCheckRDCostIntra( rpcBestCU, rpcTempCU, tmpIntraCost, SIZE_NxN DEBUG_STRING_PASS_INTO(sDebug)   );
     
    11351133#endif
    11361134          }
    1137 #if H_3D
     1135#if NH_3D_ENC_DEPTH
    11381136          }
    11391137#endif
     
    26542652#endif
    26552653
    2656 #if H_3D_DIM
    2657 Void TEncCu::xCheckRDCostIntra( TComDataCU*& rpcBestCU, TComDataCU*& rpcTempCU, PartSize eSize, Bool bOnlyIVP )
    2658 #else
    26592654Void TEncCu::xCheckRDCostIntra( TComDataCU *&rpcBestCU,
    26602655                                TComDataCU *&rpcTempCU,
    26612656                                Double      &cost,
    26622657                                PartSize     eSize
    2663                                 DEBUG_STRING_FN_DECLARE(sDebug) )
    2664 #endif
     2658                                DEBUG_STRING_FN_DECLARE(sDebug)
     2659#if NH_3D_ENC_DEPTH
     2660                              , Bool bOnlyIVP
     2661#endif
     2662                              )
    26652663{
    26662664  DEBUG_STRING_NEW(sTest)
     
    26902688  Pel resiLuma[NUMBER_OF_STORED_RESIDUAL_TYPES][MAX_CU_SIZE * MAX_CU_SIZE];
    26912689
    2692   m_pcPredSearch->estIntraPredLumaQT( rpcTempCU, m_ppcOrigYuv[uiDepth], m_ppcPredYuvTemp[uiDepth], m_ppcResiYuvTemp[uiDepth], m_ppcRecoYuvTemp[uiDepth], resiLuma DEBUG_STRING_PASS_INTO(sTest) );
     2690  m_pcPredSearch->estIntraPredLumaQT( rpcTempCU, m_ppcOrigYuv[uiDepth], m_ppcPredYuvTemp[uiDepth], m_ppcResiYuvTemp[uiDepth], m_ppcRecoYuvTemp[uiDepth], resiLuma DEBUG_STRING_PASS_INTO(sTest)
     2691#if NH_3D_ENC_DEPTH
     2692                                    , bOnlyIVP
     2693#endif
     2694                                    );
    26932695
    26942696  m_ppcRecoYuvTemp[uiDepth]->copyToPicComponent(COMPONENT_Y, rpcTempCU->getPic()->getPicYuvRec(), rpcTempCU->getCtuRsAddr(), rpcTempCU->getZorderIdxInCtu() );
     
    26962698  if (rpcBestCU->getPic()->getChromaFormat()!=CHROMA_400)
    26972699  {
    2698 #if H_3D_DIM
    2699     m_pcPredSearch->estIntraPredQT      ( rpcTempCU, m_ppcOrigYuv[uiDepth], m_ppcPredYuvTemp[uiDepth], m_ppcResiYuvTemp[uiDepth], m_ppcRecoYuvTemp[uiDepth], uiPreCalcDistC, bSeparateLumaChroma, bOnlyIVP );
    2700 #else
    27012700    m_pcPredSearch->estIntraPredChromaQT( rpcTempCU, m_ppcOrigYuv[uiDepth], m_ppcPredYuvTemp[uiDepth], m_ppcResiYuvTemp[uiDepth], m_ppcRecoYuvTemp[uiDepth], resiLuma DEBUG_STRING_PASS_INTO(sTest) );
    2702 #endif
    27032701  }
    27042702#if H_3D_DIM_SDC
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibEncoder/TEncCu.h

    r1200 r1209  
    162162  Void  xCheckRDCostDIS   ( TComDataCU*& rpcBestCU, TComDataCU*& rpcTempCU, PartSize ePartSize  );
    163163#endif
    164 #if H_3D_DIM
    165   Void  xCheckRDCostIntra   ( TComDataCU*& rpcBestCU, TComDataCU*& rpcTempCU, PartSize ePartSize, Bool bOnlyIVP );
    166 #else
    167164  Void  xCheckRDCostIntra   ( TComDataCU *&rpcBestCU,
    168165                              TComDataCU *&rpcTempCU,
     
    170167                              PartSize     ePartSize
    171168                              DEBUG_STRING_FN_DECLARE(sDebug)
     169#if NH_3D_ENC_DEPTH
     170                            , Bool bOnlyIVP
     171#endif
    172172                            );
    173 #endif
    174173  Void  xCheckDQP           ( TComDataCU*  pcCU );
    175174
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibEncoder/TEncEntropy.cpp

    r1200 r1209  
    722722    assert( pcCU->getCbf(uiAbsPartIdx, TEXT_CHROMA_V) == 1 );
    723723  }
    724 
    725 
     724#endif
     725#if H_3D_INTER_SDC
    726726  if( pcCU->getSDCFlag( uiAbsPartIdx ) && !pcCU->isIntra( uiAbsPartIdx ) )
    727727  {
     
    730730    assert( pcCU->getSlice()->getIsDepth() );
    731731  }
    732 
    733   if( pcCU->getSlice()->getIsDepth() && ( pcCU->getSDCFlag( uiAbsPartIdx ) || pcCU->isIntra( uiAbsPartIdx ) ) )
     732#endif
     733#if NH_3D
     734  if( pcCU->getSlice()->getIsDepth() )
     735  {
     736#if H_3D_DIM_SDC || H_3D_INTER_SDC
     737    if( pcCU->getSDCFlag( uiAbsPartIdx ) )
     738    {
     739      m_pcEntropyCoderIf->codeDeltaDC( pcCU, uiAbsPartIdx );
     740      return;
     741    }
     742#endif
     743#if NH_3D_DMM
     744    if( pcCU->isIntra(uiAbsPartIdx) )
    734745  {
    735746    Int iPartNum = ( pcCU->isIntra( uiAbsPartIdx ) && pcCU->getPartitionSize( uiAbsPartIdx ) == SIZE_NxN ) ? 4 : 1;
    736     UInt uiPartOffset = ( pcCU->getPic()->getNumPartInCU() >> ( pcCU->getDepth( uiAbsPartIdx ) << 1 ) ) >> 2;
    737    
    738     if( !pcCU->getSDCFlag( uiAbsPartIdx ) )
    739     {
     747      UInt uiPartOffset = ( pcCU->getPic()->getNumPartitionsInCtu() >> ( pcCU->getDepth( uiAbsPartIdx ) << 1 ) ) >> 2;
    740748      for( Int iPart = 0; iPart < iPartNum; iPart++ )
    741749      {
    742         if( getDimType( pcCU->getLumaIntraDir( uiAbsPartIdx + uiPartOffset*iPart ) ) < DIM_NUM_TYPE )
     750        if( isDmmMode( pcCU->getIntraDir( CHANNEL_TYPE_LUMA, uiAbsPartIdx + uiPartOffset*iPart ) ) )
    743751        {
    744752          m_pcEntropyCoderIf->codeDeltaDC( pcCU, uiAbsPartIdx + uiPartOffset*iPart );
     
    746754      }
    747755    }
    748     else
    749     {
    750       m_pcEntropyCoderIf->codeDeltaDC( pcCU, uiAbsPartIdx );
    751       return;
    752     }
    753   }
    754 #endif
    755 
     756#endif
     757  }
     758#endif
    756759
    757760  if( pcCU->isIntra(uiAbsPartIdx) )
     
    840843}
    841844
     845#if NH_3D_DMM || H_3D_DIM_SDC || H_3D_INTER_SDC
     846Void TEncEntropy::encodeDeltaDC  ( TComDataCU* pcCU, UInt absPartIdx )
     847{
     848  m_pcEntropyCoderIf->codeDeltaDC( pcCU, absPartIdx );
     849}
     850#endif
    842851#if H_3D_INTER_SDC
    843 Void TEncEntropy::encodeDeltaDC  ( TComDataCU* pcCU, UInt absPartIdx )
    844 {
    845   m_pcEntropyCoderIf->codeDeltaDC( pcCU, absPartIdx );
    846 }
    847 
    848852Void TEncEntropy::encodeSDCFlag( TComDataCU* pcCU, UInt uiAbsPartIdx, Bool bRD )
    849853{
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibEncoder/TEncEntropy.h

    r1200 r1209  
    8484  virtual Void codeMergeFlag     ( TComDataCU* pcCU, UInt uiAbsPartIdx ) = 0;
    8585  virtual Void codeMergeIndex    ( TComDataCU* pcCU, UInt uiAbsPartIdx ) = 0;
     86#if NH_3D_DMM || H_3D_DIM_SDC || H_3D_INTER_SDC
     87  virtual Void codeDeltaDC       ( TComDataCU* pcCU, UInt uiAbsPartIdx ) = 0;
     88#endif
    8689#if H_3D_ARP
    8790  virtual Void codeARPW          ( TComDataCU* pcCU, UInt uiAbsPartIdx ) = 0;
     
    9194#endif
    9295#if H_3D_INTER_SDC
    93   virtual Void codeDeltaDC       ( TComDataCU* pcCU, UInt uiAbsPartIdx ) = 0;
    9496  virtual Void codeSDCFlag       ( TComDataCU* pcCU, UInt uiAbsPartIdx ) = 0;
    9597#endif
     
    179181  Void encodeICFlag       ( TComDataCU* pcCU, UInt uiAbsPartIdx, Bool bRD = false );
    180182#endif
     183#if NH_3D_DMM || H_3D_DIM_SDC || H_3D_INTER_SDC
     184  Void encodeDeltaDC      ( TComDataCU* pcCU, UInt absPartIdx );
     185#endif
    181186#if H_3D_INTER_SDC
    182   Void encodeDeltaDC      ( TComDataCU* pcCU, UInt absPartIdx );
    183187  Void encodeSDCFlag      ( TComDataCU* pcCU, UInt uiAbsPartIdx, Bool bRD = false );
    184188#endif
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibEncoder/TEncSbac.cpp

    r1200 r1209  
    101101, m_ChromaQpAdjFlagSCModel             ( 1,             1,                      NUM_CHROMA_QP_ADJ_FLAG_CTX           , m_contextModels + m_numContextModels, m_numContextModels)
    102102, m_ChromaQpAdjIdcSCModel              ( 1,             1,                      NUM_CHROMA_QP_ADJ_IDC_CTX            , m_contextModels + m_numContextModels, m_numContextModels)
    103 #if H_3D_DIM
    104 , m_cDepthIntraModeSCModel             ( 1,             1,                      NUM_DEPTH_INTRA_MODE_CTX             , m_contextModels + m_numContextModels, m_numContextModels)
    105 , m_cDdcFlagSCModel                    ( 1,             1,                      NUM_DDC_FLAG_CTX                     , m_contextModels + m_numContextModels, m_numContextModels)
     103
     104#if NH_3D_DMM
     105, m_cNotDmmFlagSCModel                 ( 1,             1,                      NUM_NOTDMM_FLAG_CTX                  , m_contextModels + m_numContextModels, m_numContextModels)
     106, m_cDmmModeSCModel                    ( 1,             1,                      NUM_DMM_MODE_CTX                     , m_contextModels + m_numContextModels, m_numContextModels)
     107#endif
     108#if NH_3D_DMM || NH_3D_SDC
    106109, m_cDdcDataSCModel                    ( 1,             1,                      NUM_DDC_DATA_CTX                     , m_contextModels + m_numContextModels, m_numContextModels)
    107 , m_cAngleFlagSCModel                  ( 1,             1,                      NUM_ANGLE_FLAG_CTX                   , m_contextModels + m_numContextModels, m_numContextModels)
     110#endif
    108111#if H_3D_DIM_SDC                                                                                                     
    109112, m_cSDCResidualFlagSCModel            ( 1,             1,                      SDC_NUM_RESIDUAL_FLAG_CTX            , m_contextModels + m_numContextModels, m_numContextModels)
    110113, m_cSDCResidualSCModel                ( 1,             1,                      SDC_NUM_RESIDUAL_CTX                 , m_contextModels + m_numContextModels, m_numContextModels)
    111 #endif
    112 #endif
    113 #if H_3D_DIM_SDC
    114114, m_cSDCFlagSCModel                    ( 1,             1,                       NUM_SDC_FLAG_CTX                    , m_contextModels + m_numContextModels, m_numContextModels)
     115, m_cDdcFlagSCModel                    ( 1,             1,                      NUM_DDC_FLAG_CTX                     , m_contextModels + m_numContextModels, m_numContextModels)
    115116#endif                                                                                                         
    116117#if H_3D_DBBP                                                                                                 
     
    181182  m_ChromaQpAdjFlagSCModel.initBuffer             ( eSliceType, iQp, (UChar*)INIT_CHROMA_QP_ADJ_FLAG );
    182183  m_ChromaQpAdjIdcSCModel.initBuffer              ( eSliceType, iQp, (UChar*)INIT_CHROMA_QP_ADJ_IDC );
    183 #if H_3D_DIM
    184   m_cDepthIntraModeSCModel.initBuffer             ( eSliceType, iQp, (UChar*)INIT_DEPTH_INTRA_MODE );
    185   m_cDdcFlagSCModel.initBuffer                    ( eSliceType, iQp, (UChar*)INIT_DDC_FLAG );
     184
     185#if NH_3D_DMM
     186  m_cNotDmmFlagSCModel.initBuffer                 ( eSliceType, iQp, (UChar*)INIT_NOTDMM_FLAG );
     187  m_cDmmModeSCModel.initBuffer                    ( eSliceType, iQp, (UChar*)INIT_DMM_MODE );
     188#endif
     189#if NH_3D_DMM || NH_3D_SDC
    186190  m_cDdcDataSCModel.initBuffer                    ( eSliceType, iQp, (UChar*)INIT_DDC_DATA );
    187   m_cAngleFlagSCModel.initBuffer                  ( eSliceType, iQp, (UChar*)INIT_ANGLE_FLAG );
     191#endif
    188192#if H_3D_DIM_SDC                                 
    189193  m_cSDCResidualFlagSCModel.initBuffer            ( eSliceType, iQp, (UChar*)INIT_SDC_RESIDUAL_FLAG );
    190194  m_cSDCResidualSCModel.initBuffer                ( eSliceType, iQp, (UChar*)INIT_SDC_RESIDUAL );
    191 #endif                                           
    192 #endif                                           
    193 #if H_3D_DIM_SDC                                 
    194195  m_cSDCFlagSCModel.initBuffer                    ( eSliceType, iQp, (UChar*)INIT_SDC_FLAG );
     196  m_cDdcFlagSCModel.initBuffer                    ( eSliceType, iQp, (UChar*)INIT_DDC_FLAG );
    195197#endif                                           
    196198#if H_3D_DBBP                                   
     
    274276      curCost += m_ChromaQpAdjFlagSCModel.calcCost             ( curSliceType, qp, (UChar*)INIT_CHROMA_QP_ADJ_FLAG );
    275277      curCost += m_ChromaQpAdjIdcSCModel.calcCost              ( curSliceType, qp, (UChar*)INIT_CHROMA_QP_ADJ_IDC );
    276 #if H_3D_DIM
    277       if( m_pcSlice->getIntraSdcWedgeFlag() || m_pcSlice->getIntraContourFlag() )
    278       {
    279         curCost += m_cDepthIntraModeSCModel.calcCost    ( curSliceType, qp, (UChar*)INIT_DEPTH_INTRA_MODE );
    280         curCost += m_cDdcFlagSCModel.calcCost           ( curSliceType, qp, (UChar*)INIT_DDC_FLAG );
    281         curCost += m_cDdcDataSCModel.calcCost           ( curSliceType, qp, (UChar*)INIT_DDC_DATA );
    282         curCost += m_cAngleFlagSCModel.calcCost         ( curSliceType, qp, (UChar*)INIT_ANGLE_FLAG ); 
    283       }
     278#if NH_3D_DMM
     279      curCost += m_cNotDmmFlagSCModel.calcCost                 ( curSliceType, qp, (UChar*)INIT_NOTDMM_FLAG ); 
     280      curCost += m_cDmmModeSCModel.calcCost                    ( curSliceType, qp, (UChar*)INIT_DMM_MODE );
     281#endif
     282#if NH_3D_DMM || NH_3D_SDC
     283      curCost += m_cDdcDataSCModel.calcCost                    ( curSliceType, qp, (UChar*)INIT_DDC_DATA );
    284284#endif
    285285
     
    308308  m_cCUICFlagSCModel.initBuffer          ( eSliceType, iQp, (UChar*)INIT_IC_FLAG );
    309309#endif
    310 #if H_3D_DIM
    311   m_cDepthIntraModeSCModel.initBuffer    ( eSliceType, iQp, (UChar*)INIT_DEPTH_INTRA_MODE );
    312   m_cDdcFlagSCModel.initBuffer           ( eSliceType, iQp, (UChar*)INIT_DDC_FLAG );
    313   m_cDdcDataSCModel.initBuffer           ( eSliceType, iQp, (UChar*)INIT_DDC_DATA );
    314   m_cAngleFlagSCModel.initBuffer         ( eSliceType, iQp, (UChar*)INIT_ANGLE_FLAG );
    315310#if H_3D_DIM_SDC
    316311  m_cSDCResidualFlagSCModel.initBuffer   ( eSliceType, iQp, (UChar*)INIT_SDC_RESIDUAL_FLAG );
    317312  m_cSDCResidualSCModel.initBuffer       ( eSliceType, iQp, (UChar*)INIT_SDC_RESIDUAL );
    318 #endif
    319 #endif
    320 #if H_3D_DIM_SDC
    321313  m_cSDCFlagSCModel.initBuffer              ( eSliceType, iQp, (UChar*)INIT_SDC_FLAG );
     314  m_cDdcFlagSCModel.initBuffer           ( eSliceType, iQp, (UChar*)INIT_DDC_FLAG );
    322315#endif
    323316#if H_3D_DBBP
     
    530523  }
    531524}
    532 #if H_3D_DIM
    533 Void TEncSbac::xWriteExGolombLevel( UInt uiSymbol, ContextModel& rcSCModel  )
    534 {
    535   if( uiSymbol )
    536   {
    537     m_pcBinIf->encodeBin( 1, rcSCModel );
    538     UInt uiCount = 0;
    539     Bool bNoExGo = ( uiSymbol < 3 );
    540 
    541     while( --uiSymbol && ++uiCount < 3 )
    542     {
    543       m_pcBinIf->encodeBin( 1, rcSCModel );
    544     }
    545     if( bNoExGo )
    546     {
    547       m_pcBinIf->encodeBin( 0, rcSCModel );
    548     }
    549     else
    550     {
    551       xWriteEpExGolomb( uiSymbol, 0 );
    552     }
    553   }
    554   else
    555   {
    556     m_pcBinIf->encodeBin( 0, rcSCModel );
    557   }
    558 
    559   return;
    560 }
    561 
    562 Void TEncSbac::xCodeDimDeltaDC( Pel valDeltaDC, UInt uiNumSeg )
    563 {
    564   xWriteExGolombLevel( UInt( abs( valDeltaDC ) - ( uiNumSeg > 1 ? 0 : 1 ) ), m_cDdcDataSCModel.get(0, 0, 0) );
    565   if( valDeltaDC != 0 )
    566   {
    567     UInt uiSign = valDeltaDC > 0 ? 0 : 1;
    568     m_pcBinIf->encodeBinEP( uiSign );
    569   }
    570 }
    571 
    572 #if H_3D_DIM_DMM
    573 Void TEncSbac::xCodeDmm1WedgeIdx( UInt uiTabIdx, Int iNumBit )
    574 {
    575   for ( Int i = 0; i < iNumBit; i++ )
    576   {
    577     m_pcBinIf->encodeBinEP( ( uiTabIdx >> i ) & 1 );
    578   }
    579 }
    580 
    581 #endif
    582 #endif
    583 
    584525// SBAC RD
    585526Void  TEncSbac::load ( const TEncSbac* pSrc)
     
    601542}
    602543
    603 #if H_3D_DIM
    604 Void TEncSbac::loadIntraDepthMode( TEncSbac* pSrc)
     544#if NH_3D_DMM
     545Void TEncSbac::loadIntraDepthDmm( const TEncSbac* pSrc )
    605546{
    606547  m_pcBinIf->copyState( pSrc->m_pcBinIf );
    607 
    608   this->m_cDepthIntraModeSCModel .copyFrom( &pSrc->m_cDepthIntraModeSCModel );
    609   this->m_cDdcFlagSCModel        .copyFrom( &pSrc->m_cDdcFlagSCModel );
    610   this->m_cAngleFlagSCModel      .copyFrom( &pSrc->m_cAngleFlagSCModel );
     548  this->m_cNotDmmFlagSCModel.copyFrom( &pSrc->m_cNotDmmFlagSCModel );
     549  this->m_cDmmModeSCModel   .copyFrom( &pSrc->m_cDmmModeSCModel );
    611550}
    612551#endif
     
    10981037  {
    10991038    dir[j] = pcCU->getIntraDir( CHANNEL_TYPE_LUMA, absPartIdx+partOffset*j );
    1100 #if H_3D_DIM
     1039#if NH_3D_DMM
    11011040    if( pcCU->getSlice()->getIntraSdcWedgeFlag() ||  pcCU->getSlice()->getIntraContourFlag() )
    11021041    {
    1103       codeIntraDepth( pcCU, absPartIdx+partOffset*j );
    1104     }
    1105     if( pcCU->getLumaIntraDir( absPartIdx+partOffset*j ) < NUM_INTRA_MODE )
     1042      xCodeIntraDepthMode( pcCU, absPartIdx+partOffset*j );
     1043      xCodeDmmData       ( pcCU, absPartIdx+partOffset*j );
     1044    }
     1045    if( pcCU->getIntraDir( CHANNEL_TYPE_LUMA, absPartIdx+partOffset*j ) < NUM_INTRA_MODE )
    11061046    {
    11071047#endif
     
    11181058      DTRACE_CU("prev_intra_luma_pred_flag", (predIdx[j] != -1)? 1 : 0);
    11191059#endif
    1120 #if H_3D_DIM
     1060#if NH_3D_DMM
    11211061    }
    11221062#endif
     
    11251065  for (j=0;j<partNum;j++)
    11261066  {
    1127 #if H_3D_DIM
    1128     if( pcCU->getLumaIntraDir( absPartIdx+partOffset*j ) < NUM_INTRA_MODE )
     1067#if NH_3D_DMM
     1068    if( pcCU->getIntraDir( CHANNEL_TYPE_LUMA, absPartIdx+partOffset*j ) < NUM_INTRA_MODE )
    11291069    {
    11301070#endif
     
    11631103#endif
    11641104    }
    1165 #if H_3D_DIM
     1105#if NH_3D_DMM
    11661106    }
    11671107#endif
     
    12061146  return;
    12071147}
    1208 
    1209 #if H_3D_DIM
    1210 Void TEncSbac::codeIntraDepth( TComDataCU* pcCU, UInt absPartIdx )
    1211 {
    1212   codeIntraDepthMode( pcCU, absPartIdx );
    1213 
    1214   UInt dir     = pcCU->getLumaIntraDir( absPartIdx );
    1215   UInt dimType = getDimType( dir );
    1216 
    1217   switch( dimType )
    1218   {
    1219 #if H_3D_DIM_DMM
    1220   case( DMM1_IDX ):
    1221     {
    1222       xCodeDmm1WedgeIdx( pcCU->getDmmWedgeTabIdx( dimType, absPartIdx ), g_dmm1TabIdxBits[pcCU->getIntraSizeIdx(absPartIdx)] );
    1223     } break;
    1224   case( DMM4_IDX ): break;
    1225 #endif
    1226   default: break;
    1227   }
    1228 }
    1229 
    1230 Void TEncSbac::codeIntraDepthMode( TComDataCU* pcCU, UInt absPartIdx )
    1231 {
    1232   UInt dir = pcCU->getLumaIntraDir( absPartIdx );
    1233 
    1234   if( ( pcCU->getSlice()->getSPS()->getMaxCUWidth() >> pcCU->getDepth( absPartIdx ) ) < 64 ) //DMM and HEVC intra modes are both allowed
    1235   {
    1236     m_pcBinIf->encodeBin( isDimMode( dir ) ? 0 : 1, m_cAngleFlagSCModel.get( 0, 0, 0 ) );
    1237   }
    1238   if( isDimMode( dir ) )
    1239   {
    1240     UInt uiCodeIdx = 0;
    1241 
    1242     switch( getDimType( dir ) )
    1243     {
    1244     case DMM1_IDX: uiCodeIdx = 0; break;
    1245     case DMM4_IDX: uiCodeIdx = 1; break;
    1246     default:                      break;
    1247     }
    1248     //mode coding
    1249     if( pcCU->getSlice()->getIntraSdcWedgeFlag() && pcCU->getSlice()->getIntraContourFlag())
    1250     {
    1251       m_pcBinIf->encodeBin( uiCodeIdx == 0 ? 0 : 1, m_cDepthIntraModeSCModel.get( 0, 0, 0 ) );
    1252     }
    1253   }
    1254 }
    1255 #endif
    12561148
    12571149Void TEncSbac::codeInterDir( TComDataCU* pcCU, UInt uiAbsPartIdx )
     
    25952487}
    25962488
     2489#if NH_3D_DMM || H_3D_DIM_SDC || H_3D_INTER_SDC
     2490Void TEncSbac::codeDeltaDC( TComDataCU* pcCU, UInt absPartIdx )
     2491{
     2492#if H_3D_DIM_SDC || H_3D_INTER_SDC
     2493  if( !(pcCU->getSDCFlag( absPartIdx )) )
     2494#endif
     2495#if NH_3D_DMM
     2496    if( !(pcCU->isIntra( absPartIdx ) && isDmmMode( pcCU->getIntraDir( CHANNEL_TYPE_LUMA, absPartIdx ) )) )
     2497#endif
     2498    assert( 0 );
     2499
     2500  UInt uiNumSegments = 1;
     2501#if NH_3D_DMM
     2502  uiNumSegments = isDmmMode( pcCU->getIntraDir( CHANNEL_TYPE_LUMA, absPartIdx ) ) ? 2 : 1;
     2503#endif
     2504
     2505  UInt hasDeltaDC = 1;
     2506#if H_3D_DIM_SDC
     2507  if( pcCU->isIntra( absPartIdx ) && pcCU->getSDCFlag( absPartIdx ))
     2508  {
     2509    if( uiNumSegments == 1 )
     2510    {
     2511      hasDeltaDC = pcCU->getSDCSegmentDCOffset( 0, absPartIdx ) ? 1 : 0;
     2512    }
     2513    else
     2514    {
     2515      hasDeltaDC = ( pcCU->getSDCSegmentDCOffset( 0, absPartIdx ) || pcCU->getSDCSegmentDCOffset( 1, absPartIdx ) ) ? 1 : 0;
     2516    }
     2517    m_pcBinIf->encodeBin( hasDeltaDC, m_cDdcFlagSCModel.get( 0, 0, 0 ) );
     2518  }
     2519#endif
     2520
     2521  if( hasDeltaDC )
     2522  {
     2523    for( UInt segment = 0; segment < uiNumSegments; segment++ )
     2524    {
     2525      Pel deltaDC = 0;
     2526      if( pcCU->isIntra( absPartIdx ) )
     2527      {
     2528#if H_3D_DIM_SDC
     2529        if( pcCU->getSDCFlag( absPartIdx ) )
     2530        {
     2531          deltaDC = pcCU->getSDCSegmentDCOffset( segment, absPartIdx );
     2532        }
     2533        else
     2534        {
     2535#endif
     2536#if NH_3D_DMM
     2537        deltaDC = pcCU->getDmmDeltaDC( getDmmType( pcCU->getIntraDir( CHANNEL_TYPE_LUMA, absPartIdx ) ), segment, absPartIdx );
     2538#endif
     2539#if H_3D_DIM_SDC
     2540        }
     2541#endif
     2542      }
    25972543#if H_3D_INTER_SDC
    2598 Void TEncSbac::codeDeltaDC( TComDataCU* pcCU, UInt absPartIdx )
    2599 {
    2600   if( !( pcCU->getSDCFlag( absPartIdx ) || ( pcCU->isIntra( absPartIdx ) && getDimType( pcCU->getLumaIntraDir( absPartIdx ) ) < DIM_NUM_TYPE ) ) )
    2601   {
    2602     assert( 0 );
    2603   }
    2604 
    2605   UInt uiNumSegments = isDimMode( pcCU->getLumaIntraDir( absPartIdx ) ) ? 2 : 1;
    2606   UInt dimDeltaDC = 1;
    2607 
    2608   if( pcCU->isIntra( absPartIdx ) && pcCU->getSDCFlag( absPartIdx ))
    2609   {
    2610       if( uiNumSegments == 1 )
    2611       {
    2612         dimDeltaDC = pcCU->getSDCSegmentDCOffset( 0, absPartIdx ) ? 1 : 0;
    2613       }
    26142544      else
    26152545      {
    2616         dimDeltaDC = ( pcCU->getSDCSegmentDCOffset( 0, absPartIdx ) || pcCU->getSDCSegmentDCOffset( 1, absPartIdx ) ) ? 1 : 0;
    2617       }
    2618     m_pcBinIf->encodeBin( dimDeltaDC, m_cDdcFlagSCModel.get( 0, 0, 0 ) );
    2619   }
    2620 
    2621   if( dimDeltaDC )
    2622   {
    2623     for( UInt segment = 0; segment < uiNumSegments; segment++ )
    2624     {
    2625       Pel deltaDC = 0;
    2626 
    2627       if( pcCU->isIntra( absPartIdx ) )
    2628       {
    2629         UInt dir     = pcCU->getLumaIntraDir( absPartIdx );
    2630         deltaDC = pcCU->getSDCFlag( absPartIdx ) ? pcCU->getSDCSegmentDCOffset( segment, absPartIdx ) : pcCU->getDimDeltaDC( getDimType( dir ), segment, absPartIdx );
    2631       }
    2632       else
    2633       {
    26342546        deltaDC = pcCU->getSDCSegmentDCOffset( segment, absPartIdx );
    26352547      }
    2636 
    2637       xCodeDimDeltaDC( deltaDC, uiNumSegments );
    2638     }
    2639   }
    2640 }
    2641 
     2548#endif
     2549      xCodeDeltaDC( deltaDC, uiNumSegments );
     2550    }
     2551  }
     2552}
     2553
     2554Void TEncSbac::xCodeDeltaDC( Pel valDeltaDC, UInt uiNumSeg )
     2555{
     2556  xWriteExGolombLevelDdc( UInt( abs( valDeltaDC ) - ( uiNumSeg > 1 ? 0 : 1 ) ) );
     2557  if( valDeltaDC != 0 )
     2558  {
     2559    UInt uiSign = valDeltaDC > 0 ? 0 : 1;
     2560    m_pcBinIf->encodeBinEP( uiSign );
     2561  }
     2562}
     2563
     2564Void TEncSbac::xWriteExGolombLevelDdc( UInt uiSymbol )
     2565{
     2566  if( uiSymbol )
     2567  {
     2568    m_pcBinIf->encodeBin( 1, m_cDdcDataSCModel.get(0, 0, 0) );
     2569    UInt uiCount = 0;
     2570    Bool bNoExGo = ( uiSymbol < 3 );
     2571
     2572    while( --uiSymbol && ++uiCount < 3 )
     2573    {
     2574      m_pcBinIf->encodeBin( 1, m_cDdcDataSCModel.get(0, 0, 0) );
     2575    }
     2576    if( bNoExGo )
     2577    {
     2578      m_pcBinIf->encodeBin( 0, m_cDdcDataSCModel.get(0, 0, 0) );
     2579    }
     2580    else
     2581    {
     2582      xWriteEpExGolomb( uiSymbol, 0 );
     2583    }
     2584  }
     2585  else
     2586  {
     2587    m_pcBinIf->encodeBin( 0, m_cDdcDataSCModel.get(0, 0, 0) );
     2588  }
     2589
     2590  return;
     2591}
     2592#endif
     2593
     2594#if NH_3D_DMM
     2595Void TEncSbac::xCodeIntraDepthMode( TComDataCU* pcCU, UInt absPartIdx )
     2596{
     2597  UInt dir = pcCU->getIntraDir( CHANNEL_TYPE_LUMA, absPartIdx );
     2598
     2599  if( ( pcCU->getSlice()->getSPS()->getMaxCUWidth() >> pcCU->getDepth( absPartIdx ) ) < 64 ) //DMM and HEVC intra modes are both allowed
     2600  {
     2601    m_pcBinIf->encodeBin( isDmmMode( dir ) ? 0 : 1, m_cNotDmmFlagSCModel.get( 0, 0, 0 ) );
     2602  }
     2603  if( isDmmMode( dir ) )
     2604  {
     2605    UInt uiCodeIdx = 0;
     2606
     2607    switch( getDmmType( dir ) )
     2608    {
     2609    case DMM1_IDX: uiCodeIdx = 0; break;
     2610    case DMM4_IDX: uiCodeIdx = 1; break;
     2611    default:                      break;
     2612    }
     2613    //mode coding
     2614    if( pcCU->getSlice()->getIntraSdcWedgeFlag() && pcCU->getSlice()->getIntraContourFlag())
     2615    {
     2616      m_pcBinIf->encodeBin( uiCodeIdx == 0 ? 0 : 1, m_cDmmModeSCModel.get( 0, 0, 0 ) );
     2617    }
     2618  }
     2619}
     2620
     2621Void TEncSbac::xCodeDmmData( TComDataCU* pcCU, UInt absPartIdx )
     2622{
     2623  UInt dir = pcCU->getIntraDir( CHANNEL_TYPE_LUMA, absPartIdx );
     2624  switch( getDmmType( dir ) )
     2625  {
     2626  case( DMM1_IDX ): { xCodeDmm1WedgeIdx( pcCU->getDmm1WedgeTabIdx( absPartIdx ), g_dmm1TabIdxBits[pcCU->getIntraSizeIdx(absPartIdx)] ); } break;
     2627  case( DMM4_IDX ): break;
     2628  default:          break;
     2629  }
     2630}
     2631
     2632Void TEncSbac::xCodeDmm1WedgeIdx( UInt uiTabIdx, Int iNumBit )
     2633{
     2634  for ( Int i = 0; i < iNumBit; i++ )
     2635  {
     2636    m_pcBinIf->encodeBinEP( ( uiTabIdx >> i ) & 1 );
     2637  }
     2638}
     2639#endif
     2640
     2641#if H_3D_INTER_SDC
    26422642Void TEncSbac::codeSDCFlag( TComDataCU* pcCU, UInt uiAbsPartIdx )
    26432643{
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibEncoder/TEncSbac.h

    r1200 r1209  
    8080  Void  load                   ( const TEncSbac* pSrc  );
    8181  Void  loadIntraDirMode       ( const TEncSbac* pScr, const ChannelType chType  );
    82 #if H_3D_DIM
    83   Void  loadIntraDepthMode     ( TEncSbac* pScr );
     82#if NH_3D_DMM
     83  Void  loadIntraDepthDmm      ( const TEncSbac* pSrc );
    8484#endif
    8585  Void  store                  ( TEncSbac* pDest ) const;
     
    115115  Void  xWriteEpExGolomb     ( UInt uiSymbol, UInt uiCount );
    116116  Void  xWriteCoefRemainExGolomb ( UInt symbol, UInt &rParam, const Bool useLimitedPrefixLength, const Int maxLog2TrDynamicRange );
    117 #if H_3D_DIM
    118   Void  xWriteExGolombLevel  ( UInt uiSymbol, ContextModel& rcSCModel  );
    119   Void  xCodeDimDeltaDC      ( Pel valDeltaDC, UInt uiNumSeg );
    120 #if H_3D_DIM_DMM
     117#if NH_3D_DMM || H_3D_DIM_SDC || H_3D_INTER_SDC
     118  Void  xWriteExGolombLevelDdc( UInt uiSymbol );
     119  Void  xCodeDeltaDC         ( Pel valDeltaDC, UInt uiNumSeg );
     120#endif
     121#if NH_3D_DMM
     122  Void  xCodeIntraDepthMode  ( TComDataCU* pcCU, UInt absPartIdx );
     123  Void  xCodeDmmData         ( TComDataCU* pcCU, UInt absPartIdx );
    121124  Void  xCodeDmm1WedgeIdx    ( UInt uiTabIdx, Int iNumBit );
    122125#endif
    123 #endif
     126
    124127
    125128  Void  xCopyFrom            ( const TEncSbac* pSrc );
     
    146149  Void codeICFlag        ( TComDataCU* pcCU, UInt uiAbsPartIdx );
    147150#endif
     151#if NH_3D_DMM || H_3D_DIM_SDC || H_3D_INTER_SDC
     152  Void  codeDeltaDC      ( TComDataCU* pcCU, UInt absPartIdx );
     153#endif
    148154#if H_3D_INTER_SDC
    149   Void codeDeltaDC       ( TComDataCU* pcCU, UInt absPartIdx );
    150155  Void codeSDCFlag       ( TComDataCU* pcCU, UInt uiAbsPartIdx );
    151156#endif
     
    165170  Void codeQtRootCbfZero       ( );
    166171  Void codeIntraDirLumaAng     ( TComDataCU* pcCU, UInt absPartIdx, Bool isMultiple);
    167 
    168172  Void codeIntraDirChroma      ( TComDataCU* pcCU, UInt uiAbsPartIdx );
    169 
    170 #if H_3D_DIM
    171   Void codeIntraDepth          ( TComDataCU* pcCU, UInt absPartIdx );
    172   Void codeIntraDepthMode      ( TComDataCU* pcCU, UInt absPartIdx );
    173 #endif
    174 
    175173  Void codeInterDir            ( TComDataCU* pcCU, UInt uiAbsPartIdx );
    176174  Void codeRefFrmIdx           ( TComDataCU* pcCU, UInt uiAbsPartIdx, RefPicList eRefList );
     
    249247  ContextModel3DBuffer m_ChromaQpAdjFlagSCModel;
    250248  ContextModel3DBuffer m_ChromaQpAdjIdcSCModel;
    251 #if H_3D_DIM
    252   ContextModel3DBuffer m_cDepthIntraModeSCModel;
    253   ContextModel3DBuffer m_cDdcFlagSCModel;
     249
     250#if NH_3D_DMM
     251  ContextModel3DBuffer m_cNotDmmFlagSCModel;
     252  ContextModel3DBuffer m_cDmmModeSCModel;
     253#endif
     254#if NH_3D_DMM || NH_3D_SDC
    254255  ContextModel3DBuffer m_cDdcDataSCModel;
    255   ContextModel3DBuffer m_cAngleFlagSCModel;
     256#endif
    256257#if H_3D_DIM_SDC 
    257258  ContextModel3DBuffer m_cSDCResidualFlagSCModel;
    258259  ContextModel3DBuffer m_cSDCResidualSCModel;
    259 #endif
    260 #endif
    261 #if H_3D_DIM_SDC
    262260  ContextModel3DBuffer m_cSDCFlagSCModel;
     261  ContextModel3DBuffer m_cDdcFlagSCModel;
    263262#endif
    264263#if H_3D_DBBP
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibEncoder/TEncSearch.cpp

    r1200 r1209  
    10531053#if H_3D_DIM_SDC
    10541054          m_pcEntropyCoder->encodeSDCFlag( pcCU, 0, true );
    1055           if( pcCU->getSlice()->getIsDepth() && ( !pcCU->getSDCFlag( 0 ) ) && getDimType( pcCU->getLumaIntraDir( 0 ) ) < DIM_NUM_TYPE )
     1055          if( pcCU->getSlice()->getIsDepth() && ( !pcCU->getSDCFlag( 0 ) ) && isDmmMode( pcCU->getIntraDir( CHANNEL_TYPE_LUMA, 0 ) ) )
    10561056          {
    10571057            m_pcEntropyCoder->encodeDeltaDC( pcCU, 0 );
     
    10711071          for( UInt uiPart = 0; uiPart < 4; uiPart++ )
    10721072          {
    1073             if( pcCU->getSlice()->getIsDepth() && ( !pcCU->getSDCFlag( uiPart * uiQNumParts ) ) && getDimType( pcCU->getLumaIntraDir( uiPart * uiQNumParts ) ) < DIM_NUM_TYPE )
     1073            if( pcCU->getSlice()->getIsDepth() && ( !pcCU->getSDCFlag( uiPart * uiQNumParts ) ) && isDmmMode( pcCU->getIntraDir( CHANNEL_TYPE_LUMA, uiPart * uiQNumParts ) ) )
    10741074            {
    10751075              m_pcEntropyCoder->encodeDeltaDC( pcCU, uiPart * uiQNumParts );
     
    10811081            m_pcEntropyCoder->encodeSDCFlag( pcCU, 0, true );
    10821082          }
    1083           if( pcCU->getSlice()->getIsDepth() && ( !pcCU->getSDCFlag( uiAbsPartIdx ) ) && getDimType( pcCU->getLumaIntraDir( uiAbsPartIdx ) ) < DIM_NUM_TYPE )
     1083          if( pcCU->getSlice()->getIsDepth() && ( !pcCU->getSDCFlag( uiAbsPartIdx ) ) && isDmmMode( pcCU->getIntraDir( CHANNEL_TYPE_LUMA, uiAbsPartIdx ) ) )
    10841084          {
    10851085            m_pcEntropyCoder->encodeDeltaDC( pcCU, uiAbsPartIdx );
     
    11681168                                      DEBUG_STRING_FN_DECLARE(sDebug)
    11691169                                           ,Int         default0Save1Load2
    1170 #if H_3D_DIM_ENC
    1171                                 , Bool       zeroResi
     1170#if NH_3D_ENC_DEPTH
     1171                                          , Bool        zeroResiFlag
    11721172#endif
    11731173
     
    12441244
    12451245    //===== get prediction signal =====
    1246 #if H_3D_DIM
    1247     if( isDimMode( uiLumaPredMode ) )
    1248     {
    1249       predIntraLumaDepth( pcCU, uiAbsPartIdx, uiLumaPredMode, piPred, uiStride, uiWidth, uiHeight, true );
     1246#if NH_3D_DMM
     1247    if( bIsLuma && isDmmMode( uiChFinalMode ) )
     1248    {
     1249      predIntraLumaDmm( pcCU, uiAbsPartIdx, getDmmType( uiChFinalMode ), piPred, uiStride, uiWidth, uiHeight );
    12501250    }
    12511251    else
    12521252    {
    12531253#endif
    1254 
    12551254    predIntraAng( compID, uiChFinalMode, piOrg, uiStride, piPred, uiStride, rTu, bAboveAvail, bLeftAvail, bUseFilteredPredictions );
    1256 #if H_3D_DIM
     1255#if NH_3D_DMM
    12571256    }
    12581257#endif
     
    13011300    for( UInt uiY = 0; uiY < uiHeight; uiY++ )
    13021301    {
    1303 #if H_3D_DIM_ENC
    1304       if( zeroResi )
     1302#if NH_3D_ENC_DEPTH
     1303      if( zeroResiFlag )
    13051304      {
    13061305        memset( pResi, 0, sizeof( Pel ) * uiWidth );
     
    13181317      pResi += uiStride;
    13191318      pPred += uiStride;
    1320 #if H_3D_DIM_ENC
     1319#if NH_3D_ENC_DEPTH
    13211320      }
    13221321#endif
     
    14921491    ruiDist += m_pcRdCost->getDistPart( bitDepth, piReco, uiStride, piOrg, uiStride, uiWidth, uiHeight, compID );
    14931492}
    1494 #if H_3D_DIM
    1495     mapDepthModeToIntraDir( uiChromaPredMode );
    1496 #endif
    1497 
    1498 
    14991493
    15001494
     
    15141508                                    Double&     dRDCost,
    15151509                                    TComTU&     rTu
    1516 #if H_3D_DIM_ENC
    1517                                 , Bool        zeroResi
     1510                                    DEBUG_STRING_FN_DECLARE(sDebug)
     1511#if NH_3D_ENC_DEPTH
     1512                                  , Bool        zeroResiFlag
    15181513#endif                               
    1519                                     DEBUG_STRING_FN_DECLARE(sDebug))
     1514                                  )
    15201515{
    15211516  TComDataCU   *pcCU          = rTu.getCU();
     
    15681563  }
    15691564#endif
    1570 #if H_3D_DIM
    1571   if( isDimMode( pcCU->getLumaIntraDir( uiAbsPartIdx ) ) )
     1565#if NH_3D_DMM
     1566  if( isDmmMode( pcCU->getIntraDir( CHANNEL_TYPE_LUMA, uiAbsPartIdx ) ) )
    15721567  {
    15731568    bCheckSplit = false;
     
    17121707        pcCU ->setTransformSkipSubParts ( 0, COMPONENT_Y, uiAbsPartIdx, totalAdjustedDepthChan );
    17131708      }
    1714 #if H_3D_DIM_ENC
    1715       xIntraCodingLumaBlk( pcCU, uiTrDepth, uiAbsPartIdx, pcOrgYuv, pcPredYuv, pcResiYuv, uiSingleDistY, 0, zeroResi );
     1709#if NH_3D_ENC_DEPTH
     1710      xIntraCodingTUBlock( pcOrgYuv, pcPredYuv, pcResiYuv, resiLumaSingle, false, uiSingleDistLuma, COMPONENT_Y, rTu DEBUG_STRING_PASS_INTO(sDebug), zeroResiFlag );
    17161711#else
    17171712      xIntraCodingTUBlock( pcOrgYuv, pcPredYuv, pcResiYuv, resiLumaSingle, false, uiSingleDistLuma, COMPONENT_Y, rTu DEBUG_STRING_PASS_INTO(sDebug));
     
    19821977Void TEncSearch::xIntraCodingSDC( TComDataCU* pcCU, UInt uiAbsPartIdx, TComYuv* pcOrgYuv, TComYuv* pcPredYuv, Dist& ruiDist, Double& dRDCost, Bool bZeroResidual, Int iSDCDeltaResi  )
    19831978{
     1979#if TEMP_SDC_CLEANUP // PM: consider this cleanup for DMM and SDC
     1980  Bool bAboveAvail    = false;
     1981  Bool bLeftAvail     = false;
     1982  UInt uiWidth        = pcCU->getWidth ( 0 );
     1983  UInt uiHeight       = pcCU->getHeight( 0 );
     1984  UInt uiLumaPredMode = pcCU->getIntraDir( CHANNEL_TYPE_LUMA, uiAbsPartIdx );
     1985
     1986  UInt sdcDepth = 0;
     1987  UInt uiStride;         
     1988  Pel* piOrg;         
     1989  Pel* piPred;         
     1990  Pel* piReco;       
     1991
     1992  UInt uiZOrder;         
     1993  Pel* piRecIPred;       
     1994  UInt uiRecIPredStride;
     1995
     1996  Pel apDCPredValues[2];
     1997  Pel apDCOrigValues[2];
     1998  UInt uiNumSegments;
     1999
     2000  Bool* pbMask = NULL;
     2001  UInt uiMaskStride = 0;
     2002#if NH_3D_DMM
     2003  TComWedgelet* dmm4Segmentation = NULL;
     2004  if( isDmmMode( uiLumaPredMode ) )
     2005  {
     2006    assert( uiWidth == uiHeight  );
     2007    assert( uiWidth >= DMM_MIN_SIZE && uiWidth <= DMM_MAX_SIZE );
     2008    assert( !(( uiWidth >> pcCU->getSlice()->getSPS()->getQuadtreeTULog2MaxSize() ) > 1) );
     2009
     2010    uiNumSegments     = 2;
     2011
     2012    uiStride          = pcOrgYuv ->getStride( COMPONENT_Y );
     2013    piOrg             = pcOrgYuv ->getAddr  ( COMPONENT_Y, uiAbsPartIdx );
     2014    piPred            = pcPredYuv->getAddr  ( COMPONENT_Y, uiAbsPartIdx );
     2015    piReco            = pcPredYuv->getAddr  ( COMPONENT_Y, uiAbsPartIdx );
     2016
     2017    piRecIPred        = pcCU->getPic()->getPicYuvRec()->getAddr  ( COMPONENT_Y, pcCU->getCtuRsAddr(), pcCU->getZorderIdxInCtu() + uiAbsPartIdx );
     2018    uiRecIPredStride  = pcCU->getPic()->getPicYuvRec()->getStride( COMPONENT_Y );
     2019
     2020    //===== init availability pattern =====
     2021#if !TEMP_SDC_CLEANUP // PM: please migrate together with below "initPattern" and remove macro
     2022    pcCU->getPattern()->initPattern   ( pcCU, sdcDepth, uiAbsPartIdx );
     2023    pcCU->getPattern()->initAdiPattern( pcCU, uiAbsPartIdx, sdcDepth, m_piYuvExt, m_iYuvExtStride, m_iYuvExtHeight, bAboveAvail, bLeftAvail );
     2024#endif
     2025
     2026    // get partition
     2027    pbMask       = new Bool[ uiWidth*uiHeight ];
     2028    uiMaskStride = uiWidth;
     2029    switch( getDmmType( uiLumaPredMode ) )
     2030    {
     2031    case( DMM1_IDX ): { (getWedgeListScaled( uiWidth )->at( pcCU->getDmm1WedgeTabIdx( uiAbsPartIdx ) )).getPatternScaledCopy( uiWidth, pbMask ); } break;
     2032    case( DMM4_IDX ): { predContourFromTex( pcCU, uiAbsPartIdx, uiWidth, uiHeight, pbMask );                                                     } break;
     2033    default: assert(0);
     2034    }
     2035
     2036    // get predicted partition values
     2037    Pel predDC1 = 0, predDC2 = 0;
     2038    predBiSegDCs( pcCU, uiAbsPartIdx, uiWidth, uiHeight, pbMask, uiMaskStride, predDC1, predDC2 );
     2039
     2040    // set prediction signal
     2041    Pel* pDst = piPred;
     2042    assignBiSegDCs( pDst, uiStride, pbMask, uiMaskStride, predDC1, predDC2 );
     2043    apDCPredValues[0] = predDC1;
     2044    apDCPredValues[1] = predDC2;
     2045
     2046    // get original partition values
     2047    xCalcBiSegDCs( piOrg, uiStride, pbMask, uiMaskStride, apDCOrigValues[0], apDCOrigValues[1], 0, (uiMaskStride > 16) );
     2048  }
     2049  else // regular HEVC intra modes
     2050  {
     2051#endif
     2052    uiNumSegments = 1;
     2053
     2054    UInt numParts = 1;
     2055    UInt uiSubPartIdx = uiAbsPartIdx;
     2056
     2057    if( ( uiWidth >> pcCU->getSlice()->getSPS()->getQuadtreeTULog2MaxSize() ) > 1 )
     2058    {
     2059      numParts = uiWidth * uiWidth >> ( 2 * pcCU->getSlice()->getSPS()->getQuadtreeTULog2MaxSize() );
     2060      sdcDepth = g_aucConvertToBit[uiWidth] + 2 - pcCU->getSlice()->getSPS()->getQuadtreeTULog2MaxSize();
     2061      uiWidth = uiHeight = ( 1 << pcCU->getSlice()->getSPS()->getQuadtreeTULog2MaxSize() );
     2062    }
     2063
     2064    for ( Int i = 0; i < numParts; i++ )
     2065    {
     2066      uiStride          = pcOrgYuv ->getStride  ();
     2067      piOrg             = pcOrgYuv ->getLumaAddr( uiSubPartIdx );
     2068      piPred            = pcPredYuv->getLumaAddr( uiSubPartIdx );
     2069      piReco            = pcPredYuv->getLumaAddr( uiSubPartIdx );
     2070
     2071      uiZOrder          = pcCU->getZorderIdxInCU() + uiSubPartIdx;
     2072      piRecIPred        = pcCU->getPic()->getPicYuvRec()->getLumaAddr( pcCU->getAddr(), uiZOrder );
     2073      uiRecIPredStride  = pcCU->getPic()->getPicYuvRec()->getStride  ();
     2074
     2075      AOF( uiWidth == uiHeight );
     2076
     2077      //===== init availability pattern =====
     2078      pcCU->getPattern()->initPattern   ( pcCU, sdcDepth, uiSubPartIdx );
     2079      pcCU->getPattern()->initAdiPattern( pcCU, uiSubPartIdx, sdcDepth, m_piYuvExt, m_iYuvExtStride, m_iYuvExtHeight, bAboveAvail, bLeftAvail );
     2080
     2081      predIntraLumaAng( pcCU->getPattern(), uiLumaPredMode, piPred, uiStride, uiWidth, uiHeight, bAboveAvail, bLeftAvail );
     2082
     2083      if ( numParts > 1 )
     2084      {
     2085        for( UInt uiY = 0; uiY < uiHeight; uiY++ )
     2086        {
     2087          for( UInt uiX = 0; uiX < uiWidth; uiX++ )
     2088          {
     2089            piPred        [ uiX ] = ClipY( piPred[ uiX ] );
     2090            piRecIPred    [ uiX ] = piPred[ uiX ];
     2091          }
     2092          piPred     += uiStride;
     2093          piRecIPred += uiRecIPredStride;
     2094        }
     2095      }
     2096
     2097      uiSubPartIdx += ( ( uiWidth * uiWidth ) >> 4 );
     2098    }
     2099
     2100    // reset to full block
     2101    uiWidth  = pcCU->getWidth( 0 );
     2102    uiHeight = pcCU->getHeight( 0 );
     2103
     2104    uiStride          = pcOrgYuv ->getStride  ();
     2105    piOrg             = pcOrgYuv ->getLumaAddr( uiAbsPartIdx );
     2106    piPred            = pcPredYuv->getLumaAddr( uiAbsPartIdx );
     2107    piReco            = pcPredYuv->getLumaAddr( uiAbsPartIdx );
     2108
     2109    uiZOrder          = pcCU->getZorderIdxInCU() + uiAbsPartIdx;
     2110    piRecIPred        = pcCU->getPic()->getPicYuvRec()->getLumaAddr( pcCU->getAddr(), uiZOrder );
     2111    uiRecIPredStride  = pcCU->getPic()->getPicYuvRec()->getStride  ();
     2112
     2113    // get predicted and original DC
     2114    predConstantSDC( piPred, uiStride, uiWidth, apDCPredValues[0] ); apDCPredValues[1] = 0;
     2115    xCalcConstantSDC( piOrg, uiStride, uiWidth, apDCOrigValues[0] ); apDCOrigValues[1] = 0;
     2116#if NH_3D_DMM 
     2117  }
     2118#endif
     2119#else
    19842120  UInt    uiLumaPredMode    = pcCU     ->getLumaIntraDir( uiAbsPartIdx );
    19852121  UInt    uiWidth           = pcCU     ->getWidth   ( 0 );
     
    20242160    TComWedgelet* dmm4Segmentation = new TComWedgelet( uiWidth, uiHeight );
    20252161    //===== get prediction signal =====
    2026     if( isDimMode( uiLumaPredMode ) )
    2027     {
    2028       UInt dimType   = getDimType  ( uiLumaPredMode );
     2162    if( isDmmMode( uiLumaPredMode ) )
     2163    {
     2164      UInt dimType   = getDmmType  ( uiLumaPredMode );
    20292165      UInt patternID = pcCU->getDmmWedgeTabIdx(dimType, uiAbsPartIdx);
    20302166      UInt uiBaseWidth = pcCU->isDMM1UpscaleMode(uiWidth) ? pcCU->getDMM1BasePatternWidth(uiWidth) : uiWidth;
     
    20892225  UInt uiMaskStride = 0;
    20902226
    2091   if( getDimType( uiLumaPredMode ) == DMM1_IDX )
     2227  if( getDmmType( uiLumaPredMode ) == DMM1_IDX )
    20922228  {
    20932229    Int uiTabIdx = pcCU->getDmmWedgeTabIdx(DMM1_IDX, uiAbsPartIdx);
     
    21002236    uiMaskStride = pcCU->isDMM1UpscaleMode( uiWidth ) ? uiWidth : pcWedgelet->getStride();
    21012237  }
    2102   if( getDimType( uiLumaPredMode ) == DMM4_IDX )
     2238  if( getDmmType( uiLumaPredMode ) == DMM4_IDX )
    21032239  {
    21042240    uiNumSegments = 2;
     
    21092245  // get DC prediction for each segment
    21102246  Pel apDCPredValues[2];
    2111   if ( getDimType( uiLumaPredMode ) == DMM1_IDX || getDimType( uiLumaPredMode ) == DMM4_IDX )
     2247  if ( getDmmType( uiLumaPredMode ) == DMM1_IDX || getDmmType( uiLumaPredMode ) == DMM4_IDX )
    21122248  {
    21132249    apDCPredValues[0] = pcCU->getDmmPredictor( 0 );
     
    21232259  Pel apDCOrigValues[2];
    21242260  analyzeSegmentsSDC(piOrg, uiStride, uiWidth, apDCOrigValues, uiNumSegments, pbMask, uiMaskStride, uiLumaPredMode, true );
     2261#endif
    21252262
    21262263  for( UInt uiSegment = 0; uiSegment < uiNumSegments; uiSegment++ )
     
    22032340  }
    22042341
     2342#if TEMP_SDC_CLEANUP // PM: consider this cleanup for DMM and SDC
     2343#if NH_3D_DMM
     2344  if( pbMask ) { delete[] pbMask; }
     2345#endif
     2346#endif
     2347
    22052348  //===== determine distortion =====
    22062349#if H_3D_VSO
     
    22292372  // encode pred direction + DC residual data
    22302373  m_pcEntropyCoder->encodePredInfo( pcCU, 0, true );
    2231 #if H_3D_DIM_SDC
    22322374  m_pcEntropyCoder->encodeSDCFlag( pcCU, 0, true );
    2233 #endif
    22342375
    22352376  Bool bDummy = false;
     
    22432384#endif
    22442385    dRDCost = m_pcRdCost->calcRdCost( uiBits, ruiDist );
     2386#if !TEMP_SDC_CLEANUP // PM: should be obsolete after cleanup
    22452387  dmm4SegmentationOrg->destroy(); delete dmm4SegmentationOrg;
     2388#endif
    22462389}
    22472390#endif
     
    27892932                               TComYuv*    pcRecoYuv,
    27902933                               Pel         resiLuma[NUMBER_OF_STORED_RESIDUAL_TYPES][MAX_CU_SIZE * MAX_CU_SIZE]
    2791 #if H_3D_DIM
     2934                               DEBUG_STRING_FN_DECLARE(sDebug)
     2935#if NH_3D_ENC_DEPTH
    27922936                             , Bool        bOnlyIVP
    27932937#endif
    2794 
    2795                                DEBUG_STRING_FN_DECLARE(sDebug))
     2938                              )
    27962939{
    27972940  const UInt         uiDepth               = pcCU->getDepth(0);
     
    28653008      initIntraPatternChType( tuRecurseWithPU, bAboveAvail, bLeftAvail, COMPONENT_Y, true DEBUG_STRING_PASS_INTO(sTemp2) );
    28663009    }
    2867 #if H_3D_DIM
     3010#if NH_3D_ENC_DEPTH
    28683011    if( bOnlyIVP )
    28693012    {
     
    29873130      }
    29883131    }
    2989 #if H_3D_DIM
    2990     }
    2991 #endif
    2992 
    2993 #if H_3D_DIM
    2994     //===== determine set of depth intra modes to be tested =====
    2995     if( m_pcEncCfg->getIsDepth() && uiWidth >= DIM_MIN_SIZE && uiWidth <= DIM_MAX_SIZE && uiWidth == uiHeight )
    2996     {
    2997       if( bOnlyIVP )
    2998       {
    2999         TComWedgelet* dmm4Segmentation = new TComWedgelet( uiWidth, uiHeight );
    3000         xPredContourFromTex( pcCU, uiPartOffset, uiWidth, uiHeight, dmm4Segmentation );
    3001 
    3002         Pel deltaDC1 = 0; Pel deltaDC2 = 0;
    3003         xSearchDmmDeltaDCs( pcCU, uiPartOffset, piOrg, piPred, uiStride, dmm4Segmentation->getPattern(), dmm4Segmentation->getStride(), uiWidth, uiHeight, deltaDC1, deltaDC2 );
    3004         pcCU->setDimDeltaDC( DMM4_IDX, 0, uiPartOffset, deltaDC1 );
    3005         pcCU->setDimDeltaDC( DMM4_IDX, 1, uiPartOffset, deltaDC2 );
    3006 
    3007         uiRdModeList[ numModesForFullRD++ ] = (DMM4_IDX+DIM_OFFSET);
    3008         dmm4Segmentation->destroy(); delete dmm4Segmentation;
    3009       }
    3010       else
    3011       {
    3012 #if H_3D_FAST_DEPTH_INTRA
    3013         Int  threshold    = max(((pcCU->getQP(0))>>3)-1,3);
    3014         Int  varThreshold = (Int)( threshold * threshold - 8 );
    3015         UInt varCU      = m_pcRdCost->calcVAR(piOrg, uiStride, uiWidth,uiHeight,pcCU->getDepth(0));
    3016 #endif
    3017 
    3018 #if H_3D_DIM_DMM
    3019         if( ( ( m_pcEncCfg->getUseDMM() &&  pcCU->getSlice()->getIntraSdcWedgeFlag() )  || pcCU->getSlice()->getIntraContourFlag() )
    3020 #if H_3D_FAST_DEPTH_INTRA
    3021           && (uiRdModeList[0] != PLANAR_IDX || varCU >= varThreshold)
    3022 #endif
    3023           )
    3024         {
    3025           UInt uiStart, uiEnd;
    3026           if( ( m_pcEncCfg->getUseDMM() &&  pcCU->getSlice()->getIntraSdcWedgeFlag() ) &&  pcCU->getSlice()->getIntraContourFlag() )
     3132#if NH_3D_ENC_DEPTH
     3133    }
     3134#endif
     3135
     3136#if NH_3D_DMM
     3137    if( m_pcEncCfg->getIsDepth() )
     3138    {
     3139      const TComRectangle &puRect=tuRecurseWithPU.getRect(COMPONENT_Y);
     3140      const UInt uiAbsPartIdx=tuRecurseWithPU.GetAbsPartIdxTU();
     3141
     3142      Pel* piOrg         = pcOrgYuv ->getAddr( COMPONENT_Y, uiAbsPartIdx );
     3143      Pel* piPred        = pcPredYuv->getAddr( COMPONENT_Y, uiAbsPartIdx );
     3144      UInt uiStride      = pcPredYuv->getStride( COMPONENT_Y );
     3145
     3146      if( puRect.width >= DMM_MIN_SIZE && puRect.width <= DMM_MAX_SIZE &&  puRect.width == puRect.height &&
     3147          ((m_pcEncCfg->getUseDMM() &&  pcCU->getSlice()->getIntraSdcWedgeFlag()) || pcCU->getSlice()->getIntraContourFlag()) )
     3148      {
     3149#if NH_3D_ENC_DEPTH
     3150        if( bOnlyIVP )
     3151        {
     3152          Bool* dmm4Pattern   = new Bool[ puRect.width*puRect.height ];
     3153          UInt  patternStride = puRect.width;
     3154          predContourFromTex( pcCU, uiPartOffset, puRect.width, puRect.height, dmm4Pattern );
     3155
     3156          Pel deltaDC1 = 0; Pel deltaDC2 = 0;
     3157          xSearchDmmDeltaDCs( pcCU, uiPartOffset, piOrg, piPred, uiStride, dmm4Pattern, patternStride, puRect.width, puRect.height, deltaDC1, deltaDC2 );
     3158          pcCU->setDmmDeltaDC( DMM4_IDX, 0, uiPartOffset, deltaDC1 );
     3159          pcCU->setDmmDeltaDC( DMM4_IDX, 1, uiPartOffset, deltaDC2 );
     3160
     3161          uiRdModeList[ numModesForFullRD++ ] = (DMM4_IDX+DMM_OFFSET);
     3162          delete[] dmm4Pattern;
     3163        }
     3164        else
     3165        {
     3166          Int  threshold    = max(((pcCU->getQP(0))>>3)-1,3);
     3167          Int  varThreshold = (Int)( threshold * threshold - 8 );
     3168          UInt varCU        = m_pcRdCost->calcVAR( piOrg, uiStride, puRect.width, puRect.height, pcCU->getDepth(0), pcCU->getSlice()->getSPS()->getMaxCUWidth() );
     3169          if( uiRdModeList[0] != PLANAR_IDX || varCU >= varThreshold )
    30273170          {
    3028             uiStart = 0;
    3029             uiEnd   = 2;
     3171#endif
     3172            UInt startIdx = ( m_pcEncCfg->getUseDMM() &&  pcCU->getSlice()->getIntraSdcWedgeFlag() ) ? 0 : 1;
     3173            UInt endIdx   = (                             pcCU->getSlice()->getIntraContourFlag()  ) ? 1 : 0;
     3174            for( UInt dmmType = startIdx; dmmType <= endIdx; dmmType++ )
     3175            {
     3176#if H_3D_FCO
     3177              if ( !(pcCU->getSlice()->getIvPic(false, pcCU->getSlice()->getViewIndex() )->getReconMark()) && (DMM4_IDX == dmmType ) ) { continue; }
     3178#endif
     3179              Bool* biSegPattern  = new Bool[ puRect.width*puRect.height ];
     3180              UInt  patternStride = puRect.width;
     3181              Pel deltaDC1 = 0; Pel deltaDC2 = 0;
     3182              switch( dmmType )
     3183              {
     3184              case( DMM1_IDX ):
     3185                {
     3186                  UInt uiTabIdx = 0;
     3187                  xSearchDmm1Wedge( pcCU, uiPartOffset, piOrg, uiStride, puRect.width, puRect.height, uiTabIdx );
     3188                  pcCU->setDmm1WedgeTabIdxSubParts( uiTabIdx,  uiPartOffset, uiDepth + uiInitTrDepth );
     3189                  (getWedgeListScaled( puRect.width )->at( pcCU->getDmm1WedgeTabIdx( uiAbsPartIdx ) )).getPatternScaledCopy( puRect.width, biSegPattern );
     3190                } break;
     3191              case( DMM4_IDX ):
     3192                {
     3193                  predContourFromTex( pcCU, uiPartOffset, puRect.width, puRect.height, biSegPattern );
     3194                } break;
     3195              default: assert(0);
     3196              }
     3197
     3198              if( biSegPattern )
     3199              {
     3200                xSearchDmmDeltaDCs( pcCU, uiPartOffset, piOrg, piPred, uiStride, biSegPattern, patternStride, puRect.width, puRect.height, deltaDC1, deltaDC2 );
     3201                pcCU->setDmmDeltaDC( (DmmID)dmmType, 0, uiPartOffset, deltaDC1 );
     3202                pcCU->setDmmDeltaDC( (DmmID)dmmType, 1, uiPartOffset, deltaDC2 );
     3203 
     3204                uiRdModeList[ numModesForFullRD++ ] = (dmmType+DMM_OFFSET);
     3205                delete[] biSegPattern;
     3206              }
     3207            }
     3208#if NH_3D_ENC_DEPTH
    30303209          }
    3031           else if( ( m_pcEncCfg->getUseDMM() &&  pcCU->getSlice()->getIntraSdcWedgeFlag() ) )
    3032           {
    3033             uiStart = 0;
    3034             uiEnd   = 1;
    3035           }
    3036           else if( pcCU->getSlice()->getIntraContourFlag() )
    3037           {
    3038             uiStart = 1;
    3039             uiEnd   = 2;
    3040           }
    3041           else
    3042           {
    3043             uiStart = 0;
    3044             uiEnd   = 0;
    3045           }
    3046           for( UInt dmmType = uiStart; dmmType < uiEnd; dmmType++ )
    3047           {
    3048 #if H_3D_FCO
    3049             TComPic* picTexture  = pcCU->getSlice()->getIvPic(false, pcCU->getSlice()->getViewIndex() );
    3050 #if H_3D_FCO
    3051             if ( !picTexture->getReconMark() && (DMM4_IDX == dmmType ) )
    3052 #else
    3053             if ( !picTexture->getReconMark() && (DMM3_IDX == dmmType || DMM4_IDX == dmmType ) )
    3054 #endif
    3055             {
    3056               continue;
    3057             }
    3058 #endif
    3059             UInt uiTabIdx = 0;
    3060             TComWedgelet* biSegmentation = NULL;
    3061             Pel deltaDC1 = 0; Pel deltaDC2 = 0;
    3062             switch( dmmType )
    3063             {
    3064             case( DMM1_IDX ):
    3065               {
    3066                 xSearchDmm1Wedge( pcCU, uiPartOffset, piOrg, uiStride, uiWidth, uiHeight, uiTabIdx );
    3067                 pcCU->setDmmWedgeTabIdxSubParts( uiTabIdx, dmmType,  uiPartOffset, uiDepth + uiInitTrDepth );
    3068                 biSegmentation = pcCU->isDMM1UpscaleMode( uiWidth ) ?
    3069                   &(g_dmmWedgeLists[(g_aucConvertToBit[pcCU->getDMM1BasePatternWidth(uiWidth)])][uiTabIdx]) : &(g_dmmWedgeLists[(g_aucConvertToBit[uiWidth])][uiTabIdx]);
    3070               } break;
    3071 
    3072             case( DMM4_IDX ):
    3073               {
    3074                 {
    3075                   biSegmentation = new TComWedgelet( uiWidth, uiHeight );
    3076                   xPredContourFromTex( pcCU, uiPartOffset, uiWidth, uiHeight, biSegmentation );
    3077                 }
    3078               } break;
    3079             default: assert(0);
    3080             }
    3081 
    3082             if( biSegmentation )
    3083             {
    3084               if( dmmType == DMM1_IDX && pcCU->isDMM1UpscaleMode( uiWidth ) ){
    3085                 xSearchDmmDeltaDCs( pcCU, uiPartOffset, piOrg, piPred, uiStride, biSegmentation->getScaledPattern(uiWidth), uiWidth, uiWidth, uiHeight, deltaDC1, deltaDC2 );
    3086               }
    3087               else
    3088               {
    3089                 xSearchDmmDeltaDCs( pcCU, uiPartOffset, piOrg, piPred, uiStride, biSegmentation->getPattern(), biSegmentation->getStride(), uiWidth, uiHeight, deltaDC1, deltaDC2 );
    3090               }
    3091               pcCU->setDimDeltaDC( dmmType, 0, uiPartOffset, deltaDC1 );
    3092               pcCU->setDimDeltaDC( dmmType, 1, uiPartOffset, deltaDC2 );
    3093 
    3094               uiRdModeList[ numModesForFullRD++ ] = (dmmType  +DIM_OFFSET);
    3095               if( DMM4_IDX == dmmType ) { biSegmentation->destroy(); delete biSegmentation; }
    3096             }
    3097           }
    3098         }
    3099 #if H_3D_DIM
    3100       }
    3101 #endif
    3102 #endif
    3103     }
    3104 #endif
    3105 
     3210        }
     3211#endif
     3212      }
     3213    }
     3214#endif
    31063215
    31073216    //===== check modes (using r-d costs) =====
     
    32263335          }
    32273336#endif
    3228 #if H_3D_DIM_ENC || H_3D_DIM_SDC
    3229           Bool bTestZeroResi = false;
    3230 #if H_3D_DIM_ENC
    3231           bTestZeroResi |= pcCU->getSlice()->getIsDepth() && !pcCU->getSlice()->isIRAP();
    3232 #endif
     3337#if NH_3D_ENC_DEPTH
     3338          UInt zeroResiTest = (pcCU->getSlice()->getIsDepth() && !pcCU->getSlice()->isIRAP()) ? 1 : 0;
    32333339#if H_3D_DIM_SDC
    32343340          bTestZeroResi |= pcCU->getSDCFlag(uiPartOffset);
    3235 #endif
    32363341          if( uiSDC != 0 && iSDCDeltaResi != 0 )
    32373342          {
     
    32393344          }
    32403345#endif
    3241 
    3242 #if H_3D_DIM_ENC || H_3D_DIM_SDC     
    3243           for( UInt testZeroResi = 0; testZeroResi <= (bTestZeroResi ? 1 : 0) ; testZeroResi++ )
     3346          for( UInt zeroResi = 0; zeroResi <= zeroResiTest; zeroResi++ )
    32443347          {
    32453348#endif
    3246 
    32473349      DEBUG_STRING_NEW(sMode)
    32483350      // set context models
     
    32803382
    32813383#if HHI_RQT_INTRA_SPEEDUP
    3282 #if H_3D_DIM_ENC
    3283               xRecurIntraCodingQT( pcCU, uiInitTrDepth, uiPartOffset, bLumaOnly, pcOrgYuv, pcPredYuv, pcResiYuv, uiPUDistY, uiPUDistC, true, dPUCost, (testZeroResi != 0) );
     3384#if NH_3D_ENC_DEPTH
     3385      xRecurIntraCodingLumaQT( pcOrgYuv, pcPredYuv, pcResiYuv, resiLumaPU, uiPUDistY, true, dPUCost, tuRecurseWithPU DEBUG_STRING_PASS_INTO(sMode), (zeroResi != 0) );
    32843386#if H_3D_FAST_INTRA_SDC   
    32853387              if( dPUCost < dBestPUCostConv )
     
    32953397#endif
    32963398#else
    3297 #if H_3D_DIM_ENC
    3298               xRecurIntraCodingQT( pcCU, uiInitTrDepth, uiPartOffset, bLumaOnly, pcOrgYuv, pcPredYuv, pcResiYuv, uiPUDistY, uiPUDistC, dPUCost, (testZeroResi != 0) );
     3399#if NH_3D_ENC_DEPTH
     3400      xRecurIntraCodingLumaQT( pcOrgYuv, pcPredYuv, pcResiYuv, resiLumaPU, uiPUDistY, dPUCost, tuRecurseWithPU DEBUG_STRING_PASS_INTO(sMode), (zeroResi != 0) );
    32993401#else
    33003402      xRecurIntraCodingLumaQT( pcOrgYuv, pcPredYuv, pcResiYuv, resiLumaPU, uiPUDistY, dPUCost, tuRecurseWithPU DEBUG_STRING_PASS_INTO(sMode) );
     
    33743476      }
    33753477#endif
    3376 #if H_3D_DIM_ENC || H_3D_DIM_SDC
     3478#if NH_3D_ENC_DEPTH
    33773479          }
     3480#endif
     3481#if H_3D_DIM_SDC
    33783482        } // SDC residual loop
    3379 #endif
    3380 #if H_3D_DIM_SDC
    33813483      } // SDC loop
    33823484#endif
     
    70177119  // Reload only contexts required for coding intra mode information
    70187120  m_pcRDGoOnSbacCoder->loadIntraDirMode( m_pppcRDSbacCoder[uiDepth][CI_CURR_BEST], chType );
    7019 #if H_3D_DIM
    7020     m_pcRDGoOnSbacCoder->loadIntraDepthMode( m_pppcRDSbacCoder[uiDepth][CI_CURR_BEST] );
     7121#if NH_3D_DMM
     7122  if( pcCU->getSlice()->getIsDepth() && isLuma(chType) )
     7123  {
     7124    m_pcRDGoOnSbacCoder->loadIntraDepthDmm( m_pppcRDSbacCoder[uiDepth][CI_CURR_BEST] );
     7125  }
    70217126#endif
    70227127
     
    74017506}
    74027507
    7403 #if H_3D_DIM
     7508#if NH_3D_DMM
    74047509  // -------------------------------------------------------------------------------------------------------------------
    74057510  // Depth intra search
    74067511  // -------------------------------------------------------------------------------------------------------------------
    7407 Void TEncSearch::xCalcBiSegDCs( Pel* ptrSrc, UInt srcStride, Bool* biSegPattern, Int patternStride, Pel& valDC1, Pel& valDC2 )
     7512Void TEncSearch::xCalcBiSegDCs( Pel* ptrSrc, UInt srcStride, Bool* biSegPattern, Int patternStride, Pel& valDC1, Pel& valDC2, Pel defaultVal, Bool subSamp )
    74087513{
    7409   valDC1 = ( 1<<( g_bitDepthY - 1) );
    7410   valDC2 = ( 1<<( g_bitDepthY - 1) );
     7514  valDC1 = defaultVal;
     7515  valDC2 = defaultVal;
    74117516
    74127517  UInt uiDC1 = 0;
    74137518  UInt uiDC2 = 0;
    74147519  UInt uiNumPixDC1 = 0, uiNumPixDC2 = 0;
    7415   if( srcStride == patternStride )
    7416   {
    7417     for( UInt k = 0; k < (patternStride * patternStride); k++ )
    7418     {
    7419       if( true == biSegPattern[k] )
    7420       {
    7421         uiDC2 += ptrSrc[k];
     7520 
     7521  Int subSamplePix = subSamp ? 2 : 1;
     7522
     7523  Pel* piTemp = ptrSrc;
     7524  for( UInt uiY = 0; uiY < patternStride; uiY += subSamplePix )
     7525  {
     7526    for( UInt uiX = 0; uiX < patternStride; uiX += subSamplePix )
     7527    {
     7528      if( true == biSegPattern[uiX] )
     7529      {
     7530        uiDC2 += piTemp[uiX];
    74227531        uiNumPixDC2++;
    74237532      }
    74247533      else
    74257534      {
    7426         uiDC1 += ptrSrc[k];
     7535        uiDC1 += piTemp[uiX];
    74277536        uiNumPixDC1++;
    74287537      }
    74297538    }
    7430   }
    7431   else
    7432   {
    7433     Pel* piTemp = ptrSrc;
    7434     for( UInt uiY = 0; uiY < patternStride; uiY++ )
    7435     {
    7436       for( UInt uiX = 0; uiX < patternStride; uiX++ )
    7437       {
    7438         if( true == biSegPattern[uiX] )
    7439         {
    7440           uiDC2 += piTemp[uiX];
    7441           uiNumPixDC2++;
    7442         }
    7443         else
    7444         {
    7445           uiDC1 += piTemp[uiX];
    7446           uiNumPixDC1++;
    7447         }
    7448       }
    7449       piTemp       += srcStride;
    7450       biSegPattern += patternStride;
    7451     }
     7539    piTemp       += subSamplePix*srcStride;
     7540    biSegPattern += subSamplePix*patternStride;
    74527541  }
    74537542
     
    74567545}
    74577546
    7458 #if H_3D_DIM_DMM
    74597547Void TEncSearch::xSearchDmmDeltaDCs( TComDataCU* pcCU, UInt uiAbsPtIdx, Pel* piOrig, Pel* piPredic, UInt uiStride, Bool* biSegPattern, Int patternStride, UInt uiWidth, UInt uiHeight, Pel& rDeltaDC1, Pel& rDeltaDC2 )
    74607548{
    74617549  assert( biSegPattern );
     7550  Int bitDepthY = pcCU->getSlice()->getSPS()->getBitDepth(CHANNEL_TYPE_LUMA);
     7551
    74627552  Pel origDC1 = 0; Pel origDC2 = 0;
    7463   xCalcBiSegDCs  ( piOrig,   uiStride, biSegPattern, patternStride, origDC1, origDC2 );
    7464   xAssignBiSegDCs( piPredic, uiStride, biSegPattern, patternStride, origDC1, origDC2 );
    7465 
    7466   Int* piMask = pcCU->getPattern()->getAdiOrgBuf( uiWidth, uiHeight, m_piYuvExt ); // no filtering for DMM
    7467   Int  maskStride = 2*uiWidth + 1;
    7468   Int* ptrSrc = piMask+maskStride+1;
     7553  xCalcBiSegDCs  ( piOrig,   uiStride, biSegPattern, patternStride, origDC1, origDC2, (1<<(bitDepthY-1)) );
     7554  assignBiSegDCs( piPredic, uiStride, biSegPattern, patternStride, origDC1, origDC2 );
     7555
    74697556  Pel  predDC1 = 0; Pel predDC2 = 0;
    7470   xPredBiSegDCs( ptrSrc, maskStride, biSegPattern, patternStride, predDC1, predDC2 );
     7557  predBiSegDCs( pcCU, uiAbsPtIdx, uiWidth, uiHeight, biSegPattern, patternStride, predDC1, predDC2 );
    74717558
    74727559  rDeltaDC1 = origDC1 - predDC1;
    74737560  rDeltaDC2 = origDC2 - predDC2;
    74747561
    7475 #if H_3D_VSO
     7562#if NH_3D_VSO
    74767563  if( m_pcRdCost->getUseVSO() )
    74777564  {
     
    74927579    // limit search range to [0, IBDI_MAX]
    74937580    if( fullDeltaDC1 <  0 && uiDeltaDC1Max >                          abs(predDC1) ) { uiDeltaDC1Max =                          abs(predDC1); }
    7494     if( fullDeltaDC1 >= 0 && uiDeltaDC1Max > ((1 << g_bitDepthY)-1) - abs(predDC1) ) { uiDeltaDC1Max = ((1 << g_bitDepthY)-1) - abs(predDC1); }
     7581    if( fullDeltaDC1 >= 0 && uiDeltaDC1Max > ((1<<bitDepthY)-1) - abs(predDC1) ) { uiDeltaDC1Max = ((1<<bitDepthY)-1) - abs(predDC1); }
    74957582
    74967583    if( fullDeltaDC2 <  0 && uiDeltaDC2Max >                          abs(predDC2) ) { uiDeltaDC2Max =                          abs(predDC2); }
    7497     if( fullDeltaDC2 >= 0 && uiDeltaDC2Max > ((1 << g_bitDepthY)-1) - abs(predDC2) ) { uiDeltaDC2Max = ((1 << g_bitDepthY)-1) - abs(predDC2); }
     7584    if( fullDeltaDC2 >= 0 && uiDeltaDC2Max > ((1<<bitDepthY)-1) - abs(predDC2) ) { uiDeltaDC2Max = ((1<<bitDepthY)-1) - abs(predDC2); }
    74987585
    74997586    // init dist with original segment DCs
    7500     xAssignBiSegDCs( piPredic, uiStride, biSegPattern, patternStride, origDC1, origDC2 );
     7587    assignBiSegDCs( piPredic, uiStride, biSegPattern, patternStride, origDC1, origDC2 );
    75017588
    75027589    Dist uiOrgDist = RDO_DIST_MAX;
    75037590    if( m_pcRdCost->getUseEstimatedVSD() )
    75047591    {
    7505       uiOrgDist = m_pcRdCost->getDistPartVSD( pcCU, uiAbsPtIdx, piPredic, uiStride, piOrig, uiStride, uiWidth, uiHeight, false );
     7592      uiOrgDist = m_pcRdCost->getDistPartVSD( pcCU, uiAbsPtIdx, bitDepthY, piPredic, uiStride, piOrig, uiStride, uiWidth, uiHeight, false );
    75067593    }
    75077594    else
    75087595    {
    7509       uiOrgDist = m_pcRdCost->getDistPartVSO( pcCU, uiAbsPtIdx, piPredic, uiStride, piOrig, uiStride, uiWidth, uiHeight, false );
     7596      uiOrgDist = m_pcRdCost->getDistPartVSO( pcCU, uiAbsPtIdx, bitDepthY, piPredic, uiStride, piOrig, uiStride, uiWidth, uiHeight, false );
    75107597    }
    75117598
     
    75177604    for( UInt uiQStepDC1 = 0; uiQStepDC1 < uiDeltaDC1Max; uiQStepDC1 += 4 )
    75187605    {
    7519       Pel testDC1 = ClipY( predDC1 + ((Int)(uiQStepDC1) * (( fullDeltaDC1 < 0 ) ? -1 : 1)) );
     7606      Pel testDC1 = ClipBD( predDC1 + ((Int)(uiQStepDC1) * (( fullDeltaDC1 < 0 ) ? -1 : 1)), bitDepthY );
    75207607      for( UInt uiQStepDC2 = 0; uiQStepDC2 < uiDeltaDC2Max; uiQStepDC2 += 4 )
    75217608      {
    7522         Pel testDC2 = ClipY( predDC2 + ((Int)(uiQStepDC2) * (( fullDeltaDC2 < 0 ) ? -1 : 1)) );
    7523 
    7524         xAssignBiSegDCs( piPredic, uiStride, biSegPattern, patternStride, testDC1, testDC2 );
     7609        Pel testDC2 = ClipBD( predDC2 + ((Int)(uiQStepDC2) * (( fullDeltaDC2 < 0 ) ? -1 : 1)), bitDepthY );
     7610        assignBiSegDCs( piPredic, uiStride, biSegPattern, patternStride, testDC1, testDC2 );
    75257611
    75267612        Dist uiAct4Dist = RDO_DIST_MAX;
    75277613        if( m_pcRdCost->getUseEstimatedVSD() )
    75287614        {
    7529           uiAct4Dist = m_pcRdCost->getDistPartVSD( pcCU, uiAbsPtIdx, piPredic, uiStride, piOrig, uiStride, uiWidth, uiHeight, false );
     7615          uiAct4Dist = m_pcRdCost->getDistPartVSD( pcCU, uiAbsPtIdx, bitDepthY, piPredic, uiStride, piOrig, uiStride, uiWidth, uiHeight, false );
    75307616        }
    75317617        else
    75327618        {
    7533           uiAct4Dist = m_pcRdCost->getDistPartVSO( pcCU, uiAbsPtIdx, piPredic, uiStride, piOrig, uiStride, uiWidth, uiHeight, false );
     7619          uiAct4Dist = m_pcRdCost->getDistPartVSO( pcCU, uiAbsPtIdx, bitDepthY, piPredic, uiStride, piOrig, uiStride, uiWidth, uiHeight, false );
    75347620        }
    75357621
     
    75467632    for( UInt uiQStepDC1 = (UInt)max(0, ((Int)uiBestQStepDC1-3)); uiQStepDC1 <= (uiBestQStepDC1+3); uiQStepDC1++ )
    75477633    {
    7548       Pel testDC1 = ClipY( predDC1 + ((Int)(uiQStepDC1) * (( fullDeltaDC1 < 0 ) ? -1 : 1)) );
     7634      Pel testDC1 = ClipBD( predDC1 + ((Int)(uiQStepDC1) * (( fullDeltaDC1 < 0 ) ? -1 : 1)), bitDepthY );
    75497635      for( UInt uiQStepDC2 = (UInt)max(0, ((Int)uiBestQStepDC2-3)); uiQStepDC2 <= (uiBestQStepDC2+3); uiQStepDC2++ )
    75507636      {
    7551         Pel testDC2 = ClipY( predDC2 + ((Int)(uiQStepDC2) * (( fullDeltaDC2 < 0 ) ? -1 : 1)) );
    7552 
    7553         xAssignBiSegDCs( piPredic, uiStride, biSegPattern, patternStride, testDC1, testDC2 );
     7637        Pel testDC2 = ClipBD( predDC2 + ((Int)(uiQStepDC2) * (( fullDeltaDC2 < 0 ) ? -1 : 1)), bitDepthY );
     7638        assignBiSegDCs( piPredic, uiStride, biSegPattern, patternStride, testDC1, testDC2 );
    75547639
    75557640        Dist uiActDist = RDO_DIST_MAX;
    75567641        if( m_pcRdCost->getUseEstimatedVSD() )
    75577642        {
    7558           uiActDist = m_pcRdCost->getDistPartVSD( pcCU, uiAbsPtIdx, piPredic, uiStride, piOrig, uiStride, uiWidth, uiHeight, false );
     7643          uiActDist = m_pcRdCost->getDistPartVSD( pcCU, uiAbsPtIdx, bitDepthY, piPredic, uiStride, piOrig, uiStride, uiWidth, uiHeight, false );
    75597644        }
    75607645        else
    75617646        {
    7562           uiActDist = m_pcRdCost->getDistPartVSO( pcCU, uiAbsPtIdx, piPredic, uiStride, piOrig, uiStride, uiWidth, uiHeight, false );
     7647          uiActDist = m_pcRdCost->getDistPartVSO( pcCU, uiAbsPtIdx, bitDepthY, piPredic, uiStride, piOrig, uiStride, uiWidth, uiHeight, false );
    75637648        }
    75647649
     
    75777662
    75787663#if H_3D_DIM_DLT
    7579   rDeltaDC1 = pcCU->getSlice()->getPPS()->getDLT()->depthValue2idx( pcCU->getSlice()->getLayerIdInVps(), ClipY(predDC1 + rDeltaDC1) ) - pcCU->getSlice()->getPPS()->getDLT()->depthValue2idx( pcCU->getSlice()->getLayerIdInVps(), predDC1 );
    7580   rDeltaDC2 = pcCU->getSlice()->getPPS()->getDLT()->depthValue2idx( pcCU->getSlice()->getLayerIdInVps(), ClipY(predDC2 + rDeltaDC2) ) - pcCU->getSlice()->getPPS()->getDLT()->depthValue2idx( pcCU->getSlice()->getLayerIdInVps(), predDC2 );
     7664  rDeltaDC1 = pcCU->getSlice()->getPPS()->getDLT()->depthValue2idx( pcCU->getSlice()->getLayerIdInVps(), ClipBD(predDC1 + rDeltaDC1), bitDepthY ) - pcCU->getSlice()->getPPS()->getDLT()->depthValue2idx( pcCU->getSlice()->getLayerIdInVps(), predDC1 );
     7665  rDeltaDC2 = pcCU->getSlice()->getPPS()->getDLT()->depthValue2idx( pcCU->getSlice()->getLayerIdInVps(), ClipBD(predDC2 + rDeltaDC2), bitDepthY ) - pcCU->getSlice()->getPPS()->getDLT()->depthValue2idx( pcCU->getSlice()->getLayerIdInVps(), predDC2 );
    75817666#endif
    75827667}
     
    75857670{
    75867671  ruiTabIdx = 0;
     7672  Int bitDepthY = pcCU->getSlice()->getSPS()->getBitDepth(CHANNEL_TYPE_LUMA);
    75877673
    75887674  // local pred buffer
    75897675  TComYuv cPredYuv;
    7590   cPredYuv.create( uiWidth, uiHeight );
     7676  cPredYuv.create( uiWidth, uiHeight, CHROMA_400 );
    75917677  cPredYuv.clear();
    75927678
    7593   UInt uiPredStride = cPredYuv.getStride();
    7594   Pel* piPred       = cPredYuv.getLumaAddr();
     7679  UInt uiPredStride = cPredYuv.getStride( COMPONENT_Y );
     7680  Pel* piPred       = cPredYuv.getAddr( COMPONENT_Y );
    75957681
    75967682  Pel refDC1 = 0; Pel refDC2 = 0;
    7597   WedgeList*     pacWedgeList     = pcCU->isDMM1UpscaleMode( uiWidth ) ? &g_dmmWedgeLists[(g_aucConvertToBit[pcCU->getDMM1BasePatternWidth(uiWidth)])] : &g_dmmWedgeLists[(g_aucConvertToBit[uiWidth])];
    7598   WedgeNodeList* pacWedgeNodeList = pcCU->isDMM1UpscaleMode( uiWidth ) ? &g_dmmWedgeNodeLists[(g_aucConvertToBit[pcCU->getDMM1BasePatternWidth(uiWidth)])] : &g_dmmWedgeNodeLists[(g_aucConvertToBit[uiWidth])];
     7683
     7684  WedgeList*     pacWedgeList     = getWedgeListScaled    ( uiWidth );
     7685  WedgeNodeList* pacWedgeNodeList = getWedgeNodeListScaled( uiWidth );
    75997686
    76007687  // coarse wedge search
     
    76047691  {
    76057692    TComWedgelet* pcWedgelet = &(pacWedgeList->at(pacWedgeNodeList->at(uiNodeId).getPatternIdx()));
    7606     Bool *pbPattern = pcCU->isDMM1UpscaleMode(uiWidth) ? pcWedgelet->getScaledPattern(uiWidth) : pcWedgelet->getPattern();
    7607     UInt uiStride   = pcCU->isDMM1UpscaleMode(uiWidth) ? uiWidth : pcWedgelet->getStride();
    7608     xCalcBiSegDCs  ( piRef,  uiRefStride,  pbPattern, uiStride, refDC1, refDC2 );
    7609     xAssignBiSegDCs( piPred, uiPredStride, pbPattern, uiStride, refDC1, refDC2 );
     7693    Bool *pbPattern = pcWedgelet->getPatternScaled(uiWidth);
     7694    UInt uiStride   = uiWidth;
     7695    xCalcBiSegDCs  ( piRef,  uiRefStride,  pbPattern, uiStride, refDC1, refDC2, (1<<(bitDepthY-1)) );
     7696    assignBiSegDCs( piPred, uiPredStride, pbPattern, uiStride, refDC1, refDC2 );
    76107697
    76117698    Dist uiActDist = RDO_DIST_MAX;
    7612 #if H_3D_VSO
     7699#if NH_3D_VSO
    76137700    if( m_pcRdCost->getUseVSO() )
    76147701    {
    76157702      if( m_pcRdCost->getUseEstimatedVSD() )
    76167703      {
    7617         uiActDist = m_pcRdCost->getDistPartVSD( pcCU, uiAbsPtIdx, piPred, uiPredStride, piRef, uiRefStride, uiWidth, uiHeight, false );
     7704        uiActDist = m_pcRdCost->getDistPartVSD( pcCU, uiAbsPtIdx, bitDepthY, piPred, uiPredStride, piRef, uiRefStride, uiWidth, uiHeight, false );
    76187705      }
    76197706      else
    76207707      {
    7621         uiActDist = m_pcRdCost->getDistPartVSO( pcCU, uiAbsPtIdx, piPred, uiPredStride, piRef, uiRefStride, uiWidth, uiHeight, false );
     7708        uiActDist = m_pcRdCost->getDistPartVSO( pcCU, uiAbsPtIdx, bitDepthY, piPred, uiPredStride, piRef, uiRefStride, uiWidth, uiHeight, false );
    76227709      }
    76237710    }
     
    76257712#endif
    76267713    {
    7627       uiActDist = m_pcRdCost->getDistPart( g_bitDepthY, piPred, uiPredStride, piRef, uiRefStride, uiWidth, uiHeight, TEXT_LUMA, DF_SAD );
     7714      uiActDist = m_pcRdCost->getDistPart( bitDepthY, piPred, uiPredStride, piRef, uiRefStride, uiWidth, uiHeight, COMPONENT_Y, DF_SAD );
    76287715    }
    76297716
     
    76407727  for( UInt uiRefId = 0; uiRefId < DMM_NUM_WEDGE_REFINES; uiRefId++ )
    76417728  {
    7642     if( pacWedgeNodeList->at(uiBestNodeId).getRefineIdx( uiRefId ) != DMM_NO_WEDGEINDEX )
     7729    if( pacWedgeNodeList->at(uiBestNodeId).getRefineIdx( uiRefId ) != DMM_NO_WEDGE_IDX )
    76437730    {
    76447731      TComWedgelet* pcWedgelet = &(pacWedgeList->at(pacWedgeNodeList->at(uiBestNodeId).getRefineIdx( uiRefId )));
    7645       Bool *pbPattern = pcCU->isDMM1UpscaleMode(uiWidth) ? pcWedgelet->getScaledPattern(uiWidth) : pcWedgelet->getPattern();
    7646       UInt uiStride   = pcCU->isDMM1UpscaleMode(uiWidth) ? uiWidth : pcWedgelet->getStride();
    7647       xCalcBiSegDCs  ( piRef,  uiRefStride,  pbPattern, uiStride, refDC1, refDC2 );
    7648       xAssignBiSegDCs( piPred, uiPredStride, pbPattern, uiStride, refDC1, refDC2 );
     7732      Bool *pbPattern = pcWedgelet->getPatternScaled(uiWidth);
     7733      UInt uiStride   = uiWidth;
     7734      xCalcBiSegDCs  ( piRef,  uiRefStride,  pbPattern, uiStride, refDC1, refDC2, (1<<(bitDepthY-1)) );
     7735      assignBiSegDCs( piPred, uiPredStride, pbPattern, uiStride, refDC1, refDC2 );
    76497736      Dist uiActDist = RDO_DIST_MAX;
    7650 #if H_3D_VSO
     7737#if NH_3D_VSO
    76517738      if( m_pcRdCost->getUseVSO() )
    76527739      {
    7653         if( m_pcRdCost->getUseEstimatedVSD() ) //PM: use VSO instead of VSD here?
    7654         {
    7655           uiActDist = m_pcRdCost->getDistPartVSD( pcCU, uiAbsPtIdx, piPred, uiPredStride, piRef, uiRefStride, uiWidth, uiHeight, false );
     7740        if( m_pcRdCost->getUseEstimatedVSD() )
     7741        {
     7742          uiActDist = m_pcRdCost->getDistPartVSD( pcCU, uiAbsPtIdx, bitDepthY, piPred, uiPredStride, piRef, uiRefStride, uiWidth, uiHeight, false );
    76567743        }
    76577744        else
    76587745        {
    7659           uiActDist = m_pcRdCost->getDistPartVSO( pcCU, uiAbsPtIdx, piPred, uiPredStride, piRef, uiRefStride, uiWidth, uiHeight, false );
     7746          uiActDist = m_pcRdCost->getDistPartVSO( pcCU, uiAbsPtIdx, bitDepthY, piPred, uiPredStride, piRef, uiRefStride, uiWidth, uiHeight, false );
    76607747        }
    76617748      }
     
    76637750#endif
    76647751      {
    7665         uiActDist = m_pcRdCost->getDistPart( g_bitDepthY, piPred, uiPredStride, piRef, uiRefStride, uiWidth, uiHeight, TEXT_LUMA, DF_SAD );
     7752        uiActDist = m_pcRdCost->getDistPart( bitDepthY, piPred, uiPredStride, piRef, uiRefStride, uiWidth, uiHeight, COMPONENT_Y, DF_SAD );
    76667753      }
    76677754
     
    76817768
    76827769#endif
    7683 #endif
    7684 
     7770#if TEMP_SDC_CLEANUP // PM: consider this cleanup for SDC
     7771#if NH_3D_SDC
     7772Void TEncSearch::xCalcConstantSDC( Pel* ptrSrc, UInt srcStride, UInt uiSize, Pel& valDC )
     7773{
     7774  valDC = 0;
     7775  UInt       uiDC = 0;
     7776  UInt uiNumPixDC = 0;
     7777
     7778  Int subSamplePix = ( uiSize > 16 ) ? 2 : 1;
     7779
     7780  Pel* piTemp = ptrSrc;
     7781  for( UInt uiY = 0; uiY < uiSize; uiY += subSamplePix )
     7782  {
     7783    for( UInt uiX = 0; uiX < uiSize; uiX += subSamplePix )
     7784    {
     7785      uiDC += piTemp[uiX];
     7786      uiNumPixDC++;
     7787    }
     7788    piTemp += subSamplePix*srcStride;
     7789  }
     7790
     7791  if( uiNumPixDC > 0 ) { valDC = uiDC / uiNumPixDC; }
     7792}
     7793#endif
     7794#endif
    76857795//! \}
  • branches/HTM-14.1-update-dev1-HHI/source/Lib/TLibEncoder/TEncSearch.h

    r1200 r1209  
    179179                                  TComYuv*    pcRecoYuv,
    180180                                  Pel         resiLuma[NUMBER_OF_STORED_RESIDUAL_TYPES][MAX_CU_SIZE * MAX_CU_SIZE]
    181 #if H_3D_DIM
     181                                  DEBUG_STRING_FN_DECLARE(sDebug)
     182#if NH_3D_ENC_DEPTH
    182183                                , Bool        bOnlyIVP
    183184#endif
    184                                   DEBUG_STRING_FN_DECLARE(sDebug));
     185                                );
    185186
    186187  Void  estIntraPredChromaQT    ( TComDataCU* pcCU,
     
    282283                                    DEBUG_STRING_FN_DECLARE(sTest)
    283284                                         ,Int           default0Save1Load2 = 0
    284 #if H_3D_DIM_ENC
    285                                   , Bool          zeroResi = false
     285#if NH_3D_ENC_DEPTH
     286                                  , Bool          zeroResiFlag = false
    286287#endif
    287288                                   );
     
    300301#endif
    301302                                    Double&      dRDCost,
    302 #if H_3D_DIM_ENC
    303                                    , Bool          zeroResi = false
    304 #endif
    305303                                    TComTU      &rTu
    306                                     DEBUG_STRING_FN_DECLARE(sDebug));
     304                                    DEBUG_STRING_FN_DECLARE(sDebug)
     305#if NH_3D_ENC_DEPTH
     306                                  , Bool        zeroResiFlag = false
     307#endif
     308                                  );
    307309
    308310  Void  xSetIntraResultLumaQT     ( TComYuv*     pcRecoYuv,
     
    345347  Void xIntraCodingDIS           ( TComDataCU* pcCU, UInt uiAbsPartIdx, TComYuv* pcOrgYuv, TComYuv* pcPredYuv, Dist& ruiDist, Double& dRDCost, UInt uiPredMode );
    346348#endif
    347 #if H_3D_DIM
     349
    348350  // -------------------------------------------------------------------------------------------------------------------
    349351  // Depth intra search
    350352  // -------------------------------------------------------------------------------------------------------------------
    351   Void xCalcBiSegDCs              ( Pel* ptrSrc, UInt srcStride, Bool* biSegPattern, Int patternStride, Pel& valDC1, Pel& valDC2 );
    352 #if H_3D_DIM_DMM
     353#if NH_3D_DMM
     354  Void xCalcBiSegDCs              ( Pel* ptrSrc, UInt srcStride, Bool* biSegPattern, Int patternStride, Pel& valDC1, Pel& valDC2, Pel defaultVal, Bool subSamp = false );
    353355  Void xSearchDmmDeltaDCs         ( TComDataCU* pcCU, UInt uiAbsPtIdx, Pel* piOrig, Pel* piPredic, UInt uiStride, Bool* biSegPattern, Int patternStride, UInt uiWidth, UInt uiHeight, Pel& rDeltaDC1, Pel& rDeltaDC2 );
    354356  Void xSearchDmm1Wedge           ( TComDataCU* pcCU, UInt uiAbsPtIdx, Pel* piRef, UInt uiRefStride, UInt uiWidth, UInt uiHeight, UInt& ruiTabIdx );
     
    356358#if H_3D_DIM_SDC
    357359  Void xIntraCodingSDC            ( TComDataCU* pcCU, UInt uiAbsPartIdx, TComYuv* pcOrgYuv, TComYuv* pcPredYuv, Dist& ruiDist, Double& dRDCost, Bool bZeroResidual, Int iSDCDeltaResi    );
     360#endif
     361#if TEMP_SDC_CLEANUP // PM: consider this cleanup for SDC
     362#if NH_3D_SDC
     363  Void xCalcConstantSDC           ( Pel* ptrSrc, UInt srcStride, UInt uiSize, Pel& valDC );
    358364#endif
    359365#endif
Note: See TracChangeset for help on using the changeset viewer.