x264_param_t结构体参数分析_xpp02的博客-程序员宝宝

技术标签: ffmpeg  

参考网上的一些资料,结合个人的理解,对x264中 x264_param_t结构体作了初步的分析,不保证正确。对x264熟悉的朋友可以在这基础上修改添加

typedef struct x264_param_t
{
/* CPU 标志位 */
unsigned int cpu;
int i_threads; /* 并行编码多帧 */
int b_deterministic; /*是否允许非确定性时线程优化*/
int i_sync_lookahead; /* 线程超前缓冲 */

/* 视频属性 */
int i_width; /* 宽度*/
int i_height; /* 高度*/
int i_csp; /* 编码比特流的CSP,仅支持i420,色彩空间设置 */
int i_level_idc; /* level值的设置*/
int i_frame_total; /* 编码帧的总数, 默认 0 */
/*Vui参数集视频可用性信息视频标准化选项 */
struct
{
/* they will be reduced to be 0 < x <= 65535 and prime */
int i_sar_height;
int i_sar_width; /* 设置长宽比 */

int i_overscan; /* 0=undef, 1=no overscan, 2=overscan 过扫描线,默认"undef"(不设置),可选项:show(观看)/crop(去除)*/

/*见以下的值h264附件E */
Int i_vidformat;/* 视频格式,默认"undef",component/pal/ntsc/secam/mac/undef*/
int b_fullrange; /*Specify full range samples setting,默认"off",可选项:off/on*/
int i_colorprim; /*原始色度格式,默认"undef",可选项:undef/bt709/bt470m/bt470bg,smpte170m/smpte240m /film*/
int i_transfer; /*转换方式,默认"undef",可选项:undef/bt709/bt470m/bt470bg/linear,log100/log316 /smpte170m/smpte240m*/
int i_colmatrix; /*色度矩阵设置,默认"undef",undef/bt709/fcc/bt470bg,smpte170m/smpte240m/GBR /YCgCo*/
int i_chroma_loc; /* both top & bottom色度样本指定,范围0~5,默认0 */
} vui;

int i_fps_num;
int i_fps_den;
/*这两个参数是由fps帧率确定的,赋值的过程见下:
{ float fps;
if( sscanf( value, "%d/%d", &p->i_fps_num, &p->i_fps_den ) == 2 )
;
else if( sscanf( value, "%f", &fps ) )
{
p->i_fps_num = (int)(fps * 1000 + .5);
p->i_fps_den = 1000;
}
else
b_error = 1;
}
输入的Value的值就是fps。*/

/*流参数 */
int i_frame_reference; /* 参考帧最大数目 */
int i_keyint_max; /* 在此间隔设置IDR关键帧(每过多少帧设置一个IDR帧) */
int i_keyint_min; /* 场景切换少于此值编码为I帧, 而不是 IDR帧. */
int i_scenecut_threshold; /*控制多怎样插入I帧 */
int b_intra_refresh; //用周期帧内刷新替代IDR (这貌似是个新参数,对周期帧内刷新不甚理解,知道的朋友可否指点一下)

int i_bframe; /*在两个参考帧之间B帧的数目 */
int i_bframe_adaptive; /*自适应B帧判定*/
int i_bframe_bias; /*控制插入B帧判定,范围-100~+100,越高越容易插入B帧,默认0*/
int b_bframe_pyramid; /*允许部分B为参考帧,可选值为0,1,2 */

/*去方块滤波器需要的参数,alpha和beta是去方块滤波器的参数*/
int b_deblocking_filter;
int i_deblocking_filter_alphac0; /* [-6, 6] -6 light filter, 6 strong */
int i_deblocking_filter_beta; /* [-6, 6] idem */

/*熵编码 */
int b_cabac;
int i_cabac_init_idc;

int b_interlaced; /* 隔行扫描 */
int b_constrained_intra;

/*量化 */
int i_cqm_preset; /*自定义量化矩阵(CQM),初始化量化模式为flat*/
char *psz_cqm_file; /* JM format读取JM格式的外部量化矩阵文件,自动忽略其他—cqm 选项*/
uint8_t cqm_4iy[16]; /* used only if i_cqm_preset == X264_CQM_CUSTOM */
uint8_t cqm_4ic[16];
uint8_t cqm_4py[16];
uint8_t cqm_4pc[16];
uint8_t cqm_8iy[64];
uint8_t cqm_8py[64];

/* 日志 */
void (*pf_log)( void *, int i_level, const char *psz, va_list ); //日志函数
void *p_log_private;
int i_log_level; //日志记录级别
int b_visualize; //是否显示日志
char *psz_dump_yuv; /* 保存重建帧的文件名 */

/* 编码分析参数*/
struct
{
unsigned int intra; /* 帧间分区*/
unsigned int inter; /* 帧内分区 */

int b_transform_8x8; /* 帧间分区*/
int i_weighted_pred; //p帧加权预测
int b_weighted_bipred; /*为b帧隐式加权 */
int i_direct_mv_pred; /*时间空间队运动预测 */
int i_chroma_qp_offset; /*色度量化步长偏移量 */

int i_me_method; /* 运动估计算法 (X264_ME_*) ,做运动估计的朋友可以设计自己的运动估计函数*/
int i_me_range; /* 整像素运动估计搜索范围 (from predicted mv) */
int i_mv_range; /* 运动矢量最大长度(in pixels). -1 = auto, based on level */
int i_mv_range_thread; /* 线程之间的最小空间. -1 = auto, based on number of threads. */
int i_subpel_refine; /* 亚像素运动估计质量 */
int b_chroma_me; /* 亚像素色度运动估计和P帧的模式选择 */
int b_mixed_references; /*允许每个宏块的分区在P帧有它自己的参考号*/
int i_trellis; /* Trellis量化,对每个8x8的块寻找合适的量化值,需要CABAC,默认0 0:关闭1:只在最后编码时使用2:一直使用*/
int b_fast_pskip; /*快速P帧跳过检测*/
int b_dct_decimate; /* P帧的转换参数阈值 */
int i_noise_reduction; /*自适应伪盲区 */
float f_psy_rd; /* Psy RD strength */
float f_psy_trellis; /* Psy trellis strength */
int b_psy; /* Toggle all psy optimizations */

/*,亮度量化中使用的无效区大小*/
int i_luma_deadzone[2]; /* {帧间, 帧内} */

int b_psnr; /* 计算和打印PSNR信息 */
int b_ssim; /*计算和打印SSIM信息*/
} analyse;

/* 码率控制参数 */
struct
{
int i_rc_method; /* X264_RC_* */ //码率控制方法

int i_qp_constant; /* 0-51 */
int i_qp_min; /*允许的最小量化值 */
int i_qp_max; /*允许的最大量化值*/
int i_qp_step; /*帧间最大量化步长 */

int i_bitrate; /*设置平均码率 */
float f_rf_constant; /* 1pass VBR, nominal QP */
float f_rate_tolerance; //In CRF mode,maximum CRF as caused by VBV,这是源文件的注释,对码率控制不熟悉,不知道具体意思
int i_vbv_max_bitrate; /*平均码率模式下,最大瞬时码率,默认0(与-B设置相同) */
int i_vbv_buffer_size; /*码率控制缓冲区的大小,单位kbit,默认0 */
float f_vbv_buffer_init; /* <=1: fraction of buffer_size. >1: kbit码率控制缓冲区数据保留的最大数据量与缓冲区大小之比,范围0~1.0,默认0.9*/
float f_ip_factor;
float f_pb_factor;

int i_aq_mode; /* psy adaptive QP. (X264_AQ_*) */
float f_aq_strength;
int b_mb_tree; /* Macroblock-tree ratecontrol. */
int i_lookahead;

/* 2pass 多次压缩码率控制 */
int b_stat_write; /* Enable stat writing in psz_stat_out */
char *psz_stat_out;
int b_stat_read; /* Read stat from psz_stat_in and use it */
char *psz_stat_in;

/* 2pass params (same as ffmpeg ones) */
float f_qcompress; /* 0.0 => cbr, 1.0 => constant qp */
float f_qblur; /*时间上模糊量化 */
float f_complexity_blur; /* 时间上模糊复杂性 */
x264_zone_t *zones; /* 码率控制覆盖 */
int i_zones; /* number of zone_t's */
char *psz_zones; /*指定区的另一种方法*/
} rc;

/* Muxing parameters */
int b_aud; /*生成访问单元分隔符*/
int b_repeat_headers; /* 在每个关键帧前放置SPS/PPS*/
int b_annexb; //如果设置了该项,则在每个NAL单元前加一个四字节的前缀符
int i_sps_id; /* SPS 和 PPS id 号 */

int b_vfr_input; //VFR输入
uint32_t i_fps_num;
uint32_t i_fps_den;
uint32_t i_timebase_num;
uint32_t i_timebase_den;

int b_dts_compress;

int b_tff;

int b_pic_struct;
int b_fake_interlaced;

/*切片(像条)参数 */
int i_slice_max_size; /* 每片字节的最大数,包括预计的NAL开销. */
int i_slice_max_mbs; /* 每片宏块的最大数,重写 i_slice_count */
int i_slice_count; /* 每帧的像条数目: 设置矩形像条. */

/* Optional callback for freeing this x264_param_t when it is done being used.
* Only used when the x264_param_t sits in memory for an indefinite period of time,
* i.e. when an x264_param_t is passed to x264_t in an x264_picture_t or in zones.
* Not used when x264_encoder_reconfig is called directly. */
void (*param_free)( void* );
} x264_param_t;
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/xpp02/article/details/83732182

