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

相关文章

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

Python中help()和dir()函数的使用

《Python中help()和dir()函数的使用》我们经常需要查看某个对象(如模块、类、函数等)的属性和方法,Python提供了两个内置函数help()和dir(),它们可以帮助我们快速了解代... 目录1. 引言2. help() 函数2.1 作用2.2 使用方法2.3 示例(1) 查看内置函数的帮助(

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

C++ 函数 strftime 和时间格式示例详解

《C++函数strftime和时间格式示例详解》strftime是C/C++标准库中用于格式化日期和时间的函数,定义在ctime头文件中,它将tm结构体中的时间信息转换为指定格式的字符串,是处理... 目录C++ 函数 strftipythonme 详解一、函数原型二、功能描述三、格式字符串说明四、返回值五

Java中Map.Entry()含义及方法使用代码

《Java中Map.Entry()含义及方法使用代码》:本文主要介绍Java中Map.Entry()含义及方法使用的相关资料,Map.Entry是Java中Map的静态内部接口,用于表示键值对,其... 目录前言 Map.Entry作用核心方法常见使用场景1. 遍历 Map 的所有键值对2. 直接修改 Ma

深入解析 Java Future 类及代码示例

《深入解析JavaFuture类及代码示例》JavaFuture是java.util.concurrent包中用于表示异步计算结果的核心接口,下面给大家介绍JavaFuture类及实例代码,感兴... 目录一、Future 类概述二、核心工作机制代码示例执行流程2. 状态机模型3. 核心方法解析行为总结:三

python获取cmd环境变量值的实现代码

《python获取cmd环境变量值的实现代码》:本文主要介绍在Python中获取命令行(cmd)环境变量的值,可以使用标准库中的os模块,需要的朋友可以参考下... 前言全局说明在执行py过程中,总要使用到系统环境变量一、说明1.1 环境:Windows 11 家庭版 24H2 26100.4061

Python中bisect_left 函数实现高效插入与有序列表管理

《Python中bisect_left函数实现高效插入与有序列表管理》Python的bisect_left函数通过二分查找高效定位有序列表插入位置,与bisect_right的区别在于处理重复元素时... 目录一、bisect_left 基本介绍1.1 函数定义1.2 核心功能二、bisect_left 与

pandas实现数据concat拼接的示例代码

《pandas实现数据concat拼接的示例代码》pandas.concat用于合并DataFrame或Series,本文主要介绍了pandas实现数据concat拼接的示例代码,具有一定的参考价值,... 目录语法示例:使用pandas.concat合并数据默认的concat:参数axis=0,join=

java中BigDecimal里面的subtract函数介绍及实现方法

《java中BigDecimal里面的subtract函数介绍及实现方法》在Java中实现减法操作需要根据数据类型选择不同方法,主要分为数值型减法和字符串减法两种场景,本文给大家介绍java中BigD... 目录Java中BigDecimal里面的subtract函数的意思?一、数值型减法(高精度计算)1.