annotate DOCS/tech/snow.txt @ 15122:4d25185dedaa

Fixes suggested by The Wanderer.
author gpoirier
date Mon, 11 Apr 2005 11:13:48 +0000
parents 81ab69124505
children e743f75cdcc4
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
15117
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
1 HOW TO TEST SNOW
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
2 ----------------
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
3
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
4 Snow is an experimental wavelet-based codec made by the FFmpeg developers,
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
5 and while it is still in heavy development, it is already giving very good
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
6 results.
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
7 Be very careful though, as the format of the bitstream produced might
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
8 change, do not rely on it to store videos that you value.
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
9 For this reason, MEncoder will not encode without 'vstrict=-1' on the
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
10 command line.
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
11
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
12
15122
4d25185dedaa Fixes suggested by The Wanderer.
gpoirier
parents: 15117
diff changeset
13 OPTIONS RECOGNIZED BY SNOW
15117
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
14
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
15 * vqscale=<0.01-255>
15122
4d25185dedaa Fixes suggested by The Wanderer.
gpoirier
parents: 15117
diff changeset
16 Encoding quality, sane range 1-10, default: 0 (lossless). May be
4d25185dedaa Fixes suggested by The Wanderer.
gpoirier
parents: 15117
diff changeset
17 fractional.
15117
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
18 A given quality in snow needs a somewhat lower qscale than the same
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
19 quality in MPEG-4.
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
20 Note that 0 may not be specified; if you want lossless encoding, you
15122
4d25185dedaa Fixes suggested by The Wanderer.
gpoirier
parents: 15117
diff changeset
21 must leave out vqscale.
15117
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
22
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
23 * cmp, subcmp, mbcmp
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
24 Set the comparison function, default: 0 (SAD).
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
25 useful values = 0 (SAD), 1 (SSD), 11 (5/3 wavelet), 12 (9/7 wavelet).
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
26 Experience shows that SSD is the best most of the time, while SAD is
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
27 slightly better the remainder of the time.
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
28 You can add 256 to any of the options to enable chroma motion
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
29 estimation for that comparison (e.g. mbcmp=257 for SSD with chroma),
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
30 but it doesn't seem to help much for the moment.
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
31
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
32 * pred=<0-2>
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
33 Wavelet type. 0 (9/7 wavelet), 1 (5/3 wavelet), 2 (13/7 wavelet).
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
34 9/7 is probably better for for lossy coding, and 5/3 for lossless.
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
35
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
36 * last_pred=<0-3>
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
37 Tries a few extra predicted motion vectors before doing EPZS search,
15122
4d25185dedaa Fixes suggested by The Wanderer.
gpoirier
parents: 15117
diff changeset
38 default: 0.
15117
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
39 This option has negligible effect on both speed and quality of snow,
15122
4d25185dedaa Fixes suggested by The Wanderer.
gpoirier
parents: 15117
diff changeset
40 so just leave it off. (It does, however, help MPEG-4.)
15117
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
41
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
42 * qpel
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
43 Refines motion estimation, default: off.
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
44 This setting always helps compressibility, but costs some CPU time
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
45 both while encoding and decoding.
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
46
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
47 * v4mv
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
48 Allows smaller motion partitions, default: off.
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
49 The current MB decision algorithm doesn't make very good use of this:
15122
4d25185dedaa Fixes suggested by The Wanderer.
gpoirier
parents: 15117
diff changeset
50 It improves quality, but also increases bitrate. (You could get
15117
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
51 more quality per bitrate by reducing quantizer instead.)
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
52
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
53
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
54 v4mv and the wavelet cmp functions are theoretically good, but in practice
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
55 won't work well until we get OBMC-aware motion estimation.
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
56
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
57 In short:
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
58 The best options in almost all cases are
81ab69124505 Initial commit.
gpoirier
parents:
diff changeset
59 vcodec=snow:vstrict=-1:vqscale=$N:pred=0:cmp=1:subcmp=1:mbcmp=1:qpel