HEVC/H265 HM10.0 分析(二)TComDataCU.cpp
2013-03-12 19:00
337 查看
以下分析TComDataCU.cpp。这个cpp是很重要的,要分几次分析完,这是分析TComDataCU.cpp(一)。
在 2N*N, 2N*nU,2N*nD 中,上面部分的partIdx 为0,下面部分为1;
在N*2N,nL*2N,nR*2N中, 左边部分的partIdx为0,右边部分为1;
在N*N中, 按四叉树的结构,partIdx 分别为0,1,2,3;
在2N*2N中, partIdx只能为0;
xP,yP的值是CU块左上角的绝对位置值,nPSW,nPSH是当前CU块的宽度和高度,记住,CU是可以嵌套的,CU包含CU,所以有xP,yP,nPSW,nPSH就能够唯一的确定CU块,
限于时间关系,今天先分析至此。
Void TComDataCU::getPartPosition( UInt partIdx, Int& xP, Int& yP, Int& nPSW, Int& nPSH) { UInt col = m_uiCUPelX; UInt row = m_uiCUPelY; switch ( m_pePartSize[0] ) { case SIZE_2NxN: nPSW = getWidth(0); nPSH = getHeight(0) >> 1; xP = col; yP = (partIdx ==0)? row: row + nPSH; break; case SIZE_Nx2N: nPSW = getWidth(0) >> 1; nPSH = getHeight(0); xP = (partIdx ==0)? col: col + nPSW; yP = row; break; case SIZE_NxN: nPSW = getWidth(0) >> 1; nPSH = getHeight(0) >> 1; xP = col + (partIdx&0x1)*nPSW; yP = row + (partIdx>>1)*nPSH; break; case SIZE_2NxnU: nPSW = getWidth(0); nPSH = ( partIdx == 0 ) ? getHeight(0) >> 2 : ( getHeight(0) >> 2 ) + ( getHeight(0) >> 1 ); xP = col; yP = (partIdx ==0)? row: row + getHeight(0) - nPSH; break; case SIZE_2NxnD: nPSW = getWidth(0); nPSH = ( partIdx == 0 ) ? ( getHeight(0) >> 2 ) + ( getHeight(0) >> 1 ) : getHeight(0) >> 2; xP = col; yP = (partIdx ==0)? row: row + getHeight(0) - nPSH; break; case SIZE_nLx2N: nPSW = ( partIdx == 0 ) ? getWidth(0) >> 2 : ( getWidth(0) >> 2 ) + ( getWidth(0) >> 1 ); nPSH = getHeight(0); xP = (partIdx ==0)? col: col + getWidth(0) - nPSW; yP = row; break; case SIZE_nRx2N: nPSW = ( partIdx == 0 ) ? ( getWidth(0) >> 2 ) + ( getWidth(0) >> 1 ) : getWidth(0) >> 2; nPSH = getHeight(0); xP = (partIdx ==0)? col: col + getWidth(0) - nPSW; yP = row; break; default: assert ( m_pePartSize[0] == SIZE_2Nx2N ); nPSW = getWidth(0); nPSH = getHeight(0); xP = col ; yP = row ; break; } }
在 2N*N, 2N*nU,2N*nD 中,上面部分的partIdx 为0,下面部分为1;
在N*2N,nL*2N,nR*2N中, 左边部分的partIdx为0,右边部分为1;
在N*N中, 按四叉树的结构,partIdx 分别为0,1,2,3;
在2N*2N中, partIdx只能为0;
xP,yP的值是CU块左上角的绝对位置值,nPSW,nPSH是当前CU块的宽度和高度,记住,CU是可以嵌套的,CU包含CU,所以有xP,yP,nPSW,nPSH就能够唯一的确定CU块,
限于时间关系,今天先分析至此。
相关文章推荐
- HEVC/H265 HM10.0 分析(二)TComDataCU.cpp .
- HEVC/H265 HM10.0 分析(三)TAppDecTop.cpp .
- HEVC/H265 HM10.0 分析(一)NALread.cpp
- HEVC/H265 HM10.0 分析(三)TAppDecTop.cpp
- HEVC/H265 HM10.0 分析(一)NALread.cpp .
- 分析HM代码,首先必须把class TComDataCU完全搞明白! .
- 分析HM代码,首先必须把class TComDataCU完全搞明白!
- 分析HM代码,首先必须把class TComDataCU完全搞明白!
- HM平台之**xCompressCU**(TComDataCU*& rpcBestCU, TComDataCU*& rpcTempCU, UInt uiDepth, PartSize eParent)
- Cocos2d-x3.3RC0 Cpp-test分析之ActionManagerTest
- Cocos2d-x学习笔记(19)(TestCpp源码分析-3)
- 静态代码分析工具-jenkins应用(checkstyle and findbugs for java,cccc and cppcheck for c/c++)
- SURF源码分析之main.cpp
- 一款C++静态分析工具 —— CppDepend
- ArcGIS Engine10.0轻松入门级教程(3)——ArcEngine10.0查询分析功能
- HM框架简要分析
- Android Vold 分析(一)--system/vold/main.cpp-----mian函数分析
- cpp-ide剖析linux内核效率分析.txt
- CTBCAFBridge hpp 和 cpp 文件分析
- Recovery启动流程(3)--recovery.cpp分析