米饭影视资源网

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
热搜: 活动 交友 discuz
查看: 14379|回复: 19

[教程] x264 设置(翻译及解释)

[复制链接]
发表于 2011-10-21 17:01:37 | 显示全部楼层 |阅读模式
解释x264命令可选项的用途和使用方法。同执行 x264 --fullhelp 显示顺序。本文主要翻译:mewiki.project357.com/wiki/X264_Settings,同时参考doom9 论坛、Silky Bible、以及其它互联网资料加以注解。
% E+ X, J: T" `! u1 w( S/ G词汇翻译:
4 }* W+ d4 Z1 f, |% [( ]0 W0 M* imacroblock:宏区块。是一种图像压缩的术语。
! U3 r) g( m! Z- P宏区块是运动预测的基本单位,一张完整的图像(frame)通常会被切割成几个宏区块。h.264 的宏区块大小是可变的,常用 16x16 pixels。( N8 X7 N" n" U/ _  I
帮助
$ r4 W' }& ~' H. h  a& x8 UX264 内置帮助文档。运行 x264 时带上 --help、--longhelp 或者 --fullhelp 即可看到帮助信息。三个选项给出的信息一个比一个详细。1 t9 \; W$ c4 y! z" s
输入  x& b! O7 a( _) t* W# D' ~, M1 i
使用单一位置参数指定视频源。如:
+ M& j9 `/ M& p9 b" `: {x264.exe --output NUL C:\input.avs( ~8 W8 u* U* U2 l+ Z3 O7 _1 Y; g' P3 G
x264 --output /dev/null ~/input.y4m
/ V6 x0 R& l* i. d; |当输入是原始 YUY 数据时,必须告诉 x264 分辨率。同样的还要指定帧率:8 [8 w9 a; K# Z5 D8 P2 V+ o& }
x264.exe --output NUL --fps 25 --input-res 1280x720 D:\input.yuv
8 f+ d9 @# H7 Q, jx264 --output /dev/null --fps 30000/1001 --input-res 640x480 ~/input.yuv  p: i: R  C* X% \5 T% Y

2 a% r3 ~$ J8 [0 D预置 选项
9 Z+ t, V* Y; Q4 z, C& i0 ]预设的成套选项,方便、好用、少出错。更详细信息参见 x264.exe --fullhelp
2 U' I+ x6 R, Q7 D: l6 j& o4 pProfile6 Q- W0 Q" q. I# c* G- N
默认值:未设置
- }9 ]! Z& K0 m限定编码输出流的等级。如果你指定了等级,它将取代全部其它选项,所以使用等级选项可以得到良好的兼容性。但使用等级选项,就无法使用无损压缩(--qp 0 or --crf 0)。# h5 N! K0 R8 v+ T. ^& t) J
如果你的播放器仅能支持特定等级的话,就需要指定等级选项。大多数播放器支持高等级,就不需要指定等级选项了。
: S8 D+ R/ U. d) R* P可选项: baseline, main, high.
/ }7 {' a8 Y" ~4 _: UPreset
3 K" K! h4 `3 |' B6 x, b. y; r默认值: medium
  U$ K/ s9 {/ ]9 `选择预设配置需要综合考虑压缩效果和编码速度。
8 @$ |/ M! b1 [% n修改 x264 参数顺序:预设配置先于其它选项。
9 G# h0 k7 J; i- Q7 y0 V& `最好设置为可以接受的 slowest。5 x, ^  }/ V2 p9 z" D
可选项: ultrafast, superfast, veryfast, faster, fast, medium, slow, slower, veryslow, placebo.1 X( ?' L# Y' ~! N5 p. z3 |$ U
个人体会:slow, slower, verslow 质量基本相当,slow 略差一点。placebo 反而不如那三个,但速度却慢的多。建议使用 slower。
) k( ^5 X3 t& ^7 H( VTune% \5 B! {8 u1 }; w
默认值: 未设置3 Q/ @/ r6 a3 l
对输入内容进行优化。
8 a+ ?6 K9 Y. I" a/ U$ J修改 x264 参数顺序:调优项后于 --preset,但先于其它选项。
( v/ X. h' t+ o' o3 ~如果源内容符合下面的条件,可以使用调优,否则就不要用。
1 G0 L' [$ B5 a9 D- ~6 v可选项: film(胶片电影), animation(动画片), grain(颗粒感很重的), stillimage(静态图像), psnr(信噪比。参见:http://baike.baidu.com/view/1624289.htm), ssim(结构相似性。参见:http://baike.baidu.com/view/1559204.htm), fastdecode(快速解码。主要用于一些低性能的播放设备), zerolatency(低时延。主要用于直播等).
  y( W/ f7 |) Nslow-firstpass
# J% _* t1 r" l# `; _默认值: 未设置
* s1 r2 x+ \* i& e% c--pass 1 选项隐含把下列参数追加到 x264 命令行末尾:; Q# o9 Y$ f/ n1 G7 }+ {# n+ }
•        --ref 1; K# D+ J2 x# f, x2 F" O
•        --no-8x8dct: J7 R2 A. F$ \" W
•        --partitions i4x4 (本来有,继续有;本来无,则没有)
$ F1 M5 D  c5 @) R•        --me dia
0 [1 H0 \- U- b4 x% H•        --subme MIN( 2, subme )' a! O+ X8 j6 H3 N* D
•        --trellis 0% d  r$ p; y0 U
可以使用 --slow-firstpass 关闭 --pass 1 这项特性。; H/ e) P( i7 H" H0 s# B# y1 t0 Q' E
注意:使用 --preset placebo 隐含应用 slow-firstpass 选项。
2 s/ @& n' F; ?2 ]参阅 --pass 选项。
2 u+ f9 B# `$ Y9 K1 E5 b+ h0 Z6 Y0 z! n9 P  n
帧类型 选项
/ y6 S9 l8 [( _8 h2 [. l“帧”基础知识:
; t+ F7 h$ H4 a  J9 f- r2 Y影片可以看作是由一张张连续的图片组成的,每幅图片就是一帧。压缩的视频由3种不同类型的帧(Intra (I) frames (也叫 key frames),Predictive (P) 和 Bidirectional (B) frames)组成。7 D; s: D3 `$ T  Z; Z  |: `
特定类型的帧之间可以参考,意思是一幅帧有时仅需保存自身与被参考帧的不同之处即可。不过参考模式会导致错误延续传播,即 X 帧出错,参考它的 Y帧也会出错,那么参考 Y 帧的 Z 帧也会出错。。。,后果很严重,所以视频里一定要有不能被参考的帧。% K$ S6 i) G, e$ `# m' B
I 帧需要包含完整图像信息,所以压缩的少,体积大。在视频播放中,跳跃式快进(快退)时需要 I 帧,有的视频快进后黑屏,就是在新的播放位置还没有找到 I 帧引起的。# O: V+ |6 e7 X2 i, w7 ^
P 帧保存自身与 I 帧或其它 P 帧之间的差异。P 帧可以被当作参考帧,它需要包含足够多的信息,由于采用运动补偿压缩技术,P 帧比 I 帧保存的内容少。: g  S( B9 D* w2 E. ~/ `
B 帧也是保存自身与其它帧之间的差异,它既可以参考它前面的帧也可以参考它后的帧(播放顺序),但是它不能作为参考帧(特殊的"B-frame pyramid" 除外)。H.264 支持"B-frame pyramid",这种特殊的 B 帧可以被另外的连续 B 帧参考,除此之外,B 帧不能被其它帧参考。B 帧的压缩最大,包含的信息最少。
* S% l$ U& x0 s9 t! M图像质量高、压缩率高的视频就是I、P、B 帧的完美结合。
1 b8 S% }+ h, SKeyint
9 X9 P/ F8 V4 L9 u2 [% {9 A默认值: 250 ; s2 I  i  [; e+ k- g8 [! ?
设置 x264 输出流中两个IDR 帧(也叫 keyframes 关键帧。IDR英文原意为“瞬间解码刷新”)之间的最大间隔帧数。也可以定义“无限”从而不再插入非场景转换 IDR 帧。
8 e! W5 c7 W* tIDR 帧就像视频流里的‘分隔符’,位于它前后(播放顺序)的帧之间是不能相互参考的。而且 IDR 帧也是 I 帧,因此它也不能参考其它帧。这些特性意味着它们可以作为视频跳跃播放时的新开始点。
9 O. z, U' r6 y, j1 N8 F一般情况下 I 帧比 P 或 B 帧体积大的多(在低运动场景中常常是10倍或更大),当和低 VBV 设置并用时会给码率控制带来极大的麻烦。关于这种情况,参考 --intra-refresh。
9 l/ y9 r- {) d: m默认设置适合大多数视频。但当用于蓝光、广播、生活录像或其它专业录像时,可能需要较小的 GOP (图像组。一个GOP就是一组连续的画面。)长度(常常为fps 的1倍左右)。7 t- `0 r2 ^7 K0 }" L
参照: --min-keyint, --scenecut, --intra-refresh
( }" V5 o8 ]2 r6 C$ Emin-keyint4 U2 w& C2 C- I* m' j9 ^  e) \
默认值: auto (取 --keyint/10 和 --fps 两个中的最小值)0 r! P1 o& d0 g
设置两个 IDR 帧之间的最小间隔帧数。
3 ]$ M. x. e1 g2 `" C1 g阅读 --keyint 了解 IDR 帧。非常小的关键帧范围会造成错误放置 IDR 帧(例如:频闪场景)。选项限定在每个 IDR 帧之后放置 IDR 帧的最小间隔。
1 T; N6 {2 {0 ?min-keyint 最大允许值为 --keyint/2+1  c+ m! F) C) i. |4 t' {. g
推荐: Default, 或 1倍的framerate.
3 o3 |+ n& z+ d2 V% B参照: --keyint, --scenecut
+ J; ]6 z6 e9 n! w. p; j+ ino-scenecut
" n! C9 O. v% Z+ m" M默认值: 未设置6 f5 X. k0 q* i$ M" L4 t) |
完全关闭自适应 I 帧决策。6 B: G8 {3 b4 f4 M4 m
参照: --scenecut: V' h5 L8 C5 F  r/ ^  a' B3 I( o
scenecut
( y" C: o2 u& o' U4 N- y& T& V默认值: 40
* ]2 d: k" n: j- e' E/ a8 d设置放置 I 或 IDR 帧的阀值(阅读:场景变换检测)。9 h& n7 Q) _" ^0 H$ L5 _" d
x264 为每个帧计算一个度量来评估它与它前面的帧有多大不同。假如值小于 scenecut 设定值,意味着发生场景切换。如果此帧与前面最后一个 IDR 帧间隔小于 --min-keyint 就放置一个 I 帧,否则就放置一个 IDR 帧。过大的 scenecut 值会导致产生大量的场景切换。欲详细了解场景切换的比较过程,请参考http://forum.doom9.org/showthread.php?t=1211160 F  p- t1 F, H/ @  }
scencecut 设置为0时相当于--no-scenecut。8 Y' `* M; i; v7 W% r
推荐: Default, a" l- l, \; t; C1 S( E3 _
参照: --keyint, --min-keyint, --no-scenecut% ^2 h9 K5 a; \, B6 e; \/ y
intra-refresh- N! q* h# H4 S: s  n' k, {
默认值: Off
! ~- K1 ~0 Y6 y) w禁用 IDR 帧,取而代之的是 x264 对位于 --keyint 位置的帧采用宏区块内编码方式。这样做的好处是可以获得比使用 IDR 帧更恒定的帧大小,对要求低时延的视频流更有利。同时也增加了丢包后的视频流恢复能力。这个选项会降低压缩率,因此仅在确有必要时才使用。& K1 _2 |. _& g/ g* y
个人理解:IDR 帧虽然也是 I 帧,即本身是自解码帧,不需要参考其它帧来解码。但是 IDR 帧内部各宏区块之间是互相参考的,如果传输过程中某宏区块丢失,会导致整帧无法解码。* Y; u6 l! ?5 Q4 k) w+ G- b0 X% k
Bframes) g9 y% k6 B0 C5 n* ?$ C* N5 H
默认值: 3 * G% {/ n5 K% \1 V- _
设置 x264 可以使用的最大连续 B 帧数量。
* J$ p1 @: ^  i# t如果没有 B 帧,典型的 x264 流的帧类型就像:IPPPPP...PI。如果设置 --bframes 2,两个连续的 P 帧将被 B 帧代替,就像:IBPBBPBPPPB...PI。
" `0 }$ ]# r7 j/ j2 a0 p. c除了 B 帧可以参考后面的帧(播放顺序)外,B 帧和 P 帧差不多。向后参考可以极大提高压缩率。B 帧的平均质量由 --pbratio 控制。) C8 z& n7 E  I( d
有趣的现象:
* u- Z" M4 p  \, {; p•        x264 偶尔需要区分两种不同类型的 B 帧。一个‘B’帧可以参考另一个用于被其它帧参考的 B 帧(见 --b-pyramid,这里的 ‘b’指的是参考了别的B帧的帧,而 B 不是。假如你看到既‘b’又有‘B’,就是这个意思。当不需要区分的时候,用‘B’代表所有的 B 帧。)3 m0 g! ~0 \( t& a6 S" U) z
•        欲详细了解 x264 压缩时如何把候选帧确定为 P 或 B 帧,请参考http://article.gmane.org/gmane.comp.video.ffmpeg.devel/29064。这种情况下,帧类型看起来就像(播放顺序)(如果 --bframes 3):IBBBPBBBPBPI。
$ g2 I7 b- m! W% D参照: --no-b-adapt, --b-bias, --b-pyramid, --ref, --pbratio, --partitions, --weightb
1 r9 o6 p4 }% A( p' `$ Zb-adapt
- q% z9 \  }8 N. Y' i默认值: 1
  [8 p% h) d0 L$ C设置放置 B 帧决策算法。控制 x264 如何在 P 或 B 帧之间抉择。6 K' u7 o9 s, U1 O0 ^& e7 }
0.关闭。总是选择 B 帧。与老的 no-b-adapt 选项相同。7 x, R. t% C  N: j  i; o
1. 快速算法,较快的,当 --b-frames 值较大时速度会略微加快。采用这种模式时,基本都会使用 --bframes 16。$ u2 V" r% F) G; H( B. }3 ]
2.最优算法,较慢的,当 --b-frames 值较大时速度会大幅度降低。2 q) v5 Q* ]* t  W, a
注:当采用多遍编码时,仅需在决定帧类型的第一遍编码中使用。! n4 i0 n" N+ s8 w) h' Q- v) D4 @
b-bias; a% f5 \3 n8 v$ ^* g0 c- ^+ Q
默认值: 0 . Z5 R& ~8 t2 ~0 ?
控制用 B 帧代替 P 帧的可能性。值大于0增加采用 B 帧的可能性,小于0则相反。这个数没有度量单位。范围从 -100 到 100。值100不保证都是 P 帧,值-100不保证没有 P 帧(真想没有 P 帧可以使用 --b-adapt 0)。
% H  \, S3 ~4 X仅当你感觉能比 x264 更好的控制码率的时候采用。
1 G4 C8 d, F2 R9 y参照: --b-frames, --ipratio/ m& Q( N" ]5 K
b-pyramid6 M5 A4 d! ]. l0 p7 [
默认值: normal
: H; A9 \" S( L% F0 t9 J: Z8 k7 W允许 B 帧作为其它帧的参考帧。不设置,就只能参考 I 或 P 帧。尽管高质量的 I/P 帧作为参考帧更有价值,但 B 帧也可以作为参考帧。作为参考帧的 B 帧将被量化至 P 帧 和普通 B 帧之间(所谓的半量化)。 --bframes 至少为2时B-pyramid 才开始工作。% A6 K% d$ y# Y
压制蓝光时,使用'none' 或 'strict'。; {. D5 V/ {- I: @; e
•        none: 不允许 B 帧作为参考帧。, j. G; d: \' \8 W1 a
•        strict: 蓝光标准强制性规定:每个 minigop 中只允许一个 B 帧作为参考帧。2 z! q" F; y8 g3 v8 V
•        normal: 每个 minigop 中允许任意数量 B 帧作为参考帧。0 M6 q% p; y8 S! E9 n1 N1 v
参照: --bframes, --refs, --no-mixed-refs5 y6 ]: t) y( ^) S# i! L1 h
open-gop1 u/ f% d" h5 q; i$ g1 [
默认值: none9 f6 B% C; ]( ^5 d
Open-GOP 是一种提高压缩率的编码技术。有三种模式:; K7 b0 X$ ]+ F0 t7 ~: S
•        none: 关闭
0 V) D2 d& |. c9 _•        normal: 启用2 |6 P& }5 E, e# N3 S
•        bluray: 启用。一个较低效率版本的 Open-GOP,当压制蓝光时 normal 模式不能工作。: L2 V2 I& z: v6 M" x; t
一些解码器不完全支持Open-GOP 流,这就是为什么默认是关闭的。你需要测试播放视频流的解码器,或者等到Open-GOP 被普遍支持。8 v7 ?' N% N6 r+ N" @
Open-GOP 的解释:http://forum.doom9.org/showthread.php?p=13001248 ]6 Q" ~5 Y. [# f% n+ w
no-cabac
# K; D" v3 C8 B/ |1 g7 O2 ]+ C默认值: 未设置
8 G+ P2 J7 E7 C禁用CABAC (Context Adaptive Binary Arithmetic Coder) 流压缩,转而使用较低效的CAVLC (Context Adaptive Variable Length Coder)。显著降低压缩率(一般为10-20%)和解码能力要求。
7 ?( ~- H) Q+ l6 zref
, g- V/ M: x' \. L8 `# ]) m默认值: 3
7 \! {" [. \7 \( S& m4 z2 R控制 DPB(Decoded Picture Buffer(已经解码图像缓存))大小。范围为0-16。简单的说,就是每个 P帧可以在它前面多少帧中选取参考帧(B 帧要少1个或者2个,取决于它们是或否作为参考帧)。最小值是1。
9 i/ Q; `1 h8 _1 O" R4 J2 v6 \4 NH.264规范限定每个 level 的 DPB 大小。如果遵守 Level 4.1 规范,720p 和 1080p 视频最大的 refs 值为9和4。' A0 M, p' W- k$ ?/ O3 F
参照: --b-pyramid, --no-mixed-refs, --level( e- b1 _- }. o! u1 I" f9 k% Y! u
no-deblock. u; _2 `* u* X+ w7 F; R4 d! j7 o
默认值: 未设置
% b/ E' Y0 L8 w关闭 loop filter(环内滤波)。不推荐。
( M8 D/ K: s2 f: z) R1 Z* u参照: --deblock3 B" N- N* P' P' ?3 F6 Q+ X7 O
deblock/ K4 Y& W' J2 |( q- N/ \8 c+ z
默认值: 0:0
  z) O+ T- W) W: C5 c1 N控制 loop filter(环内滤波。也叫 inloop deblocker),是 H.264 标准的一部分。就平衡编码时间与图像质量来说它非常有效。& J( k  c7 S& U" {
参考 http://forum.doom9.org/showthread.php?t=109747(楼主帖和 akupenguin 的回复)来了解 loop filter 参数如何工作。+ H. |9 B  n" I, ^
注:楼主(*.mp4 guy)的描述有误,仔细看 lovelove 的回复。
9 Q4 T5 K& u  v0 H# M# U参照: --no-deblock
' Z+ Q( B/ C* `& Z5 |8 J- \% {slices
, e" a$ u4 f. b! |" U默认值: 0 9 N& m/ F& v; g. ?. @7 v
设置每帧的分片数量,并且强制矩形分片。# L; c( U: i# S- B
编码蓝光时设为4,除此之外不要使用这个选项,除非你知道你在干什么。
# W' P$ L* o1 ?; @参照: --slice-max-size, --slice-max-mbs.
, a9 ?$ L& \. _5 F( k8 D6 x1 Oslice-max-size' n6 R6 i# f! X$ }
默认值: 0* J; z0 W  z% u- R0 w* U
以字节为单位设置切片最大尺寸,包括预估的网络层开销在内。(目前和 --interlaced 不兼容)
- u8 B# ?" d# I* A4 m- P6 b参照: --slices
* B! @/ y, G- _slice-max-mbs4 I& E( X* _0 l* C
默认值: 0  l$ E0 d7 i5 b: U0 \$ t
以宏区块为单位设置切片最大数。(目前和 --interlaced 不兼容)- Q8 j' [- g* L9 p/ p: i8 l
参照: --slices  f/ L0 A6 _. p. y* l3 b
tff
$ S/ q3 Y$ w# f4 i* {开启隔行编码方式,并指定 top field(顶部图场)在先。x264的隔行编码使用 MBAFF,不如逐行编码效率高。因此,只有需要在隔行扫描设备上播放时才开启隔行扫描编码(或者是视频流在送给 x264 之间无法完成反隔行变换)。隐含应用 --pic-struct。
( D6 Z/ O; `: Xbff; @7 k& Q/ _* J  R& G
开启隔行编码方式,并指定 bottom field(底部图场)在先。更多信息见 --tff。  v% p7 T( p0 f0 S
constrained-intra, s$ R$ w. |2 R/ @9 s( h4 _: x
默认值: 未设置
9 _& H$ U2 X, |" b& n开启强制内部预测,这是 SVC 编码的基本要求。由于 EveryoneTM 放弃了 SVC, 你也可以无视这个选项了。
* o7 [; N, [' i  G0 [pulldown
8 V' V; G2 y& h( e6 _默认值: none
8 V/ B9 \. M' G  y; i" v2 V‘软’胶卷过带(逐行,恒定帧率。之所以叫‘软’是因为大部分胶卷过带是硬件实现的)。更多解释见http://trac.handbrake.fr/wiki/Telecine。可选项:none, 22, 32, 64, double, triple, euro.
# r9 t4 I% g7 i+ {  V除 none 外其它选项隐含应用 --pic-struct。
3 f* d  ^' R/ ^. O% R- WTelecine(胶卷过带)和 IVTC(inverse telecine。反胶卷过带)实现方法:1 R9 N: }6 c' T; d8 k0 ^4 z
电影原本是 24fps 的,如果要在 NTSC 制式的电视上播放,就需要胶卷过带,在此过程中,会把影片经过 3:2 pulldown 转为 30fps。+ s6 j, W3 s0 u, Y. m
把电影原本的 1 2 3 4 四个帧,拆成 1o 1e 2o 2e 3o 3e 4o 4e,每个帧拆成奇数扫瞄线组成的奇数图场(Odd Field)和偶数扫瞄线组成的偶数图场(Even Field)。重新组合如下(以 Odd Field First 的顺序)
" k: Q. v% e7 }' R4 O1o 1e - 2o 2e - 2o 3e - 3o 4e - 4o 4e; r0 [3 A) s# O+ V
[ A ] - [ B ] - [ C ] - [ D ] - [ E ]
; o5 E1 ~, z. S! s9 X每两个 Field 再重新组合成一个帧,就变成 [A][B][C][D][E] 五个帧。这样由原本的 4 张变成 5 张,4*6 = 24 => 5*6 = 30,就能从 24fps 转为 30fps。
, l' j, a# q0 D; d理解了胶卷过带,再理解 IVTC 就容易了。IVTC,将 30fps 转回 24fps,这样压缩的画面张数由 30fps 减少为 24fps,少了 20%,等于码率增加 20%,而且画面无交错容易压缩,所以压出来的画质会好很多。$ M1 L, ~8 e! P. M7 W: u
fake-interlaced
  D0 k) S3 Q9 i) `默认值: 未设置
4 g" l( X+ j8 Y2 S, ~7 g4 k把视频流标记为隔行方式,即使它不是隔行方式编码。允许编码 25p 和 30p 蓝光兼容视频流。
* `( G  {' R6 _& A, ~
$ G& ]7 u6 D" a. Z+ b码率控制+ }& s9 M' x  T) W; F  b4 k
qp
0 A& U$ _/ l5 j) U默认值: 未设置
+ I& r$ K6 B% }( n% v3 p: k三种可用的码率控制方法之一。以恒定量化值(Constant Quantizer)方式编码。此选项的参数用于指定 P 帧量化值。I 和 B 帧的量化值由 --ipratio 和 --pbratio 控制。CQ 模式的目标是恒定的量化值,这就意味着最终文件大小不可知(尽管能用一些方法预测)。参数 0 表示无损输出。同等的视觉质量下, qp 比 --crf 产生的文件要大。由于固定量化值的缘故,qp 模式会关闭自适应量化。; I3 G( K  c$ [# \0 m  o
本选项与 --bitrate 和 --crf 是互相排斥的,就是三选一的意思。欲详细了解码率控制,参见http://git.videolan.org/?p=x264.git;a=blob_plain;f=doc/ratecontrol.txt;hb=HEAD
2 R# J* A6 l- C3 O可以使用 --crf 代替 qp,不过 qp 模式不需要预分析会更快一些。) J9 O+ q, F. E* G, k
参照: --bitrate, --crf, --ipratio, --pbratio
/ H& E: b: E2 _( M9 h0 A7 J+ hbitrate
; n1 B9 g9 T  E; s2 v默认值: 未设置
7 f2 u/ n7 Q: {码率控制方法之二。以比特率(bitrate)作为目标的编码方式。最终文件大小可知,但最终图像质量不可知。x264 把给定的比特率作为总平均值来作为目标,也就是说每帧的比特率可能不符合给定的比特率,但是总体平均比特率符合给定的比特率。比特率的单位是 kilobits/sec(8bits = 1字节)。需要注意的是 1 kilobit 是 1000 bits,而不是 1024 位。
/ B6 A% T2 c; Z/ w' j/ g这个选项常和 --pass 一起用于2遍编码。
4 J- w" n9 b$ t/ g  L" m  [本选项与 --qp 和 --crf 是互相排斥的,就是三选一的意思。欲详细了解码率控制,参见http://git.videolan.org/?p=x264.git;a=blob_plain;f=doc/ratecontrol.txt;hb=HEAD; x+ t5 z! s2 u" M
参照: --qp, --crf, --ratetol, --pass, --stats/ }$ |! ^2 G6 I5 b2 X
crf
* T  o8 @7 Z3 |默认值: 23.02 d( x9 h( y0 V' e$ _( r9 G) k
最后的码率控制方法:恒定比例因子。(Constant Ratefactor。也叫恒定质量)。qp 的目标是确定的量化值,bitrate的目标是确定的文件大小,crf 的目标是确定的‘质量’。这个概念就是 crf n 能给人以 qp n 相同的视觉质量,仅仅体积小一些。crf 的单位是“ratefactor”。
, a3 }4 G" x; ^6 v- v' ]9 X4 ccrf 依靠降低‘不太重要’帧的质量来达到减小体积的目的。在这里,‘不太重要’是指帧包含复杂或高速运动的场景,在这些地方保持与其它地方相同质量的代价很高(即耗费比特)且又缺乏可视性(就是正常播放的时候看不清楚的意思),就增加它们的量化值(量化值越大图像质量越差)。把节省下的比特用到刀刃上。6 ]. s$ Z4 g& A' `$ K
crf 比2遍编码方式节省时间,因为它少了一次编码。另外,crf 的最终比特率是不可预测的,即文件大小不可知。使用哪种码率控制方式取决于你。
6 @2 o. G) X+ {本选项与 qp 和 --bitrate 是互相排斥的,就是三选一的意思。欲详细了解码率控制,参见http://git.videolan.org/?p=x264.git;a=blob_plain;f=doc/ratecontrol.txt;hb=HEAD' y+ ?: O1 Y) J; E
参照: --qp, --bitrate
& X* k* R" O% o( h5 M0 rrc-lookahead, W: r5 J8 l  [
默认值: 40
! i. s+ z% y! U- \: i7 R设置用于 mb-tree 码率控制和 vbv-lookahead 的帧数。最大允许值为250。
4 G& b# j* G* `& j对于 mb-tree,增加帧数能得到更好的结果但是会更慢。mb-tree 的最大值是 rc-lookahead 和 keyint 中的最小数值。
4 Y  {# ]: ], h* `4 Q2 ^8 H对于 vbv-lookahead,增加帧数会更稳定和精确。vbv-lookahead 的最大值是:MIN(rc-lookahead, MAX(--keyint, MAX(--vbv-maxrate, --bitrate) / --vbv-bufsize * --fps))- h, }0 i. J7 U% Q# H
参照: --no-mbtree, --vbv-bufsize, --vbv-maxrate0 l# \( b( S" F* q+ ?7 u
mb-tree 的解释:http://baike.baidu.com/view/3098244.html
' x: n0 A* P# ?5 p: [+ [7 K) ~vbv 的解释:http://baike.baidu.com/view/1519233.htm
' Q2 h- R  }/ v& U" fvbv-lookahead 是vbv 预检测。# \: }8 c  n. T( J) {
vbv-maxrate1 ^* g/ \4 ?9 a; }0 x  [
默认值: 0
; v" l( D& ^( K; n* u) T设置 vbv 缓存被再充满的最大码率。由于 vbv 缓存充满会造成溢出,为防止溢出发生,视频的最大码率不能超过 vbv-maxrate。, T4 U" u2 k6 g% I+ E0 y, g
vbv 降低图像质量,仅在确实需要时再使用。
, z; N2 A; B! b# k7 I8 ^! ^参照: --vbv-bufsize, --vbv-init 和 vbv 编码建议:http://mewiki.project357.com/wik ... stions#VBV_Encoding+ n- M; N5 K/ M! R- q+ R/ k
vbv-bufsize
% u! B' S8 z9 L7 R默认值: 0
9 n+ W; n: a% y8 W1 ], _以 kilobits 为单位设置 vbv 缓存大小。
$ k* C1 F7 ]: _0 U/ wvbv 降低图像质量,仅在确实需要时再使用。
* m. A, n& I% A( G* D9 t' \参照: --vbv-maxrate, --vbv-init 和 vbv 编码建议:http://mewiki.project357.com/wik ... stions#VBV_Encoding
- s! E: @" k! t5 K2 {  i) Qvbv-init- _- ]7 q+ m7 |0 B: [4 I
默认值: 0.9 % P3 N9 j  j/ _$ r4 l9 z" B
设置开始播放前 vbv 缓存必须的充满率。4 `7 U; F  b0 u" X1 P3 t5 ~8 [- }8 b
假如小于1,初始填充量为 vbv-init * vbv-bufsize。反之则是单位为 kilobits 的初始填充量数值。
' N# E! t+ g' N) _2 a4 g参照: --vbv-maxsize, --vbv-bufsize 和 vbv 编码建议:http://mewiki.project357.com/wik ... stions#VBV_Encoding
. h3 j- c4 ^* S( Y2 b  m% Q. R& xcrf-max- U% F& f. k7 f& p4 t8 K
默认值: 未设置7 H" V3 @+ t# Z7 v
类似 --qpmax,除了把指定最大量化值改为指定最大比例因子。仅当使用 crf 并且 vbv 有效时起作用。让 x264 即使违反 vbv 约束也不能把比例因子(也叫“质量”)降低到给定值之下。常用于定制的流媒体服务器。更多信息参见:http://git.videolan.org/gitweb.cgi/x264.git/?a=commit;h=81eee062a4ce9aae1eceb3befcae855c25e5ec52- |# }) B5 E$ H+ c/ y# `
参照: --crf, --vbv-maxrate, --vbv-bufsize- |; F  [& C: Q+ U3 @. v
qpmin
7 s  h8 T4 Y! b" G0 M1 C2 J- t默认值: 0" U1 f/ v& w$ M( D2 w
定义最小量化值。量化值越低,输出越接近输入,到某个量化值,输出看起来就和输入一样,尽管并不是真的相同。通常没有理由让 x264 在特别宏区块上浪费码流。- G- y7 ~$ u/ t, i
当自适应量化开启时(默认开启),提高 qpmin 是不可取的,因为这样会降低帧中平坦背景区域的画面质量。
( Q" N: }; h; s; E3 j0 i参照: --qpmax, --ipratio
# \( Z8 A6 B: h: qqpmax
9 A, p6 ~) w" L( W* u6 E9 I默认值: 51
+ V; k; ~2 p  s% J和 qpmin 相反,定义最大量化值。51是 h.264 规范中可以采用的最大量化值,质量相当低。默认值相当于禁用 qpmax。假如想控制输出的最低质量,也许你会把它设的低一些(30-40是你能设的最低值),但不建议调整它。
6 u; h( K0 R: J  Z( s4 u! }; D参照: --qpmin, --pbratio, --crf-max! G9 f4 Z! a6 C) ^" f
qpstep2 P3 K; s# Z- ^( n# @
默认值: 4) ^9 L) ^  P0 U1 `
设置两帧之间量化值的最大差值。
( [8 `  H" I- |% {ratetol
/ A6 C% t+ S3 C; v默认值: 1.0
0 Z8 ^( F3 w/ \- H这是一个双用途参数:" ?0 D% U8 t% d% @( q
•        在 1-pass 编码中,告诉 x265 可以与设定比特率相差百分之几。可以设置为‘inf’来彻底关闭码率溢出检测。最低可设为0.01。设的高些有利于 x264 处理影片末尾的复杂场景。单位是%(例如:1.0 就是 1% 的比特率偏差)。$ p1 V* ^. A' C9 ~0 z/ R* a
许多动作片等,结尾都是火爆场景。但 1-pass 不知道这些,常常会低估影片末尾的码率需求。inf 参数让编码更像 --crf 模式来缓解这个问题,但文件大小会超标。
+ D& S' K, G+ O; g•        当 vbv 启用时(例如:使用带 --vbv 前缀的选项),这个设置也影响 vbv 的作用强度。设的值越高,vbv 的波动范围就越大,甚至会有突破 vbv 设置极限的可能。由此,度量单位可以是任意的。5 r8 q  E2 F) g2 [
ipratio; B) x. w/ }# Q% u; ^( X; u& q" G
默认值: 1.40
& C' h7 S' C/ h) P- R修改 I 帧量化值比 P 帧量化值的平均增加量。值越大生成的 I 帧质量越高。1 u% o! c$ E; \: f3 K
参照: --pbratio
$ D- j7 r9 a5 g/ _2 zpbratio6 p- f/ \- d( E+ d
默认值: 1.306 ]. R5 R: F+ l" t" L5 h6 D
修改 B 帧量化值比 P 帧量化值的平均减少量。值越大生成的 B 帧质量越低。不能和 mbtree(默认开启)一起使用,mbtree 会自动计算 B 帧最佳量化值。3 V% ^  Z& M5 }
参照: --ipratio  {5 {$ p( ]" S, Y: i( x$ B+ E/ t# f7 I
chroma-qp-offset$ T1 i! n/ l" C
默认值: 0" S3 o! c6 ^2 g5 {4 a0 n. }4 n3 f
给色度的量化值增加一个偏移量。可以是负值。
* b) f" A1 ~. a: n当开启 psy-rd 和/或 psy-trellis 时,x264 会自动减小偏移量来提高亮度质量,造成色度质量下降。默认从偏移量中减2。) V8 a" f) b" M% d- {
注意:在 q29以下,x264 对亮度和色度以相同量化值进行编码。超过29后,色度量化值的增长率小于亮度,直至亮度达到 q51 和 色度达到 q39。这是 H.264 标准要求的。
5 `8 U. ]2 z) H* ~/ h/ g7 f6 ^) I3 l$ Taq-mode
; \# g9 c) C/ H$ _  e自适应量化模式7 z8 u# d# l! N2 q
默认值: 1
6 G6 a2 n, X8 s# |! R' m不用 AQ,x264 倾向于给缺乏细节的场景分配较少的码流。AQ 用来把可用的码流更好的分配给所有的宏区块。此选项用于改变 AQ 重新分配码流的范围:
1 L6 ]! u) U! A# f0 o•        0:关闭 AQ。
6 S% `6 A+ ]) L3 F6 b. O•        1:在整个视频范围和帧内部分配。
; N) m$ ~5 F- E5 G- {•        2:根据帧的比重自动分配(实验性质)。: B+ m6 {, }/ ^# `$ g; ?. M
参照: --aq-strength
1 J0 H4 B/ j0 Q4 e7 F5 jaq-strength% K. @: S# y- E, w" k( A
自适应量化比重9 m3 u+ w$ j* Z% i6 h
默认值: 1.0' e. {9 ]# E" j9 T+ p
让 AQ 向低细节(平坦、单调)宏区块倾斜。不允许负值。
/ O3 S+ t- W4 o) N参照: --aq-mode
$ \7 E9 X( ?. w. c0 n/ Bpass0 U! _6 r' x- v/ b5 X9 o1 H
默认值: 未设置
6 A7 A8 J; p4 |8 r/ n. W; W这是两边编码的重要选项。控制 x264 如何处理 stats 文件。有三种设置:
3 [# K/ S& Y- O9 I•        1:生成新 stats 文件。在第一遍编码时使用。. b! @0 K5 }0 W$ Z5 C
•        2:读 stats 文件。在最终编码时使用。
+ B# C4 P/ @) J( Q•        3:读 stats 文件,并更新文件。
+ F# x. ]) ~2 n" k1 n, fstats 文件包含每个帧的信息,x264 用于提高输出质量。第一遍编码时生成 stats 文件,第二遍编码时利用它来优化视频。最佳用途是码率控制。
' Q% p+ R3 c. c6 H* k3 I( O参照: --stats, --bitrate, --slow-firstpass X264_statsfile
& z! L1 y: H4 W% \) R9 F  Estats
! P  b2 ?3 r4 s( y0 P默认值: 'x264_2pass.log'
4 ?* O2 K0 Q+ F+ x1 |- t& n7 g& @5 w设置存放 stats 文件的位置及文件名。
6 ~1 y: M! j8 o; ?( s( T参照: --pass" F2 V2 g& M# s1 |
no-mbtree
/ A! E) [, ~, \; d& r) R默认值: 未设置
( _2 R, E, r+ S$ U+ ?禁用宏区块树(mb-tree)码率控制。使用宏区块树跟踪宏区块在帧中的使用情况和权重可以提高压缩率。需要生成一个很大的状态文件来保存数据。
# F& q8 k8 u" {. H: m7 Q推荐: Default/ }, o6 F6 D: X, J! {3 U
参照: --rc-lookahead  Y4 x3 G, o) h: U5 a
qcomp( Q/ t% ]& }: v  N" j& E' [
默认值: 0.60* S2 i$ N5 _* g4 C6 `- o2 U
量化值曲线因子。0.0 趋向于 恒定比特率,1.0 趋向于 恒定量化值。. g/ f" ^4 V$ H6 j2 `
当和 mb-tree 连用时,影响 mb-tree 权重。(高 qcomp 等价于减弱 mb-tree)5 @4 G, @3 g' V5 J3 L
推荐: Default/ _/ M; t- q' t" K6 Z5 c
参照: --cplxblur, --qblur
1 v8 ]/ z* {7 N% G0 C2 o& `cplxblur# k# U/ p! o0 Q
默认值: 20
9 |% y+ k) y2 C以指定的半径对量化值曲线应用高斯模糊滤镜。就是通过模糊相邻帧的量化值来达到限制量化值波动的目的。
. u# m# A8 e  n, D参照: --qcomp, --qblur
  v0 r8 l8 X* p. o! yqblur8 b0 c7 a4 e% u% @  B. Z+ m' W
默认值: 0.5
' E2 B" x. L  Y1 _* w: }/ S在量化值曲线压缩后,以指定的半径对量化值曲线应用高斯模糊滤镜。这个设置不重要。
; y3 S& M* [  `3 f: P$ |5 L1 O参照: --qcomp, --cplxblur0 n! z7 g4 w5 t4 [3 d2 n2 D( w  m  Z
zones0 ~; a: ^/ m* F  O! F
默认值: 未设置
9 i: `7 O0 F# z) U! |% D/ w可以把视频分段(zone),对每段分别设置压缩选项。你可以修改 zone 中的大部分 x264 选项。( g5 C# k6 c6 Y" a
•        单个 zone 格式为 <start frame>,<end frame>,<options>+ B* ], r+ C% H% u2 d+ z  m  Y0 z
•        多个 zone 之间用 '/' 分隔。' A, G8 c! G2 W$ I& R
zone 选项:
* I' z) v: u% T$ }  ?* m有两个选项比较特殊。可以仅设置一个,假如你设置一个的话,它必须是这个 zone 中的第一个选项。( C7 U7 p% ^" X; L* |
•        b=<float> 乘以原有 bitrate 是 zone 的 bitrate。有益于高速和低速场景优化。
. a4 e2 l- O( d1 y! Z4 I$ U+ E•        q=<int> 为 zone 提供一个恒定量化值。可以对一部分帧单独优化。
! f, J: z, ]: F/ r其它可用选项如下:
* R" D9 H" s8 E- ?•        ref=<integer>
* }$ h- d) a3 \5 p% `+ }•        b-bias=<integer> , }) h9 u. D1 A  r$ D7 m9 A; f
•        scenecut=<integer>
& J$ i% \3 A, Y5 U•        no-deblock
8 v/ G: [4 k2 S( z•        deblock=<integer>:<integer> 6 |2 U  O* s0 q1 S2 I( g# B2 x
•        deadzone-intra=<integer>
( x+ R- ]7 b; g/ L8 a•        deadzone-inter=<integer> ! f2 P; T1 B9 U' u
•        direct=<string> 5 z$ t2 ^; }! n1 p0 {
•        merange=<integer>
; [8 F* y+ x: m: l" K* e•        nr=<integer>
" t4 q5 a+ D6 n  ~9 d& d( P•        subme=<integer>
+ O8 _# f& b, b5 e) ^9 U- B  O2 X•        trellis=<integer>
$ p& l( o& t! i" |# k. Y•        (no-)chroma-me 8 m4 X# q1 u3 U
•        (no-)dct-decimate 3 X5 C* f  }6 o' \& O9 k( h- n
•        (no-)fast-pskip
) M2 [; O* N" _•        (no-)mixed-refs
# ^; V' Y7 ?: h8 [•        psy-rd=<float>:<float>
4 m6 J, b% q) y! ?5 u, h•        me=<string> ) _* T1 H( j8 q
•        no-8x8dct
, H8 L  `+ Z1 Y, r6 @+ A8 i•        b-pyramid=<string>
4 j2 v. [2 ~' \+ N( m, X限制: 9 b( w6 ?5 r7 |" v
•        zone 的参考帧数不能超过原有 --ref 定义值。% z& V# A: g0 c- Q4 D' @
•        不能在 zone 中 关闭 或 开启 scenecut;如果已经开启,仅可以修改。+ h) @) F2 K# d! r" s6 _( V
•        如果 subme 原有值为 0,则不能修改。
8 f; g: O" E2 Y  f( e8 @1 D$ A. `•        如果 --me 原有值为 dia, hex 或 umh,则不能设置为 esa 或 tesa。
% ?: P0 e, ?: e. @. _- d. K•        如果 --me 原有值为 esa 或 tesa ,则不能超越。
. u6 y1 y& w5 O: {例子: 0,1000,b=2/1001,2000,q=20,me=3,b-bias=-10003 O7 o) Y" d( Y+ w6 k. Y6 f  b4 R
建议: Default
# q/ p% {. i, q( X; uqpfile  m$ \4 Q& ^6 U/ ~' Q1 @8 n' }/ f
人为改变标准码率控制。提供一个文件用于指定特定帧的 量化值 和 帧类型。格式为‘帧序号 帧类型 量化值’。例如:
, y# a0 o3 E5 p9 o* y7 N6 S9 F0 I 18 < IDR (key) I-frame4 p8 F! ]7 h. F" r
1 P 18 < P-frame; I5 v) a7 @+ g& S# o+ h3 O
2 B 18 < Referenced B-frame8 ]8 O; h8 x2 ?3 D3 L
3 i 18 < Non-IDR (non-key) I-frame
+ V7 A0 s0 ^: J! [, X3 B4 b 18 < Non-referenced B-frame% N3 P$ x+ {8 A4 T+ d
5 K 18 < Keyframe*4 l$ C" N) |8 s
•        不需要指定每一帧。7 t, p$ w+ A% x. j7 S
•        把量化值设为 -1等于让 x264 自动判断最佳量化值,当仅需要指定帧率时有用。
2 X2 K' R2 K" z" I% g•        如果大量指定帧类型和量化值并且还让 x264 自行优化的话,会降低 x264 执行效率。- t! z+ a' ?# D
•        假如设置 --open-gop none,则 'Keyframe' 等价于是一个 IDR I帧的普通关键帧,反之,等价于是一个带恢复点标志 SEI的非 IDR I帧。
* B6 }% U( q' M4 i1 \: \$ r- d
( N) ~- b6 _# j& J5 p  U分析 选项
3 X$ y! i' u" K: q% j' I( h% N5 rpartitions
* ?; A, D! Z2 P( ]0 y- t6 Q, H默认: 'p8x8,b8x8,i8x8,i4x4'
( }2 L( P7 F: Z压缩过程中视频被分割成16x16 的宏区块。这些块能被进一步分割的更小,这些就由本选项控制。
, z4 V8 L9 I8 c  [9 o& \  E# a' h2 c- t使用本选项,你可以单独定义分割类型。分割类型按帧类型(如:I, P, B)分类。可用的分割类型为 p8x8, p4x4, b8x8, i8x8, 和 i4x4。- P4 K' a& c- k0 K- X- I
•        I: i8x8, i4x4
; k* d  j& M* \8 x  `•        P: p8x8 (亦包含 p16x8/p8x16), p4x4 (亦包含 p8x4/p4x8)+ a% A) |9 K. R9 k
•        B: b8x8 (亦包含 b16x8/b8x16). A# g7 h# ]6 n$ U$ `
你也可以设置为'none' 或 'all'+ l  o2 @& A& l" V+ b0 Y& b
p4x4 通常不太有用,通过使用它来增加图像质量将极大的降低压缩速度。
( N3 S; p. `' U参照: --no-8x8dct* p6 v: U# ^& k
direct3 b1 C* ?5 m9 Y3 p: ]
默认: 'spatial'
3 Z, _3 V( Y3 p& R设置直接运动矢量的预测模式。有两种模式:空域和时域(spatial, temporal)。你也可以选择 none 禁用直接运动矢量,或选择 auto 让 x264 根据情况在两种模式之间切换。如果设为 auto,x264 会在编码结束后输出相关信息。auto 在两遍编码方式下工作的很好,而且在单遍编码下也可以工作。在第一遍编码为 auto 时,x264 保存每种方法的平均执行情况,并从中选出下一种预测模式。注意:如果第一遍编码时用的 auto,第二遍编码时就只能用 auto;否则,第二遍编码将默认为 temporal。使用 none 浪费码流,严重不建议。5 l4 n1 y1 _7 s5 ^
建议: 'auto'
. h) _) ]) g: e& `no-weightb- Y! |$ t, [2 v- E' O3 y
默认: 未设置) X+ v0 e) `2 I5 x+ w7 [7 \9 M; K% ?! Q
H.264 允许设置 B 帧参考帧的权重,权重可以让你改变各参考帧对预测画面的影响程度。本选项关闭此特性。
# \, n/ K, M. c  `) {- r建议: Default) Z6 O+ N2 B1 ^1 V
weightp. |  X, y* m# _, o
默认: 2" w7 D* q" t; d0 Z* S5 H
在 P 帧中开启加权预测用于提高压缩率。同时提高淡入淡出场景质量。值越大越慢。
: V" V8 T+ z, Q模式:
3 w! b7 V/ c! `) T8 \: v•        0. 关闭
2 z1 `% H. n1 x8 I•        1. 简单: 淡入淡出分析,但是不重复引用。
! d- a; a, \- ]2 g7 |•        2. 智能: 淡入淡出分析,重复引用。1 g7 w0 L7 ]. l" Z0 C
me
/ o2 G1 g2 J& S/ H默认: 'hex'2 m! H& `) a7 v' ]
设置全像素运动预测方式。有5种选择:
: g9 t0 M; n# T1 H2 p# L  C•        dia (diamond。菱形)  最简单的搜索方式,从最佳预测点开始,在1个点的上、下、左、右四个方向判断此点的运动轨迹,选择最佳值,重复此过程直至找不到较好的轨迹。. f5 v3 K6 {- ?- q
•        hex (hexagon。六角形) 秉承简单策略,除了它是在两行共搜索6个方向,这也是它名称的由来。比 dia 有效且速度基本相当,因此是用于普通编码的好选择。/ b$ Y! l( ?) R+ i1 e& j# ^
•        umh (uneven multi-hex。非偶多六角形) 比 hex 慢,但是通过搜索复杂的多六角形区域从而避免错过难以找到的运动轨迹。不像 hex 和 dia,参数 merange 直接控制 umh 的搜索半径,允许你增加或减小搜索范围。, A( {' j+ J* a& r/ ?( t
•        esa (exhaustive。穷举) 在最佳预测点 merange 范围内的整个运动空间进行高度优化的智能搜索。它在数学上相当于在区域内搜索每个运动向量的穷举法。尽管比较快,还是比 umh 慢,没有太多好处,不适用于天天编码。/ H9 P0 S$ N0 o6 X
•        tesa (transformed exhaustive。改进的穷举) 这种算法试图粗略估计对每个运动向量进行 Hadamard 变换的效果;像 esa,更好一点也更慢一点。; B; p" l! v% n: ]9 W# M4 U0 t
参照: --merange0 f0 O6 E6 ]3 `5 D
merange
  G$ N4 z3 H0 B) x默认: 16 ' t  P/ \) Z% x, f0 @# _, W9 w) B
merange以像素为单位控制最大运动搜索范围。对于 hex 和 dia,在默认16下,它的范围强制在 4-16。对于 umh 和 esa,能在16在的基础上增加从而搜索更大的范围,对于高清和高速影片很有用。注意:对于 umh, esa 和 tesa,增加 merange 将明显降低编码速度。
4 \4 X9 I0 W3 M8 O+ ?3 R参照: --me+ `+ l% M- z% N. p
mvrange/ t" `" j0 ~' y( m9 S% j/ ?% ~
默认: -1 (auto)
4 t) G8 w. D7 U( U. X; U# o% a  W& G以像素为单位设置所有运动向量最大(垂直)范围。默认值依赖于 level 等级:
4 j5 _$ {7 {' e& `1 o•        Level 1/1b: 64 6 [6 J$ E8 `8 V4 L2 B* m- j
•        Level 1.1-2.0: 128 * ?/ c0 I7 H& D, X" m
•        Level 2.1-3.0: 256 2 Q' H3 g6 ~; W0 w, l5 }
•        Level 3.1+: 512
/ W, q' G7 q7 E注意:如果想手工设置 mvrange,当设置时从上面的值中减 0.25(如: --mvrange 127.75)。
9 Y, y# V& A0 w" \: r6 y建议: Default2 z# W, S+ w% x/ k+ w! L6 Q
mvrange-thread
% d8 i  B! ]" m" X% d! @默认: -1 (auto)
7 j% O1 x2 l5 B" w! D) w- U& a设置流(threads)之间的最小运动向量缓冲。不要动它。0 N  c) _9 i5 n- k7 u
建议: Default
& a' R) |$ ?* q& g! R% S6 q& \# Bsubme. B$ `4 ?4 s- }. l, D) }  Z
默认: 7 & G! [: T/ M" T" W
设置亚像素估计复杂度。值越大越好。1-5仅仅控制亚像素精细程度。6开启 RDO 用于模式决策,8开启 RDO 用于运动向量和内部预测模式。开启 RDO 的明显慢于未开启的。4 f& e, d& ]! a! m
使用小于2的值可以更快,且更低质量的向前预测模式,这就相当于造成降低场景切换阀值,因此不推荐这样做。
4 g+ u2 }8 e, S. `- k) h) N2 u4 n8 B可选参数:
: F) y- R& u) Z0. fullpel only
) K- L; a  Y% o4 u5 r1 G/ v7 M1. QPel SAD 1 iteration; o: J  z5 ~6 A% y* r. u
2. QPel SATD 2 iterations3 U# z& j& t# r9 e, T
3. HPel on MB then QPel, l5 k' ?; u& m. R; k: l5 c6 R$ J
4. Always QPel) q0 @$ I' |* |3 T: k
5. Multi QPel + bi-directional motion estimation) k+ A( L! c* B! Y
6. RD on I/P frames
; H' s& e5 ]( h7. RD on all frames
) ?( {1 d" C# C7 F$ B8. RD refinement on I/P frames
8 {% J* P0 Y1 q- Z+ w9. RD refinement on all frames5 f! g" p! g; c& X
10. QP-RD (需要 --trellis=2, --aq-mode > 0)
  Z* N% K3 J3 {/ l! C建议: Default, 或更高,除非编码速度很重要。( j; _" u, q' n( E$ `" L" o- y
subq
9 b! b3 e) F& M/ `$ w8 D  T6 I--subme 的别名。
$ h% [6 X" k  |: l2 P' Z6 ?* O* ypsy-rd
% K) J: {6 ~% {2 N0 `默认: 1.0:0.0
' U# y. |2 n4 h! S/ F参数中第一个数字是 Psy-RDO 的强度(当 subme>=6 时有效)。第二个数字是Psy-Trellis 的强度(当 trellis>=1 时有效)。注意:Trellis 仍处于实验阶段,至少对卡通片来说是坏事情。3 K* O/ N) H6 a3 l* \2 ~
psy-rd 的解释:http://forum.doom9.org/showthread.php?t=138293
5 h5 I. ^+ n. M" ?, I  mno-psy
8 D0 {+ g  j/ P- C, G+ B默认: 未设置
7 T8 Z$ m5 m; q* t5 y( B关闭所有用于降低 PSNR 或 SSIM的视觉效果优化功能。同时还关闭一些无法通过 x264 命令行设置的内部 psy 优化功能。& k5 L! c; J3 F4 w1 `6 y9 Q7 q
建议: Default3 I% M2 Z  c' R  T' n: Z
no-mixed-refs8 ~3 K8 W$ I* D! d
默认: 未设置( M" z( K8 ~/ t& P3 S
混合参考将以 8x8区块选择参考对象,优于按宏区块大小选择参考对象。当使用多个参考帧时可以提高图像质量,会降低编码速度。设置这个选项将关闭它。5 x9 m3 {7 m, c# H+ O. O3 r
建议: Default) M5 L! O3 [  B, G9 i, U
参照: --ref
; e2 }7 v9 a5 g: E9 b* Bno-chroma-me
6 u1 r& l! u3 \4 o% p默认: 未设置% K. V/ {$ O& ?+ B9 S
通常,在亮度和色度两个位面进行运动预测。本选项关闭色度运动预测并能略微提高编码速度。
. ?9 t" `: |# Q: S. l$ \) p建议: Default
3 ^- T; E: l# L- @# Nno-8x8dct
8 J, T. j; r1 J# y/ B- t默认: 未设置
8 q6 U: Q6 c% Q3 Q$ z$ m0 x8x8 DCT 开启智能的自适应的在 I 帧中使用 8x8 离散余弦变换。本选项关闭此特性。
: W6 V  w! X+ l9 v" [建议: Default
- K! y& E# `" {trellis
" z0 l' p3 P. s$ g( n% q8 V默认: 1& V( C; e. L$ c4 c% e: e+ R
通过分格量化(Trellis quantization)来提高效能。8 \) |1 m  u) M+ e; h1 o7 c
0. 关闭: C# O4 `7 z. }# R
1. 开启。仅用于最终宏区块编码,速度和效能的良好平衡。4 U# m! R* B2 V
2. 开启。用于所有决策,降低编码速度。
6 w/ H9 `" T% }0 U! o$ C分格量化:http://en.wikipedia.org/wiki/Trellis_quantization
" @. q4 d$ ~) p( k建议: Default% q6 C1 j3 y( c7 m
注意: 需要 --cabac
  M6 O$ n/ r2 b! |  q* {& Pno-fast-pskip
, `3 ~9 k% H% u2 O$ D5 i& A4 x默认: 未设置
1 |/ m6 u. V! ]/ u) \) V, ?' P关闭P 帧提前跳过检测。以很大的速度损耗为代价换来非常微弱的质量提高。
) N* u  Y( r' L; T1 z建议: Default
+ R1 ?3 Q' E* T% g& t) Z6 o7 Pno-dct-decimate9 i$ h$ I/ o2 N3 R
默认: 未设置
& [+ Z% }8 t* |& d2 d/ e+ EDCT Decimation 将去除中被认为不重要的 DCT 块。这样做可以提高编码效率, 并有些微的质量损失。设置本选项将关闭此功能。
4 S; \, A3 D7 I% g! E建议: Default" }- _9 `1 v/ Q+ S- v
nr
' w# }4 c8 X* Q- T% R默认: 未设置6 U* _9 K, [8 A- }2 W1 E0 \
执行快速降噪。在量化前,基于此值评估影片噪点,并试图通过去除微小细节的方法清除噪点。效果不如良好的外部降噪滤镜,但是速度非常快。
3 O+ T! G/ k/ M4 a  M1 p* e# }9 y建议: Default 或 (100 to 1000)' R& A: J% u2 N5 P& k
deadzone-inter/intra/ Z& w! x4 J1 P7 c, q: P
默认: 未设置
. D3 o) A2 A, \: C+ T) Q/ N设置inter/intra 模式下亮度量化死区值。取值应在 0 - 32 之间。死区值定义了细节精细程度等级。非常精细的细节解码和编码都很困难,去除这些细节不再保存它们有助于节省码流。Deadzone 与 Trellis 不兼容。5 {. h/ t+ j* j+ q
建议: Default
% y8 n, s4 z6 F- }7 Q/ H7 K0 Acqm
8 x) E% \# l  s6 c6 h5 |默认: Flat
7 w8 S( C" _" H1 a+ H把全部自定义量化矩阵设为内建预置。内建预置量化矩阵为 flat 或 JVT。# B+ H6 g. r5 t" E9 g: i( K; y
建议: Default
2 [7 H4 T6 q1 k0 J' B# \8 u参照: --cqmfile
0 z8 A" T( y& c" n4 t6 F# [* Z/ ~) Ucqmfile
5 e3 @  j; l3 C1 V' I% r默认: 未设置
7 A# _5 ^. K) p从 JM 兼容文件读取自定义量化矩阵。覆盖任何其它--cqm* 选项。
* D, x. Z, y  R+ r  }1 \) r+ i, x建议: Default) s1 G9 j/ {# w+ R% v' Y4 l
参照: --cqm
$ D& D  c: I0 W8 y; \3 F: E' U) bcqm4* / cqm8*/ U. ^* K3 F. k  f5 W( j; }
默认: 未设置
6 s$ M7 A7 ~, i- E, g& S•        --cqm4: 设置所有4x4量化矩阵。用逗号分隔的16个整数。
3 M  Q6 K4 D! K) d( i•        --cqm8: 设置所有8x8量化矩阵。用逗号分隔的64个整数。* B6 U4 T- u6 B3 @, T, J- c
•        --cqm4i, --cqm4p, --cqm8i, --cqm8p: 设置亮度和色度量化矩阵+ H6 Q; H6 R% ^2 J; K) x7 ?3 O
•        --cqm4iy, --cqm4ic, --cqm4py, --cqm4pc: 设置单独的量化矩阵" W* w; B- ?6 N& [
建议: Default2 N. x# ~1 P; ?! E

