HM代码阅读5:快速大范围运动估计函数xTZSearch()与xTZ8PointDiaMondSearch()

本文主要是介绍HM代码阅读5:快速大范围运动估计函数xTZSearch()与xTZ8PointDiaMondSearch(),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

上一次讲过了全搜索的做法,主要用于第二次对cost较大的参考图像列表的对应MV做一定范围内的全搜索减小cost。

这次主要讲在第一次做ME时的快速搜索算法,HM中采用TZSearch进行大范围内的ME。HM中提供的算法如下:
一般是采用Diamond搜索,也就是菱形搜索,在进搜索函数之前需要找到左、上、右上的MV,来判断是不是邻居MV更适合做ME的起始点(这里书本中没有详细写明,要注意)

Void TEncSearch::xPatternSearchFast( const TComDataCU* const  pcCU,const TComPattern* const pcPatternKey,const Pel* const         piRefY,const Int                iRefStride,const TComMv* const      pcMvSrchRngLT,const TComMv* const      pcMvSrchRngRB,TComMv&                  rcMv,Distortion&              ruiSAD,const TComMv* const      pIntegerMv2Nx2NPred )
{assert (MD_LEFT < NUM_MV_PREDICTORS);pcCU->getMvPredLeft       ( m_acMvPredictors[MD_LEFT] );assert (MD_ABOVE < NUM_MV_PREDICTORS);pcCU->getMvPredAbove      ( m_acMvPredictors[MD_ABOVE] );assert (MD_ABOVE_RIGHT < NUM_MV_PREDICTORS);pcCU->getMvPredAboveRight ( m_acMvPredictors[MD_ABOVE_RIGHT] );switch ( m_motionEstimationSearchMethod ){case MESEARCH_DIAMOND:xTZSearch( pcCU, pcPatternKey, piRefY, iRefStride, pcMvSrchRngLT, pcMvSrchRngRB, rcMv, ruiSAD, pIntegerMv2Nx2NPred, false );break;case MESEARCH_SELECTIVE:xTZSearchSelective( pcCU, pcPatternKey, piRefY, iRefStride, pcMvSrchRngLT, pcMvSrchRngRB, rcMv, ruiSAD, pIntegerMv2Nx2NPred );break;case MESEARCH_DIAMOND_ENHANCED:xTZSearch( pcCU, pcPatternKey, piRefY, iRefStride, pcMvSrchRngLT, pcMvSrchRngRB, rcMv, ruiSAD, pIntegerMv2Nx2NPred, true );break;case MESEARCH_FULL: // shouldn't get here.default:break;}
}

接下来是菱形搜索的具体过程
1、预先设置搜索的参数,如:逐行搜索还是菱形搜索,精调时选star菱形搜索还是逐行搜索,是否考虑角落等。

2、定义结构体IntTZSearchStruct ,用于存储当前最好的MV以及最小失真,以及重建帧的同位起始地址、步幅等。

3、调用xTZSearchHelp去判断最好的起始位置,需要依次考虑 当前最佳MVP、左、上、右上MVP、0运动矢量、若不是2NX2N的块,还需要判断一下2NX2N的块是不是最佳起始位置。

4、开始做菱形搜索,菱形搜索如图所示:
在这里插入图片描述

  • 步长从1 到 64 每次增加2倍。能够得到当前最佳运动矢量。 再以0矢量为起始点,再进行同样的搜索,对比两次结果找到最优MV。
  • 如果是在distance=1时找到最优的MV,那还需进行一次两点搜索。
  • 以当前最佳MV进行starRefine,以同样的方式进行8点菱形搜索。
    代码如下:
Void TEncSearch::xTZSearch( const TComDataCU* const pcCU,const TComPattern* const pcPatternKey,const Pel* const         piRefY,const Int                iRefStride,const TComMv* const      pcMvSrchRngLT,const TComMv* const      pcMvSrchRngRB,TComMv&                  rcMv,Distortion&              ruiSAD,const TComMv* const      pIntegerMv2Nx2NPred,const Bool               bExtendedSettings)
{const Bool bUseAdaptiveRaster                      = bExtendedSettings;const Int  iRaster                                 = 5;const Bool bTestOtherPredictedMV                   = bExtendedSettings;const Bool bTestZeroVector                         = true;const Bool bTestZeroVectorStart                    = bExtendedSettings;const Bool bTestZeroVectorStop                     = false;const Bool bFirstSearchDiamond                     = true;  // 1 = xTZ8PointDiamondSearch   0 = xTZ8PointSquareSearchconst Bool bFirstCornersForDiamondDist1            = bExtendedSettings;const Bool bFirstSearchStop                        = m_pcEncCfg->getFastMEAssumingSmootherMVEnabled();const UInt uiFirstSearchRounds                     = 3;     // first search stop X rounds after best match (must be >=1)const Bool bEnableRasterSearch                     = true;const Bool bAlwaysRasterSearch                     = bExtendedSettings;  // true: BETTER but factor 2 slowerconst Bool bRasterRefinementEnable                 = false; // enable either raster refinement or star refinementconst Bool bRasterRefinementDiamond                = false; // 1 = xTZ8PointDiamondSearch   0 = xTZ8PointSquareSearchconst Bool bRasterRefinementCornersForDiamondDist1 = bExtendedSettings;const Bool bStarRefinementEnable                   = true;  // enable either star refinement or raster refinementconst Bool bStarRefinementDiamond                  = true;  // 1 = xTZ8PointDiamondSearch   0 = xTZ8PointSquareSearchconst Bool bStarRefinementCornersForDiamondDist1   = bExtendedSettings;const Bool bStarRefinementStop                     = false;const UInt uiStarRefinementRounds                  = 2;  // star refinement stop X rounds after best match (must be >=1)const Bool bNewZeroNeighbourhoodTest               = bExtendedSettings;UInt uiSearchRange = m_iSearchRange;pcCU->clipMv( rcMv );
#if ME_ENABLE_ROUNDING_OF_MVSrcMv.divideByPowerOf2(2);
#elsercMv >>= 2;
#endif// init TZSearchStructIntTZSearchStruct cStruct;cStruct.iYStride    = iRefStride;cStruct.piRefY      = piRefY;cStruct.uiBestSad   = MAX_UINT;// set rcMv (Median predictor) as start point and as best pointxTZSearchHelp( pcPatternKey, cStruct, rcMv.getHor(), rcMv.getVer(), 0, 0 );// test whether one of PRED_A, PRED_B, PRED_C MV is better start point than Median predictorif ( bTestOtherPredictedMV ){for ( UInt index = 0; index < NUM_MV_PREDICTORS; index++ ){TComMv cMv = m_acMvPredictors[index];pcCU->clipMv( cMv );
#if ME_ENABLE_ROUNDING_OF_MVScMv.divideByPowerOf2(2);
#elsecMv >>= 2;
#endifif (cMv != rcMv && (cMv.getHor() != cStruct.iBestX && cMv.getVer() != cStruct.iBestY)){// only test cMV if not obviously previously tested.xTZSearchHelp( pcPatternKey, cStruct, cMv.getHor(), cMv.getVer(), 

这篇关于HM代码阅读5:快速大范围运动估计函数xTZSearch()与xTZ8PointDiaMondSearch()的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/887119

相关文章

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

Redis实现高效内存管理的示例代码

《Redis实现高效内存管理的示例代码》Redis内存管理是其核心功能之一,为了高效地利用内存,Redis采用了多种技术和策略,如优化的数据结构、内存分配策略、内存回收、数据压缩等,下面就来详细的介绍... 目录1. 内存分配策略jemalloc 的使用2. 数据压缩和编码ziplist示例代码3. 优化的

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

GO语言中函数命名返回值的使用

《GO语言中函数命名返回值的使用》在Go语言中,函数可以为其返回值指定名称,这被称为命名返回值或命名返回参数,这种特性可以使代码更清晰,特别是在返回多个值时,感兴趣的可以了解一下... 目录基本语法函数命名返回特点代码示例命名特点基本语法func functionName(parameters) (nam

Python从Word文档中提取图片并生成PPT的操作代码

《Python从Word文档中提取图片并生成PPT的操作代码》在日常办公场景中,我们经常需要从Word文档中提取图片,并将这些图片整理到PowerPoint幻灯片中,手动完成这一任务既耗时又容易出错,... 目录引言背景与需求解决方案概述代码解析代码核心逻辑说明总结引言在日常办公场景中,我们经常需要从 W

Python Counter 函数使用案例

《PythonCounter函数使用案例》Counter是collections模块中的一个类,专门用于对可迭代对象中的元素进行计数,接下来通过本文给大家介绍PythonCounter函数使用案例... 目录一、Counter函数概述二、基本使用案例(一)列表元素计数(二)字符串字符计数(三)元组计数三、C

使用Spring Cache本地缓存示例代码

《使用SpringCache本地缓存示例代码》缓存是提高应用程序性能的重要手段,通过将频繁访问的数据存储在内存中,可以减少数据库访问次数,从而加速数据读取,:本文主要介绍使用SpringCac... 目录一、Spring Cache简介核心特点:二、基础配置1. 添加依赖2. 启用缓存3. 缓存配置方案方案