智能推荐

UnixUtils_avder的博客-程序员宝宝

refer: http://blog.donews.com/chnl/archive/2006/06/27/928873.aspx由于工作,需要经常性地对一些文本进行处理。比较常用的大多是Linux系统下的一些实用工具如,grep,awk,sed,tr,sort,uniq等。    由于工作的PC是Windows平台,所以免不了要把原始的文件上传到Linux系统上,进行一番处理后,再重新下

滤镜-Color Lookup Table(ColorLUT)技术_dengfuma的博客-程序员宝宝

移动端滤镜开发(五)普通滤镜开发写在前面的话上一篇文章对简单滤镜实现有一定的讲解,那么这一篇则是对图像处理更加深层次的说明,对于一张图片怎么处理起来效果会看起来更好呢?我想大部分人首先就会想到PS软件,确实对于图像的处理PS有很多的功能,一般处理图片呢会用到下面这些工具图1 图片处理通过这些工具可以对图片各种修改,当然除了这种处理之外难免还会出现加上水印或者边框这种类型的需求,那么这种修改一般用P

桌面壁纸被计算机管理员禁用,更改桌面背景时显示已经被系统管理员禁用,这种情况要怎么处理..._皮肤科博士-Qson的博客-程序员宝宝

xp,win7更改桌面背景方法差不多。右击鼠标--个性化,选择一个主题,或者自己制作,用几个喜欢的图片。或者“联机获得更多主题”,下载,然后双击安装。如果发现被管理员禁用:右击“我的电脑”,依次单击“属性/高级/性能设置”在“视觉效果”页中将“在桌面上为图标标签使用阴影”选中,单击确定即可。右键桌面空白处右击,在“排列图标”里去掉“锁定桌面的web项目”有时会出现上述设置也不能解决问题,我们就可以...

