ffmpeg 和 x264的参数对照
x264 |
|
ffmpeg |
|
说明 |
命令行 |
字段 |
命令行 |
字段 |
|
qp qp_constant |
cqp |
|
cqp |
固定量化因子。取值范围0到51。 经常取值在20-40之间,越小质量 越好,要求的码率越高。0表示无损压缩 |
max-keyint |
i_keyint_max |
g |
gop_size |
关键帧的最大间隔帧数 |
min-keyint |
i_keyint_min |
|
keyint_min |
关键帧的最小间隔帧数 |
level |
i_level_idc |
|
level |
取值范围10-51。 设置比特流的Level。默认40,即4.0。 用来告诉解码器需要支持的什么级别的 兼容性。只有在你知道自己在做什么的 时候才设置该参数。 |
frameref |
i_frame_reference |
|
refs |
B和P帧向前预测参考的帧数。取值范 围1-16。 该值不影响解码的速度,但是越大解码 所需的内存越大。这个值在一般情况下 越大效果越好,但是超过6以后效果就 不明显了。 |
bframes |
i_bframe |
|
max_b_frames |
最大B帧数. |
b-adapt |
b_bframe_adaptive |
|
b_frame_strategy |
如果为true,则自动决定什么时候需要 插入B帧,最高达到设置的最大B帧数。 如果设置为false,那么最大的B帧数被 使用。 |
b-pyramid |
b_bframe_pyramid |
|
FLAGS2(CODEC_FLAG2_BPYRAMID) |
当设置B帧>=2时候,通过开启这个选 项可以获得质量的略微提高,但是没有 任何的速度损失。 |
|
b_deblocking_filter |
|
FLAGS(CODEC_FLAG_LOOP_FILTER) |
|
deblock |
i_deblocking_filter_alphac0 |
|
deblockalpha |
|
cabac |
b_cabac |
|
coder_type(FF_CODER_TYPE_AC) |
使用CABAC熵编码技术,为引起轻微的 编码和解码的速度损失,但是可以提高 10%-15%的编码质量。 |
qmin |
i_qp_min |
|
qmin |
最小的量化因子。取值范围1-51。建 议在10-30之间。 |
qmax |
i_qp_max |
|
qmax |
最大的量化因子。取值范围1-51。建 议在10-30之间。 |
qpstep qp-step |
i_qp_step |
|
max_qdiff |
最大的在帧与帧之间进行切变的量化 因子的变化量。 |
qcomp |
f_qcompress |
|
|
|
vbv-maxrate |
i_vbv_max_bitrate |
b |
rc_max_rate |
允许的最大码流,x264里面以kbps为 单位,ffmpeg以bps为单位 |
vbv-bufsize |
i_vbv_buffer_size |
bufsize |
rc_buffer_size |
在指定vbv-maxrate的时候必须设置 该字段。 |
vbv-init |
f_vbv_buffer_init |
|
rc_initial_buffer_occupancy |
初始的缓存占用量 |
qcomp |
f_qcompress |
|
qcompress |
量化器压缩比率0-1.越小则比特率 越区域固定,但是越高越使量化器 参数越固定。 |
direct-pred direct |
i_direct_mv_pred |
|
directpred |
B帧里面采用的运动侦测的方式。 时间和空间方式大致PSNR和速度 是一致的。设置为auto质量会好一 些,但是速度会下降一些,设置为0 ,质量和速度都会下降.可以选择 none, auto, temporal, spatial. |
weightb weight-b |
b_weighted_bipred |
|
FLAGS2(CODEC_FLAG2_WPRED) |
当B帧设置>1时使用 |
partitions analyse |
inter |
|
|
X264_ANALYSE_I4x4 X264_ANALYSE_I8x8 X264_ANALYSE_PSUB16x16 X264_ANALYSE_PSUB8x8 X264_ANALYSE_BSUB16x16 |
8x8dct |
b_transform_8x8 |
|
FLAGS(CODEC_FLAG2_8X8DCT) |
|
me |
i_me_method |
|
me_method |
运动侦测的方式 ME_EPZS ME_HEX ME_UMH ME_FULL ME_ESA |
me-range merange |
i_me_range |
|
me_range |
运动侦测的半径 |
subq subme |
i_subpel_refine |
|
me_subpel_quality |
这个参数控制在运动估算过程中质 量和速度的权衡。Subq=5可以压 缩>10%于subq=1。1-7 |
mixed-refs |
b_mixed_references |
|
FLAGS2(CODEC_FLAG2_MIXED_REFS) |
允许8*8,16*8运动块独立地选择 参考帧,如果disable,则所有的宏 块必须参考同一帧。 需要frameref > 1 |
brdo |
b_bframe_rdo |
|
FLAGS2(CODEC_FLAG2_BRDO) |
需要subq>6 |
bime |
b_bidir_me |
|
bidir_refine |
取值范围:true,false.这个值在没 有B帧的时候失效。在双向预测宏块中 双向运动矢量使用。 |
trellis |
i_trellis |
|
trellis |
|
deadzone-intra |
i_luma_deadzone |
|
没有对应值 |
|
deadzone-inter |
i_luma_deadzone |
|
没有对应值 |
|
fast-pskip |
b_fast_pskip |
|
FLAGS(CODEC_FLAG2_FASTPSKIP) |
在P帧内执行早期快速跳跃探测。 这个经常在没有任何损失的前提 下提高了速度。 |
dct-decimate |
b_dct_decimate |
|
没有对应值 |
|
nr |
i_noise_reduction |
|
noise_reduction |
0意味着关闭,对于噪声很大的 内容你需要打开。 范围:0-100000 |
interlaced |
b_interlaced |
|
没有对应值 |
|
global-header |
b_repeat_headers |
|
FLAGS(CODEC_FLAG_GLOBAL_HEADER) |
使得SPS和PPS只在流的开始处 产生一次。有些播放器,如SONY 的PSP需要开启此参数。默认的设 置使得SPS和PPS在每一个IDR帧 开始出都进行重复。 |
aud |
b_aud |
|
FLAGS2(CODEC_FLAG2_AUD) |
|
threads |
i_threads |
|
thread_count |
将帧切分成块,由不同的线程进行 分别编码。0-4。 0 for auto |
rc-eq |
psz_rc_eq |
|
rc_eq |
|
--no-psnr |
b_psnr |
|
FLAGS(CODEC_FLAG_PSNR) |
是否开启PSNR. |
--no-ssim |
b_ssim |
|
没有对应值 |
|
--progress |
b_progress |
|
没有对应值 |
|
--bitrate |
i_bitrate |
b |
bit_rate |
编码输出的比特率,并启用 ABR(Average Birtate 模式(i_rc_method), |
qblur |
f_qblur |
|
qblur |
|
|
f_complexity_blur |
|
complexityblur |
|