Changeset 1249 in SHVCSoftware


Ignore:
Timestamp:
14 Jul 2015, 00:43:13 (9 years ago)
Author:
seregin
Message:

port rev 4243

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

Legend:

Unmodified
Added
Removed
  • branches/SHM-dev/source/Lib/TLibEncoder/TEncSearch.cpp

    r1248 r1249  
    204204                      Int           bipredSearchRange,
    205205                      Int           iFastSearch,
    206                       Int           iMaxDeltaQP,
    207206                      TEncEntropy*  pcEntropyCoder,
    208207                      TComRdCost*   pcRdCost,
     
    216215  m_bipredSearchRange    = bipredSearchRange;
    217216  m_iFastSearch          = iFastSearch;
    218   m_iMaxDeltaQP          = iMaxDeltaQP;
    219217  m_pcEntropyCoder       = pcEntropyCoder;
    220218  m_pcRdCost             = pcRdCost;
     
    45014499Void TEncSearch::encodeResAndCalcRdInterCU( TComDataCU* pcCU, TComYuv* pcYuvOrg, TComYuv* pcYuvPred,
    45024500                                            TComYuv* pcYuvResi, TComYuv* pcYuvResiBest, TComYuv* pcYuvRec,
    4503                                             Bool bSkipRes DEBUG_STRING_FN_DECLARE(sDebug) )
     4501                                            Bool bSkipResidual DEBUG_STRING_FN_DECLARE(sDebug) )
    45044502{
    4505   if ( pcCU->isIntra(0) )
    4506   {
    4507     return;
    4508   }
    4509 
    4510   Bool       bHighPass    = pcCU->getSlice()->getDepth() ? true : false;
    4511   UInt       uiBits       = 0, uiBitsBest       = 0;
    4512   Distortion uiDistortion = 0, uiDistortionBest = 0;
    4513 
    4514   UInt        uiWidth      = pcCU->getWidth ( 0 );
    4515   UInt        uiHeight     = pcCU->getHeight( 0 );
    4516 
    4517   // The pcCU is not marked as skip-mode at this point, and its coeffs and arlCoeffs will all be 0.
     4503  assert ( !pcCU->isIntra(0) );
     4504
     4505  const UInt cuWidthPixels      = pcCU->getWidth ( 0 );
     4506  const UInt cuHeightPixels     = pcCU->getHeight( 0 );
     4507  const Int  numValidComponents = pcCU->getPic()->getNumberValidComponents();
     4508
     4509  // The pcCU is not marked as skip-mode at this point, and its m_pcTrCoeff, m_pcArlCoeff, m_puhCbf, m_puhTrIdx will all be 0.
    45184510  // due to prior calls to TComDataCU::initEstData(  );
    45194511
    4520   //  No residual coding : SKIP mode
    4521   if ( bSkipRes )
     4512  if ( bSkipResidual ) //  No residual coding : SKIP mode
    45224513  {
    45234514    pcCU->setSkipFlagSubParts( true, 0, pcCU->getDepth(0) );
     
    45264517
    45274518    pcYuvPred->copyToPartYuv( pcYuvRec, 0 );
    4528 
    4529     for (UInt ch=0; ch < pcCU->getPic()->getNumberValidComponents(); ch++)
    4530     {
    4531       const ComponentID compID=ComponentID(ch);
     4519    Distortion distortion = 0;
     4520
     4521    for (Int comp=0; comp < numValidComponents; comp++)
     4522    {
     4523      const ComponentID compID=ComponentID(comp);
    45324524      const UInt csx=pcYuvOrg->getComponentScaleX(compID);
    45334525      const UInt csy=pcYuvOrg->getComponentScaleY(compID);
    4534       uiDistortion += m_pcRdCost->getDistPart( g_bitDepth[toChannelType(compID)], pcYuvRec->getAddr(compID), pcYuvRec->getStride(compID), pcYuvOrg->getAddr(compID),
    4535                                                pcYuvOrg->getStride(compID), uiWidth >> csx, uiHeight >> csy, compID);
     4526      distortion += m_pcRdCost->getDistPart( g_bitDepth[toChannelType(compID)], pcYuvRec->getAddr(compID), pcYuvRec->getStride(compID), pcYuvOrg->getAddr(compID),
     4527                                               pcYuvOrg->getStride(compID), cuWidthPixels >> csx, cuHeightPixels >> csy, compID);
    45364528    }
    45374529
     
    45474539    m_pcEntropyCoder->encodeMergeIndex( pcCU, 0, true );
    45484540
    4549     uiBits = m_pcEntropyCoder->getNumberOfWrittenBits();
     4541    UInt uiBits = m_pcEntropyCoder->getNumberOfWrittenBits();
    45504542    pcCU->getTotalBits()       = uiBits;
    4551     pcCU->getTotalDistortion() = uiDistortion;
    4552     pcCU->getTotalCost()       = m_pcRdCost->calcRdCost( uiBits, uiDistortion );
     4543    pcCU->getTotalDistortion() = distortion;
     4544    pcCU->getTotalCost()       = m_pcRdCost->calcRdCost( uiBits, distortion );
    45534545
    45544546    m_pcRDGoOnSbacCoder->store(m_pppcRDSbacCoder[pcCU->getDepth(0)][CI_TEMP_BEST]);
    4555 
    4556     static const UInt cbfZero[MAX_NUM_COMPONENT]={0,0,0};
    4557     pcCU->setCbfSubParts( cbfZero, 0, pcCU->getDepth( 0 ) );
    4558     pcCU->setTrIdxSubParts( 0, 0, pcCU->getDepth(0) );
    45594547
    45604548#ifdef DEBUG_STRING
     
    45704558
    45714559  //  Residual coding.
    4572   Int qp;
    4573   Int qpBest = 0;
    4574   Int qpMin;
    4575   Int qpMax;
    4576   Double  dCost, dCostBest = MAX_DOUBLE;
    4577 
    4578   UInt uiTrLevel = 0;
    4579   if( (pcCU->getWidth(0) > pcCU->getSlice()->getSPS()->getMaxTrSize()) )
    4580   {
    4581     while( pcCU->getWidth(0) > (pcCU->getSlice()->getSPS()->getMaxTrSize()<<uiTrLevel) )
    4582     {
    4583       uiTrLevel++;
    4584     }
    4585   }
    4586 
    4587   // TODO: there should be a check on the CU depth (but see to-do below regarding this feature) eg:
    4588   // bHighPass = (bHighPass && pcCU->getDepth(0) <= pcCU->getSlice()->getPPS()->getMaxCuDQPDepth());
    4589 #if SVC_EXTENSION
    4590   qpMin =  bHighPass ? Clip3( -pcCU->getSlice()->getQpBDOffsetY(), MAX_QP, pcCU->getQP(0) - m_iMaxDeltaQP ) : pcCU->getQP( 0 );
    4591   qpMax =  bHighPass ? Clip3( -pcCU->getSlice()->getQpBDOffsetY(), MAX_QP, pcCU->getQP(0) + m_iMaxDeltaQP ) : pcCU->getQP( 0 );
    4592 #else
    4593   qpMin =  bHighPass ? Clip3( -pcCU->getSlice()->getSPS()->getQpBDOffset(CHANNEL_TYPE_LUMA), MAX_QP, pcCU->getQP(0) - m_iMaxDeltaQP ) : pcCU->getQP( 0 );
    4594   qpMax =  bHighPass ? Clip3( -pcCU->getSlice()->getSPS()->getQpBDOffset(CHANNEL_TYPE_LUMA), MAX_QP, pcCU->getQP(0) + m_iMaxDeltaQP ) : pcCU->getQP( 0 );
    4595 #endif
    4596 
    4597   pcYuvResi->subtract( pcYuvOrg, pcYuvPred, 0, uiWidth );
     4560
     4561   pcYuvResi->subtract( pcYuvOrg, pcYuvPred, 0, cuWidthPixels );
    45984562
    45994563  TComTURecurse tuLevel0(pcCU, 0);
    46004564
    4601   for ( qp = qpMin; qp <= qpMax; qp++ ) // TODO: see the to-do below about this loop.
    4602   {
    4603     dCost = 0.;
    4604     uiBits = 0;
    4605     uiDistortion = 0;
    4606 
    4607     // TODO: see the to-do below. eg:
    4608     //if (qpMin != qpMax)
    4609     //{
    4610     //  pcCU->setQPSubParts(qp, 0, pcCU->getDepth(0));
    4611     //  pcCU->setSkipFlagSubParts(false, 0, pcCU->getDepth(0));
    4612     //}
    4613 
    4614     m_pcRDGoOnSbacCoder->load( m_pppcRDSbacCoder[ pcCU->getDepth( 0 ) ][ CI_CURR_BEST ] );
    4615 
    4616     Distortion uiZeroDistortion = 0;
    4617 
    4618     xEstimateResidualQT( pcYuvResi,  dCost, uiBits, uiDistortion, &uiZeroDistortion, tuLevel0 DEBUG_STRING_PASS_INTO(sDebug) );
    4619 
    4620     // -------------------------------------------------------
    4621     // set the coefficients in the pcCU, and also calculates the residual data.
    4622     // If a block full of 0's is efficient, then just use 0's.
    4623     // The costs at this point do not include header bits.
    4624 
    4625     m_pcEntropyCoder->resetBits();
    4626     m_pcEntropyCoder->encodeQtRootCbfZero( pcCU );
    4627     UInt zeroResiBits = m_pcEntropyCoder->getNumberOfWrittenBits();
    4628     Double dZeroCost = m_pcRdCost->calcRdCost( zeroResiBits, uiZeroDistortion );
    4629 
    4630     if(pcCU->isLosslessCoded( 0 ))
    4631     {
    4632       dZeroCost = dCost + 1;
    4633     }
    4634 
    4635     const Bool bRootCbf=pcCU->getQtRootCbf(0)!=0;
    4636     if ( dZeroCost < dCost || !bRootCbf )
    4637     {
    4638       if ( dZeroCost < dCost )
    4639       {
    4640         dCost        = dZeroCost;
    4641       }
    4642       uiDistortion = uiZeroDistortion;
    4643 
    4644       const UInt uiQPartNum = tuLevel0.GetAbsPartIdxNumParts();
    4645       ::memset( pcCU->getTransformIdx()     , 0, uiQPartNum * sizeof(UChar) );
    4646       for (UInt ch=0; ch < pcCU->getPic()->getNumberValidComponents(); ch++)
    4647       {
    4648         const ComponentID component = ComponentID(ch);
    4649         ::memset( pcCU->getCbf( component ) , 0, uiQPartNum * sizeof(UChar) );
    4650         if (qpMin != qpMax) // If there is only one iteration, then these will already be 0.
    4651         {
    4652           const UInt componentShift   = pcCU->getPic()->getComponentScaleX(component) + pcCU->getPic()->getComponentScaleY(component);
    4653           ::memset( pcCU->getCoeff(component), 0, (uiWidth*uiHeight*sizeof(TCoeff))>>componentShift );
    4654 #if ADAPTIVE_QP_SELECTION
    4655           ::memset( pcCU->getArlCoeff(component), 0, (uiWidth*uiHeight*sizeof(TCoeff))>>componentShift );
    4656 #endif
    4657         }
    4658         ::memset( pcCU->getCrossComponentPredictionAlpha(component), 0, ( uiQPartNum * sizeof(Char) ) );
    4659       }
    4660       static const UInt useTS[MAX_NUM_COMPONENT]={0,0,0};
    4661       pcCU->setTransformSkipSubParts ( useTS, 0, pcCU->getDepth(0) );
     4565  Double     nonZeroCost       = 0;
     4566  UInt       nonZeroBits       = 0;
     4567  Distortion nonZeroDistortion = 0;
     4568  Distortion zeroDistortion    = 0;
     4569
     4570  m_pcRDGoOnSbacCoder->load( m_pppcRDSbacCoder[ pcCU->getDepth( 0 ) ][ CI_CURR_BEST ] );
     4571
     4572  xEstimateInterResidualQT( pcYuvResi,  nonZeroCost, nonZeroBits, nonZeroDistortion, &zeroDistortion, tuLevel0 DEBUG_STRING_PASS_INTO(sDebug) );
     4573
     4574  // -------------------------------------------------------
     4575  // set the coefficients in the pcCU, and also calculates the residual data.
     4576  // If a block full of 0's is efficient, then just use 0's.
     4577  // The costs at this point do not include header bits.
     4578
     4579  m_pcEntropyCoder->resetBits();
     4580  m_pcEntropyCoder->encodeQtRootCbfZero( pcCU );
     4581  const UInt   zeroResiBits = m_pcEntropyCoder->getNumberOfWrittenBits();
     4582  const Double zeroCost     = (pcCU->isLosslessCoded( 0 )) ? (nonZeroCost+1) : (m_pcRdCost->calcRdCost( zeroResiBits, zeroDistortion ));
     4583
     4584  if ( zeroCost < nonZeroCost || !pcCU->getQtRootCbf(0) )
     4585  {
     4586    const UInt uiQPartNum = tuLevel0.GetAbsPartIdxNumParts();
     4587    ::memset( pcCU->getTransformIdx()     , 0, uiQPartNum * sizeof(UChar) );
     4588    for (Int comp=0; comp < numValidComponents; comp++)
     4589    {
     4590      const ComponentID component = ComponentID(comp);
     4591      ::memset( pcCU->getCbf( component ) , 0, uiQPartNum * sizeof(UChar) );
     4592      ::memset( pcCU->getCrossComponentPredictionAlpha(component), 0, ( uiQPartNum * sizeof(Char) ) );
     4593    }
     4594    static const UInt useTS[MAX_NUM_COMPONENT]={0,0,0};
     4595    pcCU->setTransformSkipSubParts ( useTS, 0, pcCU->getDepth(0) );
    46624596#ifdef DEBUG_STRING
    4663       sDebug.clear();
    4664       for(UInt i=0; i<MAX_NUM_COMPONENT+1; i++)
    4665       {
    4666         sDebug+=debug_reorder_data_inter_token[i];
    4667       }
    4668 #endif
    4669     }
    4670     else
    4671     {
    4672       xSetResidualQTData( NULL, false, tuLevel0); // Call first time to set coefficients.
    4673     }
    4674 
    4675     m_pcRDGoOnSbacCoder->load( m_pppcRDSbacCoder[pcCU->getDepth(0)][CI_CURR_BEST] );
    4676 
    4677     uiBits = 0;
    4678     xAddSymbolBitsInter( pcCU, 0, 0, uiBits );
    4679     // we've now encoded the pcCU, and so have a valid bit cost
    4680 
    4681 
    4682     Double dExactCost = m_pcRdCost->calcRdCost( uiBits, uiDistortion );
    4683     dCost = dExactCost;
    4684 
    4685     // Is our new cost better?
    4686     if ( dCost < dCostBest )
    4687     {
    4688       if ( !pcCU->getQtRootCbf( 0 ) )
    4689       {
    4690         pcYuvResiBest->clear(); // Clear the residual image, if we didn't code it.
    4691       }
    4692       else
    4693       {
    4694         xSetResidualQTData( pcYuvResiBest, true, tuLevel0 ); // else set the residual image data pcYUVResiBest from the various temp images.
    4695       }
    4696 
    4697       if( qpMin != qpMax && qp != qpMax )
    4698       {
    4699         const UInt uiQPartNum = tuLevel0.GetAbsPartIdxNumParts();
    4700         ::memcpy( m_puhQTTempTrIdx, pcCU->getTransformIdx(),        uiQPartNum * sizeof(UChar) );
    4701         for(UInt i=0; i<pcCU->getPic()->getNumberValidComponents(); i++)
    4702         {
    4703           const ComponentID compID=ComponentID(i);
    4704           const UInt csr = pcCU->getPic()->getComponentScaleX(compID) + pcCU->getPic()->getComponentScaleY(compID);
    4705           ::memcpy( m_puhQTTempCbf[compID],      pcCU->getCbf( compID ),     uiQPartNum * sizeof(UChar) );
    4706           ::memcpy( m_pcQTTempCoeff[compID],     pcCU->getCoeff(compID),     uiWidth * uiHeight * sizeof( TCoeff ) >> csr     );
    4707 #if ADAPTIVE_QP_SELECTION
    4708           ::memcpy( m_pcQTTempArlCoeff[compID],  pcCU->getArlCoeff(compID),  uiWidth * uiHeight * sizeof( TCoeff )>> csr     );
    4709 #endif
    4710           ::memcpy( m_puhQTTempTransformSkipFlag[compID], pcCU->getTransformSkip(compID),     uiQPartNum * sizeof( UChar ) );
    4711           ::memcpy( m_phQTTempCrossComponentPredictionAlpha[compID], pcCU->getCrossComponentPredictionAlpha(compID), uiQPartNum * sizeof(Char) );
    4712         }
    4713       }
    4714       uiBitsBest       = uiBits;
    4715       uiDistortionBest = uiDistortion;
    4716       dCostBest        = dCost;
    4717       qpBest           = qp;
    4718 
    4719       m_pcRDGoOnSbacCoder->store( m_pppcRDSbacCoder[ pcCU->getDepth( 0 ) ][ CI_TEMP_BEST ] );
    4720     }
    4721   }
    4722 
    4723   assert ( dCostBest != MAX_DOUBLE );
    4724 
    4725   if( qpMin != qpMax && qpBest != qpMax )
    4726   {
    4727     // TODO: this code has never been used, the qp doesn't change the QP coded, and the following assert prevented this code running.
    4728     //        also, skip flag got stuck-on, as nothing cleared it. Recommend removing this.
    4729     assert( 0 ); // check
    4730     m_pcRDGoOnSbacCoder->load( m_pppcRDSbacCoder[ pcCU->getDepth( 0 ) ][ CI_TEMP_BEST ] );
    4731 
    4732       // copy best cbf and trIdx to pcCU
    4733     const UInt uiQPartNum = tuLevel0.GetAbsPartIdxNumParts();
    4734     ::memcpy( pcCU->getTransformIdx(),       m_puhQTTempTrIdx,  uiQPartNum * sizeof(UChar) );
    4735     for(UInt i=0; i<pcCU->getPic()->getNumberValidComponents(); i++)
    4736     {
    4737       const ComponentID compID=ComponentID(i);
    4738       const UInt csr = pcCU->getPic()->getComponentScaleX(compID) + pcCU->getPic()->getComponentScaleY(compID);
    4739       ::memcpy( pcCU->getCbf( compID ),     m_puhQTTempCbf[compID],     uiQPartNum * sizeof(UChar) );
    4740       ::memcpy( pcCU->getCoeff(compID),     m_pcQTTempCoeff[compID],    uiWidth * uiHeight * sizeof( TCoeff ) >> csr     );
    4741 #if ADAPTIVE_QP_SELECTION
    4742       ::memcpy( pcCU->getArlCoeff(compID),  m_pcQTTempArlCoeff[compID], uiWidth * uiHeight * sizeof( TCoeff    ) >> csr );
    4743 #endif
    4744       ::memcpy( pcCU->getTransformSkip(compID),     m_puhQTTempTransformSkipFlag[compID], uiQPartNum * sizeof( UChar ) );
    4745       ::memcpy( pcCU->getCrossComponentPredictionAlpha(compID),  m_phQTTempCrossComponentPredictionAlpha[compID], uiQPartNum * sizeof( Char ) );
    4746     }
    4747     // TODO: see to-do above. eg:
    4748     // pcCU->setSkipFlagSubParts(  (pcCU->getMergeFlag( 0 ) && pcCU->getPartitionSize( 0 ) == SIZE_2Nx2N && !pcCU->getQtRootCbf( 0 )), 0, pcCU->getDepth(0) );
    4749   }
    4750   pcYuvRec->addClip ( pcYuvPred, pcYuvResiBest, 0, uiWidth );
    4751 
    4752   // update with clipped distortion and cost (qp estimation loop uses unclipped values)
    4753 
    4754   uiDistortionBest = 0;
    4755   for(UInt ch=0; ch<pcYuvRec->getNumberValidComponents(); ch++)
    4756   {
    4757     const ComponentID compID=ComponentID(ch);
    4758     uiDistortionBest += m_pcRdCost->getDistPart( g_bitDepth[toChannelType(compID)], pcYuvRec->getAddr(compID ), pcYuvRec->getStride(compID ), pcYuvOrg->getAddr(compID ), pcYuvOrg->getStride(compID), uiWidth >> pcYuvOrg->getComponentScaleX(compID), uiHeight >> pcYuvOrg->getComponentScaleY(compID), compID);
    4759   }
    4760   dCostBest = m_pcRdCost->calcRdCost( uiBitsBest, uiDistortionBest );
    4761 
    4762   pcCU->getTotalBits()       = uiBitsBest;
    4763   pcCU->getTotalDistortion() = uiDistortionBest;
    4764   pcCU->getTotalCost()       = dCostBest;
    4765 
    4766   if( qpMin != qpMax) // TODO: see to-do above
    4767   {
    4768     pcCU->setQPSubParts( qpBest, 0, pcCU->getDepth(0) );
    4769   }
     4597    sDebug.clear();
     4598    for(UInt i=0; i<MAX_NUM_COMPONENT+1; i++)
     4599    {
     4600      sDebug+=debug_reorder_data_inter_token[i];
     4601    }
     4602#endif
     4603  }
     4604  else
     4605  {
     4606    xSetInterResidualQTData( NULL, false, tuLevel0); // Call first time to set coefficients.
     4607  }
     4608
     4609  // all decisions now made. Fully encode the CU, including the headers:
     4610  m_pcRDGoOnSbacCoder->load( m_pppcRDSbacCoder[pcCU->getDepth(0)][CI_CURR_BEST] );
     4611
     4612  UInt finalBits = 0;
     4613  xAddSymbolBitsInter( pcCU, 0, 0, finalBits );
     4614  // we've now encoded the pcCU, and so have a valid bit cost
     4615
     4616  if ( !pcCU->getQtRootCbf( 0 ) )
     4617  {
     4618    pcYuvResiBest->clear(); // Clear the residual image, if we didn't code it.
     4619  }
     4620  else
     4621  {
     4622    xSetInterResidualQTData( pcYuvResiBest, true, tuLevel0 ); // else set the residual image data pcYUVResiBest from the various temp images.
     4623  }
     4624  m_pcRDGoOnSbacCoder->store( m_pppcRDSbacCoder[ pcCU->getDepth( 0 ) ][ CI_TEMP_BEST ] );
     4625
     4626  pcYuvRec->addClip ( pcYuvPred, pcYuvResiBest, 0, cuWidthPixels );
     4627
     4628  // update with clipped distortion and cost (previously unclipped reconstruction values were used)
     4629
     4630  Distortion finalDistortion = 0;
     4631  for(Int comp=0; comp<numValidComponents; comp++)
     4632  {
     4633    const ComponentID compID=ComponentID(comp);
     4634    finalDistortion += m_pcRdCost->getDistPart( g_bitDepth[toChannelType(compID)], pcYuvRec->getAddr(compID ), pcYuvRec->getStride(compID ), pcYuvOrg->getAddr(compID ), pcYuvOrg->getStride(compID), cuWidthPixels >> pcYuvOrg->getComponentScaleX(compID), cuHeightPixels >> pcYuvOrg->getComponentScaleY(compID), compID);
     4635  }
     4636
     4637  pcCU->getTotalBits()       = finalBits;
     4638  pcCU->getTotalDistortion() = finalDistortion;
     4639  pcCU->getTotalCost()       = m_pcRdCost->calcRdCost( finalBits, finalDistortion );
    47704640}
    47714641
    47724642
    47734643
    4774 Void TEncSearch::xEstimateResidualQT( TComYuv    *pcResi,
    4775                                       Double     &rdCost,
    4776                                       UInt       &ruiBits,
    4777                                       Distortion &ruiDist,
    4778                                       Distortion *puiZeroDist,
    4779                                       TComTU     &rTu
    4780                                       DEBUG_STRING_FN_DECLARE(sDebug) )
     4644Void TEncSearch::xEstimateInterResidualQT( TComYuv    *pcResi,
     4645                                           Double     &rdCost,
     4646                                           UInt       &ruiBits,
     4647                                           Distortion &ruiDist,
     4648                                           Distortion *puiZeroDist,
     4649                                           TComTU     &rTu
     4650                                           DEBUG_STRING_FN_DECLARE(sDebug) )
    47814651{
    47824652  TComDataCU *pcCU        = rTu.getCU();
     
    52795149    {
    52805150      DEBUG_STRING_NEW(childString)
    5281       xEstimateResidualQT( pcResi, dSubdivCost, uiSubdivBits, uiSubdivDist, bCheckFull ? NULL : puiZeroDist,  tuRecurseChild DEBUG_STRING_PASS_INTO(childString));
     5151      xEstimateInterResidualQT( pcResi, dSubdivCost, uiSubdivBits, uiSubdivDist, bCheckFull ? NULL : puiZeroDist,  tuRecurseChild DEBUG_STRING_PASS_INTO(childString));
    52825152#ifdef DEBUG_STRING
    52835153      // split the string by component and append to the relevant output (because decoder decodes in channel order, whereas this search searches by TU-order)
     
    53225192
    53235193    // when compID isn't a channel, code Cbfs:
    5324     xEncodeResidualQT( MAX_NUM_COMPONENT, rTu );
     5194    xEncodeInterResidualQT( MAX_NUM_COMPONENT, rTu );
    53255195    for(UInt ch = 0; ch < numValidComp; ch++)
    53265196    {
    5327       xEncodeResidualQT( ComponentID(ch), rTu );
     5197      xEncodeInterResidualQT( ComponentID(ch), rTu );
    53285198    }
    53295199
     
    54145284
    54155285
    5416 Void TEncSearch::xEncodeResidualQT( const ComponentID compID, TComTU &rTu )
     5286Void TEncSearch::xEncodeInterResidualQT( const ComponentID compID, TComTU &rTu )
    54175287{
    54185288  TComDataCU* pcCU=rTu.getCU();
     
    54865356      do
    54875357      {
    5488         xEncodeResidualQT( compID, tuRecurseChild );
     5358        xEncodeInterResidualQT( compID, tuRecurseChild );
    54895359      } while (tuRecurseChild.nextSection(rTu));
    54905360    }
     
    54955365
    54965366
    5497 Void TEncSearch::xSetResidualQTData( TComYuv* pcResi, Bool bSpatial, TComTU &rTu ) // TODO: turn this into two functions for bSpatial=true and false.
     5367Void TEncSearch::xSetInterResidualQTData( TComYuv* pcResi, Bool bSpatial, TComTU &rTu ) // TODO: turn this into two functions for bSpatial=true and false.
    54985368{
    54995369  TComDataCU* pcCU=rTu.getCU();
     
    55525422    do
    55535423    {
    5554       xSetResidualQTData( pcResi, bSpatial, tuRecurseChild );
     5424      xSetInterResidualQTData( pcResi, bSpatial, tuRecurseChild );
    55555425    } while (tuRecurseChild.nextSection(rTu));
    55565426  }
  • branches/SHM-dev/source/Lib/TLibEncoder/TEncSearch.h

    r1243 r1249  
    116116  Pel*            m_pTempPel;
    117117  const UInt*     m_puiDFilter;
    118   Int             m_iMaxDeltaQP;
    119118
    120119  // AMVP cost computation
     
    139138            Int           bipredSearchRange,
    140139            Int           iFastSearch,
    141             Int           iMaxDeltaQP,
    142140            TEncEntropy*  pcEntropyCoder,
    143141            TComRdCost*   pcRdCost,
     
    214212                                  TComYuv*    pcYuvResiBest,
    215213                                  TComYuv*    pcYuvRec,
    216                                   Bool        bSkipRes
     214                                  Bool        bSkipResidual
    217215                                  DEBUG_STRING_FN_DECLARE(sDebug) );
    218216
     
    459457
    460458
    461   Void xEncodeResidualQT( const ComponentID compID, TComTU &rTu );
    462   Void xEstimateResidualQT( TComYuv* pcResi, Double &rdCost, UInt &ruiBits, Distortion &ruiDist, Distortion *puiZeroDist, TComTU &rTu DEBUG_STRING_FN_DECLARE(sDebug) );
    463   Void xSetResidualQTData( TComYuv* pcResi, Bool bSpatial, TComTU &rTu  );
     459  Void xEncodeInterResidualQT( const ComponentID compID, TComTU &rTu );
     460  Void xEstimateInterResidualQT( TComYuv* pcResi, Double &rdCost, UInt &ruiBits, Distortion &ruiDist, Distortion *puiZeroDist, TComTU &rTu DEBUG_STRING_FN_DECLARE(sDebug) );
     461  Void xSetInterResidualQTData( TComYuv* pcResi, Bool bSpatial, TComTU &rTu  );
    464462
    465463  UInt  xModeBitsIntra ( TComDataCU* pcCU, UInt uiMode, UInt uiPartOffset, UInt uiDepth, UInt uiInitTrDepth, const ChannelType compID );
  • branches/SHM-dev/source/Lib/TLibEncoder/TEncTop.cpp

    r1246 r1249  
    258258
    259259  // initialize encoder search class
    260   m_cSearch.init( this, &m_cTrQuant, m_iSearchRange, m_bipredSearchRange, m_iFastSearch, 0, &m_cEntropyCoder, &m_cRdCost, getRDSbacCoder(), getRDGoOnSbacCoder() );
     260  m_cSearch.init( this, &m_cTrQuant, m_iSearchRange, m_bipredSearchRange, m_iFastSearch, &m_cEntropyCoder, &m_cRdCost, getRDSbacCoder(), getRDGoOnSbacCoder() );
    261261
    262262  m_iMaxRefPicNum = 0;
     
    679679
    680680  TComSlice::sortPicList(m_cListPic);
     681
    681682
    682683  if (m_cListPic.size() >= (UInt)(m_iGOPSize + getMaxDecPicBuffering(MAX_TLAYER-1) + 2) )
     
    11041105  m_cPPS.setLoopFilterAcrossSlicesEnabledFlag( m_bLFCrossSliceBoundaryFlag );
    11051106
     1107
    11061108  Int histogram[MAX_NUM_REF + 1];
    11071109  for( Int i = 0; i <= MAX_NUM_REF; i++ )
Note: See TracChangeset for help on using the changeset viewer.