Ubuntu16 下创建文件时没有权限_飞奔的小付的博客-程序员宝宝

可以在终端输入命令行sudo nautilus ,在nautilus中直接GUI操作,中途不要关终端。

17.redis哨兵,原master节点重启后,无法变成新master节点的slave_unable to change master from to: redis://_扛麻袋的少年的博客-程序员宝宝

Redis哨兵配置,可能你会遇到这样的问题: 当配置了哨兵,将集群也都启动完成。手动将一个master节点关掉之后,该master相对应的slave节点会自动切换为master节点,但是当我们将原先的master节点服务启动之后,却无法变成现有master的slave节点。 打开哨兵日志,你会看到N多行日志,全是convert-to-slave...的信息,日志...

C语言常见小问题_gwk156的博客-程序员宝宝

c语言常见小问题1.补码的计算原则对于无符号数以及有符号数中的正数,其补码就是原码本身;对于有符号数中的负数,其补码为真值绝对值的反码加一,其中反码为原码按位取反。2.嵌入式系统中经常要用到无限循环,你怎么样用C编写死循环呢?首选的方案是: while(1) { }一些程序员更喜欢如下方案: for(;;) { }这个实现方式让我为难,因为这个语法没有确切表达到底怎么回

随便推点

python模拟excel登录插件_学会Python3模拟登录并爬取表格数据!excel高手也自叹不如!..._weixin_39767121的博客-程序员宝宝

