openh264 编码器源码分析:AnalyzePictureComplexity 函数

本文主要是介绍openh264 编码器源码分析:AnalyzePictureComplexity 函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

介绍

  1. 文件位置:
    • openh264/codec/processing/src/complexityanalysis/ComplexityAnalysis.cpp
  2. 功能:
    • 作为CWelsPreProcess类中一个方法,用来分析当前图像与参考图像之间的复杂度关系,以便编码策略。
  3. 原型:
void CWelsPreProcess::AnalyzePictureComplexity (sWelsEncCtx* pCtx, SPicture* pCurPicture, SPicture* pRefPicture,const int32_t kiDependencyId, const bool bCalculateBGD)
  1. 参数:
    • sWelsEncCtx* pCtx:指向sWelsEncCtx结构的指针,这通常是一个上下文结构,包含了编码过程中所需的状态信息。
    • SPicture* pCurPicture:指向当前待编码图片的指针。
    • SPicture* pRefPicture:指向参考图片的指针,用于与当前图片进行比较。
    • const int32_t kiDependencyId:一个整数常量,表示依赖层的ID,可能用于确定当前图片所属的编码层。
    • const bool bCalculateBGD:一个布尔值常量,指示是否需要计算背景差分(Background Difference)。

函数关系图

在这里插入图片描述

原理

桌面图像

  1. process 函数
  • 如果是IDR帧或参考图像为空,则调用GomComplexityAnalysisIntra函数执行内部复杂度分析;
  • 如果滚动标志为假或滚动偏移量在X和Y方向上都为0,则调用GomComplexityAnalysisInter函数执行无滚动的交互复杂度分析;
  • 调用GomComplexityAnalysisInter函数执行有滚动的交互复杂度分析;
  1. GomComplexityAnalysisIntra函数
  • 变量初始化;
  • 嵌套循环分析每个宏块;
    - 检查是否有可用的垂直或水平参考宏块,如果有,则使用相应的预测函数m_pIntraFunc和SAD计算函数m_pSadFunc来计算SAD值iBlockSadH、iBlockSadV;
    • 如果垂直或水平参考宏块存在,则累加中iBlockSadH、iBlockSadV的最小值到iGomSad中;
      • 如果当前宏块是一行中的最后一个宏块,或者已经到达了宏块组的底部,将iGomSad的值存储到类成员变量m_ComplexityAnalysisParam.pGomComplexity中,并更新帧复杂度m_ComplexityAnalysisParam.iFrameComplexity;
      • 更新索引iIdx,将变量iGomSad置 0,为下一个宏块组的复杂度值做准备;
      • 在处理完一行的所有宏块后,更新指针pPtrY到下一行的开始位置;
  • 更新类成员变量m_ComplexityAnalysisParam.iGomNumInFrame,表示帧中宏块组的数量;
  1. GomComplexityAnalysisInter函数
  • 变量初始化;
  • 嵌套 for 循环分析每个宏块;
    • 首先调用m_pSadFunc函数计算当前块的SAD值iInterSad;
    • 如果bScrollFlag为真,并且当前块的SAD值不为0,且滚动偏移量在有效范围内,则调用m_pSadFunc函数计算考虑滚动后的SAD值iScrollSad,并取两者的较小值作为当前块的SAD值iInterSad;
    • 如果当前宏块不是第一行或第一列的宏块,使用类成员预测函数m_pIntraFuncm_pSadFunc计算水平和垂直预测的SAD值iBlockSadH、iBlockSadV;
    • 选择iBlockSadH、iBlockSadV、iInterSad中最小值最为总体 SAD 值iGomSad;
    • 果当前宏块是一行中的最后一个宏块,或者已经到达了宏块组的底部,将iGomSad的值存储到类成员变量m_ComplexityAnalysisParam.pGomComplexity中,并更新帧复杂度m_ComplexityAnalysisParam.iFrameComplexity;
    • 更新索引iIdx,将变量iGomSad置 0,为下一个宏块组的复杂度值做准备;
    • 在处理完一行的所有宏块后,更新指针pPtrY到下一行的开始位置;
  • 更新类成员变量m_ComplexityAnalysisParam.iGomNumInFrame,表示帧中宏块组的数量;
  1. m_pSadFunc函数
  • 指向WelsSampleSad16x16_c函数
  1. m_pIntraFunc[0]函数
  • 指向WelsI16x16LumaPredV_c函数
  1. m_pIntraFunc[1]函数
  • 指向WelsI16x16LumaPredH_c函数