2 @; O( H, ]. YVideo Usability Info
3 `$ D7 P% Q) q: r9 f: Z3 d' _% {这些选项在输出流中设置标志位,标志能被解码器读出且可能起作用。值得注意的是这些选项大多数情况下是无意义的,而且通常会被软解码器忽略。/ {8 C6 w5 y5 ^7 r9 r# w  p* ?
overscan2 R0 T" G/ a' P9 [) I/ t
默认: undef
$ g: Y0 K  X/ h2 Z1 ]如何处理过扫描。过扫描在这里的意思就是播放设备仅能显示整幅图像的部分。
- i( y4 d0 c( R- _1 u可选参数:' y7 y  N  a! @; Z# y. [/ j4 [
•        undef - 未定义
$ j' y- m6 l; V  D3 }•        show - 显示全部。理论上讲如果设置了就应该被遵守。
3 X! C( S3 {. Z•        crop - 在支持过扫描的设备上让图像适应播放器。不一定遵守。 ( U0 A- _. l+ ^* O
建议: 在编码前裁剪,如果设备支持的话,设置 show,其它情况下忽略它。
+ W+ V- I+ B) m2 e$ a7 I, w. cvideoformat
2 g# M+ Z, r6 |/ F0 V" y默认: undef 1 P. I8 O  h5 R# U/ {
表明视频在编码/数字化前是什么制式。
( |" ?: A. W! \可选参数:
! x* o0 C: B  h1 d; _/ u& J( L( V•        component
( w3 B" u9 h% ?. z•        pal
) s/ T+ {) ^2 ?+ [0 x•        ntsc
9 c9 _, j; q; d+ y7 y•        secam ) |! q: X$ Y% s7 q
•        mac , |2 p1 w: ]+ y' Z* _2 F
•        undef / f' _+ t- p- c8 {$ A" T
建议: 随便, 或不定义
6 Q! S! z! k2 y$ S- U& c* }4 kfullrange; {4 I0 P% D- d+ I/ P$ N# j. x' C
默认: off
. b5 [# _, N: T表明亮度和色度是否使用全范围。如果设为 off,则使用有限范围。, u7 T/ d3 Y  Y3 V5 X4 o: G
参考:http://en.wikipedia.org/wiki/YCbCr
3 t( u7 W$ }! ~. J建议: 如果你的源是从模拟信号数值化来的,设为 off。其它,设为 on。
, o& ^& A. `" ]背景:6 `6 a3 `8 ]1 n2 z/ j
BluRay/DVD/DV 等使用 MPEG 压缩,记录格式为 YCbCr,遵循 ITU-R BT.601 规范,其数据范围(动态范围)为 Y(亮度)16~235,C(色度)以 128 为中心代表无色,范围 16~240。
# K# x% m( ~5 Y6 l5 E做处理和显示的时候,YCbCr 要转为 RGB,其范围为 16~235。6 X; z' k5 ^6 V. t& ~! s$ Y, B
但是计算机屏幕上,纯白的点,其 RGB 值为 (255,255,255),纯黑的点,其 RGB 为 (0,0,0)。所以 MPEG 所记录的纯白 (235,235,235) 在计算机屏幕上看起来就不是纯白,纯黑 (16,16,16) 在计算机屏幕上看起来也不会是纯黑。/ E$ w# m% g' V2 H; m+ t& K
因此 DV 录下来的东西,拿到计算机上看,会觉得颜色变淡,好像照上了一层白纱。同时因为数据范围(动态范围)缩小为 16~235,而不是全范围(Full Scale)0~255,所以会觉得对比不足(最亮和最暗的差距缩小),不如在电视上看漂亮。
& v% M% _5 k* M( t- \# Scolorprim
3 |& o8 B6 y9 W  W默认: undef
. [- K- R& m8 u$ J# C设置把什么源色彩色系转换为 RGB 色系。& s& A9 J1 M9 l3 Q7 J7 T
可选参数:
- W6 e8 l% ^/ c0 d0 _•        undef
3 J/ m6 a, R% G2 x# i; @, F6 f$ A•        bt709 7 O6 F$ t- Y' n. P
•        bt470m
8 l$ r0 p7 T* ]6 V3 z, @. U•        bt470bg
8 {8 r7 d4 T! p% N; e& S* P•        smpte170m + a  \8 I5 `  P
•        smpte240m
2 _" n  _7 U& |' M# S9 c•        film ! N3 d" }7 f( K& c9 |
参考:
  }3 K" T% ~0 f. E* Q6 ]% ohttp://en.wikipedia.org/wiki/RGB_color_spaces1 H! F: u. Q, D/ T
http://en.wikipedia.org/wiki/YCrCb
( `- }  z9 U2 W$ J! w: \) i9 o( a建议: 默认, 除非知道源使用的是什么。
7 n8 x: ]8 H* S7 }2 d) n9 ntransfer) z+ a8 N7 s, L* `/ I6 o
默认: undef
3 h, Y4 j8 f, ^& @6 Y0 }设置光电传输特性。(就是设置伽马曲线用于校正)
+ n3 U# Z+ J+ e4 Q4 Q  A- ]可选参数
3 r* G4 \" u- W9 ?. G# l6 B* O0 A•        undef
6 R& R* M0 h. z) B& U; {•        bt709
# |2 U1 J  a/ q$ W2 R•        bt470m
. V6 h4 z! ?$ s1 c. x& D& G! ~•        bt470bg ; R) l$ R1 {" `/ J
•        linear 1 L! u, C& {$ q8 \( X+ u3 C; ^! k
•        log100 6 Z5 o. z' y& a- E
•        log316 : v1 W* h6 o& O) A
•        smpte170m & T  T% F  I- f1 }) c8 u
•        smpte240m ( c% X! `+ N; o* D
伽马校正:http://en.wikipedia.org/wiki/Gamma_correction! H8 c; A3 ?# N$ H& h/ X7 b
建议: 默认, 除非知道源使用的是什么。: i; _1 y7 H( y% A4 B9 |3 b
colormatrix( a+ j$ O4 ?' `6 W$ Y( I% O
默认: undef
6 N* [8 |/ X, Z0 J  M4 a$ K- r设置从 RGB 转换时亮度和色度的矩阵系数。
5 _2 Q* _  S: q* H可选参数:( z  V- S7 M5 s0 o# \
•        undef
, t1 E& V) K" v; H7 J; x4 s•        bt709 4 `3 ?( |% |# H; p
•        fcc 6 B5 K+ E- q% D. t
•        bt470bg
: d& n$ D) D+ Z2 G7 l& B8 t•        smpte170m
3 e# t3 I: f% v+ O/ O# Z% p•        smpte240m 0 a- ]4 Q5 z: P3 ~* b
•        GBR % n% [& u9 M" Q' y3 I4 W
•        YCgCo $ W3 o% k5 g: D; ?
参考:http://en.wikipedia.org/wiki/YCbCr, [* v/ z1 h: k1 R
建议: 随便,或 默认。7 r# d- @/ X' e# |/ W' |
chromaloc
$ `0 A* f/ D  @1 n% d, {默认: 0& D0 W1 L  V& N  _, d' P/ ], R
设置色度取样位置。(在 ITU-T 规范附录 E 中定义。参见http://www.itu.int/rec/T-REC-H.264/en( G3 [* C* Q5 [( R" P4 W$ \0 ~
值从0到5。" A8 k4 I6 l7 h
参考:http://git.videolan.org/?p=x264.git;a=blob;f=doc/vui.txt
! x5 N! ?# K" F3 L) I建议:
+ b0 t) b& V8 D9 X8 ?0 m- q•        如果正确的从 MPEG1(比如 VCD)的 4:2:0 格式二次采样转码,且不做任何色彩空间转换,应该设为1。$ s5 I  q* t) {1 v8 U
•        如果正确的从 MPEG2(比如 DVD)的 4:2:0 格式二次采样转码,且不做任何色彩空间转换,应该设为0。  `% a% C: t$ b6 v1 S9 X1 V$ R
•        如果正确的从 MPEG4(比如蓝光)的 4:2:0 格式二次采样转码,且不做任何色彩空间转换,应该设为0。" m( g# F" |6 c
•        其它,默认。: M* |1 p6 H6 s4 E0 U
nal-hrd
! I) Q# V2 W  U8 b/ S' A0 C+ [9 l默认: None 7 r/ T5 n& K+ y1 V
标记 HRD 信息。用于蓝光、广播电视和一些其它专业领域。参数有:
2 s& y6 |0 B. B/ F7 T•        none 没有 HDR 信息。
! X6 c8 }8 @! H; {•        vbr 指定 HRD 信息。2 ^* [8 j8 c9 r
•        cbr 指定 HRD 信息且把视频流按 bitrate 规则封装。要求编码时使用 bitrate 码率控制模式。* K9 s5 D# c/ N8 e% y3 c* e5 g
建议: none, 除非需要指定此信息" J' `' `& b4 H4 Q2 m) a' ?, u
参照: --vbv-bufsize, --vbv-maxrate, --aud: L8 C7 `% t+ t% a! x5 G
pic-struct+ {( \' Z# X5 x6 T
默认: Not Set
/ z4 G2 n5 n& K7 Q: @在 Picture Timing SEI 中强制发送pic_struct。
7 D9 w# e( @5 h7 X5 X0 t当使用 --pulldown 或 --tff/--bff 时隐含采用此选项。* f+ R; l: \% k4 C/ |2 Z% |0 l: n
建议: Default
8 o" @: M5 Y% W5 M$ C! G
! m+ t) a6 ?0 h. a1 ~) HInput/Output
& G3 C# u  I: [" w0 M4 [7 j* A) V% f9 doutput
6 q; V8 ^1 M& e2 L8 K3 [+ a默认: 未设置6 w- t$ k+ U* p- C/ E0 y) j, \2 S
指定输出文件名。由指定的文件名后缀决定视频格式。如果后缀不可识别则采用默认的 raw 格式(通常 .264 后缀用这种格式存储)。
2 _! J$ `( l! S特殊的文件名 NUL (Windows)或者 /dev/null (Unix)表示丢弃输出内容。当使用 pass 1 时特别有用,你唯一关心的输出来自 stats。2 g0 N) J8 v: f5 l) U
muxer
1 `' t. w; L; p, w默认: auto
) D; L) B* l3 `' ]指定用什么格式写文件。
* N1 t$ t$ W8 o. c# w可用参数::8 N  [& f( b% O$ V. M- u
•        auto0 `" Y6 L. v( P$ q9 k
•        raw4 R# O, E& x4 e7 ~% @% ?8 D
•        mkv
6 p9 H- q. Z, q. F2 o1 Q•        flv
3 [5 _+ {# X! l3 G9 u; U•        mp4
2 W  f$ P' F7 N  n‘auto’选项将根据提供的文件名选择封装器。
4 Q: \0 H, A& q% ?- [, B; T3 V7 D2 W参照: --output% W/ R  x+ ]/ [% D) n6 @* I& i
建议: Default: l( ?* S6 e$ q/ {$ y3 U* v
demuxer
0 G. m: \& a3 t6 _! @! e6 s默认: 自动检测- q. z9 H, r' e
设置 x264 用于分析输入视频的分离器和解码器。
* |4 }" \! O, G4 O2 p: l4 f3 }可用参数:
% t4 K" ]9 |6 L•        auto. K0 n/ o4 Z5 Z6 w
•        raw- a+ E1 q! }2 b. y7 z. p8 N. h) P, A
•        y4m( y  p5 G( N& G3 ]) m" n
•        avs
2 Q5 p, w' q9 N6 _' Y" \•        lavf
2 w. y. F5 J* @" E+ L8 p•        ffms
" d2 v8 h6 c: R如果输入文件有 raw、y4m 或 avs 后缀,x264 使用相关的分离器读取文件。标准输入使用 raw 分离器。否则,x264 将依次尝试使用 ffms, lavf 来打开文件,直至放弃。7 o# Z. ~1 M4 w0 E; @7 H' g
‘lavf’和‘ffms’参数需要用各自的库文件编译 x264。如果使用两者之一,而且输出不是 raw 的话,x264 将暂缓处理输入文件中的时间码。这将有效的使 x264 采用 VFR-aware。其它参数使用 --fps 指定的固定码率或 --tcfile-in 指定的可变码率。) D$ T& q6 \' ]% i4 {
参照: --input, --muxer
& q/ \2 m! n$ S7 [1 d建议: Default
6 _& O  ^9 j+ Jinput-csp  t1 `2 T8 L! l, S3 H: U8 l) q  X
默认: i420 0 i6 T% G1 M# E8 a
告诉 x264 视频源的色彩空间。支持的色彩空间列表见 x264 --fullhelp。; S9 n6 v" [' k. W- G
注意:当指定为 RGB 色彩空间时,视频在压缩前会按 bt601 矩阵转换为 YUV。- h3 w* ^1 a8 ]! k4 D1 K/ x' W
参照: --input-res, --fps
* I+ \, R/ Q5 A: W4 q( f" @; iinput-res
" I# I$ S6 A& b9 z/ W+ v+ E/ T+ m指定 raw 格式视频源的分辨率。使用格式:--input-res 720x576
) Q/ M$ Q0 I- h% @) x3 a5 R参照: --input-csp, --fps- g1 X3 ]4 o/ q$ c" a) h
index- z( n0 v$ @& `$ @  ?9 }6 ]
默认: 未设置
* l  \+ T# O7 `一个仅当使用 ffms --demuxer 时起作用的选项。为 ffms 指定一个用于为输入源建立索引数据的文件,以后编码的时候可以省去再次建立索引的时间。通常不需要,因为相对于编码来说索引非常快。/ R0 f7 p  Y  ?, Q; L
参照: --demuxer, FFMS2 API 文档:http://ffmpegsource.googlecode.com/svn/trunk/doc/ffms2-api.html
# K" ]- n1 V. D' T6 f5 h建议: Default, 除非你想节约一分钟的索引时间。
* ]# h# k: ]# Y' `2 E; V7 Dsar, _5 F9 ~, K; P/ T# K7 f0 Y
默认: 未设置9 Y3 G( p- J. v( S4 I" g
以 宽:高 格式指定编码器使用的视频源的采样纵横比(Sample Aspect Ratio (SAR))。综合使用 SAR 和 帧尺寸可以做出依赖显示纵横比(Display Aspect Ratio (DAR))的可变形(anamorphic)输出,公式为:DAR = SAR x width/height
/ p2 j! t: ~' O+ e7 ?建议:假如使用 resize 滤镜和变形视频源的话,应该指定。
! X7 y' M- R+ l- Y- o参考:http://en.wikipedia.org/wiki/Asp ... age%29#Distinctions. W7 U' U9 p( C
译者说明:“可变形”是种特殊应用,欲详细了解可以参考“细说DVD的画面比例”这篇文章:http://www.tfcc.cn/dvd/2004-8-25_14-36-56_1259.html
. h: r' v% G, Z! Sfps
& F* Y% O7 r0 \4 S8 o默认: autodetected
+ K) g+ [( v9 ~0 y& A以浮点数(29.970)、有理数(30000/1001)或整数(2997/100)值指定视频的帧率。x264 在有效的视频源头部(y4m,avs,ffms,lavf)检测帧率并采用,否则使用25。本选项隐含使用 force-cfr。
8 Z5 n* U  F+ Q" Z9 P" N, v如果正在使用 raw YUV 视频源并且基于 --bitrate 码率控制,需要使用此选项或 --tcfile-in 指定正确的帧率。否则,x264 无法达到设定的码率目标。
% _( }! J% f; b9 z3 |7 x2 Iseek
) h' T% \( E+ V( c# z5 T默认: 未设置. t2 ?5 k% t/ M2 o1 @- o
设定编码的起始帧,允许从视频源的任意位置开始编码。
+ V/ X" B( A) R0 K  H建议: Default
) b9 l4 t9 L2 o5 s1 d8 u7 L% fframes
1 R/ M& h  B8 `+ x默认: 未设置% U( N6 A$ z" ~# c
设定编码的最大帧数,允许在视频源结束前的任意位置终止编码。
) D9 b3 e% l$ v4 p  Y1 Q- h1 R建议: Default9 _) u. ]% c6 K1 N. y1 Y$ b6 b/ R
level
1 P3 h2 t2 c% C9 Q+ ?默认: -1 (自动)
3 C; T8 k( n8 r' T在输出流中设定等级标志(H.264 标准附录A。http://en.wikipedia.org/wiki/H.264#Levels)。允许的等级有:  U$ K, h+ g& y3 g
1 1.1 1.2 1.3 2 2.1 2.2 3 3.1 3.2 4 4.1 4.2 5 5.1 (等级 1b 不被支持)9 N" w) m! u& A& L  W, t" G
如果没有设定等级,x264 将试图自动判断。自动判断并不完美且在不使用 VBV 的情况下可能低估等级。x264 将自动限制 DPB 尺寸(看 --ref)与你设定的等级相匹配(除非你手工指定 --ref)。注意:--vbv_maxrate 或 --vbv_bufsize 不会根据设定的等级自动设置,但是如果它们的参数超越设定的等级会告警。1 e( U/ B  x; Y3 u& O) l
选择什么等级?
: u: w, R/ _: R9 v! i; E/ OLevel 4.1 常常是桌面型硬件能支持的最高等级。蓝光碟仅支持 Level 4.1,许多非手机类设备,像 Xbox 360,指定 Level 4.1 为官方支持的最高等级。手机设备,像 iPhone/Android 则是完全不同的处理方式。' g2 }' d. K, K" H
详细的等级限制图表,参见:http://en.wikipedia.org/wiki/H.264/MPEG-4_AVC#Levels
- _0 X; J8 u# [5 g% O- f建议: Default,除非是为一个特定设备编码。
3 ~/ N, V3 d' J! K! _verbose
, l% [1 W6 g+ j, x; \" T默认: 未设置) p, P" V: Z4 J; O- k5 U7 b
显示每个已编码帧的统计信息。8 k- A0 \' r9 ^% s2 o7 x
建议: Default
) f9 n. C* A' ?# T% u5 Wno-progress
3 j5 |' h5 X8 S# Y/ P8 K默认: 未设置
2 Q8 _5 C- `* E' [7 u4 m编码时关闭进度指示器。  p0 w( P! p  Y# _& `! C+ R) n
建议: Default
7 C$ y/ Q. h' }' K1 [quiet( D" _  z- U0 j2 r# X" @+ Z
默认: 未设置5 d0 d& Y. x* a. R/ i
开启安静模式,屏蔽 x264 发出的状态信息。
; [6 g+ A6 \6 q" U4 H建议: Default& R: }/ n' f, ~9 N) F
log-level
. N  O+ \/ N# Z! {6 X默认: info
3 ]! ~- _4 W4 v2 y4 L手工设定 x264cli 和 libx264 的日志等级。! i, @  N! }, U5 ^4 n; F
可用参数:8 m- M1 h' j5 Z) \9 V& P
•        none; g; [. U' [2 K, p
•        error
$ v+ |6 q) s% E" K& X2 d) Q& ]•        warning
. H$ C" C9 w  z4 e- a•        info2 y% z6 J$ s8 J0 z  Z6 M
•        debug, P6 C; u! O* r/ Z9 k
越往下,日志信息越详细。
- e$ Y, o9 X4 u+ k/ z3 D- b建议: Default8 n  Y/ o3 _: P) A9 U- V% w
psnr
9 v$ X7 _9 M: ?. l, F0 h+ {默认: 未设置- ~1 l' u! Q+ w
开启 PSNR 计算,会在编码完成后给出报告,略微降低压缩速度。
/ |: E5 z6 ^4 o! e建议: Default
# D; e, f' n( Pssim
! p; s6 k0 D) e' c+ E; D默认: 未设置8 r) i6 \6 E9 \7 F* D
开启 SSIM 计算,会在完成后给出报告,略微降低压缩速度。% z- ~$ q$ m1 x
建议: Default
4 p- `3 a  N: q1 J7 Q6 @threads
6 m5 S. L2 R5 j* j/ P: e7 |默认: auto (基于帧的线程数:1.5 x 逻辑处理器数量,向下舍入取整;基于分片的线程数:1 x 逻辑处理器数量)# \  N* {, B3 |( k8 v# w
在多核处理器上通过使用开启多线程并行编码以加快速度。质量损失可以忽略不计,除非使用非常多的线程(超过16个)。速度增长和线程的数量近似于线性,直至在视频垂直方向每40px 多于1个线程为止,超过临界点后再增加线程获得的速度增长将大幅下降。" k1 a6 a; s+ N! u* E6 k+ A% O
当前在 x264 内部对线程数量限制为128,实际上你也不会设置这么高。6 N* ?3 K' Q. p6 Z. f% l
建议: Default+ u# j2 N* {0 I# P9 V- G
参照: thread-input, sliced-threads
- n! O+ ?: Z' m. Osliced-threads: l; L/ S- R' U
默认: off
( S. t/ @7 o' I8 X9 B开启基于分片的线程。比默认方式质量低、效率低,但是没有编码延迟。
6 p1 e3 H% ?# N! J3 B: i基于分片的最大线程数量公式:MIN( (height+15)/16 / 4, 128 )
3 L3 B8 G: C% [1 Z2 B* I建议: Default (off),除非你正在做实时流排序或者低延迟非常重要。: r0 t5 i% B! X9 y
thread-input
7 C' Z7 U" x" G" E: [& x* {默认: Set if threads > 1. E1 e) \7 _) `; _9 M$ m! x0 O& r
在单独线程中解码输入视频用于编码进程。5 s- B+ Q2 Q8 F) D+ |& H, W: @2 }+ Z% I
建议: Default
1 ]2 r$ ^/ ^8 F4 Q+ R, A4 O9 fsync-lookahead' e' `2 e& @2 b, }
默认: auto (bframes+1)
# D+ ^) y2 t6 g  k' p8 h. q* I设置用于线程预测的帧缓存大小。最大值是250。在第二遍及更多遍编码或基于分片线程时自动关闭。9 Q, B- O$ p% D! h- H
设为0将关闭线程预测,将减小延迟,但是以降低性能为代价。
- I; q- O& x. L  _建议: Default6 k/ X1 D2 o6 K
non-deterministic
8 S8 `2 P' R. d6 V默认: 未设置 3 a4 R( t5 K; }
在 --threads>1 时可以稍微提高编码质量,以非确定性输出编码为代价。开启多线程 mv 和 在分片类型决策时使用全部的向前预测缓存。
9 r/ Y# s: _( c- W; Q一般不用。
/ G" y( f% r) H1 x& R, K* [建议: Default " ?' L1 }1 c1 n8 C7 }9 m
参照: threads: j' ~0 @( j- X
asm* j& N9 o* @* U3 }+ B; A0 n8 d' u
默认: auto
* w5 x1 Z4 |9 U  C不理会自动 CPU 检测。用于调试或排除故障。* d2 M3 J9 g1 S' D) E4 g
建议: Default
! @1 n( Y: {  d& Tno-asm
2 v0 {3 D9 _; x2 y1 D默认: 未设置
' T& g7 G5 ?; {$ t关闭所有 CPU 优化。用于调试或排除故障。
% w- z0 ?7 Y  Z建议: Default
+ C9 B/ S3 S/ D2 ?: X. ovisualize2 B( ?. t( o5 V0 `
默认: 未设置
" a. x* t% z) s0 c开启已编码视频宏区块可视化。用于逐帧调试或分析。- _  V. ]0 j- G$ R+ M7 s$ f
需要编译支持和 X11 窗口系统。
) o* ?" Q/ m* |9 _2 W6 |+ p( R2 {; P建议: Default
* @  v/ P6 I' }% Vdump-yuv
( J; @& M* m# `6 p  E默认: 未设置
0 A6 T% X: q4 H, ?5 _把重建的 YUV 帧转储到指定文件。通常用于调试。一般不用。2 W: r6 Z, q" T1 c5 d5 P3 V3 c- ]
建议: Default
- \/ x& |/ [( F# G; M9 C) Isps-id' Z  X$ m$ B3 X
默认: 未设置
# B' d9 c" W( n2 V设置 SPS(sequence parameter set)和 PPS(picture parameter set) id。' x% u; S! d( j- W3 i8 B* J. O
一般不用。
2 ]. j- M. B3 {/ p" p# }建议: Default
# c0 G* \% z8 o% v- kaud
% Y, E9 x* S+ J( h! }5 x默认: 未设置 : I, D/ U- P% j) W
设置访问单元分隔符。) b8 s6 G6 x; s. r7 ~
建议: Default,仅用于蓝光碟。
; E8 i; Q" Q% y" W, T2 q8 f/ u$ }force-cfr# i; u% {1 y( u* n0 b! ^( ?& o. L
默认: 未设置 " a1 A/ @, a, x  ?9 P, L1 q; u, ^& Z
如果使用 ffms2 或 lavf 分离器,且输出文件不是 raw 格式,则从输入文件复制时间码。此选项关闭这个功能,并强制 x264 自己产生。当使用此选项时估计你也会设置 --fps。; k& Q3 r6 {: N, x+ Z. @
建议: Default
% o- v. ~8 J5 u/ t0 L# m  otcfile-in( {  N- r5 v# x7 X% i+ G3 @5 t' n, }1 E
指定一个说明视频源帧率的时间码文件。可以是 v1 或 v2 格式。& g, _% `- ~" r  }5 r0 S  L5 M
mkvmerge 文档中的解释:http://www.bunkus.org/videotools ... rnal_timecode_files
8 C2 ~. O  \0 `7 t( c参照: tcfile-out, force-cfr, fps) n2 K) G/ S6 ]* ^# L; @; L# i6 H. U
tcfile-out$ E  A; i% h! o* s: ]; A# @- q
输出一个基于输入时间戳的时间码文件(v2 格式)。用于当你正在编码一个 VFR 视频源且想转储时间码的时候。关于文件格式,参见 tcfile-in。0 ?1 T: M  P3 B9 R+ i4 |" {
timebase
! ]  L% w8 Y" \7 F: x默认: 未设置
* ]  s' t9 ?, R# K$ E4 o; I+ M% i允许自定义时间基准。, d) ]% p+ U: d
分子是‘秒’,分母是‘ticks’。意思是1个 tick 多少秒。5 c( P$ c& b4 w
•        如果得数为有理数,将相应的设置分子和分母。! h/ v( |; C" o
•        如果得数为整数,并且通过 tcfile-in 设置了时间码文件,将使用得数做分子,并相应的生成分母。
7 _( _& J* d% J9 ?8 Y" b8 j3 J* b•        如果得数为整数,并且没有设置时间码文件,将得数作为分母并从视频源生成每帧‘ticks’数。$ K$ ~! Z& B# H" `
与 --force-cfr 不兼容。! A3 B0 N! p7 k- Z( r
建议: Default
1 N9 d" C  C- e9 g( k& e& Ydts-compress
0 E% [* n( K" S1 f默认: 未设置
( z( R0 r4 E, h一个小把戏,仅适用于FLV和MP4容器,可以在有缺陷的解码器下工作,这些解码器认为所有的 DTS 都是正确的。使用此选项风险自担,请看说明:http://git.videolan.org/gitweb.cgi/x264.git/?a=commit;h=80d0bd4b57163389289714e681bdc53ceaaf0f7a
% X9 t4 v+ M3 ?$ I9 M( `注:DTS 指的是解码时间戳(Decode TimeStamp)。每一帧都分配一个 DTS,对应其在流媒体‘编码顺序’中的位置,不同于由显示时间戳(Presentation TimeStamp)指定的‘显示顺序’。由于使用 B 帧等压缩技术的原因,各帧在视频流中的保存顺序与其显示顺序是不同的,这就造成某些帧需要后续帧的数据。6 Z/ V3 E4 U8 H8 ]1 ^* T
. j$ S( T0 n: Z9 K! h/ P, u' W
Filtering
; i7 K2 ^5 A5 Tvideo-filter8 N$ E8 g# C* m) G  J/ F0 E
x264 过滤系统会在视频源被压缩前处理它们。可以顺序使用多个过滤器。
" V9 B) {  M. j- n5 f& I( s8 |过滤器的基本语法:# p  P4 s, ^3 V* f: n; E8 a5 C
--video-filter <filter>
' x" d# a; E' B' D连续使用多个过滤器时用 / 分隔:
8 e0 j& V5 f0 \, t--video-filter <filter1>/<filter2>  V" S, C0 R# W5 v  b9 W! J2 x4 B$ L$ Q
你可以按自己喜欢的方式链式使用多个过滤器。
; p; k, k! b* c/ d; f% Q+ K可用的过滤器有:
9 H% E# H" O. S7 Q: a% W  U" Hcrop0 j( |5 n7 I) g# g" e
语法: crop:left,top,right,bottom
' O. a- @, w9 A) X从帧的边缘移去像素。就是常说的剪裁喽。" K" s0 J  t- n# r+ n& d" ?: V! q
•        当视频源是yv12、i420、或 nv12 格式时,剪裁的像素必须是2的倍数。
) q9 [7 {% w9 ?5 U5 c7 ?•        当视频源是 i422 格式时,在宽度方向剪裁的像素必须是2的倍数。
- }! m. X1 [2 E4 e1 ~resize
. ], V2 {3 L% o1 {# L: X语法: resize:[width,height][,sar][,fittobox][,csp][,method]
( |$ V8 @6 S" i调整帧尺寸 和/或 转换帧的色彩空间。需要 x264 编译时带上 libswscale 库。$ b0 [' V4 T+ d) L* X/ X
如何调整帧尺寸有几种可能的方式:
# r$ g0 g' D2 A$ A( A6 L•        仅 分辨率:按照指定的分辨率调整帧尺寸,同时调整 SAR 从而避免图像拉伸变形。! k* N9 k, Y; E. [  l) @
•        仅 SAR:设定 SAR,同时调整帧尺寸从而避免图像拉伸变形。! j$ A0 ?% Y. T
•        分辨率 + SAR:按照指定的分辨率调整帧尺寸并且按指定值设定 SAR,可能产生拉伸变形。2 `! n9 `3 S) u
•        Fittobox:基于指定约束模式调整帧尺寸,分辨率按1:1的 SAR 自适应。
% ?4 Y6 U! i* B" s) K•        width:调整帧尺寸来符合指定宽度约束。
. ~8 Y5 H0 d! u: n6 B# Q4 H•        height:调整帧尺寸来符合指定高度约束。. a- r9 x, g+ Q4 t7 b6 |
•        both:调整帧尺寸来符合指定矩形约束。4 ?; d8 M0 h! K7 x" r( L
•        Fittobox + SAR:除额外指定 SAR 外与 Fittobox 类似,收缩视频使可变形视频符合指定的约束。% Y; O1 Q- H( E  p/ n
与调整尺寸无关的参数:# o5 u5 k: V8 y! ]3 g
•        csp:同时将帧转换为指定的色彩空间。可用的色彩空间列表见 x264 --fullhelp$ q, U/ i4 B7 N7 r
•        method (默认 bicubic):当调整帧尺寸时,使用指定的调整方法
! U, X0 W! u. q2 Q$ l: M/ pfastbilinear, bilinear, bicubic, experimental, point, area, bicublin, gauss, sinc, lanczos, spline
5 L6 Z! ]. d! \* Z# \( M- s% l- [范例:
: A/ i- K" z7 o, `  r: F& d  Cresize:width=1280,height=720,method=spline
) y" m0 h  G9 S( a+ y" Gselect_every" v8 H8 Q4 P& c/ s: G- T! y
语法: select_every:step,offset1[,offset2,...]
3 N3 Y! v0 r4 a& s, q仅选择部分输入帧进行编码,丢弃其它。每隔 step 帧,仅使用 offset 指定的帧。例如:$ Z' C0 J6 ~) d$ |7 ]
每2帧,丢弃第1帧,采用第2帧:! S- ?7 h. h! T" O6 N: W
select_every:2,1
) {' ^- \& E9 x6 a  H* F每3帧,采用第0,1帧,丢弃第2帧:
  c+ v* k, Z/ q0 qselect_every:3,0,1
3 x& N6 e8 Z* u1 A5 Q) E5 a; t4 n* g更多例子:http://avisynth.org/mediawiki/Select#SelectEvery2 J9 |5 U) G# f  ~$ p- B" `4 @
另请参阅
% K9 r: f9 Y1 W1 h2 ~" c•        http://git.videolan.org/?p=x264.git;a=tree;f=doc;hb=HEAD+ e( f5 m& O5 Z) y
x264 源代码树中的文档。几乎是最高级别的技术特性解释。一些文档相当老,但是仍然很精确。. N- Q% l7 P7 Q4 y! s' B3 m) w
•        http://sites.google.com/site/linuxencoding/8 H8 S4 P; {5 ^9 V8 r. P
Linux 编码 - x264 编码选项指南。非常实用的选项。大多数由 x264 的开发者Dark Shikari 编写。: H3 Y( A; }+ G% E0 O: F+ A
•        http://mulder.dummwiedeutsch.de/pub/x264& w) p& w3 L: Z7 Z
Lord Mulder 的 x264 Avidemux 指南。值得一看
% @" G8 f% Y. W' W3 t•        http://sites.google.com/site/x264bluray/home. k7 Z: }0 u* H  d: X5 {
使用 x264 进行蓝光编码。很多范例,极有用。
3 {! W. a. E( G9 @; c

点评

我有个参数没弄明白bframe到底是干嘛的能详细讲讲吗  发表于 2012-6-11 21:31
发表于 2011-10-22 22:25:13 | 显示全部楼层
很棒的资料,多谢分享!
发表于 2011-11-20 02:39:22 | 显示全部楼层
学习了,谢谢啊
发表于 2011-11-22 15:29:29 | 显示全部楼层
很详细啊。。。慢慢学习。。。
发表于 2011-12-8 01:03:20 | 显示全部楼层
我刚学 就是弄不清楚 bf,ref,sub,这几个的参数越大 代表的意思是什么 ??

点评

http://www.2gdy.cc/diy/new.html 二哥影视最近更新的100个影片  发表于 2015-3-31 19:19
发表于 2011-12-11 00:03:04 | 显示全部楼层
哇 这也太牛了 我慢慢看 后慢慢研究
发表于 2011-12-13 14:21:01 | 显示全部楼层
非常感谢,学习了很多,明白了很多,也增加了更多的疑问: }% Q4 {+ Y7 j- t. w& p* @; u

7 Z9 |; O& [$ j$ X" f# N- g9 [* u那几个wiki的链接中间都省略了,帮忙更新下吧,而且好像介绍有点老了,现在的x264有些参数和某些默认参数有点不同了……
发表于 2012-2-2 09:54:32 | 显示全部楼层
很有用的资料
发表于 2012-2-26 16:22:32 | 显示全部楼层
牛x资料...希望将来用的时候还能找到
发表于 2012-2-28 06:09:40 | 显示全部楼层
写的很详细,楼主费心了,感谢~
发表于 2012-3-25 07:04:02 | 显示全部楼层
本帖最后由 苍狼白鹿 于 2012-3-25 07:11 编辑
# C5 n  R( v$ S# i2 i9 U& n9 Q  Z4 x+ p& t. P6 ]
宏區塊MB(Macroblock)是一種影像壓縮的術語。2 e# S0 m' f  K* o- P2 s* ~
宏區塊是運動預測的基本單位,一張完整的圖像(frame)通常會被切割成幾個宏區塊,MPEG2和較早期的codec定義宏區塊都是 8x8 pixels. 現代的一點codec像是 h.263 和 h.264 的宏區塊通常都是 16x16 pixels和相應區域內的Cb 、Cr 色差信號陣列共同組成。
2 L7 q- N% u, ^7 `- V3 i宏區塊為基準來選擇特定的預測類型,而非整個圖像都使用同樣的類型:2 M# i4 U8 A; p2 y% f
I 圖像(Intra pictures)只可含有節點宏區塊
* u* L' s; w9 V6 ~3 Y% F" H7 ^P 圖像(Predictive pictures)可含有節點宏區塊或預測宏區塊/ f2 Z- b( Q8 k! h* X4 _
B 圖像(Bi-predictive pictures)可含有節點、預測和前後預測宏區塊
发表于 2012-3-27 16:12:52 | 显示全部楼层
慢慢揣摩,慢慢品味!
发表于 2012-4-1 22:41:27 | 显示全部楼层
感谢!
8 s6 S( h8 {/ B2 y) u# T$ e+ ^9 LMARK学习~
发表于 2012-7-20 22:26:48 | 显示全部楼层
没看完,眼睛都酸了,下次接着学习啊
发表于 2013-1-29 20:58:48 | 显示全部楼层
太复杂了,看不懂
发表于 2013-11-19 10:09:24 | 显示全部楼层
一直很纠结H264和X264的区别,这下懂了,楼主写的很详细。
发表于 2014-1-2 16:46:57 | 显示全部楼层
非常感谢,学习了很多,明白了很多,也增加了更多的疑问9 R  ?$ C; w( v& F* Q  G4 t
发表于 2015-3-14 08:05:51 | 显示全部楼层
楼主强大!多谢楼主耐心指导!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

本站仅做广众交流之平台、所有内容均为网友发布,如网友所发内容侵犯您的权益,请邮件告知,收到邮件并确认后24小时内删除,投诉专用邮箱:iminisd.com@gmail.com

Archiver|手机版|小黑屋|mFANs  

GMT+8, 2019-1-21 01:20 , Processed in 0.078327 second(s), 11 queries , Memcache On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表