HEVC MarginX MarginY getBuf() getAddr()

转载https://blog.csdn.net/rankling315/article/details/54707841

如上图所示,以亮度信号为例,解释了内存中扩展图像和原始图像之间的存储关系,以及计算关系,图像存储一份,色度信号与之类似。

[cpp]  view plain  copy
  1. Void TComPicYuv::create( Int iPicWidth, Int iPicHeight, UInt uiMaxCUWidth, UInt uiMaxCUHeight, UInt uiMaxCUDepth )  
  2. {  
  3.   m_iPicWidth       = iPicWidth;  
  4.   m_iPicHeight      = iPicHeight;  
  5.     
  6.   // --> After config finished!  
  7.   m_iCuWidth        = uiMaxCUWidth;  
  8.   m_iCuHeight       = uiMaxCUHeight;  
  9.   
  10.   Int numCuInWidth  = m_iPicWidth  / m_iCuWidth  + (m_iPicWidth  % m_iCuWidth  != 0);  
  11.   Int numCuInHeight = m_iPicHeight / m_iCuHeight + (m_iPicHeight % m_iCuHeight != 0);  
  12.     
  13.   m_iLumaMarginX    = g_uiMaxCUWidth  + 16; // for 16-byte alignment  
  14.   m_iLumaMarginY    = g_uiMaxCUHeight + 16;  // margin for 8-tap filter and infinite padding  
  15.     
  16.   m_iChromaMarginX  = m_iLumaMarginX>>1;  
  17.   m_iChromaMarginY  = m_iLumaMarginY>>1;  
  18.     
  19.   m_apiPicBufY      = (Pel*)xMalloc( Pel, ( m_iPicWidth       + (m_iLumaMarginX  <<1)) * ( m_iPicHeight       + (m_iLumaMarginY  <<1)));  
  20.   m_apiPicBufU      = (Pel*)xMalloc( Pel, ((m_iPicWidth >> 1) + (m_iChromaMarginX<<1)) * ((m_iPicHeight >> 1) + (m_iChromaMarginY<<1)));  
  21.   m_apiPicBufV      = (Pel*)xMalloc( Pel, ((m_iPicWidth >> 1) + (m_iChromaMarginX<<1)) * ((m_iPicHeight >> 1) + (m_iChromaMarginY<<1)));  
  22.     
  23.   m_piPicOrgY       = m_apiPicBufY + m_iLumaMarginY   * getStride()  + m_iLumaMarginX;  
  24.   m_piPicOrgU       = m_apiPicBufU + m_iChromaMarginY * getCStride() + m_iChromaMarginX;  
  25.   m_piPicOrgV       = m_apiPicBufV + m_iChromaMarginY * getCStride() + m_iChromaMarginX;  
  26.     
  27.   m_bIsBorderExtended = false;  
  28.     
  29.   m_cuOffsetY = new Int[numCuInWidth * numCuInHeight];  
  30.   m_cuOffsetC = new Int[numCuInWidth * numCuInHeight];  
  31.   for (Int cuRow = 0; cuRow < numCuInHeight; cuRow++)  
  32.   {  
  33.     for (Int cuCol = 0; cuCol < numCuInWidth; cuCol++)  
  34.     {  
  35.       m_cuOffsetY[cuRow * numCuInWidth + cuCol] = getStride() * cuRow * m_iCuHeight + cuCol * m_iCuWidth;  
  36.       m_cuOffsetC[cuRow * numCuInWidth + cuCol] = getCStride() * cuRow * (m_iCuHeight / 2) + cuCol * (m_iCuWidth / 2);  
  37.     }  
  38.   }  
  39.     
  40.   m_buOffsetY = new Int[(size_t)1 << (2 * uiMaxCUDepth)];  
  41.   m_buOffsetC = new Int[(size_t)1 << (2 * uiMaxCUDepth)];  
  42.   for (Int buRow = 0; buRow < (1 << uiMaxCUDepth); buRow++)  
  43.   {  
  44.     for (Int buCol = 0; buCol < (1 << uiMaxCUDepth); buCol++)  
  45.     {  
  46.       m_buOffsetY[(buRow << uiMaxCUDepth) + buCol] = getStride() * buRow * (uiMaxCUHeight >> uiMaxCUDepth) + buCol * (uiMaxCUWidth  >> uiMaxCUDepth);  
  47.       m_buOffsetC[(buRow << uiMaxCUDepth) + buCol] = getCStride() * buRow * (uiMaxCUHeight / 2 >> uiMaxCUDepth) + buCol * (uiMaxCUWidth / 2 >> uiMaxCUDepth);  
  48.     }  
  49.   }  
  50.   return;  
  51. }  


  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值