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

相关文章

Java中Date、LocalDate、LocalDateTime、LocalTime、时间戳之间的相互转换代码

《Java中Date、LocalDate、LocalDateTime、LocalTime、时间戳之间的相互转换代码》:本文主要介绍Java中日期时间转换的多种方法,包括将Date转换为LocalD... 目录一、Date转LocalDateTime二、Date转LocalDate三、LocalDateTim

MySQL中FIND_IN_SET函数与INSTR函数用法解析

《MySQL中FIND_IN_SET函数与INSTR函数用法解析》:本文主要介绍MySQL中FIND_IN_SET函数与INSTR函数用法解析,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一... 目录一、功能定义与语法1、FIND_IN_SET函数2、INSTR函数二、本质区别对比三、实际场景案例分

jupyter代码块没有运行图标的解决方案

《jupyter代码块没有运行图标的解决方案》:本文主要介绍jupyter代码块没有运行图标的解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录jupyter代码块没有运行图标的解决1.找到Jupyter notebook的系统配置文件2.这时候一般会搜索到

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

C++ Sort函数使用场景分析

《C++Sort函数使用场景分析》sort函数是algorithm库下的一个函数,sort函数是不稳定的,即大小相同的元素在排序后相对顺序可能发生改变,如果某些场景需要保持相同元素间的相对顺序,可使... 目录C++ Sort函数详解一、sort函数调用的两种方式二、sort函数使用场景三、sort函数排序

C语言函数递归实际应用举例详解

《C语言函数递归实际应用举例详解》程序调用自身的编程技巧称为递归,递归做为一种算法在程序设计语言中广泛应用,:本文主要介绍C语言函数递归实际应用举例的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录前言一、递归的概念与思想二、递归的限制条件 三、递归的实际应用举例(一)求 n 的阶乘(二)顺序打印

Python通过模块化开发优化代码的技巧分享

《Python通过模块化开发优化代码的技巧分享》模块化开发就是把代码拆成一个个“零件”,该封装封装,该拆分拆分,下面小编就来和大家简单聊聊python如何用模块化开发进行代码优化吧... 目录什么是模块化开发如何拆分代码改进版:拆分成模块让模块更强大:使用 __init__.py你一定会遇到的问题模www.

C/C++错误信息处理的常见方法及函数

《C/C++错误信息处理的常见方法及函数》C/C++是两种广泛使用的编程语言,特别是在系统编程、嵌入式开发以及高性能计算领域,:本文主要介绍C/C++错误信息处理的常见方法及函数,文中通过代码介绍... 目录前言1. errno 和 perror()示例:2. strerror()示例:3. perror(

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.