]> git.sesse.net Git - ffmpeg/blob - doc/ffmpeg-doc.texi
b87fd3ac0c9a44954eef714a9e1b289515ae373e
[ffmpeg] / doc / ffmpeg-doc.texi
1 \input texinfo @c -*- texinfo -*-
2
3 @settitle FFmpeg Documentation
4 @titlepage
5 @sp 7
6 @center @titlefont{FFmpeg Documentation}
7 @sp 3
8 @end titlepage
9
10
11 @chapter Introduction
12
13 FFmpeg is a very fast video and audio converter. It can also grab from
14 a live audio/video source.
15
16 The command line interface is designed to be intuitive, in the sense
17 that FFmpeg tries to figure out all parameters that can possibly be
18 derived automatically. You usually only have to specify the target
19 bitrate you want.
20
21 FFmpeg can also convert from any sample rate to any other, and resize
22 video on the fly with a high quality polyphase filter.
23
24 @chapter Quick Start
25
26 @c man begin EXAMPLES
27 @section Video and Audio grabbing
28
29 FFmpeg can grab video and audio from devices given that you specify the input
30 format and device.
31
32 @example
33 ffmpeg -f oss -i /dev/dsp -f video4linux2 -i /dev/video0 /tmp/out.mpg
34 @end example
35
36 Note that you must activate the right video source and channel before
37 launching FFmpeg with any TV viewer such as xawtv
38 (@url{http://bytesex.org/xawtv/}) by Gerd Knorr. You also
39 have to set the audio recording levels correctly with a
40 standard mixer.
41
42 @section X11 grabbing
43
44 FFmpeg can grab the X11 display.
45
46 @example
47 ffmpeg -f x11grab -s cif -i :0.0 /tmp/out.mpg
48 @end example
49
50 0.0 is display.screen number of your X11 server, same as
51 the DISPLAY environment variable.
52
53 @example
54 ffmpeg -f x11grab -s cif -i :0.0+10,20 /tmp/out.mpg
55 @end example
56
57 0.0 is display.screen number of your X11 server, same as the DISPLAY environment
58 variable. 10 is the x-offset and 20 the y-offset for the grabbing.
59
60 @section Video and Audio file format conversion
61
62 * FFmpeg can use any supported file format and protocol as input:
63
64 Examples:
65
66 * You can use YUV files as input:
67
68 @example
69 ffmpeg -i /tmp/test%d.Y /tmp/out.mpg
70 @end example
71
72 It will use the files:
73 @example
74 /tmp/test0.Y, /tmp/test0.U, /tmp/test0.V,
75 /tmp/test1.Y, /tmp/test1.U, /tmp/test1.V, etc...
76 @end example
77
78 The Y files use twice the resolution of the U and V files. They are
79 raw files, without header. They can be generated by all decent video
80 decoders. You must specify the size of the image with the @option{-s} option
81 if FFmpeg cannot guess it.
82
83 * You can input from a raw YUV420P file:
84
85 @example
86 ffmpeg -i /tmp/test.yuv /tmp/out.avi
87 @end example
88
89 test.yuv is a file containing raw YUV planar data. Each frame is composed
90 of the Y plane followed by the U and V planes at half vertical and
91 horizontal resolution.
92
93 * You can output to a raw YUV420P file:
94
95 @example
96 ffmpeg -i mydivx.avi hugefile.yuv
97 @end example
98
99 * You can set several input files and output files:
100
101 @example
102 ffmpeg -i /tmp/a.wav -s 640x480 -i /tmp/a.yuv /tmp/a.mpg
103 @end example
104
105 Converts the audio file a.wav and the raw YUV video file a.yuv
106 to MPEG file a.mpg.
107
108 * You can also do audio and video conversions at the same time:
109
110 @example
111 ffmpeg -i /tmp/a.wav -ar 22050 /tmp/a.mp2
112 @end example
113
114 Converts a.wav to MPEG audio at 22050Hz sample rate.
115
116 * You can encode to several formats at the same time and define a
117 mapping from input stream to output streams:
118
119 @example
120 ffmpeg -i /tmp/a.wav -ab 64k /tmp/a.mp2 -ab 128k /tmp/b.mp2 -map 0:0 -map 0:0
121 @end example
122
123 Converts a.wav to a.mp2 at 64 kbits and to b.mp2 at 128 kbits. '-map
124 file:index' specifies which input stream is used for each output
125 stream, in the order of the definition of output streams.
126
127 * You can transcode decrypted VOBs:
128
129 @example
130 ffmpeg -i snatch_1.vob -f avi -vcodec mpeg4 -b 800k -g 300 -bf 2 -acodec libmp3lame -ab 128k snatch.avi
131 @end example
132
133 This is a typical DVD ripping example; the input is a VOB file, the
134 output an AVI file with MPEG-4 video and MP3 audio. Note that in this
135 command we use B-frames so the MPEG-4 stream is DivX5 compatible, and
136 GOP size is 300 which means one intra frame every 10 seconds for 29.97fps
137 input video. Furthermore, the audio stream is MP3-encoded so you need
138 to enable LAME support by passing @code{--enable-libmp3lame} to configure.
139 The mapping is particularly useful for DVD transcoding
140 to get the desired audio language.
141
142 NOTE: To see the supported input formats, use @code{ffmpeg -formats}.
143 @c man end
144
145 @chapter Invocation
146
147 @section Syntax
148
149 The generic syntax is:
150
151 @example
152 @c man begin SYNOPSIS
153 ffmpeg [[infile options][@option{-i} @var{infile}]]... @{[outfile options] @var{outfile}@}...
154 @c man end
155 @end example
156 @c man begin DESCRIPTION
157 As a general rule, options are applied to the next specified
158 file. Therefore, order is important, and you can have the same
159 option on the command line multiple times. Each occurrence is
160 then applied to the next input or output file.
161
162 * To set the video bitrate of the output file to 64kbit/s:
163 @example
164 ffmpeg -i input.avi -b 64k output.avi
165 @end example
166
167 * To force the frame rate of the input and output file to 24 fps:
168 @example
169 ffmpeg -r 24 -i input.avi output.avi
170 @end example
171
172 * To force the frame rate of the output file to 24 fps:
173 @example
174 ffmpeg -i input.avi -r 24 output.avi
175 @end example
176
177 * To force the frame rate of input file to 1 fps and the output file to 24 fps:
178 @example
179 ffmpeg -r 1 -i input.avi -r 24 output.avi
180 @end example
181
182 The format option may be needed for raw input files.
183
184 By default, FFmpeg tries to convert as losslessly as possible: It
185 uses the same audio and video parameters for the outputs as the one
186 specified for the inputs.
187 @c man end
188
189 @c man begin OPTIONS
190 @section Main options
191
192 @table @option
193 @item -L
194 Show license.
195
196 @item -h
197 Show help.
198
199 @item -version
200 Show version.
201
202 @item -formats
203 Show available formats, codecs, protocols, ...
204
205 @item -f @var{fmt}
206 Force format.
207
208 @item -i @var{filename}
209 input file name
210
211 @item -y
212 Overwrite output files.
213
214 @item -t @var{duration}
215 Restrict the transcoded/captured video sequence
216 to the duration specified in seconds.
217 @code{hh:mm:ss[.xxx]} syntax is also supported.
218
219 @item -fs @var{limit_size}
220 Set the file size limit.
221
222 @item -ss @var{position}
223 Seek to given time position in seconds.
224 @code{hh:mm:ss[.xxx]} syntax is also supported.
225
226 @item -itsoffset @var{offset}
227 Set the input time offset in seconds.
228 @code{[-]hh:mm:ss[.xxx]} syntax is also supported.
229 This option affects all the input files that follow it.
230 The offset is added to the timestamps of the input files.
231 Specifying a positive offset means that the corresponding
232 streams are delayed by 'offset' seconds.
233
234 @item -title @var{string}
235 Set the title.
236
237 @item -timestamp @var{time}
238 Set the timestamp.
239
240 @item -author @var{string}
241 Set the author.
242
243 @item -copyright @var{string}
244 Set the copyright.
245
246 @item -comment @var{string}
247 Set the comment.
248
249 @item -album @var{string}
250 Set the album.
251
252 @item -track @var{number}
253 Set the track.
254
255 @item -year @var{number}
256 Set the year.
257
258 @item -v @var{number}
259 Set the logging verbosity level.
260
261 @item -target @var{type}
262 Specify target file type ("vcd", "svcd", "dvd", "dv", "dv50", "pal-vcd",
263 "ntsc-svcd", ... ). All the format options (bitrate, codecs,
264 buffer sizes) are then set automatically. You can just type:
265
266 @example
267 ffmpeg -i myfile.avi -target vcd /tmp/vcd.mpg
268 @end example
269
270 Nevertheless you can specify additional options as long as you know
271 they do not conflict with the standard, as in:
272
273 @example
274 ffmpeg -i myfile.avi -target vcd -bf 2 /tmp/vcd.mpg
275 @end example
276
277 @item -dframes @var{number}
278 Set the number of data frames to record.
279
280 @item -scodec @var{codec}
281 Force subtitle codec ('copy' to copy stream).
282
283 @item -newsubtitle
284 Add a new subtitle stream to the current output stream.
285
286 @item -slang @var{code}
287 Set the ISO 639 language code (3 letters) of the current subtitle stream.
288
289 @end table
290
291 @section Video Options
292
293 @table @option
294 @item -b @var{bitrate}
295 Set the video bitrate in bit/s (default = 200 kb/s).
296 @item -vframes @var{number}
297 Set the number of video frames to record.
298 @item -r @var{fps}
299 Set frame rate (Hz value, fraction or abbreviation), (default = 25).
300 @item -s @var{size}
301 Set frame size. The format is @samp{wxh} (ffserver default = 160x128, ffmpeg default = same as source).
302 The following abbreviations are recognized:
303 @table @samp
304 @item sqcif
305 128x96
306 @item qcif
307 176x144
308 @item cif
309 352x288
310 @item 4cif
311 704x576
312 @item qqvga
313 160x120
314 @item qvga
315 320x240
316 @item vga
317 640x480
318 @item svga
319 800x600
320 @item xga
321 1024x768
322 @item uxga
323 1600x1200
324 @item qxga
325 2048x1536
326 @item sxga
327 1280x1024
328 @item qsxga
329 2560x2048
330 @item hsxga
331 5120x4096
332 @item wvga
333 852x480
334 @item wxga
335 1366x768
336 @item wsxga
337 1600x1024
338 @item wuxga
339 1920x1200
340 @item woxga
341 2560x1600
342 @item wqsxga
343 3200x2048
344 @item wquxga
345 3840x2400
346 @item whsxga
347 6400x4096
348 @item whuxga
349 7680x4800
350 @item cga
351 320x200
352 @item ega
353 640x350
354 @item hd480
355 852x480
356 @item hd720
357 1280x720
358 @item hd1080
359 1920x1080
360 @end table
361
362 @item -aspect @var{aspect}
363 Set aspect ratio (4:3, 16:9 or 1.3333, 1.7777).
364 @item -croptop @var{size}
365 Set top crop band size (in pixels).
366 @item -cropbottom @var{size}
367 Set bottom crop band size (in pixels).
368 @item -cropleft @var{size}
369 Set left crop band size (in pixels).
370 @item -cropright @var{size}
371 Set right crop band size (in pixels).
372 @item -padtop @var{size}
373 Set top pad band size (in pixels).
374 @item -padbottom @var{size}
375 Set bottom pad band size (in pixels).
376 @item -padleft @var{size}
377 Set left pad band size (in pixels).
378 @item -padright @var{size}
379 Set right pad band size (in pixels).
380 @item -padcolor @var{hex_color}
381 Set color of padded bands. The value for padcolor is expressed
382 as a six digit hexadecimal number where the first two digits
383 represent red, the middle two digits green and last two digits
384 blue (default = 000000 (black)).
385 @item -vn
386 Disable video recording.
387 @item -bt @var{tolerance}
388 Set video bitrate tolerance (in bits, default 4000k).
389 Has a minimum value of: (target_bitrate/target_framerate).
390 In 1-pass mode, bitrate tolerance specifies how far ratecontrol is
391 willing to deviate from the target average bitrate value. This is
392 not related to min/max bitrate. Lowering tolerance too much has
393 an adverse effect on quality.
394 @item -maxrate @var{bitrate}
395 Set max video bitrate (in bit/s).
396 Requires -bufsize to be set.
397 @item -minrate @var{bitrate}
398 Set min video bitrate (in bit/s).
399 Most useful in setting up a CBR encode:
400 @example
401 ffmpeg -i myfile.avi -b 4000k -minrate 4000k -maxrate 4000k -bufsize 1835k out.m2v
402 @end example
403 It is of little use elsewise.
404 @item -bufsize @var{size}
405 Set video buffer verifier buffer size (in bits).
406 @item -vcodec @var{codec}
407 Force video codec to @var{codec}. Use the @code{copy} special value to
408 tell that the raw codec data must be copied as is.
409 @item -sameq
410 Use same video quality as source (implies VBR).
411
412 @item -pass @var{n}
413 Select the pass number (1 or 2). It is useful to do two pass
414 encoding. The statistics of the video are recorded in the first
415 pass and the video is generated at the exact requested bitrate
416 in the second pass.
417
418 @item -passlogfile @var{file}
419 Set two pass logfile name to @var{file}.
420
421 @item -newvideo
422 Add a new video stream to the current output stream.
423
424 @end table
425
426 @section Advanced Video Options
427
428 @table @option
429 @item -pix_fmt @var{format}
430 Set pixel format. Use 'list' as parameter to show all the supported
431 pixel formats.
432 @item -sws_flags @var{flags}
433 Set SwScaler flags (only available when compiled with swscale support).
434 @item -g @var{gop_size}
435 Set the group of pictures size.
436 @item -intra
437 Use only intra frames.
438 @item -vdt @var{n}
439 Discard threshold.
440 @item -qscale @var{q}
441 Use fixed video quantizer scale (VBR).
442 @item -qmin @var{q}
443 minimum video quantizer scale (VBR)
444 @item -qmax @var{q}
445 maximum video quantizer scale (VBR)
446 @item -qdiff @var{q}
447 maximum difference between the quantizer scales (VBR)
448 @item -qblur @var{blur}
449 video quantizer scale blur (VBR) (range 0.0 - 1.0)
450 @item -qcomp @var{compression}
451 video quantizer scale compression (VBR) (default 0.5).
452 Constant of ratecontrol equation. Recommended range for default rc_eq: 0.0-1.0
453
454 @item -lmin @var{lambda}
455 minimum video lagrange factor (VBR)
456 @item -lmax @var{lambda}
457 max video lagrange factor (VBR)
458 @item -mblmin @var{lambda}
459 minimum macroblock quantizer scale (VBR)
460 @item -mblmax @var{lambda}
461 maximum macroblock quantizer scale (VBR)
462
463 These four options (lmin, lmax, mblmin, mblmax) use 'lambda' units,
464 but you may use the QP2LAMBDA constant to easily convert from 'q' units:
465 @example
466 ffmpeg -i src.ext -lmax 21*QP2LAMBDA dst.ext
467 @end example
468
469 @item -rc_init_cplx @var{complexity}
470 initial complexity for single pass encoding
471 @item -b_qfactor @var{factor}
472 qp factor between P- and B-frames
473 @item -i_qfactor @var{factor}
474 qp factor between P- and I-frames
475 @item -b_qoffset @var{offset}
476 qp offset between P- and B-frames
477 @item -i_qoffset @var{offset}
478 qp offset between P- and I-frames
479 @item -rc_eq @var{equation}
480 Set rate control equation (@pxref{FFmpeg formula
481 evaluator}) (default = @code{tex^qComp}).
482 @item -rc_override @var{override}
483 rate control override for specific intervals
484 @item -me_method @var{method}
485 Set motion estimation method to @var{method}.
486 Available methods are (from lowest to best quality):
487 @table @samp
488 @item zero
489 Try just the (0, 0) vector.
490 @item phods
491 @item log
492 @item x1
493 @item hex
494 @item umh
495 @item epzs
496 (default method)
497 @item full
498 exhaustive search (slow and marginally better than epzs)
499 @end table
500
501 @item -dct_algo @var{algo}
502 Set DCT algorithm to @var{algo}. Available values are:
503 @table @samp
504 @item 0
505 FF_DCT_AUTO (default)
506 @item 1
507 FF_DCT_FASTINT
508 @item 2
509 FF_DCT_INT
510 @item 3
511 FF_DCT_MMX
512 @item 4
513 FF_DCT_MLIB
514 @item 5
515 FF_DCT_ALTIVEC
516 @end table
517
518 @item -idct_algo @var{algo}
519 Set IDCT algorithm to @var{algo}. Available values are:
520 @table @samp
521 @item 0
522 FF_IDCT_AUTO (default)
523 @item 1
524 FF_IDCT_INT
525 @item 2
526 FF_IDCT_SIMPLE
527 @item 3
528 FF_IDCT_SIMPLEMMX
529 @item 4
530 FF_IDCT_LIBMPEG2MMX
531 @item 5
532 FF_IDCT_PS2
533 @item 6
534 FF_IDCT_MLIB
535 @item 7
536 FF_IDCT_ARM
537 @item 8
538 FF_IDCT_ALTIVEC
539 @item 9
540 FF_IDCT_SH4
541 @item 10
542 FF_IDCT_SIMPLEARM
543 @end table
544
545 @item -er @var{n}
546 Set error resilience to @var{n}.
547 @table @samp
548 @item 1
549 FF_ER_CAREFUL (default)
550 @item 2
551 FF_ER_COMPLIANT
552 @item 3
553 FF_ER_AGGRESSIVE
554 @item 4
555 FF_ER_VERY_AGGRESSIVE
556 @end table
557
558 @item -ec @var{bit_mask}
559 Set error concealment to @var{bit_mask}. @var{bit_mask} is a bit mask of
560 the following values:
561 @table @samp
562 @item 1
563 FF_EC_GUESS_MVS (default = enabled)
564 @item 2
565 FF_EC_DEBLOCK (default = enabled)
566 @end table
567
568 @item -bf @var{frames}
569 Use 'frames' B-frames (supported for MPEG-1, MPEG-2 and MPEG-4).
570 @item -mbd @var{mode}
571 macroblock decision
572 @table @samp
573 @item 0
574 FF_MB_DECISION_SIMPLE: Use mb_cmp (cannot change it yet in FFmpeg).
575 @item 1
576 FF_MB_DECISION_BITS: Choose the one which needs the fewest bits.
577 @item 2
578 FF_MB_DECISION_RD: rate distortion
579 @end table
580
581 @item -4mv
582 Use four motion vector by macroblock (MPEG-4 only).
583 @item -part
584 Use data partitioning (MPEG-4 only).
585 @item -bug @var{param}
586 Work around encoder bugs that are not auto-detected.
587 @item -strict @var{strictness}
588 How strictly to follow the standards.
589 @item -aic
590 Enable Advanced intra coding (h263+).
591 @item -umv
592 Enable Unlimited Motion Vector (h263+)
593
594 @item -deinterlace
595 Deinterlace pictures.
596 @item -ilme
597 Force interlacing support in encoder (MPEG-2 and MPEG-4 only).
598 Use this option if your input file is interlaced and you want
599 to keep the interlaced format for minimum losses.
600 The alternative is to deinterlace the input stream with
601 @option{-deinterlace}, but deinterlacing introduces losses.
602 @item -psnr
603 Calculate PSNR of compressed frames.
604 @item -vstats
605 Dump video coding statistics to @file{vstats_HHMMSS.log}.
606 @item -vstats_file @var{file}
607 Dump video coding statistics to @var{file}.
608 @item -vhook @var{module}
609 Insert video processing @var{module}. @var{module} contains the module
610 name and its parameters separated by spaces.
611 @item -top @var{n}
612 top=1/bottom=0/auto=-1 field first
613 @item -dc @var{precision}
614 Intra_dc_precision.
615 @item -vtag @var{fourcc/tag}
616 Force video tag/fourcc.
617 @item -qphist
618 Show QP histogram.
619 @item -vbsf @var{bitstream_filter}
620 Bitstream filters available are "dump_extra", "remove_extra", "noise", "h264_mp4toannexb", "imxdump", "mjpegadump".
621 @example
622 ffmpeg -i h264.mp4 -vcodec copy -vbsf h264_mp4toannexb -an out.h264
623 @end example
624 @end table
625
626 @section Audio Options
627
628 @table @option
629 @item -aframes @var{number}
630 Set the number of audio frames to record.
631 @item -ar @var{freq}
632 Set the audio sampling frequency (default = 44100 Hz).
633 @item -ab @var{bitrate}
634 Set the audio bitrate in bit/s (default = 64k).
635 @item -ac @var{channels}
636 Set the number of audio channels (default = 1).
637 @item -an
638 Disable audio recording.
639 @item -acodec @var{codec}
640 Force audio codec to @var{codec}. Use the @code{copy} special value to
641 specify that the raw codec data must be copied as is.
642 @item -newaudio
643 Add a new audio track to the output file. If you want to specify parameters,
644 do so before @code{-newaudio} (@code{-acodec}, @code{-ab}, etc..).
645
646 Mapping will be done automatically, if the number of output streams is equal to
647 the number of input streams, else it will pick the first one that matches. You
648 can override the mapping using @code{-map} as usual.
649
650 Example:
651 @example
652 ffmpeg -i file.mpg -vcodec copy -acodec ac3 -ab 384k test.mpg -acodec mp2 -ab 192k -newaudio
653 @end example
654 @item -alang @var{code}
655 Set the ISO 639 language code (3 letters) of the current audio stream.
656 @end table
657
658 @section Advanced Audio options:
659
660 @table @option
661 @item -atag @var{fourcc/tag}
662 Force audio tag/fourcc.
663 @item -absf @var{bitstream_filter}
664 Bitstream filters available are "dump_extra", "remove_extra", "noise", "mp3comp", "mp3decomp".
665 @end table
666
667 @section Subtitle options:
668
669 @table @option
670 @item -scodec @var{codec}
671 Force subtitle codec ('copy' to copy stream).
672 @item -newsubtitle
673 Add a new subtitle stream to the current output stream.
674 @item -slang @var{code}
675 Set the ISO 639 language code (3 letters) of the current subtitle stream.
676 @item -sbsf @var{bitstream_filter}
677 Bitstream filters available are "mov2textsub", "text2movsub".
678 @example
679 ffmpeg -i file.mov -an -vn -sbsf mov2textsub -scodec copy -f rawvideo sub.txt
680 @end example
681 @end table
682
683 @section Audio/Video grab options
684
685 @table @option
686 @item -vc @var{channel}
687 Set video grab channel (DV1394 only).
688 @item -tvstd @var{standard}
689 Set television standard (NTSC, PAL (SECAM)).
690 @item -isync
691 Synchronize read on input.
692 @end table
693
694 @section Advanced options
695
696 @table @option
697 @item -map input stream id[:input stream id]
698 Set stream mapping from input streams to output streams.
699 Just enumerate the input streams in the order you want them in the output.
700 [input stream id] sets the (input) stream to sync against.
701 @item -map_meta_data @var{outfile}:@var{infile}
702 Set meta data information of @var{outfile} from @var{infile}.
703 @item -debug
704 Print specific debug info.
705 @item -benchmark
706 Add timings for benchmarking.
707 @item -dump
708 Dump each input packet.
709 @item -hex
710 When dumping packets, also dump the payload.
711 @item -bitexact
712 Only use bit exact algorithms (for codec testing).
713 @item -ps @var{size}
714 Set packet size in bits.
715 @item -re
716 Read input at native frame rate. Mainly used to simulate a grab device.
717 @item -loop_input
718 Loop over the input stream. Currently it works only for image
719 streams. This option is used for automatic FFserver testing.
720 @item -loop_output @var{number_of_times}
721 Repeatedly loop output for formats that support looping such as animated GIF
722 (0 will loop the output infinitely).
723 @item -threads @var{count}
724 Thread count.
725 @item -vsync @var{parameter}
726 Video sync method. Video will be stretched/squeezed to match the timestamps,
727 it is done by duplicating and dropping frames. With -map you can select from
728 which stream the timestamps should be taken. You can leave either video or
729 audio unchanged and sync the remaining stream(s) to the unchanged one.
730 @item -async @var{samples_per_second}
731 Audio sync method. "Stretches/squeezes" the audio stream to match the timestamps,
732 the parameter is the maximum samples per second by which the audio is changed.
733 -async 1 is a special case where only the start of the audio stream is corrected
734 without any later correction.
735 @item -copyts
736 Copy timestamps from input to output.
737 @item -shortest
738 Finish encoding when the shortest input stream ends.
739 @item -dts_delta_threshold
740 Timestamp discontinuity delta threshold.
741 @item -muxdelay @var{seconds}
742 Set the maximum demux-decode delay.
743 @item -muxpreload @var{seconds}
744 Set the initial demux-decode delay.
745 @end table
746
747 @node FFmpeg formula evaluator
748 @section FFmpeg formula evaluator
749
750 When evaluating a rate control string, FFmpeg uses an internal formula
751 evaluator.
752
753 The following binary operators are available: @code{+}, @code{-},
754 @code{*}, @code{/}, @code{^}.
755
756 The following unary operators are available: @code{+}, @code{-},
757 @code{(...)}.
758
759 The following functions are available:
760 @table @var
761 @item sinh(x)
762 @item cosh(x)
763 @item tanh(x)
764 @item sin(x)
765 @item cos(x)
766 @item tan(x)
767 @item exp(x)
768 @item log(x)
769 @item squish(x)
770 @item gauss(x)
771 @item abs(x)
772 @item max(x, y)
773 @item min(x, y)
774 @item gt(x, y)
775 @item lt(x, y)
776 @item eq(x, y)
777 @item bits2qp(bits)
778 @item qp2bits(qp)
779 @end table
780
781 The following constants are available:
782 @table @var
783 @item PI
784 @item E
785 @item iTex
786 @item pTex
787 @item tex
788 @item mv
789 @item fCode
790 @item iCount
791 @item mcVar
792 @item var
793 @item isI
794 @item isP
795 @item isB
796 @item avgQP
797 @item qComp
798 @item avgIITex
799 @item avgPITex
800 @item avgPPTex
801 @item avgBPTex
802 @item avgTex
803 @end table
804
805 @c man end
806
807 @ignore
808
809 @setfilename ffmpeg
810 @settitle FFmpeg video converter
811
812 @c man begin SEEALSO
813 ffserver(1), ffplay(1) and the HTML documentation of @file{ffmpeg}.
814 @c man end
815
816 @c man begin AUTHOR
817 Fabrice Bellard
818 @c man end
819
820 @end ignore
821
822 @section Protocols
823
824 The file name can be @file{-} to read from standard input or to write
825 to standard output.
826
827 FFmpeg also handles many protocols specified with an URL syntax.
828
829 Use 'ffmpeg -formats' to see a list of the supported protocols.
830
831 The protocol @code{http:} is currently used only to communicate with
832 FFserver (see the FFserver documentation). When FFmpeg will be a
833 video player it will also be used for streaming :-)
834
835 @chapter Tips
836
837 @itemize
838 @item For streaming at very low bitrate application, use a low frame rate
839 and a small GOP size. This is especially true for RealVideo where
840 the Linux player does not seem to be very fast, so it can miss
841 frames. An example is:
842
843 @example
844 ffmpeg -g 3 -r 3 -t 10 -b 50k -s qcif -f rv10 /tmp/b.rm
845 @end example
846
847 @item  The parameter 'q' which is displayed while encoding is the current
848 quantizer. The value 1 indicates that a very good quality could
849 be achieved. The value 31 indicates the worst quality. If q=31 appears
850 too often, it means that the encoder cannot compress enough to meet
851 your bitrate. You must either increase the bitrate, decrease the
852 frame rate or decrease the frame size.
853
854 @item If your computer is not fast enough, you can speed up the
855 compression at the expense of the compression ratio. You can use
856 '-me zero' to speed up motion estimation, and '-intra' to disable
857 motion estimation completely (you have only I-frames, which means it
858 is about as good as JPEG compression).
859
860 @item To have very low audio bitrates, reduce the sampling frequency
861 (down to 22050 kHz for MPEG audio, 22050 or 11025 for AC3).
862
863 @item To have a constant quality (but a variable bitrate), use the option
864 '-qscale n' when 'n' is between 1 (excellent quality) and 31 (worst
865 quality).
866
867 @item When converting video files, you can use the '-sameq' option which
868 uses the same quality factor in the encoder as in the decoder.
869 It allows almost lossless encoding.
870
871 @end itemize
872
873 @bye