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


Ignore:
Timestamp:
22 Jul 2015, 01:36:46 (10 years ago)
Author:
seregin
Message:

port rev 4410

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

Legend:

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

    r1331 r1332  
    165165  Bool      m_bUseSAO;
    166166  Bool      m_bTestSAODisableAtPictureLevel;
     167  Double    m_saoEncodingRate;       // When non-0 SAO early picture termination is enabled for luma and chroma
     168  Double    m_saoEncodingRateChroma; // The SAO early picture termination rate to use for chroma (when m_SaoEncodingRate is >0). If <=0, use results for luma.
    167169  Int       m_maxNumOffsetsPerPic;
    168170  Bool      m_saoCtuBoundary;
     
    724726  Void  setTestSAODisableAtPictureLevel (Bool bVal)                  { m_bTestSAODisableAtPictureLevel = bVal; }
    725727  Bool  getTestSAODisableAtPictureLevel ( ) const                    { return m_bTestSAODisableAtPictureLevel; }
     728
     729  Void   setSaoEncodingRate(Double v)                                { m_saoEncodingRate = v; }
     730  Double getSaoEncodingRate() const                                  { return m_saoEncodingRate; }
     731  Void   setSaoEncodingRateChroma(Double v)                          { m_saoEncodingRateChroma = v; }
     732  Double getSaoEncodingRateChroma() const                            { return m_saoEncodingRateChroma; }
    726733  Void  setMaxNumOffsetsPerPic                   (Int iVal)          { m_maxNumOffsetsPerPic = iVal; }
    727734  Int   getMaxNumOffsetsPerPic                   ()                  { return m_maxNumOffsetsPerPic; }
  • branches/SHM-dev/source/Lib/TLibEncoder/TEncGOP.cpp

    r1331 r1332  
    26152615      m_pcEncTop->getRDGoOnSbacCoder()->setBitstream(&tempBitCounter);
    26162616      m_pcSAO->initRDOCabacCoder(m_pcEncTop->getRDGoOnSbacCoder(), pcSlice);
    2617       m_pcSAO->SAOProcess(pcPic, sliceEnabled, pcPic->getSlice(0)->getLambdas(), m_pcCfg->getTestSAODisableAtPictureLevel()
     2617      m_pcSAO->SAOProcess(pcPic, sliceEnabled, pcPic->getSlice(0)->getLambdas(), m_pcCfg->getTestSAODisableAtPictureLevel(), m_pcCfg->getSaoEncodingRate(), m_pcCfg->getSaoEncodingRateChroma()
    26182618#if SAO_ENCODE_ALLOW_USE_PREDEBLOCK
    26192619                          , m_pcCfg->getSaoCtuBoundary()
  • branches/SHM-dev/source/Lib/TLibEncoder/TEncSampleAdaptiveOffset.cpp

    r1331 r1332  
    127127#endif
    128128
    129 #if SAO_ENCODING_CHOICE
    130129  ::memset(m_saoDisabledRate, 0, sizeof(m_saoDisabledRate));
    131 #endif
    132130
    133131  for(Int typeIdc=0; typeIdc < NUM_SAO_NEW_TYPES; typeIdc++)
     
    254252
    255253
    256 Void TEncSampleAdaptiveOffset::SAOProcess(TComPic* pPic, Bool* sliceEnabled, const Double *lambdas, const Bool bTestSAODisableAtPictureLevel
     254Void TEncSampleAdaptiveOffset::SAOProcess(TComPic* pPic, Bool* sliceEnabled, const Double *lambdas, const Bool bTestSAODisableAtPictureLevel, const Double saoEncodingRate, const Double saoEncodingRateChroma
    257255#if SAO_ENCODE_ALLOW_USE_PREDEBLOCK
    258256                                         , Bool isPreDBFSamplesUsed
     
    277275#endif
    278276  //slice on/off
    279   decidePicParams(sliceEnabled, pPic->getSlice(0)->getDepth());
     277  decidePicParams(sliceEnabled, pPic->getSlice(0)->getDepth(), saoEncodingRate, saoEncodingRateChroma);
    280278
    281279  //block on/off
    282280  SAOBlkParam* reconParams = new SAOBlkParam[m_numCTUsPic]; //temporary parameter buffer for storing reconstructed SAO parameters
    283   decideBlkParams(pPic, sliceEnabled, m_statData, srcYuv, resYuv, reconParams, pPic->getPicSym()->getSAOBlkParam(), bTestSAODisableAtPictureLevel);
     281  decideBlkParams(pPic, sliceEnabled, m_statData, srcYuv, resYuv, reconParams, pPic->getPicSym()->getSAOBlkParam(), bTestSAODisableAtPictureLevel, saoEncodingRate, saoEncodingRateChroma);
    284282  delete[] reconParams;
    285283}
     
    364362}
    365363
    366 Void TEncSampleAdaptiveOffset::decidePicParams(Bool* sliceEnabled, Int picTempLayer)
     364Void TEncSampleAdaptiveOffset::decidePicParams(Bool* sliceEnabled, Int picTempLayer, const Double saoEncodingRate, const Double saoEncodingRateChroma)
    367365{
    368366  //decide sliceEnabled[compIdx]
     
    378376    sliceEnabled[compIdx] = true;
    379377
    380 #if SAO_ENCODING_CHOICE
    381 #if SAO_ENCODING_CHOICE_CHROMA
    382     // decide slice-level on/off based on previous results
    383     if( (picTempLayer > 0)
    384       && (m_saoDisabledRate[compIdx][picTempLayer-1] > ((compIdx==COMPONENT_Y) ? SAO_ENCODING_RATE : SAO_ENCODING_RATE_CHROMA)) )
    385     {
    386       sliceEnabled[compIdx] = false;
    387     }
    388 #else
    389     // decide slice-level on/off based on previous results
    390     if( (picTempLayer > 0)
    391       && (m_saoDisabledRate[COMPONENT_Y][0] > SAO_ENCODING_RATE) )
    392     {
    393       sliceEnabled[compIdx] = false;
    394     }
    395 #endif
    396 #endif
     378    if (saoEncodingRate>0.0)
     379    {
     380      if (saoEncodingRateChroma>0.0)
     381      {
     382        // decide slice-level on/off based on previous results
     383        if( (picTempLayer > 0)
     384          && (m_saoDisabledRate[compIdx][picTempLayer-1] > ((compIdx==COMPONENT_Y) ? saoEncodingRate : saoEncodingRateChroma)) )
     385        {
     386          sliceEnabled[compIdx] = false;
     387        }
     388      }
     389      else
     390      {
     391        // decide slice-level on/off based on previous results
     392        if( (picTempLayer > 0)
     393          && (m_saoDisabledRate[COMPONENT_Y][0] > saoEncodingRate) )
     394        {
     395          sliceEnabled[compIdx] = false;
     396        }
     397      }
     398    }
    397399  }
    398400}
     
    791793}
    792794
    793 Void TEncSampleAdaptiveOffset::decideBlkParams(TComPic* pic, Bool* sliceEnabled, SAOStatData*** blkStats, TComPicYuv* srcYuv, TComPicYuv* resYuv, SAOBlkParam* reconParams, SAOBlkParam* codedParams, const Bool bTestSAODisableAtPictureLevel)
     795Void TEncSampleAdaptiveOffset::decideBlkParams(TComPic* pic, Bool* sliceEnabled, SAOStatData*** blkStats, TComPicYuv* srcYuv, TComPicYuv* resYuv,
     796                                               SAOBlkParam* reconParams, SAOBlkParam* codedParams, const Bool bTestSAODisableAtPictureLevel,
     797                                               const Double saoEncodingRate, const Double saoEncodingRateChroma)
    794798{
    795799  Bool allBlksDisabled = true;
     
    895899  }
    896900
    897 #if SAO_ENCODING_CHOICE
    898   Int picTempLayer = pic->getSlice(0)->getDepth();
    899   Int numCtusForSAOOff[MAX_NUM_COMPONENT];
    900 
    901   for (Int compIdx = 0; compIdx < numberOfComponents; compIdx++)
    902   {
    903     numCtusForSAOOff[compIdx] = 0;
    904     for(Int ctuRsAddr=0; ctuRsAddr< m_numCTUsPic; ctuRsAddr++)
    905     {
    906       if( reconParams[ctuRsAddr][compIdx].modeIdc == SAO_MODE_OFF)
    907       {
    908         numCtusForSAOOff[compIdx]++;
    909       }
    910     }
    911   }
    912 #if SAO_ENCODING_CHOICE_CHROMA
    913   for (Int compIdx = 0; compIdx < numberOfComponents; compIdx++)
    914   {
    915     m_saoDisabledRate[compIdx][picTempLayer] = (Double)numCtusForSAOOff[compIdx]/(Double)m_numCTUsPic;
    916   }
    917 #else
    918   if (picTempLayer == 0)
    919   {
    920     m_saoDisabledRate[COMPONENT_Y][0] = (Double)(numCtusForSAOOff[COMPONENT_Y]+numCtusForSAOOff[COMPONENT_Cb]+numCtusForSAOOff[COMPONENT_Cr])/(Double)(m_numCTUsPic*3);
    921   }
    922 #endif
    923 #endif
     901  if (saoEncodingRate > 0.0)
     902  {
     903    Int picTempLayer = pic->getSlice(0)->getDepth();
     904    Int numCtusForSAOOff[MAX_NUM_COMPONENT];
     905
     906    for (Int compIdx = 0; compIdx < numberOfComponents; compIdx++)
     907    {
     908      numCtusForSAOOff[compIdx] = 0;
     909      for(Int ctuRsAddr=0; ctuRsAddr< m_numCTUsPic; ctuRsAddr++)
     910      {
     911        if( reconParams[ctuRsAddr][compIdx].modeIdc == SAO_MODE_OFF)
     912        {
     913          numCtusForSAOOff[compIdx]++;
     914        }
     915      }
     916    }
     917    if (saoEncodingRateChroma > 0.0)
     918    {
     919      for (Int compIdx = 0; compIdx < numberOfComponents; compIdx++)
     920      {
     921        m_saoDisabledRate[compIdx][picTempLayer] = (Double)numCtusForSAOOff[compIdx]/(Double)m_numCTUsPic;
     922      }
     923    }
     924    else if (picTempLayer == 0)
     925    {
     926      m_saoDisabledRate[COMPONENT_Y][0] = (Double)(numCtusForSAOOff[COMPONENT_Y]+numCtusForSAOOff[COMPONENT_Cb]+numCtusForSAOOff[COMPONENT_Cr])/(Double)(m_numCTUsPic*3);
     927    }
     928  }
    924929}
    925930
  • branches/SHM-dev/source/Lib/TLibEncoder/TEncSampleAdaptiveOffset.h

    r1331 r1332  
    109109  Void destroyEncData();
    110110  Void initRDOCabacCoder(TEncSbac* pcRDGoOnSbacCoder, TComSlice* pcSlice) ;
    111   Void SAOProcess(TComPic* pPic, Bool* sliceEnabled, const Double *lambdas, const Bool bTestSAODisableAtPictureLevel
     111  Void SAOProcess(TComPic* pPic, Bool* sliceEnabled, const Double *lambdas, const Bool bTestSAODisableAtPictureLevel, const Double saoEncodingRate, const Double saoEncodingRateChroma
    112112#if SAO_ENCODE_ALLOW_USE_PREDEBLOCK
    113113                , Bool isPreDBFSamplesUsed
     
    124124#endif
    125125                   );
    126   Void decidePicParams(Bool* sliceEnabled, Int picTempLayer);
    127   Void decideBlkParams(TComPic* pic, Bool* sliceEnabled, SAOStatData*** blkStats, TComPicYuv* srcYuv, TComPicYuv* resYuv, SAOBlkParam* reconParams, SAOBlkParam* codedParams, const Bool bTestSAODisableAtPictureLevel);
     126  Void decidePicParams(Bool* sliceEnabled, Int picTempLayer, const Double saoEncodingRate, const Double saoEncodingRateChroma);
     127  Void decideBlkParams(TComPic* pic, Bool* sliceEnabled, SAOStatData*** blkStats, TComPicYuv* srcYuv, TComPicYuv* resYuv, SAOBlkParam* reconParams, SAOBlkParam* codedParams, const Bool bTestSAODisableAtPictureLevel, const Double saoEncodingRate, const Double saoEncodingRateChroma);
    128128  Void getBlkStats(const ComponentID compIdx, const Int channelBitDepth, SAOStatData* statsDataTypes, Pel* srcBlk, Pel* orgBlk, Int srcStride, Int orgStride, Int width, Int height, Bool isLeftAvail,  Bool isRightAvail, Bool isAboveAvail, Bool isBelowAvail, Bool isAboveLeftAvail, Bool isAboveRightAvail
    129129#if SAO_ENCODE_ALLOW_USE_PREDEBLOCK
     
    156156  SAOStatData***         m_preDBFstatData;
    157157#endif
    158 #if SAO_ENCODING_CHOICE
    159158  Double                 m_saoDisabledRate[MAX_NUM_COMPONENT][MAX_TLAYER];
    160 #endif
    161159  Int                    m_skipLinesR[MAX_NUM_COMPONENT][NUM_SAO_NEW_TYPES];
    162160  Int                    m_skipLinesB[MAX_NUM_COMPONENT][NUM_SAO_NEW_TYPES];
Note: See TracChangeset for help on using the changeset viewer.