Changeset 998 in 3DVCSoftware


Ignore:
Timestamp:
18 Jul 2014, 05:19:45 (11 years ago)
Author:
sharpjp-htm
Message:

Integration of I0109

Location:
branches/HTM-11.2-dev1-Sharp
Files:
3 added
6 edited

Legend:

Unmodified
Added
Removed
  • branches/HTM-11.2-dev1-Sharp/source/Lib/TLibCommon/TComPrediction.cpp

    r976 r998  
    790790}
    791791
     792#if SHARP_DBBP_SIMPLE_FLTER_I0109
     793Void TComPrediction::combineSegmentsWithMask( TComYuv* pInYuv[2], TComYuv* pOutYuv, Bool* pMask, UInt uiWidth, UInt uiHeight, UInt uiPartAddr, UInt partSize )
     794#else
    792795Void TComPrediction::combineSegmentsWithMask( TComYuv* pInYuv[2], TComYuv* pOutYuv, Bool* pMask, UInt uiWidth, UInt uiHeight, UInt uiPartAddr )
     796#endif
    793797{
    794798  Pel*  piSrc[2]    = {pInYuv[0]->getLumaAddr(uiPartAddr), pInYuv[1]->getLumaAddr(uiPartAddr)};
     
    798802 
    799803  UInt  uiMaskStride= MAX_CU_SIZE;
     804#if !SHARP_DBBP_SIMPLE_FLTER_I0109
    800805  Pel  filSrc = 0;
     806#endif
    801807  Pel* tmpTar = 0;
    802808  tmpTar = (Pel *)xMalloc(Pel, uiWidth*uiHeight);
     
    821827    pMask     += uiMaskStride;
    822828  }
    823  
     829
     830#if SHARP_DBBP_SIMPLE_FLTER_I0109
     831  if (partSize == SIZE_Nx2N)
     832  {
     833    for (Int y=0; y<uiHeight; y++)
     834    {
     835      for (Int x=0; x<uiWidth; x++)
     836      {
     837        Bool l = (x==0)?pMaskStart[y*uiMaskStride+x]:pMaskStart[y*uiMaskStride+x-1];
     838        Bool r = (x==uiWidth-1)?pMaskStart[y*uiMaskStride+x]:pMaskStart[y*uiMaskStride+x+1];
     839       
     840        Pel left, right;
     841        left   = (x==0)          ? tmpTar[y*uiWidth+x] : tmpTar[y*uiWidth+x-1];
     842        right  = (x==uiWidth-1)  ? tmpTar[y*uiWidth+x] : tmpTar[y*uiWidth+x+1];
     843       
     844        piDst[x] = (l!=r) ? Clip3( Pel( 0 ), Pel( 255 ), Pel(( left + (tmpTar[y*uiWidth+x] << 1) + right ) >> 2 )) : tmpTar[y*uiWidth+x];
     845      }
     846      piDst     += uiDstStride;
     847    }
     848  }
     849  else // SIZE_2NxN
     850  {
     851    for (Int y=0; y<uiHeight; y++)
     852    {
     853      for (Int x=0; x<uiWidth; x++)
     854      {
     855        Bool t = (y==0)?pMaskStart[y*uiMaskStride+x]:pMaskStart[(y-1)*uiMaskStride+x];
     856        Bool b = (y==uiHeight-1)?pMaskStart[y*uiMaskStride+x]:pMaskStart[(y+1)*uiMaskStride+x];
     857       
     858        Pel top, bottom;
     859        top    = (y==0)          ? tmpTar[y*uiWidth+x] : tmpTar[(y-1)*uiWidth+x];
     860        bottom = (y==uiHeight-1) ? tmpTar[y*uiWidth+x] : tmpTar[(y+1)*uiWidth+x];
     861       
     862        piDst[x] = (t!=b) ? Clip3( Pel( 0 ), Pel( 255 ), Pel(( top + (tmpTar[y*uiWidth+x] << 1) + bottom ) >> 2 )) : tmpTar[y*uiWidth+x];
     863      }
     864      piDst     += uiDstStride;
     865    }
     866  }
     867#else
    824868  for (Int y=0; y<uiHeight; y++)
    825869  {
     
    855899    piDst     += uiDstStride;
    856900  }
     901#endif
     902
    857903  if ( tmpTar    ) { xFree(tmpTar);             tmpTar        = NULL; }
    858904 
     
    890936    pMask       += 2*uiMaskStride;
    891937  }
    892 
     938 
     939#if SHARP_DBBP_SIMPLE_FLTER_I0109
     940  if (partSize == SIZE_Nx2N)
     941  {
     942    for (Int y=0; y<uiHeightC; y++)
     943    {
     944      for (Int x=0; x<uiWidthC; x++)
     945      {
     946        Bool l = (x==0)?pMaskStart[y*2*uiMaskStride+x*2]:pMaskStart[y*2*uiMaskStride+(x-1)*2];
     947        Bool r = (x==uiWidthC-1)?pMaskStart[y*2*uiMaskStride+x*2]:pMaskStart[y*2*uiMaskStride+(x+1)*2];
     948
     949        Pel leftU, rightU;
     950        leftU   = (x==0)           ? tmpTarU[y*uiWidthC+x] : tmpTarU[y*uiWidthC+x-1];
     951        rightU  = (x==uiWidthC-1)  ? tmpTarU[y*uiWidthC+x] : tmpTarU[y*uiWidthC+x+1];
     952        Pel leftV, rightV;
     953        leftV   = (x==0)           ? tmpTarV[y*uiWidthC+x] : tmpTarV[y*uiWidthC+x-1];
     954        rightV  = (x==uiWidthC-1)  ? tmpTarV[y*uiWidthC+x] : tmpTarV[y*uiWidthC+x+1];
     955
     956        if (l!=r)
     957        {
     958          filSrcU = Clip3( Pel( 0 ), Pel( 255 ), Pel(( leftU + (tmpTarU[y*uiWidthC+x] << 1) + rightU ) >> 2 ));
     959          filSrcV = Clip3( Pel( 0 ), Pel( 255 ), Pel(( leftV + (tmpTarV[y*uiWidthC+x] << 1) + rightV ) >> 2 ));
     960        }
     961        else
     962        {
     963          filSrcU = tmpTarU[y*uiWidthC+x];
     964          filSrcV = tmpTarV[y*uiWidthC+x];
     965        }
     966        piDstU[x] = filSrcU;
     967        piDstV[x] = filSrcV;
     968      }
     969      piDstU      += uiDstStrideC;
     970      piDstV      += uiDstStrideC;
     971    }
     972  }
     973  else
     974  {
     975    for (Int y=0; y<uiHeightC; y++)
     976    {
     977      for (Int x=0; x<uiWidthC; x++)
     978      {
     979        Bool t = (y==0)?pMaskStart[y*2*uiMaskStride+x*2]:pMaskStart[(y-1)*2*uiMaskStride+x*2];
     980        Bool b = (y==uiHeightC-1)?pMaskStart[y*2*uiMaskStride+x*2]:pMaskStart[(y+1)*2*uiMaskStride+x*2];
     981
     982        Pel topU, bottomU;
     983        topU    = (y==0)           ? tmpTarU[y*uiWidthC+x] : tmpTarU[(y-1)*uiWidthC+x];
     984        bottomU = (y==uiHeightC-1) ? tmpTarU[y*uiWidthC+x] : tmpTarU[(y+1)*uiWidthC+x];
     985        Pel topV, bottomV;
     986        topV    = (y==0)           ? tmpTarV[y*uiWidthC+x] : tmpTarV[(y-1)*uiWidthC+x];
     987        bottomV = (y==uiHeightC-1) ? tmpTarV[y*uiWidthC+x] : tmpTarV[(y+1)*uiWidthC+x];
     988
     989        if (t!=b)
     990        {
     991          filSrcU = Clip3( Pel( 0 ), Pel( 255 ), Pel(( topU + (tmpTarU[y*uiWidthC+x] << 1) + bottomU ) >> 2 ));
     992          filSrcV = Clip3( Pel( 0 ), Pel( 255 ), Pel(( topV + (tmpTarV[y*uiWidthC+x] << 1) + bottomV ) >> 2 ));
     993        }
     994        else
     995        {
     996          filSrcU = tmpTarU[y*uiWidthC+x];
     997          filSrcV = tmpTarV[y*uiWidthC+x];
     998        }
     999        piDstU[x] = filSrcU;
     1000        piDstV[x] = filSrcV;
     1001      }
     1002      piDstU      += uiDstStrideC;
     1003      piDstV      += uiDstStrideC;
     1004    }
     1005  }
     1006#else
    8931007  for (Int y=0; y<uiHeightC; y++)
    8941008  {
     
    9361050    piDstV      += uiDstStrideC;
    9371051  }
     1052#endif
    9381053  if ( tmpTarU    ) { xFree(tmpTarU);             tmpTarU        = NULL; }
    9391054  if ( tmpTarV    ) { xFree(tmpTarV);             tmpTarV        = NULL; }
  • branches/HTM-11.2-dev1-Sharp/source/Lib/TLibCommon/TComPrediction.h

    r884 r998  
    176176  PartSize      getPartitionSizeFromDepth(Pel* pDepthPels, UInt uiDepthStride, UInt uiSize);
    177177  Bool          getSegmentMaskFromDepth( Pel* pDepthPels, UInt uiDepthStride, UInt uiWidth, UInt uiHeight, Bool* pMask );
     178#if SHARP_DBBP_SIMPLE_FLTER_I0109
     179  Void          combineSegmentsWithMask( TComYuv* pInYuv[2], TComYuv* pOutYuv, Bool* pMask, UInt uiWidth, UInt uiHeight, UInt uiPartAddr, UInt partSize );
     180#else
    178181  Void          combineSegmentsWithMask( TComYuv* pInYuv[2], TComYuv* pOutYuv, Bool* pMask, UInt uiWidth, UInt uiHeight, UInt uiPartAddr = 0 );
     182#endif
    179183#endif
    180184
  • branches/HTM-11.2-dev1-Sharp/source/Lib/TLibCommon/TypeDef.h

    r991 r998  
    237237#define SEC_DBBP_EXPLICIT_SIG_I0077       1   // Remove the partition derivation and signal dbbp_flag only when the partion mode is 2NxN/Nx2N, JCT3V-I0077
    238238#define SEC_DBBP_DISALLOW_8x8_I0078       1   // Disallow DBBP in 8x8 CU, JCT3V-I0078
     239#define SHARP_DBBP_SIMPLE_FLTER_I0109     1   // Simple condition and one dimensional dilter for DBBP
    239240
    240241#define H_3D_DDD                          1   // Disparity derived depth coding
  • branches/HTM-11.2-dev1-Sharp/source/Lib/TLibDecoder/TDecCu.cpp

    r976 r998  
    832832 
    833833  // reconstruct final prediction signal by combining both segments
     834#if SHARP_DBBP_SIMPLE_FLTER_I0109
     835  m_pcPrediction->combineSegmentsWithMask(apSegPredYuv, m_ppcYuvReco[uiDepth], pMask, pcCU->getWidth(0), pcCU->getHeight(0), 0, ePartSize);
     836#else
    834837  m_pcPrediction->combineSegmentsWithMask(apSegPredYuv, m_ppcYuvReco[uiDepth], pMask, pcCU->getWidth(0), pcCU->getHeight(0));
     838#endif
    835839 
    836840  // inter recon
  • branches/HTM-11.2-dev1-Sharp/source/Lib/TLibEncoder/TEncCu.cpp

    r991 r998  
    24452445 
    24462446  // reconstruct final prediction signal by combining both segments
     2447#if SHARP_DBBP_SIMPLE_FLTER_I0109
     2448  m_pcPredSearch->combineSegmentsWithMask(apPredYuv, m_ppcPredYuvTemp[uhDepth], pMask, uiWidth, uiHeight, 0, eVirtualPartSize);
     2449#else
    24472450  m_pcPredSearch->combineSegmentsWithMask(apPredYuv, m_ppcPredYuvTemp[uhDepth], pMask, uiWidth, uiHeight);
     2451#endif
    24482452 
    24492453  m_pcPredSearch->encodeResAndCalcRdInterCU( rpcTempCU, m_ppcOrigYuv[uhDepth], m_ppcPredYuvTemp[uhDepth], m_ppcResiYuvTemp[uhDepth], m_ppcResiYuvBest[uhDepth], m_ppcRecoYuvTemp[uhDepth], false );
Note: See TracChangeset for help on using the changeset viewer.