1 \input texinfo @c -*- texinfo -*-
3 @settitle FFmpeg Documentation
6 @center @titlefont{FFmpeg Documentation}
13 FFmpeg is a very fast video and audio converter. It can also grab from
14 a live audio/video source.
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
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.
27 @section Video and Audio grabbing
29 FFmpeg can grab video and audio from devices given that you specify the input
33 ffmpeg -f oss -i /dev/dsp -f video4linux2 -i /dev/video0 /tmp/out.mpg
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
44 FFmpeg can grab the X11 display.
47 ffmpeg -f x11grab -s cif -i :0.0 /tmp/out.mpg
50 0.0 is display.screen number of your X11 server, same as
51 the DISPLAY environment variable.
54 ffmpeg -f x11grab -s cif -i :0.0+10,20 /tmp/out.mpg
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.
60 @section Video and Audio file format conversion
62 * FFmpeg can use any supported file format and protocol as input:
66 * You can use YUV files as input:
69 ffmpeg -i /tmp/test%d.Y /tmp/out.mpg
72 It will use the files:
74 /tmp/test0.Y, /tmp/test0.U, /tmp/test0.V,
75 /tmp/test1.Y, /tmp/test1.U, /tmp/test1.V, etc...
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.
83 * You can input from a raw YUV420P file:
86 ffmpeg -i /tmp/test.yuv /tmp/out.avi
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.
93 * You can output to a raw YUV420P file:
96 ffmpeg -i mydivx.avi hugefile.yuv
99 * You can set several input files and output files:
102 ffmpeg -i /tmp/a.wav -s 640x480 -i /tmp/a.yuv /tmp/a.mpg
105 Converts the audio file a.wav and the raw YUV video file a.yuv
108 * You can also do audio and video conversions at the same time:
111 ffmpeg -i /tmp/a.wav -ar 22050 /tmp/a.mp2
114 Converts a.wav to MPEG audio at 22050Hz sample rate.
116 * You can encode to several formats at the same time and define a
117 mapping from input stream to output streams:
120 ffmpeg -i /tmp/a.wav -ab 64k /tmp/a.mp2 -ab 128k /tmp/b.mp2 -map 0:0 -map 0:0
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.
127 * You can transcode decrypted VOBs:
130 ffmpeg -i snatch_1.vob -f avi -vcodec mpeg4 -b 800k -g 300 -bf 2 -acodec libmp3lame -ab 128k snatch.avi
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.
142 NOTE: To see the supported input formats, use @code{ffmpeg -formats}.
149 The generic syntax is:
152 @c man begin SYNOPSIS
153 ffmpeg [[infile options][@option{-i} @var{infile}]]... @{[outfile options] @var{outfile}@}...
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.
162 * To set the video bitrate of the output file to 64kbit/s:
164 ffmpeg -i input.avi -b 64k output.avi
167 * To force the frame rate of the input and output file to 24 fps:
169 ffmpeg -r 24 -i input.avi output.avi
172 * To force the frame rate of the output file to 24 fps:
174 ffmpeg -i input.avi -r 24 output.avi
177 * To force the frame rate of input file to 1 fps and the output file to 24 fps:
179 ffmpeg -r 1 -i input.avi -r 24 output.avi
182 The format option may be needed for raw input files.
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.
190 @section Main options
203 Show available formats, codecs, protocols, ...
208 @item -i @var{filename}
212 Overwrite output files.
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.
219 @item -fs @var{limit_size}
220 Set the file size limit.
222 @item -ss @var{position}
223 Seek to given time position in seconds.
224 @code{hh:mm:ss[.xxx]} syntax is also supported.
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.
234 @item -title @var{string}
237 @item -timestamp @var{time}
240 @item -author @var{string}
243 @item -copyright @var{string}
246 @item -comment @var{string}
249 @item -album @var{string}
252 @item -track @var{number}
255 @item -year @var{number}
258 @item -v @var{number}
259 Set the logging verbosity level.
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:
267 ffmpeg -i myfile.avi -target vcd /tmp/vcd.mpg
270 Nevertheless you can specify additional options as long as you know
271 they do not conflict with the standard, as in:
274 ffmpeg -i myfile.avi -target vcd -bf 2 /tmp/vcd.mpg
277 @item -dframes @var{number}
278 Set the number of data frames to record.
280 @item -scodec @var{codec}
281 Force subtitle codec ('copy' to copy stream).
284 Add a new subtitle stream to the current output stream.
286 @item -slang @var{code}
287 Set the ISO 639 language code (3 letters) of the current subtitle stream.
291 @section Video Options
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.
299 Set frame rate (Hz value, fraction or abbreviation), (default = 25).
301 Set frame size. The format is @samp{wxh} (ffserver default = 160x128, ffmpeg default = same as source).
302 The following abbreviations are recognized:
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)).
386 Disable video recording.
387 @item -bt @var{tolerance}
388 Set video bitrate tolerance (in bit/s).
389 @item -maxrate @var{bitrate}
390 Set max video bitrate (in bit/s).
391 @item -minrate @var{bitrate}
392 Set min video bitrate (in bit/s).
393 @item -bufsize @var{size}
394 Set video buffer verifier buffer size (in bits).
395 @item -vcodec @var{codec}
396 Force video codec to @var{codec}. Use the @code{copy} special value to
397 tell that the raw codec data must be copied as is.
399 Use same video quality as source (implies VBR).
402 Select the pass number (1 or 2). It is useful to do two pass
403 encoding. The statistics of the video are recorded in the first
404 pass and the video is generated at the exact requested bitrate
407 @item -passlogfile @var{file}
408 Set two pass logfile name to @var{file}.
411 Add a new video stream to the current output stream.
415 @section Advanced Video Options
418 @item -pix_fmt @var{format}
419 Set pixel format. Use 'list' as parameter to show all the supported
421 @item -sws_flags @var{flags}
422 Set SwScaler flags (only available when compiled with swscale support).
423 @item -g @var{gop_size}
424 Set the group of pictures size.
426 Use only intra frames.
429 @item -qscale @var{q}
430 Use fixed video quantizer scale (VBR).
432 minimum video quantizer scale (VBR)
434 maximum video quantizer scale (VBR)
436 maximum difference between the quantizer scales (VBR)
437 @item -qblur @var{blur}
438 video quantizer scale blur (VBR)
439 @item -qcomp @var{compression}
440 video quantizer scale compression (VBR)
442 @item -lmin @var{lambda}
443 minimum video lagrange factor (VBR)
444 @item -lmax @var{lambda}
445 max video lagrange factor (VBR)
446 @item -mblmin @var{lambda}
447 minimum macroblock quantizer scale (VBR)
448 @item -mblmax @var{lambda}
449 maximum macroblock quantizer scale (VBR)
451 These four options (lmin, lmax, mblmin, mblmax) use 'lambda' units,
452 but you may use the QP2LAMBDA constant to easily convert from 'q' units:
454 ffmpeg -i src.ext -lmax 21*QP2LAMBDA dst.ext
457 @item -rc_init_cplx @var{complexity}
458 initial complexity for single pass encoding
459 @item -b_qfactor @var{factor}
460 qp factor between P- and B-frames
461 @item -i_qfactor @var{factor}
462 qp factor between P- and I-frames
463 @item -b_qoffset @var{offset}
464 qp offset between P- and B-frames
465 @item -i_qoffset @var{offset}
466 qp offset between P- and I-frames
467 @item -rc_eq @var{equation}
468 Set rate control equation (@pxref{FFmpeg formula
469 evaluator}) (default = @code{tex^qComp}).
470 @item -rc_override @var{override}
471 rate control override for specific intervals
472 @item -me_method @var{method}
473 Set motion estimation method to @var{method}.
474 Available methods are (from lowest to best quality):
477 Try just the (0, 0) vector.
486 exhaustive search (slow and marginally better than epzs)
489 @item -dct_algo @var{algo}
490 Set DCT algorithm to @var{algo}. Available values are:
493 FF_DCT_AUTO (default)
506 @item -idct_algo @var{algo}
507 Set IDCT algorithm to @var{algo}. Available values are:
510 FF_IDCT_AUTO (default)
534 Set error resilience to @var{n}.
537 FF_ER_CAREFUL (default)
543 FF_ER_VERY_AGGRESSIVE
546 @item -ec @var{bit_mask}
547 Set error concealment to @var{bit_mask}. @var{bit_mask} is a bit mask of
548 the following values:
551 FF_EC_GUESS_MVS (default = enabled)
553 FF_EC_DEBLOCK (default = enabled)
556 @item -bf @var{frames}
557 Use 'frames' B-frames (supported for MPEG-1, MPEG-2 and MPEG-4).
558 @item -mbd @var{mode}
562 FF_MB_DECISION_SIMPLE: Use mb_cmp (cannot change it yet in FFmpeg).
564 FF_MB_DECISION_BITS: Choose the one which needs the fewest bits.
566 FF_MB_DECISION_RD: rate distortion
570 Use four motion vector by macroblock (MPEG-4 only).
572 Use data partitioning (MPEG-4 only).
573 @item -bug @var{param}
574 Work around encoder bugs that are not auto-detected.
575 @item -strict @var{strictness}
576 How strictly to follow the standards.
578 Enable Advanced intra coding (h263+).
580 Enable Unlimited Motion Vector (h263+)
583 Deinterlace pictures.
585 Force interlacing support in encoder (MPEG-2 and MPEG-4 only).
586 Use this option if your input file is interlaced and you want
587 to keep the interlaced format for minimum losses.
588 The alternative is to deinterlace the input stream with
589 @option{-deinterlace}, but deinterlacing introduces losses.
591 Calculate PSNR of compressed frames.
593 Dump video coding statistics to @file{vstats_HHMMSS.log}.
594 @item -vstats_file @var{file}
595 Dump video coding statistics to @var{file}.
596 @item -vhook @var{module}
597 Insert video processing @var{module}. @var{module} contains the module
598 name and its parameters separated by spaces.
600 top=1/bottom=0/auto=-1 field first
601 @item -dc @var{precision}
603 @item -vtag @var{fourcc/tag}
604 Force video tag/fourcc.
607 @item -vbsf @var{bitstream_filter}
608 Bitstream filters available are "dump_extra", "remove_extra", "noise".
611 @section Audio Options
614 @item -aframes @var{number}
615 Set the number of audio frames to record.
617 Set the audio sampling frequency (default = 44100 Hz).
618 @item -ab @var{bitrate}
619 Set the audio bitrate in bit/s (default = 64k).
620 @item -ac @var{channels}
621 Set the number of audio channels (default = 1).
623 Disable audio recording.
624 @item -acodec @var{codec}
625 Force audio codec to @var{codec}. Use the @code{copy} special value to
626 specify that the raw codec data must be copied as is.
628 Add a new audio track to the output file. If you want to specify parameters,
629 do so before @code{-newaudio} (@code{-acodec}, @code{-ab}, etc..).
631 Mapping will be done automatically, if the number of output streams is equal to
632 the number of input streams, else it will pick the first one that matches. You
633 can override the mapping using @code{-map} as usual.
637 ffmpeg -i file.mpg -vcodec copy -acodec ac3 -ab 384k test.mpg -acodec mp2 -ab 192k -newaudio
639 @item -alang @var{code}
640 Set the ISO 639 language code (3 letters) of the current audio stream.
643 @section Advanced Audio options:
646 @item -atag @var{fourcc/tag}
647 Force audio tag/fourcc.
648 @item -absf @var{bitstream_filter}
649 Bitstream filters available are "dump_extra", "remove_extra", "noise", "mp3comp", "mp3decomp".
652 @section Subtitle options:
655 @item -scodec @var{codec}
656 Force subtitle codec ('copy' to copy stream).
658 Add a new subtitle stream to the current output stream.
659 @item -slang @var{code}
660 Set the ISO 639 language code (3 letters) of the current subtitle stream.
663 @section Audio/Video grab options
666 @item -vc @var{channel}
667 Set video grab channel (DV1394 only).
668 @item -tvstd @var{standard}
669 Set television standard (NTSC, PAL (SECAM)).
671 Synchronize read on input.
674 @section Advanced options
677 @item -map input stream id[:input stream id]
678 Set stream mapping from input streams to output streams.
679 Just enumerate the input streams in the order you want them in the output.
680 [input stream id] sets the (input) stream to sync against.
681 @item -map_meta_data @var{outfile}:@var{infile}
682 Set meta data information of @var{outfile} from @var{infile}.
684 Print specific debug info.
686 Add timings for benchmarking.
688 Dump each input packet.
690 When dumping packets, also dump the payload.
692 Only use bit exact algorithms (for codec testing).
694 Set packet size in bits.
696 Read input at native frame rate. Mainly used to simulate a grab device.
698 Loop over the input stream. Currently it works only for image
699 streams. This option is used for automatic FFserver testing.
700 @item -loop_output @var{number_of_times}
701 Repeatedly loop output for formats that support looping such as animated GIF
702 (0 will loop the output infinitely).
703 @item -threads @var{count}
705 @item -vsync @var{parameter}
706 Video sync method. Video will be stretched/squeezed to match the timestamps,
707 it is done by duplicating and dropping frames. With -map you can select from
708 which stream the timestamps should be taken. You can leave either video or
709 audio unchanged and sync the remaining stream(s) to the unchanged one.
710 @item -async @var{samples_per_second}
711 Audio sync method. "Stretches/squeezes" the audio stream to match the timestamps,
712 the parameter is the maximum samples per second by which the audio is changed.
713 -async 1 is a special case where only the start of the audio stream is corrected
714 without any later correction.
716 Copy timestamps from input to output.
718 Finish encoding when the shortest input stream ends.
719 @item -dts_delta_threshold
720 Timestamp discontinuity delta threshold.
721 @item -muxdelay @var{seconds}
722 Set the maximum demux-decode delay.
723 @item -muxpreload @var{seconds}
724 Set the initial demux-decode delay.
727 @node FFmpeg formula evaluator
728 @section FFmpeg formula evaluator
730 When evaluating a rate control string, FFmpeg uses an internal formula
733 The following binary operators are available: @code{+}, @code{-},
734 @code{*}, @code{/}, @code{^}.
736 The following unary operators are available: @code{+}, @code{-},
739 The following functions are available:
761 The following constants are available:
790 @settitle FFmpeg video converter
793 ffserver(1), ffplay(1) and the HTML documentation of @file{ffmpeg}.
804 The file name can be @file{-} to read from standard input or to write
807 FFmpeg also handles many protocols specified with an URL syntax.
809 Use 'ffmpeg -formats' to see a list of the supported protocols.
811 The protocol @code{http:} is currently used only to communicate with
812 FFserver (see the FFserver documentation). When FFmpeg will be a
813 video player it will also be used for streaming :-)
818 @item For streaming at very low bitrate application, use a low frame rate
819 and a small GOP size. This is especially true for RealVideo where
820 the Linux player does not seem to be very fast, so it can miss
821 frames. An example is:
824 ffmpeg -g 3 -r 3 -t 10 -b 50k -s qcif -f rv10 /tmp/b.rm
827 @item The parameter 'q' which is displayed while encoding is the current
828 quantizer. The value 1 indicates that a very good quality could
829 be achieved. The value 31 indicates the worst quality. If q=31 appears
830 too often, it means that the encoder cannot compress enough to meet
831 your bitrate. You must either increase the bitrate, decrease the
832 frame rate or decrease the frame size.
834 @item If your computer is not fast enough, you can speed up the
835 compression at the expense of the compression ratio. You can use
836 '-me zero' to speed up motion estimation, and '-intra' to disable
837 motion estimation completely (you have only I-frames, which means it
838 is about as good as JPEG compression).
840 @item To have very low audio bitrates, reduce the sampling frequency
841 (down to 22050 kHz for MPEG audio, 22050 or 11025 for AC3).
843 @item To have a constant quality (but a variable bitrate), use the option
844 '-qscale n' when 'n' is between 1 (excellent quality) and 31 (worst
847 @item When converting video files, you can use the '-sameq' option which
848 uses the same quality factor in the encoder as in the decoder.
849 It allows almost lossless encoding.