Changeset 1328 in SHVCSoftware for branches/SHM-dev/source/Lib/TLibEncoder


Ignore:
Timestamp:
22 Jul 2015, 00:52:14 (10 years ago)
Author:
seregin
Message:

port rev 4406

Location:
branches/SHM-dev/source/Lib/TLibEncoder
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • branches/SHM-dev/source/Lib/TLibEncoder/TEncCfg.h

    r1327 r1328  
    223223  Bool      m_bUseConstrainedIntraPred;
    224224  Bool      m_bFastUDIUseMPMEnabled;
     225  Bool      m_bFastMEForGenBLowDelayEnabled;
    225226  Bool      m_usePCM;
    226227  Int       m_PCMBitDepth[MAX_NUM_CHANNEL_TYPE];
     
    641642  Void      setUseConstrainedIntraPred      ( Bool  b )     { m_bUseConstrainedIntraPred = b; }
    642643  Void      setFastUDIUseMPMEnabled         ( Bool  b )     { m_bFastUDIUseMPMEnabled = b; }
     644  Void      setFastMEForGenBLowDelayEnabled ( Bool  b )     { m_bFastMEForGenBLowDelayEnabled = b; }
    643645  Void      setPCMInputBitDepthFlag         ( Bool  b )     { m_bPCMInputBitDepthFlag = b; }
    644646  Void      setPCMFilterDisableFlag         ( Bool  b )     {  m_bPCMFilterDisableFlag = b; }
     
    664666  Bool      getUseConstrainedIntraPred      ()      { return m_bUseConstrainedIntraPred; }
    665667  Bool      getFastUDIUseMPMEnabled         ()      { return m_bFastUDIUseMPMEnabled; }
     668  Bool      getFastMEForGenBLowDelayEnabled ()      { return m_bFastMEForGenBLowDelayEnabled; }
    666669  Bool      getPCMInputBitDepthFlag         ()      { return m_bPCMInputBitDepthFlag;   }
    667670  Bool      getPCMFilterDisableFlag         ()      { return m_bPCMFilterDisableFlag;   }
  • branches/SHM-dev/source/Lib/TLibEncoder/TEncSearch.cpp

    r1326 r1328  
    22502250    Int numModesAvailable     = 35; //total number of Intra modes
    22512251    UInt uiRdModeList[FAST_UDI_MAX_RDMODE_NUM];
    2252     Int numModesForFullRD = g_aucIntraModeNumFast[ uiWidthBit ];
     2252    Int numModesForFullRD = m_pcEncCfg->getFastUDIUseMPMEnabled()?g_aucIntraModeNumFast_UseMPM[ uiWidthBit ] : g_aucIntraModeNumFast_NotUseMPM[ uiWidthBit ];
    22532253
    22542254    if (tuRecurseWithPU.ProcessComponentSection(COMPONENT_Y))
     
    23382338      }
    23392339
    2340 #if FAST_UDI_USE_MPM
     2340      if (m_pcEncCfg->getFastUDIUseMPMEnabled())
     2341      {
    23412342#if FAST_INTRA_SHVC == 0
    2342       Int uiPreds[NUM_MOST_PROBABLE_MODES] = {-1, -1, -1};
    2343 
    2344       Int iMode = -1;
    2345       pcCU->getIntraDirPredictor( uiPartOffset, uiPreds, COMPONENT_Y, &iMode );
    2346 #endif
    2347       const Int numCand = ( iMode >= 0 ) ? iMode : Int(NUM_MOST_PROBABLE_MODES);
    2348 
    2349       for( Int j=0; j < numCand; j++)
    2350       {
    2351         Bool mostProbableModeIncluded = false;
    2352         Int mostProbableMode = uiPreds[j];
    2353 
    2354         for( Int i=0; i < numModesForFullRD; i++)
    2355         {
    2356           mostProbableModeIncluded |= (mostProbableMode == uiRdModeList[i]);
    2357         }
    2358         if (!mostProbableModeIncluded)
    2359         {
    2360           uiRdModeList[numModesForFullRD++] = mostProbableMode;
    2361         }
    2362       }
    2363 #endif // FAST_UDI_USE_MPM
     2343        Int uiPreds[NUM_MOST_PROBABLE_MODES] = {-1, -1, -1};
     2344
     2345        Int iMode = -1;
     2346        pcCU->getIntraDirPredictor( uiPartOffset, uiPreds, COMPONENT_Y, &iMode );
     2347#endif
     2348        const Int numCand = ( iMode >= 0 ) ? iMode : Int(NUM_MOST_PROBABLE_MODES);
     2349
     2350        for( Int j=0; j < numCand; j++)
     2351        {
     2352          Bool mostProbableModeIncluded = false;
     2353          Int mostProbableMode = uiPreds[j];
     2354
     2355          for( Int i=0; i < numModesForFullRD; i++)
     2356          {
     2357            mostProbableModeIncluded |= (mostProbableMode == uiRdModeList[i]);
     2358          }
     2359          if (!mostProbableModeIncluded)
     2360          {
     2361            uiRdModeList[numModesForFullRD++] = mostProbableMode;
     2362          }
     2363        }
     2364      }
    23642365    }
    23652366    else
     
    31493150        uiBitsTemp += m_auiMVPIdxCost[aaiMvpIdx[iRefList][iRefIdxTemp]][AMVP_MAX_NUM_CANDS];
    31503151
    3151 #if GPB_SIMPLE_UNI
    3152         if ( iRefList == 1 )    // list 1
     3152        if ( m_pcEncCfg->getFastMEForGenBLowDelayEnabled() && iRefList == 1 )    // list 1
    31533153        {
    31543154          if ( pcCU->getSlice()->getList1IdxToList0Idx( iRefIdxTemp ) >= 0 )
     
    31733173          xMotionEstimation ( pcCU, pcOrgYuv, iPartIdx, eRefPicList, &cMvPred[iRefList][iRefIdxTemp], iRefIdxTemp, cMvTemp[iRefList][iRefIdxTemp], uiBitsTemp, uiCostTemp );
    31743174        }
    3175 #else
    3176         xMotionEstimation ( pcCU, pcOrgYuv, iPartIdx, eRefPicList, &cMvPred[iRefList][iRefIdxTemp], iRefIdxTemp, cMvTemp[iRefList][iRefIdxTemp], uiBitsTemp, uiCostTemp );
    3177 #endif
    31783175        xCopyAMVPInfo(pcCU->getCUMvField(eRefPicList)->getAMVPInfo(), &aacAMVPInfo[iRefList][iRefIdxTemp]); // must always be done ( also when AMVP_MODE = AM_NONE )
    31793176        xCheckBestMVP(pcCU, eRefPicList, cMvTemp[iRefList][iRefIdxTemp], cMvPred[iRefList][iRefIdxTemp], aaiMvpIdx[iRefList][iRefIdxTemp], uiBitsTemp, uiCostTemp);
Note: See TracChangeset for help on using the changeset viewer.