摄像镜头图像

  1. process 函数
  • iComplexityAnalysisMode等于FRAME_SAD时,调用AnalyzeFrameComplexityViaSad函数分析图像复杂度;
  • iComplexityAnalysisMode等于GOM_SAD时,调用AnalyzeGomComplexityViaSad函数分析图像复杂度;
  • iComplexityAnalysisMode等于GOM_VAR时,调用AnalyzeGomComplexityViaVar函数分析图像复杂度;
  1. AnalyzeFrameComplexityViaSad函数
  • 将pCalcResult赋值给pVaaCalcResults;
  • 将pVaaCalcResults中的iFrameSad赋值给m_sComplexityAnalysisParam.iFrameComplexity,作为当前帧的复杂度;
  • 如果iCalcBgd,即有背景检测,则调用GetFrameSadExcludeBackground函数计算复杂度,赋值给m_sComplexityAnalysisParam.iFrameComplexity,作为当前帧的复杂度;
  • GetFrameSadExcludeBackground函数:这个函数的目的是计算帧的SAD值,但在计算时排除了背景区域的宏块,这有助于更准确地评估帧中实际的前景复杂度。
    • 初始化变量,计算宏块组iMbNumInGom和宏块数iGomMbNum;
    • m_sComplexityAnalysisParam.pCalcResult赋值给pVaaCalcResults;
    • 双层嵌套 for 循环遍历所有宏块,
      • 如果宏块不是背景宏块,增加对应宏块组的前景宏块数量,并累加该宏块的四个8x8块的SAD值到uiFrameSad;
    • 返回 uiFrameSad值;
  1. AnalyzeGomComplexityViaSad函数
  • 初始化变量,计算宏块组iMbNumInGom和宏块数iGomMbNum;
  • 调用InitGomSadFunc函数初始化SAD计算函数(m_pfGomSad),并为每个GOB分配一个SAD变量(uiGomSad)
  • 嵌套双层循环处理每个宏块,
    • 对当前GOB的每一行进行循环,计算SAD;
    • 调用m_pfGomSad函数来累加当前宏块的SAD值uiGomSad;
    • 将计算得到的SAD值uiGomSad存储到pGomComplexity数组中;
    • 更新整个帧的SAD值(uiFrameSad);
  • 将帧的SAD值uiFrameSad存储在m_sComplexityAnalysisParam结构体中。
  1. AnalyzeGomComplexityViaVar函数
  • 初始化变量,计算宏块组iMbNumInGom和宏块数iGomMbNum;
  • 初始化样本和平方和变量(uiSampleSum和uiSquareSum);
  • 双层嵌套循环遍历每一个宏块;
    • 对当前GOB的每一行进行循环,累加样本和uiSampleSum和平方和uiSquareSum;
    • 计算宏块组方差,将结果存到pGomComplexity中;
    • 累加pGomComplexity到帧的 SAD 值uiFrameSad;
  • 将帧的SAD值uiFrameSad存储在m_sComplexityAnalysisParam结构体中。

源码

  • 略。

这篇关于openh264 编码器源码分析:AnalyzePictureComplexity 函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

Java ArrayList扩容机制 (源码解读)

结论:初始长度为10,若所需长度小于1.5倍原长度,则按照1.5倍扩容。若不够用则按照所需长度扩容。 一. 明确类内部重要变量含义         1:数组默认长度         2:这是一个共享的空数组实例,用于明确创建长度为0时的ArrayList ,比如通过 new ArrayList<>(0),ArrayList 内部的数组 elementData 会指向这个 EMPTY_EL

如何在Visual Studio中调试.NET源码

今天偶然在看别人代码时,发现在他的代码里使用了Any判断List<T>是否为空。 我一般的做法是先判断是否为null,再判断Count。 看了一下Count的源码如下: 1 [__DynamicallyInvokable]2 public int Count3 {4 [__DynamicallyInvokable]5 get

SWAP作物生长模型安装教程、数据制备、敏感性分析、气候变化影响、R模型敏感性分析与贝叶斯优化、Fortran源代码分析、气候数据降尺度与变化影响分析

查看原文>>>全流程SWAP农业模型数据制备、敏感性分析及气候变化影响实践技术应用 SWAP模型是由荷兰瓦赫宁根大学开发的先进农作物模型,它综合考虑了土壤-水分-大气以及植被间的相互作用;是一种描述作物生长过程的一种机理性作物生长模型。它不但运用Richard方程,使其能够精确的模拟土壤中水分的运动,而且耦合了WOFOST作物模型使作物的生长描述更为科学。 本文让更多的科研人员和农业工作者

MOLE 2.5 分析分子通道和孔隙

软件介绍 生物大分子通道和孔隙在生物学中发挥着重要作用,例如在分子识别和酶底物特异性方面。 我们介绍了一种名为 MOLE 2.5 的高级软件工具,该工具旨在分析分子通道和孔隙。 与其他可用软件工具的基准测试表明,MOLE 2.5 相比更快、更强大、功能更丰富。作为一项新功能,MOLE 2.5 可以估算已识别通道的物理化学性质。 软件下载 https://pan.quark.cn/s/57

工厂ERP管理系统实现源码(JAVA)

工厂进销存管理系统是一个集采购管理、仓库管理、生产管理和销售管理于一体的综合解决方案。该系统旨在帮助企业优化流程、提高效率、降低成本,并实时掌握各环节的运营状况。 在采购管理方面,系统能够处理采购订单、供应商管理和采购入库等流程,确保采购过程的透明和高效。仓库管理方面,实现库存的精准管理,包括入库、出库、盘点等操作,确保库存数据的准确性和实时性。 生产管理模块则涵盖了生产计划制定、物料需求计划、

衡石分析平台使用手册-单机安装及启动

单机安装及启动​ 本文讲述如何在单机环境下进行 HENGSHI SENSE 安装的操作过程。 在安装前请确认网络环境,如果是隔离环境,无法连接互联网时,请先按照 离线环境安装依赖的指导进行依赖包的安装,然后按照本文的指导继续操作。如果网络环境可以连接互联网,请直接按照本文的指导进行安装。 准备工作​ 请参考安装环境文档准备安装环境。 配置用户与安装目录。 在操作前请检查您是否有 sud

C++操作符重载实例(独立函数)

C++操作符重载实例,我们把坐标值CVector的加法进行重载,计算c3=c1+c2时,也就是计算x3=x1+x2,y3=y1+y2,今天我们以独立函数的方式重载操作符+(加号),以下是C++代码: c1802.cpp源代码: D:\YcjWork\CppTour>vim c1802.cpp #include <iostream>using namespace std;/*** 以独立函数