主要内容有:通过requests库模拟表单提交通过pandas库提取网页表格朋友发给我一个网址,哭哭啼啼地求我:“去!把这个网页上所有年所有县所有作物的数据全爬下来,存到Access里!”我看他可怜,勉为其难地挥挥手说:“好嘞,马上就开始!”大家在学python的时候肯定会遇到很多难题,以及对于新技术的追求,这里推荐一下我们的Python学习扣qun:631441315,这里是python学习者聚...

vue配合cookie进行登录记住密码以及请求验证 以及记住密码功能_vue 验证密码是否等于cookies_许洪源的博客-程序员宝宝

vue配合cookie进行登录记住密码以及请求验证 以及记住密码功能使用cookie时先在项目中导入vue-cookie包npm install vue-cookies --save在main.js中引入import Vue from ‘vue’import VueCookies from ‘vue-cookies’Vue.use(VueCookies)登录框界面login.vue&lt;template&gt; &lt;div class="main" v-loading="loadi

aac adts解析的c++代码_c语言解析aac音频_yingyemin的博客-程序员宝宝

简介 本文代码功能为,从aac文件中,将aac一帧帧的读出来,并解析采样率,声道等信息代码:parseAAC.cpp#include &lt;iostream&gt;using namespace std;int getNextAacFrame(FILE*fp, unsigned char* buf, int &amp;size){ int n = fread(buf, 1, 7, fp); if (n &lt; 7) { cout &l...

如何将double类型的数据转换成String类型_js double转string_小王裁缝的博客-程序员宝宝

在EditText中使用setText()方法要求传入的数据类型为String类型,若想将double类型的数据在此方法中输出,则需要将double类型的数据转成String类型。double d = 123456789.50;DecimalFormat format = new DecimalFormat("#.00");//#后面的则为小数点的位数,若想没有小数点,则输入以下语句//DecimalFormat format = new DecimalFormat("#");String str

c语言 乱码转化为16进制_面向小白的C语言科普教程(一)文件和扩展名、编码和十六进制..._之四的博客-程序员宝宝

前言本系列文章偏向科普向,出发点是因为某乎每天都给我推送有关C语言基础的低质问题,答得多了发现不仅收不到赞,甚至会因为太弱智而掉粉。所以萌生了尝试给有想要了解、学习C语言及相关计算机知识的同学复制一条自身觉得可能会比较高效的路线的想法,目标是让电脑小白在学习的过程中了解计算机自底向上尽可能全面的相关知识,进而真正地学会C语言。毕竟C语言与其他语言不同,比较偏向底层,如果完全不了解体系结构和操作系统...

“无法启动程序,因为计算机中丢失MSVCP100D.dll”的解决方案_protoc.exe msvcp100d.ddll_Renduy的博客-程序员宝宝

用VS2012安装OpenCV时出现这个错误,在网上搜索了很多解决方案,最终解决了问题。现在把这些解决方案汇总一下。方案一:下载MSVCP100D.dll1、复制文件“msvcr100d.dll”到系统目录下。2、系统目录一般为:C:\WINNT\System32 64位系统为C:\Windows\SysWOW64。3、最后点击开始菜单–>运行–>输入regsvr32 msvcr100d.dll,回

推荐文章

热门文章

相关标签