一个CTU分割细节过程—— VTM (13.0)源码阅读

摘要:本文主要分析VTM13.0 一个CTU分割过程,目的是为了在此基础上嵌入深度学习算法加速CU 分割决策过程。

1. CU/CTU 总体划分框架

1)CTU -> CU

2)xComPressCU(): 传入tempCS(curr_CU) 、bestCS(best_CU)、partitioner(CTU树节点信息,以栈的方式存储需要遍历的CU,即栈的顺序是树遍历的顺序)

3)然后执行m_modeCtrl->initCULevel( partitioner, *tempCS );  初始化可分割的模式列表,以栈的方式保存,然后遍历curr_CU -> testMode 

// CU 入栈
m_ComprCUCtxList.push_back(CU),存放需要遍历CU栈 : 
// currCU下的testModes 入栈(多个模式) 
m_ComprCUCtxList.back().testModes().push_back( { ETM_SPLIT_TT_H, ETO_STANDARD, qp } )

4)计算  帧间/帧内/其他模式/分割模式  (这集中模式的计算为并列关系,特别是分割模式,与以往的理解有出入)

5)xCheckModeSplit(encTestMode)  // 传入当前 split mode 并分割出对应的subCU,然后遍历对应的subCU 调用xCompressCU() :如此递归下去,直到不能分割为止。遍历完所有 的subCU 后,对比SUM( subCus RD Cost) 与当前 CU 的RD Cost ,得到最优的CU

6)提取当前CU的下一个split mode

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值