1FFPLAY-ALL(1) FFPLAY-ALL(1)
2
3
4
6 ffplay - FFplay media player
7
9 ffplay [options] [input_url]
10
12 FFplay is a very simple and portable media player using the FFmpeg
13 libraries and the SDL library. It is mostly used as a testbed for the
14 various FFmpeg APIs.
15
17 All the numerical options, if not specified otherwise, accept a string
18 representing a number as input, which may be followed by one of the SI
19 unit prefixes, for example: 'K', 'M', or 'G'.
20
21 If 'i' is appended to the SI unit prefix, the complete prefix will be
22 interpreted as a unit prefix for binary multiples, which are based on
23 powers of 1024 instead of powers of 1000. Appending 'B' to the SI unit
24 prefix multiplies the value by 8. This allows using, for example: 'KB',
25 'MiB', 'G' and 'B' as number suffixes.
26
27 Options which do not take arguments are boolean options, and set the
28 corresponding value to true. They can be set to false by prefixing the
29 option name with "no". For example using "-nofoo" will set the boolean
30 option with name "foo" to false.
31
32 Stream specifiers
33 Some options are applied per-stream, e.g. bitrate or codec. Stream
34 specifiers are used to precisely specify which stream(s) a given option
35 belongs to.
36
37 A stream specifier is a string generally appended to the option name
38 and separated from it by a colon. E.g. "-codec:a:1 ac3" contains the
39 "a:1" stream specifier, which matches the second audio stream.
40 Therefore, it would select the ac3 codec for the second audio stream.
41
42 A stream specifier can match several streams, so that the option is
43 applied to all of them. E.g. the stream specifier in "-b:a 128k"
44 matches all audio streams.
45
46 An empty stream specifier matches all streams. For example, "-codec
47 copy" or "-codec: copy" would copy all the streams without reencoding.
48
49 Possible forms of stream specifiers are:
50
51 stream_index
52 Matches the stream with this index. E.g. "-threads:1 4" would set
53 the thread count for the second stream to 4. If stream_index is
54 used as an additional stream specifier (see below), then it selects
55 stream number stream_index from the matching streams. Stream
56 numbering is based on the order of the streams as detected by
57 libavformat except when a program ID is also specified. In this
58 case it is based on the ordering of the streams in the program.
59
60 stream_type[:additional_stream_specifier]
61 stream_type is one of following: 'v' or 'V' for video, 'a' for
62 audio, 's' for subtitle, 'd' for data, and 't' for attachments. 'v'
63 matches all video streams, 'V' only matches video streams which are
64 not attached pictures, video thumbnails or cover arts. If
65 additional_stream_specifier is used, then it matches streams which
66 both have this type and match the additional_stream_specifier.
67 Otherwise, it matches all streams of the specified type.
68
69 p:program_id[:additional_stream_specifier]
70 Matches streams which are in the program with the id program_id. If
71 additional_stream_specifier is used, then it matches streams which
72 both are part of the program and match the
73 additional_stream_specifier.
74
75 #stream_id or i:stream_id
76 Match the stream by stream id (e.g. PID in MPEG-TS container).
77
78 m:key[:value]
79 Matches streams with the metadata tag key having the specified
80 value. If value is not given, matches streams that contain the
81 given tag with any value.
82
83 u Matches streams with usable configuration, the codec must be
84 defined and the essential information such as video dimension or
85 audio sample rate must be present.
86
87 Note that in ffmpeg, matching by metadata will only work properly
88 for input files.
89
90 Generic options
91 These options are shared amongst the ff* tools.
92
93 -L Show license.
94
95 -h, -?, -help, --help [arg]
96 Show help. An optional parameter may be specified to print help
97 about a specific item. If no argument is specified, only basic (non
98 advanced) tool options are shown.
99
100 Possible values of arg are:
101
102 long
103 Print advanced tool options in addition to the basic tool
104 options.
105
106 full
107 Print complete list of options, including shared and private
108 options for encoders, decoders, demuxers, muxers, filters, etc.
109
110 decoder=decoder_name
111 Print detailed information about the decoder named
112 decoder_name. Use the -decoders option to get a list of all
113 decoders.
114
115 encoder=encoder_name
116 Print detailed information about the encoder named
117 encoder_name. Use the -encoders option to get a list of all
118 encoders.
119
120 demuxer=demuxer_name
121 Print detailed information about the demuxer named
122 demuxer_name. Use the -formats option to get a list of all
123 demuxers and muxers.
124
125 muxer=muxer_name
126 Print detailed information about the muxer named muxer_name.
127 Use the -formats option to get a list of all muxers and
128 demuxers.
129
130 filter=filter_name
131 Print detailed information about the filter named filter_name.
132 Use the -filters option to get a list of all filters.
133
134 bsf=bitstream_filter_name
135 Print detailed information about the bitstream filter named
136 bitstream_filter_name. Use the -bsfs option to get a list of
137 all bitstream filters.
138
139 protocol=protocol_name
140 Print detailed information about the protocol named
141 protocol_name. Use the -protocols option to get a list of all
142 protocols.
143
144 -version
145 Show version.
146
147 -buildconf
148 Show the build configuration, one option per line.
149
150 -formats
151 Show available formats (including devices).
152
153 -demuxers
154 Show available demuxers.
155
156 -muxers
157 Show available muxers.
158
159 -devices
160 Show available devices.
161
162 -codecs
163 Show all codecs known to libavcodec.
164
165 Note that the term 'codec' is used throughout this documentation as
166 a shortcut for what is more correctly called a media bitstream
167 format.
168
169 -decoders
170 Show available decoders.
171
172 -encoders
173 Show all available encoders.
174
175 -bsfs
176 Show available bitstream filters.
177
178 -protocols
179 Show available protocols.
180
181 -filters
182 Show available libavfilter filters.
183
184 -pix_fmts
185 Show available pixel formats.
186
187 -sample_fmts
188 Show available sample formats.
189
190 -layouts
191 Show channel names and standard channel layouts.
192
193 -dispositions
194 Show stream dispositions.
195
196 -colors
197 Show recognized color names.
198
199 -sources device[,opt1=val1[,opt2=val2]...]
200 Show autodetected sources of the input device. Some devices may
201 provide system-dependent source names that cannot be autodetected.
202 The returned list cannot be assumed to be always complete.
203
204 ffmpeg -sources pulse,server=192.168.0.4
205
206 -sinks device[,opt1=val1[,opt2=val2]...]
207 Show autodetected sinks of the output device. Some devices may
208 provide system-dependent sink names that cannot be autodetected.
209 The returned list cannot be assumed to be always complete.
210
211 ffmpeg -sinks pulse,server=192.168.0.4
212
213 -loglevel [flags+]loglevel | -v [flags+]loglevel
214 Set logging level and flags used by the library.
215
216 The optional flags prefix can consist of the following values:
217
218 repeat
219 Indicates that repeated log output should not be compressed to
220 the first line and the "Last message repeated n times" line
221 will be omitted.
222
223 level
224 Indicates that log output should add a "[level]" prefix to each
225 message line. This can be used as an alternative to log
226 coloring, e.g. when dumping the log to file.
227
228 Flags can also be used alone by adding a '+'/'-' prefix to
229 set/reset a single flag without affecting other flags or changing
230 loglevel. When setting both flags and loglevel, a '+' separator is
231 expected between the last flags value and before loglevel.
232
233 loglevel is a string or a number containing one of the following
234 values:
235
236 quiet, -8
237 Show nothing at all; be silent.
238
239 panic, 0
240 Only show fatal errors which could lead the process to crash,
241 such as an assertion failure. This is not currently used for
242 anything.
243
244 fatal, 8
245 Only show fatal errors. These are errors after which the
246 process absolutely cannot continue.
247
248 error, 16
249 Show all errors, including ones which can be recovered from.
250
251 warning, 24
252 Show all warnings and errors. Any message related to possibly
253 incorrect or unexpected events will be shown.
254
255 info, 32
256 Show informative messages during processing. This is in
257 addition to warnings and errors. This is the default value.
258
259 verbose, 40
260 Same as "info", except more verbose.
261
262 debug, 48
263 Show everything, including debugging information.
264
265 trace, 56
266
267 For example to enable repeated log output, add the "level" prefix,
268 and set loglevel to "verbose":
269
270 ffmpeg -loglevel repeat+level+verbose -i input output
271
272 Another example that enables repeated log output without affecting
273 current state of "level" prefix flag or loglevel:
274
275 ffmpeg [...] -loglevel +repeat
276
277 By default the program logs to stderr. If coloring is supported by
278 the terminal, colors are used to mark errors and warnings. Log
279 coloring can be disabled setting the environment variable
280 AV_LOG_FORCE_NOCOLOR, or can be forced setting the environment
281 variable AV_LOG_FORCE_COLOR.
282
283 -report
284 Dump full command line and log output to a file named
285 "program-YYYYMMDD-HHMMSS.log" in the current directory. This file
286 can be useful for bug reports. It also implies "-loglevel debug".
287
288 Setting the environment variable FFREPORT to any value has the same
289 effect. If the value is a ':'-separated key=value sequence, these
290 options will affect the report; option values must be escaped if
291 they contain special characters or the options delimiter ':' (see
292 the ``Quoting and escaping'' section in the ffmpeg-utils manual).
293
294 The following options are recognized:
295
296 file
297 set the file name to use for the report; %p is expanded to the
298 name of the program, %t is expanded to a timestamp, "%%" is
299 expanded to a plain "%"
300
301 level
302 set the log verbosity level using a numerical value (see
303 "-loglevel").
304
305 For example, to output a report to a file named ffreport.log using
306 a log level of 32 (alias for log level "info"):
307
308 FFREPORT=file=ffreport.log:level=32 ffmpeg -i input output
309
310 Errors in parsing the environment variable are not fatal, and will
311 not appear in the report.
312
313 -hide_banner
314 Suppress printing banner.
315
316 All FFmpeg tools will normally show a copyright notice, build
317 options and library versions. This option can be used to suppress
318 printing this information.
319
320 -cpuflags flags (global)
321 Allows setting and clearing cpu flags. This option is intended for
322 testing. Do not use it unless you know what you're doing.
323
324 ffmpeg -cpuflags -sse+mmx ...
325 ffmpeg -cpuflags mmx ...
326 ffmpeg -cpuflags 0 ...
327
328 Possible flags for this option are:
329
330 x86
331 mmx
332 mmxext
333 sse
334 sse2
335 sse2slow
336 sse3
337 sse3slow
338 ssse3
339 atom
340 sse4.1
341 sse4.2
342 avx
343 avx2
344 xop
345 fma3
346 fma4
347 3dnow
348 3dnowext
349 bmi1
350 bmi2
351 cmov
352 ARM
353 armv5te
354 armv6
355 armv6t2
356 vfp
357 vfpv3
358 neon
359 setend
360 AArch64
361 armv8
362 vfp
363 neon
364 PowerPC
365 altivec
366 Specific Processors
367 pentium2
368 pentium3
369 pentium4
370 k6
371 k62
372 athlon
373 athlonxp
374 k8
375 -cpucount count (global)
376 Override detection of CPU count. This option is intended for
377 testing. Do not use it unless you know what you're doing.
378
379 ffmpeg -cpucount 2
380
381 -max_alloc bytes
382 Set the maximum size limit for allocating a block on the heap by
383 ffmpeg's family of malloc functions. Exercise extreme caution when
384 using this option. Don't use if you do not understand the full
385 consequence of doing so. Default is INT_MAX.
386
387 AVOptions
388 These options are provided directly by the libavformat, libavdevice and
389 libavcodec libraries. To see the list of available AVOptions, use the
390 -help option. They are separated into two categories:
391
392 generic
393 These options can be set for any container, codec or device.
394 Generic options are listed under AVFormatContext options for
395 containers/devices and under AVCodecContext options for codecs.
396
397 private
398 These options are specific to the given container, device or codec.
399 Private options are listed under their corresponding
400 containers/devices/codecs.
401
402 For example to write an ID3v2.3 header instead of a default ID3v2.4 to
403 an MP3 file, use the id3v2_version private option of the MP3 muxer:
404
405 ffmpeg -i input.flac -id3v2_version 3 out.mp3
406
407 All codec AVOptions are per-stream, and thus a stream specifier should
408 be attached to them:
409
410 ffmpeg -i multichannel.mxf -map 0:v:0 -map 0:a:0 -map 0:a:0 -c:a:0 ac3 -b:a:0 640k -ac:a:1 2 -c:a:1 aac -b:2 128k out.mp4
411
412 In the above example, a multichannel audio stream is mapped twice for
413 output. The first instance is encoded with codec ac3 and bitrate 640k.
414 The second instance is downmixed to 2 channels and encoded with codec
415 aac. A bitrate of 128k is specified for it using absolute index of the
416 output stream.
417
418 Note: the -nooption syntax cannot be used for boolean AVOptions, use
419 -option 0/-option 1.
420
421 Note: the old undocumented way of specifying per-stream AVOptions by
422 prepending v/a/s to the options name is now obsolete and will be
423 removed soon.
424
425 Main options
426 -x width
427 Force displayed width.
428
429 -y height
430 Force displayed height.
431
432 -s size
433 Set frame size (WxH or abbreviation), needed for videos which do
434 not contain a header with the frame size like raw YUV. This option
435 has been deprecated in favor of private options, try -video_size.
436
437 -fs Start in fullscreen mode.
438
439 -an Disable audio.
440
441 -vn Disable video.
442
443 -sn Disable subtitles.
444
445 -ss pos
446 Seek to pos. Note that in most formats it is not possible to seek
447 exactly, so ffplay will seek to the nearest seek point to pos.
448
449 pos must be a time duration specification, see the Time duration
450 section in the ffmpeg-utils(1) manual.
451
452 -t duration
453 Play duration seconds of audio/video.
454
455 duration must be a time duration specification, see the Time
456 duration section in the ffmpeg-utils(1) manual.
457
458 -bytes
459 Seek by bytes.
460
461 -seek_interval
462 Set custom interval, in seconds, for seeking using left/right keys.
463 Default is 10 seconds.
464
465 -nodisp
466 Disable graphical display.
467
468 -noborder
469 Borderless window.
470
471 -alwaysontop
472 Window always on top. Available on: X11 with SDL >= 2.0.5, Windows
473 SDL >= 2.0.6.
474
475 -volume
476 Set the startup volume. 0 means silence, 100 means no volume
477 reduction or amplification. Negative values are treated as 0,
478 values above 100 are treated as 100.
479
480 -f fmt
481 Force format.
482
483 -window_title title
484 Set window title (default is the input filename).
485
486 -left title
487 Set the x position for the left of the window (default is a
488 centered window).
489
490 -top title
491 Set the y position for the top of the window (default is a centered
492 window).
493
494 -loop number
495 Loops movie playback <number> times. 0 means forever.
496
497 -showmode mode
498 Set the show mode to use. Available values for mode are:
499
500 0, video
501 show video
502
503 1, waves
504 show audio waves
505
506 2, rdft
507 show audio frequency band using RDFT ((Inverse) Real Discrete
508 Fourier Transform)
509
510 Default value is "video", if video is not present or cannot be
511 played "rdft" is automatically selected.
512
513 You can interactively cycle through the available show modes by
514 pressing the key w.
515
516 -vf filtergraph
517 Create the filtergraph specified by filtergraph and use it to
518 filter the video stream.
519
520 filtergraph is a description of the filtergraph to apply to the
521 stream, and must have a single video input and a single video
522 output. In the filtergraph, the input is associated to the label
523 "in", and the output to the label "out". See the ffmpeg-filters
524 manual for more information about the filtergraph syntax.
525
526 You can specify this parameter multiple times and cycle through the
527 specified filtergraphs along with the show modes by pressing the
528 key w.
529
530 -af filtergraph
531 filtergraph is a description of the filtergraph to apply to the
532 input audio. Use the option "-filters" to show all the available
533 filters (including sources and sinks).
534
535 -i input_url
536 Read input_url.
537
538 Advanced options
539 -pix_fmt format
540 Set pixel format. This option has been deprecated in favor of
541 private options, try -pixel_format.
542
543 -stats
544 Print several playback statistics, in particular show the stream
545 duration, the codec parameters, the current position in the stream
546 and the audio/video synchronisation drift. It is shown by default,
547 unless the log level is lower than "info". Its display can be
548 forced by manually specifying this option. To disable it, you need
549 to specify "-nostats".
550
551 -fast
552 Non-spec-compliant optimizations.
553
554 -genpts
555 Generate pts.
556
557 -sync type
558 Set the master clock to audio ("type=audio"), video ("type=video")
559 or external ("type=ext"). Default is audio. The master clock is
560 used to control audio-video synchronization. Most media players use
561 audio as master clock, but in some cases (streaming or high quality
562 broadcast) it is necessary to change that. This option is mainly
563 used for debugging purposes.
564
565 -ast audio_stream_specifier
566 Select the desired audio stream using the given stream specifier.
567 The stream specifiers are described in the Stream specifiers
568 chapter. If this option is not specified, the "best" audio stream
569 is selected in the program of the already selected video stream.
570
571 -vst video_stream_specifier
572 Select the desired video stream using the given stream specifier.
573 The stream specifiers are described in the Stream specifiers
574 chapter. If this option is not specified, the "best" video stream
575 is selected.
576
577 -sst subtitle_stream_specifier
578 Select the desired subtitle stream using the given stream
579 specifier. The stream specifiers are described in the Stream
580 specifiers chapter. If this option is not specified, the "best"
581 subtitle stream is selected in the program of the already selected
582 video or audio stream.
583
584 -autoexit
585 Exit when video is done playing.
586
587 -exitonkeydown
588 Exit if any key is pressed.
589
590 -exitonmousedown
591 Exit if any mouse button is pressed.
592
593 -codec:media_specifier codec_name
594 Force a specific decoder implementation for the stream identified
595 by media_specifier, which can assume the values "a" (audio), "v"
596 (video), and "s" subtitle.
597
598 -acodec codec_name
599 Force a specific audio decoder.
600
601 -vcodec codec_name
602 Force a specific video decoder.
603
604 -scodec codec_name
605 Force a specific subtitle decoder.
606
607 -autorotate
608 Automatically rotate the video according to file metadata. Enabled
609 by default, use -noautorotate to disable it.
610
611 -framedrop
612 Drop video frames if video is out of sync. Enabled by default if
613 the master clock is not set to video. Use this option to enable
614 frame dropping for all master clock sources, use -noframedrop to
615 disable it.
616
617 -infbuf
618 Do not limit the input buffer size, read as much data as possible
619 from the input as soon as possible. Enabled by default for realtime
620 streams, where data may be dropped if not read in time. Use this
621 option to enable infinite buffers for all inputs, use -noinfbuf to
622 disable it.
623
624 -filter_threads nb_threads
625 Defines how many threads are used to process a filter pipeline.
626 Each pipeline will produce a thread pool with this many threads
627 available for parallel processing. The default is 0 which means
628 that the thread count will be determined by the number of available
629 CPUs.
630
631 While playing
632 q, ESC
633 Quit.
634
635 f Toggle full screen.
636
637 p, SPC
638 Pause.
639
640 m Toggle mute.
641
642 9, 0
643 Decrease and increase volume respectively.
644
645 /, *
646 Decrease and increase volume respectively.
647
648 a Cycle audio channel in the current program.
649
650 v Cycle video channel.
651
652 t Cycle subtitle channel in the current program.
653
654 c Cycle program.
655
656 w Cycle video filters or show modes.
657
658 s Step to the next frame.
659
660 Pause if the stream is not already paused, step to the next video
661 frame, and pause.
662
663 left/right
664 Seek backward/forward 10 seconds.
665
666 down/up
667 Seek backward/forward 1 minute.
668
669 page down/page up
670 Seek to the previous/next chapter. or if there are no chapters
671 Seek backward/forward 10 minutes.
672
673 right mouse click
674 Seek to percentage in file corresponding to fraction of width.
675
676 left mouse double-click
677 Toggle full screen.
678
680 This section documents the syntax and formats employed by the FFmpeg
681 libraries and tools.
682
683 Quoting and escaping
684 FFmpeg adopts the following quoting and escaping mechanism, unless
685 explicitly specified. The following rules are applied:
686
687 • ' and \ are special characters (respectively used for quoting and
688 escaping). In addition to them, there might be other special
689 characters depending on the specific syntax where the escaping and
690 quoting are employed.
691
692 • A special character is escaped by prefixing it with a \.
693
694 • All characters enclosed between '' are included literally in the
695 parsed string. The quote character ' itself cannot be quoted, so
696 you may need to close the quote and escape it.
697
698 • Leading and trailing whitespaces, unless escaped or quoted, are
699 removed from the parsed string.
700
701 Note that you may need to add a second level of escaping when using the
702 command line or a script, which depends on the syntax of the adopted
703 shell language.
704
705 The function "av_get_token" defined in libavutil/avstring.h can be used
706 to parse a token quoted or escaped according to the rules defined
707 above.
708
709 The tool tools/ffescape in the FFmpeg source tree can be used to
710 automatically quote or escape a string in a script.
711
712 Examples
713
714 • Escape the string "Crime d'Amour" containing the "'" special
715 character:
716
717 Crime d\'Amour
718
719 • The string above contains a quote, so the "'" needs to be escaped
720 when quoting it:
721
722 'Crime d'\''Amour'
723
724 • Include leading or trailing whitespaces using quoting:
725
726 ' this string starts and ends with whitespaces '
727
728 • Escaping and quoting can be mixed together:
729
730 ' The string '\'string\'' is a string '
731
732 • To include a literal \ you can use either escaping or quoting:
733
734 'c:\foo' can be written as c:\\foo
735
736 Date
737 The accepted syntax is:
738
739 [(YYYY-MM-DD|YYYYMMDD)[T|t| ]]((HH:MM:SS[.m...]]])|(HHMMSS[.m...]]]))[Z]
740 now
741
742 If the value is "now" it takes the current time.
743
744 Time is local time unless Z is appended, in which case it is
745 interpreted as UTC. If the year-month-day part is not specified it
746 takes the current year-month-day.
747
748 Time duration
749 There are two accepted syntaxes for expressing time duration.
750
751 [-][<HH>:]<MM>:<SS>[.<m>...]
752
753 HH expresses the number of hours, MM the number of minutes for a
754 maximum of 2 digits, and SS the number of seconds for a maximum of 2
755 digits. The m at the end expresses decimal value for SS.
756
757 or
758
759 [-]<S>+[.<m>...][s|ms|us]
760
761 S expresses the number of seconds, with the optional decimal part m.
762 The optional literal suffixes s, ms or us indicate to interpret the
763 value as seconds, milliseconds or microseconds, respectively.
764
765 In both expressions, the optional - indicates negative duration.
766
767 Examples
768
769 The following examples are all valid time duration:
770
771 55 55 seconds
772
773 0.2 0.2 seconds
774
775 200ms
776 200 milliseconds, that's 0.2s
777
778 200000us
779 200000 microseconds, that's 0.2s
780
781 12:03:45
782 12 hours, 03 minutes and 45 seconds
783
784 23.189
785 23.189 seconds
786
787 Video size
788 Specify the size of the sourced video, it may be a string of the form
789 widthxheight, or the name of a size abbreviation.
790
791 The following abbreviations are recognized:
792
793 ntsc
794 720x480
795
796 pal 720x576
797
798 qntsc
799 352x240
800
801 qpal
802 352x288
803
804 sntsc
805 640x480
806
807 spal
808 768x576
809
810 film
811 352x240
812
813 ntsc-film
814 352x240
815
816 sqcif
817 128x96
818
819 qcif
820 176x144
821
822 cif 352x288
823
824 4cif
825 704x576
826
827 16cif
828 1408x1152
829
830 qqvga
831 160x120
832
833 qvga
834 320x240
835
836 vga 640x480
837
838 svga
839 800x600
840
841 xga 1024x768
842
843 uxga
844 1600x1200
845
846 qxga
847 2048x1536
848
849 sxga
850 1280x1024
851
852 qsxga
853 2560x2048
854
855 hsxga
856 5120x4096
857
858 wvga
859 852x480
860
861 wxga
862 1366x768
863
864 wsxga
865 1600x1024
866
867 wuxga
868 1920x1200
869
870 woxga
871 2560x1600
872
873 wqsxga
874 3200x2048
875
876 wquxga
877 3840x2400
878
879 whsxga
880 6400x4096
881
882 whuxga
883 7680x4800
884
885 cga 320x200
886
887 ega 640x350
888
889 hd480
890 852x480
891
892 hd720
893 1280x720
894
895 hd1080
896 1920x1080
897
898 2k 2048x1080
899
900 2kflat
901 1998x1080
902
903 2kscope
904 2048x858
905
906 4k 4096x2160
907
908 4kflat
909 3996x2160
910
911 4kscope
912 4096x1716
913
914 nhd 640x360
915
916 hqvga
917 240x160
918
919 wqvga
920 400x240
921
922 fwqvga
923 432x240
924
925 hvga
926 480x320
927
928 qhd 960x540
929
930 2kdci
931 2048x1080
932
933 4kdci
934 4096x2160
935
936 uhd2160
937 3840x2160
938
939 uhd4320
940 7680x4320
941
942 Video rate
943 Specify the frame rate of a video, expressed as the number of frames
944 generated per second. It has to be a string in the format
945 frame_rate_num/frame_rate_den, an integer number, a float number or a
946 valid video frame rate abbreviation.
947
948 The following abbreviations are recognized:
949
950 ntsc
951 30000/1001
952
953 pal 25/1
954
955 qntsc
956 30000/1001
957
958 qpal
959 25/1
960
961 sntsc
962 30000/1001
963
964 spal
965 25/1
966
967 film
968 24/1
969
970 ntsc-film
971 24000/1001
972
973 Ratio
974 A ratio can be expressed as an expression, or in the form
975 numerator:denominator.
976
977 Note that a ratio with infinite (1/0) or negative value is considered
978 valid, so you should check on the returned value if you want to exclude
979 those values.
980
981 The undefined value can be expressed using the "0:0" string.
982
983 Color
984 It can be the name of a color as defined below (case insensitive match)
985 or a "[0x|#]RRGGBB[AA]" sequence, possibly followed by @ and a string
986 representing the alpha component.
987
988 The alpha component may be a string composed by "0x" followed by an
989 hexadecimal number or a decimal number between 0.0 and 1.0, which
990 represents the opacity value (0x00 or 0.0 means completely transparent,
991 0xff or 1.0 completely opaque). If the alpha component is not specified
992 then 0xff is assumed.
993
994 The string random will result in a random color.
995
996 The following names of colors are recognized:
997
998 AliceBlue
999 0xF0F8FF
1000
1001 AntiqueWhite
1002 0xFAEBD7
1003
1004 Aqua
1005 0x00FFFF
1006
1007 Aquamarine
1008 0x7FFFD4
1009
1010 Azure
1011 0xF0FFFF
1012
1013 Beige
1014 0xF5F5DC
1015
1016 Bisque
1017 0xFFE4C4
1018
1019 Black
1020 0x000000
1021
1022 BlanchedAlmond
1023 0xFFEBCD
1024
1025 Blue
1026 0x0000FF
1027
1028 BlueViolet
1029 0x8A2BE2
1030
1031 Brown
1032 0xA52A2A
1033
1034 BurlyWood
1035 0xDEB887
1036
1037 CadetBlue
1038 0x5F9EA0
1039
1040 Chartreuse
1041 0x7FFF00
1042
1043 Chocolate
1044 0xD2691E
1045
1046 Coral
1047 0xFF7F50
1048
1049 CornflowerBlue
1050 0x6495ED
1051
1052 Cornsilk
1053 0xFFF8DC
1054
1055 Crimson
1056 0xDC143C
1057
1058 Cyan
1059 0x00FFFF
1060
1061 DarkBlue
1062 0x00008B
1063
1064 DarkCyan
1065 0x008B8B
1066
1067 DarkGoldenRod
1068 0xB8860B
1069
1070 DarkGray
1071 0xA9A9A9
1072
1073 DarkGreen
1074 0x006400
1075
1076 DarkKhaki
1077 0xBDB76B
1078
1079 DarkMagenta
1080 0x8B008B
1081
1082 DarkOliveGreen
1083 0x556B2F
1084
1085 Darkorange
1086 0xFF8C00
1087
1088 DarkOrchid
1089 0x9932CC
1090
1091 DarkRed
1092 0x8B0000
1093
1094 DarkSalmon
1095 0xE9967A
1096
1097 DarkSeaGreen
1098 0x8FBC8F
1099
1100 DarkSlateBlue
1101 0x483D8B
1102
1103 DarkSlateGray
1104 0x2F4F4F
1105
1106 DarkTurquoise
1107 0x00CED1
1108
1109 DarkViolet
1110 0x9400D3
1111
1112 DeepPink
1113 0xFF1493
1114
1115 DeepSkyBlue
1116 0x00BFFF
1117
1118 DimGray
1119 0x696969
1120
1121 DodgerBlue
1122 0x1E90FF
1123
1124 FireBrick
1125 0xB22222
1126
1127 FloralWhite
1128 0xFFFAF0
1129
1130 ForestGreen
1131 0x228B22
1132
1133 Fuchsia
1134 0xFF00FF
1135
1136 Gainsboro
1137 0xDCDCDC
1138
1139 GhostWhite
1140 0xF8F8FF
1141
1142 Gold
1143 0xFFD700
1144
1145 GoldenRod
1146 0xDAA520
1147
1148 Gray
1149 0x808080
1150
1151 Green
1152 0x008000
1153
1154 GreenYellow
1155 0xADFF2F
1156
1157 HoneyDew
1158 0xF0FFF0
1159
1160 HotPink
1161 0xFF69B4
1162
1163 IndianRed
1164 0xCD5C5C
1165
1166 Indigo
1167 0x4B0082
1168
1169 Ivory
1170 0xFFFFF0
1171
1172 Khaki
1173 0xF0E68C
1174
1175 Lavender
1176 0xE6E6FA
1177
1178 LavenderBlush
1179 0xFFF0F5
1180
1181 LawnGreen
1182 0x7CFC00
1183
1184 LemonChiffon
1185 0xFFFACD
1186
1187 LightBlue
1188 0xADD8E6
1189
1190 LightCoral
1191 0xF08080
1192
1193 LightCyan
1194 0xE0FFFF
1195
1196 LightGoldenRodYellow
1197 0xFAFAD2
1198
1199 LightGreen
1200 0x90EE90
1201
1202 LightGrey
1203 0xD3D3D3
1204
1205 LightPink
1206 0xFFB6C1
1207
1208 LightSalmon
1209 0xFFA07A
1210
1211 LightSeaGreen
1212 0x20B2AA
1213
1214 LightSkyBlue
1215 0x87CEFA
1216
1217 LightSlateGray
1218 0x778899
1219
1220 LightSteelBlue
1221 0xB0C4DE
1222
1223 LightYellow
1224 0xFFFFE0
1225
1226 Lime
1227 0x00FF00
1228
1229 LimeGreen
1230 0x32CD32
1231
1232 Linen
1233 0xFAF0E6
1234
1235 Magenta
1236 0xFF00FF
1237
1238 Maroon
1239 0x800000
1240
1241 MediumAquaMarine
1242 0x66CDAA
1243
1244 MediumBlue
1245 0x0000CD
1246
1247 MediumOrchid
1248 0xBA55D3
1249
1250 MediumPurple
1251 0x9370D8
1252
1253 MediumSeaGreen
1254 0x3CB371
1255
1256 MediumSlateBlue
1257 0x7B68EE
1258
1259 MediumSpringGreen
1260 0x00FA9A
1261
1262 MediumTurquoise
1263 0x48D1CC
1264
1265 MediumVioletRed
1266 0xC71585
1267
1268 MidnightBlue
1269 0x191970
1270
1271 MintCream
1272 0xF5FFFA
1273
1274 MistyRose
1275 0xFFE4E1
1276
1277 Moccasin
1278 0xFFE4B5
1279
1280 NavajoWhite
1281 0xFFDEAD
1282
1283 Navy
1284 0x000080
1285
1286 OldLace
1287 0xFDF5E6
1288
1289 Olive
1290 0x808000
1291
1292 OliveDrab
1293 0x6B8E23
1294
1295 Orange
1296 0xFFA500
1297
1298 OrangeRed
1299 0xFF4500
1300
1301 Orchid
1302 0xDA70D6
1303
1304 PaleGoldenRod
1305 0xEEE8AA
1306
1307 PaleGreen
1308 0x98FB98
1309
1310 PaleTurquoise
1311 0xAFEEEE
1312
1313 PaleVioletRed
1314 0xD87093
1315
1316 PapayaWhip
1317 0xFFEFD5
1318
1319 PeachPuff
1320 0xFFDAB9
1321
1322 Peru
1323 0xCD853F
1324
1325 Pink
1326 0xFFC0CB
1327
1328 Plum
1329 0xDDA0DD
1330
1331 PowderBlue
1332 0xB0E0E6
1333
1334 Purple
1335 0x800080
1336
1337 Red 0xFF0000
1338
1339 RosyBrown
1340 0xBC8F8F
1341
1342 RoyalBlue
1343 0x4169E1
1344
1345 SaddleBrown
1346 0x8B4513
1347
1348 Salmon
1349 0xFA8072
1350
1351 SandyBrown
1352 0xF4A460
1353
1354 SeaGreen
1355 0x2E8B57
1356
1357 SeaShell
1358 0xFFF5EE
1359
1360 Sienna
1361 0xA0522D
1362
1363 Silver
1364 0xC0C0C0
1365
1366 SkyBlue
1367 0x87CEEB
1368
1369 SlateBlue
1370 0x6A5ACD
1371
1372 SlateGray
1373 0x708090
1374
1375 Snow
1376 0xFFFAFA
1377
1378 SpringGreen
1379 0x00FF7F
1380
1381 SteelBlue
1382 0x4682B4
1383
1384 Tan 0xD2B48C
1385
1386 Teal
1387 0x008080
1388
1389 Thistle
1390 0xD8BFD8
1391
1392 Tomato
1393 0xFF6347
1394
1395 Turquoise
1396 0x40E0D0
1397
1398 Violet
1399 0xEE82EE
1400
1401 Wheat
1402 0xF5DEB3
1403
1404 White
1405 0xFFFFFF
1406
1407 WhiteSmoke
1408 0xF5F5F5
1409
1410 Yellow
1411 0xFFFF00
1412
1413 YellowGreen
1414 0x9ACD32
1415
1416 Channel Layout
1417 A channel layout specifies the spatial disposition of the channels in a
1418 multi-channel audio stream. To specify a channel layout, FFmpeg makes
1419 use of a special syntax.
1420
1421 Individual channels are identified by an id, as given by the table
1422 below:
1423
1424 FL front left
1425
1426 FR front right
1427
1428 FC front center
1429
1430 LFE low frequency
1431
1432 BL back left
1433
1434 BR back right
1435
1436 FLC front left-of-center
1437
1438 FRC front right-of-center
1439
1440 BC back center
1441
1442 SL side left
1443
1444 SR side right
1445
1446 TC top center
1447
1448 TFL top front left
1449
1450 TFC top front center
1451
1452 TFR top front right
1453
1454 TBL top back left
1455
1456 TBC top back center
1457
1458 TBR top back right
1459
1460 DL downmix left
1461
1462 DR downmix right
1463
1464 WL wide left
1465
1466 WR wide right
1467
1468 SDL surround direct left
1469
1470 SDR surround direct right
1471
1472 LFE2
1473 low frequency 2
1474
1475 Standard channel layout compositions can be specified by using the
1476 following identifiers:
1477
1478 mono
1479 FC
1480
1481 stereo
1482 FL+FR
1483
1484 2.1 FL+FR+LFE
1485
1486 3.0 FL+FR+FC
1487
1488 3.0(back)
1489 FL+FR+BC
1490
1491 4.0 FL+FR+FC+BC
1492
1493 quad
1494 FL+FR+BL+BR
1495
1496 quad(side)
1497 FL+FR+SL+SR
1498
1499 3.1 FL+FR+FC+LFE
1500
1501 5.0 FL+FR+FC+BL+BR
1502
1503 5.0(side)
1504 FL+FR+FC+SL+SR
1505
1506 4.1 FL+FR+FC+LFE+BC
1507
1508 5.1 FL+FR+FC+LFE+BL+BR
1509
1510 5.1(side)
1511 FL+FR+FC+LFE+SL+SR
1512
1513 6.0 FL+FR+FC+BC+SL+SR
1514
1515 6.0(front)
1516 FL+FR+FLC+FRC+SL+SR
1517
1518 hexagonal
1519 FL+FR+FC+BL+BR+BC
1520
1521 6.1 FL+FR+FC+LFE+BC+SL+SR
1522
1523 6.1 FL+FR+FC+LFE+BL+BR+BC
1524
1525 6.1(front)
1526 FL+FR+LFE+FLC+FRC+SL+SR
1527
1528 7.0 FL+FR+FC+BL+BR+SL+SR
1529
1530 7.0(front)
1531 FL+FR+FC+FLC+FRC+SL+SR
1532
1533 7.1 FL+FR+FC+LFE+BL+BR+SL+SR
1534
1535 7.1(wide)
1536 FL+FR+FC+LFE+BL+BR+FLC+FRC
1537
1538 7.1(wide-side)
1539 FL+FR+FC+LFE+FLC+FRC+SL+SR
1540
1541 octagonal
1542 FL+FR+FC+BL+BR+BC+SL+SR
1543
1544 hexadecagonal
1545 FL+FR+FC+BL+BR+BC+SL+SR+WL+WR+TBL+TBR+TBC+TFC+TFL+TFR
1546
1547 downmix
1548 DL+DR
1549
1550 22.2
1551 FL+FR+FC+LFE+BL+BR+FLC+FRC+BC+SL+SR+TC+TFL+TFC+TFR+TBL+TBC+TBR+LFE2+TSL+TSR+BFC+BFL+BFR
1552
1553 A custom channel layout can be specified as a sequence of terms,
1554 separated by '+' or '|'. Each term can be:
1555
1556 • the name of a standard channel layout (e.g. mono, stereo, 4.0,
1557 quad, 5.0, etc.)
1558
1559 • the name of a single channel (e.g. FL, FR, FC, LFE, etc.)
1560
1561 • a number of channels, in decimal, followed by 'c', yielding the
1562 default channel layout for that number of channels (see the
1563 function "av_get_default_channel_layout"). Note that not all
1564 channel counts have a default layout.
1565
1566 • a number of channels, in decimal, followed by 'C', yielding an
1567 unknown channel layout with the specified number of channels. Note
1568 that not all channel layout specification strings support unknown
1569 channel layouts.
1570
1571 • a channel layout mask, in hexadecimal starting with "0x" (see the
1572 "AV_CH_*" macros in libavutil/channel_layout.h.
1573
1574 Before libavutil version 53 the trailing character "c" to specify a
1575 number of channels was optional, but now it is required, while a
1576 channel layout mask can also be specified as a decimal number (if and
1577 only if not followed by "c" or "C").
1578
1579 See also the function "av_get_channel_layout" defined in
1580 libavutil/channel_layout.h.
1581
1583 When evaluating an arithmetic expression, FFmpeg uses an internal
1584 formula evaluator, implemented through the libavutil/eval.h interface.
1585
1586 An expression may contain unary, binary operators, constants, and
1587 functions.
1588
1589 Two expressions expr1 and expr2 can be combined to form another
1590 expression "expr1;expr2". expr1 and expr2 are evaluated in turn, and
1591 the new expression evaluates to the value of expr2.
1592
1593 The following binary operators are available: "+", "-", "*", "/", "^".
1594
1595 The following unary operators are available: "+", "-".
1596
1597 The following functions are available:
1598
1599 abs(x)
1600 Compute absolute value of x.
1601
1602 acos(x)
1603 Compute arccosine of x.
1604
1605 asin(x)
1606 Compute arcsine of x.
1607
1608 atan(x)
1609 Compute arctangent of x.
1610
1611 atan2(x, y)
1612 Compute principal value of the arc tangent of y/x.
1613
1614 between(x, min, max)
1615 Return 1 if x is greater than or equal to min and lesser than or
1616 equal to max, 0 otherwise.
1617
1618 bitand(x, y)
1619 bitor(x, y)
1620 Compute bitwise and/or operation on x and y.
1621
1622 The results of the evaluation of x and y are converted to integers
1623 before executing the bitwise operation.
1624
1625 Note that both the conversion to integer and the conversion back to
1626 floating point can lose precision. Beware of unexpected results for
1627 large numbers (usually 2^53 and larger).
1628
1629 ceil(expr)
1630 Round the value of expression expr upwards to the nearest integer.
1631 For example, "ceil(1.5)" is "2.0".
1632
1633 clip(x, min, max)
1634 Return the value of x clipped between min and max.
1635
1636 cos(x)
1637 Compute cosine of x.
1638
1639 cosh(x)
1640 Compute hyperbolic cosine of x.
1641
1642 eq(x, y)
1643 Return 1 if x and y are equivalent, 0 otherwise.
1644
1645 exp(x)
1646 Compute exponential of x (with base "e", the Euler's number).
1647
1648 floor(expr)
1649 Round the value of expression expr downwards to the nearest
1650 integer. For example, "floor(-1.5)" is "-2.0".
1651
1652 gauss(x)
1653 Compute Gauss function of x, corresponding to "exp(-x*x/2) /
1654 sqrt(2*PI)".
1655
1656 gcd(x, y)
1657 Return the greatest common divisor of x and y. If both x and y are
1658 0 or either or both are less than zero then behavior is undefined.
1659
1660 gt(x, y)
1661 Return 1 if x is greater than y, 0 otherwise.
1662
1663 gte(x, y)
1664 Return 1 if x is greater than or equal to y, 0 otherwise.
1665
1666 hypot(x, y)
1667 This function is similar to the C function with the same name; it
1668 returns "sqrt(x*x + y*y)", the length of the hypotenuse of a right
1669 triangle with sides of length x and y, or the distance of the point
1670 (x, y) from the origin.
1671
1672 if(x, y)
1673 Evaluate x, and if the result is non-zero return the result of the
1674 evaluation of y, return 0 otherwise.
1675
1676 if(x, y, z)
1677 Evaluate x, and if the result is non-zero return the evaluation
1678 result of y, otherwise the evaluation result of z.
1679
1680 ifnot(x, y)
1681 Evaluate x, and if the result is zero return the result of the
1682 evaluation of y, return 0 otherwise.
1683
1684 ifnot(x, y, z)
1685 Evaluate x, and if the result is zero return the evaluation result
1686 of y, otherwise the evaluation result of z.
1687
1688 isinf(x)
1689 Return 1.0 if x is +/-INFINITY, 0.0 otherwise.
1690
1691 isnan(x)
1692 Return 1.0 if x is NAN, 0.0 otherwise.
1693
1694 ld(var)
1695 Load the value of the internal variable with number var, which was
1696 previously stored with st(var, expr). The function returns the
1697 loaded value.
1698
1699 lerp(x, y, z)
1700 Return linear interpolation between x and y by amount of z.
1701
1702 log(x)
1703 Compute natural logarithm of x.
1704
1705 lt(x, y)
1706 Return 1 if x is lesser than y, 0 otherwise.
1707
1708 lte(x, y)
1709 Return 1 if x is lesser than or equal to y, 0 otherwise.
1710
1711 max(x, y)
1712 Return the maximum between x and y.
1713
1714 min(x, y)
1715 Return the minimum between x and y.
1716
1717 mod(x, y)
1718 Compute the remainder of division of x by y.
1719
1720 not(expr)
1721 Return 1.0 if expr is zero, 0.0 otherwise.
1722
1723 pow(x, y)
1724 Compute the power of x elevated y, it is equivalent to "(x)^(y)".
1725
1726 print(t)
1727 print(t, l)
1728 Print the value of expression t with loglevel l. If l is not
1729 specified then a default log level is used. Returns the value of
1730 the expression printed.
1731
1732 Prints t with loglevel l
1733
1734 random(x)
1735 Return a pseudo random value between 0.0 and 1.0. x is the index of
1736 the internal variable which will be used to save the seed/state.
1737
1738 root(expr, max)
1739 Find an input value for which the function represented by expr with
1740 argument ld(0) is 0 in the interval 0..max.
1741
1742 The expression in expr must denote a continuous function or the
1743 result is undefined.
1744
1745 ld(0) is used to represent the function input value, which means
1746 that the given expression will be evaluated multiple times with
1747 various input values that the expression can access through ld(0).
1748 When the expression evaluates to 0 then the corresponding input
1749 value will be returned.
1750
1751 round(expr)
1752 Round the value of expression expr to the nearest integer. For
1753 example, "round(1.5)" is "2.0".
1754
1755 sgn(x)
1756 Compute sign of x.
1757
1758 sin(x)
1759 Compute sine of x.
1760
1761 sinh(x)
1762 Compute hyperbolic sine of x.
1763
1764 sqrt(expr)
1765 Compute the square root of expr. This is equivalent to "(expr)^.5".
1766
1767 squish(x)
1768 Compute expression "1/(1 + exp(4*x))".
1769
1770 st(var, expr)
1771 Store the value of the expression expr in an internal variable. var
1772 specifies the number of the variable where to store the value, and
1773 it is a value ranging from 0 to 9. The function returns the value
1774 stored in the internal variable. Note, Variables are currently not
1775 shared between expressions.
1776
1777 tan(x)
1778 Compute tangent of x.
1779
1780 tanh(x)
1781 Compute hyperbolic tangent of x.
1782
1783 taylor(expr, x)
1784 taylor(expr, x, id)
1785 Evaluate a Taylor series at x, given an expression representing the
1786 "ld(id)"-th derivative of a function at 0.
1787
1788 When the series does not converge the result is undefined.
1789
1790 ld(id) is used to represent the derivative order in expr, which
1791 means that the given expression will be evaluated multiple times
1792 with various input values that the expression can access through
1793 "ld(id)". If id is not specified then 0 is assumed.
1794
1795 Note, when you have the derivatives at y instead of 0,
1796 "taylor(expr, x-y)" can be used.
1797
1798 time(0)
1799 Return the current (wallclock) time in seconds.
1800
1801 trunc(expr)
1802 Round the value of expression expr towards zero to the nearest
1803 integer. For example, "trunc(-1.5)" is "-1.0".
1804
1805 while(cond, expr)
1806 Evaluate expression expr while the expression cond is non-zero, and
1807 returns the value of the last expr evaluation, or NAN if cond was
1808 always false.
1809
1810 The following constants are available:
1811
1812 PI area of the unit disc, approximately 3.14
1813
1814 E exp(1) (Euler's number), approximately 2.718
1815
1816 PHI golden ratio (1+sqrt(5))/2, approximately 1.618
1817
1818 Assuming that an expression is considered "true" if it has a non-zero
1819 value, note that:
1820
1821 "*" works like AND
1822
1823 "+" works like OR
1824
1825 For example the construct:
1826
1827 if (A AND B) then C
1828
1829 is equivalent to:
1830
1831 if(A*B, C)
1832
1833 In your C code, you can extend the list of unary and binary functions,
1834 and define recognized constants, so that they are available for your
1835 expressions.
1836
1837 The evaluator also recognizes the International System unit prefixes.
1838 If 'i' is appended after the prefix, binary prefixes are used, which
1839 are based on powers of 1024 instead of powers of 1000. The 'B' postfix
1840 multiplies the value by 8, and can be appended after a unit prefix or
1841 used alone. This allows using for example 'KB', 'MiB', 'G' and 'B' as
1842 number postfix.
1843
1844 The list of available International System prefixes follows, with
1845 indication of the corresponding powers of 10 and of 2.
1846
1847 y 10^-24 / 2^-80
1848
1849 z 10^-21 / 2^-70
1850
1851 a 10^-18 / 2^-60
1852
1853 f 10^-15 / 2^-50
1854
1855 p 10^-12 / 2^-40
1856
1857 n 10^-9 / 2^-30
1858
1859 u 10^-6 / 2^-20
1860
1861 m 10^-3 / 2^-10
1862
1863 c 10^-2
1864
1865 d 10^-1
1866
1867 h 10^2
1868
1869 k 10^3 / 2^10
1870
1871 K 10^3 / 2^10
1872
1873 M 10^6 / 2^20
1874
1875 G 10^9 / 2^30
1876
1877 T 10^12 / 2^40
1878
1879 P 10^15 / 2^40
1880
1881 E 10^18 / 2^50
1882
1883 Z 10^21 / 2^60
1884
1885 Y 10^24 / 2^70
1886
1888 libavcodec provides some generic global options, which can be set on
1889 all the encoders and decoders. In addition each codec may support so-
1890 called private options, which are specific for a given codec.
1891
1892 Sometimes, a global option may only affect a specific kind of codec,
1893 and may be nonsensical or ignored by another, so you need to be aware
1894 of the meaning of the specified options. Also some options are meant
1895 only for decoding or encoding.
1896
1897 Options may be set by specifying -option value in the FFmpeg tools, or
1898 by setting the value explicitly in the "AVCodecContext" options or
1899 using the libavutil/opt.h API for programmatic use.
1900
1901 The list of supported options follow:
1902
1903 b integer (encoding,audio,video)
1904 Set bitrate in bits/s. Default value is 200K.
1905
1906 ab integer (encoding,audio)
1907 Set audio bitrate (in bits/s). Default value is 128K.
1908
1909 bt integer (encoding,video)
1910 Set video bitrate tolerance (in bits/s). In 1-pass mode, bitrate
1911 tolerance specifies how far ratecontrol is willing to deviate from
1912 the target average bitrate value. This is not related to min/max
1913 bitrate. Lowering tolerance too much has an adverse effect on
1914 quality.
1915
1916 flags flags (decoding/encoding,audio,video,subtitles)
1917 Set generic flags.
1918
1919 Possible values:
1920
1921 mv4 Use four motion vector by macroblock (mpeg4).
1922
1923 qpel
1924 Use 1/4 pel motion compensation.
1925
1926 loop
1927 Use loop filter.
1928
1929 qscale
1930 Use fixed qscale.
1931
1932 pass1
1933 Use internal 2pass ratecontrol in first pass mode.
1934
1935 pass2
1936 Use internal 2pass ratecontrol in second pass mode.
1937
1938 gray
1939 Only decode/encode grayscale.
1940
1941 psnr
1942 Set error[?] variables during encoding.
1943
1944 truncated
1945 Input bitstream might be randomly truncated.
1946
1947 drop_changed
1948 Don't output frames whose parameters differ from first decoded
1949 frame in stream. Error AVERROR_INPUT_CHANGED is returned when
1950 a frame is dropped.
1951
1952 ildct
1953 Use interlaced DCT.
1954
1955 low_delay
1956 Force low delay.
1957
1958 global_header
1959 Place global headers in extradata instead of every keyframe.
1960
1961 bitexact
1962 Only write platform-, build- and time-independent data. (except
1963 (I)DCT). This ensures that file and data checksums are
1964 reproducible and match between platforms. Its primary use is
1965 for regression testing.
1966
1967 aic Apply H263 advanced intra coding / mpeg4 ac prediction.
1968
1969 ilme
1970 Apply interlaced motion estimation.
1971
1972 cgop
1973 Use closed gop.
1974
1975 output_corrupt
1976 Output even potentially corrupted frames.
1977
1978 time_base rational number
1979 Set codec time base.
1980
1981 It is the fundamental unit of time (in seconds) in terms of which
1982 frame timestamps are represented. For fixed-fps content, timebase
1983 should be "1 / frame_rate" and timestamp increments should be
1984 identically 1.
1985
1986 g integer (encoding,video)
1987 Set the group of picture (GOP) size. Default value is 12.
1988
1989 ar integer (decoding/encoding,audio)
1990 Set audio sampling rate (in Hz).
1991
1992 ac integer (decoding/encoding,audio)
1993 Set number of audio channels.
1994
1995 cutoff integer (encoding,audio)
1996 Set cutoff bandwidth. (Supported only by selected encoders, see
1997 their respective documentation sections.)
1998
1999 frame_size integer (encoding,audio)
2000 Set audio frame size.
2001
2002 Each submitted frame except the last must contain exactly
2003 frame_size samples per channel. May be 0 when the codec has
2004 CODEC_CAP_VARIABLE_FRAME_SIZE set, in that case the frame size is
2005 not restricted. It is set by some decoders to indicate constant
2006 frame size.
2007
2008 frame_number integer
2009 Set the frame number.
2010
2011 delay integer
2012 qcomp float (encoding,video)
2013 Set video quantizer scale compression (VBR). It is used as a
2014 constant in the ratecontrol equation. Recommended range for default
2015 rc_eq: 0.0-1.0.
2016
2017 qblur float (encoding,video)
2018 Set video quantizer scale blur (VBR).
2019
2020 qmin integer (encoding,video)
2021 Set min video quantizer scale (VBR). Must be included between -1
2022 and 69, default value is 2.
2023
2024 qmax integer (encoding,video)
2025 Set max video quantizer scale (VBR). Must be included between -1
2026 and 1024, default value is 31.
2027
2028 qdiff integer (encoding,video)
2029 Set max difference between the quantizer scale (VBR).
2030
2031 bf integer (encoding,video)
2032 Set max number of B frames between non-B-frames.
2033
2034 Must be an integer between -1 and 16. 0 means that B-frames are
2035 disabled. If a value of -1 is used, it will choose an automatic
2036 value depending on the encoder.
2037
2038 Default value is 0.
2039
2040 b_qfactor float (encoding,video)
2041 Set qp factor between P and B frames.
2042
2043 codec_tag integer
2044 bug flags (decoding,video)
2045 Workaround not auto detected encoder bugs.
2046
2047 Possible values:
2048
2049 autodetect
2050 xvid_ilace
2051 Xvid interlacing bug (autodetected if fourcc==XVIX)
2052
2053 ump4
2054 (autodetected if fourcc==UMP4)
2055
2056 no_padding
2057 padding bug (autodetected)
2058
2059 amv
2060 qpel_chroma
2061 std_qpel
2062 old standard qpel (autodetected per fourcc/version)
2063
2064 qpel_chroma2
2065 direct_blocksize
2066 direct-qpel-blocksize bug (autodetected per fourcc/version)
2067
2068 edge
2069 edge padding bug (autodetected per fourcc/version)
2070
2071 hpel_chroma
2072 dc_clip
2073 ms Workaround various bugs in microsoft broken decoders.
2074
2075 trunc
2076 trancated frames
2077
2078 strict integer (decoding/encoding,audio,video)
2079 Specify how strictly to follow the standards.
2080
2081 Possible values:
2082
2083 very
2084 strictly conform to an older more strict version of the spec or
2085 reference software
2086
2087 strict
2088 strictly conform to all the things in the spec no matter what
2089 consequences
2090
2091 normal
2092 unofficial
2093 allow unofficial extensions
2094
2095 experimental
2096 allow non standardized experimental things, experimental
2097 (unfinished/work in progress/not well tested) decoders and
2098 encoders. Note: experimental decoders can pose a security
2099 risk, do not use this for decoding untrusted input.
2100
2101 b_qoffset float (encoding,video)
2102 Set QP offset between P and B frames.
2103
2104 err_detect flags (decoding,audio,video)
2105 Set error detection flags.
2106
2107 Possible values:
2108
2109 crccheck
2110 verify embedded CRCs
2111
2112 bitstream
2113 detect bitstream specification deviations
2114
2115 buffer
2116 detect improper bitstream length
2117
2118 explode
2119 abort decoding on minor error detection
2120
2121 ignore_err
2122 ignore decoding errors, and continue decoding. This is useful
2123 if you want to analyze the content of a video and thus want
2124 everything to be decoded no matter what. This option will not
2125 result in a video that is pleasing to watch in case of errors.
2126
2127 careful
2128 consider things that violate the spec and have not been seen in
2129 the wild as errors
2130
2131 compliant
2132 consider all spec non compliancies as errors
2133
2134 aggressive
2135 consider things that a sane encoder should not do as an error
2136
2137 has_b_frames integer
2138 block_align integer
2139 rc_override_count integer
2140 maxrate integer (encoding,audio,video)
2141 Set max bitrate tolerance (in bits/s). Requires bufsize to be set.
2142
2143 minrate integer (encoding,audio,video)
2144 Set min bitrate tolerance (in bits/s). Most useful in setting up a
2145 CBR encode. It is of little use elsewise.
2146
2147 bufsize integer (encoding,audio,video)
2148 Set ratecontrol buffer size (in bits).
2149
2150 i_qfactor float (encoding,video)
2151 Set QP factor between P and I frames.
2152
2153 i_qoffset float (encoding,video)
2154 Set QP offset between P and I frames.
2155
2156 dct integer (encoding,video)
2157 Set DCT algorithm.
2158
2159 Possible values:
2160
2161 auto
2162 autoselect a good one (default)
2163
2164 fastint
2165 fast integer
2166
2167 int accurate integer
2168
2169 mmx
2170 altivec
2171 faan
2172 floating point AAN DCT
2173
2174 lumi_mask float (encoding,video)
2175 Compress bright areas stronger than medium ones.
2176
2177 tcplx_mask float (encoding,video)
2178 Set temporal complexity masking.
2179
2180 scplx_mask float (encoding,video)
2181 Set spatial complexity masking.
2182
2183 p_mask float (encoding,video)
2184 Set inter masking.
2185
2186 dark_mask float (encoding,video)
2187 Compress dark areas stronger than medium ones.
2188
2189 idct integer (decoding/encoding,video)
2190 Select IDCT implementation.
2191
2192 Possible values:
2193
2194 auto
2195 int
2196 simple
2197 simplemmx
2198 simpleauto
2199 Automatically pick a IDCT compatible with the simple one
2200
2201 arm
2202 altivec
2203 sh4
2204 simplearm
2205 simplearmv5te
2206 simplearmv6
2207 simpleneon
2208 xvid
2209 faani
2210 floating point AAN IDCT
2211
2212 slice_count integer
2213 ec flags (decoding,video)
2214 Set error concealment strategy.
2215
2216 Possible values:
2217
2218 guess_mvs
2219 iterative motion vector (MV) search (slow)
2220
2221 deblock
2222 use strong deblock filter for damaged MBs
2223
2224 favor_inter
2225 favor predicting from the previous frame instead of the current
2226
2227 bits_per_coded_sample integer
2228 aspect rational number (encoding,video)
2229 Set sample aspect ratio.
2230
2231 sar rational number (encoding,video)
2232 Set sample aspect ratio. Alias to aspect.
2233
2234 debug flags (decoding/encoding,audio,video,subtitles)
2235 Print specific debug info.
2236
2237 Possible values:
2238
2239 pict
2240 picture info
2241
2242 rc rate control
2243
2244 bitstream
2245 mb_type
2246 macroblock (MB) type
2247
2248 qp per-block quantization parameter (QP)
2249
2250 dct_coeff
2251 green_metadata
2252 display complexity metadata for the upcoming frame, GoP or for
2253 a given duration.
2254
2255 skip
2256 startcode
2257 er error recognition
2258
2259 mmco
2260 memory management control operations (H.264)
2261
2262 bugs
2263 buffers
2264 picture buffer allocations
2265
2266 thread_ops
2267 threading operations
2268
2269 nomc
2270 skip motion compensation
2271
2272 cmp integer (encoding,video)
2273 Set full pel me compare function.
2274
2275 Possible values:
2276
2277 sad sum of absolute differences, fast (default)
2278
2279 sse sum of squared errors
2280
2281 satd
2282 sum of absolute Hadamard transformed differences
2283
2284 dct sum of absolute DCT transformed differences
2285
2286 psnr
2287 sum of squared quantization errors (avoid, low quality)
2288
2289 bit number of bits needed for the block
2290
2291 rd rate distortion optimal, slow
2292
2293 zero
2294 0
2295
2296 vsad
2297 sum of absolute vertical differences
2298
2299 vsse
2300 sum of squared vertical differences
2301
2302 nsse
2303 noise preserving sum of squared differences
2304
2305 w53 5/3 wavelet, only used in snow
2306
2307 w97 9/7 wavelet, only used in snow
2308
2309 dctmax
2310 chroma
2311 subcmp integer (encoding,video)
2312 Set sub pel me compare function.
2313
2314 Possible values:
2315
2316 sad sum of absolute differences, fast (default)
2317
2318 sse sum of squared errors
2319
2320 satd
2321 sum of absolute Hadamard transformed differences
2322
2323 dct sum of absolute DCT transformed differences
2324
2325 psnr
2326 sum of squared quantization errors (avoid, low quality)
2327
2328 bit number of bits needed for the block
2329
2330 rd rate distortion optimal, slow
2331
2332 zero
2333 0
2334
2335 vsad
2336 sum of absolute vertical differences
2337
2338 vsse
2339 sum of squared vertical differences
2340
2341 nsse
2342 noise preserving sum of squared differences
2343
2344 w53 5/3 wavelet, only used in snow
2345
2346 w97 9/7 wavelet, only used in snow
2347
2348 dctmax
2349 chroma
2350 mbcmp integer (encoding,video)
2351 Set macroblock compare function.
2352
2353 Possible values:
2354
2355 sad sum of absolute differences, fast (default)
2356
2357 sse sum of squared errors
2358
2359 satd
2360 sum of absolute Hadamard transformed differences
2361
2362 dct sum of absolute DCT transformed differences
2363
2364 psnr
2365 sum of squared quantization errors (avoid, low quality)
2366
2367 bit number of bits needed for the block
2368
2369 rd rate distortion optimal, slow
2370
2371 zero
2372 0
2373
2374 vsad
2375 sum of absolute vertical differences
2376
2377 vsse
2378 sum of squared vertical differences
2379
2380 nsse
2381 noise preserving sum of squared differences
2382
2383 w53 5/3 wavelet, only used in snow
2384
2385 w97 9/7 wavelet, only used in snow
2386
2387 dctmax
2388 chroma
2389 ildctcmp integer (encoding,video)
2390 Set interlaced dct compare function.
2391
2392 Possible values:
2393
2394 sad sum of absolute differences, fast (default)
2395
2396 sse sum of squared errors
2397
2398 satd
2399 sum of absolute Hadamard transformed differences
2400
2401 dct sum of absolute DCT transformed differences
2402
2403 psnr
2404 sum of squared quantization errors (avoid, low quality)
2405
2406 bit number of bits needed for the block
2407
2408 rd rate distortion optimal, slow
2409
2410 zero
2411 0
2412
2413 vsad
2414 sum of absolute vertical differences
2415
2416 vsse
2417 sum of squared vertical differences
2418
2419 nsse
2420 noise preserving sum of squared differences
2421
2422 w53 5/3 wavelet, only used in snow
2423
2424 w97 9/7 wavelet, only used in snow
2425
2426 dctmax
2427 chroma
2428 dia_size integer (encoding,video)
2429 Set diamond type & size for motion estimation.
2430
2431 (1024, INT_MAX)
2432 full motion estimation(slowest)
2433
2434 (768, 1024]
2435 umh motion estimation
2436
2437 (512, 768]
2438 hex motion estimation
2439
2440 (256, 512]
2441 l2s diamond motion estimation
2442
2443 [2,256]
2444 var diamond motion estimation
2445
2446 (-1, 2)
2447 small diamond motion estimation
2448
2449 -1 funny diamond motion estimation
2450
2451 (INT_MIN, -1)
2452 sab diamond motion estimation
2453
2454 last_pred integer (encoding,video)
2455 Set amount of motion predictors from the previous frame.
2456
2457 precmp integer (encoding,video)
2458 Set pre motion estimation compare function.
2459
2460 Possible values:
2461
2462 sad sum of absolute differences, fast (default)
2463
2464 sse sum of squared errors
2465
2466 satd
2467 sum of absolute Hadamard transformed differences
2468
2469 dct sum of absolute DCT transformed differences
2470
2471 psnr
2472 sum of squared quantization errors (avoid, low quality)
2473
2474 bit number of bits needed for the block
2475
2476 rd rate distortion optimal, slow
2477
2478 zero
2479 0
2480
2481 vsad
2482 sum of absolute vertical differences
2483
2484 vsse
2485 sum of squared vertical differences
2486
2487 nsse
2488 noise preserving sum of squared differences
2489
2490 w53 5/3 wavelet, only used in snow
2491
2492 w97 9/7 wavelet, only used in snow
2493
2494 dctmax
2495 chroma
2496 pre_dia_size integer (encoding,video)
2497 Set diamond type & size for motion estimation pre-pass.
2498
2499 subq integer (encoding,video)
2500 Set sub pel motion estimation quality.
2501
2502 me_range integer (encoding,video)
2503 Set limit motion vectors range (1023 for DivX player).
2504
2505 global_quality integer (encoding,audio,video)
2506 slice_flags integer
2507 mbd integer (encoding,video)
2508 Set macroblock decision algorithm (high quality mode).
2509
2510 Possible values:
2511
2512 simple
2513 use mbcmp (default)
2514
2515 bits
2516 use fewest bits
2517
2518 rd use best rate distortion
2519
2520 rc_init_occupancy integer (encoding,video)
2521 Set number of bits which should be loaded into the rc buffer before
2522 decoding starts.
2523
2524 flags2 flags (decoding/encoding,audio,video,subtitles)
2525 Possible values:
2526
2527 fast
2528 Allow non spec compliant speedup tricks.
2529
2530 noout
2531 Skip bitstream encoding.
2532
2533 ignorecrop
2534 Ignore cropping information from sps.
2535
2536 local_header
2537 Place global headers at every keyframe instead of in extradata.
2538
2539 chunks
2540 Frame data might be split into multiple chunks.
2541
2542 showall
2543 Show all frames before the first keyframe.
2544
2545 export_mvs
2546 Export motion vectors into frame side-data (see
2547 "AV_FRAME_DATA_MOTION_VECTORS") for codecs that support it. See
2548 also doc/examples/export_mvs.c.
2549
2550 skip_manual
2551 Do not skip samples and export skip information as frame side
2552 data.
2553
2554 ass_ro_flush_noop
2555 Do not reset ASS ReadOrder field on flush.
2556
2557 export_side_data flags (decoding/encoding,audio,video,subtitles)
2558 Possible values:
2559
2560 mvs Export motion vectors into frame side-data (see
2561 "AV_FRAME_DATA_MOTION_VECTORS") for codecs that support it. See
2562 also doc/examples/export_mvs.c.
2563
2564 prft
2565 Export encoder Producer Reference Time into packet side-data
2566 (see "AV_PKT_DATA_PRFT") for codecs that support it.
2567
2568 venc_params
2569 Export video encoding parameters through frame side data (see
2570 "AV_FRAME_DATA_VIDEO_ENC_PARAMS") for codecs that support it.
2571 At present, those are H.264 and VP9.
2572
2573 film_grain
2574 Export film grain parameters through frame side data (see
2575 "AV_FRAME_DATA_FILM_GRAIN_PARAMS"). Supported at present by
2576 AV1 decoders.
2577
2578 threads integer (decoding/encoding,video)
2579 Set the number of threads to be used, in case the selected codec
2580 implementation supports multi-threading.
2581
2582 Possible values:
2583
2584 auto, 0
2585 automatically select the number of threads to set
2586
2587 Default value is auto.
2588
2589 dc integer (encoding,video)
2590 Set intra_dc_precision.
2591
2592 nssew integer (encoding,video)
2593 Set nsse weight.
2594
2595 skip_top integer (decoding,video)
2596 Set number of macroblock rows at the top which are skipped.
2597
2598 skip_bottom integer (decoding,video)
2599 Set number of macroblock rows at the bottom which are skipped.
2600
2601 profile integer (encoding,audio,video)
2602 Set encoder codec profile. Default value is unknown. Encoder
2603 specific profiles are documented in the relevant encoder
2604 documentation.
2605
2606 level integer (encoding,audio,video)
2607 Possible values:
2608
2609 unknown
2610 lowres integer (decoding,audio,video)
2611 Decode at 1= 1/2, 2=1/4, 3=1/8 resolutions.
2612
2613 mblmin integer (encoding,video)
2614 Set min macroblock lagrange factor (VBR).
2615
2616 mblmax integer (encoding,video)
2617 Set max macroblock lagrange factor (VBR).
2618
2619 skip_loop_filter integer (decoding,video)
2620 skip_idct integer (decoding,video)
2621 skip_frame integer (decoding,video)
2622 Make decoder discard processing depending on the frame type
2623 selected by the option value.
2624
2625 skip_loop_filter skips frame loop filtering, skip_idct skips frame
2626 IDCT/dequantization, skip_frame skips decoding.
2627
2628 Possible values:
2629
2630 none
2631 Discard no frame.
2632
2633 default
2634 Discard useless frames like 0-sized frames.
2635
2636 noref
2637 Discard all non-reference frames.
2638
2639 bidir
2640 Discard all bidirectional frames.
2641
2642 nokey
2643 Discard all frames excepts keyframes.
2644
2645 nointra
2646 Discard all frames except I frames.
2647
2648 all Discard all frames.
2649
2650 Default value is default.
2651
2652 bidir_refine integer (encoding,video)
2653 Refine the two motion vectors used in bidirectional macroblocks.
2654
2655 keyint_min integer (encoding,video)
2656 Set minimum interval between IDR-frames.
2657
2658 refs integer (encoding,video)
2659 Set reference frames to consider for motion compensation.
2660
2661 trellis integer (encoding,audio,video)
2662 Set rate-distortion optimal quantization.
2663
2664 mv0_threshold integer (encoding,video)
2665 compression_level integer (encoding,audio,video)
2666 bits_per_raw_sample integer
2667 channel_layout integer (decoding/encoding,audio)
2668 Possible values:
2669
2670 request_channel_layout integer (decoding,audio)
2671 Possible values:
2672
2673 rc_max_vbv_use float (encoding,video)
2674 rc_min_vbv_use float (encoding,video)
2675 ticks_per_frame integer (decoding/encoding,audio,video)
2676 color_primaries integer (decoding/encoding,video)
2677 Possible values:
2678
2679 bt709
2680 BT.709
2681
2682 bt470m
2683 BT.470 M
2684
2685 bt470bg
2686 BT.470 BG
2687
2688 smpte170m
2689 SMPTE 170 M
2690
2691 smpte240m
2692 SMPTE 240 M
2693
2694 film
2695 Film
2696
2697 bt2020
2698 BT.2020
2699
2700 smpte428
2701 smpte428_1
2702 SMPTE ST 428-1
2703
2704 smpte431
2705 SMPTE 431-2
2706
2707 smpte432
2708 SMPTE 432-1
2709
2710 jedec-p22
2711 JEDEC P22
2712
2713 color_trc integer (decoding/encoding,video)
2714 Possible values:
2715
2716 bt709
2717 BT.709
2718
2719 gamma22
2720 BT.470 M
2721
2722 gamma28
2723 BT.470 BG
2724
2725 smpte170m
2726 SMPTE 170 M
2727
2728 smpte240m
2729 SMPTE 240 M
2730
2731 linear
2732 Linear
2733
2734 log
2735 log100
2736 Log
2737
2738 log_sqrt
2739 log316
2740 Log square root
2741
2742 iec61966_2_4
2743 iec61966-2-4
2744 IEC 61966-2-4
2745
2746 bt1361
2747 bt1361e
2748 BT.1361
2749
2750 iec61966_2_1
2751 iec61966-2-1
2752 IEC 61966-2-1
2753
2754 bt2020_10
2755 bt2020_10bit
2756 BT.2020 - 10 bit
2757
2758 bt2020_12
2759 bt2020_12bit
2760 BT.2020 - 12 bit
2761
2762 smpte2084
2763 SMPTE ST 2084
2764
2765 smpte428
2766 smpte428_1
2767 SMPTE ST 428-1
2768
2769 arib-std-b67
2770 ARIB STD-B67
2771
2772 colorspace integer (decoding/encoding,video)
2773 Possible values:
2774
2775 rgb RGB
2776
2777 bt709
2778 BT.709
2779
2780 fcc FCC
2781
2782 bt470bg
2783 BT.470 BG
2784
2785 smpte170m
2786 SMPTE 170 M
2787
2788 smpte240m
2789 SMPTE 240 M
2790
2791 ycocg
2792 YCOCG
2793
2794 bt2020nc
2795 bt2020_ncl
2796 BT.2020 NCL
2797
2798 bt2020c
2799 bt2020_cl
2800 BT.2020 CL
2801
2802 smpte2085
2803 SMPTE 2085
2804
2805 chroma-derived-nc
2806 Chroma-derived NCL
2807
2808 chroma-derived-c
2809 Chroma-derived CL
2810
2811 ictcp
2812 ICtCp
2813
2814 color_range integer (decoding/encoding,video)
2815 If used as input parameter, it serves as a hint to the decoder,
2816 which color_range the input has. Possible values:
2817
2818 tv
2819 mpeg
2820 MPEG (219*2^(n-8))
2821
2822 pc
2823 jpeg
2824 JPEG (2^n-1)
2825
2826 chroma_sample_location integer (decoding/encoding,video)
2827 Possible values:
2828
2829 left
2830 center
2831 topleft
2832 top
2833 bottomleft
2834 bottom
2835 log_level_offset integer
2836 Set the log level offset.
2837
2838 slices integer (encoding,video)
2839 Number of slices, used in parallelized encoding.
2840
2841 thread_type flags (decoding/encoding,video)
2842 Select which multithreading methods to use.
2843
2844 Use of frame will increase decoding delay by one frame per thread,
2845 so clients which cannot provide future frames should not use it.
2846
2847 Possible values:
2848
2849 slice
2850 Decode more than one part of a single frame at once.
2851
2852 Multithreading using slices works only when the video was
2853 encoded with slices.
2854
2855 frame
2856 Decode more than one frame at once.
2857
2858 Default value is slice+frame.
2859
2860 audio_service_type integer (encoding,audio)
2861 Set audio service type.
2862
2863 Possible values:
2864
2865 ma Main Audio Service
2866
2867 ef Effects
2868
2869 vi Visually Impaired
2870
2871 hi Hearing Impaired
2872
2873 di Dialogue
2874
2875 co Commentary
2876
2877 em Emergency
2878
2879 vo Voice Over
2880
2881 ka Karaoke
2882
2883 request_sample_fmt sample_fmt (decoding,audio)
2884 Set sample format audio decoders should prefer. Default value is
2885 "none".
2886
2887 pkt_timebase rational number
2888 sub_charenc encoding (decoding,subtitles)
2889 Set the input subtitles character encoding.
2890
2891 field_order field_order (video)
2892 Set/override the field order of the video. Possible values:
2893
2894 progressive
2895 Progressive video
2896
2897 tt Interlaced video, top field coded and displayed first
2898
2899 bb Interlaced video, bottom field coded and displayed first
2900
2901 tb Interlaced video, top coded first, bottom displayed first
2902
2903 bt Interlaced video, bottom coded first, top displayed first
2904
2905 skip_alpha bool (decoding,video)
2906 Set to 1 to disable processing alpha (transparency). This works
2907 like the gray flag in the flags option which skips chroma
2908 information instead of alpha. Default is 0.
2909
2910 codec_whitelist list (input)
2911 "," separated list of allowed decoders. By default all are allowed.
2912
2913 dump_separator string (input)
2914 Separator used to separate the fields printed on the command line
2915 about the Stream parameters. For example, to separate the fields
2916 with newlines and indentation:
2917
2918 ffprobe -dump_separator "
2919 " -i ~/videos/matrixbench_mpeg2.mpg
2920
2921 max_pixels integer (decoding/encoding,video)
2922 Maximum number of pixels per image. This value can be used to avoid
2923 out of memory failures due to large images.
2924
2925 apply_cropping bool (decoding,video)
2926 Enable cropping if cropping parameters are multiples of the
2927 required alignment for the left and top parameters. If the
2928 alignment is not met the cropping will be partially applied to
2929 maintain alignment. Default is 1 (enabled). Note: The required
2930 alignment depends on if "AV_CODEC_FLAG_UNALIGNED" is set and the
2931 CPU. "AV_CODEC_FLAG_UNALIGNED" cannot be changed from the command
2932 line. Also hardware decoders will not apply left/top Cropping.
2933
2935 Decoders are configured elements in FFmpeg which allow the decoding of
2936 multimedia streams.
2937
2938 When you configure your FFmpeg build, all the supported native decoders
2939 are enabled by default. Decoders requiring an external library must be
2940 enabled manually via the corresponding "--enable-lib" option. You can
2941 list all available decoders using the configure option
2942 "--list-decoders".
2943
2944 You can disable all the decoders with the configure option
2945 "--disable-decoders" and selectively enable / disable single decoders
2946 with the options "--enable-decoder=DECODER" /
2947 "--disable-decoder=DECODER".
2948
2949 The option "-decoders" of the ff* tools will display the list of
2950 enabled decoders.
2951
2953 A description of some of the currently available video decoders
2954 follows.
2955
2956 av1
2957 AOMedia Video 1 (AV1) decoder.
2958
2959 Options
2960
2961 operating_point
2962 Select an operating point of a scalable AV1 bitstream (0 - 31).
2963 Default is 0.
2964
2965 rawvideo
2966 Raw video decoder.
2967
2968 This decoder decodes rawvideo streams.
2969
2970 Options
2971
2972 top top_field_first
2973 Specify the assumed field type of the input video.
2974
2975 -1 the video is assumed to be progressive (default)
2976
2977 0 bottom-field-first is assumed
2978
2979 1 top-field-first is assumed
2980
2981 libdav1d
2982 dav1d AV1 decoder.
2983
2984 libdav1d allows libavcodec to decode the AOMedia Video 1 (AV1) codec.
2985 Requires the presence of the libdav1d headers and library during
2986 configuration. You need to explicitly configure the build with
2987 "--enable-libdav1d".
2988
2989 Options
2990
2991 The following options are supported by the libdav1d wrapper.
2992
2993 framethreads
2994 Set amount of frame threads to use during decoding. The default
2995 value is 0 (autodetect). This option is deprecated for libdav1d >=
2996 1.0 and will be removed in the future. Use the global option
2997 "threads" instead.
2998
2999 tilethreads
3000 Set amount of tile threads to use during decoding. The default
3001 value is 0 (autodetect). This option is deprecated for libdav1d >=
3002 1.0 and will be removed in the future. Use the global option
3003 "threads" instead.
3004
3005 filmgrain
3006 Apply film grain to the decoded video if present in the bitstream.
3007 Defaults to the internal default of the library. This option is
3008 deprecated and will be removed in the future. See the global option
3009 "export_side_data" to export Film Grain parameters instead of
3010 applying it.
3011
3012 oppoint
3013 Select an operating point of a scalable AV1 bitstream (0 - 31).
3014 Defaults to the internal default of the library.
3015
3016 alllayers
3017 Output all spatial layers of a scalable AV1 bitstream. The default
3018 value is false.
3019
3020 libdavs2
3021 AVS2-P2/IEEE1857.4 video decoder wrapper.
3022
3023 This decoder allows libavcodec to decode AVS2 streams with davs2
3024 library.
3025
3026 libuavs3d
3027 AVS3-P2/IEEE1857.10 video decoder.
3028
3029 libuavs3d allows libavcodec to decode AVS3 streams. Requires the
3030 presence of the libuavs3d headers and library during configuration.
3031 You need to explicitly configure the build with "--enable-libuavs3d".
3032
3033 Options
3034
3035 The following option is supported by the libuavs3d wrapper.
3036
3037 frame_threads
3038 Set amount of frame threads to use during decoding. The default
3039 value is 0 (autodetect).
3040
3042 A description of some of the currently available audio decoders
3043 follows.
3044
3045 ac3
3046 AC-3 audio decoder.
3047
3048 This decoder implements part of ATSC A/52:2010 and ETSI TS 102 366, as
3049 well as the undocumented RealAudio 3 (a.k.a. dnet).
3050
3051 AC-3 Decoder Options
3052
3053 -drc_scale value
3054 Dynamic Range Scale Factor. The factor to apply to dynamic range
3055 values from the AC-3 stream. This factor is applied exponentially.
3056 The default value is 1. There are 3 notable scale factor ranges:
3057
3058 drc_scale == 0
3059 DRC disabled. Produces full range audio.
3060
3061 0 < drc_scale <= 1
3062 DRC enabled. Applies a fraction of the stream DRC value.
3063 Audio reproduction is between full range and full compression.
3064
3065 drc_scale > 1
3066 DRC enabled. Applies drc_scale asymmetrically. Loud sounds are
3067 fully compressed. Soft sounds are enhanced.
3068
3069 flac
3070 FLAC audio decoder.
3071
3072 This decoder aims to implement the complete FLAC specification from
3073 Xiph.
3074
3075 FLAC Decoder options
3076
3077 -use_buggy_lpc
3078 The lavc FLAC encoder used to produce buggy streams with high lpc
3079 values (like the default value). This option makes it possible to
3080 decode such streams correctly by using lavc's old buggy lpc logic
3081 for decoding.
3082
3083 ffwavesynth
3084 Internal wave synthesizer.
3085
3086 This decoder generates wave patterns according to predefined sequences.
3087 Its use is purely internal and the format of the data it accepts is not
3088 publicly documented.
3089
3090 libcelt
3091 libcelt decoder wrapper.
3092
3093 libcelt allows libavcodec to decode the Xiph CELT ultra-low delay audio
3094 codec. Requires the presence of the libcelt headers and library during
3095 configuration. You need to explicitly configure the build with
3096 "--enable-libcelt".
3097
3098 libgsm
3099 libgsm decoder wrapper.
3100
3101 libgsm allows libavcodec to decode the GSM full rate audio codec.
3102 Requires the presence of the libgsm headers and library during
3103 configuration. You need to explicitly configure the build with
3104 "--enable-libgsm".
3105
3106 This decoder supports both the ordinary GSM and the Microsoft variant.
3107
3108 libilbc
3109 libilbc decoder wrapper.
3110
3111 libilbc allows libavcodec to decode the Internet Low Bitrate Codec
3112 (iLBC) audio codec. Requires the presence of the libilbc headers and
3113 library during configuration. You need to explicitly configure the
3114 build with "--enable-libilbc".
3115
3116 Options
3117
3118 The following option is supported by the libilbc wrapper.
3119
3120 enhance
3121 Enable the enhancement of the decoded audio when set to 1. The
3122 default value is 0 (disabled).
3123
3124 libopencore-amrnb
3125 libopencore-amrnb decoder wrapper.
3126
3127 libopencore-amrnb allows libavcodec to decode the Adaptive Multi-Rate
3128 Narrowband audio codec. Using it requires the presence of the
3129 libopencore-amrnb headers and library during configuration. You need to
3130 explicitly configure the build with "--enable-libopencore-amrnb".
3131
3132 An FFmpeg native decoder for AMR-NB exists, so users can decode AMR-NB
3133 without this library.
3134
3135 libopencore-amrwb
3136 libopencore-amrwb decoder wrapper.
3137
3138 libopencore-amrwb allows libavcodec to decode the Adaptive Multi-Rate
3139 Wideband audio codec. Using it requires the presence of the
3140 libopencore-amrwb headers and library during configuration. You need to
3141 explicitly configure the build with "--enable-libopencore-amrwb".
3142
3143 An FFmpeg native decoder for AMR-WB exists, so users can decode AMR-WB
3144 without this library.
3145
3146 libopus
3147 libopus decoder wrapper.
3148
3149 libopus allows libavcodec to decode the Opus Interactive Audio Codec.
3150 Requires the presence of the libopus headers and library during
3151 configuration. You need to explicitly configure the build with
3152 "--enable-libopus".
3153
3154 An FFmpeg native decoder for Opus exists, so users can decode Opus
3155 without this library.
3156
3158 libaribb24
3159 ARIB STD-B24 caption decoder.
3160
3161 Implements profiles A and C of the ARIB STD-B24 standard.
3162
3163 libaribb24 Decoder Options
3164
3165 -aribb24-base-path path
3166 Sets the base path for the libaribb24 library. This is utilized for
3167 reading of configuration files (for custom unicode conversions),
3168 and for dumping of non-text symbols as images under that location.
3169
3170 Unset by default.
3171
3172 -aribb24-skip-ruby-text boolean
3173 Tells the decoder wrapper to skip text blocks that contain half-
3174 height ruby text.
3175
3176 Enabled by default.
3177
3178 dvbsub
3179 Options
3180
3181 compute_clut
3182 -2 Compute clut once if no matching CLUT is in the stream.
3183
3184 -1 Compute clut if no matching CLUT is in the stream.
3185
3186 0 Never compute CLUT
3187
3188 1 Always compute CLUT and override the one provided in the
3189 stream.
3190
3191 dvb_substream
3192 Selects the dvb substream, or all substreams if -1 which is
3193 default.
3194
3195 dvdsub
3196 This codec decodes the bitmap subtitles used in DVDs; the same
3197 subtitles can also be found in VobSub file pairs and in some Matroska
3198 files.
3199
3200 Options
3201
3202 palette
3203 Specify the global palette used by the bitmaps. When stored in
3204 VobSub, the palette is normally specified in the index file; in
3205 Matroska, the palette is stored in the codec extra-data in the same
3206 format as in VobSub. In DVDs, the palette is stored in the IFO
3207 file, and therefore not available when reading from dumped VOB
3208 files.
3209
3210 The format for this option is a string containing 16 24-bits
3211 hexadecimal numbers (without 0x prefix) separated by commas, for
3212 example "0d00ee, ee450d, 101010, eaeaea, 0ce60b, ec14ed, ebff0b,
3213 0d617a, 7b7b7b, d1d1d1, 7b2a0e, 0d950c, 0f007b, cf0dec, cfa80c,
3214 7c127b".
3215
3216 ifo_palette
3217 Specify the IFO file from which the global palette is obtained.
3218 (experimental)
3219
3220 forced_subs_only
3221 Only decode subtitle entries marked as forced. Some titles have
3222 forced and non-forced subtitles in the same track. Setting this
3223 flag to 1 will only keep the forced subtitles. Default value is 0.
3224
3225 libzvbi-teletext
3226 Libzvbi allows libavcodec to decode DVB teletext pages and DVB teletext
3227 subtitles. Requires the presence of the libzvbi headers and library
3228 during configuration. You need to explicitly configure the build with
3229 "--enable-libzvbi".
3230
3231 Options
3232
3233 txt_page
3234 List of teletext page numbers to decode. Pages that do not match
3235 the specified list are dropped. You may use the special "*" string
3236 to match all pages, or "subtitle" to match all subtitle pages.
3237 Default value is *.
3238
3239 txt_default_region
3240 Set default character set used for decoding, a value between 0 and
3241 87 (see ETS 300 706, Section 15, Table 32). Default value is -1,
3242 which does not override the libzvbi default. This option is needed
3243 for some legacy level 1.0 transmissions which cannot signal the
3244 proper charset.
3245
3246 txt_chop_top
3247 Discards the top teletext line. Default value is 1.
3248
3249 txt_format
3250 Specifies the format of the decoded subtitles.
3251
3252 bitmap
3253 The default format, you should use this for teletext pages,
3254 because certain graphics and colors cannot be expressed in
3255 simple text or even ASS.
3256
3257 text
3258 Simple text based output without formatting.
3259
3260 ass Formatted ASS output, subtitle pages and teletext pages are
3261 returned in different styles, subtitle pages are stripped down
3262 to text, but an effort is made to keep the text alignment and
3263 the formatting.
3264
3265 txt_left
3266 X offset of generated bitmaps, default is 0.
3267
3268 txt_top
3269 Y offset of generated bitmaps, default is 0.
3270
3271 txt_chop_spaces
3272 Chops leading and trailing spaces and removes empty lines from the
3273 generated text. This option is useful for teletext based subtitles
3274 where empty spaces may be present at the start or at the end of the
3275 lines or empty lines may be present between the subtitle lines
3276 because of double-sized teletext characters. Default value is 1.
3277
3278 txt_duration
3279 Sets the display duration of the decoded teletext pages or
3280 subtitles in milliseconds. Default value is -1 which means infinity
3281 or until the next subtitle event comes.
3282
3283 txt_transparent
3284 Force transparent background of the generated teletext bitmaps.
3285 Default value is 0 which means an opaque background.
3286
3287 txt_opacity
3288 Sets the opacity (0-255) of the teletext background. If
3289 txt_transparent is not set, it only affects characters between a
3290 start box and an end box, typically subtitles. Default value is 0
3291 if txt_transparent is set, 255 otherwise.
3292
3294 When you configure your FFmpeg build, all the supported bitstream
3295 filters are enabled by default. You can list all available ones using
3296 the configure option "--list-bsfs".
3297
3298 You can disable all the bitstream filters using the configure option
3299 "--disable-bsfs", and selectively enable any bitstream filter using the
3300 option "--enable-bsf=BSF", or you can disable a particular bitstream
3301 filter using the option "--disable-bsf=BSF".
3302
3303 The option "-bsfs" of the ff* tools will display the list of all the
3304 supported bitstream filters included in your build.
3305
3306 The ff* tools have a -bsf option applied per stream, taking a comma-
3307 separated list of filters, whose parameters follow the filter name
3308 after a '='.
3309
3310 ffmpeg -i INPUT -c:v copy -bsf:v filter1[=opt1=str1:opt2=str2][,filter2] OUTPUT
3311
3312 Below is a description of the currently available bitstream filters,
3313 with their parameters, if any.
3314
3315 aac_adtstoasc
3316 Convert MPEG-2/4 AAC ADTS to an MPEG-4 Audio Specific Configuration
3317 bitstream.
3318
3319 This filter creates an MPEG-4 AudioSpecificConfig from an MPEG-2/4 ADTS
3320 header and removes the ADTS header.
3321
3322 This filter is required for example when copying an AAC stream from a
3323 raw ADTS AAC or an MPEG-TS container to MP4A-LATM, to an FLV file, or
3324 to MOV/MP4 files and related formats such as 3GP or M4A. Please note
3325 that it is auto-inserted for MP4A-LATM and MOV/MP4 and related formats.
3326
3327 av1_metadata
3328 Modify metadata embedded in an AV1 stream.
3329
3330 td Insert or remove temporal delimiter OBUs in all temporal units of
3331 the stream.
3332
3333 insert
3334 Insert a TD at the beginning of every TU which does not already
3335 have one.
3336
3337 remove
3338 Remove the TD from the beginning of every TU which has one.
3339
3340 color_primaries
3341 transfer_characteristics
3342 matrix_coefficients
3343 Set the color description fields in the stream (see AV1 section
3344 6.4.2).
3345
3346 color_range
3347 Set the color range in the stream (see AV1 section 6.4.2; note that
3348 this cannot be set for streams using BT.709 primaries, sRGB
3349 transfer characteristic and identity (RGB) matrix coefficients).
3350
3351 tv Limited range.
3352
3353 pc Full range.
3354
3355 chroma_sample_position
3356 Set the chroma sample location in the stream (see AV1 section
3357 6.4.2). This can only be set for 4:2:0 streams.
3358
3359 vertical
3360 Left position (matching the default in MPEG-2 and H.264).
3361
3362 colocated
3363 Top-left position.
3364
3365 tick_rate
3366 Set the tick rate (time_scale / num_units_in_display_tick) in the
3367 timing info in the sequence header.
3368
3369 num_ticks_per_picture
3370 Set the number of ticks in each picture, to indicate that the
3371 stream has a fixed framerate. Ignored if tick_rate is not also
3372 set.
3373
3374 delete_padding
3375 Deletes Padding OBUs.
3376
3377 chomp
3378 Remove zero padding at the end of a packet.
3379
3380 dca_core
3381 Extract the core from a DCA/DTS stream, dropping extensions such as
3382 DTS-HD.
3383
3384 dump_extra
3385 Add extradata to the beginning of the filtered packets except when said
3386 packets already exactly begin with the extradata that is intended to be
3387 added.
3388
3389 freq
3390 The additional argument specifies which packets should be filtered.
3391 It accepts the values:
3392
3393 k
3394 keyframe
3395 add extradata to all key packets
3396
3397 e
3398 all add extradata to all packets
3399
3400 If not specified it is assumed k.
3401
3402 For example the following ffmpeg command forces a global header (thus
3403 disabling individual packet headers) in the H.264 packets generated by
3404 the "libx264" encoder, but corrects them by adding the header stored in
3405 extradata to the key packets:
3406
3407 ffmpeg -i INPUT -map 0 -flags:v +global_header -c:v libx264 -bsf:v dump_extra out.ts
3408
3409 eac3_core
3410 Extract the core from a E-AC-3 stream, dropping extra channels.
3411
3412 extract_extradata
3413 Extract the in-band extradata.
3414
3415 Certain codecs allow the long-term headers (e.g. MPEG-2 sequence
3416 headers, or H.264/HEVC (VPS/)SPS/PPS) to be transmitted either "in-
3417 band" (i.e. as a part of the bitstream containing the coded frames) or
3418 "out of band" (e.g. on the container level). This latter form is called
3419 "extradata" in FFmpeg terminology.
3420
3421 This bitstream filter detects the in-band headers and makes them
3422 available as extradata.
3423
3424 remove
3425 When this option is enabled, the long-term headers are removed from
3426 the bitstream after extraction.
3427
3428 filter_units
3429 Remove units with types in or not in a given set from the stream.
3430
3431 pass_types
3432 List of unit types or ranges of unit types to pass through while
3433 removing all others. This is specified as a '|'-separated list of
3434 unit type values or ranges of values with '-'.
3435
3436 remove_types
3437 Identical to pass_types, except the units in the given set removed
3438 and all others passed through.
3439
3440 Extradata is unchanged by this transformation, but note that if the
3441 stream contains inline parameter sets then the output may be unusable
3442 if they are removed.
3443
3444 For example, to remove all non-VCL NAL units from an H.264 stream:
3445
3446 ffmpeg -i INPUT -c:v copy -bsf:v 'filter_units=pass_types=1-5' OUTPUT
3447
3448 To remove all AUDs, SEI and filler from an H.265 stream:
3449
3450 ffmpeg -i INPUT -c:v copy -bsf:v 'filter_units=remove_types=35|38-40' OUTPUT
3451
3452 hapqa_extract
3453 Extract Rgb or Alpha part of an HAPQA file, without recompression, in
3454 order to create an HAPQ or an HAPAlphaOnly file.
3455
3456 texture
3457 Specifies the texture to keep.
3458
3459 color
3460 alpha
3461
3462 Convert HAPQA to HAPQ
3463
3464 ffmpeg -i hapqa_inputfile.mov -c copy -bsf:v hapqa_extract=texture=color -tag:v HapY -metadata:s:v:0 encoder="HAPQ" hapq_file.mov
3465
3466 Convert HAPQA to HAPAlphaOnly
3467
3468 ffmpeg -i hapqa_inputfile.mov -c copy -bsf:v hapqa_extract=texture=alpha -tag:v HapA -metadata:s:v:0 encoder="HAPAlpha Only" hapalphaonly_file.mov
3469
3470 h264_metadata
3471 Modify metadata embedded in an H.264 stream.
3472
3473 aud Insert or remove AUD NAL units in all access units of the stream.
3474
3475 insert
3476 remove
3477 sample_aspect_ratio
3478 Set the sample aspect ratio of the stream in the VUI parameters.
3479
3480 overscan_appropriate_flag
3481 Set whether the stream is suitable for display using overscan or
3482 not (see H.264 section E.2.1).
3483
3484 video_format
3485 video_full_range_flag
3486 Set the video format in the stream (see H.264 section E.2.1 and
3487 table E-2).
3488
3489 colour_primaries
3490 transfer_characteristics
3491 matrix_coefficients
3492 Set the colour description in the stream (see H.264 section E.2.1
3493 and tables E-3, E-4 and E-5).
3494
3495 chroma_sample_loc_type
3496 Set the chroma sample location in the stream (see H.264 section
3497 E.2.1 and figure E-1).
3498
3499 tick_rate
3500 Set the tick rate (time_scale / num_units_in_tick) in the VUI
3501 parameters. This is the smallest time unit representable in the
3502 stream, and in many cases represents the field rate of the stream
3503 (double the frame rate).
3504
3505 fixed_frame_rate_flag
3506 Set whether the stream has fixed framerate - typically this
3507 indicates that the framerate is exactly half the tick rate, but the
3508 exact meaning is dependent on interlacing and the picture structure
3509 (see H.264 section E.2.1 and table E-6).
3510
3511 zero_new_constraint_set_flags
3512 Zero constraint_set4_flag and constraint_set5_flag in the SPS.
3513 These bits were reserved in a previous version of the H.264 spec,
3514 and thus some hardware decoders require these to be zero. The
3515 result of zeroing this is still a valid bitstream.
3516
3517 crop_left
3518 crop_right
3519 crop_top
3520 crop_bottom
3521 Set the frame cropping offsets in the SPS. These values will
3522 replace the current ones if the stream is already cropped.
3523
3524 These fields are set in pixels. Note that some sizes may not be
3525 representable if the chroma is subsampled or the stream is
3526 interlaced (see H.264 section 7.4.2.1.1).
3527
3528 sei_user_data
3529 Insert a string as SEI unregistered user data. The argument must
3530 be of the form UUID+string, where the UUID is as hex digits
3531 possibly separated by hyphens, and the string can be anything.
3532
3533 For example, 086f3693-b7b3-4f2c-9653-21492feee5b8+hello will insert
3534 the string ``hello'' associated with the given UUID.
3535
3536 delete_filler
3537 Deletes both filler NAL units and filler SEI messages.
3538
3539 level
3540 Set the level in the SPS. Refer to H.264 section A.3 and tables
3541 A-1 to A-5.
3542
3543 The argument must be the name of a level (for example, 4.2), a
3544 level_idc value (for example, 42), or the special name auto
3545 indicating that the filter should attempt to guess the level from
3546 the input stream properties.
3547
3548 h264_mp4toannexb
3549 Convert an H.264 bitstream from length prefixed mode to start code
3550 prefixed mode (as defined in the Annex B of the ITU-T H.264
3551 specification).
3552
3553 This is required by some streaming formats, typically the MPEG-2
3554 transport stream format (muxer "mpegts").
3555
3556 For example to remux an MP4 file containing an H.264 stream to mpegts
3557 format with ffmpeg, you can use the command:
3558
3559 ffmpeg -i INPUT.mp4 -codec copy -bsf:v h264_mp4toannexb OUTPUT.ts
3560
3561 Please note that this filter is auto-inserted for MPEG-TS (muxer
3562 "mpegts") and raw H.264 (muxer "h264") output formats.
3563
3564 h264_redundant_pps
3565 This applies a specific fixup to some Blu-ray streams which contain
3566 redundant PPSs modifying irrelevant parameters of the stream which
3567 confuse other transformations which require correct extradata.
3568
3569 A new single global PPS is created, and all of the redundant PPSs
3570 within the stream are removed.
3571
3572 hevc_metadata
3573 Modify metadata embedded in an HEVC stream.
3574
3575 aud Insert or remove AUD NAL units in all access units of the stream.
3576
3577 insert
3578 remove
3579 sample_aspect_ratio
3580 Set the sample aspect ratio in the stream in the VUI parameters.
3581
3582 video_format
3583 video_full_range_flag
3584 Set the video format in the stream (see H.265 section E.3.1 and
3585 table E.2).
3586
3587 colour_primaries
3588 transfer_characteristics
3589 matrix_coefficients
3590 Set the colour description in the stream (see H.265 section E.3.1
3591 and tables E.3, E.4 and E.5).
3592
3593 chroma_sample_loc_type
3594 Set the chroma sample location in the stream (see H.265 section
3595 E.3.1 and figure E.1).
3596
3597 tick_rate
3598 Set the tick rate in the VPS and VUI parameters (time_scale /
3599 num_units_in_tick). Combined with num_ticks_poc_diff_one, this can
3600 set a constant framerate in the stream. Note that it is likely to
3601 be overridden by container parameters when the stream is in a
3602 container.
3603
3604 num_ticks_poc_diff_one
3605 Set poc_proportional_to_timing_flag in VPS and VUI and use this
3606 value to set num_ticks_poc_diff_one_minus1 (see H.265 sections
3607 7.4.3.1 and E.3.1). Ignored if tick_rate is not also set.
3608
3609 crop_left
3610 crop_right
3611 crop_top
3612 crop_bottom
3613 Set the conformance window cropping offsets in the SPS. These
3614 values will replace the current ones if the stream is already
3615 cropped.
3616
3617 These fields are set in pixels. Note that some sizes may not be
3618 representable if the chroma is subsampled (H.265 section
3619 7.4.3.2.1).
3620
3621 level
3622 Set the level in the VPS and SPS. See H.265 section A.4 and tables
3623 A.6 and A.7.
3624
3625 The argument must be the name of a level (for example, 5.1), a
3626 general_level_idc value (for example, 153 for level 5.1), or the
3627 special name auto indicating that the filter should attempt to
3628 guess the level from the input stream properties.
3629
3630 hevc_mp4toannexb
3631 Convert an HEVC/H.265 bitstream from length prefixed mode to start code
3632 prefixed mode (as defined in the Annex B of the ITU-T H.265
3633 specification).
3634
3635 This is required by some streaming formats, typically the MPEG-2
3636 transport stream format (muxer "mpegts").
3637
3638 For example to remux an MP4 file containing an HEVC stream to mpegts
3639 format with ffmpeg, you can use the command:
3640
3641 ffmpeg -i INPUT.mp4 -codec copy -bsf:v hevc_mp4toannexb OUTPUT.ts
3642
3643 Please note that this filter is auto-inserted for MPEG-TS (muxer
3644 "mpegts") and raw HEVC/H.265 (muxer "h265" or "hevc") output formats.
3645
3646 imxdump
3647 Modifies the bitstream to fit in MOV and to be usable by the Final Cut
3648 Pro decoder. This filter only applies to the mpeg2video codec, and is
3649 likely not needed for Final Cut Pro 7 and newer with the appropriate
3650 -tag:v.
3651
3652 For example, to remux 30 MB/sec NTSC IMX to MOV:
3653
3654 ffmpeg -i input.mxf -c copy -bsf:v imxdump -tag:v mx3n output.mov
3655
3656 mjpeg2jpeg
3657 Convert MJPEG/AVI1 packets to full JPEG/JFIF packets.
3658
3659 MJPEG is a video codec wherein each video frame is essentially a JPEG
3660 image. The individual frames can be extracted without loss, e.g. by
3661
3662 ffmpeg -i ../some_mjpeg.avi -c:v copy frames_%d.jpg
3663
3664 Unfortunately, these chunks are incomplete JPEG images, because they
3665 lack the DHT segment required for decoding. Quoting from
3666 <http://www.digitalpreservation.gov/formats/fdd/fdd000063.shtml>:
3667
3668 Avery Lee, writing in the rec.video.desktop newsgroup in 2001,
3669 commented that "MJPEG, or at least the MJPEG in AVIs having the MJPG
3670 fourcc, is restricted JPEG with a fixed -- and *omitted* -- Huffman
3671 table. The JPEG must be YCbCr colorspace, it must be 4:2:2, and it must
3672 use basic Huffman encoding, not arithmetic or progressive. . . . You
3673 can indeed extract the MJPEG frames and decode them with a regular JPEG
3674 decoder, but you have to prepend the DHT segment to them, or else the
3675 decoder won't have any idea how to decompress the data. The exact table
3676 necessary is given in the OpenDML spec."
3677
3678 This bitstream filter patches the header of frames extracted from an
3679 MJPEG stream (carrying the AVI1 header ID and lacking a DHT segment) to
3680 produce fully qualified JPEG images.
3681
3682 ffmpeg -i mjpeg-movie.avi -c:v copy -bsf:v mjpeg2jpeg frame_%d.jpg
3683 exiftran -i -9 frame*.jpg
3684 ffmpeg -i frame_%d.jpg -c:v copy rotated.avi
3685
3686 mjpegadump
3687 Add an MJPEG A header to the bitstream, to enable decoding by
3688 Quicktime.
3689
3690 mov2textsub
3691 Extract a representable text file from MOV subtitles, stripping the
3692 metadata header from each subtitle packet.
3693
3694 See also the text2movsub filter.
3695
3696 mp3decomp
3697 Decompress non-standard compressed MP3 audio headers.
3698
3699 mpeg2_metadata
3700 Modify metadata embedded in an MPEG-2 stream.
3701
3702 display_aspect_ratio
3703 Set the display aspect ratio in the stream.
3704
3705 The following fixed values are supported:
3706
3707 4/3
3708 16/9
3709 221/100
3710
3711 Any other value will result in square pixels being signalled
3712 instead (see H.262 section 6.3.3 and table 6-3).
3713
3714 frame_rate
3715 Set the frame rate in the stream. This is constructed from a table
3716 of known values combined with a small multiplier and divisor - if
3717 the supplied value is not exactly representable, the nearest
3718 representable value will be used instead (see H.262 section 6.3.3
3719 and table 6-4).
3720
3721 video_format
3722 Set the video format in the stream (see H.262 section 6.3.6 and
3723 table 6-6).
3724
3725 colour_primaries
3726 transfer_characteristics
3727 matrix_coefficients
3728 Set the colour description in the stream (see H.262 section 6.3.6
3729 and tables 6-7, 6-8 and 6-9).
3730
3731 mpeg4_unpack_bframes
3732 Unpack DivX-style packed B-frames.
3733
3734 DivX-style packed B-frames are not valid MPEG-4 and were only a
3735 workaround for the broken Video for Windows subsystem. They use more
3736 space, can cause minor AV sync issues, require more CPU power to decode
3737 (unless the player has some decoded picture queue to compensate the
3738 2,0,2,0 frame per packet style) and cause trouble if copied into a
3739 standard container like mp4 or mpeg-ps/ts, because MPEG-4 decoders may
3740 not be able to decode them, since they are not valid MPEG-4.
3741
3742 For example to fix an AVI file containing an MPEG-4 stream with DivX-
3743 style packed B-frames using ffmpeg, you can use the command:
3744
3745 ffmpeg -i INPUT.avi -codec copy -bsf:v mpeg4_unpack_bframes OUTPUT.avi
3746
3747 noise
3748 Damages the contents of packets or simply drops them without damaging
3749 the container. Can be used for fuzzing or testing error
3750 resilience/concealment.
3751
3752 Parameters:
3753
3754 amount
3755 Accepts an expression whose evaluation per-packet determines how
3756 often bytes in that packet will be modified. A value below 0 will
3757 result in a variable frequency. Default is 0 which results in no
3758 modification. However, if neither amount nor drop is specified,
3759 amount will be set to -1. See below for accepted variables.
3760
3761 drop
3762 Accepts an expression evaluated per-packet whose value determines
3763 whether that packet is dropped. Evaluation to a positive value
3764 results in the packet being dropped. Evaluation to a negative value
3765 results in a variable chance of it being dropped, roughly inverse
3766 in proportion to the magnitude of the value. Default is 0 which
3767 results in no drops. See below for accepted variables.
3768
3769 dropamount
3770 Accepts a non-negative integer, which assigns a variable chance of
3771 it being dropped, roughly inverse in proportion to the value.
3772 Default is 0 which results in no drops. This option is kept for
3773 backwards compatibility and is equivalent to setting drop to a
3774 negative value with the same magnitude i.e. "dropamount=4" is the
3775 same as "drop=-4". Ignored if drop is also specified.
3776
3777 Both "amount" and "drop" accept expressions containing the following
3778 variables:
3779
3780 n The index of the packet, starting from zero.
3781
3782 tb The timebase for packet timestamps.
3783
3784 pts Packet presentation timestamp.
3785
3786 dts Packet decoding timestamp.
3787
3788 nopts
3789 Constant representing AV_NOPTS_VALUE.
3790
3791 startpts
3792 First non-AV_NOPTS_VALUE PTS seen in the stream.
3793
3794 startdts
3795 First non-AV_NOPTS_VALUE DTS seen in the stream.
3796
3797 duration
3798 d Packet duration, in timebase units.
3799
3800 pos Packet position in input; may be -1 when unknown or not set.
3801
3802 size
3803 Packet size, in bytes.
3804
3805 key Whether packet is marked as a keyframe.
3806
3807 state
3808 A pseudo random integer, primarily derived from the content of
3809 packet payload.
3810
3811 Examples
3812
3813 Apply modification to every byte but don't drop any packets.
3814
3815 ffmpeg -i INPUT -c copy -bsf noise=1 output.mkv
3816
3817 Drop every video packet not marked as a keyframe after timestamp 30s
3818 but do not modify any of the remaining packets.
3819
3820 ffmpeg -i INPUT -c copy -bsf:v noise=drop='gt(t\,30)*not(key)' output.mkv
3821
3822 Drop one second of audio every 10 seconds and add some random noise to
3823 the rest.
3824
3825 ffmpeg -i INPUT -c copy -bsf:a noise=amount=-1:drop='between(mod(t\,10)\,9\,10)' output.mkv
3826
3827 null
3828 This bitstream filter passes the packets through unchanged.
3829
3830 pcm_rechunk
3831 Repacketize PCM audio to a fixed number of samples per packet or a
3832 fixed packet rate per second. This is similar to the asetnsamples audio
3833 filter but works on audio packets instead of audio frames.
3834
3835 nb_out_samples, n
3836 Set the number of samples per each output audio packet. The number
3837 is intended as the number of samples per each channel. Default
3838 value is 1024.
3839
3840 pad, p
3841 If set to 1, the filter will pad the last audio packet with
3842 silence, so that it will contain the same number of samples (or
3843 roughly the same number of samples, see frame_rate) as the previous
3844 ones. Default value is 1.
3845
3846 frame_rate, r
3847 This option makes the filter output a fixed number of packets per
3848 second instead of a fixed number of samples per packet. If the
3849 audio sample rate is not divisible by the frame rate then the
3850 number of samples will not be constant but will vary slightly so
3851 that each packet will start as close to the frame boundary as
3852 possible. Using this option has precedence over nb_out_samples.
3853
3854 You can generate the well known 1602-1601-1602-1601-1602 pattern of
3855 48kHz audio for NTSC frame rate using the frame_rate option.
3856
3857 ffmpeg -f lavfi -i sine=r=48000:d=1 -c pcm_s16le -bsf pcm_rechunk=r=30000/1001 -f framecrc -
3858
3859 prores_metadata
3860 Modify color property metadata embedded in prores stream.
3861
3862 color_primaries
3863 Set the color primaries. Available values are:
3864
3865 auto
3866 Keep the same color primaries property (default).
3867
3868 unknown
3869 bt709
3870 bt470bg
3871 BT601 625
3872
3873 smpte170m
3874 BT601 525
3875
3876 bt2020
3877 smpte431
3878 DCI P3
3879
3880 smpte432
3881 P3 D65
3882
3883 transfer_characteristics
3884 Set the color transfer. Available values are:
3885
3886 auto
3887 Keep the same transfer characteristics property (default).
3888
3889 unknown
3890 bt709
3891 BT 601, BT 709, BT 2020
3892
3893 smpte2084
3894 SMPTE ST 2084
3895
3896 arib-std-b67
3897 ARIB STD-B67
3898
3899 matrix_coefficients
3900 Set the matrix coefficient. Available values are:
3901
3902 auto
3903 Keep the same colorspace property (default).
3904
3905 unknown
3906 bt709
3907 smpte170m
3908 BT 601
3909
3910 bt2020nc
3911
3912 Set Rec709 colorspace for each frame of the file
3913
3914 ffmpeg -i INPUT -c copy -bsf:v prores_metadata=color_primaries=bt709:color_trc=bt709:colorspace=bt709 output.mov
3915
3916 Set Hybrid Log-Gamma parameters for each frame of the file
3917
3918 ffmpeg -i INPUT -c copy -bsf:v prores_metadata=color_primaries=bt2020:color_trc=arib-std-b67:colorspace=bt2020nc output.mov
3919
3920 remove_extra
3921 Remove extradata from packets.
3922
3923 It accepts the following parameter:
3924
3925 freq
3926 Set which frame types to remove extradata from.
3927
3928 k Remove extradata from non-keyframes only.
3929
3930 keyframe
3931 Remove extradata from keyframes only.
3932
3933 e, all
3934 Remove extradata from all frames.
3935
3936 setts
3937 Set PTS and DTS in packets.
3938
3939 It accepts the following parameters:
3940
3941 ts
3942 pts
3943 dts Set expressions for PTS, DTS or both.
3944
3945 The expressions are evaluated through the eval API and can contain the
3946 following constants:
3947
3948 N The count of the input packet. Starting from 0.
3949
3950 TS The demux timestamp in input in case of "ts" or "dts" option or
3951 presentation timestamp in case of "pts" option.
3952
3953 POS The original position in the file of the packet, or undefined if
3954 undefined for the current packet
3955
3956 DTS The demux timestamp in input.
3957
3958 PTS The presentation timestamp in input.
3959
3960 STARTDTS
3961 The DTS of the first packet.
3962
3963 STARTPTS
3964 The PTS of the first packet.
3965
3966 PREV_INDTS
3967 The previous input DTS.
3968
3969 PREV_INPTS
3970 The previous input PTS.
3971
3972 PREV_OUTDTS
3973 The previous output DTS.
3974
3975 PREV_OUTPTS
3976 The previous output PTS.
3977
3978 TB The timebase of stream packet belongs.
3979
3980 SR The sample rate of stream packet belongs.
3981
3982 NOPTS
3983 The AV_NOPTS_VALUE constant.
3984
3985 text2movsub
3986 Convert text subtitles to MOV subtitles (as used by the "mov_text"
3987 codec) with metadata headers.
3988
3989 See also the mov2textsub filter.
3990
3991 trace_headers
3992 Log trace output containing all syntax elements in the coded stream
3993 headers (everything above the level of individual coded blocks). This
3994 can be useful for debugging low-level stream issues.
3995
3996 Supports AV1, H.264, H.265, (M)JPEG, MPEG-2 and VP9, but depending on
3997 the build only a subset of these may be available.
3998
3999 truehd_core
4000 Extract the core from a TrueHD stream, dropping ATMOS data.
4001
4002 vp9_metadata
4003 Modify metadata embedded in a VP9 stream.
4004
4005 color_space
4006 Set the color space value in the frame header. Note that any frame
4007 set to RGB will be implicitly set to PC range and that RGB is
4008 incompatible with profiles 0 and 2.
4009
4010 unknown
4011 bt601
4012 bt709
4013 smpte170
4014 smpte240
4015 bt2020
4016 rgb
4017 color_range
4018 Set the color range value in the frame header. Note that any value
4019 imposed by the color space will take precedence over this value.
4020
4021 tv
4022 pc
4023
4024 vp9_superframe
4025 Merge VP9 invisible (alt-ref) frames back into VP9 superframes. This
4026 fixes merging of split/segmented VP9 streams where the alt-ref frame
4027 was split from its visible counterpart.
4028
4029 vp9_superframe_split
4030 Split VP9 superframes into single frames.
4031
4032 vp9_raw_reorder
4033 Given a VP9 stream with correct timestamps but possibly out of order,
4034 insert additional show-existing-frame packets to correct the ordering.
4035
4037 The libavformat library provides some generic global options, which can
4038 be set on all the muxers and demuxers. In addition each muxer or
4039 demuxer may support so-called private options, which are specific for
4040 that component.
4041
4042 Options may be set by specifying -option value in the FFmpeg tools, or
4043 by setting the value explicitly in the "AVFormatContext" options or
4044 using the libavutil/opt.h API for programmatic use.
4045
4046 The list of supported options follows:
4047
4048 avioflags flags (input/output)
4049 Possible values:
4050
4051 direct
4052 Reduce buffering.
4053
4054 probesize integer (input)
4055 Set probing size in bytes, i.e. the size of the data to analyze to
4056 get stream information. A higher value will enable detecting more
4057 information in case it is dispersed into the stream, but will
4058 increase latency. Must be an integer not lesser than 32. It is
4059 5000000 by default.
4060
4061 max_probe_packets integer (input)
4062 Set the maximum number of buffered packets when probing a codec.
4063 Default is 2500 packets.
4064
4065 packetsize integer (output)
4066 Set packet size.
4067
4068 fflags flags
4069 Set format flags. Some are implemented for a limited number of
4070 formats.
4071
4072 Possible values for input files:
4073
4074 discardcorrupt
4075 Discard corrupted packets.
4076
4077 fastseek
4078 Enable fast, but inaccurate seeks for some formats.
4079
4080 genpts
4081 Generate missing PTS if DTS is present.
4082
4083 igndts
4084 Ignore DTS if PTS is set. Inert when nofillin is set.
4085
4086 ignidx
4087 Ignore index.
4088
4089 nobuffer
4090 Reduce the latency introduced by buffering during initial input
4091 streams analysis.
4092
4093 nofillin
4094 Do not fill in missing values in packet fields that can be
4095 exactly calculated.
4096
4097 noparse
4098 Disable AVParsers, this needs "+nofillin" too.
4099
4100 sortdts
4101 Try to interleave output packets by DTS. At present, available
4102 only for AVIs with an index.
4103
4104 Possible values for output files:
4105
4106 autobsf
4107 Automatically apply bitstream filters as required by the output
4108 format. Enabled by default.
4109
4110 bitexact
4111 Only write platform-, build- and time-independent data. This
4112 ensures that file and data checksums are reproducible and match
4113 between platforms. Its primary use is for regression testing.
4114
4115 flush_packets
4116 Write out packets immediately.
4117
4118 shortest
4119 Stop muxing at the end of the shortest stream. It may be
4120 needed to increase max_interleave_delta to avoid flushing the
4121 longer streams before EOF.
4122
4123 seek2any integer (input)
4124 Allow seeking to non-keyframes on demuxer level when supported if
4125 set to 1. Default is 0.
4126
4127 analyzeduration integer (input)
4128 Specify how many microseconds are analyzed to probe the input. A
4129 higher value will enable detecting more accurate information, but
4130 will increase latency. It defaults to 5,000,000 microseconds = 5
4131 seconds.
4132
4133 cryptokey hexadecimal string (input)
4134 Set decryption key.
4135
4136 indexmem integer (input)
4137 Set max memory used for timestamp index (per stream).
4138
4139 rtbufsize integer (input)
4140 Set max memory used for buffering real-time frames.
4141
4142 fdebug flags (input/output)
4143 Print specific debug info.
4144
4145 Possible values:
4146
4147 ts
4148 max_delay integer (input/output)
4149 Set maximum muxing or demuxing delay in microseconds.
4150
4151 fpsprobesize integer (input)
4152 Set number of frames used to probe fps.
4153
4154 audio_preload integer (output)
4155 Set microseconds by which audio packets should be interleaved
4156 earlier.
4157
4158 chunk_duration integer (output)
4159 Set microseconds for each chunk.
4160
4161 chunk_size integer (output)
4162 Set size in bytes for each chunk.
4163
4164 err_detect, f_err_detect flags (input)
4165 Set error detection flags. "f_err_detect" is deprecated and should
4166 be used only via the ffmpeg tool.
4167
4168 Possible values:
4169
4170 crccheck
4171 Verify embedded CRCs.
4172
4173 bitstream
4174 Detect bitstream specification deviations.
4175
4176 buffer
4177 Detect improper bitstream length.
4178
4179 explode
4180 Abort decoding on minor error detection.
4181
4182 careful
4183 Consider things that violate the spec and have not been seen in
4184 the wild as errors.
4185
4186 compliant
4187 Consider all spec non compliancies as errors.
4188
4189 aggressive
4190 Consider things that a sane encoder should not do as an error.
4191
4192 max_interleave_delta integer (output)
4193 Set maximum buffering duration for interleaving. The duration is
4194 expressed in microseconds, and defaults to 10000000 (10 seconds).
4195
4196 To ensure all the streams are interleaved correctly, libavformat
4197 will wait until it has at least one packet for each stream before
4198 actually writing any packets to the output file. When some streams
4199 are "sparse" (i.e. there are large gaps between successive
4200 packets), this can result in excessive buffering.
4201
4202 This field specifies the maximum difference between the timestamps
4203 of the first and the last packet in the muxing queue, above which
4204 libavformat will output a packet regardless of whether it has
4205 queued a packet for all the streams.
4206
4207 If set to 0, libavformat will continue buffering packets until it
4208 has a packet for each stream, regardless of the maximum timestamp
4209 difference between the buffered packets.
4210
4211 use_wallclock_as_timestamps integer (input)
4212 Use wallclock as timestamps if set to 1. Default is 0.
4213
4214 avoid_negative_ts integer (output)
4215 Possible values:
4216
4217 make_non_negative
4218 Shift timestamps to make them non-negative. Also note that
4219 this affects only leading negative timestamps, and not non-
4220 monotonic negative timestamps.
4221
4222 make_zero
4223 Shift timestamps so that the first timestamp is 0.
4224
4225 auto (default)
4226 Enables shifting when required by the target format.
4227
4228 disabled
4229 Disables shifting of timestamp.
4230
4231 When shifting is enabled, all output timestamps are shifted by the
4232 same amount. Audio, video, and subtitles desynching and relative
4233 timestamp differences are preserved compared to how they would have
4234 been without shifting.
4235
4236 skip_initial_bytes integer (input)
4237 Set number of bytes to skip before reading header and frames if set
4238 to 1. Default is 0.
4239
4240 correct_ts_overflow integer (input)
4241 Correct single timestamp overflows if set to 1. Default is 1.
4242
4243 flush_packets integer (output)
4244 Flush the underlying I/O stream after each packet. Default is -1
4245 (auto), which means that the underlying protocol will decide, 1
4246 enables it, and has the effect of reducing the latency, 0 disables
4247 it and may increase IO throughput in some cases.
4248
4249 output_ts_offset offset (output)
4250 Set the output time offset.
4251
4252 offset must be a time duration specification, see the Time duration
4253 section in the ffmpeg-utils(1) manual.
4254
4255 The offset is added by the muxer to the output timestamps.
4256
4257 Specifying a positive offset means that the corresponding streams
4258 are delayed bt the time duration specified in offset. Default value
4259 is 0 (meaning that no offset is applied).
4260
4261 format_whitelist list (input)
4262 "," separated list of allowed demuxers. By default all are allowed.
4263
4264 dump_separator string (input)
4265 Separator used to separate the fields printed on the command line
4266 about the Stream parameters. For example, to separate the fields
4267 with newlines and indentation:
4268
4269 ffprobe -dump_separator "
4270 " -i ~/videos/matrixbench_mpeg2.mpg
4271
4272 max_streams integer (input)
4273 Specifies the maximum number of streams. This can be used to reject
4274 files that would require too many resources due to a large number
4275 of streams.
4276
4277 skip_estimate_duration_from_pts bool (input)
4278 Skip estimation of input duration when calculated using PTS. At
4279 present, applicable for MPEG-PS and MPEG-TS.
4280
4281 strict, f_strict integer (input/output)
4282 Specify how strictly to follow the standards. "f_strict" is
4283 deprecated and should be used only via the ffmpeg tool.
4284
4285 Possible values:
4286
4287 very
4288 strictly conform to an older more strict version of the spec or
4289 reference software
4290
4291 strict
4292 strictly conform to all the things in the spec no matter what
4293 consequences
4294
4295 normal
4296 unofficial
4297 allow unofficial extensions
4298
4299 experimental
4300 allow non standardized experimental things, experimental
4301 (unfinished/work in progress/not well tested) decoders and
4302 encoders. Note: experimental decoders can pose a security
4303 risk, do not use this for decoding untrusted input.
4304
4305 Format stream specifiers
4306 Format stream specifiers allow selection of one or more streams that
4307 match specific properties.
4308
4309 The exact semantics of stream specifiers is defined by the
4310 "avformat_match_stream_specifier()" function declared in the
4311 libavformat/avformat.h header and documented in the Stream specifiers
4312 section in the ffmpeg(1) manual.
4313
4315 Demuxers are configured elements in FFmpeg that can read the multimedia
4316 streams from a particular type of file.
4317
4318 When you configure your FFmpeg build, all the supported demuxers are
4319 enabled by default. You can list all available ones using the configure
4320 option "--list-demuxers".
4321
4322 You can disable all the demuxers using the configure option
4323 "--disable-demuxers", and selectively enable a single demuxer with the
4324 option "--enable-demuxer=DEMUXER", or disable it with the option
4325 "--disable-demuxer=DEMUXER".
4326
4327 The option "-demuxers" of the ff* tools will display the list of
4328 enabled demuxers. Use "-formats" to view a combined list of enabled
4329 demuxers and muxers.
4330
4331 The description of some of the currently available demuxers follows.
4332
4333 aa
4334 Audible Format 2, 3, and 4 demuxer.
4335
4336 This demuxer is used to demux Audible Format 2, 3, and 4 (.aa) files.
4337
4338 aac
4339 Raw Audio Data Transport Stream AAC demuxer.
4340
4341 This demuxer is used to demux an ADTS input containing a single AAC
4342 stream alongwith any ID3v1/2 or APE tags in it.
4343
4344 apng
4345 Animated Portable Network Graphics demuxer.
4346
4347 This demuxer is used to demux APNG files. All headers, but the PNG
4348 signature, up to (but not including) the first fcTL chunk are
4349 transmitted as extradata. Frames are then split as being all the
4350 chunks between two fcTL ones, or between the last fcTL and IEND chunks.
4351
4352 -ignore_loop bool
4353 Ignore the loop variable in the file if set. Default is enabled.
4354
4355 -max_fps int
4356 Maximum framerate in frames per second. Default of 0 imposes no
4357 limit.
4358
4359 -default_fps int
4360 Default framerate in frames per second when none is specified in
4361 the file (0 meaning as fast as possible). Default is 15.
4362
4363 asf
4364 Advanced Systems Format demuxer.
4365
4366 This demuxer is used to demux ASF files and MMS network streams.
4367
4368 -no_resync_search bool
4369 Do not try to resynchronize by looking for a certain optional start
4370 code.
4371
4372 concat
4373 Virtual concatenation script demuxer.
4374
4375 This demuxer reads a list of files and other directives from a text
4376 file and demuxes them one after the other, as if all their packets had
4377 been muxed together.
4378
4379 The timestamps in the files are adjusted so that the first file starts
4380 at 0 and each next file starts where the previous one finishes. Note
4381 that it is done globally and may cause gaps if all streams do not have
4382 exactly the same length.
4383
4384 All files must have the same streams (same codecs, same time base,
4385 etc.).
4386
4387 The duration of each file is used to adjust the timestamps of the next
4388 file: if the duration is incorrect (because it was computed using the
4389 bit-rate or because the file is truncated, for example), it can cause
4390 artifacts. The "duration" directive can be used to override the
4391 duration stored in each file.
4392
4393 Syntax
4394
4395 The script is a text file in extended-ASCII, with one directive per
4396 line. Empty lines, leading spaces and lines starting with '#' are
4397 ignored. The following directive is recognized:
4398
4399 "file path"
4400 Path to a file to read; special characters and spaces must be
4401 escaped with backslash or single quotes.
4402
4403 All subsequent file-related directives apply to that file.
4404
4405 "ffconcat version 1.0"
4406 Identify the script type and version.
4407
4408 To make FFmpeg recognize the format automatically, this directive
4409 must appear exactly as is (no extra space or byte-order-mark) on
4410 the very first line of the script.
4411
4412 "duration dur"
4413 Duration of the file. This information can be specified from the
4414 file; specifying it here may be more efficient or help if the
4415 information from the file is not available or accurate.
4416
4417 If the duration is set for all files, then it is possible to seek
4418 in the whole concatenated video.
4419
4420 "inpoint timestamp"
4421 In point of the file. When the demuxer opens the file it instantly
4422 seeks to the specified timestamp. Seeking is done so that all
4423 streams can be presented successfully at In point.
4424
4425 This directive works best with intra frame codecs, because for non-
4426 intra frame ones you will usually get extra packets before the
4427 actual In point and the decoded content will most likely contain
4428 frames before In point too.
4429
4430 For each file, packets before the file In point will have
4431 timestamps less than the calculated start timestamp of the file
4432 (negative in case of the first file), and the duration of the files
4433 (if not specified by the "duration" directive) will be reduced
4434 based on their specified In point.
4435
4436 Because of potential packets before the specified In point, packet
4437 timestamps may overlap between two concatenated files.
4438
4439 "outpoint timestamp"
4440 Out point of the file. When the demuxer reaches the specified
4441 decoding timestamp in any of the streams, it handles it as an end
4442 of file condition and skips the current and all the remaining
4443 packets from all streams.
4444
4445 Out point is exclusive, which means that the demuxer will not
4446 output packets with a decoding timestamp greater or equal to Out
4447 point.
4448
4449 This directive works best with intra frame codecs and formats where
4450 all streams are tightly interleaved. For non-intra frame codecs you
4451 will usually get additional packets with presentation timestamp
4452 after Out point therefore the decoded content will most likely
4453 contain frames after Out point too. If your streams are not tightly
4454 interleaved you may not get all the packets from all streams before
4455 Out point and you may only will be able to decode the earliest
4456 stream until Out point.
4457
4458 The duration of the files (if not specified by the "duration"
4459 directive) will be reduced based on their specified Out point.
4460
4461 "file_packet_metadata key=value"
4462 Metadata of the packets of the file. The specified metadata will be
4463 set for each file packet. You can specify this directive multiple
4464 times to add multiple metadata entries. This directive is
4465 deprecated, use "file_packet_meta" instead.
4466
4467 "file_packet_meta key value"
4468 Metadata of the packets of the file. The specified metadata will be
4469 set for each file packet. You can specify this directive multiple
4470 times to add multiple metadata entries.
4471
4472 "option key value"
4473 Option to access, open and probe the file. Can be present multiple
4474 times.
4475
4476 "stream"
4477 Introduce a stream in the virtual file. All subsequent stream-
4478 related directives apply to the last introduced stream. Some
4479 streams properties must be set in order to allow identifying the
4480 matching streams in the subfiles. If no streams are defined in the
4481 script, the streams from the first file are copied.
4482
4483 "exact_stream_id id"
4484 Set the id of the stream. If this directive is given, the string
4485 with the corresponding id in the subfiles will be used. This is
4486 especially useful for MPEG-PS (VOB) files, where the order of the
4487 streams is not reliable.
4488
4489 "stream_meta key value"
4490 Metadata for the stream. Can be present multiple times.
4491
4492 "stream_codec value"
4493 Codec for the stream.
4494
4495 "stream_extradata hex_string"
4496 Extradata for the string, encoded in hexadecimal.
4497
4498 "chapter id start end"
4499 Add a chapter. id is an unique identifier, possibly small and
4500 consecutive.
4501
4502 Options
4503
4504 This demuxer accepts the following option:
4505
4506 safe
4507 If set to 1, reject unsafe file paths and directives. A file path
4508 is considered safe if it does not contain a protocol specification
4509 and is relative and all components only contain characters from the
4510 portable character set (letters, digits, period, underscore and
4511 hyphen) and have no period at the beginning of a component.
4512
4513 If set to 0, any file name is accepted.
4514
4515 The default is 1.
4516
4517 auto_convert
4518 If set to 1, try to perform automatic conversions on packet data to
4519 make the streams concatenable. The default is 1.
4520
4521 Currently, the only conversion is adding the h264_mp4toannexb
4522 bitstream filter to H.264 streams in MP4 format. This is necessary
4523 in particular if there are resolution changes.
4524
4525 segment_time_metadata
4526 If set to 1, every packet will contain the lavf.concat.start_time
4527 and the lavf.concat.duration packet metadata values which are the
4528 start_time and the duration of the respective file segments in the
4529 concatenated output expressed in microseconds. The duration
4530 metadata is only set if it is known based on the concat file. The
4531 default is 0.
4532
4533 Examples
4534
4535 • Use absolute filenames and include some comments:
4536
4537 # my first filename
4538 file /mnt/share/file-1.wav
4539 # my second filename including whitespace
4540 file '/mnt/share/file 2.wav'
4541 # my third filename including whitespace plus single quote
4542 file '/mnt/share/file 3'\''.wav'
4543
4544 • Allow for input format auto-probing, use safe filenames and set the
4545 duration of the first file:
4546
4547 ffconcat version 1.0
4548
4549 file file-1.wav
4550 duration 20.0
4551
4552 file subdir/file-2.wav
4553
4554 dash
4555 Dynamic Adaptive Streaming over HTTP demuxer.
4556
4557 This demuxer presents all AVStreams found in the manifest. By setting
4558 the discard flags on AVStreams the caller can decide which streams to
4559 actually receive. Each stream mirrors the "id" and "bandwidth"
4560 properties from the "<Representation>" as metadata keys named "id" and
4561 "variant_bitrate" respectively.
4562
4563 imf
4564 Interoperable Master Format demuxer.
4565
4566 This demuxer presents audio and video streams found in an IMF
4567 Composition.
4568
4569 flv, live_flv, kux
4570 Adobe Flash Video Format demuxer.
4571
4572 This demuxer is used to demux FLV files and RTMP network streams. In
4573 case of live network streams, if you force format, you may use live_flv
4574 option instead of flv to survive timestamp discontinuities. KUX is a
4575 flv variant used on the Youku platform.
4576
4577 ffmpeg -f flv -i myfile.flv ...
4578 ffmpeg -f live_flv -i rtmp://<any.server>/anything/key ....
4579
4580 -flv_metadata bool
4581 Allocate the streams according to the onMetaData array content.
4582
4583 -flv_ignore_prevtag bool
4584 Ignore the size of previous tag value.
4585
4586 -flv_full_metadata bool
4587 Output all context of the onMetadata.
4588
4589 gif
4590 Animated GIF demuxer.
4591
4592 It accepts the following options:
4593
4594 min_delay
4595 Set the minimum valid delay between frames in hundredths of
4596 seconds. Range is 0 to 6000. Default value is 2.
4597
4598 max_gif_delay
4599 Set the maximum valid delay between frames in hundredth of seconds.
4600 Range is 0 to 65535. Default value is 65535 (nearly eleven
4601 minutes), the maximum value allowed by the specification.
4602
4603 default_delay
4604 Set the default delay between frames in hundredths of seconds.
4605 Range is 0 to 6000. Default value is 10.
4606
4607 ignore_loop
4608 GIF files can contain information to loop a certain number of times
4609 (or infinitely). If ignore_loop is set to 1, then the loop setting
4610 from the input will be ignored and looping will not occur. If set
4611 to 0, then looping will occur and will cycle the number of times
4612 according to the GIF. Default value is 1.
4613
4614 For example, with the overlay filter, place an infinitely looping GIF
4615 over another video:
4616
4617 ffmpeg -i input.mp4 -ignore_loop 0 -i input.gif -filter_complex overlay=shortest=1 out.mkv
4618
4619 Note that in the above example the shortest option for overlay filter
4620 is used to end the output video at the length of the shortest input
4621 file, which in this case is input.mp4 as the GIF in this example loops
4622 infinitely.
4623
4624 hls
4625 HLS demuxer
4626
4627 Apple HTTP Live Streaming demuxer.
4628
4629 This demuxer presents all AVStreams from all variant streams. The id
4630 field is set to the bitrate variant index number. By setting the
4631 discard flags on AVStreams (by pressing 'a' or 'v' in ffplay), the
4632 caller can decide which variant streams to actually receive. The total
4633 bitrate of the variant that the stream belongs to is available in a
4634 metadata key named "variant_bitrate".
4635
4636 It accepts the following options:
4637
4638 live_start_index
4639 segment index to start live streams at (negative values are from
4640 the end).
4641
4642 allowed_extensions
4643 ',' separated list of file extensions that hls is allowed to
4644 access.
4645
4646 max_reload
4647 Maximum number of times a insufficient list is attempted to be
4648 reloaded. Default value is 1000.
4649
4650 m3u8_hold_counters
4651 The maximum number of times to load m3u8 when it refreshes without
4652 new segments. Default value is 1000.
4653
4654 http_persistent
4655 Use persistent HTTP connections. Applicable only for HTTP streams.
4656 Enabled by default.
4657
4658 http_multiple
4659 Use multiple HTTP connections for downloading HTTP segments.
4660 Enabled by default for HTTP/1.1 servers.
4661
4662 http_seekable
4663 Use HTTP partial requests for downloading HTTP segments. 0 =
4664 disable, 1 = enable, -1 = auto, Default is auto.
4665
4666 seg_format_options
4667 Set options for the demuxer of media segments using a list of
4668 key=value pairs separated by ":".
4669
4670 image2
4671 Image file demuxer.
4672
4673 This demuxer reads from a list of image files specified by a pattern.
4674 The syntax and meaning of the pattern is specified by the option
4675 pattern_type.
4676
4677 The pattern may contain a suffix which is used to automatically
4678 determine the format of the images contained in the files.
4679
4680 The size, the pixel format, and the format of each image must be the
4681 same for all the files in the sequence.
4682
4683 This demuxer accepts the following options:
4684
4685 framerate
4686 Set the frame rate for the video stream. It defaults to 25.
4687
4688 loop
4689 If set to 1, loop over the input. Default value is 0.
4690
4691 pattern_type
4692 Select the pattern type used to interpret the provided filename.
4693
4694 pattern_type accepts one of the following values.
4695
4696 none
4697 Disable pattern matching, therefore the video will only contain
4698 the specified image. You should use this option if you do not
4699 want to create sequences from multiple images and your
4700 filenames may contain special pattern characters.
4701
4702 sequence
4703 Select a sequence pattern type, used to specify a sequence of
4704 files indexed by sequential numbers.
4705
4706 A sequence pattern may contain the string "%d" or "%0Nd", which
4707 specifies the position of the characters representing a
4708 sequential number in each filename matched by the pattern. If
4709 the form "%d0Nd" is used, the string representing the number in
4710 each filename is 0-padded and N is the total number of 0-padded
4711 digits representing the number. The literal character '%' can
4712 be specified in the pattern with the string "%%".
4713
4714 If the sequence pattern contains "%d" or "%0Nd", the first
4715 filename of the file list specified by the pattern must contain
4716 a number inclusively contained between start_number and
4717 start_number+start_number_range-1, and all the following
4718 numbers must be sequential.
4719
4720 For example the pattern "img-%03d.bmp" will match a sequence of
4721 filenames of the form img-001.bmp, img-002.bmp, ...,
4722 img-010.bmp, etc.; the pattern "i%%m%%g-%d.jpg" will match a
4723 sequence of filenames of the form i%m%g-1.jpg, i%m%g-2.jpg,
4724 ..., i%m%g-10.jpg, etc.
4725
4726 Note that the pattern must not necessarily contain "%d" or
4727 "%0Nd", for example to convert a single image file img.jpeg you
4728 can employ the command:
4729
4730 ffmpeg -i img.jpeg img.png
4731
4732 glob
4733 Select a glob wildcard pattern type.
4734
4735 The pattern is interpreted like a "glob()" pattern. This is
4736 only selectable if libavformat was compiled with globbing
4737 support.
4738
4739 glob_sequence (deprecated, will be removed)
4740 Select a mixed glob wildcard/sequence pattern.
4741
4742 If your version of libavformat was compiled with globbing
4743 support, and the provided pattern contains at least one glob
4744 meta character among "%*?[]{}" that is preceded by an unescaped
4745 "%", the pattern is interpreted like a "glob()" pattern,
4746 otherwise it is interpreted like a sequence pattern.
4747
4748 All glob special characters "%*?[]{}" must be prefixed with
4749 "%". To escape a literal "%" you shall use "%%".
4750
4751 For example the pattern "foo-%*.jpeg" will match all the
4752 filenames prefixed by "foo-" and terminating with ".jpeg", and
4753 "foo-%?%?%?.jpeg" will match all the filenames prefixed with
4754 "foo-", followed by a sequence of three characters, and
4755 terminating with ".jpeg".
4756
4757 This pattern type is deprecated in favor of glob and sequence.
4758
4759 Default value is glob_sequence.
4760
4761 pixel_format
4762 Set the pixel format of the images to read. If not specified the
4763 pixel format is guessed from the first image file in the sequence.
4764
4765 start_number
4766 Set the index of the file matched by the image file pattern to
4767 start to read from. Default value is 0.
4768
4769 start_number_range
4770 Set the index interval range to check when looking for the first
4771 image file in the sequence, starting from start_number. Default
4772 value is 5.
4773
4774 ts_from_file
4775 If set to 1, will set frame timestamp to modification time of image
4776 file. Note that monotonity of timestamps is not provided: images go
4777 in the same order as without this option. Default value is 0. If
4778 set to 2, will set frame timestamp to the modification time of the
4779 image file in nanosecond precision.
4780
4781 video_size
4782 Set the video size of the images to read. If not specified the
4783 video size is guessed from the first image file in the sequence.
4784
4785 export_path_metadata
4786 If set to 1, will add two extra fields to the metadata found in
4787 input, making them also available for other filters (see drawtext
4788 filter for examples). Default value is 0. The extra fields are
4789 described below:
4790
4791 lavf.image2dec.source_path
4792 Corresponds to the full path to the input file being read.
4793
4794 lavf.image2dec.source_basename
4795 Corresponds to the name of the file being read.
4796
4797 Examples
4798
4799 • Use ffmpeg for creating a video from the images in the file
4800 sequence img-001.jpeg, img-002.jpeg, ..., assuming an input frame
4801 rate of 10 frames per second:
4802
4803 ffmpeg -framerate 10 -i 'img-%03d.jpeg' out.mkv
4804
4805 • As above, but start by reading from a file with index 100 in the
4806 sequence:
4807
4808 ffmpeg -framerate 10 -start_number 100 -i 'img-%03d.jpeg' out.mkv
4809
4810 • Read images matching the "*.png" glob pattern , that is all the
4811 files terminating with the ".png" suffix:
4812
4813 ffmpeg -framerate 10 -pattern_type glob -i "*.png" out.mkv
4814
4815 libgme
4816 The Game Music Emu library is a collection of video game music file
4817 emulators.
4818
4819 See <https://bitbucket.org/mpyne/game-music-emu/overview> for more
4820 information.
4821
4822 It accepts the following options:
4823
4824 track_index
4825 Set the index of which track to demux. The demuxer can only export
4826 one track. Track indexes start at 0. Default is to pick the first
4827 track. Number of tracks is exported as tracks metadata entry.
4828
4829 sample_rate
4830 Set the sampling rate of the exported track. Range is 1000 to
4831 999999. Default is 44100.
4832
4833 max_size (bytes)
4834 The demuxer buffers the entire file into memory. Adjust this value
4835 to set the maximum buffer size, which in turn, acts as a ceiling
4836 for the size of files that can be read. Default is 50 MiB.
4837
4838 libmodplug
4839 ModPlug based module demuxer
4840
4841 See <https://github.com/Konstanty/libmodplug>
4842
4843 It will export one 2-channel 16-bit 44.1 kHz audio stream. Optionally,
4844 a "pal8" 16-color video stream can be exported with or without printed
4845 metadata.
4846
4847 It accepts the following options:
4848
4849 noise_reduction
4850 Apply a simple low-pass filter. Can be 1 (on) or 0 (off). Default
4851 is 0.
4852
4853 reverb_depth
4854 Set amount of reverb. Range 0-100. Default is 0.
4855
4856 reverb_delay
4857 Set delay in ms, clamped to 40-250 ms. Default is 0.
4858
4859 bass_amount
4860 Apply bass expansion a.k.a. XBass or megabass. Range is 0 (quiet)
4861 to 100 (loud). Default is 0.
4862
4863 bass_range
4864 Set cutoff i.e. upper-bound for bass frequencies. Range is 10-100
4865 Hz. Default is 0.
4866
4867 surround_depth
4868 Apply a Dolby Pro-Logic surround effect. Range is 0 (quiet) to 100
4869 (heavy). Default is 0.
4870
4871 surround_delay
4872 Set surround delay in ms, clamped to 5-40 ms. Default is 0.
4873
4874 max_size
4875 The demuxer buffers the entire file into memory. Adjust this value
4876 to set the maximum buffer size, which in turn, acts as a ceiling
4877 for the size of files that can be read. Range is 0 to 100 MiB. 0
4878 removes buffer size limit (not recommended). Default is 5 MiB.
4879
4880 video_stream_expr
4881 String which is evaluated using the eval API to assign colors to
4882 the generated video stream. Variables which can be used are "x",
4883 "y", "w", "h", "t", "speed", "tempo", "order", "pattern" and "row".
4884
4885 video_stream
4886 Generate video stream. Can be 1 (on) or 0 (off). Default is 0.
4887
4888 video_stream_w
4889 Set video frame width in 'chars' where one char indicates 8 pixels.
4890 Range is 20-512. Default is 30.
4891
4892 video_stream_h
4893 Set video frame height in 'chars' where one char indicates 8
4894 pixels. Range is 20-512. Default is 30.
4895
4896 video_stream_ptxt
4897 Print metadata on video stream. Includes "speed", "tempo", "order",
4898 "pattern", "row" and "ts" (time in ms). Can be 1 (on) or 0 (off).
4899 Default is 1.
4900
4901 libopenmpt
4902 libopenmpt based module demuxer
4903
4904 See <https://lib.openmpt.org/libopenmpt/> for more information.
4905
4906 Some files have multiple subsongs (tracks) this can be set with the
4907 subsong option.
4908
4909 It accepts the following options:
4910
4911 subsong
4912 Set the subsong index. This can be either 'all', 'auto', or the
4913 index of the subsong. Subsong indexes start at 0. The default is
4914 'auto'.
4915
4916 The default value is to let libopenmpt choose.
4917
4918 layout
4919 Set the channel layout. Valid values are 1, 2, and 4 channel
4920 layouts. The default value is STEREO.
4921
4922 sample_rate
4923 Set the sample rate for libopenmpt to output. Range is from 1000
4924 to INT_MAX. The value default is 48000.
4925
4926 mov/mp4/3gp
4927 Demuxer for Quicktime File Format & ISO/IEC Base Media File Format
4928 (ISO/IEC 14496-12 or MPEG-4 Part 12, ISO/IEC 15444-12 or JPEG 2000 Part
4929 12).
4930
4931 Registered extensions: mov, mp4, m4a, 3gp, 3g2, mj2, psp, m4b, ism,
4932 ismv, isma, f4v
4933
4934 Options
4935
4936 This demuxer accepts the following options:
4937
4938 enable_drefs
4939 Enable loading of external tracks, disabled by default. Enabling
4940 this can theoretically leak information in some use cases.
4941
4942 use_absolute_path
4943 Allows loading of external tracks via absolute paths, disabled by
4944 default. Enabling this poses a security risk. It should only be
4945 enabled if the source is known to be non-malicious.
4946
4947 seek_streams_individually
4948 When seeking, identify the closest point in each stream
4949 individually and demux packets in that stream from identified
4950 point. This can lead to a different sequence of packets compared to
4951 demuxing linearly from the beginning. Default is true.
4952
4953 ignore_editlist
4954 Ignore any edit list atoms. The demuxer, by default, modifies the
4955 stream index to reflect the timeline described by the edit list.
4956 Default is false.
4957
4958 advanced_editlist
4959 Modify the stream index to reflect the timeline described by the
4960 edit list. "ignore_editlist" must be set to false for this option
4961 to be effective. If both "ignore_editlist" and this option are set
4962 to false, then only the start of the stream index is modified to
4963 reflect initial dwell time or starting timestamp described by the
4964 edit list. Default is true.
4965
4966 ignore_chapters
4967 Don't parse chapters. This includes GoPro 'HiLight' tags/moments.
4968 Note that chapters are only parsed when input is seekable. Default
4969 is false.
4970
4971 use_mfra_for
4972 For seekable fragmented input, set fragment's starting timestamp
4973 from media fragment random access box, if present.
4974
4975 Following options are available:
4976
4977 auto
4978 Auto-detect whether to set mfra timestamps as PTS or DTS
4979 (default)
4980
4981 dts Set mfra timestamps as DTS
4982
4983 pts Set mfra timestamps as PTS
4984
4985 0 Don't use mfra box to set timestamps
4986
4987 use_tfdt
4988 For fragmented input, set fragment's starting timestamp to
4989 "baseMediaDecodeTime" from the "tfdt" box. Default is enabled,
4990 which will prefer to use the "tfdt" box to set DTS. Disable to use
4991 the "earliest_presentation_time" from the "sidx" box. In either
4992 case, the timestamp from the "mfra" box will be used if it's
4993 available and "use_mfra_for" is set to pts or dts.
4994
4995 export_all
4996 Export unrecognized boxes within the udta box as metadata entries.
4997 The first four characters of the box type are set as the key.
4998 Default is false.
4999
5000 export_xmp
5001 Export entire contents of XMP_ box and uuid box as a string with
5002 key "xmp". Note that if "export_all" is set and this option isn't,
5003 the contents of XMP_ box are still exported but with key "XMP_".
5004 Default is false.
5005
5006 activation_bytes
5007 4-byte key required to decrypt Audible AAX and AAX+ files. See
5008 Audible AAX subsection below.
5009
5010 audible_fixed_key
5011 Fixed key used for handling Audible AAX/AAX+ files. It has been
5012 pre-set so should not be necessary to specify.
5013
5014 decryption_key
5015 16-byte key, in hex, to decrypt files encrypted using ISO Common
5016 Encryption (CENC/AES-128 CTR; ISO/IEC 23001-7).
5017
5018 max_stts_delta
5019 Very high sample deltas written in a trak's stts box may
5020 occasionally be intended but usually they are written in error or
5021 used to store a negative value for dts correction when treated as
5022 signed 32-bit integers. This option lets the user set an upper
5023 limit, beyond which the delta is clamped to 1. Values greater than
5024 the limit if negative when cast to int32 are used to adjust onward
5025 dts.
5026
5027 Unit is the track time scale. Range is 0 to UINT_MAX. Default is
5028 "UINT_MAX - 48000*10" which allows upto a 10 second dts correction
5029 for 48 kHz audio streams while accommodating 99.9% of "uint32"
5030 range.
5031
5032 Audible AAX
5033
5034 Audible AAX files are encrypted M4B files, and they can be decrypted by
5035 specifying a 4 byte activation secret.
5036
5037 ffmpeg -activation_bytes 1CEB00DA -i test.aax -vn -c:a copy output.mp4
5038
5039 mpegts
5040 MPEG-2 transport stream demuxer.
5041
5042 This demuxer accepts the following options:
5043
5044 resync_size
5045 Set size limit for looking up a new synchronization. Default value
5046 is 65536.
5047
5048 skip_unknown_pmt
5049 Skip PMTs for programs not defined in the PAT. Default value is 0.
5050
5051 fix_teletext_pts
5052 Override teletext packet PTS and DTS values with the timestamps
5053 calculated from the PCR of the first program which the teletext
5054 stream is part of and is not discarded. Default value is 1, set
5055 this option to 0 if you want your teletext packet PTS and DTS
5056 values untouched.
5057
5058 ts_packetsize
5059 Output option carrying the raw packet size in bytes. Show the
5060 detected raw packet size, cannot be set by the user.
5061
5062 scan_all_pmts
5063 Scan and combine all PMTs. The value is an integer with value from
5064 -1 to 1 (-1 means automatic setting, 1 means enabled, 0 means
5065 disabled). Default value is -1.
5066
5067 merge_pmt_versions
5068 Re-use existing streams when a PMT's version is updated and
5069 elementary streams move to different PIDs. Default value is 0.
5070
5071 mpjpeg
5072 MJPEG encapsulated in multi-part MIME demuxer.
5073
5074 This demuxer allows reading of MJPEG, where each frame is represented
5075 as a part of multipart/x-mixed-replace stream.
5076
5077 strict_mime_boundary
5078 Default implementation applies a relaxed standard to multi-part
5079 MIME boundary detection, to prevent regression with numerous
5080 existing endpoints not generating a proper MIME MJPEG stream.
5081 Turning this option on by setting it to 1 will result in a stricter
5082 check of the boundary value.
5083
5084 rawvideo
5085 Raw video demuxer.
5086
5087 This demuxer allows one to read raw video data. Since there is no
5088 header specifying the assumed video parameters, the user must specify
5089 them in order to be able to decode the data correctly.
5090
5091 This demuxer accepts the following options:
5092
5093 framerate
5094 Set input video frame rate. Default value is 25.
5095
5096 pixel_format
5097 Set the input video pixel format. Default value is "yuv420p".
5098
5099 video_size
5100 Set the input video size. This value must be specified explicitly.
5101
5102 For example to read a rawvideo file input.raw with ffplay, assuming a
5103 pixel format of "rgb24", a video size of "320x240", and a frame rate of
5104 10 images per second, use the command:
5105
5106 ffplay -f rawvideo -pixel_format rgb24 -video_size 320x240 -framerate 10 input.raw
5107
5108 sbg
5109 SBaGen script demuxer.
5110
5111 This demuxer reads the script language used by SBaGen
5112 <http://uazu.net/sbagen/> to generate binaural beats sessions. A SBG
5113 script looks like that:
5114
5115 -SE
5116 a: 300-2.5/3 440+4.5/0
5117 b: 300-2.5/0 440+4.5/3
5118 off: -
5119 NOW == a
5120 +0:07:00 == b
5121 +0:14:00 == a
5122 +0:21:00 == b
5123 +0:30:00 off
5124
5125 A SBG script can mix absolute and relative timestamps. If the script
5126 uses either only absolute timestamps (including the script start time)
5127 or only relative ones, then its layout is fixed, and the conversion is
5128 straightforward. On the other hand, if the script mixes both kind of
5129 timestamps, then the NOW reference for relative timestamps will be
5130 taken from the current time of day at the time the script is read, and
5131 the script layout will be frozen according to that reference. That
5132 means that if the script is directly played, the actual times will
5133 match the absolute timestamps up to the sound controller's clock
5134 accuracy, but if the user somehow pauses the playback or seeks, all
5135 times will be shifted accordingly.
5136
5137 tedcaptions
5138 JSON captions used for <http://www.ted.com/>.
5139
5140 TED does not provide links to the captions, but they can be guessed
5141 from the page. The file tools/bookmarklets.html from the FFmpeg source
5142 tree contains a bookmarklet to expose them.
5143
5144 This demuxer accepts the following option:
5145
5146 start_time
5147 Set the start time of the TED talk, in milliseconds. The default is
5148 15000 (15s). It is used to sync the captions with the downloadable
5149 videos, because they include a 15s intro.
5150
5151 Example: convert the captions to a format most players understand:
5152
5153 ffmpeg -i http://www.ted.com/talks/subtitles/id/1/lang/en talk1-en.srt
5154
5155 vapoursynth
5156 Vapoursynth wrapper.
5157
5158 Due to security concerns, Vapoursynth scripts will not be autodetected
5159 so the input format has to be forced. For ff* CLI tools, add "-f
5160 vapoursynth" before the input "-i yourscript.vpy".
5161
5162 This demuxer accepts the following option:
5163
5164 max_script_size
5165 The demuxer buffers the entire script into memory. Adjust this
5166 value to set the maximum buffer size, which in turn, acts as a
5167 ceiling for the size of scripts that can be read. Default is 1
5168 MiB.
5169
5171 FFmpeg is able to dump metadata from media files into a simple
5172 UTF-8-encoded INI-like text file and then load it back using the
5173 metadata muxer/demuxer.
5174
5175 The file format is as follows:
5176
5177 1. A file consists of a header and a number of metadata tags divided
5178 into sections, each on its own line.
5179
5180 2. The header is a ;FFMETADATA string, followed by a version number
5181 (now 1).
5182
5183 3. Metadata tags are of the form key=value
5184
5185 4. Immediately after header follows global metadata
5186
5187 5. After global metadata there may be sections with
5188 per-stream/per-chapter metadata.
5189
5190 6. A section starts with the section name in uppercase (i.e. STREAM or
5191 CHAPTER) in brackets ([, ]) and ends with next section or end of
5192 file.
5193
5194 7. At the beginning of a chapter section there may be an optional
5195 timebase to be used for start/end values. It must be in form
5196 TIMEBASE=num/den, where num and den are integers. If the timebase
5197 is missing then start/end times are assumed to be in nanoseconds.
5198
5199 Next a chapter section must contain chapter start and end times in
5200 form START=num, END=num, where num is a positive integer.
5201
5202 8. Empty lines and lines starting with ; or # are ignored.
5203
5204 9. Metadata keys or values containing special characters (=, ;, #, \
5205 and a newline) must be escaped with a backslash \.
5206
5207 10. Note that whitespace in metadata (e.g. foo = bar) is considered to
5208 be a part of the tag (in the example above key is foo , value is
5209 bar).
5210
5211 A ffmetadata file might look like this:
5212
5213 ;FFMETADATA1
5214 title=bike\\shed
5215 ;this is a comment
5216 artist=FFmpeg troll team
5217
5218 [CHAPTER]
5219 TIMEBASE=1/1000
5220 START=0
5221 #chapter ends at 0:01:00
5222 END=60000
5223 title=chapter \#1
5224 [STREAM]
5225 title=multi\
5226 line
5227
5228 By using the ffmetadata muxer and demuxer it is possible to extract
5229 metadata from an input file to an ffmetadata file, and then transcode
5230 the file into an output file with the edited ffmetadata file.
5231
5232 Extracting an ffmetadata file with ffmpeg goes as follows:
5233
5234 ffmpeg -i INPUT -f ffmetadata FFMETADATAFILE
5235
5236 Reinserting edited metadata information from the FFMETADATAFILE file
5237 can be done as:
5238
5239 ffmpeg -i INPUT -i FFMETADATAFILE -map_metadata 1 -codec copy OUTPUT
5240
5242 The libavformat library provides some generic global options, which can
5243 be set on all the protocols. In addition each protocol may support so-
5244 called private options, which are specific for that component.
5245
5246 Options may be set by specifying -option value in the FFmpeg tools, or
5247 by setting the value explicitly in the "AVFormatContext" options or
5248 using the libavutil/opt.h API for programmatic use.
5249
5250 The list of supported options follows:
5251
5252 protocol_whitelist list (input)
5253 Set a ","-separated list of allowed protocols. "ALL" matches all
5254 protocols. Protocols prefixed by "-" are disabled. All protocols
5255 are allowed by default but protocols used by an another protocol
5256 (nested protocols) are restricted to a per protocol subset.
5257
5259 Protocols are configured elements in FFmpeg that enable access to
5260 resources that require specific protocols.
5261
5262 When you configure your FFmpeg build, all the supported protocols are
5263 enabled by default. You can list all available ones using the configure
5264 option "--list-protocols".
5265
5266 You can disable all the protocols using the configure option
5267 "--disable-protocols", and selectively enable a protocol using the
5268 option "--enable-protocol=PROTOCOL", or you can disable a particular
5269 protocol using the option "--disable-protocol=PROTOCOL".
5270
5271 The option "-protocols" of the ff* tools will display the list of
5272 supported protocols.
5273
5274 All protocols accept the following options:
5275
5276 rw_timeout
5277 Maximum time to wait for (network) read/write operations to
5278 complete, in microseconds.
5279
5280 A description of the currently available protocols follows.
5281
5282 amqp
5283 Advanced Message Queueing Protocol (AMQP) version 0-9-1 is a broker
5284 based publish-subscribe communication protocol.
5285
5286 FFmpeg must be compiled with --enable-librabbitmq to support AMQP. A
5287 separate AMQP broker must also be run. An example open-source AMQP
5288 broker is RabbitMQ.
5289
5290 After starting the broker, an FFmpeg client may stream data to the
5291 broker using the command:
5292
5293 ffmpeg -re -i input -f mpegts amqp://[[user]:[password]@]hostname[:port][/vhost]
5294
5295 Where hostname and port (default is 5672) is the address of the broker.
5296 The client may also set a user/password for authentication. The default
5297 for both fields is "guest". Name of virtual host on broker can be set
5298 with vhost. The default value is "/".
5299
5300 Muliple subscribers may stream from the broker using the command:
5301
5302 ffplay amqp://[[user]:[password]@]hostname[:port][/vhost]
5303
5304 In RabbitMQ all data published to the broker flows through a specific
5305 exchange, and each subscribing client has an assigned queue/buffer.
5306 When a packet arrives at an exchange, it may be copied to a client's
5307 queue depending on the exchange and routing_key fields.
5308
5309 The following options are supported:
5310
5311 exchange
5312 Sets the exchange to use on the broker. RabbitMQ has several
5313 predefined exchanges: "amq.direct" is the default exchange, where
5314 the publisher and subscriber must have a matching routing_key;
5315 "amq.fanout" is the same as a broadcast operation (i.e. the data is
5316 forwarded to all queues on the fanout exchange independent of the
5317 routing_key); and "amq.topic" is similar to "amq.direct", but
5318 allows for more complex pattern matching (refer to the RabbitMQ
5319 documentation).
5320
5321 routing_key
5322 Sets the routing key. The default value is "amqp". The routing key
5323 is used on the "amq.direct" and "amq.topic" exchanges to decide
5324 whether packets are written to the queue of a subscriber.
5325
5326 pkt_size
5327 Maximum size of each packet sent/received to the broker. Default is
5328 131072. Minimum is 4096 and max is any large value (representable
5329 by an int). When receiving packets, this sets an internal buffer
5330 size in FFmpeg. It should be equal to or greater than the size of
5331 the published packets to the broker. Otherwise the received message
5332 may be truncated causing decoding errors.
5333
5334 connection_timeout
5335 The timeout in seconds during the initial connection to the broker.
5336 The default value is rw_timeout, or 5 seconds if rw_timeout is not
5337 set.
5338
5339 delivery_mode mode
5340 Sets the delivery mode of each message sent to broker. The
5341 following values are accepted:
5342
5343 persistent
5344 Delivery mode set to "persistent" (2). This is the default
5345 value. Messages may be written to the broker's disk depending
5346 on its setup.
5347
5348 non-persistent
5349 Delivery mode set to "non-persistent" (1). Messages will stay
5350 in broker's memory unless the broker is under memory pressure.
5351
5352 async
5353 Asynchronous data filling wrapper for input stream.
5354
5355 Fill data in a background thread, to decouple I/O operation from demux
5356 thread.
5357
5358 async:<URL>
5359 async:http://host/resource
5360 async:cache:http://host/resource
5361
5362 bluray
5363 Read BluRay playlist.
5364
5365 The accepted options are:
5366
5367 angle
5368 BluRay angle
5369
5370 chapter
5371 Start chapter (1...N)
5372
5373 playlist
5374 Playlist to read (BDMV/PLAYLIST/?????.mpls)
5375
5376 Examples:
5377
5378 Read longest playlist from BluRay mounted to /mnt/bluray:
5379
5380 bluray:/mnt/bluray
5381
5382 Read angle 2 of playlist 4 from BluRay mounted to /mnt/bluray, start
5383 from chapter 2:
5384
5385 -playlist 4 -angle 2 -chapter 2 bluray:/mnt/bluray
5386
5387 cache
5388 Caching wrapper for input stream.
5389
5390 Cache the input stream to temporary file. It brings seeking capability
5391 to live streams.
5392
5393 The accepted options are:
5394
5395 read_ahead_limit
5396 Amount in bytes that may be read ahead when seeking isn't
5397 supported. Range is -1 to INT_MAX. -1 for unlimited. Default is
5398 65536.
5399
5400 URL Syntax is
5401
5402 cache:<URL>
5403
5404 concat
5405 Physical concatenation protocol.
5406
5407 Read and seek from many resources in sequence as if they were a unique
5408 resource.
5409
5410 A URL accepted by this protocol has the syntax:
5411
5412 concat:<URL1>|<URL2>|...|<URLN>
5413
5414 where URL1, URL2, ..., URLN are the urls of the resource to be
5415 concatenated, each one possibly specifying a distinct protocol.
5416
5417 For example to read a sequence of files split1.mpeg, split2.mpeg,
5418 split3.mpeg with ffplay use the command:
5419
5420 ffplay concat:split1.mpeg\|split2.mpeg\|split3.mpeg
5421
5422 Note that you may need to escape the character "|" which is special for
5423 many shells.
5424
5425 concatf
5426 Physical concatenation protocol using a line break delimited list of
5427 resources.
5428
5429 Read and seek from many resources in sequence as if they were a unique
5430 resource.
5431
5432 A URL accepted by this protocol has the syntax:
5433
5434 concatf:<URL>
5435
5436 where URL is the url containing a line break delimited list of
5437 resources to be concatenated, each one possibly specifying a distinct
5438 protocol. Special characters must be escaped with backslash or single
5439 quotes. See the "Quoting and escaping" section in the ffmpeg-utils(1)
5440 manual.
5441
5442 For example to read a sequence of files split1.mpeg, split2.mpeg,
5443 split3.mpeg listed in separate lines within a file split.txt with
5444 ffplay use the command:
5445
5446 ffplay concatf:split.txt
5447
5448 Where split.txt contains the lines:
5449
5450 split1.mpeg
5451 split2.mpeg
5452 split3.mpeg
5453
5454 crypto
5455 AES-encrypted stream reading protocol.
5456
5457 The accepted options are:
5458
5459 key Set the AES decryption key binary block from given hexadecimal
5460 representation.
5461
5462 iv Set the AES decryption initialization vector binary block from
5463 given hexadecimal representation.
5464
5465 Accepted URL formats:
5466
5467 crypto:<URL>
5468 crypto+<URL>
5469
5470 data
5471 Data in-line in the URI. See
5472 <http://en.wikipedia.org/wiki/Data_URI_scheme>.
5473
5474 For example, to convert a GIF file given inline with ffmpeg:
5475
5476 ffmpeg -i "" smiley.png
5477
5478 file
5479 File access protocol.
5480
5481 Read from or write to a file.
5482
5483 A file URL can have the form:
5484
5485 file:<filename>
5486
5487 where filename is the path of the file to read.
5488
5489 An URL that does not have a protocol prefix will be assumed to be a
5490 file URL. Depending on the build, an URL that looks like a Windows path
5491 with the drive letter at the beginning will also be assumed to be a
5492 file URL (usually not the case in builds for unix-like systems).
5493
5494 For example to read from a file input.mpeg with ffmpeg use the command:
5495
5496 ffmpeg -i file:input.mpeg output.mpeg
5497
5498 This protocol accepts the following options:
5499
5500 truncate
5501 Truncate existing files on write, if set to 1. A value of 0
5502 prevents truncating. Default value is 1.
5503
5504 blocksize
5505 Set I/O operation maximum block size, in bytes. Default value is
5506 "INT_MAX", which results in not limiting the requested block size.
5507 Setting this value reasonably low improves user termination request
5508 reaction time, which is valuable for files on slow medium.
5509
5510 follow
5511 If set to 1, the protocol will retry reading at the end of the
5512 file, allowing reading files that still are being written. In order
5513 for this to terminate, you either need to use the rw_timeout
5514 option, or use the interrupt callback (for API users).
5515
5516 seekable
5517 Controls if seekability is advertised on the file. 0 means non-
5518 seekable, -1 means auto (seekable for normal files, non-seekable
5519 for named pipes).
5520
5521 Many demuxers handle seekable and non-seekable resources
5522 differently, overriding this might speed up opening certain files
5523 at the cost of losing some features (e.g. accurate seeking).
5524
5525 ftp
5526 FTP (File Transfer Protocol).
5527
5528 Read from or write to remote resources using FTP protocol.
5529
5530 Following syntax is required.
5531
5532 ftp://[user[:password]@]server[:port]/path/to/remote/resource.mpeg
5533
5534 This protocol accepts the following options.
5535
5536 timeout
5537 Set timeout in microseconds of socket I/O operations used by the
5538 underlying low level operation. By default it is set to -1, which
5539 means that the timeout is not specified.
5540
5541 ftp-user
5542 Set a user to be used for authenticating to the FTP server. This is
5543 overridden by the user in the FTP URL.
5544
5545 ftp-password
5546 Set a password to be used for authenticating to the FTP server.
5547 This is overridden by the password in the FTP URL, or by ftp-
5548 anonymous-password if no user is set.
5549
5550 ftp-anonymous-password
5551 Password used when login as anonymous user. Typically an e-mail
5552 address should be used.
5553
5554 ftp-write-seekable
5555 Control seekability of connection during encoding. If set to 1 the
5556 resource is supposed to be seekable, if set to 0 it is assumed not
5557 to be seekable. Default value is 0.
5558
5559 NOTE: Protocol can be used as output, but it is recommended to not do
5560 it, unless special care is taken (tests, customized server
5561 configuration etc.). Different FTP servers behave in different way
5562 during seek operation. ff* tools may produce incomplete content due to
5563 server limitations.
5564
5565 gopher
5566 Gopher protocol.
5567
5568 gophers
5569 Gophers protocol.
5570
5571 The Gopher protocol with TLS encapsulation.
5572
5573 hls
5574 Read Apple HTTP Live Streaming compliant segmented stream as a uniform
5575 one. The M3U8 playlists describing the segments can be remote HTTP
5576 resources or local files, accessed using the standard file protocol.
5577 The nested protocol is declared by specifying "+proto" after the hls
5578 URI scheme name, where proto is either "file" or "http".
5579
5580 hls+http://host/path/to/remote/resource.m3u8
5581 hls+file://path/to/local/resource.m3u8
5582
5583 Using this protocol is discouraged - the hls demuxer should work just
5584 as well (if not, please report the issues) and is more complete. To
5585 use the hls demuxer instead, simply use the direct URLs to the m3u8
5586 files.
5587
5588 http
5589 HTTP (Hyper Text Transfer Protocol).
5590
5591 This protocol accepts the following options:
5592
5593 seekable
5594 Control seekability of connection. If set to 1 the resource is
5595 supposed to be seekable, if set to 0 it is assumed not to be
5596 seekable, if set to -1 it will try to autodetect if it is seekable.
5597 Default value is -1.
5598
5599 chunked_post
5600 If set to 1 use chunked Transfer-Encoding for posts, default is 1.
5601
5602 content_type
5603 Set a specific content type for the POST messages or for listen
5604 mode.
5605
5606 http_proxy
5607 set HTTP proxy to tunnel through e.g. http://example.com:1234
5608
5609 headers
5610 Set custom HTTP headers, can override built in default headers. The
5611 value must be a string encoding the headers.
5612
5613 multiple_requests
5614 Use persistent connections if set to 1, default is 0.
5615
5616 post_data
5617 Set custom HTTP post data.
5618
5619 referer
5620 Set the Referer header. Include 'Referer: URL' header in HTTP
5621 request.
5622
5623 user_agent
5624 Override the User-Agent header. If not specified the protocol will
5625 use a string describing the libavformat build. ("Lavf/<version>")
5626
5627 reconnect_at_eof
5628 If set then eof is treated like an error and causes reconnection,
5629 this is useful for live / endless streams.
5630
5631 reconnect_streamed
5632 If set then even streamed/non seekable streams will be reconnected
5633 on errors.
5634
5635 reconnect_on_network_error
5636 Reconnect automatically in case of TCP/TLS errors during connect.
5637
5638 reconnect_on_http_error
5639 A comma separated list of HTTP status codes to reconnect on. The
5640 list can include specific status codes (e.g. '503') or the strings
5641 '4xx' / '5xx'.
5642
5643 reconnect_delay_max
5644 Sets the maximum delay in seconds after which to give up
5645 reconnecting
5646
5647 mime_type
5648 Export the MIME type.
5649
5650 http_version
5651 Exports the HTTP response version number. Usually "1.0" or "1.1".
5652
5653 icy If set to 1 request ICY (SHOUTcast) metadata from the server. If
5654 the server supports this, the metadata has to be retrieved by the
5655 application by reading the icy_metadata_headers and
5656 icy_metadata_packet options. The default is 1.
5657
5658 icy_metadata_headers
5659 If the server supports ICY metadata, this contains the ICY-specific
5660 HTTP reply headers, separated by newline characters.
5661
5662 icy_metadata_packet
5663 If the server supports ICY metadata, and icy was set to 1, this
5664 contains the last non-empty metadata packet sent by the server. It
5665 should be polled in regular intervals by applications interested in
5666 mid-stream metadata updates.
5667
5668 cookies
5669 Set the cookies to be sent in future requests. The format of each
5670 cookie is the same as the value of a Set-Cookie HTTP response
5671 field. Multiple cookies can be delimited by a newline character.
5672
5673 offset
5674 Set initial byte offset.
5675
5676 end_offset
5677 Try to limit the request to bytes preceding this offset.
5678
5679 method
5680 When used as a client option it sets the HTTP method for the
5681 request.
5682
5683 When used as a server option it sets the HTTP method that is going
5684 to be expected from the client(s). If the expected and the
5685 received HTTP method do not match the client will be given a Bad
5686 Request response. When unset the HTTP method is not checked for
5687 now. This will be replaced by autodetection in the future.
5688
5689 listen
5690 If set to 1 enables experimental HTTP server. This can be used to
5691 send data when used as an output option, or read data from a client
5692 with HTTP POST when used as an input option. If set to 2 enables
5693 experimental multi-client HTTP server. This is not yet implemented
5694 in ffmpeg.c and thus must not be used as a command line option.
5695
5696 # Server side (sending):
5697 ffmpeg -i somefile.ogg -c copy -listen 1 -f ogg http://<server>:<port>
5698
5699 # Client side (receiving):
5700 ffmpeg -i http://<server>:<port> -c copy somefile.ogg
5701
5702 # Client can also be done with wget:
5703 wget http://<server>:<port> -O somefile.ogg
5704
5705 # Server side (receiving):
5706 ffmpeg -listen 1 -i http://<server>:<port> -c copy somefile.ogg
5707
5708 # Client side (sending):
5709 ffmpeg -i somefile.ogg -chunked_post 0 -c copy -f ogg http://<server>:<port>
5710
5711 # Client can also be done with wget:
5712 wget --post-file=somefile.ogg http://<server>:<port>
5713
5714 send_expect_100
5715 Send an Expect: 100-continue header for POST. If set to 1 it will
5716 send, if set to 0 it won't, if set to -1 it will try to send if it
5717 is applicable. Default value is -1.
5718
5719 auth_type
5720 Set HTTP authentication type. No option for Digest, since this
5721 method requires getting nonce parameters from the server first and
5722 can't be used straight away like Basic.
5723
5724 none
5725 Choose the HTTP authentication type automatically. This is the
5726 default.
5727
5728 basic
5729 Choose the HTTP basic authentication.
5730
5731 Basic authentication sends a Base64-encoded string that
5732 contains a user name and password for the client. Base64 is not
5733 a form of encryption and should be considered the same as
5734 sending the user name and password in clear text (Base64 is a
5735 reversible encoding). If a resource needs to be protected,
5736 strongly consider using an authentication scheme other than
5737 basic authentication. HTTPS/TLS should be used with basic
5738 authentication. Without these additional security
5739 enhancements, basic authentication should not be used to
5740 protect sensitive or valuable information.
5741
5742 HTTP Cookies
5743
5744 Some HTTP requests will be denied unless cookie values are passed in
5745 with the request. The cookies option allows these cookies to be
5746 specified. At the very least, each cookie must specify a value along
5747 with a path and domain. HTTP requests that match both the domain and
5748 path will automatically include the cookie value in the HTTP Cookie
5749 header field. Multiple cookies can be delimited by a newline.
5750
5751 The required syntax to play a stream specifying a cookie is:
5752
5753 ffplay -cookies "nlqptid=nltid=tsn; path=/; domain=somedomain.com;" http://somedomain.com/somestream.m3u8
5754
5755 Icecast
5756 Icecast protocol (stream to Icecast servers)
5757
5758 This protocol accepts the following options:
5759
5760 ice_genre
5761 Set the stream genre.
5762
5763 ice_name
5764 Set the stream name.
5765
5766 ice_description
5767 Set the stream description.
5768
5769 ice_url
5770 Set the stream website URL.
5771
5772 ice_public
5773 Set if the stream should be public. The default is 0 (not public).
5774
5775 user_agent
5776 Override the User-Agent header. If not specified a string of the
5777 form "Lavf/<version>" will be used.
5778
5779 password
5780 Set the Icecast mountpoint password.
5781
5782 content_type
5783 Set the stream content type. This must be set if it is different
5784 from audio/mpeg.
5785
5786 legacy_icecast
5787 This enables support for Icecast versions < 2.4.0, that do not
5788 support the HTTP PUT method but the SOURCE method.
5789
5790 tls Establish a TLS (HTTPS) connection to Icecast.
5791
5792 icecast://[<username>[:<password>]@]<server>:<port>/<mountpoint>
5793
5794 mmst
5795 MMS (Microsoft Media Server) protocol over TCP.
5796
5797 mmsh
5798 MMS (Microsoft Media Server) protocol over HTTP.
5799
5800 The required syntax is:
5801
5802 mmsh://<server>[:<port>][/<app>][/<playpath>]
5803
5804 md5
5805 MD5 output protocol.
5806
5807 Computes the MD5 hash of the data to be written, and on close writes
5808 this to the designated output or stdout if none is specified. It can be
5809 used to test muxers without writing an actual file.
5810
5811 Some examples follow.
5812
5813 # Write the MD5 hash of the encoded AVI file to the file output.avi.md5.
5814 ffmpeg -i input.flv -f avi -y md5:output.avi.md5
5815
5816 # Write the MD5 hash of the encoded AVI file to stdout.
5817 ffmpeg -i input.flv -f avi -y md5:
5818
5819 Note that some formats (typically MOV) require the output protocol to
5820 be seekable, so they will fail with the MD5 output protocol.
5821
5822 pipe
5823 UNIX pipe access protocol.
5824
5825 Read and write from UNIX pipes.
5826
5827 The accepted syntax is:
5828
5829 pipe:[<number>]
5830
5831 number is the number corresponding to the file descriptor of the pipe
5832 (e.g. 0 for stdin, 1 for stdout, 2 for stderr). If number is not
5833 specified, by default the stdout file descriptor will be used for
5834 writing, stdin for reading.
5835
5836 For example to read from stdin with ffmpeg:
5837
5838 cat test.wav | ffmpeg -i pipe:0
5839 # ...this is the same as...
5840 cat test.wav | ffmpeg -i pipe:
5841
5842 For writing to stdout with ffmpeg:
5843
5844 ffmpeg -i test.wav -f avi pipe:1 | cat > test.avi
5845 # ...this is the same as...
5846 ffmpeg -i test.wav -f avi pipe: | cat > test.avi
5847
5848 This protocol accepts the following options:
5849
5850 blocksize
5851 Set I/O operation maximum block size, in bytes. Default value is
5852 "INT_MAX", which results in not limiting the requested block size.
5853 Setting this value reasonably low improves user termination request
5854 reaction time, which is valuable if data transmission is slow.
5855
5856 Note that some formats (typically MOV), require the output protocol to
5857 be seekable, so they will fail with the pipe output protocol.
5858
5859 prompeg
5860 Pro-MPEG Code of Practice #3 Release 2 FEC protocol.
5861
5862 The Pro-MPEG CoP#3 FEC is a 2D parity-check forward error correction
5863 mechanism for MPEG-2 Transport Streams sent over RTP.
5864
5865 This protocol must be used in conjunction with the "rtp_mpegts" muxer
5866 and the "rtp" protocol.
5867
5868 The required syntax is:
5869
5870 -f rtp_mpegts -fec prompeg=<option>=<val>... rtp://<hostname>:<port>
5871
5872 The destination UDP ports are "port + 2" for the column FEC stream and
5873 "port + 4" for the row FEC stream.
5874
5875 This protocol accepts the following options:
5876
5877 l=n The number of columns (4-20, LxD <= 100)
5878
5879 d=n The number of rows (4-20, LxD <= 100)
5880
5881 Example usage:
5882
5883 -f rtp_mpegts -fec prompeg=l=8:d=4 rtp://<hostname>:<port>
5884
5885 rist
5886 Reliable Internet Streaming Transport protocol
5887
5888 The accepted options are:
5889
5890 rist_profile
5891 Supported values:
5892
5893 simple
5894 main
5895 This one is default.
5896
5897 advanced
5898 buffer_size
5899 Set internal RIST buffer size in milliseconds for retransmission of
5900 data. Default value is 0 which means the librist default (1 sec).
5901 Maximum value is 30 seconds.
5902
5903 pkt_size
5904 Set maximum packet size for sending data. 1316 by default.
5905
5906 log_level
5907 Set loglevel for RIST logging messages. You only need to set this
5908 if you explicitly want to enable debug level messages or packet
5909 loss simulation, otherwise the regular loglevel is respected.
5910
5911 secret
5912 Set override of encryption secret, by default is unset.
5913
5914 encryption
5915 Set encryption type, by default is disabled. Acceptable values are
5916 128 and 256.
5917
5918 rtmp
5919 Real-Time Messaging Protocol.
5920
5921 The Real-Time Messaging Protocol (RTMP) is used for streaming
5922 multimedia content across a TCP/IP network.
5923
5924 The required syntax is:
5925
5926 rtmp://[<username>:<password>@]<server>[:<port>][/<app>][/<instance>][/<playpath>]
5927
5928 The accepted parameters are:
5929
5930 username
5931 An optional username (mostly for publishing).
5932
5933 password
5934 An optional password (mostly for publishing).
5935
5936 server
5937 The address of the RTMP server.
5938
5939 port
5940 The number of the TCP port to use (by default is 1935).
5941
5942 app It is the name of the application to access. It usually corresponds
5943 to the path where the application is installed on the RTMP server
5944 (e.g. /ondemand/, /flash/live/, etc.). You can override the value
5945 parsed from the URI through the "rtmp_app" option, too.
5946
5947 playpath
5948 It is the path or name of the resource to play with reference to
5949 the application specified in app, may be prefixed by "mp4:". You
5950 can override the value parsed from the URI through the
5951 "rtmp_playpath" option, too.
5952
5953 listen
5954 Act as a server, listening for an incoming connection.
5955
5956 timeout
5957 Maximum time to wait for the incoming connection. Implies listen.
5958
5959 Additionally, the following parameters can be set via command line
5960 options (or in code via "AVOption"s):
5961
5962 rtmp_app
5963 Name of application to connect on the RTMP server. This option
5964 overrides the parameter specified in the URI.
5965
5966 rtmp_buffer
5967 Set the client buffer time in milliseconds. The default is 3000.
5968
5969 rtmp_conn
5970 Extra arbitrary AMF connection parameters, parsed from a string,
5971 e.g. like "B:1 S:authMe O:1 NN:code:1.23 NS:flag:ok O:0". Each
5972 value is prefixed by a single character denoting the type, B for
5973 Boolean, N for number, S for string, O for object, or Z for null,
5974 followed by a colon. For Booleans the data must be either 0 or 1
5975 for FALSE or TRUE, respectively. Likewise for Objects the data
5976 must be 0 or 1 to end or begin an object, respectively. Data items
5977 in subobjects may be named, by prefixing the type with 'N' and
5978 specifying the name before the value (i.e. "NB:myFlag:1"). This
5979 option may be used multiple times to construct arbitrary AMF
5980 sequences.
5981
5982 rtmp_flashver
5983 Version of the Flash plugin used to run the SWF player. The default
5984 is LNX 9,0,124,2. (When publishing, the default is FMLE/3.0
5985 (compatible; <libavformat version>).)
5986
5987 rtmp_flush_interval
5988 Number of packets flushed in the same request (RTMPT only). The
5989 default is 10.
5990
5991 rtmp_live
5992 Specify that the media is a live stream. No resuming or seeking in
5993 live streams is possible. The default value is "any", which means
5994 the subscriber first tries to play the live stream specified in the
5995 playpath. If a live stream of that name is not found, it plays the
5996 recorded stream. The other possible values are "live" and
5997 "recorded".
5998
5999 rtmp_pageurl
6000 URL of the web page in which the media was embedded. By default no
6001 value will be sent.
6002
6003 rtmp_playpath
6004 Stream identifier to play or to publish. This option overrides the
6005 parameter specified in the URI.
6006
6007 rtmp_subscribe
6008 Name of live stream to subscribe to. By default no value will be
6009 sent. It is only sent if the option is specified or if rtmp_live
6010 is set to live.
6011
6012 rtmp_swfhash
6013 SHA256 hash of the decompressed SWF file (32 bytes).
6014
6015 rtmp_swfsize
6016 Size of the decompressed SWF file, required for SWFVerification.
6017
6018 rtmp_swfurl
6019 URL of the SWF player for the media. By default no value will be
6020 sent.
6021
6022 rtmp_swfverify
6023 URL to player swf file, compute hash/size automatically.
6024
6025 rtmp_tcurl
6026 URL of the target stream. Defaults to proto://host[:port]/app.
6027
6028 tcp_nodelay=1|0
6029 Set TCP_NODELAY to disable Nagle's algorithm. Default value is 0.
6030
6031 Remark: Writing to the socket is currently not optimized to
6032 minimize system calls and reduces the efficiency / effect of
6033 TCP_NODELAY.
6034
6035 For example to read with ffplay a multimedia resource named "sample"
6036 from the application "vod" from an RTMP server "myserver":
6037
6038 ffplay rtmp://myserver/vod/sample
6039
6040 To publish to a password protected server, passing the playpath and app
6041 names separately:
6042
6043 ffmpeg -re -i <input> -f flv -rtmp_playpath some/long/path -rtmp_app long/app/name rtmp://username:password@myserver/
6044
6045 rtmpe
6046 Encrypted Real-Time Messaging Protocol.
6047
6048 The Encrypted Real-Time Messaging Protocol (RTMPE) is used for
6049 streaming multimedia content within standard cryptographic primitives,
6050 consisting of Diffie-Hellman key exchange and HMACSHA256, generating a
6051 pair of RC4 keys.
6052
6053 rtmps
6054 Real-Time Messaging Protocol over a secure SSL connection.
6055
6056 The Real-Time Messaging Protocol (RTMPS) is used for streaming
6057 multimedia content across an encrypted connection.
6058
6059 rtmpt
6060 Real-Time Messaging Protocol tunneled through HTTP.
6061
6062 The Real-Time Messaging Protocol tunneled through HTTP (RTMPT) is used
6063 for streaming multimedia content within HTTP requests to traverse
6064 firewalls.
6065
6066 rtmpte
6067 Encrypted Real-Time Messaging Protocol tunneled through HTTP.
6068
6069 The Encrypted Real-Time Messaging Protocol tunneled through HTTP
6070 (RTMPTE) is used for streaming multimedia content within HTTP requests
6071 to traverse firewalls.
6072
6073 rtmpts
6074 Real-Time Messaging Protocol tunneled through HTTPS.
6075
6076 The Real-Time Messaging Protocol tunneled through HTTPS (RTMPTS) is
6077 used for streaming multimedia content within HTTPS requests to traverse
6078 firewalls.
6079
6080 libsmbclient
6081 libsmbclient permits one to manipulate CIFS/SMB network resources.
6082
6083 Following syntax is required.
6084
6085 smb://[[domain:]user[:password@]]server[/share[/path[/file]]]
6086
6087 This protocol accepts the following options.
6088
6089 timeout
6090 Set timeout in milliseconds of socket I/O operations used by the
6091 underlying low level operation. By default it is set to -1, which
6092 means that the timeout is not specified.
6093
6094 truncate
6095 Truncate existing files on write, if set to 1. A value of 0
6096 prevents truncating. Default value is 1.
6097
6098 workgroup
6099 Set the workgroup used for making connections. By default workgroup
6100 is not specified.
6101
6102 For more information see: <http://www.samba.org/>.
6103
6104 libssh
6105 Secure File Transfer Protocol via libssh
6106
6107 Read from or write to remote resources using SFTP protocol.
6108
6109 Following syntax is required.
6110
6111 sftp://[user[:password]@]server[:port]/path/to/remote/resource.mpeg
6112
6113 This protocol accepts the following options.
6114
6115 timeout
6116 Set timeout of socket I/O operations used by the underlying low
6117 level operation. By default it is set to -1, which means that the
6118 timeout is not specified.
6119
6120 truncate
6121 Truncate existing files on write, if set to 1. A value of 0
6122 prevents truncating. Default value is 1.
6123
6124 private_key
6125 Specify the path of the file containing private key to use during
6126 authorization. By default libssh searches for keys in the ~/.ssh/
6127 directory.
6128
6129 Example: Play a file stored on remote server.
6130
6131 ffplay sftp://user:password@server_address:22/home/user/resource.mpeg
6132
6133 librtmp rtmp, rtmpe, rtmps, rtmpt, rtmpte
6134 Real-Time Messaging Protocol and its variants supported through
6135 librtmp.
6136
6137 Requires the presence of the librtmp headers and library during
6138 configuration. You need to explicitly configure the build with
6139 "--enable-librtmp". If enabled this will replace the native RTMP
6140 protocol.
6141
6142 This protocol provides most client functions and a few server functions
6143 needed to support RTMP, RTMP tunneled in HTTP (RTMPT), encrypted RTMP
6144 (RTMPE), RTMP over SSL/TLS (RTMPS) and tunneled variants of these
6145 encrypted types (RTMPTE, RTMPTS).
6146
6147 The required syntax is:
6148
6149 <rtmp_proto>://<server>[:<port>][/<app>][/<playpath>] <options>
6150
6151 where rtmp_proto is one of the strings "rtmp", "rtmpt", "rtmpe",
6152 "rtmps", "rtmpte", "rtmpts" corresponding to each RTMP variant, and
6153 server, port, app and playpath have the same meaning as specified for
6154 the RTMP native protocol. options contains a list of space-separated
6155 options of the form key=val.
6156
6157 See the librtmp manual page (man 3 librtmp) for more information.
6158
6159 For example, to stream a file in real-time to an RTMP server using
6160 ffmpeg:
6161
6162 ffmpeg -re -i myfile -f flv rtmp://myserver/live/mystream
6163
6164 To play the same stream using ffplay:
6165
6166 ffplay "rtmp://myserver/live/mystream live=1"
6167
6168 rtp
6169 Real-time Transport Protocol.
6170
6171 The required syntax for an RTP URL is:
6172 rtp://hostname[:port][?option=val...]
6173
6174 port specifies the RTP port to use.
6175
6176 The following URL options are supported:
6177
6178 ttl=n
6179 Set the TTL (Time-To-Live) value (for multicast only).
6180
6181 rtcpport=n
6182 Set the remote RTCP port to n.
6183
6184 localrtpport=n
6185 Set the local RTP port to n.
6186
6187 localrtcpport=n'
6188 Set the local RTCP port to n.
6189
6190 pkt_size=n
6191 Set max packet size (in bytes) to n.
6192
6193 buffer_size=size
6194 Set the maximum UDP socket buffer size in bytes.
6195
6196 connect=0|1
6197 Do a "connect()" on the UDP socket (if set to 1) or not (if set to
6198 0).
6199
6200 sources=ip[,ip]
6201 List allowed source IP addresses.
6202
6203 block=ip[,ip]
6204 List disallowed (blocked) source IP addresses.
6205
6206 write_to_source=0|1
6207 Send packets to the source address of the latest received packet
6208 (if set to 1) or to a default remote address (if set to 0).
6209
6210 localport=n
6211 Set the local RTP port to n.
6212
6213 localaddr=addr
6214 Local IP address of a network interface used for sending packets or
6215 joining multicast groups.
6216
6217 timeout=n
6218 Set timeout (in microseconds) of socket I/O operations to n.
6219
6220 This is a deprecated option. Instead, localrtpport should be used.
6221
6222 Important notes:
6223
6224 1. If rtcpport is not set the RTCP port will be set to the RTP port
6225 value plus 1.
6226
6227 2. If localrtpport (the local RTP port) is not set any available port
6228 will be used for the local RTP and RTCP ports.
6229
6230 3. If localrtcpport (the local RTCP port) is not set it will be set to
6231 the local RTP port value plus 1.
6232
6233 rtsp
6234 Real-Time Streaming Protocol.
6235
6236 RTSP is not technically a protocol handler in libavformat, it is a
6237 demuxer and muxer. The demuxer supports both normal RTSP (with data
6238 transferred over RTP; this is used by e.g. Apple and Microsoft) and
6239 Real-RTSP (with data transferred over RDT).
6240
6241 The muxer can be used to send a stream using RTSP ANNOUNCE to a server
6242 supporting it (currently Darwin Streaming Server and Mischa
6243 Spiegelmock's <https://github.com/revmischa/rtsp-server>).
6244
6245 The required syntax for a RTSP url is:
6246
6247 rtsp://<hostname>[:<port>]/<path>
6248
6249 Options can be set on the ffmpeg/ffplay command line, or set in code
6250 via "AVOption"s or in "avformat_open_input".
6251
6252 The following options are supported.
6253
6254 initial_pause
6255 Do not start playing the stream immediately if set to 1. Default
6256 value is 0.
6257
6258 rtsp_transport
6259 Set RTSP transport protocols.
6260
6261 It accepts the following values:
6262
6263 udp Use UDP as lower transport protocol.
6264
6265 tcp Use TCP (interleaving within the RTSP control channel) as lower
6266 transport protocol.
6267
6268 udp_multicast
6269 Use UDP multicast as lower transport protocol.
6270
6271 http
6272 Use HTTP tunneling as lower transport protocol, which is useful
6273 for passing proxies.
6274
6275 Multiple lower transport protocols may be specified, in that case
6276 they are tried one at a time (if the setup of one fails, the next
6277 one is tried). For the muxer, only the tcp and udp options are
6278 supported.
6279
6280 rtsp_flags
6281 Set RTSP flags.
6282
6283 The following values are accepted:
6284
6285 filter_src
6286 Accept packets only from negotiated peer address and port.
6287
6288 listen
6289 Act as a server, listening for an incoming connection.
6290
6291 prefer_tcp
6292 Try TCP for RTP transport first, if TCP is available as RTSP
6293 RTP transport.
6294
6295 Default value is none.
6296
6297 allowed_media_types
6298 Set media types to accept from the server.
6299
6300 The following flags are accepted:
6301
6302 video
6303 audio
6304 data
6305
6306 By default it accepts all media types.
6307
6308 min_port
6309 Set minimum local UDP port. Default value is 5000.
6310
6311 max_port
6312 Set maximum local UDP port. Default value is 65000.
6313
6314 listen_timeout
6315 Set maximum timeout (in seconds) to establish an initial
6316 connection. Setting listen_timeout > 0 sets rtsp_flags to listen.
6317 Default is -1 which means an infinite timeout when listen mode is
6318 set.
6319
6320 reorder_queue_size
6321 Set number of packets to buffer for handling of reordered packets.
6322
6323 timeout
6324 Set socket TCP I/O timeout in microseconds.
6325
6326 user_agent
6327 Override User-Agent header. If not specified, it defaults to the
6328 libavformat identifier string.
6329
6330 When receiving data over UDP, the demuxer tries to reorder received
6331 packets (since they may arrive out of order, or packets may get lost
6332 totally). This can be disabled by setting the maximum demuxing delay to
6333 zero (via the "max_delay" field of AVFormatContext).
6334
6335 When watching multi-bitrate Real-RTSP streams with ffplay, the streams
6336 to display can be chosen with "-vst" n and "-ast" n for video and audio
6337 respectively, and can be switched on the fly by pressing "v" and "a".
6338
6339 Examples
6340
6341 The following examples all make use of the ffplay and ffmpeg tools.
6342
6343 • Watch a stream over UDP, with a max reordering delay of 0.5
6344 seconds:
6345
6346 ffplay -max_delay 500000 -rtsp_transport udp rtsp://server/video.mp4
6347
6348 • Watch a stream tunneled over HTTP:
6349
6350 ffplay -rtsp_transport http rtsp://server/video.mp4
6351
6352 • Send a stream in realtime to a RTSP server, for others to watch:
6353
6354 ffmpeg -re -i <input> -f rtsp -muxdelay 0.1 rtsp://server/live.sdp
6355
6356 • Receive a stream in realtime:
6357
6358 ffmpeg -rtsp_flags listen -i rtsp://ownaddress/live.sdp <output>
6359
6360 sap
6361 Session Announcement Protocol (RFC 2974). This is not technically a
6362 protocol handler in libavformat, it is a muxer and demuxer. It is used
6363 for signalling of RTP streams, by announcing the SDP for the streams
6364 regularly on a separate port.
6365
6366 Muxer
6367
6368 The syntax for a SAP url given to the muxer is:
6369
6370 sap://<destination>[:<port>][?<options>]
6371
6372 The RTP packets are sent to destination on port port, or to port 5004
6373 if no port is specified. options is a "&"-separated list. The
6374 following options are supported:
6375
6376 announce_addr=address
6377 Specify the destination IP address for sending the announcements
6378 to. If omitted, the announcements are sent to the commonly used
6379 SAP announcement multicast address 224.2.127.254 (sap.mcast.net),
6380 or ff0e::2:7ffe if destination is an IPv6 address.
6381
6382 announce_port=port
6383 Specify the port to send the announcements on, defaults to 9875 if
6384 not specified.
6385
6386 ttl=ttl
6387 Specify the time to live value for the announcements and RTP
6388 packets, defaults to 255.
6389
6390 same_port=0|1
6391 If set to 1, send all RTP streams on the same port pair. If zero
6392 (the default), all streams are sent on unique ports, with each
6393 stream on a port 2 numbers higher than the previous. VLC/Live555
6394 requires this to be set to 1, to be able to receive the stream.
6395 The RTP stack in libavformat for receiving requires all streams to
6396 be sent on unique ports.
6397
6398 Example command lines follow.
6399
6400 To broadcast a stream on the local subnet, for watching in VLC:
6401
6402 ffmpeg -re -i <input> -f sap sap://224.0.0.255?same_port=1
6403
6404 Similarly, for watching in ffplay:
6405
6406 ffmpeg -re -i <input> -f sap sap://224.0.0.255
6407
6408 And for watching in ffplay, over IPv6:
6409
6410 ffmpeg -re -i <input> -f sap sap://[ff0e::1:2:3:4]
6411
6412 Demuxer
6413
6414 The syntax for a SAP url given to the demuxer is:
6415
6416 sap://[<address>][:<port>]
6417
6418 address is the multicast address to listen for announcements on, if
6419 omitted, the default 224.2.127.254 (sap.mcast.net) is used. port is the
6420 port that is listened on, 9875 if omitted.
6421
6422 The demuxers listens for announcements on the given address and port.
6423 Once an announcement is received, it tries to receive that particular
6424 stream.
6425
6426 Example command lines follow.
6427
6428 To play back the first stream announced on the normal SAP multicast
6429 address:
6430
6431 ffplay sap://
6432
6433 To play back the first stream announced on one the default IPv6 SAP
6434 multicast address:
6435
6436 ffplay sap://[ff0e::2:7ffe]
6437
6438 sctp
6439 Stream Control Transmission Protocol.
6440
6441 The accepted URL syntax is:
6442
6443 sctp://<host>:<port>[?<options>]
6444
6445 The protocol accepts the following options:
6446
6447 listen
6448 If set to any value, listen for an incoming connection. Outgoing
6449 connection is done by default.
6450
6451 max_streams
6452 Set the maximum number of streams. By default no limit is set.
6453
6454 srt
6455 Haivision Secure Reliable Transport Protocol via libsrt.
6456
6457 The supported syntax for a SRT URL is:
6458
6459 srt://<hostname>:<port>[?<options>]
6460
6461 options contains a list of &-separated options of the form key=val.
6462
6463 or
6464
6465 <options> srt://<hostname>:<port>
6466
6467 options contains a list of '-key val' options.
6468
6469 This protocol accepts the following options.
6470
6471 connect_timeout=milliseconds
6472 Connection timeout; SRT cannot connect for RTT > 1500 msec (2
6473 handshake exchanges) with the default connect timeout of 3 seconds.
6474 This option applies to the caller and rendezvous connection modes.
6475 The connect timeout is 10 times the value set for the rendezvous
6476 mode (which can be used as a workaround for this connection problem
6477 with earlier versions).
6478
6479 ffs=bytes
6480 Flight Flag Size (Window Size), in bytes. FFS is actually an
6481 internal parameter and you should set it to not less than
6482 recv_buffer_size and mss. The default value is relatively large,
6483 therefore unless you set a very large receiver buffer, you do not
6484 need to change this option. Default value is 25600.
6485
6486 inputbw=bytes/seconds
6487 Sender nominal input rate, in bytes per seconds. Used along with
6488 oheadbw, when maxbw is set to relative (0), to calculate maximum
6489 sending rate when recovery packets are sent along with the main
6490 media stream: inputbw * (100 + oheadbw) / 100 if inputbw is not set
6491 while maxbw is set to relative (0), the actual input rate is
6492 evaluated inside the library. Default value is 0.
6493
6494 iptos=tos
6495 IP Type of Service. Applies to sender only. Default value is 0xB8.
6496
6497 ipttl=ttl
6498 IP Time To Live. Applies to sender only. Default value is 64.
6499
6500 latency=microseconds
6501 Timestamp-based Packet Delivery Delay. Used to absorb bursts of
6502 missed packet retransmissions. This flag sets both rcvlatency and
6503 peerlatency to the same value. Note that prior to version 1.3.0
6504 this is the only flag to set the latency, however this is
6505 effectively equivalent to setting peerlatency, when side is sender
6506 and rcvlatency when side is receiver, and the bidirectional stream
6507 sending is not supported.
6508
6509 listen_timeout=microseconds
6510 Set socket listen timeout.
6511
6512 maxbw=bytes/seconds
6513 Maximum sending bandwidth, in bytes per seconds. -1 infinite
6514 (CSRTCC limit is 30mbps) 0 relative to input rate (see inputbw) >0
6515 absolute limit value Default value is 0 (relative)
6516
6517 mode=caller|listener|rendezvous
6518 Connection mode. caller opens client connection. listener starts
6519 server to listen for incoming connections. rendezvous use Rendez-
6520 Vous connection mode. Default value is caller.
6521
6522 mss=bytes
6523 Maximum Segment Size, in bytes. Used for buffer allocation and rate
6524 calculation using a packet counter assuming fully filled packets.
6525 The smallest MSS between the peers is used. This is 1500 by default
6526 in the overall internet. This is the maximum size of the UDP
6527 packet and can be only decreased, unless you have some unusual
6528 dedicated network settings. Default value is 1500.
6529
6530 nakreport=1|0
6531 If set to 1, Receiver will send `UMSG_LOSSREPORT` messages
6532 periodically until a lost packet is retransmitted or intentionally
6533 dropped. Default value is 1.
6534
6535 oheadbw=percents
6536 Recovery bandwidth overhead above input rate, in percents. See
6537 inputbw. Default value is 25%.
6538
6539 passphrase=string
6540 HaiCrypt Encryption/Decryption Passphrase string, length from 10 to
6541 79 characters. The passphrase is the shared secret between the
6542 sender and the receiver. It is used to generate the Key Encrypting
6543 Key using PBKDF2 (Password-Based Key Derivation Function). It is
6544 used only if pbkeylen is non-zero. It is used on the receiver only
6545 if the received data is encrypted. The configured passphrase
6546 cannot be recovered (write-only).
6547
6548 enforced_encryption=1|0
6549 If true, both connection parties must have the same password set
6550 (including empty, that is, with no encryption). If the password
6551 doesn't match or only one side is unencrypted, the connection is
6552 rejected. Default is true.
6553
6554 kmrefreshrate=packets
6555 The number of packets to be transmitted after which the encryption
6556 key is switched to a new key. Default is -1. -1 means auto
6557 (0x1000000 in srt library). The range for this option is integers
6558 in the 0 - "INT_MAX".
6559
6560 kmpreannounce=packets
6561 The interval between when a new encryption key is sent and when
6562 switchover occurs. This value also applies to the subsequent
6563 interval between when switchover occurs and when the old encryption
6564 key is decommissioned. Default is -1. -1 means auto (0x1000 in srt
6565 library). The range for this option is integers in the 0 -
6566 "INT_MAX".
6567
6568 snddropdelay=microseconds
6569 The sender's extra delay before dropping packets. This delay is
6570 added to the default drop delay time interval value.
6571
6572 Special value -1: Do not drop packets on the sender at all.
6573
6574 payload_size=bytes
6575 Sets the maximum declared size of a packet transferred during the
6576 single call to the sending function in Live mode. Use 0 if this
6577 value isn't used (which is default in file mode). Default is -1
6578 (automatic), which typically means MPEG-TS; if you are going to use
6579 SRT to send any different kind of payload, such as, for example,
6580 wrapping a live stream in very small frames, then you can use a
6581 bigger maximum frame size, though not greater than 1456 bytes.
6582
6583 pkt_size=bytes
6584 Alias for payload_size.
6585
6586 peerlatency=microseconds
6587 The latency value (as described in rcvlatency) that is set by the
6588 sender side as a minimum value for the receiver.
6589
6590 pbkeylen=bytes
6591 Sender encryption key length, in bytes. Only can be set to 0, 16,
6592 24 and 32. Enable sender encryption if not 0. Not required on
6593 receiver (set to 0), key size obtained from sender in HaiCrypt
6594 handshake. Default value is 0.
6595
6596 rcvlatency=microseconds
6597 The time that should elapse since the moment when the packet was
6598 sent and the moment when it's delivered to the receiver application
6599 in the receiving function. This time should be a buffer time large
6600 enough to cover the time spent for sending, unexpectedly extended
6601 RTT time, and the time needed to retransmit the lost UDP packet.
6602 The effective latency value will be the maximum of this options'
6603 value and the value of peerlatency set by the peer side. Before
6604 version 1.3.0 this option is only available as latency.
6605
6606 recv_buffer_size=bytes
6607 Set UDP receive buffer size, expressed in bytes.
6608
6609 send_buffer_size=bytes
6610 Set UDP send buffer size, expressed in bytes.
6611
6612 timeout=microseconds
6613 Set raise error timeouts for read, write and connect operations.
6614 Note that the SRT library has internal timeouts which can be
6615 controlled separately, the value set here is only a cap on those.
6616
6617 tlpktdrop=1|0
6618 Too-late Packet Drop. When enabled on receiver, it skips missing
6619 packets that have not been delivered in time and delivers the
6620 following packets to the application when their time-to-play has
6621 come. It also sends a fake ACK to the sender. When enabled on
6622 sender and enabled on the receiving peer, the sender drops the
6623 older packets that have no chance of being delivered in time. It
6624 was automatically enabled in the sender if the receiver supports
6625 it.
6626
6627 sndbuf=bytes
6628 Set send buffer size, expressed in bytes.
6629
6630 rcvbuf=bytes
6631 Set receive buffer size, expressed in bytes.
6632
6633 Receive buffer must not be greater than ffs.
6634
6635 lossmaxttl=packets
6636 The value up to which the Reorder Tolerance may grow. When Reorder
6637 Tolerance is > 0, then packet loss report is delayed until that
6638 number of packets come in. Reorder Tolerance increases every time a
6639 "belated" packet has come, but it wasn't due to retransmission
6640 (that is, when UDP packets tend to come out of order), with the
6641 difference between the latest sequence and this packet's sequence,
6642 and not more than the value of this option. By default it's 0,
6643 which means that this mechanism is turned off, and the loss report
6644 is always sent immediately upon experiencing a "gap" in sequences.
6645
6646 minversion
6647 The minimum SRT version that is required from the peer. A
6648 connection to a peer that does not satisfy the minimum version
6649 requirement will be rejected.
6650
6651 The version format in hex is 0xXXYYZZ for x.y.z in human readable
6652 form.
6653
6654 streamid=string
6655 A string limited to 512 characters that can be set on the socket
6656 prior to connecting. This stream ID will be able to be retrieved by
6657 the listener side from the socket that is returned from srt_accept
6658 and was connected by a socket with that set stream ID. SRT does not
6659 enforce any special interpretation of the contents of this string.
6660 This option doesnXt make sense in Rendezvous connection; the result
6661 might be that simply one side will override the value from the
6662 other side and itXs the matter of luck which one would win
6663
6664 srt_streamid=string
6665 Alias for streamid to avoid conflict with ffmpeg command line
6666 option.
6667
6668 smoother=live|file
6669 The type of Smoother used for the transmission for that socket,
6670 which is responsible for the transmission and congestion control.
6671 The Smoother type must be exactly the same on both connecting
6672 parties, otherwise the connection is rejected.
6673
6674 messageapi=1|0
6675 When set, this socket uses the Message API, otherwise it uses
6676 Buffer API. Note that in live mode (see transtype) thereXs only
6677 message API available. In File mode you can chose to use one of two
6678 modes:
6679
6680 Stream API (default, when this option is false). In this mode you
6681 may send as many data as you wish with one sending instruction, or
6682 even use dedicated functions that read directly from a file. The
6683 internal facility will take care of any speed and congestion
6684 control. When receiving, you can also receive as many data as
6685 desired, the data not extracted will be waiting for the next call.
6686 There is no boundary between data portions in the Stream mode.
6687
6688 Message API. In this mode your single sending instruction passes
6689 exactly one piece of data that has boundaries (a message). Contrary
6690 to Live mode, this message may span across multiple UDP packets and
6691 the only size limitation is that it shall fit as a whole in the
6692 sending buffer. The receiver shall use as large buffer as necessary
6693 to receive the message, otherwise the message will not be given up.
6694 When the message is not complete (not all packets received or there
6695 was a packet loss) it will not be given up.
6696
6697 transtype=live|file
6698 Sets the transmission type for the socket, in particular, setting
6699 this option sets multiple other parameters to their default values
6700 as required for a particular transmission type.
6701
6702 live: Set options as for live transmission. In this mode, you
6703 should send by one sending instruction only so many data that fit
6704 in one UDP packet, and limited to the value defined first in
6705 payload_size (1316 is default in this mode). There is no speed
6706 control in this mode, only the bandwidth control, if configured, in
6707 order to not exceed the bandwidth with the overhead transmission
6708 (retransmitted and control packets).
6709
6710 file: Set options as for non-live transmission. See messageapi for
6711 further explanations
6712
6713 linger=seconds
6714 The number of seconds that the socket waits for unsent data when
6715 closing. Default is -1. -1 means auto (off with 0 seconds in live
6716 mode, on with 180 seconds in file mode). The range for this option
6717 is integers in the 0 - "INT_MAX".
6718
6719 tsbpd=1|0
6720 When true, use Timestamp-based Packet Delivery mode. The default
6721 behavior depends on the transmission type: enabled in live mode,
6722 disabled in file mode.
6723
6724 For more information see: <https://github.com/Haivision/srt>.
6725
6726 srtp
6727 Secure Real-time Transport Protocol.
6728
6729 The accepted options are:
6730
6731 srtp_in_suite
6732 srtp_out_suite
6733 Select input and output encoding suites.
6734
6735 Supported values:
6736
6737 AES_CM_128_HMAC_SHA1_80
6738 SRTP_AES128_CM_HMAC_SHA1_80
6739 AES_CM_128_HMAC_SHA1_32
6740 SRTP_AES128_CM_HMAC_SHA1_32
6741 srtp_in_params
6742 srtp_out_params
6743 Set input and output encoding parameters, which are expressed by a
6744 base64-encoded representation of a binary block. The first 16 bytes
6745 of this binary block are used as master key, the following 14 bytes
6746 are used as master salt.
6747
6748 subfile
6749 Virtually extract a segment of a file or another stream. The
6750 underlying stream must be seekable.
6751
6752 Accepted options:
6753
6754 start
6755 Start offset of the extracted segment, in bytes.
6756
6757 end End offset of the extracted segment, in bytes. If set to 0,
6758 extract till end of file.
6759
6760 Examples:
6761
6762 Extract a chapter from a DVD VOB file (start and end sectors obtained
6763 externally and multiplied by 2048):
6764
6765 subfile,,start,153391104,end,268142592,,:/media/dvd/VIDEO_TS/VTS_08_1.VOB
6766
6767 Play an AVI file directly from a TAR archive:
6768
6769 subfile,,start,183241728,end,366490624,,:archive.tar
6770
6771 Play a MPEG-TS file from start offset till end:
6772
6773 subfile,,start,32815239,end,0,,:video.ts
6774
6775 tee
6776 Writes the output to multiple protocols. The individual outputs are
6777 separated by |
6778
6779 tee:file://path/to/local/this.avi|file://path/to/local/that.avi
6780
6781 tcp
6782 Transmission Control Protocol.
6783
6784 The required syntax for a TCP url is:
6785
6786 tcp://<hostname>:<port>[?<options>]
6787
6788 options contains a list of &-separated options of the form key=val.
6789
6790 The list of supported options follows.
6791
6792 listen=2|1|0
6793 Listen for an incoming connection. 0 disables listen, 1 enables
6794 listen in single client mode, 2 enables listen in multi-client
6795 mode. Default value is 0.
6796
6797 timeout=microseconds
6798 Set raise error timeout, expressed in microseconds.
6799
6800 This option is only relevant in read mode: if no data arrived in
6801 more than this time interval, raise error.
6802
6803 listen_timeout=milliseconds
6804 Set listen timeout, expressed in milliseconds.
6805
6806 recv_buffer_size=bytes
6807 Set receive buffer size, expressed bytes.
6808
6809 send_buffer_size=bytes
6810 Set send buffer size, expressed bytes.
6811
6812 tcp_nodelay=1|0
6813 Set TCP_NODELAY to disable Nagle's algorithm. Default value is 0.
6814
6815 Remark: Writing to the socket is currently not optimized to
6816 minimize system calls and reduces the efficiency / effect of
6817 TCP_NODELAY.
6818
6819 tcp_mss=bytes
6820 Set maximum segment size for outgoing TCP packets, expressed in
6821 bytes.
6822
6823 The following example shows how to setup a listening TCP connection
6824 with ffmpeg, which is then accessed with ffplay:
6825
6826 ffmpeg -i <input> -f <format> tcp://<hostname>:<port>?listen
6827 ffplay tcp://<hostname>:<port>
6828
6829 tls
6830 Transport Layer Security (TLS) / Secure Sockets Layer (SSL)
6831
6832 The required syntax for a TLS/SSL url is:
6833
6834 tls://<hostname>:<port>[?<options>]
6835
6836 The following parameters can be set via command line options (or in
6837 code via "AVOption"s):
6838
6839 ca_file, cafile=filename
6840 A file containing certificate authority (CA) root certificates to
6841 treat as trusted. If the linked TLS library contains a default this
6842 might not need to be specified for verification to work, but not
6843 all libraries and setups have defaults built in. The file must be
6844 in OpenSSL PEM format.
6845
6846 tls_verify=1|0
6847 If enabled, try to verify the peer that we are communicating with.
6848 Note, if using OpenSSL, this currently only makes sure that the
6849 peer certificate is signed by one of the root certificates in the
6850 CA database, but it does not validate that the certificate actually
6851 matches the host name we are trying to connect to. (With other
6852 backends, the host name is validated as well.)
6853
6854 This is disabled by default since it requires a CA database to be
6855 provided by the caller in many cases.
6856
6857 cert_file, cert=filename
6858 A file containing a certificate to use in the handshake with the
6859 peer. (When operating as server, in listen mode, this is more
6860 often required by the peer, while client certificates only are
6861 mandated in certain setups.)
6862
6863 key_file, key=filename
6864 A file containing the private key for the certificate.
6865
6866 listen=1|0
6867 If enabled, listen for connections on the provided port, and assume
6868 the server role in the handshake instead of the client role.
6869
6870 http_proxy
6871 The HTTP proxy to tunnel through, e.g. "http://example.com:1234".
6872 The proxy must support the CONNECT method.
6873
6874 Example command lines:
6875
6876 To create a TLS/SSL server that serves an input stream.
6877
6878 ffmpeg -i <input> -f <format> tls://<hostname>:<port>?listen&cert=<server.crt>&key=<server.key>
6879
6880 To play back a stream from the TLS/SSL server using ffplay:
6881
6882 ffplay tls://<hostname>:<port>
6883
6884 udp
6885 User Datagram Protocol.
6886
6887 The required syntax for an UDP URL is:
6888
6889 udp://<hostname>:<port>[?<options>]
6890
6891 options contains a list of &-separated options of the form key=val.
6892
6893 In case threading is enabled on the system, a circular buffer is used
6894 to store the incoming data, which allows one to reduce loss of data due
6895 to UDP socket buffer overruns. The fifo_size and overrun_nonfatal
6896 options are related to this buffer.
6897
6898 The list of supported options follows.
6899
6900 buffer_size=size
6901 Set the UDP maximum socket buffer size in bytes. This is used to
6902 set either the receive or send buffer size, depending on what the
6903 socket is used for. Default is 32 KB for output, 384 KB for input.
6904 See also fifo_size.
6905
6906 bitrate=bitrate
6907 If set to nonzero, the output will have the specified constant
6908 bitrate if the input has enough packets to sustain it.
6909
6910 burst_bits=bits
6911 When using bitrate this specifies the maximum number of bits in
6912 packet bursts.
6913
6914 localport=port
6915 Override the local UDP port to bind with.
6916
6917 localaddr=addr
6918 Local IP address of a network interface used for sending packets or
6919 joining multicast groups.
6920
6921 pkt_size=size
6922 Set the size in bytes of UDP packets.
6923
6924 reuse=1|0
6925 Explicitly allow or disallow reusing UDP sockets.
6926
6927 ttl=ttl
6928 Set the time to live value (for multicast only).
6929
6930 connect=1|0
6931 Initialize the UDP socket with "connect()". In this case, the
6932 destination address can't be changed with ff_udp_set_remote_url
6933 later. If the destination address isn't known at the start, this
6934 option can be specified in ff_udp_set_remote_url, too. This allows
6935 finding out the source address for the packets with getsockname,
6936 and makes writes return with AVERROR(ECONNREFUSED) if "destination
6937 unreachable" is received. For receiving, this gives the benefit of
6938 only receiving packets from the specified peer address/port.
6939
6940 sources=address[,address]
6941 Only receive packets sent from the specified addresses. In case of
6942 multicast, also subscribe to multicast traffic coming from these
6943 addresses only.
6944
6945 block=address[,address]
6946 Ignore packets sent from the specified addresses. In case of
6947 multicast, also exclude the source addresses in the multicast
6948 subscription.
6949
6950 fifo_size=units
6951 Set the UDP receiving circular buffer size, expressed as a number
6952 of packets with size of 188 bytes. If not specified defaults to
6953 7*4096.
6954
6955 overrun_nonfatal=1|0
6956 Survive in case of UDP receiving circular buffer overrun. Default
6957 value is 0.
6958
6959 timeout=microseconds
6960 Set raise error timeout, expressed in microseconds.
6961
6962 This option is only relevant in read mode: if no data arrived in
6963 more than this time interval, raise error.
6964
6965 broadcast=1|0
6966 Explicitly allow or disallow UDP broadcasting.
6967
6968 Note that broadcasting may not work properly on networks having a
6969 broadcast storm protection.
6970
6971 Examples
6972
6973 • Use ffmpeg to stream over UDP to a remote endpoint:
6974
6975 ffmpeg -i <input> -f <format> udp://<hostname>:<port>
6976
6977 • Use ffmpeg to stream in mpegts format over UDP using 188 sized UDP
6978 packets, using a large input buffer:
6979
6980 ffmpeg -i <input> -f mpegts udp://<hostname>:<port>?pkt_size=188&buffer_size=65535
6981
6982 • Use ffmpeg to receive over UDP from a remote endpoint:
6983
6984 ffmpeg -i udp://[<multicast-address>]:<port> ...
6985
6986 unix
6987 Unix local socket
6988
6989 The required syntax for a Unix socket URL is:
6990
6991 unix://<filepath>
6992
6993 The following parameters can be set via command line options (or in
6994 code via "AVOption"s):
6995
6996 timeout
6997 Timeout in ms.
6998
6999 listen
7000 Create the Unix socket in listening mode.
7001
7002 zmq
7003 ZeroMQ asynchronous messaging using the libzmq library.
7004
7005 This library supports unicast streaming to multiple clients without
7006 relying on an external server.
7007
7008 The required syntax for streaming or connecting to a stream is:
7009
7010 zmq:tcp://ip-address:port
7011
7012 Example: Create a localhost stream on port 5555:
7013
7014 ffmpeg -re -i input -f mpegts zmq:tcp://127.0.0.1:5555
7015
7016 Multiple clients may connect to the stream using:
7017
7018 ffplay zmq:tcp://127.0.0.1:5555
7019
7020 Streaming to multiple clients is implemented using a ZeroMQ Pub-Sub
7021 pattern. The server side binds to a port and publishes data. Clients
7022 connect to the server (via IP address/port) and subscribe to the
7023 stream. The order in which the server and client start generally does
7024 not matter.
7025
7026 ffmpeg must be compiled with the --enable-libzmq option to support this
7027 protocol.
7028
7029 Options can be set on the ffmpeg/ffplay command line. The following
7030 options are supported:
7031
7032 pkt_size
7033 Forces the maximum packet size for sending/receiving data. The
7034 default value is 131,072 bytes. On the server side, this sets the
7035 maximum size of sent packets via ZeroMQ. On the clients, it sets an
7036 internal buffer size for receiving packets. Note that pkt_size on
7037 the clients should be equal to or greater than pkt_size on the
7038 server. Otherwise the received message may be truncated causing
7039 decoding errors.
7040
7042 The libavdevice library provides the same interface as libavformat.
7043 Namely, an input device is considered like a demuxer, and an output
7044 device like a muxer, and the interface and generic device options are
7045 the same provided by libavformat (see the ffmpeg-formats manual).
7046
7047 In addition each input or output device may support so-called private
7048 options, which are specific for that component.
7049
7050 Options may be set by specifying -option value in the FFmpeg tools, or
7051 by setting the value explicitly in the device "AVFormatContext" options
7052 or using the libavutil/opt.h API for programmatic use.
7053
7055 Input devices are configured elements in FFmpeg which enable accessing
7056 the data coming from a multimedia device attached to your system.
7057
7058 When you configure your FFmpeg build, all the supported input devices
7059 are enabled by default. You can list all available ones using the
7060 configure option "--list-indevs".
7061
7062 You can disable all the input devices using the configure option
7063 "--disable-indevs", and selectively enable an input device using the
7064 option "--enable-indev=INDEV", or you can disable a particular input
7065 device using the option "--disable-indev=INDEV".
7066
7067 The option "-devices" of the ff* tools will display the list of
7068 supported input devices.
7069
7070 A description of the currently available input devices follows.
7071
7072 alsa
7073 ALSA (Advanced Linux Sound Architecture) input device.
7074
7075 To enable this input device during configuration you need libasound
7076 installed on your system.
7077
7078 This device allows capturing from an ALSA device. The name of the
7079 device to capture has to be an ALSA card identifier.
7080
7081 An ALSA identifier has the syntax:
7082
7083 hw:<CARD>[,<DEV>[,<SUBDEV>]]
7084
7085 where the DEV and SUBDEV components are optional.
7086
7087 The three arguments (in order: CARD,DEV,SUBDEV) specify card number or
7088 identifier, device number and subdevice number (-1 means any).
7089
7090 To see the list of cards currently recognized by your system check the
7091 files /proc/asound/cards and /proc/asound/devices.
7092
7093 For example to capture with ffmpeg from an ALSA device with card id 0,
7094 you may run the command:
7095
7096 ffmpeg -f alsa -i hw:0 alsaout.wav
7097
7098 For more information see:
7099 <http://www.alsa-project.org/alsa-doc/alsa-lib/pcm.html>
7100
7101 Options
7102
7103 sample_rate
7104 Set the sample rate in Hz. Default is 48000.
7105
7106 channels
7107 Set the number of channels. Default is 2.
7108
7109 android_camera
7110 Android camera input device.
7111
7112 This input devices uses the Android Camera2 NDK API which is available
7113 on devices with API level 24+. The availability of android_camera is
7114 autodetected during configuration.
7115
7116 This device allows capturing from all cameras on an Android device,
7117 which are integrated into the Camera2 NDK API.
7118
7119 The available cameras are enumerated internally and can be selected
7120 with the camera_index parameter. The input file string is discarded.
7121
7122 Generally the back facing camera has index 0 while the front facing
7123 camera has index 1.
7124
7125 Options
7126
7127 video_size
7128 Set the video size given as a string such as 640x480 or hd720.
7129 Falls back to the first available configuration reported by Android
7130 if requested video size is not available or by default.
7131
7132 framerate
7133 Set the video framerate. Falls back to the first available
7134 configuration reported by Android if requested framerate is not
7135 available or by default (-1).
7136
7137 camera_index
7138 Set the index of the camera to use. Default is 0.
7139
7140 input_queue_size
7141 Set the maximum number of frames to buffer. Default is 5.
7142
7143 avfoundation
7144 AVFoundation input device.
7145
7146 AVFoundation is the currently recommended framework by Apple for
7147 streamgrabbing on OSX >= 10.7 as well as on iOS.
7148
7149 The input filename has to be given in the following syntax:
7150
7151 -i "[[VIDEO]:[AUDIO]]"
7152
7153 The first entry selects the video input while the latter selects the
7154 audio input. The stream has to be specified by the device name or the
7155 device index as shown by the device list. Alternatively, the video
7156 and/or audio input device can be chosen by index using the
7157
7158 B<-video_device_index E<lt>INDEXE<gt>>
7159
7160 and/or
7161
7162 B<-audio_device_index E<lt>INDEXE<gt>>
7163
7164 , overriding any device name or index given in the input filename.
7165
7166 All available devices can be enumerated by using -list_devices true,
7167 listing all device names and corresponding indices.
7168
7169 There are two device name aliases:
7170
7171 "default"
7172 Select the AVFoundation default device of the corresponding type.
7173
7174 "none"
7175 Do not record the corresponding media type. This is equivalent to
7176 specifying an empty device name or index.
7177
7178 Options
7179
7180 AVFoundation supports the following options:
7181
7182 -list_devices <TRUE|FALSE>
7183 If set to true, a list of all available input devices is given
7184 showing all device names and indices.
7185
7186 -video_device_index <INDEX>
7187 Specify the video device by its index. Overrides anything given in
7188 the input filename.
7189
7190 -audio_device_index <INDEX>
7191 Specify the audio device by its index. Overrides anything given in
7192 the input filename.
7193
7194 -pixel_format <FORMAT>
7195 Request the video device to use a specific pixel format. If the
7196 specified format is not supported, a list of available formats is
7197 given and the first one in this list is used instead. Available
7198 pixel formats are: "monob, rgb555be, rgb555le, rgb565be, rgb565le,
7199 rgb24, bgr24, 0rgb, bgr0, 0bgr, rgb0,
7200 bgr48be, uyvy422, yuva444p, yuva444p16le, yuv444p, yuv422p16,
7201 yuv422p10, yuv444p10,
7202 yuv420p, nv12, yuyv422, gray"
7203
7204 -framerate
7205 Set the grabbing frame rate. Default is "ntsc", corresponding to a
7206 frame rate of "30000/1001".
7207
7208 -video_size
7209 Set the video frame size.
7210
7211 -capture_cursor
7212 Capture the mouse pointer. Default is 0.
7213
7214 -capture_mouse_clicks
7215 Capture the screen mouse clicks. Default is 0.
7216
7217 -capture_raw_data
7218 Capture the raw device data. Default is 0. Using this option may
7219 result in receiving the underlying data delivered to the
7220 AVFoundation framework. E.g. for muxed devices that sends raw DV
7221 data to the framework (like tape-based camcorders), setting this
7222 option to false results in extracted video frames captured in the
7223 designated pixel format only. Setting this option to true results
7224 in receiving the raw DV stream untouched.
7225
7226 Examples
7227
7228 • Print the list of AVFoundation supported devices and exit:
7229
7230 $ ffmpeg -f avfoundation -list_devices true -i ""
7231
7232 • Record video from video device 0 and audio from audio device 0 into
7233 out.avi:
7234
7235 $ ffmpeg -f avfoundation -i "0:0" out.avi
7236
7237 • Record video from video device 2 and audio from audio device 1 into
7238 out.avi:
7239
7240 $ ffmpeg -f avfoundation -video_device_index 2 -i ":1" out.avi
7241
7242 • Record video from the system default video device using the pixel
7243 format bgr0 and do not record any audio into out.avi:
7244
7245 $ ffmpeg -f avfoundation -pixel_format bgr0 -i "default:none" out.avi
7246
7247 • Record raw DV data from a suitable input device and write the
7248 output into out.dv:
7249
7250 $ ffmpeg -f avfoundation -capture_raw_data true -i "zr100:none" out.dv
7251
7252 bktr
7253 BSD video input device.
7254
7255 Options
7256
7257 framerate
7258 Set the frame rate.
7259
7260 video_size
7261 Set the video frame size. Default is "vga".
7262
7263 standard
7264 Available values are:
7265
7266 pal
7267 ntsc
7268 secam
7269 paln
7270 palm
7271 ntscj
7272
7273 decklink
7274 The decklink input device provides capture capabilities for Blackmagic
7275 DeckLink devices.
7276
7277 To enable this input device, you need the Blackmagic DeckLink SDK and
7278 you need to configure with the appropriate "--extra-cflags" and
7279 "--extra-ldflags". On Windows, you need to run the IDL files through
7280 widl.
7281
7282 DeckLink is very picky about the formats it supports. Pixel format of
7283 the input can be set with raw_format. Framerate and video size must be
7284 determined for your device with -list_formats 1. Audio sample rate is
7285 always 48 kHz and the number of channels can be 2, 8 or 16. Note that
7286 all audio channels are bundled in one single audio track.
7287
7288 Options
7289
7290 list_devices
7291 If set to true, print a list of devices and exit. Defaults to
7292 false. This option is deprecated, please use the "-sources" option
7293 of ffmpeg to list the available input devices.
7294
7295 list_formats
7296 If set to true, print a list of supported formats and exit.
7297 Defaults to false.
7298
7299 format_code <FourCC>
7300 This sets the input video format to the format given by the FourCC.
7301 To see the supported values of your device(s) use list_formats.
7302 Note that there is a FourCC 'pal ' that can also be used as pal (3
7303 letters). Default behavior is autodetection of the input video
7304 format, if the hardware supports it.
7305
7306 raw_format
7307 Set the pixel format of the captured video. Available values are:
7308
7309 auto
7310 This is the default which means 8-bit YUV 422 or 8-bit ARGB if
7311 format autodetection is used, 8-bit YUV 422 otherwise.
7312
7313 uyvy422
7314 8-bit YUV 422.
7315
7316 yuv422p10
7317 10-bit YUV 422.
7318
7319 argb
7320 8-bit RGB.
7321
7322 bgra
7323 8-bit RGB.
7324
7325 rgb10
7326 10-bit RGB.
7327
7328 teletext_lines
7329 If set to nonzero, an additional teletext stream will be captured
7330 from the vertical ancillary data. Both SD PAL (576i) and HD (1080i
7331 or 1080p) sources are supported. In case of HD sources, OP47
7332 packets are decoded.
7333
7334 This option is a bitmask of the SD PAL VBI lines captured,
7335 specifically lines 6 to 22, and lines 318 to 335. Line 6 is the LSB
7336 in the mask. Selected lines which do not contain teletext
7337 information will be ignored. You can use the special all constant
7338 to select all possible lines, or standard to skip lines 6, 318 and
7339 319, which are not compatible with all receivers.
7340
7341 For SD sources, ffmpeg needs to be compiled with
7342 "--enable-libzvbi". For HD sources, on older (pre-4K) DeckLink card
7343 models you have to capture in 10 bit mode.
7344
7345 channels
7346 Defines number of audio channels to capture. Must be 2, 8 or 16.
7347 Defaults to 2.
7348
7349 duplex_mode
7350 Sets the decklink device duplex/profile mode. Must be unset, half,
7351 full, one_sub_device_full, one_sub_device_half,
7352 two_sub_device_full, four_sub_device_half Defaults to unset.
7353
7354 Note: DeckLink SDK 11.0 have replaced the duplex property by a
7355 profile property. For the DeckLink Duo 2 and DeckLink Quad 2, a
7356 profile is shared between any 2 sub-devices that utilize the same
7357 connectors. For the DeckLink 8K Pro, a profile is shared between
7358 all 4 sub-devices. So DeckLink 8K Pro support four profiles.
7359
7360 Valid profile modes for DeckLink 8K Pro(with DeckLink SDK >= 11.0):
7361 one_sub_device_full, one_sub_device_half, two_sub_device_full,
7362 four_sub_device_half
7363
7364 Valid profile modes for DeckLink Quad 2 and DeckLink Duo 2: half,
7365 full
7366
7367 timecode_format
7368 Timecode type to include in the frame and video stream metadata.
7369 Must be none, rp188vitc, rp188vitc2, rp188ltc, rp188hfr, rp188any,
7370 vitc, vitc2, or serial. Defaults to none (not included).
7371
7372 In order to properly support 50/60 fps timecodes, the ordering of
7373 the queried timecode types for rp188any is HFR, VITC1, VITC2 and
7374 LTC for >30 fps content. Note that this is slightly different to
7375 the ordering used by the DeckLink API, which is HFR, VITC1, LTC,
7376 VITC2.
7377
7378 video_input
7379 Sets the video input source. Must be unset, sdi, hdmi, optical_sdi,
7380 component, composite or s_video. Defaults to unset.
7381
7382 audio_input
7383 Sets the audio input source. Must be unset, embedded, aes_ebu,
7384 analog, analog_xlr, analog_rca or microphone. Defaults to unset.
7385
7386 video_pts
7387 Sets the video packet timestamp source. Must be video, audio,
7388 reference, wallclock or abs_wallclock. Defaults to video.
7389
7390 audio_pts
7391 Sets the audio packet timestamp source. Must be video, audio,
7392 reference, wallclock or abs_wallclock. Defaults to audio.
7393
7394 draw_bars
7395 If set to true, color bars are drawn in the event of a signal loss.
7396 Defaults to true.
7397
7398 queue_size
7399 Sets maximum input buffer size in bytes. If the buffering reaches
7400 this value, incoming frames will be dropped. Defaults to
7401 1073741824.
7402
7403 audio_depth
7404 Sets the audio sample bit depth. Must be 16 or 32. Defaults to 16.
7405
7406 decklink_copyts
7407 If set to true, timestamps are forwarded as they are without
7408 removing the initial offset. Defaults to false.
7409
7410 timestamp_align
7411 Capture start time alignment in seconds. If set to nonzero, input
7412 frames are dropped till the system timestamp aligns with configured
7413 value. Alignment difference of up to one frame duration is
7414 tolerated. This is useful for maintaining input synchronization
7415 across N different hardware devices deployed for 'N-way'
7416 redundancy. The system time of different hardware devices should be
7417 synchronized with protocols such as NTP or PTP, before using this
7418 option. Note that this method is not foolproof. In some border
7419 cases input synchronization may not happen due to thread scheduling
7420 jitters in the OS. Either sync could go wrong by 1 frame or in a
7421 rarer case timestamp_align seconds. Defaults to 0.
7422
7423 wait_for_tc (bool)
7424 Drop frames till a frame with timecode is received. Sometimes
7425 serial timecode isn't received with the first input frame. If that
7426 happens, the stored stream timecode will be inaccurate. If this
7427 option is set to true, input frames are dropped till a frame with
7428 timecode is received. Option timecode_format must be specified.
7429 Defaults to false.
7430
7431 enable_klv(bool)
7432 If set to true, extracts KLV data from VANC and outputs KLV
7433 packets. KLV VANC packets are joined based on MID and PSC fields
7434 and aggregated into one KLV packet. Defaults to false.
7435
7436 Examples
7437
7438 • List input devices:
7439
7440 ffmpeg -sources decklink
7441
7442 • List supported formats:
7443
7444 ffmpeg -f decklink -list_formats 1 -i 'Intensity Pro'
7445
7446 • Capture video clip at 1080i50:
7447
7448 ffmpeg -format_code Hi50 -f decklink -i 'Intensity Pro' -c:a copy -c:v copy output.avi
7449
7450 • Capture video clip at 1080i50 10 bit:
7451
7452 ffmpeg -raw_format yuv422p10 -format_code Hi50 -f decklink -i 'UltraStudio Mini Recorder' -c:a copy -c:v copy output.avi
7453
7454 • Capture video clip at 1080i50 with 16 audio channels:
7455
7456 ffmpeg -channels 16 -format_code Hi50 -f decklink -i 'UltraStudio Mini Recorder' -c:a copy -c:v copy output.avi
7457
7458 dshow
7459 Windows DirectShow input device.
7460
7461 DirectShow support is enabled when FFmpeg is built with the mingw-w64
7462 project. Currently only audio and video devices are supported.
7463
7464 Multiple devices may be opened as separate inputs, but they may also be
7465 opened on the same input, which should improve synchronism between
7466 them.
7467
7468 The input name should be in the format:
7469
7470 <TYPE>=<NAME>[:<TYPE>=<NAME>]
7471
7472 where TYPE can be either audio or video, and NAME is the device's name
7473 or alternative name..
7474
7475 Options
7476
7477 If no options are specified, the device's defaults are used. If the
7478 device does not support the requested options, it will fail to open.
7479
7480 video_size
7481 Set the video size in the captured video.
7482
7483 framerate
7484 Set the frame rate in the captured video.
7485
7486 sample_rate
7487 Set the sample rate (in Hz) of the captured audio.
7488
7489 sample_size
7490 Set the sample size (in bits) of the captured audio.
7491
7492 channels
7493 Set the number of channels in the captured audio.
7494
7495 list_devices
7496 If set to true, print a list of devices and exit.
7497
7498 list_options
7499 If set to true, print a list of selected device's options and exit.
7500
7501 video_device_number
7502 Set video device number for devices with the same name (starts at
7503 0, defaults to 0).
7504
7505 audio_device_number
7506 Set audio device number for devices with the same name (starts at
7507 0, defaults to 0).
7508
7509 pixel_format
7510 Select pixel format to be used by DirectShow. This may only be set
7511 when the video codec is not set or set to rawvideo.
7512
7513 audio_buffer_size
7514 Set audio device buffer size in milliseconds (which can directly
7515 impact latency, depending on the device). Defaults to using the
7516 audio device's default buffer size (typically some multiple of
7517 500ms). Setting this value too low can degrade performance. See
7518 also
7519 <http://msdn.microsoft.com/en-us/library/windows/desktop/dd377582(v=vs.85).aspx>
7520
7521 video_pin_name
7522 Select video capture pin to use by name or alternative name.
7523
7524 audio_pin_name
7525 Select audio capture pin to use by name or alternative name.
7526
7527 crossbar_video_input_pin_number
7528 Select video input pin number for crossbar device. This will be
7529 routed to the crossbar device's Video Decoder output pin. Note
7530 that changing this value can affect future invocations (sets a new
7531 default) until system reboot occurs.
7532
7533 crossbar_audio_input_pin_number
7534 Select audio input pin number for crossbar device. This will be
7535 routed to the crossbar device's Audio Decoder output pin. Note
7536 that changing this value can affect future invocations (sets a new
7537 default) until system reboot occurs.
7538
7539 show_video_device_dialog
7540 If set to true, before capture starts, popup a display dialog to
7541 the end user, allowing them to change video filter properties and
7542 configurations manually. Note that for crossbar devices, adjusting
7543 values in this dialog may be needed at times to toggle between PAL
7544 (25 fps) and NTSC (29.97) input frame rates, sizes, interlacing,
7545 etc. Changing these values can enable different scan rates/frame
7546 rates and avoiding green bars at the bottom, flickering scan lines,
7547 etc. Note that with some devices, changing these properties can
7548 also affect future invocations (sets new defaults) until system
7549 reboot occurs.
7550
7551 show_audio_device_dialog
7552 If set to true, before capture starts, popup a display dialog to
7553 the end user, allowing them to change audio filter properties and
7554 configurations manually.
7555
7556 show_video_crossbar_connection_dialog
7557 If set to true, before capture starts, popup a display dialog to
7558 the end user, allowing them to manually modify crossbar pin
7559 routings, when it opens a video device.
7560
7561 show_audio_crossbar_connection_dialog
7562 If set to true, before capture starts, popup a display dialog to
7563 the end user, allowing them to manually modify crossbar pin
7564 routings, when it opens an audio device.
7565
7566 show_analog_tv_tuner_dialog
7567 If set to true, before capture starts, popup a display dialog to
7568 the end user, allowing them to manually modify TV channels and
7569 frequencies.
7570
7571 show_analog_tv_tuner_audio_dialog
7572 If set to true, before capture starts, popup a display dialog to
7573 the end user, allowing them to manually modify TV audio (like mono
7574 vs. stereo, Language A,B or C).
7575
7576 audio_device_load
7577 Load an audio capture filter device from file instead of searching
7578 it by name. It may load additional parameters too, if the filter
7579 supports the serialization of its properties to. To use this an
7580 audio capture source has to be specified, but it can be anything
7581 even fake one.
7582
7583 audio_device_save
7584 Save the currently used audio capture filter device and its
7585 parameters (if the filter supports it) to a file. If a file with
7586 the same name exists it will be overwritten.
7587
7588 video_device_load
7589 Load a video capture filter device from file instead of searching
7590 it by name. It may load additional parameters too, if the filter
7591 supports the serialization of its properties to. To use this a
7592 video capture source has to be specified, but it can be anything
7593 even fake one.
7594
7595 video_device_save
7596 Save the currently used video capture filter device and its
7597 parameters (if the filter supports it) to a file. If a file with
7598 the same name exists it will be overwritten.
7599
7600 use_video_device_timestamps
7601 If set to false, the timestamp for video frames will be derived
7602 from the wallclock instead of the timestamp provided by the capture
7603 device. This allows working around devices that provide unreliable
7604 timestamps.
7605
7606 Examples
7607
7608 • Print the list of DirectShow supported devices and exit:
7609
7610 $ ffmpeg -list_devices true -f dshow -i dummy
7611
7612 • Open video device Camera:
7613
7614 $ ffmpeg -f dshow -i video="Camera"
7615
7616 • Open second video device with name Camera:
7617
7618 $ ffmpeg -f dshow -video_device_number 1 -i video="Camera"
7619
7620 • Open video device Camera and audio device Microphone:
7621
7622 $ ffmpeg -f dshow -i video="Camera":audio="Microphone"
7623
7624 • Print the list of supported options in selected device and exit:
7625
7626 $ ffmpeg -list_options true -f dshow -i video="Camera"
7627
7628 • Specify pin names to capture by name or alternative name, specify
7629 alternative device name:
7630
7631 $ ffmpeg -f dshow -audio_pin_name "Audio Out" -video_pin_name 2 -i video=video="@device_pnp_\\?\pci#ven_1a0a&dev_6200&subsys_62021461&rev_01#4&e2c7dd6&0&00e1#{65e8773d-8f56-11d0-a3b9-00a0c9223196}\{ca465100-deb0-4d59-818f-8c477184adf6}":audio="Microphone"
7632
7633 • Configure a crossbar device, specifying crossbar pins, allow user
7634 to adjust video capture properties at startup:
7635
7636 $ ffmpeg -f dshow -show_video_device_dialog true -crossbar_video_input_pin_number 0
7637 -crossbar_audio_input_pin_number 3 -i video="AVerMedia BDA Analog Capture":audio="AVerMedia BDA Analog Capture"
7638
7639 fbdev
7640 Linux framebuffer input device.
7641
7642 The Linux framebuffer is a graphic hardware-independent abstraction
7643 layer to show graphics on a computer monitor, typically on the console.
7644 It is accessed through a file device node, usually /dev/fb0.
7645
7646 For more detailed information read the file
7647 Documentation/fb/framebuffer.txt included in the Linux source tree.
7648
7649 See also <http://linux-fbdev.sourceforge.net/>, and fbset(1).
7650
7651 To record from the framebuffer device /dev/fb0 with ffmpeg:
7652
7653 ffmpeg -f fbdev -framerate 10 -i /dev/fb0 out.avi
7654
7655 You can take a single screenshot image with the command:
7656
7657 ffmpeg -f fbdev -framerate 1 -i /dev/fb0 -frames:v 1 screenshot.jpeg
7658
7659 Options
7660
7661 framerate
7662 Set the frame rate. Default is 25.
7663
7664 gdigrab
7665 Win32 GDI-based screen capture device.
7666
7667 This device allows you to capture a region of the display on Windows.
7668
7669 There are two options for the input filename:
7670
7671 desktop
7672
7673 or
7674
7675 title=<window_title>
7676
7677 The first option will capture the entire desktop, or a fixed region of
7678 the desktop. The second option will instead capture the contents of a
7679 single window, regardless of its position on the screen.
7680
7681 For example, to grab the entire desktop using ffmpeg:
7682
7683 ffmpeg -f gdigrab -framerate 6 -i desktop out.mpg
7684
7685 Grab a 640x480 region at position "10,20":
7686
7687 ffmpeg -f gdigrab -framerate 6 -offset_x 10 -offset_y 20 -video_size vga -i desktop out.mpg
7688
7689 Grab the contents of the window named "Calculator"
7690
7691 ffmpeg -f gdigrab -framerate 6 -i title=Calculator out.mpg
7692
7693 Options
7694
7695 draw_mouse
7696 Specify whether to draw the mouse pointer. Use the value 0 to not
7697 draw the pointer. Default value is 1.
7698
7699 framerate
7700 Set the grabbing frame rate. Default value is "ntsc", corresponding
7701 to a frame rate of "30000/1001".
7702
7703 show_region
7704 Show grabbed region on screen.
7705
7706 If show_region is specified with 1, then the grabbing region will
7707 be indicated on screen. With this option, it is easy to know what
7708 is being grabbed if only a portion of the screen is grabbed.
7709
7710 Note that show_region is incompatible with grabbing the contents of
7711 a single window.
7712
7713 For example:
7714
7715 ffmpeg -f gdigrab -show_region 1 -framerate 6 -video_size cif -offset_x 10 -offset_y 20 -i desktop out.mpg
7716
7717 video_size
7718 Set the video frame size. The default is to capture the full screen
7719 if desktop is selected, or the full window size if
7720 title=window_title is selected.
7721
7722 offset_x
7723 When capturing a region with video_size, set the distance from the
7724 left edge of the screen or desktop.
7725
7726 Note that the offset calculation is from the top left corner of the
7727 primary monitor on Windows. If you have a monitor positioned to the
7728 left of your primary monitor, you will need to use a negative
7729 offset_x value to move the region to that monitor.
7730
7731 offset_y
7732 When capturing a region with video_size, set the distance from the
7733 top edge of the screen or desktop.
7734
7735 Note that the offset calculation is from the top left corner of the
7736 primary monitor on Windows. If you have a monitor positioned above
7737 your primary monitor, you will need to use a negative offset_y
7738 value to move the region to that monitor.
7739
7740 iec61883
7741 FireWire DV/HDV input device using libiec61883.
7742
7743 To enable this input device, you need libiec61883, libraw1394 and
7744 libavc1394 installed on your system. Use the configure option
7745 "--enable-libiec61883" to compile with the device enabled.
7746
7747 The iec61883 capture device supports capturing from a video device
7748 connected via IEEE1394 (FireWire), using libiec61883 and the new Linux
7749 FireWire stack (juju). This is the default DV/HDV input method in Linux
7750 Kernel 2.6.37 and later, since the old FireWire stack was removed.
7751
7752 Specify the FireWire port to be used as input file, or "auto" to choose
7753 the first port connected.
7754
7755 Options
7756
7757 dvtype
7758 Override autodetection of DV/HDV. This should only be used if auto
7759 detection does not work, or if usage of a different device type
7760 should be prohibited. Treating a DV device as HDV (or vice versa)
7761 will not work and result in undefined behavior. The values auto,
7762 dv and hdv are supported.
7763
7764 dvbuffer
7765 Set maximum size of buffer for incoming data, in frames. For DV,
7766 this is an exact value. For HDV, it is not frame exact, since HDV
7767 does not have a fixed frame size.
7768
7769 dvguid
7770 Select the capture device by specifying its GUID. Capturing will
7771 only be performed from the specified device and fails if no device
7772 with the given GUID is found. This is useful to select the input if
7773 multiple devices are connected at the same time. Look at
7774 /sys/bus/firewire/devices to find out the GUIDs.
7775
7776 Examples
7777
7778 • Grab and show the input of a FireWire DV/HDV device.
7779
7780 ffplay -f iec61883 -i auto
7781
7782 • Grab and record the input of a FireWire DV/HDV device, using a
7783 packet buffer of 100000 packets if the source is HDV.
7784
7785 ffmpeg -f iec61883 -i auto -dvbuffer 100000 out.mpg
7786
7787 jack
7788 JACK input device.
7789
7790 To enable this input device during configuration you need libjack
7791 installed on your system.
7792
7793 A JACK input device creates one or more JACK writable clients, one for
7794 each audio channel, with name client_name:input_N, where client_name is
7795 the name provided by the application, and N is a number which
7796 identifies the channel. Each writable client will send the acquired
7797 data to the FFmpeg input device.
7798
7799 Once you have created one or more JACK readable clients, you need to
7800 connect them to one or more JACK writable clients.
7801
7802 To connect or disconnect JACK clients you can use the jack_connect and
7803 jack_disconnect programs, or do it through a graphical interface, for
7804 example with qjackctl.
7805
7806 To list the JACK clients and their properties you can invoke the
7807 command jack_lsp.
7808
7809 Follows an example which shows how to capture a JACK readable client
7810 with ffmpeg.
7811
7812 # Create a JACK writable client with name "ffmpeg".
7813 $ ffmpeg -f jack -i ffmpeg -y out.wav
7814
7815 # Start the sample jack_metro readable client.
7816 $ jack_metro -b 120 -d 0.2 -f 4000
7817
7818 # List the current JACK clients.
7819 $ jack_lsp -c
7820 system:capture_1
7821 system:capture_2
7822 system:playback_1
7823 system:playback_2
7824 ffmpeg:input_1
7825 metro:120_bpm
7826
7827 # Connect metro to the ffmpeg writable client.
7828 $ jack_connect metro:120_bpm ffmpeg:input_1
7829
7830 For more information read: <http://jackaudio.org/>
7831
7832 Options
7833
7834 channels
7835 Set the number of channels. Default is 2.
7836
7837 kmsgrab
7838 KMS video input device.
7839
7840 Captures the KMS scanout framebuffer associated with a specified CRTC
7841 or plane as a DRM object that can be passed to other hardware
7842 functions.
7843
7844 Requires either DRM master or CAP_SYS_ADMIN to run.
7845
7846 If you don't understand what all of that means, you probably don't want
7847 this. Look at x11grab instead.
7848
7849 Options
7850
7851 device
7852 DRM device to capture on. Defaults to /dev/dri/card0.
7853
7854 format
7855 Pixel format of the framebuffer. This can be autodetected if you
7856 are running Linux 5.7 or later, but needs to be provided for
7857 earlier versions. Defaults to bgr0, which is the most common
7858 format used by the Linux console and Xorg X server.
7859
7860 format_modifier
7861 Format modifier to signal on output frames. This is necessary to
7862 import correctly into some APIs. It can be autodetected if you are
7863 running Linux 5.7 or later, but will need to be provided explicitly
7864 when needed in earlier versions. See the libdrm documentation for
7865 possible values.
7866
7867 crtc_id
7868 KMS CRTC ID to define the capture source. The first active plane
7869 on the given CRTC will be used.
7870
7871 plane_id
7872 KMS plane ID to define the capture source. Defaults to the first
7873 active plane found if neither crtc_id nor plane_id are specified.
7874
7875 framerate
7876 Framerate to capture at. This is not synchronised to any page
7877 flipping or framebuffer changes - it just defines the interval at
7878 which the framebuffer is sampled. Sampling faster than the
7879 framebuffer update rate will generate independent frames with the
7880 same content. Defaults to 30.
7881
7882 Examples
7883
7884 • Capture from the first active plane, download the result to normal
7885 frames and encode. This will only work if the framebuffer is both
7886 linear and mappable - if not, the result may be scrambled or fail
7887 to download.
7888
7889 ffmpeg -f kmsgrab -i - -vf 'hwdownload,format=bgr0' output.mp4
7890
7891 • Capture from CRTC ID 42 at 60fps, map the result to VAAPI, convert
7892 to NV12 and encode as H.264.
7893
7894 ffmpeg -crtc_id 42 -framerate 60 -f kmsgrab -i - -vf 'hwmap=derive_device=vaapi,scale_vaapi=w=1920:h=1080:format=nv12' -c:v h264_vaapi output.mp4
7895
7896 • To capture only part of a plane the output can be cropped - this
7897 can be used to capture a single window, as long as it has a known
7898 absolute position and size. For example, to capture and encode the
7899 middle quarter of a 1920x1080 plane:
7900
7901 ffmpeg -f kmsgrab -i - -vf 'hwmap=derive_device=vaapi,crop=960:540:480:270,scale_vaapi=960:540:nv12' -c:v h264_vaapi output.mp4
7902
7903 lavfi
7904 Libavfilter input virtual device.
7905
7906 This input device reads data from the open output pads of a libavfilter
7907 filtergraph.
7908
7909 For each filtergraph open output, the input device will create a
7910 corresponding stream which is mapped to the generated output. Currently
7911 only video data is supported. The filtergraph is specified through the
7912 option graph.
7913
7914 Options
7915
7916 graph
7917 Specify the filtergraph to use as input. Each video open output
7918 must be labelled by a unique string of the form "outN", where N is
7919 a number starting from 0 corresponding to the mapped input stream
7920 generated by the device. The first unlabelled output is
7921 automatically assigned to the "out0" label, but all the others need
7922 to be specified explicitly.
7923
7924 The suffix "+subcc" can be appended to the output label to create
7925 an extra stream with the closed captions packets attached to that
7926 output (experimental; only for EIA-608 / CEA-708 for now). The
7927 subcc streams are created after all the normal streams, in the
7928 order of the corresponding stream. For example, if there is
7929 "out19+subcc", "out7+subcc" and up to "out42", the stream #43 is
7930 subcc for stream #7 and stream #44 is subcc for stream #19.
7931
7932 If not specified defaults to the filename specified for the input
7933 device.
7934
7935 graph_file
7936 Set the filename of the filtergraph to be read and sent to the
7937 other filters. Syntax of the filtergraph is the same as the one
7938 specified by the option graph.
7939
7940 dumpgraph
7941 Dump graph to stderr.
7942
7943 Examples
7944
7945 • Create a color video stream and play it back with ffplay:
7946
7947 ffplay -f lavfi -graph "color=c=pink [out0]" dummy
7948
7949 • As the previous example, but use filename for specifying the graph
7950 description, and omit the "out0" label:
7951
7952 ffplay -f lavfi color=c=pink
7953
7954 • Create three different video test filtered sources and play them:
7955
7956 ffplay -f lavfi -graph "testsrc [out0]; testsrc,hflip [out1]; testsrc,negate [out2]" test3
7957
7958 • Read an audio stream from a file using the amovie source and play
7959 it back with ffplay:
7960
7961 ffplay -f lavfi "amovie=test.wav"
7962
7963 • Read an audio stream and a video stream and play it back with
7964 ffplay:
7965
7966 ffplay -f lavfi "movie=test.avi[out0];amovie=test.wav[out1]"
7967
7968 • Dump decoded frames to images and closed captions to a file
7969 (experimental):
7970
7971 ffmpeg -f lavfi -i "movie=test.ts[out0+subcc]" -map v frame%08d.png -map s -c copy -f rawvideo subcc.bin
7972
7973 libcdio
7974 Audio-CD input device based on libcdio.
7975
7976 To enable this input device during configuration you need libcdio
7977 installed on your system. It requires the configure option
7978 "--enable-libcdio".
7979
7980 This device allows playing and grabbing from an Audio-CD.
7981
7982 For example to copy with ffmpeg the entire Audio-CD in /dev/sr0, you
7983 may run the command:
7984
7985 ffmpeg -f libcdio -i /dev/sr0 cd.wav
7986
7987 Options
7988
7989 speed
7990 Set drive reading speed. Default value is 0.
7991
7992 The speed is specified CD-ROM speed units. The speed is set through
7993 the libcdio "cdio_cddap_speed_set" function. On many CD-ROM drives,
7994 specifying a value too large will result in using the fastest
7995 speed.
7996
7997 paranoia_mode
7998 Set paranoia recovery mode flags. It accepts one of the following
7999 values:
8000
8001 disable
8002 verify
8003 overlap
8004 neverskip
8005 full
8006
8007 Default value is disable.
8008
8009 For more information about the available recovery modes, consult
8010 the paranoia project documentation.
8011
8012 libdc1394
8013 IIDC1394 input device, based on libdc1394 and libraw1394.
8014
8015 Requires the configure option "--enable-libdc1394".
8016
8017 Options
8018
8019 framerate
8020 Set the frame rate. Default is "ntsc", corresponding to a frame
8021 rate of "30000/1001".
8022
8023 pixel_format
8024 Select the pixel format. Default is "uyvy422".
8025
8026 video_size
8027 Set the video size given as a string such as "640x480" or "hd720".
8028 Default is "qvga".
8029
8030 openal
8031 The OpenAL input device provides audio capture on all systems with a
8032 working OpenAL 1.1 implementation.
8033
8034 To enable this input device during configuration, you need OpenAL
8035 headers and libraries installed on your system, and need to configure
8036 FFmpeg with "--enable-openal".
8037
8038 OpenAL headers and libraries should be provided as part of your OpenAL
8039 implementation, or as an additional download (an SDK). Depending on
8040 your installation you may need to specify additional flags via the
8041 "--extra-cflags" and "--extra-ldflags" for allowing the build system to
8042 locate the OpenAL headers and libraries.
8043
8044 An incomplete list of OpenAL implementations follows:
8045
8046 Creative
8047 The official Windows implementation, providing hardware
8048 acceleration with supported devices and software fallback. See
8049 <http://openal.org/>.
8050
8051 OpenAL Soft
8052 Portable, open source (LGPL) software implementation. Includes
8053 backends for the most common sound APIs on the Windows, Linux,
8054 Solaris, and BSD operating systems. See
8055 <http://kcat.strangesoft.net/openal.html>.
8056
8057 Apple
8058 OpenAL is part of Core Audio, the official Mac OS X Audio
8059 interface. See
8060 <http://developer.apple.com/technologies/mac/audio-and-video.html>
8061
8062 This device allows one to capture from an audio input device handled
8063 through OpenAL.
8064
8065 You need to specify the name of the device to capture in the provided
8066 filename. If the empty string is provided, the device will
8067 automatically select the default device. You can get the list of the
8068 supported devices by using the option list_devices.
8069
8070 Options
8071
8072 channels
8073 Set the number of channels in the captured audio. Only the values 1
8074 (monaural) and 2 (stereo) are currently supported. Defaults to 2.
8075
8076 sample_size
8077 Set the sample size (in bits) of the captured audio. Only the
8078 values 8 and 16 are currently supported. Defaults to 16.
8079
8080 sample_rate
8081 Set the sample rate (in Hz) of the captured audio. Defaults to
8082 44.1k.
8083
8084 list_devices
8085 If set to true, print a list of devices and exit. Defaults to
8086 false.
8087
8088 Examples
8089
8090 Print the list of OpenAL supported devices and exit:
8091
8092 $ ffmpeg -list_devices true -f openal -i dummy out.ogg
8093
8094 Capture from the OpenAL device DR-BT101 via PulseAudio:
8095
8096 $ ffmpeg -f openal -i 'DR-BT101 via PulseAudio' out.ogg
8097
8098 Capture from the default device (note the empty string '' as filename):
8099
8100 $ ffmpeg -f openal -i '' out.ogg
8101
8102 Capture from two devices simultaneously, writing to two different
8103 files, within the same ffmpeg command:
8104
8105 $ ffmpeg -f openal -i 'DR-BT101 via PulseAudio' out1.ogg -f openal -i 'ALSA Default' out2.ogg
8106
8107 Note: not all OpenAL implementations support multiple simultaneous
8108 capture - try the latest OpenAL Soft if the above does not work.
8109
8110 oss
8111 Open Sound System input device.
8112
8113 The filename to provide to the input device is the device node
8114 representing the OSS input device, and is usually set to /dev/dsp.
8115
8116 For example to grab from /dev/dsp using ffmpeg use the command:
8117
8118 ffmpeg -f oss -i /dev/dsp /tmp/oss.wav
8119
8120 For more information about OSS see:
8121 <http://manuals.opensound.com/usersguide/dsp.html>
8122
8123 Options
8124
8125 sample_rate
8126 Set the sample rate in Hz. Default is 48000.
8127
8128 channels
8129 Set the number of channels. Default is 2.
8130
8131 pulse
8132 PulseAudio input device.
8133
8134 To enable this output device you need to configure FFmpeg with
8135 "--enable-libpulse".
8136
8137 The filename to provide to the input device is a source device or the
8138 string "default"
8139
8140 To list the PulseAudio source devices and their properties you can
8141 invoke the command pactl list sources.
8142
8143 More information about PulseAudio can be found on
8144 <http://www.pulseaudio.org>.
8145
8146 Options
8147
8148 server
8149 Connect to a specific PulseAudio server, specified by an IP
8150 address. Default server is used when not provided.
8151
8152 name
8153 Specify the application name PulseAudio will use when showing
8154 active clients, by default it is the "LIBAVFORMAT_IDENT" string.
8155
8156 stream_name
8157 Specify the stream name PulseAudio will use when showing active
8158 streams, by default it is "record".
8159
8160 sample_rate
8161 Specify the samplerate in Hz, by default 48kHz is used.
8162
8163 channels
8164 Specify the channels in use, by default 2 (stereo) is set.
8165
8166 frame_size
8167 Specify the number of bytes per frame, by default it is set to
8168 1024.
8169
8170 fragment_size
8171 Specify the minimal buffering fragment in PulseAudio, it will
8172 affect the audio latency. By default it is unset.
8173
8174 wallclock
8175 Set the initial PTS using the current time. Default is 1.
8176
8177 Examples
8178
8179 Record a stream from default device:
8180
8181 ffmpeg -f pulse -i default /tmp/pulse.wav
8182
8183 sndio
8184 sndio input device.
8185
8186 To enable this input device during configuration you need libsndio
8187 installed on your system.
8188
8189 The filename to provide to the input device is the device node
8190 representing the sndio input device, and is usually set to /dev/audio0.
8191
8192 For example to grab from /dev/audio0 using ffmpeg use the command:
8193
8194 ffmpeg -f sndio -i /dev/audio0 /tmp/oss.wav
8195
8196 Options
8197
8198 sample_rate
8199 Set the sample rate in Hz. Default is 48000.
8200
8201 channels
8202 Set the number of channels. Default is 2.
8203
8204 video4linux2, v4l2
8205 Video4Linux2 input video device.
8206
8207 "v4l2" can be used as alias for "video4linux2".
8208
8209 If FFmpeg is built with v4l-utils support (by using the
8210 "--enable-libv4l2" configure option), it is possible to use it with the
8211 "-use_libv4l2" input device option.
8212
8213 The name of the device to grab is a file device node, usually Linux
8214 systems tend to automatically create such nodes when the device (e.g.
8215 an USB webcam) is plugged into the system, and has a name of the kind
8216 /dev/videoN, where N is a number associated to the device.
8217
8218 Video4Linux2 devices usually support a limited set of widthxheight
8219 sizes and frame rates. You can check which are supported using
8220 -list_formats all for Video4Linux2 devices. Some devices, like TV
8221 cards, support one or more standards. It is possible to list all the
8222 supported standards using -list_standards all.
8223
8224 The time base for the timestamps is 1 microsecond. Depending on the
8225 kernel version and configuration, the timestamps may be derived from
8226 the real time clock (origin at the Unix Epoch) or the monotonic clock
8227 (origin usually at boot time, unaffected by NTP or manual changes to
8228 the clock). The -timestamps abs or -ts abs option can be used to force
8229 conversion into the real time clock.
8230
8231 Some usage examples of the video4linux2 device with ffmpeg and ffplay:
8232
8233 • List supported formats for a video4linux2 device:
8234
8235 ffplay -f video4linux2 -list_formats all /dev/video0
8236
8237 • Grab and show the input of a video4linux2 device:
8238
8239 ffplay -f video4linux2 -framerate 30 -video_size hd720 /dev/video0
8240
8241 • Grab and record the input of a video4linux2 device, leave the frame
8242 rate and size as previously set:
8243
8244 ffmpeg -f video4linux2 -input_format mjpeg -i /dev/video0 out.mpeg
8245
8246 For more information about Video4Linux, check <http://linuxtv.org/>.
8247
8248 Options
8249
8250 standard
8251 Set the standard. Must be the name of a supported standard. To get
8252 a list of the supported standards, use the list_standards option.
8253
8254 channel
8255 Set the input channel number. Default to -1, which means using the
8256 previously selected channel.
8257
8258 video_size
8259 Set the video frame size. The argument must be a string in the form
8260 WIDTHxHEIGHT or a valid size abbreviation.
8261
8262 pixel_format
8263 Select the pixel format (only valid for raw video input).
8264
8265 input_format
8266 Set the preferred pixel format (for raw video) or a codec name.
8267 This option allows one to select the input format, when several are
8268 available.
8269
8270 framerate
8271 Set the preferred video frame rate.
8272
8273 list_formats
8274 List available formats (supported pixel formats, codecs, and frame
8275 sizes) and exit.
8276
8277 Available values are:
8278
8279 all Show all available (compressed and non-compressed) formats.
8280
8281 raw Show only raw video (non-compressed) formats.
8282
8283 compressed
8284 Show only compressed formats.
8285
8286 list_standards
8287 List supported standards and exit.
8288
8289 Available values are:
8290
8291 all Show all supported standards.
8292
8293 timestamps, ts
8294 Set type of timestamps for grabbed frames.
8295
8296 Available values are:
8297
8298 default
8299 Use timestamps from the kernel.
8300
8301 abs Use absolute timestamps (wall clock).
8302
8303 mono2abs
8304 Force conversion from monotonic to absolute timestamps.
8305
8306 Default value is "default".
8307
8308 use_libv4l2
8309 Use libv4l2 (v4l-utils) conversion functions. Default is 0.
8310
8311 vfwcap
8312 VfW (Video for Windows) capture input device.
8313
8314 The filename passed as input is the capture driver number, ranging from
8315 0 to 9. You may use "list" as filename to print a list of drivers. Any
8316 other filename will be interpreted as device number 0.
8317
8318 Options
8319
8320 video_size
8321 Set the video frame size.
8322
8323 framerate
8324 Set the grabbing frame rate. Default value is "ntsc", corresponding
8325 to a frame rate of "30000/1001".
8326
8327 x11grab
8328 X11 video input device.
8329
8330 To enable this input device during configuration you need libxcb
8331 installed on your system. It will be automatically detected during
8332 configuration.
8333
8334 This device allows one to capture a region of an X11 display.
8335
8336 The filename passed as input has the syntax:
8337
8338 [<hostname>]:<display_number>.<screen_number>[+<x_offset>,<y_offset>]
8339
8340 hostname:display_number.screen_number specifies the X11 display name of
8341 the screen to grab from. hostname can be omitted, and defaults to
8342 "localhost". The environment variable DISPLAY contains the default
8343 display name.
8344
8345 x_offset and y_offset specify the offsets of the grabbed area with
8346 respect to the top-left border of the X11 screen. They default to 0.
8347
8348 Check the X11 documentation (e.g. man X) for more detailed information.
8349
8350 Use the xdpyinfo program for getting basic information about the
8351 properties of your X11 display (e.g. grep for "name" or "dimensions").
8352
8353 For example to grab from :0.0 using ffmpeg:
8354
8355 ffmpeg -f x11grab -framerate 25 -video_size cif -i :0.0 out.mpg
8356
8357 Grab at position "10,20":
8358
8359 ffmpeg -f x11grab -framerate 25 -video_size cif -i :0.0+10,20 out.mpg
8360
8361 Options
8362
8363 select_region
8364 Specify whether to select the grabbing area graphically using the
8365 pointer. A value of 1 prompts the user to select the grabbing area
8366 graphically by clicking and dragging. A single click with no
8367 dragging will select the whole screen. A region with zero width or
8368 height will also select the whole screen. This option overwrites
8369 the video_size, grab_x, and grab_y options. Default value is 0.
8370
8371 draw_mouse
8372 Specify whether to draw the mouse pointer. A value of 0 specifies
8373 not to draw the pointer. Default value is 1.
8374
8375 follow_mouse
8376 Make the grabbed area follow the mouse. The argument can be
8377 "centered" or a number of pixels PIXELS.
8378
8379 When it is specified with "centered", the grabbing region follows
8380 the mouse pointer and keeps the pointer at the center of region;
8381 otherwise, the region follows only when the mouse pointer reaches
8382 within PIXELS (greater than zero) to the edge of region.
8383
8384 For example:
8385
8386 ffmpeg -f x11grab -follow_mouse centered -framerate 25 -video_size cif -i :0.0 out.mpg
8387
8388 To follow only when the mouse pointer reaches within 100 pixels to
8389 edge:
8390
8391 ffmpeg -f x11grab -follow_mouse 100 -framerate 25 -video_size cif -i :0.0 out.mpg
8392
8393 framerate
8394 Set the grabbing frame rate. Default value is "ntsc", corresponding
8395 to a frame rate of "30000/1001".
8396
8397 show_region
8398 Show grabbed region on screen.
8399
8400 If show_region is specified with 1, then the grabbing region will
8401 be indicated on screen. With this option, it is easy to know what
8402 is being grabbed if only a portion of the screen is grabbed.
8403
8404 region_border
8405 Set the region border thickness if -show_region 1 is used. Range
8406 is 1 to 128 and default is 3 (XCB-based x11grab only).
8407
8408 For example:
8409
8410 ffmpeg -f x11grab -show_region 1 -framerate 25 -video_size cif -i :0.0+10,20 out.mpg
8411
8412 With follow_mouse:
8413
8414 ffmpeg -f x11grab -follow_mouse centered -show_region 1 -framerate 25 -video_size cif -i :0.0 out.mpg
8415
8416 window_id
8417 Grab this window, instead of the whole screen. Default value is 0,
8418 which maps to the whole screen (root window).
8419
8420 The id of a window can be found using the xwininfo program,
8421 possibly with options -tree and -root.
8422
8423 If the window is later enlarged, the new area is not recorded.
8424 Video ends when the window is closed, unmapped (i.e., iconified) or
8425 shrunk beyond the video size (which defaults to the initial window
8426 size).
8427
8428 This option disables options follow_mouse and select_region.
8429
8430 video_size
8431 Set the video frame size. Default is the full desktop or window.
8432
8433 grab_x
8434 grab_y
8435 Set the grabbing region coordinates. They are expressed as offset
8436 from the top left corner of the X11 window and correspond to the
8437 x_offset and y_offset parameters in the device name. The default
8438 value for both options is 0.
8439
8441 The audio resampler supports the following named options.
8442
8443 Options may be set by specifying -option value in the FFmpeg tools,
8444 option=value for the aresample filter, by setting the value explicitly
8445 in the "SwrContext" options or using the libavutil/opt.h API for
8446 programmatic use.
8447
8448 ich, in_channel_count
8449 Set the number of input channels. Default value is 0. Setting this
8450 value is not mandatory if the corresponding channel layout
8451 in_channel_layout is set.
8452
8453 och, out_channel_count
8454 Set the number of output channels. Default value is 0. Setting this
8455 value is not mandatory if the corresponding channel layout
8456 out_channel_layout is set.
8457
8458 uch, used_channel_count
8459 Set the number of used input channels. Default value is 0. This
8460 option is only used for special remapping.
8461
8462 isr, in_sample_rate
8463 Set the input sample rate. Default value is 0.
8464
8465 osr, out_sample_rate
8466 Set the output sample rate. Default value is 0.
8467
8468 isf, in_sample_fmt
8469 Specify the input sample format. It is set by default to "none".
8470
8471 osf, out_sample_fmt
8472 Specify the output sample format. It is set by default to "none".
8473
8474 tsf, internal_sample_fmt
8475 Set the internal sample format. Default value is "none". This will
8476 automatically be chosen when it is not explicitly set.
8477
8478 icl, in_channel_layout
8479 ocl, out_channel_layout
8480 Set the input/output channel layout.
8481
8482 See the Channel Layout section in the ffmpeg-utils(1) manual for
8483 the required syntax.
8484
8485 clev, center_mix_level
8486 Set the center mix level. It is a value expressed in deciBel, and
8487 must be in the interval [-32,32].
8488
8489 slev, surround_mix_level
8490 Set the surround mix level. It is a value expressed in deciBel, and
8491 must be in the interval [-32,32].
8492
8493 lfe_mix_level
8494 Set LFE mix into non LFE level. It is used when there is a LFE
8495 input but no LFE output. It is a value expressed in deciBel, and
8496 must be in the interval [-32,32].
8497
8498 rmvol, rematrix_volume
8499 Set rematrix volume. Default value is 1.0.
8500
8501 rematrix_maxval
8502 Set maximum output value for rematrixing. This can be used to
8503 prevent clipping vs. preventing volume reduction. A value of 1.0
8504 prevents clipping.
8505
8506 flags, swr_flags
8507 Set flags used by the converter. Default value is 0.
8508
8509 It supports the following individual flags:
8510
8511 res force resampling, this flag forces resampling to be used even
8512 when the input and output sample rates match.
8513
8514 dither_scale
8515 Set the dither scale. Default value is 1.
8516
8517 dither_method
8518 Set dither method. Default value is 0.
8519
8520 Supported values:
8521
8522 rectangular
8523 select rectangular dither
8524
8525 triangular
8526 select triangular dither
8527
8528 triangular_hp
8529 select triangular dither with high pass
8530
8531 lipshitz
8532 select Lipshitz noise shaping dither.
8533
8534 shibata
8535 select Shibata noise shaping dither.
8536
8537 low_shibata
8538 select low Shibata noise shaping dither.
8539
8540 high_shibata
8541 select high Shibata noise shaping dither.
8542
8543 f_weighted
8544 select f-weighted noise shaping dither
8545
8546 modified_e_weighted
8547 select modified-e-weighted noise shaping dither
8548
8549 improved_e_weighted
8550 select improved-e-weighted noise shaping dither
8551
8552 resampler
8553 Set resampling engine. Default value is swr.
8554
8555 Supported values:
8556
8557 swr select the native SW Resampler; filter options precision and
8558 cheby are not applicable in this case.
8559
8560 soxr
8561 select the SoX Resampler (where available); compensation, and
8562 filter options filter_size, phase_shift, exact_rational,
8563 filter_type & kaiser_beta, are not applicable in this case.
8564
8565 filter_size
8566 For swr only, set resampling filter size, default value is 32.
8567
8568 phase_shift
8569 For swr only, set resampling phase shift, default value is 10, and
8570 must be in the interval [0,30].
8571
8572 linear_interp
8573 Use linear interpolation when enabled (the default). Disable it if
8574 you want to preserve speed instead of quality when exact_rational
8575 fails.
8576
8577 exact_rational
8578 For swr only, when enabled, try to use exact phase_count based on
8579 input and output sample rate. However, if it is larger than "1 <<
8580 phase_shift", the phase_count will be "1 << phase_shift" as
8581 fallback. Default is enabled.
8582
8583 cutoff
8584 Set cutoff frequency (swr: 6dB point; soxr: 0dB point) ratio; must
8585 be a float value between 0 and 1. Default value is 0.97 with swr,
8586 and 0.91 with soxr (which, with a sample-rate of 44100, preserves
8587 the entire audio band to 20kHz).
8588
8589 precision
8590 For soxr only, the precision in bits to which the resampled signal
8591 will be calculated. The default value of 20 (which, with suitable
8592 dithering, is appropriate for a destination bit-depth of 16) gives
8593 SoX's 'High Quality'; a value of 28 gives SoX's 'Very High
8594 Quality'.
8595
8596 cheby
8597 For soxr only, selects passband rolloff none (Chebyshev) & higher-
8598 precision approximation for 'irrational' ratios. Default value is
8599 0.
8600
8601 async
8602 For swr only, simple 1 parameter audio sync to timestamps using
8603 stretching, squeezing, filling and trimming. Setting this to 1 will
8604 enable filling and trimming, larger values represent the maximum
8605 amount in samples that the data may be stretched or squeezed for
8606 each second. Default value is 0, thus no compensation is applied
8607 to make the samples match the audio timestamps.
8608
8609 first_pts
8610 For swr only, assume the first pts should be this value. The time
8611 unit is 1 / sample rate. This allows for padding/trimming at the
8612 start of stream. By default, no assumption is made about the first
8613 frame's expected pts, so no padding or trimming is done. For
8614 example, this could be set to 0 to pad the beginning with silence
8615 if an audio stream starts after the video stream or to trim any
8616 samples with a negative pts due to encoder delay.
8617
8618 min_comp
8619 For swr only, set the minimum difference between timestamps and
8620 audio data (in seconds) to trigger stretching/squeezing/filling or
8621 trimming of the data to make it match the timestamps. The default
8622 is that stretching/squeezing/filling and trimming is disabled
8623 (min_comp = "FLT_MAX").
8624
8625 min_hard_comp
8626 For swr only, set the minimum difference between timestamps and
8627 audio data (in seconds) to trigger adding/dropping samples to make
8628 it match the timestamps. This option effectively is a threshold to
8629 select between hard (trim/fill) and soft (squeeze/stretch)
8630 compensation. Note that all compensation is by default disabled
8631 through min_comp. The default is 0.1.
8632
8633 comp_duration
8634 For swr only, set duration (in seconds) over which data is
8635 stretched/squeezed to make it match the timestamps. Must be a non-
8636 negative double float value, default value is 1.0.
8637
8638 max_soft_comp
8639 For swr only, set maximum factor by which data is
8640 stretched/squeezed to make it match the timestamps. Must be a non-
8641 negative double float value, default value is 0.
8642
8643 matrix_encoding
8644 Select matrixed stereo encoding.
8645
8646 It accepts the following values:
8647
8648 none
8649 select none
8650
8651 dolby
8652 select Dolby
8653
8654 dplii
8655 select Dolby Pro Logic II
8656
8657 Default value is "none".
8658
8659 filter_type
8660 For swr only, select resampling filter type. This only affects
8661 resampling operations.
8662
8663 It accepts the following values:
8664
8665 cubic
8666 select cubic
8667
8668 blackman_nuttall
8669 select Blackman Nuttall windowed sinc
8670
8671 kaiser
8672 select Kaiser windowed sinc
8673
8674 kaiser_beta
8675 For swr only, set Kaiser window beta value. Must be a double float
8676 value in the interval [2,16], default value is 9.
8677
8678 output_sample_bits
8679 For swr only, set number of used output sample bits for dithering.
8680 Must be an integer in the interval [0,64], default value is 0,
8681 which means it's not used.
8682
8684 The video scaler supports the following named options.
8685
8686 Options may be set by specifying -option value in the FFmpeg tools,
8687 with a few API-only exceptions noted below. For programmatic use, they
8688 can be set explicitly in the "SwsContext" options or through the
8689 libavutil/opt.h API.
8690
8691 sws_flags
8692 Set the scaler flags. This is also used to set the scaling
8693 algorithm. Only a single algorithm should be selected. Default
8694 value is bicubic.
8695
8696 It accepts the following values:
8697
8698 fast_bilinear
8699 Select fast bilinear scaling algorithm.
8700
8701 bilinear
8702 Select bilinear scaling algorithm.
8703
8704 bicubic
8705 Select bicubic scaling algorithm.
8706
8707 experimental
8708 Select experimental scaling algorithm.
8709
8710 neighbor
8711 Select nearest neighbor rescaling algorithm.
8712
8713 area
8714 Select averaging area rescaling algorithm.
8715
8716 bicublin
8717 Select bicubic scaling algorithm for the luma component,
8718 bilinear for chroma components.
8719
8720 gauss
8721 Select Gaussian rescaling algorithm.
8722
8723 sinc
8724 Select sinc rescaling algorithm.
8725
8726 lanczos
8727 Select Lanczos rescaling algorithm. The default width (alpha)
8728 is 3 and can be changed by setting "param0".
8729
8730 spline
8731 Select natural bicubic spline rescaling algorithm.
8732
8733 print_info
8734 Enable printing/debug logging.
8735
8736 accurate_rnd
8737 Enable accurate rounding.
8738
8739 full_chroma_int
8740 Enable full chroma interpolation.
8741
8742 full_chroma_inp
8743 Select full chroma input.
8744
8745 bitexact
8746 Enable bitexact output.
8747
8748 srcw (API only)
8749 Set source width.
8750
8751 srch (API only)
8752 Set source height.
8753
8754 dstw (API only)
8755 Set destination width.
8756
8757 dsth (API only)
8758 Set destination height.
8759
8760 src_format (API only)
8761 Set source pixel format (must be expressed as an integer).
8762
8763 dst_format (API only)
8764 Set destination pixel format (must be expressed as an integer).
8765
8766 src_range (boolean)
8767 If value is set to 1, indicates source is full range. Default value
8768 is 0, which indicates source is limited range.
8769
8770 dst_range (boolean)
8771 If value is set to 1, enable full range for destination. Default
8772 value is 0, which enables limited range.
8773
8774 param0, param1
8775 Set scaling algorithm parameters. The specified values are specific
8776 of some scaling algorithms and ignored by others. The specified
8777 values are floating point number values.
8778
8779 sws_dither
8780 Set the dithering algorithm. Accepts one of the following values.
8781 Default value is auto.
8782
8783 auto
8784 automatic choice
8785
8786 none
8787 no dithering
8788
8789 bayer
8790 bayer dither
8791
8792 ed error diffusion dither
8793
8794 a_dither
8795 arithmetic dither, based using addition
8796
8797 x_dither
8798 arithmetic dither, based using xor (more random/less apparent
8799 patterning that a_dither).
8800
8801 alphablend
8802 Set the alpha blending to use when the input has alpha but the
8803 output does not. Default value is none.
8804
8805 uniform_color
8806 Blend onto a uniform background color
8807
8808 checkerboard
8809 Blend onto a checkerboard
8810
8811 none
8812 No blending
8813
8815 Filtering in FFmpeg is enabled through the libavfilter library.
8816
8817 In libavfilter, a filter can have multiple inputs and multiple outputs.
8818 To illustrate the sorts of things that are possible, we consider the
8819 following filtergraph.
8820
8821 [main]
8822 input --> split ---------------------> overlay --> output
8823 | ^
8824 |[tmp] [flip]|
8825 +-----> crop --> vflip -------+
8826
8827 This filtergraph splits the input stream in two streams, then sends one
8828 stream through the crop filter and the vflip filter, before merging it
8829 back with the other stream by overlaying it on top. You can use the
8830 following command to achieve this:
8831
8832 ffmpeg -i INPUT -vf "split [main][tmp]; [tmp] crop=iw:ih/2:0:0, vflip [flip]; [main][flip] overlay=0:H/2" OUTPUT
8833
8834 The result will be that the top half of the video is mirrored onto the
8835 bottom half of the output video.
8836
8837 Filters in the same linear chain are separated by commas, and distinct
8838 linear chains of filters are separated by semicolons. In our example,
8839 crop,vflip are in one linear chain, split and overlay are separately in
8840 another. The points where the linear chains join are labelled by names
8841 enclosed in square brackets. In the example, the split filter generates
8842 two outputs that are associated to the labels [main] and [tmp].
8843
8844 The stream sent to the second output of split, labelled as [tmp], is
8845 processed through the crop filter, which crops away the lower half part
8846 of the video, and then vertically flipped. The overlay filter takes in
8847 input the first unchanged output of the split filter (which was
8848 labelled as [main]), and overlay on its lower half the output generated
8849 by the crop,vflip filterchain.
8850
8851 Some filters take in input a list of parameters: they are specified
8852 after the filter name and an equal sign, and are separated from each
8853 other by a colon.
8854
8855 There exist so-called source filters that do not have an audio/video
8856 input, and sink filters that will not have audio/video output.
8857
8859 The graph2dot program included in the FFmpeg tools directory can be
8860 used to parse a filtergraph description and issue a corresponding
8861 textual representation in the dot language.
8862
8863 Invoke the command:
8864
8865 graph2dot -h
8866
8867 to see how to use graph2dot.
8868
8869 You can then pass the dot description to the dot program (from the
8870 graphviz suite of programs) and obtain a graphical representation of
8871 the filtergraph.
8872
8873 For example the sequence of commands:
8874
8875 echo <GRAPH_DESCRIPTION> | \
8876 tools/graph2dot -o graph.tmp && \
8877 dot -Tpng graph.tmp -o graph.png && \
8878 display graph.png
8879
8880 can be used to create and display an image representing the graph
8881 described by the GRAPH_DESCRIPTION string. Note that this string must
8882 be a complete self-contained graph, with its inputs and outputs
8883 explicitly defined. For example if your command line is of the form:
8884
8885 ffmpeg -i infile -vf scale=640:360 outfile
8886
8887 your GRAPH_DESCRIPTION string will need to be of the form:
8888
8889 nullsrc,scale=640:360,nullsink
8890
8891 you may also need to set the nullsrc parameters and add a format filter
8892 in order to simulate a specific input file.
8893
8895 A filtergraph is a directed graph of connected filters. It can contain
8896 cycles, and there can be multiple links between a pair of filters. Each
8897 link has one input pad on one side connecting it to one filter from
8898 which it takes its input, and one output pad on the other side
8899 connecting it to one filter accepting its output.
8900
8901 Each filter in a filtergraph is an instance of a filter class
8902 registered in the application, which defines the features and the
8903 number of input and output pads of the filter.
8904
8905 A filter with no input pads is called a "source", and a filter with no
8906 output pads is called a "sink".
8907
8908 Filtergraph syntax
8909 A filtergraph has a textual representation, which is recognized by the
8910 -filter/-vf/-af and -filter_complex options in ffmpeg and -vf/-af in
8911 ffplay, and by the "avfilter_graph_parse_ptr()" function defined in
8912 libavfilter/avfilter.h.
8913
8914 A filterchain consists of a sequence of connected filters, each one
8915 connected to the previous one in the sequence. A filterchain is
8916 represented by a list of ","-separated filter descriptions.
8917
8918 A filtergraph consists of a sequence of filterchains. A sequence of
8919 filterchains is represented by a list of ";"-separated filterchain
8920 descriptions.
8921
8922 A filter is represented by a string of the form:
8923 [in_link_1]...[in_link_N]filter_name@id=arguments[out_link_1]...[out_link_M]
8924
8925 filter_name is the name of the filter class of which the described
8926 filter is an instance of, and has to be the name of one of the filter
8927 classes registered in the program optionally followed by "@id". The
8928 name of the filter class is optionally followed by a string
8929 "=arguments".
8930
8931 arguments is a string which contains the parameters used to initialize
8932 the filter instance. It may have one of two forms:
8933
8934 • A ':'-separated list of key=value pairs.
8935
8936 • A ':'-separated list of value. In this case, the keys are assumed
8937 to be the option names in the order they are declared. E.g. the
8938 "fade" filter declares three options in this order -- type,
8939 start_frame and nb_frames. Then the parameter list in:0:30 means
8940 that the value in is assigned to the option type, 0 to start_frame
8941 and 30 to nb_frames.
8942
8943 • A ':'-separated list of mixed direct value and long key=value
8944 pairs. The direct value must precede the key=value pairs, and
8945 follow the same constraints order of the previous point. The
8946 following key=value pairs can be set in any preferred order.
8947
8948 If the option value itself is a list of items (e.g. the "format" filter
8949 takes a list of pixel formats), the items in the list are usually
8950 separated by |.
8951
8952 The list of arguments can be quoted using the character ' as initial
8953 and ending mark, and the character \ for escaping the characters within
8954 the quoted text; otherwise the argument string is considered terminated
8955 when the next special character (belonging to the set []=;,) is
8956 encountered.
8957
8958 The name and arguments of the filter are optionally preceded and
8959 followed by a list of link labels. A link label allows one to name a
8960 link and associate it to a filter output or input pad. The preceding
8961 labels in_link_1 ... in_link_N, are associated to the filter input
8962 pads, the following labels out_link_1 ... out_link_M, are associated to
8963 the output pads.
8964
8965 When two link labels with the same name are found in the filtergraph, a
8966 link between the corresponding input and output pad is created.
8967
8968 If an output pad is not labelled, it is linked by default to the first
8969 unlabelled input pad of the next filter in the filterchain. For
8970 example in the filterchain
8971
8972 nullsrc, split[L1], [L2]overlay, nullsink
8973
8974 the split filter instance has two output pads, and the overlay filter
8975 instance two input pads. The first output pad of split is labelled
8976 "L1", the first input pad of overlay is labelled "L2", and the second
8977 output pad of split is linked to the second input pad of overlay, which
8978 are both unlabelled.
8979
8980 In a filter description, if the input label of the first filter is not
8981 specified, "in" is assumed; if the output label of the last filter is
8982 not specified, "out" is assumed.
8983
8984 In a complete filterchain all the unlabelled filter input and output
8985 pads must be connected. A filtergraph is considered valid if all the
8986 filter input and output pads of all the filterchains are connected.
8987
8988 Libavfilter will automatically insert scale filters where format
8989 conversion is required. It is possible to specify swscale flags for
8990 those automatically inserted scalers by prepending "sws_flags=flags;"
8991 to the filtergraph description.
8992
8993 Here is a BNF description of the filtergraph syntax:
8994
8995 <NAME> ::= sequence of alphanumeric characters and '_'
8996 <FILTER_NAME> ::= <NAME>["@"<NAME>]
8997 <LINKLABEL> ::= "[" <NAME> "]"
8998 <LINKLABELS> ::= <LINKLABEL> [<LINKLABELS>]
8999 <FILTER_ARGUMENTS> ::= sequence of chars (possibly quoted)
9000 <FILTER> ::= [<LINKLABELS>] <FILTER_NAME> ["=" <FILTER_ARGUMENTS>] [<LINKLABELS>]
9001 <FILTERCHAIN> ::= <FILTER> [,<FILTERCHAIN>]
9002 <FILTERGRAPH> ::= [sws_flags=<flags>;] <FILTERCHAIN> [;<FILTERGRAPH>]
9003
9004 Notes on filtergraph escaping
9005 Filtergraph description composition entails several levels of escaping.
9006 See the "Quoting and escaping" section in the ffmpeg-utils(1) manual
9007 for more information about the employed escaping procedure.
9008
9009 A first level escaping affects the content of each filter option value,
9010 which may contain the special character ":" used to separate values, or
9011 one of the escaping characters "\'".
9012
9013 A second level escaping affects the whole filter description, which may
9014 contain the escaping characters "\'" or the special characters "[],;"
9015 used by the filtergraph description.
9016
9017 Finally, when you specify a filtergraph on a shell commandline, you
9018 need to perform a third level escaping for the shell special characters
9019 contained within it.
9020
9021 For example, consider the following string to be embedded in the
9022 drawtext filter description text value:
9023
9024 this is a 'string': may contain one, or more, special characters
9025
9026 This string contains the "'" special escaping character, and the ":"
9027 special character, so it needs to be escaped in this way:
9028
9029 text=this is a \'string\'\: may contain one, or more, special characters
9030
9031 A second level of escaping is required when embedding the filter
9032 description in a filtergraph description, in order to escape all the
9033 filtergraph special characters. Thus the example above becomes:
9034
9035 drawtext=text=this is a \\\'string\\\'\\: may contain one\, or more\, special characters
9036
9037 (note that in addition to the "\'" escaping special characters, also
9038 "," needs to be escaped).
9039
9040 Finally an additional level of escaping is needed when writing the
9041 filtergraph description in a shell command, which depends on the
9042 escaping rules of the adopted shell. For example, assuming that "\" is
9043 special and needs to be escaped with another "\", the previous string
9044 will finally result in:
9045
9046 -vf "drawtext=text=this is a \\\\\\'string\\\\\\'\\\\: may contain one\\, or more\\, special characters"
9047
9049 Some filters support a generic enable option. For the filters
9050 supporting timeline editing, this option can be set to an expression
9051 which is evaluated before sending a frame to the filter. If the
9052 evaluation is non-zero, the filter will be enabled, otherwise the frame
9053 will be sent unchanged to the next filter in the filtergraph.
9054
9055 The expression accepts the following values:
9056
9057 t timestamp expressed in seconds, NAN if the input timestamp is
9058 unknown
9059
9060 n sequential number of the input frame, starting from 0
9061
9062 pos the position in the file of the input frame, NAN if unknown
9063
9064 w
9065 h width and height of the input frame if video
9066
9067 Additionally, these filters support an enable command that can be used
9068 to re-define the expression.
9069
9070 Like any other filtering option, the enable option follows the same
9071 rules.
9072
9073 For example, to enable a blur filter (smartblur) from 10 seconds to 3
9074 minutes, and a curves filter starting at 3 seconds:
9075
9076 smartblur = enable='between(t,10,3*60)',
9077 curves = enable='gte(t,3)' : preset=cross_process
9078
9079 See "ffmpeg -filters" to view which filters have timeline support.
9080
9082 Some options can be changed during the operation of the filter using a
9083 command. These options are marked 'T' on the output of ffmpeg -h
9084 filter=<name of filter>. The name of the command is the name of the
9085 option and the argument is the new value.
9086
9088 Some filters with several inputs support a common set of options.
9089 These options can only be set by name, not with the short notation.
9090
9091 eof_action
9092 The action to take when EOF is encountered on the secondary input;
9093 it accepts one of the following values:
9094
9095 repeat
9096 Repeat the last frame (the default).
9097
9098 endall
9099 End both streams.
9100
9101 pass
9102 Pass the main input through.
9103
9104 shortest
9105 If set to 1, force the output to terminate when the shortest input
9106 terminates. Default value is 0.
9107
9108 repeatlast
9109 If set to 1, force the filter to extend the last frame of secondary
9110 streams until the end of the primary stream. A value of 0 disables
9111 this behavior. Default value is 1.
9112
9114 When you configure your FFmpeg build, you can disable any of the
9115 existing filters using "--disable-filters". The configure output will
9116 show the audio filters included in your build.
9117
9118 Below is a description of the currently available audio filters.
9119
9120 acompressor
9121 A compressor is mainly used to reduce the dynamic range of a signal.
9122 Especially modern music is mostly compressed at a high ratio to improve
9123 the overall loudness. It's done to get the highest attention of a
9124 listener, "fatten" the sound and bring more "power" to the track. If a
9125 signal is compressed too much it may sound dull or "dead" afterwards or
9126 it may start to "pump" (which could be a powerful effect but can also
9127 destroy a track completely). The right compression is the key to reach
9128 a professional sound and is the high art of mixing and mastering.
9129 Because of its complex settings it may take a long time to get the
9130 right feeling for this kind of effect.
9131
9132 Compression is done by detecting the volume above a chosen level
9133 "threshold" and dividing it by the factor set with "ratio". So if you
9134 set the threshold to -12dB and your signal reaches -6dB a ratio of 2:1
9135 will result in a signal at -9dB. Because an exact manipulation of the
9136 signal would cause distortion of the waveform the reduction can be
9137 levelled over the time. This is done by setting "Attack" and "Release".
9138 "attack" determines how long the signal has to rise above the threshold
9139 before any reduction will occur and "release" sets the time the signal
9140 has to fall below the threshold to reduce the reduction again. Shorter
9141 signals than the chosen attack time will be left untouched. The
9142 overall reduction of the signal can be made up afterwards with the
9143 "makeup" setting. So compressing the peaks of a signal about 6dB and
9144 raising the makeup to this level results in a signal twice as loud than
9145 the source. To gain a softer entry in the compression the "knee"
9146 flattens the hard edge at the threshold in the range of the chosen
9147 decibels.
9148
9149 The filter accepts the following options:
9150
9151 level_in
9152 Set input gain. Default is 1. Range is between 0.015625 and 64.
9153
9154 mode
9155 Set mode of compressor operation. Can be "upward" or "downward".
9156 Default is "downward".
9157
9158 threshold
9159 If a signal of stream rises above this level it will affect the
9160 gain reduction. By default it is 0.125. Range is between
9161 0.00097563 and 1.
9162
9163 ratio
9164 Set a ratio by which the signal is reduced. 1:2 means that if the
9165 level rose 4dB above the threshold, it will be only 2dB above after
9166 the reduction. Default is 2. Range is between 1 and 20.
9167
9168 attack
9169 Amount of milliseconds the signal has to rise above the threshold
9170 before gain reduction starts. Default is 20. Range is between 0.01
9171 and 2000.
9172
9173 release
9174 Amount of milliseconds the signal has to fall below the threshold
9175 before reduction is decreased again. Default is 250. Range is
9176 between 0.01 and 9000.
9177
9178 makeup
9179 Set the amount by how much signal will be amplified after
9180 processing. Default is 1. Range is from 1 to 64.
9181
9182 knee
9183 Curve the sharp knee around the threshold to enter gain reduction
9184 more softly. Default is 2.82843. Range is between 1 and 8.
9185
9186 link
9187 Choose if the "average" level between all channels of input stream
9188 or the louder("maximum") channel of input stream affects the
9189 reduction. Default is "average".
9190
9191 detection
9192 Should the exact signal be taken in case of "peak" or an RMS one in
9193 case of "rms". Default is "rms" which is mostly smoother.
9194
9195 mix How much to use compressed signal in output. Default is 1. Range
9196 is between 0 and 1.
9197
9198 Commands
9199
9200 This filter supports the all above options as commands.
9201
9202 acontrast
9203 Simple audio dynamic range compression/expansion filter.
9204
9205 The filter accepts the following options:
9206
9207 contrast
9208 Set contrast. Default is 33. Allowed range is between 0 and 100.
9209
9210 acopy
9211 Copy the input audio source unchanged to the output. This is mainly
9212 useful for testing purposes.
9213
9214 acrossfade
9215 Apply cross fade from one input audio stream to another input audio
9216 stream. The cross fade is applied for specified duration near the end
9217 of first stream.
9218
9219 The filter accepts the following options:
9220
9221 nb_samples, ns
9222 Specify the number of samples for which the cross fade effect has
9223 to last. At the end of the cross fade effect the first input audio
9224 will be completely silent. Default is 44100.
9225
9226 duration, d
9227 Specify the duration of the cross fade effect. See the Time
9228 duration section in the ffmpeg-utils(1) manual for the accepted
9229 syntax. By default the duration is determined by nb_samples. If
9230 set this option is used instead of nb_samples.
9231
9232 overlap, o
9233 Should first stream end overlap with second stream start. Default
9234 is enabled.
9235
9236 curve1
9237 Set curve for cross fade transition for first stream.
9238
9239 curve2
9240 Set curve for cross fade transition for second stream.
9241
9242 For description of available curve types see afade filter
9243 description.
9244
9245 Examples
9246
9247 • Cross fade from one input to another:
9248
9249 ffmpeg -i first.flac -i second.flac -filter_complex acrossfade=d=10:c1=exp:c2=exp output.flac
9250
9251 • Cross fade from one input to another but without overlapping:
9252
9253 ffmpeg -i first.flac -i second.flac -filter_complex acrossfade=d=10:o=0:c1=exp:c2=exp output.flac
9254
9255 acrossover
9256 Split audio stream into several bands.
9257
9258 This filter splits audio stream into two or more frequency ranges.
9259 Summing all streams back will give flat output.
9260
9261 The filter accepts the following options:
9262
9263 split
9264 Set split frequencies. Those must be positive and increasing.
9265
9266 order
9267 Set filter order for each band split. This controls filter roll-off
9268 or steepness of filter transfer function. Available values are:
9269
9270 2nd 12 dB per octave.
9271
9272 4th 24 dB per octave.
9273
9274 6th 36 dB per octave.
9275
9276 8th 48 dB per octave.
9277
9278 10th
9279 60 dB per octave.
9280
9281 12th
9282 72 dB per octave.
9283
9284 14th
9285 84 dB per octave.
9286
9287 16th
9288 96 dB per octave.
9289
9290 18th
9291 108 dB per octave.
9292
9293 20th
9294 120 dB per octave.
9295
9296 Default is 4th.
9297
9298 level
9299 Set input gain level. Allowed range is from 0 to 1. Default value
9300 is 1.
9301
9302 gains
9303 Set output gain for each band. Default value is 1 for all bands.
9304
9305 Examples
9306
9307 • Split input audio stream into two bands (low and high) with split
9308 frequency of 1500 Hz, each band will be in separate stream:
9309
9310 ffmpeg -i in.flac -filter_complex 'acrossover=split=1500[LOW][HIGH]' -map '[LOW]' low.wav -map '[HIGH]' high.wav
9311
9312 • Same as above, but with higher filter order:
9313
9314 ffmpeg -i in.flac -filter_complex 'acrossover=split=1500:order=8th[LOW][HIGH]' -map '[LOW]' low.wav -map '[HIGH]' high.wav
9315
9316 • Same as above, but also with additional middle band (frequencies
9317 between 1500 and 8000):
9318
9319 ffmpeg -i in.flac -filter_complex 'acrossover=split=1500 8000:order=8th[LOW][MID][HIGH]' -map '[LOW]' low.wav -map '[MID]' mid.wav -map '[HIGH]' high.wav
9320
9321 acrusher
9322 Reduce audio bit resolution.
9323
9324 This filter is bit crusher with enhanced functionality. A bit crusher
9325 is used to audibly reduce number of bits an audio signal is sampled
9326 with. This doesn't change the bit depth at all, it just produces the
9327 effect. Material reduced in bit depth sounds more harsh and "digital".
9328 This filter is able to even round to continuous values instead of
9329 discrete bit depths. Additionally it has a D/C offset which results in
9330 different crushing of the lower and the upper half of the signal. An
9331 Anti-Aliasing setting is able to produce "softer" crushing sounds.
9332
9333 Another feature of this filter is the logarithmic mode. This setting
9334 switches from linear distances between bits to logarithmic ones. The
9335 result is a much more "natural" sounding crusher which doesn't gate low
9336 signals for example. The human ear has a logarithmic perception, so
9337 this kind of crushing is much more pleasant. Logarithmic crushing is
9338 also able to get anti-aliased.
9339
9340 The filter accepts the following options:
9341
9342 level_in
9343 Set level in.
9344
9345 level_out
9346 Set level out.
9347
9348 bits
9349 Set bit reduction.
9350
9351 mix Set mixing amount.
9352
9353 mode
9354 Can be linear: "lin" or logarithmic: "log".
9355
9356 dc Set DC.
9357
9358 aa Set anti-aliasing.
9359
9360 samples
9361 Set sample reduction.
9362
9363 lfo Enable LFO. By default disabled.
9364
9365 lforange
9366 Set LFO range.
9367
9368 lforate
9369 Set LFO rate.
9370
9371 Commands
9372
9373 This filter supports the all above options as commands.
9374
9375 acue
9376 Delay audio filtering until a given wallclock timestamp. See the cue
9377 filter.
9378
9379 adeclick
9380 Remove impulsive noise from input audio.
9381
9382 Samples detected as impulsive noise are replaced by interpolated
9383 samples using autoregressive modelling.
9384
9385 window, w
9386 Set window size, in milliseconds. Allowed range is from 10 to 100.
9387 Default value is 55 milliseconds. This sets size of window which
9388 will be processed at once.
9389
9390 overlap, o
9391 Set window overlap, in percentage of window size. Allowed range is
9392 from 50 to 95. Default value is 75 percent. Setting this to a very
9393 high value increases impulsive noise removal but makes whole
9394 process much slower.
9395
9396 arorder, a
9397 Set autoregression order, in percentage of window size. Allowed
9398 range is from 0 to 25. Default value is 2 percent. This option also
9399 controls quality of interpolated samples using neighbour good
9400 samples.
9401
9402 threshold, t
9403 Set threshold value. Allowed range is from 1 to 100. Default value
9404 is 2. This controls the strength of impulsive noise which is going
9405 to be removed. The lower value, the more samples will be detected
9406 as impulsive noise.
9407
9408 burst, b
9409 Set burst fusion, in percentage of window size. Allowed range is 0
9410 to 10. Default value is 2. If any two samples detected as noise
9411 are spaced less than this value then any sample between those two
9412 samples will be also detected as noise.
9413
9414 method, m
9415 Set overlap method.
9416
9417 It accepts the following values:
9418
9419 add, a
9420 Select overlap-add method. Even not interpolated samples are
9421 slightly changed with this method.
9422
9423 save, s
9424 Select overlap-save method. Not interpolated samples remain
9425 unchanged.
9426
9427 Default value is "a".
9428
9429 adeclip
9430 Remove clipped samples from input audio.
9431
9432 Samples detected as clipped are replaced by interpolated samples using
9433 autoregressive modelling.
9434
9435 window, w
9436 Set window size, in milliseconds. Allowed range is from 10 to 100.
9437 Default value is 55 milliseconds. This sets size of window which
9438 will be processed at once.
9439
9440 overlap, o
9441 Set window overlap, in percentage of window size. Allowed range is
9442 from 50 to 95. Default value is 75 percent.
9443
9444 arorder, a
9445 Set autoregression order, in percentage of window size. Allowed
9446 range is from 0 to 25. Default value is 8 percent. This option also
9447 controls quality of interpolated samples using neighbour good
9448 samples.
9449
9450 threshold, t
9451 Set threshold value. Allowed range is from 1 to 100. Default value
9452 is 10. Higher values make clip detection less aggressive.
9453
9454 hsize, n
9455 Set size of histogram used to detect clips. Allowed range is from
9456 100 to 9999. Default value is 1000. Higher values make clip
9457 detection less aggressive.
9458
9459 method, m
9460 Set overlap method.
9461
9462 It accepts the following values:
9463
9464 add, a
9465 Select overlap-add method. Even not interpolated samples are
9466 slightly changed with this method.
9467
9468 save, s
9469 Select overlap-save method. Not interpolated samples remain
9470 unchanged.
9471
9472 Default value is "a".
9473
9474 adecorrelate
9475 Apply decorrelation to input audio stream.
9476
9477 The filter accepts the following options:
9478
9479 stages
9480 Set decorrelation stages of filtering. Allowed range is from 1 to
9481 16. Default value is 6.
9482
9483 seed
9484 Set random seed used for setting delay in samples across channels.
9485
9486 adelay
9487 Delay one or more audio channels.
9488
9489 Samples in delayed channel are filled with silence.
9490
9491 The filter accepts the following option:
9492
9493 delays
9494 Set list of delays in milliseconds for each channel separated by
9495 '|'. Unused delays will be silently ignored. If number of given
9496 delays is smaller than number of channels all remaining channels
9497 will not be delayed. If you want to delay exact number of samples,
9498 append 'S' to number. If you want instead to delay in seconds,
9499 append 's' to number.
9500
9501 all Use last set delay for all remaining channels. By default is
9502 disabled. This option if enabled changes how option "delays" is
9503 interpreted.
9504
9505 Examples
9506
9507 • Delay first channel by 1.5 seconds, the third channel by 0.5
9508 seconds and leave the second channel (and any other channels that
9509 may be present) unchanged.
9510
9511 adelay=1500|0|500
9512
9513 • Delay second channel by 500 samples, the third channel by 700
9514 samples and leave the first channel (and any other channels that
9515 may be present) unchanged.
9516
9517 adelay=0|500S|700S
9518
9519 • Delay all channels by same number of samples:
9520
9521 adelay=delays=64S:all=1
9522
9523 adenorm
9524 Remedy denormals in audio by adding extremely low-level noise.
9525
9526 This filter shall be placed before any filter that can produce
9527 denormals.
9528
9529 A description of the accepted parameters follows.
9530
9531 level
9532 Set level of added noise in dB. Default is "-351". Allowed range
9533 is from -451 to -90.
9534
9535 type
9536 Set type of added noise.
9537
9538 dc Add DC signal.
9539
9540 ac Add AC signal.
9541
9542 square
9543 Add square signal.
9544
9545 pulse
9546 Add pulse signal.
9547
9548 Default is "dc".
9549
9550 Commands
9551
9552 This filter supports the all above options as commands.
9553
9554 aderivative, aintegral
9555 Compute derivative/integral of audio stream.
9556
9557 Applying both filters one after another produces original audio.
9558
9559 adynamicequalizer
9560 Apply dynamic equalization to input audio stream.
9561
9562 A description of the accepted options follows.
9563
9564 threshold
9565 Set the detection threshold used to trigger equalization.
9566 Threshold detection is using bandpass filter. Default value is 0.
9567 Allowed range is from 0 to 100.
9568
9569 dfrequency
9570 Set the detection frequency in Hz used for bandpass filter used to
9571 trigger equalization. Default value is 1000 Hz. Allowed range is
9572 between 2 and 1000000 Hz.
9573
9574 dqfactor
9575 Set the detection resonance factor for bandpass filter used to
9576 trigger equalization. Default value is 1. Allowed range is from
9577 0.001 to 1000.
9578
9579 tfrequency
9580 Set the target frequency of equalization filter. Default value is
9581 1000 Hz. Allowed range is between 2 and 1000000 Hz.
9582
9583 tqfactor
9584 Set the target resonance factor for target equalization filter.
9585 Default value is 1. Allowed range is from 0.001 to 1000.
9586
9587 attack
9588 Set the amount of milliseconds the signal from detection has to
9589 rise above the detection threshold before equalization starts.
9590 Default is 20. Allowed range is between 1 and 2000.
9591
9592 release
9593 Set the amount of milliseconds the signal from detection has to
9594 fall below the detection threshold before equalization ends.
9595 Default is 200. Allowed range is between 1 and 2000.
9596
9597 knee
9598 Curve the sharp knee around the detection threshold to calculate
9599 equalization gain more softly. Default is 1. Allowed range is
9600 between 0 and 8.
9601
9602 ratio
9603 Set the ratio by which the equalization gain is raised. Default is
9604 1. Allowed range is between 1 and 20.
9605
9606 makeup
9607 Set the makeup offset in dB by which the equalization gain is
9608 raised. Default is 0. Allowed range is between 0 and 30.
9609
9610 range
9611 Set the max allowed cut/boost amount in dB. Default is 0. Allowed
9612 range is from 0 to 200.
9613
9614 slew
9615 Set the slew factor. Default is 1. Allowed range is from 1 to 200.
9616
9617 mode
9618 Set the mode of filter operation, can be one of the following:
9619
9620 listen
9621 Output only isolated bandpass signal.
9622
9623 cut Cut frequencies above detection threshold.
9624
9625 boost
9626 Boost frequencies bellow detection threshold.
9627
9628 Default mode is cut.
9629
9630 Commands
9631
9632 This filter supports the all above options as commands.
9633
9634 adynamicsmooth
9635 Apply dynamic smoothing to input audio stream.
9636
9637 A description of the accepted options follows.
9638
9639 sensitivity
9640 Set an amount of sensitivity to frequency fluctations. Default is
9641 2. Allowed range is from 0 to 1e+06.
9642
9643 basefreq
9644 Set a base frequency for smoothing. Default value is 22050.
9645 Allowed range is from 2 to 1e+06.
9646
9647 Commands
9648
9649 This filter supports the all above options as commands.
9650
9651 aecho
9652 Apply echoing to the input audio.
9653
9654 Echoes are reflected sound and can occur naturally amongst mountains
9655 (and sometimes large buildings) when talking or shouting; digital echo
9656 effects emulate this behaviour and are often used to help fill out the
9657 sound of a single instrument or vocal. The time difference between the
9658 original signal and the reflection is the "delay", and the loudness of
9659 the reflected signal is the "decay". Multiple echoes can have
9660 different delays and decays.
9661
9662 A description of the accepted parameters follows.
9663
9664 in_gain
9665 Set input gain of reflected signal. Default is 0.6.
9666
9667 out_gain
9668 Set output gain of reflected signal. Default is 0.3.
9669
9670 delays
9671 Set list of time intervals in milliseconds between original signal
9672 and reflections separated by '|'. Allowed range for each "delay" is
9673 "(0 - 90000.0]". Default is 1000.
9674
9675 decays
9676 Set list of loudness of reflected signals separated by '|'.
9677 Allowed range for each "decay" is "(0 - 1.0]". Default is 0.5.
9678
9679 Examples
9680
9681 • Make it sound as if there are twice as many instruments as are
9682 actually playing:
9683
9684 aecho=0.8:0.88:60:0.4
9685
9686 • If delay is very short, then it sounds like a (metallic) robot
9687 playing music:
9688
9689 aecho=0.8:0.88:6:0.4
9690
9691 • A longer delay will sound like an open air concert in the
9692 mountains:
9693
9694 aecho=0.8:0.9:1000:0.3
9695
9696 • Same as above but with one more mountain:
9697
9698 aecho=0.8:0.9:1000|1800:0.3|0.25
9699
9700 aemphasis
9701 Audio emphasis filter creates or restores material directly taken from
9702 LPs or emphased CDs with different filter curves. E.g. to store music
9703 on vinyl the signal has to be altered by a filter first to even out the
9704 disadvantages of this recording medium. Once the material is played
9705 back the inverse filter has to be applied to restore the distortion of
9706 the frequency response.
9707
9708 The filter accepts the following options:
9709
9710 level_in
9711 Set input gain.
9712
9713 level_out
9714 Set output gain.
9715
9716 mode
9717 Set filter mode. For restoring material use "reproduction" mode,
9718 otherwise use "production" mode. Default is "reproduction" mode.
9719
9720 type
9721 Set filter type. Selects medium. Can be one of the following:
9722
9723 col select Columbia.
9724
9725 emi select EMI.
9726
9727 bsi select BSI (78RPM).
9728
9729 riaa
9730 select RIAA.
9731
9732 cd select Compact Disc (CD).
9733
9734 50fm
9735 select 50Xs (FM).
9736
9737 75fm
9738 select 75Xs (FM).
9739
9740 50kf
9741 select 50Xs (FM-KF).
9742
9743 75kf
9744 select 75Xs (FM-KF).
9745
9746 Commands
9747
9748 This filter supports the all above options as commands.
9749
9750 aeval
9751 Modify an audio signal according to the specified expressions.
9752
9753 This filter accepts one or more expressions (one for each channel),
9754 which are evaluated and used to modify a corresponding audio signal.
9755
9756 It accepts the following parameters:
9757
9758 exprs
9759 Set the '|'-separated expressions list for each separate channel.
9760 If the number of input channels is greater than the number of
9761 expressions, the last specified expression is used for the
9762 remaining output channels.
9763
9764 channel_layout, c
9765 Set output channel layout. If not specified, the channel layout is
9766 specified by the number of expressions. If set to same, it will use
9767 by default the same input channel layout.
9768
9769 Each expression in exprs can contain the following constants and
9770 functions:
9771
9772 ch channel number of the current expression
9773
9774 n number of the evaluated sample, starting from 0
9775
9776 s sample rate
9777
9778 t time of the evaluated sample expressed in seconds
9779
9780 nb_in_channels
9781 nb_out_channels
9782 input and output number of channels
9783
9784 val(CH)
9785 the value of input channel with number CH
9786
9787 Note: this filter is slow. For faster processing you should use a
9788 dedicated filter.
9789
9790 Examples
9791
9792 • Half volume:
9793
9794 aeval=val(ch)/2:c=same
9795
9796 • Invert phase of the second channel:
9797
9798 aeval=val(0)|-val(1)
9799
9800 aexciter
9801 An exciter is used to produce high sound that is not present in the
9802 original signal. This is done by creating harmonic distortions of the
9803 signal which are restricted in range and added to the original signal.
9804 An Exciter raises the upper end of an audio signal without simply
9805 raising the higher frequencies like an equalizer would do to create a
9806 more "crisp" or "brilliant" sound.
9807
9808 The filter accepts the following options:
9809
9810 level_in
9811 Set input level prior processing of signal. Allowed range is from
9812 0 to 64. Default value is 1.
9813
9814 level_out
9815 Set output level after processing of signal. Allowed range is from
9816 0 to 64. Default value is 1.
9817
9818 amount
9819 Set the amount of harmonics added to original signal. Allowed
9820 range is from 0 to 64. Default value is 1.
9821
9822 drive
9823 Set the amount of newly created harmonics. Allowed range is from
9824 0.1 to 10. Default value is 8.5.
9825
9826 blend
9827 Set the octave of newly created harmonics. Allowed range is from
9828 -10 to 10. Default value is 0.
9829
9830 freq
9831 Set the lower frequency limit of producing harmonics in Hz.
9832 Allowed range is from 2000 to 12000 Hz. Default is 7500 Hz.
9833
9834 ceil
9835 Set the upper frequency limit of producing harmonics. Allowed
9836 range is from 9999 to 20000 Hz. If value is lower than 10000 Hz no
9837 limit is applied.
9838
9839 listen
9840 Mute the original signal and output only added harmonics. By
9841 default is disabled.
9842
9843 Commands
9844
9845 This filter supports the all above options as commands.
9846
9847 afade
9848 Apply fade-in/out effect to input audio.
9849
9850 A description of the accepted parameters follows.
9851
9852 type, t
9853 Specify the effect type, can be either "in" for fade-in, or "out"
9854 for a fade-out effect. Default is "in".
9855
9856 start_sample, ss
9857 Specify the number of the start sample for starting to apply the
9858 fade effect. Default is 0.
9859
9860 nb_samples, ns
9861 Specify the number of samples for which the fade effect has to
9862 last. At the end of the fade-in effect the output audio will have
9863 the same volume as the input audio, at the end of the fade-out
9864 transition the output audio will be silence. Default is 44100.
9865
9866 start_time, st
9867 Specify the start time of the fade effect. Default is 0. The value
9868 must be specified as a time duration; see the Time duration section
9869 in the ffmpeg-utils(1) manual for the accepted syntax. If set this
9870 option is used instead of start_sample.
9871
9872 duration, d
9873 Specify the duration of the fade effect. See the Time duration
9874 section in the ffmpeg-utils(1) manual for the accepted syntax. At
9875 the end of the fade-in effect the output audio will have the same
9876 volume as the input audio, at the end of the fade-out transition
9877 the output audio will be silence. By default the duration is
9878 determined by nb_samples. If set this option is used instead of
9879 nb_samples.
9880
9881 curve
9882 Set curve for fade transition.
9883
9884 It accepts the following values:
9885
9886 tri select triangular, linear slope (default)
9887
9888 qsin
9889 select quarter of sine wave
9890
9891 hsin
9892 select half of sine wave
9893
9894 esin
9895 select exponential sine wave
9896
9897 log select logarithmic
9898
9899 ipar
9900 select inverted parabola
9901
9902 qua select quadratic
9903
9904 cub select cubic
9905
9906 squ select square root
9907
9908 cbr select cubic root
9909
9910 par select parabola
9911
9912 exp select exponential
9913
9914 iqsin
9915 select inverted quarter of sine wave
9916
9917 ihsin
9918 select inverted half of sine wave
9919
9920 dese
9921 select double-exponential seat
9922
9923 desi
9924 select double-exponential sigmoid
9925
9926 losi
9927 select logistic sigmoid
9928
9929 sinc
9930 select sine cardinal function
9931
9932 isinc
9933 select inverted sine cardinal function
9934
9935 nofade
9936 no fade applied
9937
9938 Commands
9939
9940 This filter supports the all above options as commands.
9941
9942 Examples
9943
9944 • Fade in first 15 seconds of audio:
9945
9946 afade=t=in:ss=0:d=15
9947
9948 • Fade out last 25 seconds of a 900 seconds audio:
9949
9950 afade=t=out:st=875:d=25
9951
9952 afftdn
9953 Denoise audio samples with FFT.
9954
9955 A description of the accepted parameters follows.
9956
9957 nr Set the noise reduction in dB, allowed range is 0.01 to 97.
9958 Default value is 12 dB.
9959
9960 nf Set the noise floor in dB, allowed range is -80 to -20. Default
9961 value is -50 dB.
9962
9963 nt Set the noise type.
9964
9965 It accepts the following values:
9966
9967 w Select white noise.
9968
9969 v Select vinyl noise.
9970
9971 s Select shellac noise.
9972
9973 c Select custom noise, defined in "bn" option.
9974
9975 Default value is white noise.
9976
9977 bn Set custom band noise for every one of 15 bands. Bands are
9978 separated by ' ' or '|'.
9979
9980 rf Set the residual floor in dB, allowed range is -80 to -20. Default
9981 value is -38 dB.
9982
9983 tn Enable noise tracking. By default is disabled. With this enabled,
9984 noise floor is automatically adjusted.
9985
9986 tr Enable residual tracking. By default is disabled.
9987
9988 om Set the output mode.
9989
9990 It accepts the following values:
9991
9992 i Pass input unchanged.
9993
9994 o Pass noise filtered out.
9995
9996 n Pass only noise.
9997
9998 Default value is o.
9999
10000 Commands
10001
10002 This filter supports the following commands:
10003
10004 sample_noise, sn
10005 Start or stop measuring noise profile. Syntax for the command is :
10006 "start" or "stop" string. After measuring noise profile is stopped
10007 it will be automatically applied in filtering.
10008
10009 noise_reduction, nr
10010 Change noise reduction. Argument is single float number. Syntax
10011 for the command is : "noise_reduction"
10012
10013 noise_floor, nf
10014 Change noise floor. Argument is single float number. Syntax for
10015 the command is : "noise_floor"
10016
10017 output_mode, om
10018 Change output mode operation. Syntax for the command is : "i", "o"
10019 or "n" string.
10020
10021 afftfilt
10022 Apply arbitrary expressions to samples in frequency domain.
10023
10024 real
10025 Set frequency domain real expression for each separate channel
10026 separated by '|'. Default is "re". If the number of input channels
10027 is greater than the number of expressions, the last specified
10028 expression is used for the remaining output channels.
10029
10030 imag
10031 Set frequency domain imaginary expression for each separate channel
10032 separated by '|'. Default is "im".
10033
10034 Each expression in real and imag can contain the following
10035 constants and functions:
10036
10037 sr sample rate
10038
10039 b current frequency bin number
10040
10041 nb number of available bins
10042
10043 ch channel number of the current expression
10044
10045 chs number of channels
10046
10047 pts current frame pts
10048
10049 re current real part of frequency bin of current channel
10050
10051 im current imaginary part of frequency bin of current channel
10052
10053 real(b, ch)
10054 Return the value of real part of frequency bin at location
10055 (bin,channel)
10056
10057 imag(b, ch)
10058 Return the value of imaginary part of frequency bin at location
10059 (bin,channel)
10060
10061 win_size
10062 Set window size. Allowed range is from 16 to 131072. Default is
10063 4096
10064
10065 win_func
10066 Set window function.
10067
10068 It accepts the following values:
10069
10070 rect
10071 bartlett
10072 hann, hanning
10073 hamming
10074 blackman
10075 welch
10076 flattop
10077 bharris
10078 bnuttall
10079 bhann
10080 sine
10081 nuttall
10082 lanczos
10083 gauss
10084 tukey
10085 dolph
10086 cauchy
10087 parzen
10088 poisson
10089 bohman
10090
10091 Default is "hann".
10092
10093 overlap
10094 Set window overlap. If set to 1, the recommended overlap for
10095 selected window function will be picked. Default is 0.75.
10096
10097 Examples
10098
10099 • Leave almost only low frequencies in audio:
10100
10101 afftfilt="'real=re * (1-clip((b/nb)*b,0,1))':imag='im * (1-clip((b/nb)*b,0,1))'"
10102
10103 • Apply robotize effect:
10104
10105 afftfilt="real='hypot(re,im)*sin(0)':imag='hypot(re,im)*cos(0)':win_size=512:overlap=0.75"
10106
10107 • Apply whisper effect:
10108
10109 afftfilt="real='hypot(re,im)*cos((random(0)*2-1)*2*3.14)':imag='hypot(re,im)*sin((random(1)*2-1)*2*3.14)':win_size=128:overlap=0.8"
10110
10111 afir
10112 Apply an arbitrary Finite Impulse Response filter.
10113
10114 This filter is designed for applying long FIR filters, up to 60 seconds
10115 long.
10116
10117 It can be used as component for digital crossover filters, room
10118 equalization, cross talk cancellation, wavefield synthesis,
10119 auralization, ambiophonics, ambisonics and spatialization.
10120
10121 This filter uses the streams higher than first one as FIR coefficients.
10122 If the non-first stream holds a single channel, it will be used for all
10123 input channels in the first stream, otherwise the number of channels in
10124 the non-first stream must be same as the number of channels in the
10125 first stream.
10126
10127 It accepts the following parameters:
10128
10129 dry Set dry gain. This sets input gain.
10130
10131 wet Set wet gain. This sets final output gain.
10132
10133 length
10134 Set Impulse Response filter length. Default is 1, which means whole
10135 IR is processed.
10136
10137 gtype
10138 Enable applying gain measured from power of IR.
10139
10140 Set which approach to use for auto gain measurement.
10141
10142 none
10143 Do not apply any gain.
10144
10145 peak
10146 select peak gain, very conservative approach. This is default
10147 value.
10148
10149 dc select DC gain, limited application.
10150
10151 gn select gain to noise approach, this is most popular one.
10152
10153 irgain
10154 Set gain to be applied to IR coefficients before filtering.
10155 Allowed range is 0 to 1. This gain is applied after any gain
10156 applied with gtype option.
10157
10158 irfmt
10159 Set format of IR stream. Can be "mono" or "input". Default is
10160 "input".
10161
10162 maxir
10163 Set max allowed Impulse Response filter duration in seconds.
10164 Default is 30 seconds. Allowed range is 0.1 to 60 seconds.
10165
10166 response
10167 Show IR frequency response, magnitude(magenta), phase(green) and
10168 group delay(yellow) in additional video stream. By default it is
10169 disabled.
10170
10171 channel
10172 Set for which IR channel to display frequency response. By default
10173 is first channel displayed. This option is used only when response
10174 is enabled.
10175
10176 size
10177 Set video stream size. This option is used only when response is
10178 enabled.
10179
10180 rate
10181 Set video stream frame rate. This option is used only when response
10182 is enabled.
10183
10184 minp
10185 Set minimal partition size used for convolution. Default is 8192.
10186 Allowed range is from 1 to 32768. Lower values decreases latency
10187 at cost of higher CPU usage.
10188
10189 maxp
10190 Set maximal partition size used for convolution. Default is 8192.
10191 Allowed range is from 8 to 32768. Lower values may increase CPU
10192 usage.
10193
10194 nbirs
10195 Set number of input impulse responses streams which will be
10196 switchable at runtime. Allowed range is from 1 to 32. Default is
10197 1.
10198
10199 ir Set IR stream which will be used for convolution, starting from 0,
10200 should always be lower than supplied value by "nbirs" option.
10201 Default is 0. This option can be changed at runtime via commands.
10202
10203 Examples
10204
10205 • Apply reverb to stream using mono IR file as second input, complete
10206 command using ffmpeg:
10207
10208 ffmpeg -i input.wav -i middle_tunnel_1way_mono.wav -lavfi afir output.wav
10209
10210 aformat
10211 Set output format constraints for the input audio. The framework will
10212 negotiate the most appropriate format to minimize conversions.
10213
10214 It accepts the following parameters:
10215
10216 sample_fmts, f
10217 A '|'-separated list of requested sample formats.
10218
10219 sample_rates, r
10220 A '|'-separated list of requested sample rates.
10221
10222 channel_layouts, cl
10223 A '|'-separated list of requested channel layouts.
10224
10225 See the Channel Layout section in the ffmpeg-utils(1) manual for
10226 the required syntax.
10227
10228 If a parameter is omitted, all values are allowed.
10229
10230 Force the output to either unsigned 8-bit or signed 16-bit stereo
10231
10232 aformat=sample_fmts=u8|s16:channel_layouts=stereo
10233
10234 afreqshift
10235 Apply frequency shift to input audio samples.
10236
10237 The filter accepts the following options:
10238
10239 shift
10240 Specify frequency shift. Allowed range is -INT_MAX to INT_MAX.
10241 Default value is 0.0.
10242
10243 level
10244 Set output gain applied to final output. Allowed range is from 0.0
10245 to 1.0. Default value is 1.0.
10246
10247 order
10248 Set filter order used for filtering. Allowed range is from 1 to 16.
10249 Default value is 8.
10250
10251 Commands
10252
10253 This filter supports the all above options as commands.
10254
10255 afwtdn
10256 Reduce broadband noise from input samples using Wavelets.
10257
10258 A description of the accepted options follows.
10259
10260 sigma
10261 Set the noise sigma, allowed range is from 0 to 1. Default value
10262 is 0. This option controls strength of denoising applied to input
10263 samples. Most useful way to set this option is via decibels, eg.
10264 -45dB.
10265
10266 levels
10267 Set the number of wavelet levels of decomposition. Allowed range
10268 is from 1 to 12. Default value is 10. Setting this too low make
10269 denoising performance very poor.
10270
10271 wavet
10272 Set wavelet type for decomposition of input frame. They are sorted
10273 by number of coefficients, from lowest to highest. More
10274 coefficients means worse filtering speed, but overall better
10275 quality. Available wavelets are:
10276
10277 sym2
10278 sym4
10279 rbior68
10280 deb10
10281 sym10
10282 coif5
10283 bl3
10284 percent
10285 Set percent of full denoising. Allowed range is from 0 to 100
10286 percent. Default value is 85 percent or partial denoising.
10287
10288 profile
10289 If enabled, first input frame will be used as noise profile. If
10290 first frame samples contain non-noise performance will be very
10291 poor.
10292
10293 adaptive
10294 If enabled, input frames are analyzed for presence of noise. If
10295 noise is detected with high possibility then input frame profile
10296 will be used for processing following frames, until new noise frame
10297 is detected.
10298
10299 samples
10300 Set size of single frame in number of samples. Allowed range is
10301 from 512 to 65536. Default frame size is 8192 samples.
10302
10303 softness
10304 Set softness applied inside thresholding function. Allowed range is
10305 from 0 to 10. Default softness is 1.
10306
10307 Commands
10308
10309 This filter supports the all above options as commands.
10310
10311 agate
10312 A gate is mainly used to reduce lower parts of a signal. This kind of
10313 signal processing reduces disturbing noise between useful signals.
10314
10315 Gating is done by detecting the volume below a chosen level threshold
10316 and dividing it by the factor set with ratio. The bottom of the noise
10317 floor is set via range. Because an exact manipulation of the signal
10318 would cause distortion of the waveform the reduction can be levelled
10319 over time. This is done by setting attack and release.
10320
10321 attack determines how long the signal has to fall below the threshold
10322 before any reduction will occur and release sets the time the signal
10323 has to rise above the threshold to reduce the reduction again. Shorter
10324 signals than the chosen attack time will be left untouched.
10325
10326 level_in
10327 Set input level before filtering. Default is 1. Allowed range is
10328 from 0.015625 to 64.
10329
10330 mode
10331 Set the mode of operation. Can be "upward" or "downward". Default
10332 is "downward". If set to "upward" mode, higher parts of signal will
10333 be amplified, expanding dynamic range in upward direction.
10334 Otherwise, in case of "downward" lower parts of signal will be
10335 reduced.
10336
10337 range
10338 Set the level of gain reduction when the signal is below the
10339 threshold. Default is 0.06125. Allowed range is from 0 to 1.
10340 Setting this to 0 disables reduction and then filter behaves like
10341 expander.
10342
10343 threshold
10344 If a signal rises above this level the gain reduction is released.
10345 Default is 0.125. Allowed range is from 0 to 1.
10346
10347 ratio
10348 Set a ratio by which the signal is reduced. Default is 2. Allowed
10349 range is from 1 to 9000.
10350
10351 attack
10352 Amount of milliseconds the signal has to rise above the threshold
10353 before gain reduction stops. Default is 20 milliseconds. Allowed
10354 range is from 0.01 to 9000.
10355
10356 release
10357 Amount of milliseconds the signal has to fall below the threshold
10358 before the reduction is increased again. Default is 250
10359 milliseconds. Allowed range is from 0.01 to 9000.
10360
10361 makeup
10362 Set amount of amplification of signal after processing. Default is
10363 1. Allowed range is from 1 to 64.
10364
10365 knee
10366 Curve the sharp knee around the threshold to enter gain reduction
10367 more softly. Default is 2.828427125. Allowed range is from 1 to 8.
10368
10369 detection
10370 Choose if exact signal should be taken for detection or an RMS like
10371 one. Default is "rms". Can be "peak" or "rms".
10372
10373 link
10374 Choose if the average level between all channels or the louder
10375 channel affects the reduction. Default is "average". Can be
10376 "average" or "maximum".
10377
10378 Commands
10379
10380 This filter supports the all above options as commands.
10381
10382 aiir
10383 Apply an arbitrary Infinite Impulse Response filter.
10384
10385 It accepts the following parameters:
10386
10387 zeros, z
10388 Set B/numerator/zeros/reflection coefficients.
10389
10390 poles, p
10391 Set A/denominator/poles/ladder coefficients.
10392
10393 gains, k
10394 Set channels gains.
10395
10396 dry_gain
10397 Set input gain.
10398
10399 wet_gain
10400 Set output gain.
10401
10402 format, f
10403 Set coefficients format.
10404
10405 ll lattice-ladder function
10406
10407 sf analog transfer function
10408
10409 tf digital transfer function
10410
10411 zp Z-plane zeros/poles, cartesian (default)
10412
10413 pr Z-plane zeros/poles, polar radians
10414
10415 pd Z-plane zeros/poles, polar degrees
10416
10417 sp S-plane zeros/poles
10418
10419 process, r
10420 Set type of processing.
10421
10422 d direct processing
10423
10424 s serial processing
10425
10426 p parallel processing
10427
10428 precision, e
10429 Set filtering precision.
10430
10431 dbl double-precision floating-point (default)
10432
10433 flt single-precision floating-point
10434
10435 i32 32-bit integers
10436
10437 i16 16-bit integers
10438
10439 normalize, n
10440 Normalize filter coefficients, by default is enabled. Enabling it
10441 will normalize magnitude response at DC to 0dB.
10442
10443 mix How much to use filtered signal in output. Default is 1. Range is
10444 between 0 and 1.
10445
10446 response
10447 Show IR frequency response, magnitude(magenta), phase(green) and
10448 group delay(yellow) in additional video stream. By default it is
10449 disabled.
10450
10451 channel
10452 Set for which IR channel to display frequency response. By default
10453 is first channel displayed. This option is used only when response
10454 is enabled.
10455
10456 size
10457 Set video stream size. This option is used only when response is
10458 enabled.
10459
10460 Coefficients in "tf" and "sf" format are separated by spaces and are in
10461 ascending order.
10462
10463 Coefficients in "zp" format are separated by spaces and order of
10464 coefficients doesn't matter. Coefficients in "zp" format are complex
10465 numbers with i imaginary unit.
10466
10467 Different coefficients and gains can be provided for every channel, in
10468 such case use '|' to separate coefficients or gains. Last provided
10469 coefficients will be used for all remaining channels.
10470
10471 Examples
10472
10473 • Apply 2 pole elliptic notch at around 5000Hz for 48000 Hz sample
10474 rate:
10475
10476 aiir=k=1:z=7.957584807809675810E-1 -2.575128568908332300 3.674839853930788710 -2.57512875289799137 7.957586296317130880E-1:p=1 -2.86950072432325953 3.63022088054647218 -2.28075678147272232 6.361362326477423500E-1:f=tf:r=d
10477
10478 • Same as above but in "zp" format:
10479
10480 aiir=k=0.79575848078096756:z=0.80918701+0.58773007i 0.80918701-0.58773007i 0.80884700+0.58784055i 0.80884700-0.58784055i:p=0.63892345+0.59951235i 0.63892345-0.59951235i 0.79582691+0.44198673i 0.79582691-0.44198673i:f=zp:r=s
10481
10482 • Apply 3-rd order analog normalized Butterworth low-pass filter,
10483 using analog transfer function format:
10484
10485 aiir=z=1.3057 0 0 0:p=1.3057 2.3892 2.1860 1:f=sf:r=d
10486
10487 alimiter
10488 The limiter prevents an input signal from rising over a desired
10489 threshold. This limiter uses lookahead technology to prevent your
10490 signal from distorting. It means that there is a small delay after the
10491 signal is processed. Keep in mind that the delay it produces is the
10492 attack time you set.
10493
10494 The filter accepts the following options:
10495
10496 level_in
10497 Set input gain. Default is 1.
10498
10499 level_out
10500 Set output gain. Default is 1.
10501
10502 limit
10503 Don't let signals above this level pass the limiter. Default is 1.
10504
10505 attack
10506 The limiter will reach its attenuation level in this amount of time
10507 in milliseconds. Default is 5 milliseconds.
10508
10509 release
10510 Come back from limiting to attenuation 1.0 in this amount of
10511 milliseconds. Default is 50 milliseconds.
10512
10513 asc When gain reduction is always needed ASC takes care of releasing to
10514 an average reduction level rather than reaching a reduction of 0 in
10515 the release time.
10516
10517 asc_level
10518 Select how much the release time is affected by ASC, 0 means nearly
10519 no changes in release time while 1 produces higher release times.
10520
10521 level
10522 Auto level output signal. Default is enabled. This normalizes
10523 audio back to 0dB if enabled.
10524
10525 Depending on picked setting it is recommended to upsample input 2x or
10526 4x times with aresample before applying this filter.
10527
10528 allpass
10529 Apply a two-pole all-pass filter with central frequency (in Hz)
10530 frequency, and filter-width width. An all-pass filter changes the
10531 audio's frequency to phase relationship without changing its frequency
10532 to amplitude relationship.
10533
10534 The filter accepts the following options:
10535
10536 frequency, f
10537 Set frequency in Hz.
10538
10539 width_type, t
10540 Set method to specify band-width of filter.
10541
10542 h Hz
10543
10544 q Q-Factor
10545
10546 o octave
10547
10548 s slope
10549
10550 k kHz
10551
10552 width, w
10553 Specify the band-width of a filter in width_type units.
10554
10555 mix, m
10556 How much to use filtered signal in output. Default is 1. Range is
10557 between 0 and 1.
10558
10559 channels, c
10560 Specify which channels to filter, by default all available are
10561 filtered.
10562
10563 normalize, n
10564 Normalize biquad coefficients, by default is disabled. Enabling it
10565 will normalize magnitude response at DC to 0dB.
10566
10567 order, o
10568 Set the filter order, can be 1 or 2. Default is 2.
10569
10570 transform, a
10571 Set transform type of IIR filter.
10572
10573 di
10574 dii
10575 tdii
10576 latt
10577 svf
10578 precision, r
10579 Set precison of filtering.
10580
10581 auto
10582 Pick automatic sample format depending on surround filters.
10583
10584 s16 Always use signed 16-bit.
10585
10586 s32 Always use signed 32-bit.
10587
10588 f32 Always use float 32-bit.
10589
10590 f64 Always use float 64-bit.
10591
10592 Commands
10593
10594 This filter supports the following commands:
10595
10596 frequency, f
10597 Change allpass frequency. Syntax for the command is : "frequency"
10598
10599 width_type, t
10600 Change allpass width_type. Syntax for the command is :
10601 "width_type"
10602
10603 width, w
10604 Change allpass width. Syntax for the command is : "width"
10605
10606 mix, m
10607 Change allpass mix. Syntax for the command is : "mix"
10608
10609 aloop
10610 Loop audio samples.
10611
10612 The filter accepts the following options:
10613
10614 loop
10615 Set the number of loops. Setting this value to -1 will result in
10616 infinite loops. Default is 0.
10617
10618 size
10619 Set maximal number of samples. Default is 0.
10620
10621 start
10622 Set first sample of loop. Default is 0.
10623
10624 amerge
10625 Merge two or more audio streams into a single multi-channel stream.
10626
10627 The filter accepts the following options:
10628
10629 inputs
10630 Set the number of inputs. Default is 2.
10631
10632 If the channel layouts of the inputs are disjoint, and therefore
10633 compatible, the channel layout of the output will be set accordingly
10634 and the channels will be reordered as necessary. If the channel layouts
10635 of the inputs are not disjoint, the output will have all the channels
10636 of the first input then all the channels of the second input, in that
10637 order, and the channel layout of the output will be the default value
10638 corresponding to the total number of channels.
10639
10640 For example, if the first input is in 2.1 (FL+FR+LF) and the second
10641 input is FC+BL+BR, then the output will be in 5.1, with the channels in
10642 the following order: a1, a2, b1, a3, b2, b3 (a1 is the first channel of
10643 the first input, b1 is the first channel of the second input).
10644
10645 On the other hand, if both input are in stereo, the output channels
10646 will be in the default order: a1, a2, b1, b2, and the channel layout
10647 will be arbitrarily set to 4.0, which may or may not be the expected
10648 value.
10649
10650 All inputs must have the same sample rate, and format.
10651
10652 If inputs do not have the same duration, the output will stop with the
10653 shortest.
10654
10655 Examples
10656
10657 • Merge two mono files into a stereo stream:
10658
10659 amovie=left.wav [l] ; amovie=right.mp3 [r] ; [l] [r] amerge
10660
10661 • Multiple merges assuming 1 video stream and 6 audio streams in
10662 input.mkv:
10663
10664 ffmpeg -i input.mkv -filter_complex "[0:1][0:2][0:3][0:4][0:5][0:6] amerge=inputs=6" -c:a pcm_s16le output.mkv
10665
10666 amix
10667 Mixes multiple audio inputs into a single output.
10668
10669 Note that this filter only supports float samples (the amerge and pan
10670 audio filters support many formats). If the amix input has integer
10671 samples then aresample will be automatically inserted to perform the
10672 conversion to float samples.
10673
10674 For example
10675
10676 ffmpeg -i INPUT1 -i INPUT2 -i INPUT3 -filter_complex amix=inputs=3:duration=first:dropout_transition=3 OUTPUT
10677
10678 will mix 3 input audio streams to a single output with the same
10679 duration as the first input and a dropout transition time of 3 seconds.
10680
10681 It accepts the following parameters:
10682
10683 inputs
10684 The number of inputs. If unspecified, it defaults to 2.
10685
10686 duration
10687 How to determine the end-of-stream.
10688
10689 longest
10690 The duration of the longest input. (default)
10691
10692 shortest
10693 The duration of the shortest input.
10694
10695 first
10696 The duration of the first input.
10697
10698 dropout_transition
10699 The transition time, in seconds, for volume renormalization when an
10700 input stream ends. The default value is 2 seconds.
10701
10702 weights
10703 Specify weight of each input audio stream as sequence. Each weight
10704 is separated by space. By default all inputs have same weight.
10705
10706 normalize
10707 Always scale inputs instead of only doing summation of samples.
10708 Beware of heavy clipping if inputs are not normalized prior or
10709 after filtering by this filter if this option is disabled. By
10710 default is enabled.
10711
10712 Commands
10713
10714 This filter supports the following commands:
10715
10716 weights
10717 normalize
10718 Syntax is same as option with same name.
10719
10720 amultiply
10721 Multiply first audio stream with second audio stream and store result
10722 in output audio stream. Multiplication is done by multiplying each
10723 sample from first stream with sample at same position from second
10724 stream.
10725
10726 With this element-wise multiplication one can create amplitude fades
10727 and amplitude modulations.
10728
10729 anequalizer
10730 High-order parametric multiband equalizer for each channel.
10731
10732 It accepts the following parameters:
10733
10734 params
10735 This option string is in format: "cchn f=cf w=w g=g t=f | ..."
10736 Each equalizer band is separated by '|'.
10737
10738 chn Set channel number to which equalization will be applied. If
10739 input doesn't have that channel the entry is ignored.
10740
10741 f Set central frequency for band. If input doesn't have that
10742 frequency the entry is ignored.
10743
10744 w Set band width in Hertz.
10745
10746 g Set band gain in dB.
10747
10748 t Set filter type for band, optional, can be:
10749
10750 0 Butterworth, this is default.
10751
10752 1 Chebyshev type 1.
10753
10754 2 Chebyshev type 2.
10755
10756 curves
10757 With this option activated frequency response of anequalizer is
10758 displayed in video stream.
10759
10760 size
10761 Set video stream size. Only useful if curves option is activated.
10762
10763 mgain
10764 Set max gain that will be displayed. Only useful if curves option
10765 is activated. Setting this to a reasonable value makes it possible
10766 to display gain which is derived from neighbour bands which are too
10767 close to each other and thus produce higher gain when both are
10768 activated.
10769
10770 fscale
10771 Set frequency scale used to draw frequency response in video
10772 output. Can be linear or logarithmic. Default is logarithmic.
10773
10774 colors
10775 Set color for each channel curve which is going to be displayed in
10776 video stream. This is list of color names separated by space or by
10777 '|'. Unrecognised or missing colors will be replaced by white
10778 color.
10779
10780 Examples
10781
10782 • Lower gain by 10 of central frequency 200Hz and width 100 Hz for
10783 first 2 channels using Chebyshev type 1 filter:
10784
10785 anequalizer=c0 f=200 w=100 g=-10 t=1|c1 f=200 w=100 g=-10 t=1
10786
10787 Commands
10788
10789 This filter supports the following commands:
10790
10791 change
10792 Alter existing filter parameters. Syntax for the commands is :
10793 "fN|f=freq|w=width|g=gain"
10794
10795 fN is existing filter number, starting from 0, if no such filter is
10796 available error is returned. freq set new frequency parameter.
10797 width set new width parameter in Hertz. gain set new gain
10798 parameter in dB.
10799
10800 Full filter invocation with asendcmd may look like this:
10801 asendcmd=c='4.0 anequalizer change
10802 0|f=200|w=50|g=1',anequalizer=...
10803
10804 anlmdn
10805 Reduce broadband noise in audio samples using Non-Local Means
10806 algorithm.
10807
10808 Each sample is adjusted by looking for other samples with similar
10809 contexts. This context similarity is defined by comparing their
10810 surrounding patches of size p. Patches are searched in an area of r
10811 around the sample.
10812
10813 The filter accepts the following options:
10814
10815 strength, s
10816 Set denoising strength. Allowed range is from 0.00001 to 10.
10817 Default value is 0.00001.
10818
10819 patch, p
10820 Set patch radius duration. Allowed range is from 1 to 100
10821 milliseconds. Default value is 2 milliseconds.
10822
10823 research, r
10824 Set research radius duration. Allowed range is from 2 to 300
10825 milliseconds. Default value is 6 milliseconds.
10826
10827 output, o
10828 Set the output mode.
10829
10830 It accepts the following values:
10831
10832 i Pass input unchanged.
10833
10834 o Pass noise filtered out.
10835
10836 n Pass only noise.
10837
10838 Default value is o.
10839
10840 smooth, m
10841 Set smooth factor. Default value is 11. Allowed range is from 1 to
10842 15.
10843
10844 Commands
10845
10846 This filter supports the all above options as commands.
10847
10848 anlmf, anlms
10849 Apply Normalized Least-Mean-(Squares|Fourth) algorithm to the first
10850 audio stream using the second audio stream.
10851
10852 This adaptive filter is used to mimic a desired filter by finding the
10853 filter coefficients that relate to producing the least mean square of
10854 the error signal (difference between the desired, 2nd input audio
10855 stream and the actual signal, the 1st input audio stream).
10856
10857 A description of the accepted options follows.
10858
10859 order
10860 Set filter order.
10861
10862 mu Set filter mu.
10863
10864 eps Set the filter eps.
10865
10866 leakage
10867 Set the filter leakage.
10868
10869 out_mode
10870 It accepts the following values:
10871
10872 i Pass the 1st input.
10873
10874 d Pass the 2nd input.
10875
10876 o Pass filtered samples.
10877
10878 n Pass difference between desired and filtered samples.
10879
10880 Default value is o.
10881
10882 Examples
10883
10884 • One of many usages of this filter is noise reduction, input audio
10885 is filtered with same samples that are delayed by fixed amount, one
10886 such example for stereo audio is:
10887
10888 asplit[a][b],[a]adelay=32S|32S[a],[b][a]anlms=order=128:leakage=0.0005:mu=.5:out_mode=o
10889
10890 Commands
10891
10892 This filter supports the same commands as options, excluding option
10893 "order".
10894
10895 anull
10896 Pass the audio source unchanged to the output.
10897
10898 apad
10899 Pad the end of an audio stream with silence.
10900
10901 This can be used together with ffmpeg -shortest to extend audio streams
10902 to the same length as the video stream.
10903
10904 A description of the accepted options follows.
10905
10906 packet_size
10907 Set silence packet size. Default value is 4096.
10908
10909 pad_len
10910 Set the number of samples of silence to add to the end. After the
10911 value is reached, the stream is terminated. This option is mutually
10912 exclusive with whole_len.
10913
10914 whole_len
10915 Set the minimum total number of samples in the output audio stream.
10916 If the value is longer than the input audio length, silence is
10917 added to the end, until the value is reached. This option is
10918 mutually exclusive with pad_len.
10919
10920 pad_dur
10921 Specify the duration of samples of silence to add. See the Time
10922 duration section in the ffmpeg-utils(1) manual for the accepted
10923 syntax. Used only if set to non-negative value.
10924
10925 whole_dur
10926 Specify the minimum total duration in the output audio stream. See
10927 the Time duration section in the ffmpeg-utils(1) manual for the
10928 accepted syntax. Used only if set to non-negative value. If the
10929 value is longer than the input audio length, silence is added to
10930 the end, until the value is reached. This option is mutually
10931 exclusive with pad_dur
10932
10933 If neither the pad_len nor the whole_len nor pad_dur nor whole_dur
10934 option is set, the filter will add silence to the end of the input
10935 stream indefinitely.
10936
10937 Note that for ffmpeg 4.4 and earlier a zero pad_dur or whole_dur also
10938 caused the filter to add silence indefinitely.
10939
10940 Examples
10941
10942 • Add 1024 samples of silence to the end of the input:
10943
10944 apad=pad_len=1024
10945
10946 • Make sure the audio output will contain at least 10000 samples, pad
10947 the input with silence if required:
10948
10949 apad=whole_len=10000
10950
10951 • Use ffmpeg to pad the audio input with silence, so that the video
10952 stream will always result the shortest and will be converted until
10953 the end in the output file when using the shortest option:
10954
10955 ffmpeg -i VIDEO -i AUDIO -filter_complex "[1:0]apad" -shortest OUTPUT
10956
10957 aphaser
10958 Add a phasing effect to the input audio.
10959
10960 A phaser filter creates series of peaks and troughs in the frequency
10961 spectrum. The position of the peaks and troughs are modulated so that
10962 they vary over time, creating a sweeping effect.
10963
10964 A description of the accepted parameters follows.
10965
10966 in_gain
10967 Set input gain. Default is 0.4.
10968
10969 out_gain
10970 Set output gain. Default is 0.74
10971
10972 delay
10973 Set delay in milliseconds. Default is 3.0.
10974
10975 decay
10976 Set decay. Default is 0.4.
10977
10978 speed
10979 Set modulation speed in Hz. Default is 0.5.
10980
10981 type
10982 Set modulation type. Default is triangular.
10983
10984 It accepts the following values:
10985
10986 triangular, t
10987 sinusoidal, s
10988
10989 aphaseshift
10990 Apply phase shift to input audio samples.
10991
10992 The filter accepts the following options:
10993
10994 shift
10995 Specify phase shift. Allowed range is from -1.0 to 1.0. Default
10996 value is 0.0.
10997
10998 level
10999 Set output gain applied to final output. Allowed range is from 0.0
11000 to 1.0. Default value is 1.0.
11001
11002 order
11003 Set filter order used for filtering. Allowed range is from 1 to 16.
11004 Default value is 8.
11005
11006 Commands
11007
11008 This filter supports the all above options as commands.
11009
11010 apsyclip
11011 Apply Psychoacoustic clipper to input audio stream.
11012
11013 The filter accepts the following options:
11014
11015 level_in
11016 Set input gain. By default it is 1. Range is [0.015625 - 64].
11017
11018 level_out
11019 Set output gain. By default it is 1. Range is [0.015625 - 64].
11020
11021 clip
11022 Set the clipping start value. Default value is 0dBFS or 1.
11023
11024 diff
11025 Output only difference samples, useful to hear introduced
11026 distortions. By default is disabled.
11027
11028 adaptive
11029 Set strenght of adaptive distortion applied. Default value is 0.5.
11030 Allowed range is from 0 to 1.
11031
11032 iterations
11033 Set number of iterations of psychoacoustic clipper. Allowed range
11034 is from 1 to 20. Default value is 10.
11035
11036 level
11037 Auto level output signal. Default is disabled. This normalizes
11038 audio back to 0dBFS if enabled.
11039
11040 Commands
11041
11042 This filter supports the all above options as commands.
11043
11044 apulsator
11045 Audio pulsator is something between an autopanner and a tremolo. But
11046 it can produce funny stereo effects as well. Pulsator changes the
11047 volume of the left and right channel based on a LFO (low frequency
11048 oscillator) with different waveforms and shifted phases. This filter
11049 have the ability to define an offset between left and right channel. An
11050 offset of 0 means that both LFO shapes match each other. The left and
11051 right channel are altered equally - a conventional tremolo. An offset
11052 of 50% means that the shape of the right channel is exactly shifted in
11053 phase (or moved backwards about half of the frequency) - pulsator acts
11054 as an autopanner. At 1 both curves match again. Every setting in
11055 between moves the phase shift gapless between all stages and produces
11056 some "bypassing" sounds with sine and triangle waveforms. The more you
11057 set the offset near 1 (starting from the 0.5) the faster the signal
11058 passes from the left to the right speaker.
11059
11060 The filter accepts the following options:
11061
11062 level_in
11063 Set input gain. By default it is 1. Range is [0.015625 - 64].
11064
11065 level_out
11066 Set output gain. By default it is 1. Range is [0.015625 - 64].
11067
11068 mode
11069 Set waveform shape the LFO will use. Can be one of: sine, triangle,
11070 square, sawup or sawdown. Default is sine.
11071
11072 amount
11073 Set modulation. Define how much of original signal is affected by
11074 the LFO.
11075
11076 offset_l
11077 Set left channel offset. Default is 0. Allowed range is [0 - 1].
11078
11079 offset_r
11080 Set right channel offset. Default is 0.5. Allowed range is [0 - 1].
11081
11082 width
11083 Set pulse width. Default is 1. Allowed range is [0 - 2].
11084
11085 timing
11086 Set possible timing mode. Can be one of: bpm, ms or hz. Default is
11087 hz.
11088
11089 bpm Set bpm. Default is 120. Allowed range is [30 - 300]. Only used if
11090 timing is set to bpm.
11091
11092 ms Set ms. Default is 500. Allowed range is [10 - 2000]. Only used if
11093 timing is set to ms.
11094
11095 hz Set frequency in Hz. Default is 2. Allowed range is [0.01 - 100].
11096 Only used if timing is set to hz.
11097
11098 aresample
11099 Resample the input audio to the specified parameters, using the
11100 libswresample library. If none are specified then the filter will
11101 automatically convert between its input and output.
11102
11103 This filter is also able to stretch/squeeze the audio data to make it
11104 match the timestamps or to inject silence / cut out audio to make it
11105 match the timestamps, do a combination of both or do neither.
11106
11107 The filter accepts the syntax [sample_rate:]resampler_options, where
11108 sample_rate expresses a sample rate and resampler_options is a list of
11109 key=value pairs, separated by ":". See the "Resampler Options" section
11110 in the ffmpeg-resampler(1) manual for the complete list of supported
11111 options.
11112
11113 Examples
11114
11115 • Resample the input audio to 44100Hz:
11116
11117 aresample=44100
11118
11119 • Stretch/squeeze samples to the given timestamps, with a maximum of
11120 1000 samples per second compensation:
11121
11122 aresample=async=1000
11123
11124 areverse
11125 Reverse an audio clip.
11126
11127 Warning: This filter requires memory to buffer the entire clip, so
11128 trimming is suggested.
11129
11130 Examples
11131
11132 • Take the first 5 seconds of a clip, and reverse it.
11133
11134 atrim=end=5,areverse
11135
11136 arnndn
11137 Reduce noise from speech using Recurrent Neural Networks.
11138
11139 This filter accepts the following options:
11140
11141 model, m
11142 Set train model file to load. This option is always required.
11143
11144 mix Set how much to mix filtered samples into final output. Allowed
11145 range is from -1 to 1. Default value is 1. Negative values are
11146 special, they set how much to keep filtered noise in the final
11147 filter output. Set this option to -1 to hear actual noise removed
11148 from input signal.
11149
11150 Commands
11151
11152 This filter supports the all above options as commands.
11153
11154 asdr
11155 Measure Audio Signal-to-Distortion Ratio.
11156
11157 This filter takes two audio streams for input, and outputs first audio
11158 stream. Results are in dB per channel at end of either input.
11159
11160 asetnsamples
11161 Set the number of samples per each output audio frame.
11162
11163 The last output packet may contain a different number of samples, as
11164 the filter will flush all the remaining samples when the input audio
11165 signals its end.
11166
11167 The filter accepts the following options:
11168
11169 nb_out_samples, n
11170 Set the number of frames per each output audio frame. The number is
11171 intended as the number of samples per each channel. Default value
11172 is 1024.
11173
11174 pad, p
11175 If set to 1, the filter will pad the last audio frame with zeroes,
11176 so that the last frame will contain the same number of samples as
11177 the previous ones. Default value is 1.
11178
11179 For example, to set the number of per-frame samples to 1234 and disable
11180 padding for the last frame, use:
11181
11182 asetnsamples=n=1234:p=0
11183
11184 asetrate
11185 Set the sample rate without altering the PCM data. This will result in
11186 a change of speed and pitch.
11187
11188 The filter accepts the following options:
11189
11190 sample_rate, r
11191 Set the output sample rate. Default is 44100 Hz.
11192
11193 ashowinfo
11194 Show a line containing various information for each input audio frame.
11195 The input audio is not modified.
11196
11197 The shown line contains a sequence of key/value pairs of the form
11198 key:value.
11199
11200 The following values are shown in the output:
11201
11202 n The (sequential) number of the input frame, starting from 0.
11203
11204 pts The presentation timestamp of the input frame, in time base units;
11205 the time base depends on the filter input pad, and is usually
11206 1/sample_rate.
11207
11208 pts_time
11209 The presentation timestamp of the input frame in seconds.
11210
11211 pos position of the frame in the input stream, -1 if this information
11212 in unavailable and/or meaningless (for example in case of synthetic
11213 audio)
11214
11215 fmt The sample format.
11216
11217 chlayout
11218 The channel layout.
11219
11220 rate
11221 The sample rate for the audio frame.
11222
11223 nb_samples
11224 The number of samples (per channel) in the frame.
11225
11226 checksum
11227 The Adler-32 checksum (printed in hexadecimal) of the audio data.
11228 For planar audio, the data is treated as if all the planes were
11229 concatenated.
11230
11231 plane_checksums
11232 A list of Adler-32 checksums for each data plane.
11233
11234 asoftclip
11235 Apply audio soft clipping.
11236
11237 Soft clipping is a type of distortion effect where the amplitude of a
11238 signal is saturated along a smooth curve, rather than the abrupt shape
11239 of hard-clipping.
11240
11241 This filter accepts the following options:
11242
11243 type
11244 Set type of soft-clipping.
11245
11246 It accepts the following values:
11247
11248 hard
11249 tanh
11250 atan
11251 cubic
11252 exp
11253 alg
11254 quintic
11255 sin
11256 erf
11257 threshold
11258 Set threshold from where to start clipping. Default value is 0dB or
11259 1.
11260
11261 output
11262 Set gain applied to output. Default value is 0dB or 1.
11263
11264 param
11265 Set additional parameter which controls sigmoid function.
11266
11267 oversample
11268 Set oversampling factor.
11269
11270 Commands
11271
11272 This filter supports the all above options as commands.
11273
11274 aspectralstats
11275 Display frequency domain statistical information about the audio
11276 channels. Statistics are calculated and stored as metadata for each
11277 audio channel and for each audio frame.
11278
11279 It accepts the following option:
11280
11281 win_size
11282 Set the window length in samples. Default value is 2048. Allowed
11283 range is from 32 to 65536.
11284
11285 win_func
11286 Set window function.
11287
11288 It accepts the following values:
11289
11290 rect
11291 bartlett
11292 hann, hanning
11293 hamming
11294 blackman
11295 welch
11296 flattop
11297 bharris
11298 bnuttall
11299 bhann
11300 sine
11301 nuttall
11302 lanczos
11303 gauss
11304 tukey
11305 dolph
11306 cauchy
11307 parzen
11308 poisson
11309 bohman
11310
11311 Default is "hann".
11312
11313 overlap
11314 Set window overlap. Allowed range is from 0 to 1. Default value is
11315 0.5.
11316
11317 A list of each metadata key follows:
11318
11319 mean
11320 variance
11321 centroid
11322 spread
11323 skewness
11324 kurtosis
11325 entropy
11326 flatness
11327 crest
11328 flux
11329 slope
11330 decrease
11331 rolloff
11332
11333 asr
11334 Automatic Speech Recognition
11335
11336 This filter uses PocketSphinx for speech recognition. To enable
11337 compilation of this filter, you need to configure FFmpeg with
11338 "--enable-pocketsphinx".
11339
11340 It accepts the following options:
11341
11342 rate
11343 Set sampling rate of input audio. Defaults is 16000. This need to
11344 match speech models, otherwise one will get poor results.
11345
11346 hmm Set dictionary containing acoustic model files.
11347
11348 dict
11349 Set pronunciation dictionary.
11350
11351 lm Set language model file.
11352
11353 lmctl
11354 Set language model set.
11355
11356 lmname
11357 Set which language model to use.
11358
11359 logfn
11360 Set output for log messages.
11361
11362 The filter exports recognized speech as the frame metadata
11363 "lavfi.asr.text".
11364
11365 astats
11366 Display time domain statistical information about the audio channels.
11367 Statistics are calculated and displayed for each audio channel and,
11368 where applicable, an overall figure is also given.
11369
11370 It accepts the following option:
11371
11372 length
11373 Short window length in seconds, used for peak and trough RMS
11374 measurement. Default is 0.05 (50 milliseconds). Allowed range is
11375 "[0 - 10]".
11376
11377 metadata
11378 Set metadata injection. All the metadata keys are prefixed with
11379 "lavfi.astats.X", where "X" is channel number starting from 1 or
11380 string "Overall". Default is disabled.
11381
11382 Available keys for each channel are: DC_offset Min_level Max_level
11383 Min_difference Max_difference Mean_difference RMS_difference
11384 Peak_level RMS_peak RMS_trough Crest_factor Flat_factor Peak_count
11385 Noise_floor Noise_floor_count Entropy Bit_depth Dynamic_range
11386 Zero_crossings Zero_crossings_rate Number_of_NaNs Number_of_Infs
11387 Number_of_denormals
11388
11389 and for Overall: DC_offset Min_level Max_level Min_difference
11390 Max_difference Mean_difference RMS_difference Peak_level RMS_level
11391 RMS_peak RMS_trough Flat_factor Peak_count Noise_floor
11392 Noise_floor_count Entropy Bit_depth Number_of_samples
11393 Number_of_NaNs Number_of_Infs Number_of_denormals
11394
11395 For example full key look like this "lavfi.astats.1.DC_offset" or
11396 this "lavfi.astats.Overall.Peak_count".
11397
11398 For description what each key means read below.
11399
11400 reset
11401 Set the number of frames over which cumulative stats are calculated
11402 before being reset Default is disabled.
11403
11404 measure_perchannel
11405 Select the parameters which are measured per channel. The metadata
11406 keys can be used as flags, default is all which measures
11407 everything. none disables all per channel measurement.
11408
11409 measure_overall
11410 Select the parameters which are measured overall. The metadata keys
11411 can be used as flags, default is all which measures everything.
11412 none disables all overall measurement.
11413
11414 A description of each shown parameter follows:
11415
11416 DC offset
11417 Mean amplitude displacement from zero.
11418
11419 Min level
11420 Minimal sample level.
11421
11422 Max level
11423 Maximal sample level.
11424
11425 Min difference
11426 Minimal difference between two consecutive samples.
11427
11428 Max difference
11429 Maximal difference between two consecutive samples.
11430
11431 Mean difference
11432 Mean difference between two consecutive samples. The average of
11433 each difference between two consecutive samples.
11434
11435 RMS difference
11436 Root Mean Square difference between two consecutive samples.
11437
11438 Peak level dB
11439 RMS level dB
11440 Standard peak and RMS level measured in dBFS.
11441
11442 RMS peak dB
11443 RMS trough dB
11444 Peak and trough values for RMS level measured over a short window.
11445
11446 Crest factor
11447 Standard ratio of peak to RMS level (note: not in dB).
11448
11449 Flat factor
11450 Flatness (i.e. consecutive samples with the same value) of the
11451 signal at its peak levels (i.e. either Min level or Max level).
11452
11453 Peak count
11454 Number of occasions (not the number of samples) that the signal
11455 attained either Min level or Max level.
11456
11457 Noise floor dB
11458 Minimum local peak measured in dBFS over a short window.
11459
11460 Noise floor count
11461 Number of occasions (not the number of samples) that the signal
11462 attained Noise floor.
11463
11464 Entropy
11465 Entropy measured across whole audio. Entropy of value near 1.0 is
11466 typically measured for white noise.
11467
11468 Bit depth
11469 Overall bit depth of audio. Number of bits used for each sample.
11470
11471 Dynamic range
11472 Measured dynamic range of audio in dB.
11473
11474 Zero crossings
11475 Number of points where the waveform crosses the zero level axis.
11476
11477 Zero crossings rate
11478 Rate of Zero crossings and number of audio samples.
11479
11480 asubboost
11481 Boost subwoofer frequencies.
11482
11483 The filter accepts the following options:
11484
11485 dry Set dry gain, how much of original signal is kept. Allowed range is
11486 from 0 to 1. Default value is 0.7.
11487
11488 wet Set wet gain, how much of filtered signal is kept. Allowed range is
11489 from 0 to 1. Default value is 0.7.
11490
11491 decay
11492 Set delay line decay gain value. Allowed range is from 0 to 1.
11493 Default value is 0.7.
11494
11495 feedback
11496 Set delay line feedback gain value. Allowed range is from 0 to 1.
11497 Default value is 0.9.
11498
11499 cutoff
11500 Set cutoff frequency in Hertz. Allowed range is 50 to 900. Default
11501 value is 100.
11502
11503 slope
11504 Set slope amount for cutoff frequency. Allowed range is 0.0001 to
11505 1. Default value is 0.5.
11506
11507 delay
11508 Set delay. Allowed range is from 1 to 100. Default value is 20.
11509
11510 Commands
11511
11512 This filter supports the all above options as commands.
11513
11514 asubcut
11515 Cut subwoofer frequencies.
11516
11517 This filter allows to set custom, steeper roll off than highpass
11518 filter, and thus is able to more attenuate frequency content in stop-
11519 band.
11520
11521 The filter accepts the following options:
11522
11523 cutoff
11524 Set cutoff frequency in Hertz. Allowed range is 2 to 200. Default
11525 value is 20.
11526
11527 order
11528 Set filter order. Available values are from 3 to 20. Default value
11529 is 10.
11530
11531 level
11532 Set input gain level. Allowed range is from 0 to 1. Default value
11533 is 1.
11534
11535 Commands
11536
11537 This filter supports the all above options as commands.
11538
11539 asupercut
11540 Cut super frequencies.
11541
11542 The filter accepts the following options:
11543
11544 cutoff
11545 Set cutoff frequency in Hertz. Allowed range is 20000 to 192000.
11546 Default value is 20000.
11547
11548 order
11549 Set filter order. Available values are from 3 to 20. Default value
11550 is 10.
11551
11552 level
11553 Set input gain level. Allowed range is from 0 to 1. Default value
11554 is 1.
11555
11556 Commands
11557
11558 This filter supports the all above options as commands.
11559
11560 asuperpass
11561 Apply high order Butterworth band-pass filter.
11562
11563 The filter accepts the following options:
11564
11565 centerf
11566 Set center frequency in Hertz. Allowed range is 2 to 999999.
11567 Default value is 1000.
11568
11569 order
11570 Set filter order. Available values are from 4 to 20. Default value
11571 is 4.
11572
11573 qfactor
11574 Set Q-factor. Allowed range is from 0.01 to 100. Default value is
11575 1.
11576
11577 level
11578 Set input gain level. Allowed range is from 0 to 2. Default value
11579 is 1.
11580
11581 Commands
11582
11583 This filter supports the all above options as commands.
11584
11585 asuperstop
11586 Apply high order Butterworth band-stop filter.
11587
11588 The filter accepts the following options:
11589
11590 centerf
11591 Set center frequency in Hertz. Allowed range is 2 to 999999.
11592 Default value is 1000.
11593
11594 order
11595 Set filter order. Available values are from 4 to 20. Default value
11596 is 4.
11597
11598 qfactor
11599 Set Q-factor. Allowed range is from 0.01 to 100. Default value is
11600 1.
11601
11602 level
11603 Set input gain level. Allowed range is from 0 to 2. Default value
11604 is 1.
11605
11606 Commands
11607
11608 This filter supports the all above options as commands.
11609
11610 atempo
11611 Adjust audio tempo.
11612
11613 The filter accepts exactly one parameter, the audio tempo. If not
11614 specified then the filter will assume nominal 1.0 tempo. Tempo must be
11615 in the [0.5, 100.0] range.
11616
11617 Note that tempo greater than 2 will skip some samples rather than blend
11618 them in. If for any reason this is a concern it is always possible to
11619 daisy-chain several instances of atempo to achieve the desired product
11620 tempo.
11621
11622 Examples
11623
11624 • Slow down audio to 80% tempo:
11625
11626 atempo=0.8
11627
11628 • To speed up audio to 300% tempo:
11629
11630 atempo=3
11631
11632 • To speed up audio to 300% tempo by daisy-chaining two atempo
11633 instances:
11634
11635 atempo=sqrt(3),atempo=sqrt(3)
11636
11637 Commands
11638
11639 This filter supports the following commands:
11640
11641 tempo
11642 Change filter tempo scale factor. Syntax for the command is :
11643 "tempo"
11644
11645 atilt
11646 Apply spectral tilt filter to audio stream.
11647
11648 This filter apply any spectral roll-off slope over any specified
11649 frequency band.
11650
11651 The filter accepts the following options:
11652
11653 freq
11654 Set central frequency of tilt in Hz. Default is 10000 Hz.
11655
11656 slope
11657 Set slope direction of tilt. Default is 0. Allowed range is from -1
11658 to 1.
11659
11660 width
11661 Set width of tilt. Default is 1000. Allowed range is from 100 to
11662 10000.
11663
11664 order
11665 Set order of tilt filter.
11666
11667 level
11668 Set input volume level. Allowed range is from 0 to 4. Defalt is 1.
11669
11670 Commands
11671
11672 This filter supports the all above options as commands.
11673
11674 atrim
11675 Trim the input so that the output contains one continuous subpart of
11676 the input.
11677
11678 It accepts the following parameters:
11679
11680 start
11681 Timestamp (in seconds) of the start of the section to keep. I.e.
11682 the audio sample with the timestamp start will be the first sample
11683 in the output.
11684
11685 end Specify time of the first audio sample that will be dropped, i.e.
11686 the audio sample immediately preceding the one with the timestamp
11687 end will be the last sample in the output.
11688
11689 start_pts
11690 Same as start, except this option sets the start timestamp in
11691 samples instead of seconds.
11692
11693 end_pts
11694 Same as end, except this option sets the end timestamp in samples
11695 instead of seconds.
11696
11697 duration
11698 The maximum duration of the output in seconds.
11699
11700 start_sample
11701 The number of the first sample that should be output.
11702
11703 end_sample
11704 The number of the first sample that should be dropped.
11705
11706 start, end, and duration are expressed as time duration specifications;
11707 see the Time duration section in the ffmpeg-utils(1) manual.
11708
11709 Note that the first two sets of the start/end options and the duration
11710 option look at the frame timestamp, while the _sample options simply
11711 count the samples that pass through the filter. So start/end_pts and
11712 start/end_sample will give different results when the timestamps are
11713 wrong, inexact or do not start at zero. Also note that this filter does
11714 not modify the timestamps. If you wish to have the output timestamps
11715 start at zero, insert the asetpts filter after the atrim filter.
11716
11717 If multiple start or end options are set, this filter tries to be
11718 greedy and keep all samples that match at least one of the specified
11719 constraints. To keep only the part that matches all the constraints at
11720 once, chain multiple atrim filters.
11721
11722 The defaults are such that all the input is kept. So it is possible to
11723 set e.g. just the end values to keep everything before the specified
11724 time.
11725
11726 Examples:
11727
11728 • Drop everything except the second minute of input:
11729
11730 ffmpeg -i INPUT -af atrim=60:120
11731
11732 • Keep only the first 1000 samples:
11733
11734 ffmpeg -i INPUT -af atrim=end_sample=1000
11735
11736 axcorrelate
11737 Calculate normalized windowed cross-correlation between two input audio
11738 streams.
11739
11740 Resulted samples are always between -1 and 1 inclusive. If result is 1
11741 it means two input samples are highly correlated in that selected
11742 segment. Result 0 means they are not correlated at all. If result is
11743 -1 it means two input samples are out of phase, which means they cancel
11744 each other.
11745
11746 The filter accepts the following options:
11747
11748 size
11749 Set size of segment over which cross-correlation is calculated.
11750 Default is 256. Allowed range is from 2 to 131072.
11751
11752 algo
11753 Set algorithm for cross-correlation. Can be "slow" or "fast".
11754 Default is "slow". Fast algorithm assumes mean values over any
11755 given segment are always zero and thus need much less calculations
11756 to make. This is generally not true, but is valid for typical
11757 audio streams.
11758
11759 Examples
11760
11761 • Calculate correlation between channels in stereo audio stream:
11762
11763 ffmpeg -i stereo.wav -af channelsplit,axcorrelate=size=1024:algo=fast correlation.wav
11764
11765 bandpass
11766 Apply a two-pole Butterworth band-pass filter with central frequency
11767 frequency, and (3dB-point) band-width width. The csg option selects a
11768 constant skirt gain (peak gain = Q) instead of the default: constant
11769 0dB peak gain. The filter roll off at 6dB per octave (20dB per
11770 decade).
11771
11772 The filter accepts the following options:
11773
11774 frequency, f
11775 Set the filter's central frequency. Default is 3000.
11776
11777 csg Constant skirt gain if set to 1. Defaults to 0.
11778
11779 width_type, t
11780 Set method to specify band-width of filter.
11781
11782 h Hz
11783
11784 q Q-Factor
11785
11786 o octave
11787
11788 s slope
11789
11790 k kHz
11791
11792 width, w
11793 Specify the band-width of a filter in width_type units.
11794
11795 mix, m
11796 How much to use filtered signal in output. Default is 1. Range is
11797 between 0 and 1.
11798
11799 channels, c
11800 Specify which channels to filter, by default all available are
11801 filtered.
11802
11803 normalize, n
11804 Normalize biquad coefficients, by default is disabled. Enabling it
11805 will normalize magnitude response at DC to 0dB.
11806
11807 transform, a
11808 Set transform type of IIR filter.
11809
11810 di
11811 dii
11812 tdii
11813 latt
11814 svf
11815 precision, r
11816 Set precison of filtering.
11817
11818 auto
11819 Pick automatic sample format depending on surround filters.
11820
11821 s16 Always use signed 16-bit.
11822
11823 s32 Always use signed 32-bit.
11824
11825 f32 Always use float 32-bit.
11826
11827 f64 Always use float 64-bit.
11828
11829 Commands
11830
11831 This filter supports the following commands:
11832
11833 frequency, f
11834 Change bandpass frequency. Syntax for the command is : "frequency"
11835
11836 width_type, t
11837 Change bandpass width_type. Syntax for the command is :
11838 "width_type"
11839
11840 width, w
11841 Change bandpass width. Syntax for the command is : "width"
11842
11843 mix, m
11844 Change bandpass mix. Syntax for the command is : "mix"
11845
11846 bandreject
11847 Apply a two-pole Butterworth band-reject filter with central frequency
11848 frequency, and (3dB-point) band-width width. The filter roll off at
11849 6dB per octave (20dB per decade).
11850
11851 The filter accepts the following options:
11852
11853 frequency, f
11854 Set the filter's central frequency. Default is 3000.
11855
11856 width_type, t
11857 Set method to specify band-width of filter.
11858
11859 h Hz
11860
11861 q Q-Factor
11862
11863 o octave
11864
11865 s slope
11866
11867 k kHz
11868
11869 width, w
11870 Specify the band-width of a filter in width_type units.
11871
11872 mix, m
11873 How much to use filtered signal in output. Default is 1. Range is
11874 between 0 and 1.
11875
11876 channels, c
11877 Specify which channels to filter, by default all available are
11878 filtered.
11879
11880 normalize, n
11881 Normalize biquad coefficients, by default is disabled. Enabling it
11882 will normalize magnitude response at DC to 0dB.
11883
11884 transform, a
11885 Set transform type of IIR filter.
11886
11887 di
11888 dii
11889 tdii
11890 latt
11891 svf
11892 precision, r
11893 Set precison of filtering.
11894
11895 auto
11896 Pick automatic sample format depending on surround filters.
11897
11898 s16 Always use signed 16-bit.
11899
11900 s32 Always use signed 32-bit.
11901
11902 f32 Always use float 32-bit.
11903
11904 f64 Always use float 64-bit.
11905
11906 Commands
11907
11908 This filter supports the following commands:
11909
11910 frequency, f
11911 Change bandreject frequency. Syntax for the command is :
11912 "frequency"
11913
11914 width_type, t
11915 Change bandreject width_type. Syntax for the command is :
11916 "width_type"
11917
11918 width, w
11919 Change bandreject width. Syntax for the command is : "width"
11920
11921 mix, m
11922 Change bandreject mix. Syntax for the command is : "mix"
11923
11924 bass, lowshelf
11925 Boost or cut the bass (lower) frequencies of the audio using a two-pole
11926 shelving filter with a response similar to that of a standard hi-fi's
11927 tone-controls. This is also known as shelving equalisation (EQ).
11928
11929 The filter accepts the following options:
11930
11931 gain, g
11932 Give the gain at 0 Hz. Its useful range is about -20 (for a large
11933 cut) to +20 (for a large boost). Beware of clipping when using a
11934 positive gain.
11935
11936 frequency, f
11937 Set the filter's central frequency and so can be used to extend or
11938 reduce the frequency range to be boosted or cut. The default value
11939 is 100 Hz.
11940
11941 width_type, t
11942 Set method to specify band-width of filter.
11943
11944 h Hz
11945
11946 q Q-Factor
11947
11948 o octave
11949
11950 s slope
11951
11952 k kHz
11953
11954 width, w
11955 Determine how steep is the filter's shelf transition.
11956
11957 poles, p
11958 Set number of poles. Default is 2.
11959
11960 mix, m
11961 How much to use filtered signal in output. Default is 1. Range is
11962 between 0 and 1.
11963
11964 channels, c
11965 Specify which channels to filter, by default all available are
11966 filtered.
11967
11968 normalize, n
11969 Normalize biquad coefficients, by default is disabled. Enabling it
11970 will normalize magnitude response at DC to 0dB.
11971
11972 transform, a
11973 Set transform type of IIR filter.
11974
11975 di
11976 dii
11977 tdii
11978 latt
11979 svf
11980 precision, r
11981 Set precison of filtering.
11982
11983 auto
11984 Pick automatic sample format depending on surround filters.
11985
11986 s16 Always use signed 16-bit.
11987
11988 s32 Always use signed 32-bit.
11989
11990 f32 Always use float 32-bit.
11991
11992 f64 Always use float 64-bit.
11993
11994 Commands
11995
11996 This filter supports the following commands:
11997
11998 frequency, f
11999 Change bass frequency. Syntax for the command is : "frequency"
12000
12001 width_type, t
12002 Change bass width_type. Syntax for the command is : "width_type"
12003
12004 width, w
12005 Change bass width. Syntax for the command is : "width"
12006
12007 gain, g
12008 Change bass gain. Syntax for the command is : "gain"
12009
12010 mix, m
12011 Change bass mix. Syntax for the command is : "mix"
12012
12013 biquad
12014 Apply a biquad IIR filter with the given coefficients. Where b0, b1,
12015 b2 and a0, a1, a2 are the numerator and denominator coefficients
12016 respectively. and channels, c specify which channels to filter, by
12017 default all available are filtered.
12018
12019 Commands
12020
12021 This filter supports the following commands:
12022
12023 a0
12024 a1
12025 a2
12026 b0
12027 b1
12028 b2 Change biquad parameter. Syntax for the command is : "value"
12029
12030 mix, m
12031 How much to use filtered signal in output. Default is 1. Range is
12032 between 0 and 1.
12033
12034 channels, c
12035 Specify which channels to filter, by default all available are
12036 filtered.
12037
12038 normalize, n
12039 Normalize biquad coefficients, by default is disabled. Enabling it
12040 will normalize magnitude response at DC to 0dB.
12041
12042 transform, a
12043 Set transform type of IIR filter.
12044
12045 di
12046 dii
12047 tdii
12048 latt
12049 svf
12050 precision, r
12051 Set precison of filtering.
12052
12053 auto
12054 Pick automatic sample format depending on surround filters.
12055
12056 s16 Always use signed 16-bit.
12057
12058 s32 Always use signed 32-bit.
12059
12060 f32 Always use float 32-bit.
12061
12062 f64 Always use float 64-bit.
12063
12064 bs2b
12065 Bauer stereo to binaural transformation, which improves headphone
12066 listening of stereo audio records.
12067
12068 To enable compilation of this filter you need to configure FFmpeg with
12069 "--enable-libbs2b".
12070
12071 It accepts the following parameters:
12072
12073 profile
12074 Pre-defined crossfeed level.
12075
12076 default
12077 Default level (fcut=700, feed=50).
12078
12079 cmoy
12080 Chu Moy circuit (fcut=700, feed=60).
12081
12082 jmeier
12083 Jan Meier circuit (fcut=650, feed=95).
12084
12085 fcut
12086 Cut frequency (in Hz).
12087
12088 feed
12089 Feed level (in Hz).
12090
12091 channelmap
12092 Remap input channels to new locations.
12093
12094 It accepts the following parameters:
12095
12096 map Map channels from input to output. The argument is a '|'-separated
12097 list of mappings, each in the "in_channel-out_channel" or
12098 in_channel form. in_channel can be either the name of the input
12099 channel (e.g. FL for front left) or its index in the input channel
12100 layout. out_channel is the name of the output channel or its index
12101 in the output channel layout. If out_channel is not given then it
12102 is implicitly an index, starting with zero and increasing by one
12103 for each mapping.
12104
12105 channel_layout
12106 The channel layout of the output stream.
12107
12108 If no mapping is present, the filter will implicitly map input channels
12109 to output channels, preserving indices.
12110
12111 Examples
12112
12113 • For example, assuming a 5.1+downmix input MOV file,
12114
12115 ffmpeg -i in.mov -filter 'channelmap=map=DL-FL|DR-FR' out.wav
12116
12117 will create an output WAV file tagged as stereo from the downmix
12118 channels of the input.
12119
12120 • To fix a 5.1 WAV improperly encoded in AAC's native channel order
12121
12122 ffmpeg -i in.wav -filter 'channelmap=1|2|0|5|3|4:5.1' out.wav
12123
12124 channelsplit
12125 Split each channel from an input audio stream into a separate output
12126 stream.
12127
12128 It accepts the following parameters:
12129
12130 channel_layout
12131 The channel layout of the input stream. The default is "stereo".
12132
12133 channels
12134 A channel layout describing the channels to be extracted as
12135 separate output streams or "all" to extract each input channel as a
12136 separate stream. The default is "all".
12137
12138 Choosing channels not present in channel layout in the input will
12139 result in an error.
12140
12141 Examples
12142
12143 • For example, assuming a stereo input MP3 file,
12144
12145 ffmpeg -i in.mp3 -filter_complex channelsplit out.mkv
12146
12147 will create an output Matroska file with two audio streams, one
12148 containing only the left channel and the other the right channel.
12149
12150 • Split a 5.1 WAV file into per-channel files:
12151
12152 ffmpeg -i in.wav -filter_complex
12153 'channelsplit=channel_layout=5.1[FL][FR][FC][LFE][SL][SR]'
12154 -map '[FL]' front_left.wav -map '[FR]' front_right.wav -map '[FC]'
12155 front_center.wav -map '[LFE]' lfe.wav -map '[SL]' side_left.wav -map '[SR]'
12156 side_right.wav
12157
12158 • Extract only LFE from a 5.1 WAV file:
12159
12160 ffmpeg -i in.wav -filter_complex 'channelsplit=channel_layout=5.1:channels=LFE[LFE]'
12161 -map '[LFE]' lfe.wav
12162
12163 chorus
12164 Add a chorus effect to the audio.
12165
12166 Can make a single vocal sound like a chorus, but can also be applied to
12167 instrumentation.
12168
12169 Chorus resembles an echo effect with a short delay, but whereas with
12170 echo the delay is constant, with chorus, it is varied using using
12171 sinusoidal or triangular modulation. The modulation depth defines the
12172 range the modulated delay is played before or after the delay. Hence
12173 the delayed sound will sound slower or faster, that is the delayed
12174 sound tuned around the original one, like in a chorus where some vocals
12175 are slightly off key.
12176
12177 It accepts the following parameters:
12178
12179 in_gain
12180 Set input gain. Default is 0.4.
12181
12182 out_gain
12183 Set output gain. Default is 0.4.
12184
12185 delays
12186 Set delays. A typical delay is around 40ms to 60ms.
12187
12188 decays
12189 Set decays.
12190
12191 speeds
12192 Set speeds.
12193
12194 depths
12195 Set depths.
12196
12197 Examples
12198
12199 • A single delay:
12200
12201 chorus=0.7:0.9:55:0.4:0.25:2
12202
12203 • Two delays:
12204
12205 chorus=0.6:0.9:50|60:0.4|0.32:0.25|0.4:2|1.3
12206
12207 • Fuller sounding chorus with three delays:
12208
12209 chorus=0.5:0.9:50|60|40:0.4|0.32|0.3:0.25|0.4|0.3:2|2.3|1.3
12210
12211 compand
12212 Compress or expand the audio's dynamic range.
12213
12214 It accepts the following parameters:
12215
12216 attacks
12217 decays
12218 A list of times in seconds for each channel over which the
12219 instantaneous level of the input signal is averaged to determine
12220 its volume. attacks refers to increase of volume and decays refers
12221 to decrease of volume. For most situations, the attack time
12222 (response to the audio getting louder) should be shorter than the
12223 decay time, because the human ear is more sensitive to sudden loud
12224 audio than sudden soft audio. A typical value for attack is 0.3
12225 seconds and a typical value for decay is 0.8 seconds. If specified
12226 number of attacks & decays is lower than number of channels, the
12227 last set attack/decay will be used for all remaining channels.
12228
12229 points
12230 A list of points for the transfer function, specified in dB
12231 relative to the maximum possible signal amplitude. Each key points
12232 list must be defined using the following syntax:
12233 "x0/y0|x1/y1|x2/y2|...." or "x0/y0 x1/y1 x2/y2 ...."
12234
12235 The input values must be in strictly increasing order but the
12236 transfer function does not have to be monotonically rising. The
12237 point "0/0" is assumed but may be overridden (by "0/out-dBn").
12238 Typical values for the transfer function are "-70/-70|-60/-20|1/0".
12239
12240 soft-knee
12241 Set the curve radius in dB for all joints. It defaults to 0.01.
12242
12243 gain
12244 Set the additional gain in dB to be applied at all points on the
12245 transfer function. This allows for easy adjustment of the overall
12246 gain. It defaults to 0.
12247
12248 volume
12249 Set an initial volume, in dB, to be assumed for each channel when
12250 filtering starts. This permits the user to supply a nominal level
12251 initially, so that, for example, a very large gain is not applied
12252 to initial signal levels before the companding has begun to
12253 operate. A typical value for audio which is initially quiet is -90
12254 dB. It defaults to 0.
12255
12256 delay
12257 Set a delay, in seconds. The input audio is analyzed immediately,
12258 but audio is delayed before being fed to the volume adjuster.
12259 Specifying a delay approximately equal to the attack/decay times
12260 allows the filter to effectively operate in predictive rather than
12261 reactive mode. It defaults to 0.
12262
12263 Examples
12264
12265 • Make music with both quiet and loud passages suitable for listening
12266 to in a noisy environment:
12267
12268 compand=.3|.3:1|1:-90/-60|-60/-40|-40/-30|-20/-20:6:0:-90:0.2
12269
12270 Another example for audio with whisper and explosion parts:
12271
12272 compand=0|0:1|1:-90/-900|-70/-70|-30/-9|0/-3:6:0:0:0
12273
12274 • A noise gate for when the noise is at a lower level than the
12275 signal:
12276
12277 compand=.1|.1:.2|.2:-900/-900|-50.1/-900|-50/-50:.01:0:-90:.1
12278
12279 • Here is another noise gate, this time for when the noise is at a
12280 higher level than the signal (making it, in some ways, similar to
12281 squelch):
12282
12283 compand=.1|.1:.1|.1:-45.1/-45.1|-45/-900|0/-900:.01:45:-90:.1
12284
12285 • 2:1 compression starting at -6dB:
12286
12287 compand=points=-80/-80|-6/-6|0/-3.8|20/3.5
12288
12289 • 2:1 compression starting at -9dB:
12290
12291 compand=points=-80/-80|-9/-9|0/-5.3|20/2.9
12292
12293 • 2:1 compression starting at -12dB:
12294
12295 compand=points=-80/-80|-12/-12|0/-6.8|20/1.9
12296
12297 • 2:1 compression starting at -18dB:
12298
12299 compand=points=-80/-80|-18/-18|0/-9.8|20/0.7
12300
12301 • 3:1 compression starting at -15dB:
12302
12303 compand=points=-80/-80|-15/-15|0/-10.8|20/-5.2
12304
12305 • Compressor/Gate:
12306
12307 compand=points=-80/-105|-62/-80|-15.4/-15.4|0/-12|20/-7.6
12308
12309 • Expander:
12310
12311 compand=attacks=0:points=-80/-169|-54/-80|-49.5/-64.6|-41.1/-41.1|-25.8/-15|-10.8/-4.5|0/0|20/8.3
12312
12313 • Hard limiter at -6dB:
12314
12315 compand=attacks=0:points=-80/-80|-6/-6|20/-6
12316
12317 • Hard limiter at -12dB:
12318
12319 compand=attacks=0:points=-80/-80|-12/-12|20/-12
12320
12321 • Hard noise gate at -35 dB:
12322
12323 compand=attacks=0:points=-80/-115|-35.1/-80|-35/-35|20/20
12324
12325 • Soft limiter:
12326
12327 compand=attacks=0:points=-80/-80|-12.4/-12.4|-6/-8|0/-6.8|20/-2.8
12328
12329 compensationdelay
12330 Compensation Delay Line is a metric based delay to compensate differing
12331 positions of microphones or speakers.
12332
12333 For example, you have recorded guitar with two microphones placed in
12334 different locations. Because the front of sound wave has fixed speed in
12335 normal conditions, the phasing of microphones can vary and depends on
12336 their location and interposition. The best sound mix can be achieved
12337 when these microphones are in phase (synchronized). Note that a
12338 distance of ~30 cm between microphones makes one microphone capture the
12339 signal in antiphase to the other microphone. That makes the final mix
12340 sound moody. This filter helps to solve phasing problems by adding
12341 different delays to each microphone track and make them synchronized.
12342
12343 The best result can be reached when you take one track as base and
12344 synchronize other tracks one by one with it. Remember that
12345 synchronization/delay tolerance depends on sample rate, too. Higher
12346 sample rates will give more tolerance.
12347
12348 The filter accepts the following parameters:
12349
12350 mm Set millimeters distance. This is compensation distance for fine
12351 tuning. Default is 0.
12352
12353 cm Set cm distance. This is compensation distance for tightening
12354 distance setup. Default is 0.
12355
12356 m Set meters distance. This is compensation distance for hard
12357 distance setup. Default is 0.
12358
12359 dry Set dry amount. Amount of unprocessed (dry) signal. Default is 0.
12360
12361 wet Set wet amount. Amount of processed (wet) signal. Default is 1.
12362
12363 temp
12364 Set temperature in degrees Celsius. This is the temperature of the
12365 environment. Default is 20.
12366
12367 crossfeed
12368 Apply headphone crossfeed filter.
12369
12370 Crossfeed is the process of blending the left and right channels of
12371 stereo audio recording. It is mainly used to reduce extreme stereo
12372 separation of low frequencies.
12373
12374 The intent is to produce more speaker like sound to the listener.
12375
12376 The filter accepts the following options:
12377
12378 strength
12379 Set strength of crossfeed. Default is 0.2. Allowed range is from 0
12380 to 1. This sets gain of low shelf filter for side part of stereo
12381 image. Default is -6dB. Max allowed is -30db when strength is set
12382 to 1.
12383
12384 range
12385 Set soundstage wideness. Default is 0.5. Allowed range is from 0 to
12386 1. This sets cut off frequency of low shelf filter. Default is cut
12387 off near 1550 Hz. With range set to 1 cut off frequency is set to
12388 2100 Hz.
12389
12390 slope
12391 Set curve slope of low shelf filter. Default is 0.5. Allowed range
12392 is from 0.01 to 1.
12393
12394 level_in
12395 Set input gain. Default is 0.9.
12396
12397 level_out
12398 Set output gain. Default is 1.
12399
12400 Commands
12401
12402 This filter supports the all above options as commands.
12403
12404 crystalizer
12405 Simple algorithm for audio noise sharpening.
12406
12407 This filter linearly increases differences betweeen each audio sample.
12408
12409 The filter accepts the following options:
12410
12411 i Sets the intensity of effect (default: 2.0). Must be in range
12412 between -10.0 to 0 (unchanged sound) to 10.0 (maximum effect). To
12413 inverse filtering use negative value.
12414
12415 c Enable clipping. By default is enabled.
12416
12417 Commands
12418
12419 This filter supports the all above options as commands.
12420
12421 dcshift
12422 Apply a DC shift to the audio.
12423
12424 This can be useful to remove a DC offset (caused perhaps by a hardware
12425 problem in the recording chain) from the audio. The effect of a DC
12426 offset is reduced headroom and hence volume. The astats filter can be
12427 used to determine if a signal has a DC offset.
12428
12429 shift
12430 Set the DC shift, allowed range is [-1, 1]. It indicates the amount
12431 to shift the audio.
12432
12433 limitergain
12434 Optional. It should have a value much less than 1 (e.g. 0.05 or
12435 0.02) and is used to prevent clipping.
12436
12437 deesser
12438 Apply de-essing to the audio samples.
12439
12440 i Set intensity for triggering de-essing. Allowed range is from 0 to
12441 1. Default is 0.
12442
12443 m Set amount of ducking on treble part of sound. Allowed range is
12444 from 0 to 1. Default is 0.5.
12445
12446 f How much of original frequency content to keep when de-essing.
12447 Allowed range is from 0 to 1. Default is 0.5.
12448
12449 s Set the output mode.
12450
12451 It accepts the following values:
12452
12453 i Pass input unchanged.
12454
12455 o Pass ess filtered out.
12456
12457 e Pass only ess.
12458
12459 Default value is o.
12460
12461 drmeter
12462 Measure audio dynamic range.
12463
12464 DR values of 14 and higher is found in very dynamic material. DR of 8
12465 to 13 is found in transition material. And anything less that 8 have
12466 very poor dynamics and is very compressed.
12467
12468 The filter accepts the following options:
12469
12470 length
12471 Set window length in seconds used to split audio into segments of
12472 equal length. Default is 3 seconds.
12473
12474 dynaudnorm
12475 Dynamic Audio Normalizer.
12476
12477 This filter applies a certain amount of gain to the input audio in
12478 order to bring its peak magnitude to a target level (e.g. 0 dBFS).
12479 However, in contrast to more "simple" normalization algorithms, the
12480 Dynamic Audio Normalizer *dynamically* re-adjusts the gain factor to
12481 the input audio. This allows for applying extra gain to the "quiet"
12482 sections of the audio while avoiding distortions or clipping the "loud"
12483 sections. In other words: The Dynamic Audio Normalizer will "even out"
12484 the volume of quiet and loud sections, in the sense that the volume of
12485 each section is brought to the same target level. Note, however, that
12486 the Dynamic Audio Normalizer achieves this goal *without* applying
12487 "dynamic range compressing". It will retain 100% of the dynamic range
12488 *within* each section of the audio file.
12489
12490 framelen, f
12491 Set the frame length in milliseconds. In range from 10 to 8000
12492 milliseconds. Default is 500 milliseconds. The Dynamic Audio
12493 Normalizer processes the input audio in small chunks, referred to
12494 as frames. This is required, because a peak magnitude has no
12495 meaning for just a single sample value. Instead, we need to
12496 determine the peak magnitude for a contiguous sequence of sample
12497 values. While a "standard" normalizer would simply use the peak
12498 magnitude of the complete file, the Dynamic Audio Normalizer
12499 determines the peak magnitude individually for each frame. The
12500 length of a frame is specified in milliseconds. By default, the
12501 Dynamic Audio Normalizer uses a frame length of 500 milliseconds,
12502 which has been found to give good results with most files. Note
12503 that the exact frame length, in number of samples, will be
12504 determined automatically, based on the sampling rate of the
12505 individual input audio file.
12506
12507 gausssize, g
12508 Set the Gaussian filter window size. In range from 3 to 301, must
12509 be odd number. Default is 31. Probably the most important
12510 parameter of the Dynamic Audio Normalizer is the "window size" of
12511 the Gaussian smoothing filter. The filter's window size is
12512 specified in frames, centered around the current frame. For the
12513 sake of simplicity, this must be an odd number. Consequently, the
12514 default value of 31 takes into account the current frame, as well
12515 as the 15 preceding frames and the 15 subsequent frames. Using a
12516 larger window results in a stronger smoothing effect and thus in
12517 less gain variation, i.e. slower gain adaptation. Conversely, using
12518 a smaller window results in a weaker smoothing effect and thus in
12519 more gain variation, i.e. faster gain adaptation. In other words,
12520 the more you increase this value, the more the Dynamic Audio
12521 Normalizer will behave like a "traditional" normalization filter.
12522 On the contrary, the more you decrease this value, the more the
12523 Dynamic Audio Normalizer will behave like a dynamic range
12524 compressor.
12525
12526 peak, p
12527 Set the target peak value. This specifies the highest permissible
12528 magnitude level for the normalized audio input. This filter will
12529 try to approach the target peak magnitude as closely as possible,
12530 but at the same time it also makes sure that the normalized signal
12531 will never exceed the peak magnitude. A frame's maximum local gain
12532 factor is imposed directly by the target peak magnitude. The
12533 default value is 0.95 and thus leaves a headroom of 5%*. It is not
12534 recommended to go above this value.
12535
12536 maxgain, m
12537 Set the maximum gain factor. In range from 1.0 to 100.0. Default is
12538 10.0. The Dynamic Audio Normalizer determines the maximum possible
12539 (local) gain factor for each input frame, i.e. the maximum gain
12540 factor that does not result in clipping or distortion. The maximum
12541 gain factor is determined by the frame's highest magnitude sample.
12542 However, the Dynamic Audio Normalizer additionally bounds the
12543 frame's maximum gain factor by a predetermined (global) maximum
12544 gain factor. This is done in order to avoid excessive gain factors
12545 in "silent" or almost silent frames. By default, the maximum gain
12546 factor is 10.0, For most inputs the default value should be
12547 sufficient and it usually is not recommended to increase this
12548 value. Though, for input with an extremely low overall volume
12549 level, it may be necessary to allow even higher gain factors. Note,
12550 however, that the Dynamic Audio Normalizer does not simply apply a
12551 "hard" threshold (i.e. cut off values above the threshold).
12552 Instead, a "sigmoid" threshold function will be applied. This way,
12553 the gain factors will smoothly approach the threshold value, but
12554 never exceed that value.
12555
12556 targetrms, r
12557 Set the target RMS. In range from 0.0 to 1.0. Default is 0.0 -
12558 disabled. By default, the Dynamic Audio Normalizer performs "peak"
12559 normalization. This means that the maximum local gain factor for
12560 each frame is defined (only) by the frame's highest magnitude
12561 sample. This way, the samples can be amplified as much as possible
12562 without exceeding the maximum signal level, i.e. without clipping.
12563 Optionally, however, the Dynamic Audio Normalizer can also take
12564 into account the frame's root mean square, abbreviated RMS. In
12565 electrical engineering, the RMS is commonly used to determine the
12566 power of a time-varying signal. It is therefore considered that the
12567 RMS is a better approximation of the "perceived loudness" than just
12568 looking at the signal's peak magnitude. Consequently, by adjusting
12569 all frames to a constant RMS value, a uniform "perceived loudness"
12570 can be established. If a target RMS value has been specified, a
12571 frame's local gain factor is defined as the factor that would
12572 result in exactly that RMS value. Note, however, that the maximum
12573 local gain factor is still restricted by the frame's highest
12574 magnitude sample, in order to prevent clipping.
12575
12576 coupling, n
12577 Enable channels coupling. By default is enabled. By default, the
12578 Dynamic Audio Normalizer will amplify all channels by the same
12579 amount. This means the same gain factor will be applied to all
12580 channels, i.e. the maximum possible gain factor is determined by
12581 the "loudest" channel. However, in some recordings, it may happen
12582 that the volume of the different channels is uneven, e.g. one
12583 channel may be "quieter" than the other one(s). In this case, this
12584 option can be used to disable the channel coupling. This way, the
12585 gain factor will be determined independently for each channel,
12586 depending only on the individual channel's highest magnitude
12587 sample. This allows for harmonizing the volume of the different
12588 channels.
12589
12590 correctdc, c
12591 Enable DC bias correction. By default is disabled. An audio signal
12592 (in the time domain) is a sequence of sample values. In the
12593 Dynamic Audio Normalizer these sample values are represented in the
12594 -1.0 to 1.0 range, regardless of the original input format.
12595 Normally, the audio signal, or "waveform", should be centered
12596 around the zero point. That means if we calculate the mean value
12597 of all samples in a file, or in a single frame, then the result
12598 should be 0.0 or at least very close to that value. If, however,
12599 there is a significant deviation of the mean value from 0.0, in
12600 either positive or negative direction, this is referred to as a DC
12601 bias or DC offset. Since a DC bias is clearly undesirable, the
12602 Dynamic Audio Normalizer provides optional DC bias correction.
12603 With DC bias correction enabled, the Dynamic Audio Normalizer will
12604 determine the mean value, or "DC correction" offset, of each input
12605 frame and subtract that value from all of the frame's sample values
12606 which ensures those samples are centered around 0.0 again. Also, in
12607 order to avoid "gaps" at the frame boundaries, the DC correction
12608 offset values will be interpolated smoothly between neighbouring
12609 frames.
12610
12611 altboundary, b
12612 Enable alternative boundary mode. By default is disabled. The
12613 Dynamic Audio Normalizer takes into account a certain neighbourhood
12614 around each frame. This includes the preceding frames as well as
12615 the subsequent frames. However, for the "boundary" frames, located
12616 at the very beginning and at the very end of the audio file, not
12617 all neighbouring frames are available. In particular, for the first
12618 few frames in the audio file, the preceding frames are not known.
12619 And, similarly, for the last few frames in the audio file, the
12620 subsequent frames are not known. Thus, the question arises which
12621 gain factors should be assumed for the missing frames in the
12622 "boundary" region. The Dynamic Audio Normalizer implements two
12623 modes to deal with this situation. The default boundary mode
12624 assumes a gain factor of exactly 1.0 for the missing frames,
12625 resulting in a smooth "fade in" and "fade out" at the beginning and
12626 at the end of the input, respectively.
12627
12628 compress, s
12629 Set the compress factor. In range from 0.0 to 30.0. Default is 0.0.
12630 By default, the Dynamic Audio Normalizer does not apply
12631 "traditional" compression. This means that signal peaks will not be
12632 pruned and thus the full dynamic range will be retained within each
12633 local neighbourhood. However, in some cases it may be desirable to
12634 combine the Dynamic Audio Normalizer's normalization algorithm with
12635 a more "traditional" compression. For this purpose, the Dynamic
12636 Audio Normalizer provides an optional compression (thresholding)
12637 function. If (and only if) the compression feature is enabled, all
12638 input frames will be processed by a soft knee thresholding function
12639 prior to the actual normalization process. Put simply, the
12640 thresholding function is going to prune all samples whose magnitude
12641 exceeds a certain threshold value. However, the Dynamic Audio
12642 Normalizer does not simply apply a fixed threshold value. Instead,
12643 the threshold value will be adjusted for each individual frame. In
12644 general, smaller parameters result in stronger compression, and
12645 vice versa. Values below 3.0 are not recommended, because audible
12646 distortion may appear.
12647
12648 threshold, t
12649 Set the target threshold value. This specifies the lowest
12650 permissible magnitude level for the audio input which will be
12651 normalized. If input frame volume is above this value frame will
12652 be normalized. Otherwise frame may not be normalized at all. The
12653 default value is set to 0, which means all input frames will be
12654 normalized. This option is mostly useful if digital noise is not
12655 wanted to be amplified.
12656
12657 Commands
12658
12659 This filter supports the all above options as commands.
12660
12661 earwax
12662 Make audio easier to listen to on headphones.
12663
12664 This filter adds `cues' to 44.1kHz stereo (i.e. audio CD format) audio
12665 so that when listened to on headphones the stereo image is moved from
12666 inside your head (standard for headphones) to outside and in front of
12667 the listener (standard for speakers).
12668
12669 Ported from SoX.
12670
12671 equalizer
12672 Apply a two-pole peaking equalisation (EQ) filter. With this filter,
12673 the signal-level at and around a selected frequency can be increased or
12674 decreased, whilst (unlike bandpass and bandreject filters) that at all
12675 other frequencies is unchanged.
12676
12677 In order to produce complex equalisation curves, this filter can be
12678 given several times, each with a different central frequency.
12679
12680 The filter accepts the following options:
12681
12682 frequency, f
12683 Set the filter's central frequency in Hz.
12684
12685 width_type, t
12686 Set method to specify band-width of filter.
12687
12688 h Hz
12689
12690 q Q-Factor
12691
12692 o octave
12693
12694 s slope
12695
12696 k kHz
12697
12698 width, w
12699 Specify the band-width of a filter in width_type units.
12700
12701 gain, g
12702 Set the required gain or attenuation in dB. Beware of clipping
12703 when using a positive gain.
12704
12705 mix, m
12706 How much to use filtered signal in output. Default is 1. Range is
12707 between 0 and 1.
12708
12709 channels, c
12710 Specify which channels to filter, by default all available are
12711 filtered.
12712
12713 normalize, n
12714 Normalize biquad coefficients, by default is disabled. Enabling it
12715 will normalize magnitude response at DC to 0dB.
12716
12717 transform, a
12718 Set transform type of IIR filter.
12719
12720 di
12721 dii
12722 tdii
12723 latt
12724 svf
12725 precision, r
12726 Set precison of filtering.
12727
12728 auto
12729 Pick automatic sample format depending on surround filters.
12730
12731 s16 Always use signed 16-bit.
12732
12733 s32 Always use signed 32-bit.
12734
12735 f32 Always use float 32-bit.
12736
12737 f64 Always use float 64-bit.
12738
12739 Examples
12740
12741 • Attenuate 10 dB at 1000 Hz, with a bandwidth of 200 Hz:
12742
12743 equalizer=f=1000:t=h:width=200:g=-10
12744
12745 • Apply 2 dB gain at 1000 Hz with Q 1 and attenuate 5 dB at 100 Hz
12746 with Q 2:
12747
12748 equalizer=f=1000:t=q:w=1:g=2,equalizer=f=100:t=q:w=2:g=-5
12749
12750 Commands
12751
12752 This filter supports the following commands:
12753
12754 frequency, f
12755 Change equalizer frequency. Syntax for the command is :
12756 "frequency"
12757
12758 width_type, t
12759 Change equalizer width_type. Syntax for the command is :
12760 "width_type"
12761
12762 width, w
12763 Change equalizer width. Syntax for the command is : "width"
12764
12765 gain, g
12766 Change equalizer gain. Syntax for the command is : "gain"
12767
12768 mix, m
12769 Change equalizer mix. Syntax for the command is : "mix"
12770
12771 extrastereo
12772 Linearly increases the difference between left and right channels which
12773 adds some sort of "live" effect to playback.
12774
12775 The filter accepts the following options:
12776
12777 m Sets the difference coefficient (default: 2.5). 0.0 means mono
12778 sound (average of both channels), with 1.0 sound will be unchanged,
12779 with -1.0 left and right channels will be swapped.
12780
12781 c Enable clipping. By default is enabled.
12782
12783 Commands
12784
12785 This filter supports the all above options as commands.
12786
12787 firequalizer
12788 Apply FIR Equalization using arbitrary frequency response.
12789
12790 The filter accepts the following option:
12791
12792 gain
12793 Set gain curve equation (in dB). The expression can contain
12794 variables:
12795
12796 f the evaluated frequency
12797
12798 sr sample rate
12799
12800 ch channel number, set to 0 when multichannels evaluation is
12801 disabled
12802
12803 chid
12804 channel id, see libavutil/channel_layout.h, set to the first
12805 channel id when multichannels evaluation is disabled
12806
12807 chs number of channels
12808
12809 chlayout
12810 channel_layout, see libavutil/channel_layout.h
12811
12812 and functions:
12813
12814 gain_interpolate(f)
12815 interpolate gain on frequency f based on gain_entry
12816
12817 cubic_interpolate(f)
12818 same as gain_interpolate, but smoother
12819
12820 This option is also available as command. Default is
12821 gain_interpolate(f).
12822
12823 gain_entry
12824 Set gain entry for gain_interpolate function. The expression can
12825 contain functions:
12826
12827 entry(f, g)
12828 store gain entry at frequency f with value g
12829
12830 This option is also available as command.
12831
12832 delay
12833 Set filter delay in seconds. Higher value means more accurate.
12834 Default is 0.01.
12835
12836 accuracy
12837 Set filter accuracy in Hz. Lower value means more accurate.
12838 Default is 5.
12839
12840 wfunc
12841 Set window function. Acceptable values are:
12842
12843 rectangular
12844 rectangular window, useful when gain curve is already smooth
12845
12846 hann
12847 hann window (default)
12848
12849 hamming
12850 hamming window
12851
12852 blackman
12853 blackman window
12854
12855 nuttall3
12856 3-terms continuous 1st derivative nuttall window
12857
12858 mnuttall3
12859 minimum 3-terms discontinuous nuttall window
12860
12861 nuttall
12862 4-terms continuous 1st derivative nuttall window
12863
12864 bnuttall
12865 minimum 4-terms discontinuous nuttall (blackman-nuttall) window
12866
12867 bharris
12868 blackman-harris window
12869
12870 tukey
12871 tukey window
12872
12873 fixed
12874 If enabled, use fixed number of audio samples. This improves speed
12875 when filtering with large delay. Default is disabled.
12876
12877 multi
12878 Enable multichannels evaluation on gain. Default is disabled.
12879
12880 zero_phase
12881 Enable zero phase mode by subtracting timestamp to compensate
12882 delay. Default is disabled.
12883
12884 scale
12885 Set scale used by gain. Acceptable values are:
12886
12887 linlin
12888 linear frequency, linear gain
12889
12890 linlog
12891 linear frequency, logarithmic (in dB) gain (default)
12892
12893 loglin
12894 logarithmic (in octave scale where 20 Hz is 0) frequency,
12895 linear gain
12896
12897 loglog
12898 logarithmic frequency, logarithmic gain
12899
12900 dumpfile
12901 Set file for dumping, suitable for gnuplot.
12902
12903 dumpscale
12904 Set scale for dumpfile. Acceptable values are same with scale
12905 option. Default is linlog.
12906
12907 fft2
12908 Enable 2-channel convolution using complex FFT. This improves speed
12909 significantly. Default is disabled.
12910
12911 min_phase
12912 Enable minimum phase impulse response. Default is disabled.
12913
12914 Examples
12915
12916 • lowpass at 1000 Hz:
12917
12918 firequalizer=gain='if(lt(f,1000), 0, -INF)'
12919
12920 • lowpass at 1000 Hz with gain_entry:
12921
12922 firequalizer=gain_entry='entry(1000,0); entry(1001, -INF)'
12923
12924 • custom equalization:
12925
12926 firequalizer=gain_entry='entry(100,0); entry(400, -4); entry(1000, -6); entry(2000, 0)'
12927
12928 • higher delay with zero phase to compensate delay:
12929
12930 firequalizer=delay=0.1:fixed=on:zero_phase=on
12931
12932 • lowpass on left channel, highpass on right channel:
12933
12934 firequalizer=gain='if(eq(chid,1), gain_interpolate(f), if(eq(chid,2), gain_interpolate(1e6+f), 0))'
12935 :gain_entry='entry(1000, 0); entry(1001,-INF); entry(1e6+1000,0)':multi=on
12936
12937 flanger
12938 Apply a flanging effect to the audio.
12939
12940 The filter accepts the following options:
12941
12942 delay
12943 Set base delay in milliseconds. Range from 0 to 30. Default value
12944 is 0.
12945
12946 depth
12947 Set added sweep delay in milliseconds. Range from 0 to 10. Default
12948 value is 2.
12949
12950 regen
12951 Set percentage regeneration (delayed signal feedback). Range from
12952 -95 to 95. Default value is 0.
12953
12954 width
12955 Set percentage of delayed signal mixed with original. Range from 0
12956 to 100. Default value is 71.
12957
12958 speed
12959 Set sweeps per second (Hz). Range from 0.1 to 10. Default value is
12960 0.5.
12961
12962 shape
12963 Set swept wave shape, can be triangular or sinusoidal. Default
12964 value is sinusoidal.
12965
12966 phase
12967 Set swept wave percentage-shift for multi channel. Range from 0 to
12968 100. Default value is 25.
12969
12970 interp
12971 Set delay-line interpolation, linear or quadratic. Default is
12972 linear.
12973
12974 haas
12975 Apply Haas effect to audio.
12976
12977 Note that this makes most sense to apply on mono signals. With this
12978 filter applied to mono signals it give some directionality and
12979 stretches its stereo image.
12980
12981 The filter accepts the following options:
12982
12983 level_in
12984 Set input level. By default is 1, or 0dB
12985
12986 level_out
12987 Set output level. By default is 1, or 0dB.
12988
12989 side_gain
12990 Set gain applied to side part of signal. By default is 1.
12991
12992 middle_source
12993 Set kind of middle source. Can be one of the following:
12994
12995 left
12996 Pick left channel.
12997
12998 right
12999 Pick right channel.
13000
13001 mid Pick middle part signal of stereo image.
13002
13003 side
13004 Pick side part signal of stereo image.
13005
13006 middle_phase
13007 Change middle phase. By default is disabled.
13008
13009 left_delay
13010 Set left channel delay. By default is 2.05 milliseconds.
13011
13012 left_balance
13013 Set left channel balance. By default is -1.
13014
13015 left_gain
13016 Set left channel gain. By default is 1.
13017
13018 left_phase
13019 Change left phase. By default is disabled.
13020
13021 right_delay
13022 Set right channel delay. By defaults is 2.12 milliseconds.
13023
13024 right_balance
13025 Set right channel balance. By default is 1.
13026
13027 right_gain
13028 Set right channel gain. By default is 1.
13029
13030 right_phase
13031 Change right phase. By default is enabled.
13032
13033 hdcd
13034 Decodes High Definition Compatible Digital (HDCD) data. A 16-bit PCM
13035 stream with embedded HDCD codes is expanded into a 20-bit PCM stream.
13036
13037 The filter supports the Peak Extend and Low-level Gain Adjustment
13038 features of HDCD, and detects the Transient Filter flag.
13039
13040 ffmpeg -i HDCD16.flac -af hdcd OUT24.flac
13041
13042 When using the filter with wav, note the default encoding for wav is
13043 16-bit, so the resulting 20-bit stream will be truncated back to
13044 16-bit. Use something like -acodec pcm_s24le after the filter to get
13045 24-bit PCM output.
13046
13047 ffmpeg -i HDCD16.wav -af hdcd OUT16.wav
13048 ffmpeg -i HDCD16.wav -af hdcd -c:a pcm_s24le OUT24.wav
13049
13050 The filter accepts the following options:
13051
13052 disable_autoconvert
13053 Disable any automatic format conversion or resampling in the filter
13054 graph.
13055
13056 process_stereo
13057 Process the stereo channels together. If target_gain does not match
13058 between channels, consider it invalid and use the last valid
13059 target_gain.
13060
13061 cdt_ms
13062 Set the code detect timer period in ms.
13063
13064 force_pe
13065 Always extend peaks above -3dBFS even if PE isn't signaled.
13066
13067 analyze_mode
13068 Replace audio with a solid tone and adjust the amplitude to signal
13069 some specific aspect of the decoding process. The output file can
13070 be loaded in an audio editor alongside the original to aid
13071 analysis.
13072
13073 "analyze_mode=pe:force_pe=true" can be used to see all samples
13074 above the PE level.
13075
13076 Modes are:
13077
13078 0, off
13079 Disabled
13080
13081 1, lle
13082 Gain adjustment level at each sample
13083
13084 2, pe
13085 Samples where peak extend occurs
13086
13087 3, cdt
13088 Samples where the code detect timer is active
13089
13090 4, tgm
13091 Samples where the target gain does not match between channels
13092
13093 headphone
13094 Apply head-related transfer functions (HRTFs) to create virtual
13095 loudspeakers around the user for binaural listening via headphones.
13096 The HRIRs are provided via additional streams, for each channel one
13097 stereo input stream is needed.
13098
13099 The filter accepts the following options:
13100
13101 map Set mapping of input streams for convolution. The argument is a
13102 '|'-separated list of channel names in order as they are given as
13103 additional stream inputs for filter. This also specify number of
13104 input streams. Number of input streams must be not less than number
13105 of channels in first stream plus one.
13106
13107 gain
13108 Set gain applied to audio. Value is in dB. Default is 0.
13109
13110 type
13111 Set processing type. Can be time or freq. time is processing audio
13112 in time domain which is slow. freq is processing audio in
13113 frequency domain which is fast. Default is freq.
13114
13115 lfe Set custom gain for LFE channels. Value is in dB. Default is 0.
13116
13117 size
13118 Set size of frame in number of samples which will be processed at
13119 once. Default value is 1024. Allowed range is from 1024 to 96000.
13120
13121 hrir
13122 Set format of hrir stream. Default value is stereo. Alternative
13123 value is multich. If value is set to stereo, number of additional
13124 streams should be greater or equal to number of input channels in
13125 first input stream. Also each additional stream should have stereo
13126 number of channels. If value is set to multich, number of
13127 additional streams should be exactly one. Also number of input
13128 channels of additional stream should be equal or greater than twice
13129 number of channels of first input stream.
13130
13131 Examples
13132
13133 • Full example using wav files as coefficients with amovie filters
13134 for 7.1 downmix, each amovie filter use stereo file with IR
13135 coefficients as input. The files give coefficients for each
13136 position of virtual loudspeaker:
13137
13138 ffmpeg -i input.wav
13139 -filter_complex "amovie=azi_270_ele_0_DFC.wav[sr];amovie=azi_90_ele_0_DFC.wav[sl];amovie=azi_225_ele_0_DFC.wav[br];amovie=azi_135_ele_0_DFC.wav[bl];amovie=azi_0_ele_0_DFC.wav,asplit[fc][lfe];amovie=azi_35_ele_0_DFC.wav[fl];amovie=azi_325_ele_0_DFC.wav[fr];[0:a][fl][fr][fc][lfe][bl][br][sl][sr]headphone=FL|FR|FC|LFE|BL|BR|SL|SR"
13140 output.wav
13141
13142 • Full example using wav files as coefficients with amovie filters
13143 for 7.1 downmix, but now in multich hrir format.
13144
13145 ffmpeg -i input.wav -filter_complex "amovie=minp.wav[hrirs];[0:a][hrirs]headphone=map=FL|FR|FC|LFE|BL|BR|SL|SR:hrir=multich"
13146 output.wav
13147
13148 highpass
13149 Apply a high-pass filter with 3dB point frequency. The filter can be
13150 either single-pole, or double-pole (the default). The filter roll off
13151 at 6dB per pole per octave (20dB per pole per decade).
13152
13153 The filter accepts the following options:
13154
13155 frequency, f
13156 Set frequency in Hz. Default is 3000.
13157
13158 poles, p
13159 Set number of poles. Default is 2.
13160
13161 width_type, t
13162 Set method to specify band-width of filter.
13163
13164 h Hz
13165
13166 q Q-Factor
13167
13168 o octave
13169
13170 s slope
13171
13172 k kHz
13173
13174 width, w
13175 Specify the band-width of a filter in width_type units. Applies
13176 only to double-pole filter. The default is 0.707q and gives a
13177 Butterworth response.
13178
13179 mix, m
13180 How much to use filtered signal in output. Default is 1. Range is
13181 between 0 and 1.
13182
13183 channels, c
13184 Specify which channels to filter, by default all available are
13185 filtered.
13186
13187 normalize, n
13188 Normalize biquad coefficients, by default is disabled. Enabling it
13189 will normalize magnitude response at DC to 0dB.
13190
13191 transform, a
13192 Set transform type of IIR filter.
13193
13194 di
13195 dii
13196 tdii
13197 latt
13198 svf
13199 precision, r
13200 Set precison of filtering.
13201
13202 auto
13203 Pick automatic sample format depending on surround filters.
13204
13205 s16 Always use signed 16-bit.
13206
13207 s32 Always use signed 32-bit.
13208
13209 f32 Always use float 32-bit.
13210
13211 f64 Always use float 64-bit.
13212
13213 Commands
13214
13215 This filter supports the following commands:
13216
13217 frequency, f
13218 Change highpass frequency. Syntax for the command is : "frequency"
13219
13220 width_type, t
13221 Change highpass width_type. Syntax for the command is :
13222 "width_type"
13223
13224 width, w
13225 Change highpass width. Syntax for the command is : "width"
13226
13227 mix, m
13228 Change highpass mix. Syntax for the command is : "mix"
13229
13230 join
13231 Join multiple input streams into one multi-channel stream.
13232
13233 It accepts the following parameters:
13234
13235 inputs
13236 The number of input streams. It defaults to 2.
13237
13238 channel_layout
13239 The desired output channel layout. It defaults to stereo.
13240
13241 map Map channels from inputs to output. The argument is a '|'-separated
13242 list of mappings, each in the "input_idx.in_channel-out_channel"
13243 form. input_idx is the 0-based index of the input stream.
13244 in_channel can be either the name of the input channel (e.g. FL for
13245 front left) or its index in the specified input stream. out_channel
13246 is the name of the output channel.
13247
13248 The filter will attempt to guess the mappings when they are not
13249 specified explicitly. It does so by first trying to find an unused
13250 matching input channel and if that fails it picks the first unused
13251 input channel.
13252
13253 Join 3 inputs (with properly set channel layouts):
13254
13255 ffmpeg -i INPUT1 -i INPUT2 -i INPUT3 -filter_complex join=inputs=3 OUTPUT
13256
13257 Build a 5.1 output from 6 single-channel streams:
13258
13259 ffmpeg -i fl -i fr -i fc -i sl -i sr -i lfe -filter_complex
13260 'join=inputs=6:channel_layout=5.1:map=0.0-FL|1.0-FR|2.0-FC|3.0-SL|4.0-SR|5.0-LFE'
13261 out
13262
13263 ladspa
13264 Load a LADSPA (Linux Audio Developer's Simple Plugin API) plugin.
13265
13266 To enable compilation of this filter you need to configure FFmpeg with
13267 "--enable-ladspa".
13268
13269 file, f
13270 Specifies the name of LADSPA plugin library to load. If the
13271 environment variable LADSPA_PATH is defined, the LADSPA plugin is
13272 searched in each one of the directories specified by the colon
13273 separated list in LADSPA_PATH, otherwise in the standard LADSPA
13274 paths, which are in this order: HOME/.ladspa/lib/,
13275 /usr/local/lib/ladspa/, /usr/lib/ladspa/.
13276
13277 plugin, p
13278 Specifies the plugin within the library. Some libraries contain
13279 only one plugin, but others contain many of them. If this is not
13280 set filter will list all available plugins within the specified
13281 library.
13282
13283 controls, c
13284 Set the '|' separated list of controls which are zero or more
13285 floating point values that determine the behavior of the loaded
13286 plugin (for example delay, threshold or gain). Controls need to be
13287 defined using the following syntax:
13288 c0=value0|c1=value1|c2=value2|..., where valuei is the value set on
13289 the i-th control. Alternatively they can be also defined using the
13290 following syntax: value0|value1|value2|..., where valuei is the
13291 value set on the i-th control. If controls is set to "help", all
13292 available controls and their valid ranges are printed.
13293
13294 sample_rate, s
13295 Specify the sample rate, default to 44100. Only used if plugin have
13296 zero inputs.
13297
13298 nb_samples, n
13299 Set the number of samples per channel per each output frame,
13300 default is 1024. Only used if plugin have zero inputs.
13301
13302 duration, d
13303 Set the minimum duration of the sourced audio. See the Time
13304 duration section in the ffmpeg-utils(1) manual for the accepted
13305 syntax. Note that the resulting duration may be greater than the
13306 specified duration, as the generated audio is always cut at the end
13307 of a complete frame. If not specified, or the expressed duration
13308 is negative, the audio is supposed to be generated forever. Only
13309 used if plugin have zero inputs.
13310
13311 latency, l
13312 Enable latency compensation, by default is disabled. Only used if
13313 plugin have inputs.
13314
13315 Examples
13316
13317 • List all available plugins within amp (LADSPA example plugin)
13318 library:
13319
13320 ladspa=file=amp
13321
13322 • List all available controls and their valid ranges for "vcf_notch"
13323 plugin from "VCF" library:
13324
13325 ladspa=f=vcf:p=vcf_notch:c=help
13326
13327 • Simulate low quality audio equipment using "Computer Music Toolkit"
13328 (CMT) plugin library:
13329
13330 ladspa=file=cmt:plugin=lofi:controls=c0=22|c1=12|c2=12
13331
13332 • Add reverberation to the audio using TAP-plugins (Tom's Audio
13333 Processing plugins):
13334
13335 ladspa=file=tap_reverb:tap_reverb
13336
13337 • Generate white noise, with 0.2 amplitude:
13338
13339 ladspa=file=cmt:noise_source_white:c=c0=.2
13340
13341 • Generate 20 bpm clicks using plugin "C* Click - Metronome" from the
13342 "C* Audio Plugin Suite" (CAPS) library:
13343
13344 ladspa=file=caps:Click:c=c1=20'
13345
13346 • Apply "C* Eq10X2 - Stereo 10-band equaliser" effect:
13347
13348 ladspa=caps:Eq10X2:c=c0=-48|c9=-24|c3=12|c4=2
13349
13350 • Increase volume by 20dB using fast lookahead limiter from Steve
13351 Harris "SWH Plugins" collection:
13352
13353 ladspa=fast_lookahead_limiter_1913:fastLookaheadLimiter:20|0|2
13354
13355 • Attenuate low frequencies using Multiband EQ from Steve Harris "SWH
13356 Plugins" collection:
13357
13358 ladspa=mbeq_1197:mbeq:-24|-24|-24|0|0|0|0|0|0|0|0|0|0|0|0
13359
13360 • Reduce stereo image using "Narrower" from the "C* Audio Plugin
13361 Suite" (CAPS) library:
13362
13363 ladspa=caps:Narrower
13364
13365 • Another white noise, now using "C* Audio Plugin Suite" (CAPS)
13366 library:
13367
13368 ladspa=caps:White:.2
13369
13370 • Some fractal noise, using "C* Audio Plugin Suite" (CAPS) library:
13371
13372 ladspa=caps:Fractal:c=c1=1
13373
13374 • Dynamic volume normalization using "VLevel" plugin:
13375
13376 ladspa=vlevel-ladspa:vlevel_mono
13377
13378 Commands
13379
13380 This filter supports the following commands:
13381
13382 cN Modify the N-th control value.
13383
13384 If the specified value is not valid, it is ignored and prior one is
13385 kept.
13386
13387 loudnorm
13388 EBU R128 loudness normalization. Includes both dynamic and linear
13389 normalization modes. Support for both single pass (livestreams, files)
13390 and double pass (files) modes. This algorithm can target IL, LRA, and
13391 maximum true peak. In dynamic mode, to accurately detect true peaks,
13392 the audio stream will be upsampled to 192 kHz. Use the "-ar" option or
13393 "aresample" filter to explicitly set an output sample rate.
13394
13395 The filter accepts the following options:
13396
13397 I, i
13398 Set integrated loudness target. Range is -70.0 - -5.0. Default
13399 value is -24.0.
13400
13401 LRA, lra
13402 Set loudness range target. Range is 1.0 - 20.0. Default value is
13403 7.0.
13404
13405 TP, tp
13406 Set maximum true peak. Range is -9.0 - +0.0. Default value is
13407 -2.0.
13408
13409 measured_I, measured_i
13410 Measured IL of input file. Range is -99.0 - +0.0.
13411
13412 measured_LRA, measured_lra
13413 Measured LRA of input file. Range is 0.0 - 99.0.
13414
13415 measured_TP, measured_tp
13416 Measured true peak of input file. Range is -99.0 - +99.0.
13417
13418 measured_thresh
13419 Measured threshold of input file. Range is -99.0 - +0.0.
13420
13421 offset
13422 Set offset gain. Gain is applied before the true-peak limiter.
13423 Range is -99.0 - +99.0. Default is +0.0.
13424
13425 linear
13426 Normalize by linearly scaling the source audio. "measured_I",
13427 "measured_LRA", "measured_TP", and "measured_thresh" must all be
13428 specified. Target LRA shouldn't be lower than source LRA and the
13429 change in integrated loudness shouldn't result in a true peak which
13430 exceeds the target TP. If any of these conditions aren't met,
13431 normalization mode will revert to dynamic. Options are "true" or
13432 "false". Default is "true".
13433
13434 dual_mono
13435 Treat mono input files as "dual-mono". If a mono file is intended
13436 for playback on a stereo system, its EBU R128 measurement will be
13437 perceptually incorrect. If set to "true", this option will
13438 compensate for this effect. Multi-channel input files are not
13439 affected by this option. Options are true or false. Default is
13440 false.
13441
13442 print_format
13443 Set print format for stats. Options are summary, json, or none.
13444 Default value is none.
13445
13446 lowpass
13447 Apply a low-pass filter with 3dB point frequency. The filter can be
13448 either single-pole or double-pole (the default). The filter roll off
13449 at 6dB per pole per octave (20dB per pole per decade).
13450
13451 The filter accepts the following options:
13452
13453 frequency, f
13454 Set frequency in Hz. Default is 500.
13455
13456 poles, p
13457 Set number of poles. Default is 2.
13458
13459 width_type, t
13460 Set method to specify band-width of filter.
13461
13462 h Hz
13463
13464 q Q-Factor
13465
13466 o octave
13467
13468 s slope
13469
13470 k kHz
13471
13472 width, w
13473 Specify the band-width of a filter in width_type units. Applies
13474 only to double-pole filter. The default is 0.707q and gives a
13475 Butterworth response.
13476
13477 mix, m
13478 How much to use filtered signal in output. Default is 1. Range is
13479 between 0 and 1.
13480
13481 channels, c
13482 Specify which channels to filter, by default all available are
13483 filtered.
13484
13485 normalize, n
13486 Normalize biquad coefficients, by default is disabled. Enabling it
13487 will normalize magnitude response at DC to 0dB.
13488
13489 transform, a
13490 Set transform type of IIR filter.
13491
13492 di
13493 dii
13494 tdii
13495 latt
13496 svf
13497 precision, r
13498 Set precison of filtering.
13499
13500 auto
13501 Pick automatic sample format depending on surround filters.
13502
13503 s16 Always use signed 16-bit.
13504
13505 s32 Always use signed 32-bit.
13506
13507 f32 Always use float 32-bit.
13508
13509 f64 Always use float 64-bit.
13510
13511 Examples
13512
13513 • Lowpass only LFE channel, it LFE is not present it does nothing:
13514
13515 lowpass=c=LFE
13516
13517 Commands
13518
13519 This filter supports the following commands:
13520
13521 frequency, f
13522 Change lowpass frequency. Syntax for the command is : "frequency"
13523
13524 width_type, t
13525 Change lowpass width_type. Syntax for the command is :
13526 "width_type"
13527
13528 width, w
13529 Change lowpass width. Syntax for the command is : "width"
13530
13531 mix, m
13532 Change lowpass mix. Syntax for the command is : "mix"
13533
13534 lv2
13535 Load a LV2 (LADSPA Version 2) plugin.
13536
13537 To enable compilation of this filter you need to configure FFmpeg with
13538 "--enable-lv2".
13539
13540 plugin, p
13541 Specifies the plugin URI. You may need to escape ':'.
13542
13543 controls, c
13544 Set the '|' separated list of controls which are zero or more
13545 floating point values that determine the behavior of the loaded
13546 plugin (for example delay, threshold or gain). If controls is set
13547 to "help", all available controls and their valid ranges are
13548 printed.
13549
13550 sample_rate, s
13551 Specify the sample rate, default to 44100. Only used if plugin have
13552 zero inputs.
13553
13554 nb_samples, n
13555 Set the number of samples per channel per each output frame,
13556 default is 1024. Only used if plugin have zero inputs.
13557
13558 duration, d
13559 Set the minimum duration of the sourced audio. See the Time
13560 duration section in the ffmpeg-utils(1) manual for the accepted
13561 syntax. Note that the resulting duration may be greater than the
13562 specified duration, as the generated audio is always cut at the end
13563 of a complete frame. If not specified, or the expressed duration
13564 is negative, the audio is supposed to be generated forever. Only
13565 used if plugin have zero inputs.
13566
13567 Examples
13568
13569 • Apply bass enhancer plugin from Calf:
13570
13571 lv2=p=http\\\\://calf.sourceforge.net/plugins/BassEnhancer:c=amount=2
13572
13573 • Apply vinyl plugin from Calf:
13574
13575 lv2=p=http\\\\://calf.sourceforge.net/plugins/Vinyl:c=drone=0.2|aging=0.5
13576
13577 • Apply bit crusher plugin from ArtyFX:
13578
13579 lv2=p=http\\\\://www.openavproductions.com/artyfx#bitta:c=crush=0.3
13580
13581 mcompand
13582 Multiband Compress or expand the audio's dynamic range.
13583
13584 The input audio is divided into bands using 4th order Linkwitz-Riley
13585 IIRs. This is akin to the crossover of a loudspeaker, and results in
13586 flat frequency response when absent compander action.
13587
13588 It accepts the following parameters:
13589
13590 args
13591 This option syntax is: attack,decay,[attack,decay..] soft-knee
13592 points crossover_frequency [delay [initial_volume [gain]]] |
13593 attack,decay ... For explanation of each item refer to compand
13594 filter documentation.
13595
13596 pan
13597 Mix channels with specific gain levels. The filter accepts the output
13598 channel layout followed by a set of channels definitions.
13599
13600 This filter is also designed to efficiently remap the channels of an
13601 audio stream.
13602
13603 The filter accepts parameters of the form: "l|outdef|outdef|..."
13604
13605 l output channel layout or number of channels
13606
13607 outdef
13608 output channel specification, of the form:
13609 "out_name=[gain*]in_name[(+-)[gain*]in_name...]"
13610
13611 out_name
13612 output channel to define, either a channel name (FL, FR, etc.) or a
13613 channel number (c0, c1, etc.)
13614
13615 gain
13616 multiplicative coefficient for the channel, 1 leaving the volume
13617 unchanged
13618
13619 in_name
13620 input channel to use, see out_name for details; it is not possible
13621 to mix named and numbered input channels
13622
13623 If the `=' in a channel specification is replaced by `<', then the
13624 gains for that specification will be renormalized so that the total is
13625 1, thus avoiding clipping noise.
13626
13627 Mixing examples
13628
13629 For example, if you want to down-mix from stereo to mono, but with a
13630 bigger factor for the left channel:
13631
13632 pan=1c|c0=0.9*c0+0.1*c1
13633
13634 A customized down-mix to stereo that works automatically for 3-, 4-, 5-
13635 and 7-channels surround:
13636
13637 pan=stereo| FL < FL + 0.5*FC + 0.6*BL + 0.6*SL | FR < FR + 0.5*FC + 0.6*BR + 0.6*SR
13638
13639 Note that ffmpeg integrates a default down-mix (and up-mix) system that
13640 should be preferred (see "-ac" option) unless you have very specific
13641 needs.
13642
13643 Remapping examples
13644
13645 The channel remapping will be effective if, and only if:
13646
13647 *<gain coefficients are zeroes or ones,>
13648 *<only one input per channel output,>
13649
13650 If all these conditions are satisfied, the filter will notify the user
13651 ("Pure channel mapping detected"), and use an optimized and lossless
13652 method to do the remapping.
13653
13654 For example, if you have a 5.1 source and want a stereo audio stream by
13655 dropping the extra channels:
13656
13657 pan="stereo| c0=FL | c1=FR"
13658
13659 Given the same source, you can also switch front left and front right
13660 channels and keep the input channel layout:
13661
13662 pan="5.1| c0=c1 | c1=c0 | c2=c2 | c3=c3 | c4=c4 | c5=c5"
13663
13664 If the input is a stereo audio stream, you can mute the front left
13665 channel (and still keep the stereo channel layout) with:
13666
13667 pan="stereo|c1=c1"
13668
13669 Still with a stereo audio stream input, you can copy the right channel
13670 in both front left and right:
13671
13672 pan="stereo| c0=FR | c1=FR"
13673
13674 replaygain
13675 ReplayGain scanner filter. This filter takes an audio stream as an
13676 input and outputs it unchanged. At end of filtering it displays
13677 "track_gain" and "track_peak".
13678
13679 resample
13680 Convert the audio sample format, sample rate and channel layout. It is
13681 not meant to be used directly.
13682
13683 rubberband
13684 Apply time-stretching and pitch-shifting with librubberband.
13685
13686 To enable compilation of this filter, you need to configure FFmpeg with
13687 "--enable-librubberband".
13688
13689 The filter accepts the following options:
13690
13691 tempo
13692 Set tempo scale factor.
13693
13694 pitch
13695 Set pitch scale factor.
13696
13697 transients
13698 Set transients detector. Possible values are:
13699
13700 crisp
13701 mixed
13702 smooth
13703 detector
13704 Set detector. Possible values are:
13705
13706 compound
13707 percussive
13708 soft
13709 phase
13710 Set phase. Possible values are:
13711
13712 laminar
13713 independent
13714 window
13715 Set processing window size. Possible values are:
13716
13717 standard
13718 short
13719 long
13720 smoothing
13721 Set smoothing. Possible values are:
13722
13723 off
13724 on
13725 formant
13726 Enable formant preservation when shift pitching. Possible values
13727 are:
13728
13729 shifted
13730 preserved
13731 pitchq
13732 Set pitch quality. Possible values are:
13733
13734 quality
13735 speed
13736 consistency
13737 channels
13738 Set channels. Possible values are:
13739
13740 apart
13741 together
13742
13743 Commands
13744
13745 This filter supports the following commands:
13746
13747 tempo
13748 Change filter tempo scale factor. Syntax for the command is :
13749 "tempo"
13750
13751 pitch
13752 Change filter pitch scale factor. Syntax for the command is :
13753 "pitch"
13754
13755 sidechaincompress
13756 This filter acts like normal compressor but has the ability to compress
13757 detected signal using second input signal. It needs two input streams
13758 and returns one output stream. First input stream will be processed
13759 depending on second stream signal. The filtered signal then can be
13760 filtered with other filters in later stages of processing. See pan and
13761 amerge filter.
13762
13763 The filter accepts the following options:
13764
13765 level_in
13766 Set input gain. Default is 1. Range is between 0.015625 and 64.
13767
13768 mode
13769 Set mode of compressor operation. Can be "upward" or "downward".
13770 Default is "downward".
13771
13772 threshold
13773 If a signal of second stream raises above this level it will affect
13774 the gain reduction of first stream. By default is 0.125. Range is
13775 between 0.00097563 and 1.
13776
13777 ratio
13778 Set a ratio about which the signal is reduced. 1:2 means that if
13779 the level raised 4dB above the threshold, it will be only 2dB above
13780 after the reduction. Default is 2. Range is between 1 and 20.
13781
13782 attack
13783 Amount of milliseconds the signal has to rise above the threshold
13784 before gain reduction starts. Default is 20. Range is between 0.01
13785 and 2000.
13786
13787 release
13788 Amount of milliseconds the signal has to fall below the threshold
13789 before reduction is decreased again. Default is 250. Range is
13790 between 0.01 and 9000.
13791
13792 makeup
13793 Set the amount by how much signal will be amplified after
13794 processing. Default is 1. Range is from 1 to 64.
13795
13796 knee
13797 Curve the sharp knee around the threshold to enter gain reduction
13798 more softly. Default is 2.82843. Range is between 1 and 8.
13799
13800 link
13801 Choose if the "average" level between all channels of side-chain
13802 stream or the louder("maximum") channel of side-chain stream
13803 affects the reduction. Default is "average".
13804
13805 detection
13806 Should the exact signal be taken in case of "peak" or an RMS one in
13807 case of "rms". Default is "rms" which is mainly smoother.
13808
13809 level_sc
13810 Set sidechain gain. Default is 1. Range is between 0.015625 and 64.
13811
13812 mix How much to use compressed signal in output. Default is 1. Range
13813 is between 0 and 1.
13814
13815 Commands
13816
13817 This filter supports the all above options as commands.
13818
13819 Examples
13820
13821 • Full ffmpeg example taking 2 audio inputs, 1st input to be
13822 compressed depending on the signal of 2nd input and later
13823 compressed signal to be merged with 2nd input:
13824
13825 ffmpeg -i main.flac -i sidechain.flac -filter_complex "[1:a]asplit=2[sc][mix];[0:a][sc]sidechaincompress[compr];[compr][mix]amerge"
13826
13827 sidechaingate
13828 A sidechain gate acts like a normal (wideband) gate but has the ability
13829 to filter the detected signal before sending it to the gain reduction
13830 stage. Normally a gate uses the full range signal to detect a level
13831 above the threshold. For example: If you cut all lower frequencies
13832 from your sidechain signal the gate will decrease the volume of your
13833 track only if not enough highs appear. With this technique you are able
13834 to reduce the resonation of a natural drum or remove "rumbling" of
13835 muted strokes from a heavily distorted guitar. It needs two input
13836 streams and returns one output stream. First input stream will be
13837 processed depending on second stream signal.
13838
13839 The filter accepts the following options:
13840
13841 level_in
13842 Set input level before filtering. Default is 1. Allowed range is
13843 from 0.015625 to 64.
13844
13845 mode
13846 Set the mode of operation. Can be "upward" or "downward". Default
13847 is "downward". If set to "upward" mode, higher parts of signal will
13848 be amplified, expanding dynamic range in upward direction.
13849 Otherwise, in case of "downward" lower parts of signal will be
13850 reduced.
13851
13852 range
13853 Set the level of gain reduction when the signal is below the
13854 threshold. Default is 0.06125. Allowed range is from 0 to 1.
13855 Setting this to 0 disables reduction and then filter behaves like
13856 expander.
13857
13858 threshold
13859 If a signal rises above this level the gain reduction is released.
13860 Default is 0.125. Allowed range is from 0 to 1.
13861
13862 ratio
13863 Set a ratio about which the signal is reduced. Default is 2.
13864 Allowed range is from 1 to 9000.
13865
13866 attack
13867 Amount of milliseconds the signal has to rise above the threshold
13868 before gain reduction stops. Default is 20 milliseconds. Allowed
13869 range is from 0.01 to 9000.
13870
13871 release
13872 Amount of milliseconds the signal has to fall below the threshold
13873 before the reduction is increased again. Default is 250
13874 milliseconds. Allowed range is from 0.01 to 9000.
13875
13876 makeup
13877 Set amount of amplification of signal after processing. Default is
13878 1. Allowed range is from 1 to 64.
13879
13880 knee
13881 Curve the sharp knee around the threshold to enter gain reduction
13882 more softly. Default is 2.828427125. Allowed range is from 1 to 8.
13883
13884 detection
13885 Choose if exact signal should be taken for detection or an RMS like
13886 one. Default is rms. Can be peak or rms.
13887
13888 link
13889 Choose if the average level between all channels or the louder
13890 channel affects the reduction. Default is average. Can be average
13891 or maximum.
13892
13893 level_sc
13894 Set sidechain gain. Default is 1. Range is from 0.015625 to 64.
13895
13896 Commands
13897
13898 This filter supports the all above options as commands.
13899
13900 silencedetect
13901 Detect silence in an audio stream.
13902
13903 This filter logs a message when it detects that the input audio volume
13904 is less or equal to a noise tolerance value for a duration greater or
13905 equal to the minimum detected noise duration.
13906
13907 The printed times and duration are expressed in seconds. The
13908 "lavfi.silence_start" or "lavfi.silence_start.X" metadata key is set on
13909 the first frame whose timestamp equals or exceeds the detection
13910 duration and it contains the timestamp of the first frame of the
13911 silence.
13912
13913 The "lavfi.silence_duration" or "lavfi.silence_duration.X" and
13914 "lavfi.silence_end" or "lavfi.silence_end.X" metadata keys are set on
13915 the first frame after the silence. If mono is enabled, and each channel
13916 is evaluated separately, the ".X" suffixed keys are used, and "X"
13917 corresponds to the channel number.
13918
13919 The filter accepts the following options:
13920
13921 noise, n
13922 Set noise tolerance. Can be specified in dB (in case "dB" is
13923 appended to the specified value) or amplitude ratio. Default is
13924 -60dB, or 0.001.
13925
13926 duration, d
13927 Set silence duration until notification (default is 2 seconds). See
13928 the Time duration section in the ffmpeg-utils(1) manual for the
13929 accepted syntax.
13930
13931 mono, m
13932 Process each channel separately, instead of combined. By default is
13933 disabled.
13934
13935 Examples
13936
13937 • Detect 5 seconds of silence with -50dB noise tolerance:
13938
13939 silencedetect=n=-50dB:d=5
13940
13941 • Complete example with ffmpeg to detect silence with 0.0001 noise
13942 tolerance in silence.mp3:
13943
13944 ffmpeg -i silence.mp3 -af silencedetect=noise=0.0001 -f null -
13945
13946 silenceremove
13947 Remove silence from the beginning, middle or end of the audio.
13948
13949 The filter accepts the following options:
13950
13951 start_periods
13952 This value is used to indicate if audio should be trimmed at
13953 beginning of the audio. A value of zero indicates no silence should
13954 be trimmed from the beginning. When specifying a non-zero value, it
13955 trims audio up until it finds non-silence. Normally, when trimming
13956 silence from beginning of audio the start_periods will be 1 but it
13957 can be increased to higher values to trim all audio up to specific
13958 count of non-silence periods. Default value is 0.
13959
13960 start_duration
13961 Specify the amount of time that non-silence must be detected before
13962 it stops trimming audio. By increasing the duration, bursts of
13963 noises can be treated as silence and trimmed off. Default value is
13964 0.
13965
13966 start_threshold
13967 This indicates what sample value should be treated as silence. For
13968 digital audio, a value of 0 may be fine but for audio recorded from
13969 analog, you may wish to increase the value to account for
13970 background noise. Can be specified in dB (in case "dB" is appended
13971 to the specified value) or amplitude ratio. Default value is 0.
13972
13973 start_silence
13974 Specify max duration of silence at beginning that will be kept
13975 after trimming. Default is 0, which is equal to trimming all
13976 samples detected as silence.
13977
13978 start_mode
13979 Specify mode of detection of silence end in start of multi-channel
13980 audio. Can be any or all. Default is any. With any, any sample
13981 that is detected as non-silence will cause stopped trimming of
13982 silence. With all, only if all channels are detected as non-
13983 silence will cause stopped trimming of silence.
13984
13985 stop_periods
13986 Set the count for trimming silence from the end of audio. To
13987 remove silence from the middle of a file, specify a stop_periods
13988 that is negative. This value is then treated as a positive value
13989 and is used to indicate the effect should restart processing as
13990 specified by start_periods, making it suitable for removing periods
13991 of silence in the middle of the audio. Default value is 0.
13992
13993 stop_duration
13994 Specify a duration of silence that must exist before audio is not
13995 copied any more. By specifying a higher duration, silence that is
13996 wanted can be left in the audio. Default value is 0.
13997
13998 stop_threshold
13999 This is the same as start_threshold but for trimming silence from
14000 the end of audio. Can be specified in dB (in case "dB" is appended
14001 to the specified value) or amplitude ratio. Default value is 0.
14002
14003 stop_silence
14004 Specify max duration of silence at end that will be kept after
14005 trimming. Default is 0, which is equal to trimming all samples
14006 detected as silence.
14007
14008 stop_mode
14009 Specify mode of detection of silence start in end of multi-channel
14010 audio. Can be any or all. Default is any. With any, any sample
14011 that is detected as non-silence will cause stopped trimming of
14012 silence. With all, only if all channels are detected as non-
14013 silence will cause stopped trimming of silence.
14014
14015 detection
14016 Set how is silence detected. Can be "rms" or "peak". Second is
14017 faster and works better with digital silence which is exactly 0.
14018 Default value is "rms".
14019
14020 window
14021 Set duration in number of seconds used to calculate size of window
14022 in number of samples for detecting silence. Default value is 0.02.
14023 Allowed range is from 0 to 10.
14024
14025 Examples
14026
14027 • The following example shows how this filter can be used to start a
14028 recording that does not contain the delay at the start which
14029 usually occurs between pressing the record button and the start of
14030 the performance:
14031
14032 silenceremove=start_periods=1:start_duration=5:start_threshold=0.02
14033
14034 • Trim all silence encountered from beginning to end where there is
14035 more than 1 second of silence in audio:
14036
14037 silenceremove=stop_periods=-1:stop_duration=1:stop_threshold=-90dB
14038
14039 • Trim all digital silence samples, using peak detection, from
14040 beginning to end where there is more than 0 samples of digital
14041 silence in audio and digital silence is detected in all channels at
14042 same positions in stream:
14043
14044 silenceremove=window=0:detection=peak:stop_mode=all:start_mode=all:stop_periods=-1:stop_threshold=0
14045
14046 sofalizer
14047 SOFAlizer uses head-related transfer functions (HRTFs) to create
14048 virtual loudspeakers around the user for binaural listening via
14049 headphones (audio formats up to 9 channels supported). The HRTFs are
14050 stored in SOFA files (see <http://www.sofacoustics.org/> for a
14051 database). SOFAlizer is developed at the Acoustics Research Institute
14052 (ARI) of the Austrian Academy of Sciences.
14053
14054 To enable compilation of this filter you need to configure FFmpeg with
14055 "--enable-libmysofa".
14056
14057 The filter accepts the following options:
14058
14059 sofa
14060 Set the SOFA file used for rendering.
14061
14062 gain
14063 Set gain applied to audio. Value is in dB. Default is 0.
14064
14065 rotation
14066 Set rotation of virtual loudspeakers in deg. Default is 0.
14067
14068 elevation
14069 Set elevation of virtual speakers in deg. Default is 0.
14070
14071 radius
14072 Set distance in meters between loudspeakers and the listener with
14073 near-field HRTFs. Default is 1.
14074
14075 type
14076 Set processing type. Can be time or freq. time is processing audio
14077 in time domain which is slow. freq is processing audio in
14078 frequency domain which is fast. Default is freq.
14079
14080 speakers
14081 Set custom positions of virtual loudspeakers. Syntax for this
14082 option is: <CH> <AZIM> <ELEV>[|<CH> <AZIM> <ELEV>|...]. Each
14083 virtual loudspeaker is described with short channel name following
14084 with azimuth and elevation in degrees. Each virtual loudspeaker
14085 description is separated by '|'. For example to override front
14086 left and front right channel positions use: 'speakers=FL 45 15|FR
14087 345 15'. Descriptions with unrecognised channel names are ignored.
14088
14089 lfegain
14090 Set custom gain for LFE channels. Value is in dB. Default is 0.
14091
14092 framesize
14093 Set custom frame size in number of samples. Default is 1024.
14094 Allowed range is from 1024 to 96000. Only used if option type is
14095 set to freq.
14096
14097 normalize
14098 Should all IRs be normalized upon importing SOFA file. By default
14099 is enabled.
14100
14101 interpolate
14102 Should nearest IRs be interpolated with neighbor IRs if exact
14103 position does not match. By default is disabled.
14104
14105 minphase
14106 Minphase all IRs upon loading of SOFA file. By default is disabled.
14107
14108 anglestep
14109 Set neighbor search angle step. Only used if option interpolate is
14110 enabled.
14111
14112 radstep
14113 Set neighbor search radius step. Only used if option interpolate is
14114 enabled.
14115
14116 Examples
14117
14118 • Using ClubFritz6 sofa file:
14119
14120 sofalizer=sofa=/path/to/ClubFritz6.sofa:type=freq:radius=1
14121
14122 • Using ClubFritz12 sofa file and bigger radius with small rotation:
14123
14124 sofalizer=sofa=/path/to/ClubFritz12.sofa:type=freq:radius=2:rotation=5
14125
14126 • Similar as above but with custom speaker positions for front left,
14127 front right, back left and back right and also with custom gain:
14128
14129 "sofalizer=sofa=/path/to/ClubFritz6.sofa:type=freq:radius=2:speakers=FL 45|FR 315|BL 135|BR 225:gain=28"
14130
14131 speechnorm
14132 Speech Normalizer.
14133
14134 This filter expands or compresses each half-cycle of audio samples
14135 (local set of samples all above or all below zero and between two
14136 nearest zero crossings) depending on threshold value, so audio reaches
14137 target peak value under conditions controlled by below options.
14138
14139 The filter accepts the following options:
14140
14141 peak, p
14142 Set the expansion target peak value. This specifies the highest
14143 allowed absolute amplitude level for the normalized audio input.
14144 Default value is 0.95. Allowed range is from 0.0 to 1.0.
14145
14146 expansion, e
14147 Set the maximum expansion factor. Allowed range is from 1.0 to
14148 50.0. Default value is 2.0. This option controls maximum local
14149 half-cycle of samples expansion. The maximum expansion would be
14150 such that local peak value reaches target peak value but never to
14151 surpass it and that ratio between new and previous peak value does
14152 not surpass this option value.
14153
14154 compression, c
14155 Set the maximum compression factor. Allowed range is from 1.0 to
14156 50.0. Default value is 2.0. This option controls maximum local
14157 half-cycle of samples compression. This option is used only if
14158 threshold option is set to value greater than 0.0, then in such
14159 cases when local peak is lower or same as value set by threshold
14160 all samples belonging to that peak's half-cycle will be compressed
14161 by current compression factor.
14162
14163 threshold, t
14164 Set the threshold value. Default value is 0.0. Allowed range is
14165 from 0.0 to 1.0. This option specifies which half-cycles of
14166 samples will be compressed and which will be expanded. Any half-
14167 cycle samples with their local peak value below or same as this
14168 option value will be compressed by current compression factor,
14169 otherwise, if greater than threshold value they will be expanded
14170 with expansion factor so that it could reach peak target value but
14171 never surpass it.
14172
14173 raise, r
14174 Set the expansion raising amount per each half-cycle of samples.
14175 Default value is 0.001. Allowed range is from 0.0 to 1.0. This
14176 controls how fast expansion factor is raised per each new half-
14177 cycle until it reaches expansion value. Setting this options too
14178 high may lead to distortions.
14179
14180 fall, f
14181 Set the compression raising amount per each half-cycle of samples.
14182 Default value is 0.001. Allowed range is from 0.0 to 1.0. This
14183 controls how fast compression factor is raised per each new half-
14184 cycle until it reaches compression value.
14185
14186 channels, h
14187 Specify which channels to filter, by default all available channels
14188 are filtered.
14189
14190 invert, i
14191 Enable inverted filtering, by default is disabled. This inverts
14192 interpretation of threshold option. When enabled any half-cycle of
14193 samples with their local peak value below or same as threshold
14194 option will be expanded otherwise it will be compressed.
14195
14196 link, l
14197 Link channels when calculating gain applied to each filtered
14198 channel sample, by default is disabled. When disabled each
14199 filtered channel gain calculation is independent, otherwise when
14200 this option is enabled the minimum of all possible gains for each
14201 filtered channel is used.
14202
14203 Commands
14204
14205 This filter supports the all above options as commands.
14206
14207 stereotools
14208 This filter has some handy utilities to manage stereo signals, for
14209 converting M/S stereo recordings to L/R signal while having control
14210 over the parameters or spreading the stereo image of master track.
14211
14212 The filter accepts the following options:
14213
14214 level_in
14215 Set input level before filtering for both channels. Defaults is 1.
14216 Allowed range is from 0.015625 to 64.
14217
14218 level_out
14219 Set output level after filtering for both channels. Defaults is 1.
14220 Allowed range is from 0.015625 to 64.
14221
14222 balance_in
14223 Set input balance between both channels. Default is 0. Allowed
14224 range is from -1 to 1.
14225
14226 balance_out
14227 Set output balance between both channels. Default is 0. Allowed
14228 range is from -1 to 1.
14229
14230 softclip
14231 Enable softclipping. Results in analog distortion instead of harsh
14232 digital 0dB clipping. Disabled by default.
14233
14234 mutel
14235 Mute the left channel. Disabled by default.
14236
14237 muter
14238 Mute the right channel. Disabled by default.
14239
14240 phasel
14241 Change the phase of the left channel. Disabled by default.
14242
14243 phaser
14244 Change the phase of the right channel. Disabled by default.
14245
14246 mode
14247 Set stereo mode. Available values are:
14248
14249 lr>lr
14250 Left/Right to Left/Right, this is default.
14251
14252 lr>ms
14253 Left/Right to Mid/Side.
14254
14255 ms>lr
14256 Mid/Side to Left/Right.
14257
14258 lr>ll
14259 Left/Right to Left/Left.
14260
14261 lr>rr
14262 Left/Right to Right/Right.
14263
14264 lr>l+r
14265 Left/Right to Left + Right.
14266
14267 lr>rl
14268 Left/Right to Right/Left.
14269
14270 ms>ll
14271 Mid/Side to Left/Left.
14272
14273 ms>rr
14274 Mid/Side to Right/Right.
14275
14276 ms>rl
14277 Mid/Side to Right/Left.
14278
14279 lr>l-r
14280 Left/Right to Left - Right.
14281
14282 slev
14283 Set level of side signal. Default is 1. Allowed range is from
14284 0.015625 to 64.
14285
14286 sbal
14287 Set balance of side signal. Default is 0. Allowed range is from -1
14288 to 1.
14289
14290 mlev
14291 Set level of the middle signal. Default is 1. Allowed range is
14292 from 0.015625 to 64.
14293
14294 mpan
14295 Set middle signal pan. Default is 0. Allowed range is from -1 to 1.
14296
14297 base
14298 Set stereo base between mono and inversed channels. Default is 0.
14299 Allowed range is from -1 to 1.
14300
14301 delay
14302 Set delay in milliseconds how much to delay left from right channel
14303 and vice versa. Default is 0. Allowed range is from -20 to 20.
14304
14305 sclevel
14306 Set S/C level. Default is 1. Allowed range is from 1 to 100.
14307
14308 phase
14309 Set the stereo phase in degrees. Default is 0. Allowed range is
14310 from 0 to 360.
14311
14312 bmode_in, bmode_out
14313 Set balance mode for balance_in/balance_out option.
14314
14315 Can be one of the following:
14316
14317 balance
14318 Classic balance mode. Attenuate one channel at time. Gain is
14319 raised up to 1.
14320
14321 amplitude
14322 Similar as classic mode above but gain is raised up to 2.
14323
14324 power
14325 Equal power distribution, from -6dB to +6dB range.
14326
14327 Commands
14328
14329 This filter supports the all above options as commands.
14330
14331 Examples
14332
14333 • Apply karaoke like effect:
14334
14335 stereotools=mlev=0.015625
14336
14337 • Convert M/S signal to L/R:
14338
14339 "stereotools=mode=ms>lr"
14340
14341 stereowiden
14342 This filter enhance the stereo effect by suppressing signal common to
14343 both channels and by delaying the signal of left into right and vice
14344 versa, thereby widening the stereo effect.
14345
14346 The filter accepts the following options:
14347
14348 delay
14349 Time in milliseconds of the delay of left signal into right and
14350 vice versa. Default is 20 milliseconds.
14351
14352 feedback
14353 Amount of gain in delayed signal into right and vice versa. Gives a
14354 delay effect of left signal in right output and vice versa which
14355 gives widening effect. Default is 0.3.
14356
14357 crossfeed
14358 Cross feed of left into right with inverted phase. This helps in
14359 suppressing the mono. If the value is 1 it will cancel all the
14360 signal common to both channels. Default is 0.3.
14361
14362 drymix
14363 Set level of input signal of original channel. Default is 0.8.
14364
14365 Commands
14366
14367 This filter supports the all above options except "delay" as commands.
14368
14369 superequalizer
14370 Apply 18 band equalizer.
14371
14372 The filter accepts the following options:
14373
14374 1b Set 65Hz band gain.
14375
14376 2b Set 92Hz band gain.
14377
14378 3b Set 131Hz band gain.
14379
14380 4b Set 185Hz band gain.
14381
14382 5b Set 262Hz band gain.
14383
14384 6b Set 370Hz band gain.
14385
14386 7b Set 523Hz band gain.
14387
14388 8b Set 740Hz band gain.
14389
14390 9b Set 1047Hz band gain.
14391
14392 10b Set 1480Hz band gain.
14393
14394 11b Set 2093Hz band gain.
14395
14396 12b Set 2960Hz band gain.
14397
14398 13b Set 4186Hz band gain.
14399
14400 14b Set 5920Hz band gain.
14401
14402 15b Set 8372Hz band gain.
14403
14404 16b Set 11840Hz band gain.
14405
14406 17b Set 16744Hz band gain.
14407
14408 18b Set 20000Hz band gain.
14409
14410 surround
14411 Apply audio surround upmix filter.
14412
14413 This filter allows to produce multichannel output from audio stream.
14414
14415 The filter accepts the following options:
14416
14417 chl_out
14418 Set output channel layout. By default, this is 5.1.
14419
14420 See the Channel Layout section in the ffmpeg-utils(1) manual for
14421 the required syntax.
14422
14423 chl_in
14424 Set input channel layout. By default, this is stereo.
14425
14426 See the Channel Layout section in the ffmpeg-utils(1) manual for
14427 the required syntax.
14428
14429 level_in
14430 Set input volume level. By default, this is 1.
14431
14432 level_out
14433 Set output volume level. By default, this is 1.
14434
14435 lfe Enable LFE channel output if output channel layout has it. By
14436 default, this is enabled.
14437
14438 lfe_low
14439 Set LFE low cut off frequency. By default, this is 128 Hz.
14440
14441 lfe_high
14442 Set LFE high cut off frequency. By default, this is 256 Hz.
14443
14444 lfe_mode
14445 Set LFE mode, can be add or sub. Default is add. In add mode, LFE
14446 channel is created from input audio and added to output. In sub
14447 mode, LFE channel is created from input audio and added to output
14448 but also all non-LFE output channels are subtracted with output LFE
14449 channel.
14450
14451 angle
14452 Set angle of stereo surround transform, Allowed range is from 0 to
14453 360. Default is 90.
14454
14455 fc_in
14456 Set front center input volume. By default, this is 1.
14457
14458 fc_out
14459 Set front center output volume. By default, this is 1.
14460
14461 fl_in
14462 Set front left input volume. By default, this is 1.
14463
14464 fl_out
14465 Set front left output volume. By default, this is 1.
14466
14467 fr_in
14468 Set front right input volume. By default, this is 1.
14469
14470 fr_out
14471 Set front right output volume. By default, this is 1.
14472
14473 sl_in
14474 Set side left input volume. By default, this is 1.
14475
14476 sl_out
14477 Set side left output volume. By default, this is 1.
14478
14479 sr_in
14480 Set side right input volume. By default, this is 1.
14481
14482 sr_out
14483 Set side right output volume. By default, this is 1.
14484
14485 bl_in
14486 Set back left input volume. By default, this is 1.
14487
14488 bl_out
14489 Set back left output volume. By default, this is 1.
14490
14491 br_in
14492 Set back right input volume. By default, this is 1.
14493
14494 br_out
14495 Set back right output volume. By default, this is 1.
14496
14497 bc_in
14498 Set back center input volume. By default, this is 1.
14499
14500 bc_out
14501 Set back center output volume. By default, this is 1.
14502
14503 lfe_in
14504 Set LFE input volume. By default, this is 1.
14505
14506 lfe_out
14507 Set LFE output volume. By default, this is 1.
14508
14509 allx
14510 Set spread usage of stereo image across X axis for all channels.
14511
14512 ally
14513 Set spread usage of stereo image across Y axis for all channels.
14514
14515 fcx, flx, frx, blx, brx, slx, srx, bcx
14516 Set spread usage of stereo image across X axis for each channel.
14517
14518 fcy, fly, fry, bly, bry, sly, sry, bcy
14519 Set spread usage of stereo image across Y axis for each channel.
14520
14521 win_size
14522 Set window size. Allowed range is from 1024 to 65536. Default size
14523 is 4096.
14524
14525 win_func
14526 Set window function.
14527
14528 It accepts the following values:
14529
14530 rect
14531 bartlett
14532 hann, hanning
14533 hamming
14534 blackman
14535 welch
14536 flattop
14537 bharris
14538 bnuttall
14539 bhann
14540 sine
14541 nuttall
14542 lanczos
14543 gauss
14544 tukey
14545 dolph
14546 cauchy
14547 parzen
14548 poisson
14549 bohman
14550
14551 Default is "hann".
14552
14553 overlap
14554 Set window overlap. If set to 1, the recommended overlap for
14555 selected window function will be picked. Default is 0.5.
14556
14557 treble, highshelf
14558 Boost or cut treble (upper) frequencies of the audio using a two-pole
14559 shelving filter with a response similar to that of a standard hi-fi's
14560 tone-controls. This is also known as shelving equalisation (EQ).
14561
14562 The filter accepts the following options:
14563
14564 gain, g
14565 Give the gain at whichever is the lower of ~22 kHz and the Nyquist
14566 frequency. Its useful range is about -20 (for a large cut) to +20
14567 (for a large boost). Beware of clipping when using a positive gain.
14568
14569 frequency, f
14570 Set the filter's central frequency and so can be used to extend or
14571 reduce the frequency range to be boosted or cut. The default value
14572 is 3000 Hz.
14573
14574 width_type, t
14575 Set method to specify band-width of filter.
14576
14577 h Hz
14578
14579 q Q-Factor
14580
14581 o octave
14582
14583 s slope
14584
14585 k kHz
14586
14587 width, w
14588 Determine how steep is the filter's shelf transition.
14589
14590 poles, p
14591 Set number of poles. Default is 2.
14592
14593 mix, m
14594 How much to use filtered signal in output. Default is 1. Range is
14595 between 0 and 1.
14596
14597 channels, c
14598 Specify which channels to filter, by default all available are
14599 filtered.
14600
14601 normalize, n
14602 Normalize biquad coefficients, by default is disabled. Enabling it
14603 will normalize magnitude response at DC to 0dB.
14604
14605 transform, a
14606 Set transform type of IIR filter.
14607
14608 di
14609 dii
14610 tdii
14611 latt
14612 svf
14613 precision, r
14614 Set precison of filtering.
14615
14616 auto
14617 Pick automatic sample format depending on surround filters.
14618
14619 s16 Always use signed 16-bit.
14620
14621 s32 Always use signed 32-bit.
14622
14623 f32 Always use float 32-bit.
14624
14625 f64 Always use float 64-bit.
14626
14627 Commands
14628
14629 This filter supports the following commands:
14630
14631 frequency, f
14632 Change treble frequency. Syntax for the command is : "frequency"
14633
14634 width_type, t
14635 Change treble width_type. Syntax for the command is : "width_type"
14636
14637 width, w
14638 Change treble width. Syntax for the command is : "width"
14639
14640 gain, g
14641 Change treble gain. Syntax for the command is : "gain"
14642
14643 mix, m
14644 Change treble mix. Syntax for the command is : "mix"
14645
14646 tremolo
14647 Sinusoidal amplitude modulation.
14648
14649 The filter accepts the following options:
14650
14651 f Modulation frequency in Hertz. Modulation frequencies in the
14652 subharmonic range (20 Hz or lower) will result in a tremolo effect.
14653 This filter may also be used as a ring modulator by specifying a
14654 modulation frequency higher than 20 Hz. Range is 0.1 - 20000.0.
14655 Default value is 5.0 Hz.
14656
14657 d Depth of modulation as a percentage. Range is 0.0 - 1.0. Default
14658 value is 0.5.
14659
14660 vibrato
14661 Sinusoidal phase modulation.
14662
14663 The filter accepts the following options:
14664
14665 f Modulation frequency in Hertz. Range is 0.1 - 20000.0. Default
14666 value is 5.0 Hz.
14667
14668 d Depth of modulation as a percentage. Range is 0.0 - 1.0. Default
14669 value is 0.5.
14670
14671 volume
14672 Adjust the input audio volume.
14673
14674 It accepts the following parameters:
14675
14676 volume
14677 Set audio volume expression.
14678
14679 Output values are clipped to the maximum value.
14680
14681 The output audio volume is given by the relation:
14682
14683 <output_volume> = <volume> * <input_volume>
14684
14685 The default value for volume is "1.0".
14686
14687 precision
14688 This parameter represents the mathematical precision.
14689
14690 It determines which input sample formats will be allowed, which
14691 affects the precision of the volume scaling.
14692
14693 fixed
14694 8-bit fixed-point; this limits input sample format to U8, S16,
14695 and S32.
14696
14697 float
14698 32-bit floating-point; this limits input sample format to FLT.
14699 (default)
14700
14701 double
14702 64-bit floating-point; this limits input sample format to DBL.
14703
14704 replaygain
14705 Choose the behaviour on encountering ReplayGain side data in input
14706 frames.
14707
14708 drop
14709 Remove ReplayGain side data, ignoring its contents (the
14710 default).
14711
14712 ignore
14713 Ignore ReplayGain side data, but leave it in the frame.
14714
14715 track
14716 Prefer the track gain, if present.
14717
14718 album
14719 Prefer the album gain, if present.
14720
14721 replaygain_preamp
14722 Pre-amplification gain in dB to apply to the selected replaygain
14723 gain.
14724
14725 Default value for replaygain_preamp is 0.0.
14726
14727 replaygain_noclip
14728 Prevent clipping by limiting the gain applied.
14729
14730 Default value for replaygain_noclip is 1.
14731
14732 eval
14733 Set when the volume expression is evaluated.
14734
14735 It accepts the following values:
14736
14737 once
14738 only evaluate expression once during the filter initialization,
14739 or when the volume command is sent
14740
14741 frame
14742 evaluate expression for each incoming frame
14743
14744 Default value is once.
14745
14746 The volume expression can contain the following parameters.
14747
14748 n frame number (starting at zero)
14749
14750 nb_channels
14751 number of channels
14752
14753 nb_consumed_samples
14754 number of samples consumed by the filter
14755
14756 nb_samples
14757 number of samples in the current frame
14758
14759 pos original frame position in the file
14760
14761 pts frame PTS
14762
14763 sample_rate
14764 sample rate
14765
14766 startpts
14767 PTS at start of stream
14768
14769 startt
14770 time at start of stream
14771
14772 t frame time
14773
14774 tb timestamp timebase
14775
14776 volume
14777 last set volume value
14778
14779 Note that when eval is set to once only the sample_rate and tb
14780 variables are available, all other variables will evaluate to NAN.
14781
14782 Commands
14783
14784 This filter supports the following commands:
14785
14786 volume
14787 Modify the volume expression. The command accepts the same syntax
14788 of the corresponding option.
14789
14790 If the specified expression is not valid, it is kept at its current
14791 value.
14792
14793 Examples
14794
14795 • Halve the input audio volume:
14796
14797 volume=volume=0.5
14798 volume=volume=1/2
14799 volume=volume=-6.0206dB
14800
14801 In all the above example the named key for volume can be omitted,
14802 for example like in:
14803
14804 volume=0.5
14805
14806 • Increase input audio power by 6 decibels using fixed-point
14807 precision:
14808
14809 volume=volume=6dB:precision=fixed
14810
14811 • Fade volume after time 10 with an annihilation period of 5 seconds:
14812
14813 volume='if(lt(t,10),1,max(1-(t-10)/5,0))':eval=frame
14814
14815 volumedetect
14816 Detect the volume of the input video.
14817
14818 The filter has no parameters. The input is not modified. Statistics
14819 about the volume will be printed in the log when the input stream end
14820 is reached.
14821
14822 In particular it will show the mean volume (root mean square), maximum
14823 volume (on a per-sample basis), and the beginning of a histogram of the
14824 registered volume values (from the maximum value to a cumulated 1/1000
14825 of the samples).
14826
14827 All volumes are in decibels relative to the maximum PCM value.
14828
14829 Examples
14830
14831 Here is an excerpt of the output:
14832
14833 [Parsed_volumedetect_0 0xa23120] mean_volume: -27 dB
14834 [Parsed_volumedetect_0 0xa23120] max_volume: -4 dB
14835 [Parsed_volumedetect_0 0xa23120] histogram_4db: 6
14836 [Parsed_volumedetect_0 0xa23120] histogram_5db: 62
14837 [Parsed_volumedetect_0 0xa23120] histogram_6db: 286
14838 [Parsed_volumedetect_0 0xa23120] histogram_7db: 1042
14839 [Parsed_volumedetect_0 0xa23120] histogram_8db: 2551
14840 [Parsed_volumedetect_0 0xa23120] histogram_9db: 4609
14841 [Parsed_volumedetect_0 0xa23120] histogram_10db: 8409
14842
14843 It means that:
14844
14845 • The mean square energy is approximately -27 dB, or 10^-2.7.
14846
14847 • The largest sample is at -4 dB, or more precisely between -4 dB and
14848 -5 dB.
14849
14850 • There are 6 samples at -4 dB, 62 at -5 dB, 286 at -6 dB, etc.
14851
14852 In other words, raising the volume by +4 dB does not cause any
14853 clipping, raising it by +5 dB causes clipping for 6 samples, etc.
14854
14856 Below is a description of the currently available audio sources.
14857
14858 abuffer
14859 Buffer audio frames, and make them available to the filter chain.
14860
14861 This source is mainly intended for a programmatic use, in particular
14862 through the interface defined in libavfilter/buffersrc.h.
14863
14864 It accepts the following parameters:
14865
14866 time_base
14867 The timebase which will be used for timestamps of submitted frames.
14868 It must be either a floating-point number or in
14869 numerator/denominator form.
14870
14871 sample_rate
14872 The sample rate of the incoming audio buffers.
14873
14874 sample_fmt
14875 The sample format of the incoming audio buffers. Either a sample
14876 format name or its corresponding integer representation from the
14877 enum AVSampleFormat in libavutil/samplefmt.h
14878
14879 channel_layout
14880 The channel layout of the incoming audio buffers. Either a channel
14881 layout name from channel_layout_map in libavutil/channel_layout.c
14882 or its corresponding integer representation from the AV_CH_LAYOUT_*
14883 macros in libavutil/channel_layout.h
14884
14885 channels
14886 The number of channels of the incoming audio buffers. If both
14887 channels and channel_layout are specified, then they must be
14888 consistent.
14889
14890 Examples
14891
14892 abuffer=sample_rate=44100:sample_fmt=s16p:channel_layout=stereo
14893
14894 will instruct the source to accept planar 16bit signed stereo at
14895 44100Hz. Since the sample format with name "s16p" corresponds to the
14896 number 6 and the "stereo" channel layout corresponds to the value 0x3,
14897 this is equivalent to:
14898
14899 abuffer=sample_rate=44100:sample_fmt=6:channel_layout=0x3
14900
14901 aevalsrc
14902 Generate an audio signal specified by an expression.
14903
14904 This source accepts in input one or more expressions (one for each
14905 channel), which are evaluated and used to generate a corresponding
14906 audio signal.
14907
14908 This source accepts the following options:
14909
14910 exprs
14911 Set the '|'-separated expressions list for each separate channel.
14912 In case the channel_layout option is not specified, the selected
14913 channel layout depends on the number of provided expressions.
14914 Otherwise the last specified expression is applied to the remaining
14915 output channels.
14916
14917 channel_layout, c
14918 Set the channel layout. The number of channels in the specified
14919 layout must be equal to the number of specified expressions.
14920
14921 duration, d
14922 Set the minimum duration of the sourced audio. See the Time
14923 duration section in the ffmpeg-utils(1) manual for the accepted
14924 syntax. Note that the resulting duration may be greater than the
14925 specified duration, as the generated audio is always cut at the end
14926 of a complete frame.
14927
14928 If not specified, or the expressed duration is negative, the audio
14929 is supposed to be generated forever.
14930
14931 nb_samples, n
14932 Set the number of samples per channel per each output frame,
14933 default to 1024.
14934
14935 sample_rate, s
14936 Specify the sample rate, default to 44100.
14937
14938 Each expression in exprs can contain the following constants:
14939
14940 n number of the evaluated sample, starting from 0
14941
14942 t time of the evaluated sample expressed in seconds, starting from 0
14943
14944 s sample rate
14945
14946 Examples
14947
14948 • Generate silence:
14949
14950 aevalsrc=0
14951
14952 • Generate a sin signal with frequency of 440 Hz, set sample rate to
14953 8000 Hz:
14954
14955 aevalsrc="sin(440*2*PI*t):s=8000"
14956
14957 • Generate a two channels signal, specify the channel layout (Front
14958 Center + Back Center) explicitly:
14959
14960 aevalsrc="sin(420*2*PI*t)|cos(430*2*PI*t):c=FC|BC"
14961
14962 • Generate white noise:
14963
14964 aevalsrc="-2+random(0)"
14965
14966 • Generate an amplitude modulated signal:
14967
14968 aevalsrc="sin(10*2*PI*t)*sin(880*2*PI*t)"
14969
14970 • Generate 2.5 Hz binaural beats on a 360 Hz carrier:
14971
14972 aevalsrc="0.1*sin(2*PI*(360-2.5/2)*t) | 0.1*sin(2*PI*(360+2.5/2)*t)"
14973
14974 afirsrc
14975 Generate a FIR coefficients using frequency sampling method.
14976
14977 The resulting stream can be used with afir filter for filtering the
14978 audio signal.
14979
14980 The filter accepts the following options:
14981
14982 taps, t
14983 Set number of filter coefficents in output audio stream. Default
14984 value is 1025.
14985
14986 frequency, f
14987 Set frequency points from where magnitude and phase are set. This
14988 must be in non decreasing order, and first element must be 0, while
14989 last element must be 1. Elements are separated by white spaces.
14990
14991 magnitude, m
14992 Set magnitude value for every frequency point set by frequency.
14993 Number of values must be same as number of frequency points.
14994 Values are separated by white spaces.
14995
14996 phase, p
14997 Set phase value for every frequency point set by frequency. Number
14998 of values must be same as number of frequency points. Values are
14999 separated by white spaces.
15000
15001 sample_rate, r
15002 Set sample rate, default is 44100.
15003
15004 nb_samples, n
15005 Set number of samples per each frame. Default is 1024.
15006
15007 win_func, w
15008 Set window function. Default is blackman.
15009
15010 anullsrc
15011 The null audio source, return unprocessed audio frames. It is mainly
15012 useful as a template and to be employed in analysis / debugging tools,
15013 or as the source for filters which ignore the input data (for example
15014 the sox synth filter).
15015
15016 This source accepts the following options:
15017
15018 channel_layout, cl
15019 Specifies the channel layout, and can be either an integer or a
15020 string representing a channel layout. The default value of
15021 channel_layout is "stereo".
15022
15023 Check the channel_layout_map definition in
15024 libavutil/channel_layout.c for the mapping between strings and
15025 channel layout values.
15026
15027 sample_rate, r
15028 Specifies the sample rate, and defaults to 44100.
15029
15030 nb_samples, n
15031 Set the number of samples per requested frames.
15032
15033 duration, d
15034 Set the duration of the sourced audio. See the Time duration
15035 section in the ffmpeg-utils(1) manual for the accepted syntax.
15036
15037 If not specified, or the expressed duration is negative, the audio
15038 is supposed to be generated forever.
15039
15040 Examples
15041
15042 • Set the sample rate to 48000 Hz and the channel layout to
15043 AV_CH_LAYOUT_MONO.
15044
15045 anullsrc=r=48000:cl=4
15046
15047 • Do the same operation with a more obvious syntax:
15048
15049 anullsrc=r=48000:cl=mono
15050
15051 All the parameters need to be explicitly defined.
15052
15053 flite
15054 Synthesize a voice utterance using the libflite library.
15055
15056 To enable compilation of this filter you need to configure FFmpeg with
15057 "--enable-libflite".
15058
15059 Note that versions of the flite library prior to 2.0 are not thread-
15060 safe.
15061
15062 The filter accepts the following options:
15063
15064 list_voices
15065 If set to 1, list the names of the available voices and exit
15066 immediately. Default value is 0.
15067
15068 nb_samples, n
15069 Set the maximum number of samples per frame. Default value is 512.
15070
15071 textfile
15072 Set the filename containing the text to speak.
15073
15074 text
15075 Set the text to speak.
15076
15077 voice, v
15078 Set the voice to use for the speech synthesis. Default value is
15079 "kal". See also the list_voices option.
15080
15081 Examples
15082
15083 • Read from file speech.txt, and synthesize the text using the
15084 standard flite voice:
15085
15086 flite=textfile=speech.txt
15087
15088 • Read the specified text selecting the "slt" voice:
15089
15090 flite=text='So fare thee well, poor devil of a Sub-Sub, whose commentator I am':voice=slt
15091
15092 • Input text to ffmpeg:
15093
15094 ffmpeg -f lavfi -i flite=text='So fare thee well, poor devil of a Sub-Sub, whose commentator I am':voice=slt
15095
15096 • Make ffplay speak the specified text, using "flite" and the "lavfi"
15097 device:
15098
15099 ffplay -f lavfi flite=text='No more be grieved for which that thou hast done.'
15100
15101 For more information about libflite, check:
15102 <http://www.festvox.org/flite/>
15103
15104 anoisesrc
15105 Generate a noise audio signal.
15106
15107 The filter accepts the following options:
15108
15109 sample_rate, r
15110 Specify the sample rate. Default value is 48000 Hz.
15111
15112 amplitude, a
15113 Specify the amplitude (0.0 - 1.0) of the generated audio stream.
15114 Default value is 1.0.
15115
15116 duration, d
15117 Specify the duration of the generated audio stream. Not specifying
15118 this option results in noise with an infinite length.
15119
15120 color, colour, c
15121 Specify the color of noise. Available noise colors are white, pink,
15122 brown, blue, violet and velvet. Default color is white.
15123
15124 seed, s
15125 Specify a value used to seed the PRNG.
15126
15127 nb_samples, n
15128 Set the number of samples per each output frame, default is 1024.
15129
15130 Examples
15131
15132 • Generate 60 seconds of pink noise, with a 44.1 kHz sampling rate
15133 and an amplitude of 0.5:
15134
15135 anoisesrc=d=60:c=pink:r=44100:a=0.5
15136
15137 hilbert
15138 Generate odd-tap Hilbert transform FIR coefficients.
15139
15140 The resulting stream can be used with afir filter for phase-shifting
15141 the signal by 90 degrees.
15142
15143 This is used in many matrix coding schemes and for analytic signal
15144 generation. The process is often written as a multiplication by i (or
15145 j), the imaginary unit.
15146
15147 The filter accepts the following options:
15148
15149 sample_rate, s
15150 Set sample rate, default is 44100.
15151
15152 taps, t
15153 Set length of FIR filter, default is 22051.
15154
15155 nb_samples, n
15156 Set number of samples per each frame.
15157
15158 win_func, w
15159 Set window function to be used when generating FIR coefficients.
15160
15161 sinc
15162 Generate a sinc kaiser-windowed low-pass, high-pass, band-pass, or
15163 band-reject FIR coefficients.
15164
15165 The resulting stream can be used with afir filter for filtering the
15166 audio signal.
15167
15168 The filter accepts the following options:
15169
15170 sample_rate, r
15171 Set sample rate, default is 44100.
15172
15173 nb_samples, n
15174 Set number of samples per each frame. Default is 1024.
15175
15176 hp Set high-pass frequency. Default is 0.
15177
15178 lp Set low-pass frequency. Default is 0. If high-pass frequency is
15179 lower than low-pass frequency and low-pass frequency is higher than
15180 0 then filter will create band-pass filter coefficients, otherwise
15181 band-reject filter coefficients.
15182
15183 phase
15184 Set filter phase response. Default is 50. Allowed range is from 0
15185 to 100.
15186
15187 beta
15188 Set Kaiser window beta.
15189
15190 att Set stop-band attenuation. Default is 120dB, allowed range is from
15191 40 to 180 dB.
15192
15193 round
15194 Enable rounding, by default is disabled.
15195
15196 hptaps
15197 Set number of taps for high-pass filter.
15198
15199 lptaps
15200 Set number of taps for low-pass filter.
15201
15202 sine
15203 Generate an audio signal made of a sine wave with amplitude 1/8.
15204
15205 The audio signal is bit-exact.
15206
15207 The filter accepts the following options:
15208
15209 frequency, f
15210 Set the carrier frequency. Default is 440 Hz.
15211
15212 beep_factor, b
15213 Enable a periodic beep every second with frequency beep_factor
15214 times the carrier frequency. Default is 0, meaning the beep is
15215 disabled.
15216
15217 sample_rate, r
15218 Specify the sample rate, default is 44100.
15219
15220 duration, d
15221 Specify the duration of the generated audio stream.
15222
15223 samples_per_frame
15224 Set the number of samples per output frame.
15225
15226 The expression can contain the following constants:
15227
15228 n The (sequential) number of the output audio frame, starting
15229 from 0.
15230
15231 pts The PTS (Presentation TimeStamp) of the output audio frame,
15232 expressed in TB units.
15233
15234 t The PTS of the output audio frame, expressed in seconds.
15235
15236 TB The timebase of the output audio frames.
15237
15238 Default is 1024.
15239
15240 Examples
15241
15242 • Generate a simple 440 Hz sine wave:
15243
15244 sine
15245
15246 • Generate a 220 Hz sine wave with a 880 Hz beep each second, for 5
15247 seconds:
15248
15249 sine=220:4:d=5
15250 sine=f=220:b=4:d=5
15251 sine=frequency=220:beep_factor=4:duration=5
15252
15253 • Generate a 1 kHz sine wave following "1602,1601,1602,1601,1602"
15254 NTSC pattern:
15255
15256 sine=1000:samples_per_frame='st(0,mod(n,5)); 1602-not(not(eq(ld(0),1)+eq(ld(0),3)))'
15257
15259 Below is a description of the currently available audio sinks.
15260
15261 abuffersink
15262 Buffer audio frames, and make them available to the end of filter
15263 chain.
15264
15265 This sink is mainly intended for programmatic use, in particular
15266 through the interface defined in libavfilter/buffersink.h or the
15267 options system.
15268
15269 It accepts a pointer to an AVABufferSinkContext structure, which
15270 defines the incoming buffers' formats, to be passed as the opaque
15271 parameter to "avfilter_init_filter" for initialization.
15272
15273 anullsink
15274 Null audio sink; do absolutely nothing with the input audio. It is
15275 mainly useful as a template and for use in analysis / debugging tools.
15276
15278 When you configure your FFmpeg build, you can disable any of the
15279 existing filters using "--disable-filters". The configure output will
15280 show the video filters included in your build.
15281
15282 Below is a description of the currently available video filters.
15283
15284 addroi
15285 Mark a region of interest in a video frame.
15286
15287 The frame data is passed through unchanged, but metadata is attached to
15288 the frame indicating regions of interest which can affect the behaviour
15289 of later encoding. Multiple regions can be marked by applying the
15290 filter multiple times.
15291
15292 x Region distance in pixels from the left edge of the frame.
15293
15294 y Region distance in pixels from the top edge of the frame.
15295
15296 w Region width in pixels.
15297
15298 h Region height in pixels.
15299
15300 The parameters x, y, w and h are expressions, and may contain the
15301 following variables:
15302
15303 iw Width of the input frame.
15304
15305 ih Height of the input frame.
15306
15307 qoffset
15308 Quantisation offset to apply within the region.
15309
15310 This must be a real value in the range -1 to +1. A value of zero
15311 indicates no quality change. A negative value asks for better
15312 quality (less quantisation), while a positive value asks for worse
15313 quality (greater quantisation).
15314
15315 The range is calibrated so that the extreme values indicate the
15316 largest possible offset - if the rest of the frame is encoded with
15317 the worst possible quality, an offset of -1 indicates that this
15318 region should be encoded with the best possible quality anyway.
15319 Intermediate values are then interpolated in some codec-dependent
15320 way.
15321
15322 For example, in 10-bit H.264 the quantisation parameter varies
15323 between -12 and 51. A typical qoffset value of -1/10 therefore
15324 indicates that this region should be encoded with a QP around one-
15325 tenth of the full range better than the rest of the frame. So, if
15326 most of the frame were to be encoded with a QP of around 30, this
15327 region would get a QP of around 24 (an offset of approximately
15328 -1/10 * (51 - -12) = -6.3). An extreme value of -1 would indicate
15329 that this region should be encoded with the best possible quality
15330 regardless of the treatment of the rest of the frame - that is,
15331 should be encoded at a QP of -12.
15332
15333 clear
15334 If set to true, remove any existing regions of interest marked on
15335 the frame before adding the new one.
15336
15337 Examples
15338
15339 • Mark the centre quarter of the frame as interesting.
15340
15341 addroi=iw/4:ih/4:iw/2:ih/2:-1/10
15342
15343 • Mark the 100-pixel-wide region on the left edge of the frame as
15344 very uninteresting (to be encoded at much lower quality than the
15345 rest of the frame).
15346
15347 addroi=0:0:100:ih:+1/5
15348
15349 alphaextract
15350 Extract the alpha component from the input as a grayscale video. This
15351 is especially useful with the alphamerge filter.
15352
15353 alphamerge
15354 Add or replace the alpha component of the primary input with the
15355 grayscale value of a second input. This is intended for use with
15356 alphaextract to allow the transmission or storage of frame sequences
15357 that have alpha in a format that doesn't support an alpha channel.
15358
15359 For example, to reconstruct full frames from a normal YUV-encoded video
15360 and a separate video created with alphaextract, you might use:
15361
15362 movie=in_alpha.mkv [alpha]; [in][alpha] alphamerge [out]
15363
15364 amplify
15365 Amplify differences between current pixel and pixels of adjacent frames
15366 in same pixel location.
15367
15368 This filter accepts the following options:
15369
15370 radius
15371 Set frame radius. Default is 2. Allowed range is from 1 to 63. For
15372 example radius of 3 will instruct filter to calculate average of 7
15373 frames.
15374
15375 factor
15376 Set factor to amplify difference. Default is 2. Allowed range is
15377 from 0 to 65535.
15378
15379 threshold
15380 Set threshold for difference amplification. Any difference greater
15381 or equal to this value will not alter source pixel. Default is 10.
15382 Allowed range is from 0 to 65535.
15383
15384 tolerance
15385 Set tolerance for difference amplification. Any difference lower to
15386 this value will not alter source pixel. Default is 0. Allowed
15387 range is from 0 to 65535.
15388
15389 low Set lower limit for changing source pixel. Default is 65535.
15390 Allowed range is from 0 to 65535. This option controls maximum
15391 possible value that will decrease source pixel value.
15392
15393 high
15394 Set high limit for changing source pixel. Default is 65535. Allowed
15395 range is from 0 to 65535. This option controls maximum possible
15396 value that will increase source pixel value.
15397
15398 planes
15399 Set which planes to filter. Default is all. Allowed range is from 0
15400 to 15.
15401
15402 Commands
15403
15404 This filter supports the following commands that corresponds to option
15405 of same name:
15406
15407 factor
15408 threshold
15409 tolerance
15410 low
15411 high
15412 planes
15413
15414 ass
15415 Same as the subtitles filter, except that it doesn't require libavcodec
15416 and libavformat to work. On the other hand, it is limited to ASS
15417 (Advanced Substation Alpha) subtitles files.
15418
15419 This filter accepts the following option in addition to the common
15420 options from the subtitles filter:
15421
15422 shaping
15423 Set the shaping engine
15424
15425 Available values are:
15426
15427 auto
15428 The default libass shaping engine, which is the best available.
15429
15430 simple
15431 Fast, font-agnostic shaper that can do only substitutions
15432
15433 complex
15434 Slower shaper using OpenType for substitutions and positioning
15435
15436 The default is "auto".
15437
15438 atadenoise
15439 Apply an Adaptive Temporal Averaging Denoiser to the video input.
15440
15441 The filter accepts the following options:
15442
15443 0a Set threshold A for 1st plane. Default is 0.02. Valid range is 0
15444 to 0.3.
15445
15446 0b Set threshold B for 1st plane. Default is 0.04. Valid range is 0
15447 to 5.
15448
15449 1a Set threshold A for 2nd plane. Default is 0.02. Valid range is 0
15450 to 0.3.
15451
15452 1b Set threshold B for 2nd plane. Default is 0.04. Valid range is 0
15453 to 5.
15454
15455 2a Set threshold A for 3rd plane. Default is 0.02. Valid range is 0
15456 to 0.3.
15457
15458 2b Set threshold B for 3rd plane. Default is 0.04. Valid range is 0
15459 to 5.
15460
15461 Threshold A is designed to react on abrupt changes in the input
15462 signal and threshold B is designed to react on continuous changes
15463 in the input signal.
15464
15465 s Set number of frames filter will use for averaging. Default is 9.
15466 Must be odd number in range [5, 129].
15467
15468 p Set what planes of frame filter will use for averaging. Default is
15469 all.
15470
15471 a Set what variant of algorithm filter will use for averaging.
15472 Default is "p" parallel. Alternatively can be set to "s" serial.
15473
15474 Parallel can be faster then serial, while other way around is never
15475 true. Parallel will abort early on first change being greater then
15476 thresholds, while serial will continue processing other side of
15477 frames if they are equal or below thresholds.
15478
15479 0s
15480 1s
15481 2s Set sigma for 1st plane, 2nd plane or 3rd plane. Default is 32767.
15482 Valid range is from 0 to 32767. This options controls weight for
15483 each pixel in radius defined by size. Default value means every
15484 pixel have same weight. Setting this option to 0 effectively
15485 disables filtering.
15486
15487 Commands
15488
15489 This filter supports same commands as options except option "s". The
15490 command accepts the same syntax of the corresponding option.
15491
15492 avgblur
15493 Apply average blur filter.
15494
15495 The filter accepts the following options:
15496
15497 sizeX
15498 Set horizontal radius size.
15499
15500 planes
15501 Set which planes to filter. By default all planes are filtered.
15502
15503 sizeY
15504 Set vertical radius size, if zero it will be same as "sizeX".
15505 Default is 0.
15506
15507 Commands
15508
15509 This filter supports same commands as options. The command accepts the
15510 same syntax of the corresponding option.
15511
15512 If the specified expression is not valid, it is kept at its current
15513 value.
15514
15515 bbox
15516 Compute the bounding box for the non-black pixels in the input frame
15517 luminance plane.
15518
15519 This filter computes the bounding box containing all the pixels with a
15520 luminance value greater than the minimum allowed value. The parameters
15521 describing the bounding box are printed on the filter log.
15522
15523 The filter accepts the following option:
15524
15525 min_val
15526 Set the minimal luminance value. Default is 16.
15527
15528 Commands
15529
15530 This filter supports the all above options as commands.
15531
15532 bilateral
15533 Apply bilateral filter, spatial smoothing while preserving edges.
15534
15535 The filter accepts the following options:
15536
15537 sigmaS
15538 Set sigma of gaussian function to calculate spatial weight.
15539 Allowed range is 0 to 512. Default is 0.1.
15540
15541 sigmaR
15542 Set sigma of gaussian function to calculate range weight. Allowed
15543 range is 0 to 1. Default is 0.1.
15544
15545 planes
15546 Set planes to filter. Default is first only.
15547
15548 Commands
15549
15550 This filter supports the all above options as commands.
15551
15552 bitplanenoise
15553 Show and measure bit plane noise.
15554
15555 The filter accepts the following options:
15556
15557 bitplane
15558 Set which plane to analyze. Default is 1.
15559
15560 filter
15561 Filter out noisy pixels from "bitplane" set above. Default is
15562 disabled.
15563
15564 blackdetect
15565 Detect video intervals that are (almost) completely black. Can be
15566 useful to detect chapter transitions, commercials, or invalid
15567 recordings.
15568
15569 The filter outputs its detection analysis to both the log as well as
15570 frame metadata. If a black segment of at least the specified minimum
15571 duration is found, a line with the start and end timestamps as well as
15572 duration is printed to the log with level "info". In addition, a log
15573 line with level "debug" is printed per frame showing the black amount
15574 detected for that frame.
15575
15576 The filter also attaches metadata to the first frame of a black segment
15577 with key "lavfi.black_start" and to the first frame after the black
15578 segment ends with key "lavfi.black_end". The value is the frame's
15579 timestamp. This metadata is added regardless of the minimum duration
15580 specified.
15581
15582 The filter accepts the following options:
15583
15584 black_min_duration, d
15585 Set the minimum detected black duration expressed in seconds. It
15586 must be a non-negative floating point number.
15587
15588 Default value is 2.0.
15589
15590 picture_black_ratio_th, pic_th
15591 Set the threshold for considering a picture "black". Express the
15592 minimum value for the ratio:
15593
15594 <nb_black_pixels> / <nb_pixels>
15595
15596 for which a picture is considered black. Default value is 0.98.
15597
15598 pixel_black_th, pix_th
15599 Set the threshold for considering a pixel "black".
15600
15601 The threshold expresses the maximum pixel luminance value for which
15602 a pixel is considered "black". The provided value is scaled
15603 according to the following equation:
15604
15605 <absolute_threshold> = <luminance_minimum_value> + <pixel_black_th> * <luminance_range_size>
15606
15607 luminance_range_size and luminance_minimum_value depend on the
15608 input video format, the range is [0-255] for YUV full-range formats
15609 and [16-235] for YUV non full-range formats.
15610
15611 Default value is 0.10.
15612
15613 The following example sets the maximum pixel threshold to the minimum
15614 value, and detects only black intervals of 2 or more seconds:
15615
15616 blackdetect=d=2:pix_th=0.00
15617
15618 blackframe
15619 Detect frames that are (almost) completely black. Can be useful to
15620 detect chapter transitions or commercials. Output lines consist of the
15621 frame number of the detected frame, the percentage of blackness, the
15622 position in the file if known or -1 and the timestamp in seconds.
15623
15624 In order to display the output lines, you need to set the loglevel at
15625 least to the AV_LOG_INFO value.
15626
15627 This filter exports frame metadata "lavfi.blackframe.pblack". The
15628 value represents the percentage of pixels in the picture that are below
15629 the threshold value.
15630
15631 It accepts the following parameters:
15632
15633 amount
15634 The percentage of the pixels that have to be below the threshold;
15635 it defaults to 98.
15636
15637 threshold, thresh
15638 The threshold below which a pixel value is considered black; it
15639 defaults to 32.
15640
15641 blend
15642 Blend two video frames into each other.
15643
15644 The "blend" filter takes two input streams and outputs one stream, the
15645 first input is the "top" layer and second input is "bottom" layer. By
15646 default, the output terminates when the longest input terminates.
15647
15648 The "tblend" (time blend) filter takes two consecutive frames from one
15649 single stream, and outputs the result obtained by blending the new
15650 frame on top of the old frame.
15651
15652 A description of the accepted options follows.
15653
15654 c0_mode
15655 c1_mode
15656 c2_mode
15657 c3_mode
15658 all_mode
15659 Set blend mode for specific pixel component or all pixel components
15660 in case of all_mode. Default value is "normal".
15661
15662 Available values for component modes are:
15663
15664 addition
15665 and
15666 average
15667 bleach
15668 burn
15669 darken
15670 difference
15671 divide
15672 dodge
15673 exclusion
15674 extremity
15675 freeze
15676 geometric
15677 glow
15678 grainextract
15679 grainmerge
15680 hardlight
15681 hardmix
15682 hardoverlay
15683 harmonic
15684 heat
15685 interpolate
15686 lighten
15687 linearlight
15688 multiply
15689 multiply128
15690 negation
15691 normal
15692 or
15693 overlay
15694 phoenix
15695 pinlight
15696 reflect
15697 screen
15698 softdifference
15699 softlight
15700 stain
15701 subtract
15702 vividlight
15703 xor
15704 c0_opacity
15705 c1_opacity
15706 c2_opacity
15707 c3_opacity
15708 all_opacity
15709 Set blend opacity for specific pixel component or all pixel
15710 components in case of all_opacity. Only used in combination with
15711 pixel component blend modes.
15712
15713 c0_expr
15714 c1_expr
15715 c2_expr
15716 c3_expr
15717 all_expr
15718 Set blend expression for specific pixel component or all pixel
15719 components in case of all_expr. Note that related mode options will
15720 be ignored if those are set.
15721
15722 The expressions can use the following variables:
15723
15724 N The sequential number of the filtered frame, starting from 0.
15725
15726 X
15727 Y the coordinates of the current sample
15728
15729 W
15730 H the width and height of currently filtered plane
15731
15732 SW
15733 SH Width and height scale for the plane being filtered. It is the
15734 ratio between the dimensions of the current plane to the luma
15735 plane, e.g. for a "yuv420p" frame, the values are "1,1" for the
15736 luma plane and "0.5,0.5" for the chroma planes.
15737
15738 T Time of the current frame, expressed in seconds.
15739
15740 TOP, A
15741 Value of pixel component at current location for first video
15742 frame (top layer).
15743
15744 BOTTOM, B
15745 Value of pixel component at current location for second video
15746 frame (bottom layer).
15747
15748 The "blend" filter also supports the framesync options.
15749
15750 Examples
15751
15752 • Apply transition from bottom layer to top layer in first 10
15753 seconds:
15754
15755 blend=all_expr='A*(if(gte(T,10),1,T/10))+B*(1-(if(gte(T,10),1,T/10)))'
15756
15757 • Apply linear horizontal transition from top layer to bottom layer:
15758
15759 blend=all_expr='A*(X/W)+B*(1-X/W)'
15760
15761 • Apply 1x1 checkerboard effect:
15762
15763 blend=all_expr='if(eq(mod(X,2),mod(Y,2)),A,B)'
15764
15765 • Apply uncover left effect:
15766
15767 blend=all_expr='if(gte(N*SW+X,W),A,B)'
15768
15769 • Apply uncover down effect:
15770
15771 blend=all_expr='if(gte(Y-N*SH,0),A,B)'
15772
15773 • Apply uncover up-left effect:
15774
15775 blend=all_expr='if(gte(T*SH*40+Y,H)*gte((T*40*SW+X)*W/H,W),A,B)'
15776
15777 • Split diagonally video and shows top and bottom layer on each side:
15778
15779 blend=all_expr='if(gt(X,Y*(W/H)),A,B)'
15780
15781 • Display differences between the current and the previous frame:
15782
15783 tblend=all_mode=grainextract
15784
15785 Commands
15786
15787 This filter supports same commands as options.
15788
15789 bm3d
15790 Denoise frames using Block-Matching 3D algorithm.
15791
15792 The filter accepts the following options.
15793
15794 sigma
15795 Set denoising strength. Default value is 1. Allowed range is from
15796 0 to 999.9. The denoising algorithm is very sensitive to sigma, so
15797 adjust it according to the source.
15798
15799 block
15800 Set local patch size. This sets dimensions in 2D.
15801
15802 bstep
15803 Set sliding step for processing blocks. Default value is 4.
15804 Allowed range is from 1 to 64. Smaller values allows processing
15805 more reference blocks and is slower.
15806
15807 group
15808 Set maximal number of similar blocks for 3rd dimension. Default
15809 value is 1. When set to 1, no block matching is done. Larger
15810 values allows more blocks in single group. Allowed range is from 1
15811 to 256.
15812
15813 range
15814 Set radius for search block matching. Default is 9. Allowed range
15815 is from 1 to INT32_MAX.
15816
15817 mstep
15818 Set step between two search locations for block matching. Default
15819 is 1. Allowed range is from 1 to 64. Smaller is slower.
15820
15821 thmse
15822 Set threshold of mean square error for block matching. Valid range
15823 is 0 to INT32_MAX.
15824
15825 hdthr
15826 Set thresholding parameter for hard thresholding in 3D transformed
15827 domain. Larger values results in stronger hard-thresholding
15828 filtering in frequency domain.
15829
15830 estim
15831 Set filtering estimation mode. Can be "basic" or "final". Default
15832 is "basic".
15833
15834 ref If enabled, filter will use 2nd stream for block matching. Default
15835 is disabled for "basic" value of estim option, and always enabled
15836 if value of estim is "final".
15837
15838 planes
15839 Set planes to filter. Default is all available except alpha.
15840
15841 Examples
15842
15843 • Basic filtering with bm3d:
15844
15845 bm3d=sigma=3:block=4:bstep=2:group=1:estim=basic
15846
15847 • Same as above, but filtering only luma:
15848
15849 bm3d=sigma=3:block=4:bstep=2:group=1:estim=basic:planes=1
15850
15851 • Same as above, but with both estimation modes:
15852
15853 split[a][b],[a]bm3d=sigma=3:block=4:bstep=2:group=1:estim=basic[a],[b][a]bm3d=sigma=3:block=4:bstep=2:group=16:estim=final:ref=1
15854
15855 • Same as above, but prefilter with nlmeans filter instead:
15856
15857 split[a][b],[a]nlmeans=s=3:r=7:p=3[a],[b][a]bm3d=sigma=3:block=4:bstep=2:group=16:estim=final:ref=1
15858
15859 boxblur
15860 Apply a boxblur algorithm to the input video.
15861
15862 It accepts the following parameters:
15863
15864 luma_radius, lr
15865 luma_power, lp
15866 chroma_radius, cr
15867 chroma_power, cp
15868 alpha_radius, ar
15869 alpha_power, ap
15870
15871 A description of the accepted options follows.
15872
15873 luma_radius, lr
15874 chroma_radius, cr
15875 alpha_radius, ar
15876 Set an expression for the box radius in pixels used for blurring
15877 the corresponding input plane.
15878
15879 The radius value must be a non-negative number, and must not be
15880 greater than the value of the expression "min(w,h)/2" for the luma
15881 and alpha planes, and of "min(cw,ch)/2" for the chroma planes.
15882
15883 Default value for luma_radius is "2". If not specified,
15884 chroma_radius and alpha_radius default to the corresponding value
15885 set for luma_radius.
15886
15887 The expressions can contain the following constants:
15888
15889 w
15890 h The input width and height in pixels.
15891
15892 cw
15893 ch The input chroma image width and height in pixels.
15894
15895 hsub
15896 vsub
15897 The horizontal and vertical chroma subsample values. For
15898 example, for the pixel format "yuv422p", hsub is 2 and vsub is
15899 1.
15900
15901 luma_power, lp
15902 chroma_power, cp
15903 alpha_power, ap
15904 Specify how many times the boxblur filter is applied to the
15905 corresponding plane.
15906
15907 Default value for luma_power is 2. If not specified, chroma_power
15908 and alpha_power default to the corresponding value set for
15909 luma_power.
15910
15911 A value of 0 will disable the effect.
15912
15913 Examples
15914
15915 • Apply a boxblur filter with the luma, chroma, and alpha radii set
15916 to 2:
15917
15918 boxblur=luma_radius=2:luma_power=1
15919 boxblur=2:1
15920
15921 • Set the luma radius to 2, and alpha and chroma radius to 0:
15922
15923 boxblur=2:1:cr=0:ar=0
15924
15925 • Set the luma and chroma radii to a fraction of the video dimension:
15926
15927 boxblur=luma_radius=min(h\,w)/10:luma_power=1:chroma_radius=min(cw\,ch)/10:chroma_power=1
15928
15929 bwdif
15930 Deinterlace the input video ("bwdif" stands for "Bob Weaver
15931 Deinterlacing Filter").
15932
15933 Motion adaptive deinterlacing based on yadif with the use of w3fdif and
15934 cubic interpolation algorithms. It accepts the following parameters:
15935
15936 mode
15937 The interlacing mode to adopt. It accepts one of the following
15938 values:
15939
15940 0, send_frame
15941 Output one frame for each frame.
15942
15943 1, send_field
15944 Output one frame for each field.
15945
15946 The default value is "send_field".
15947
15948 parity
15949 The picture field parity assumed for the input interlaced video. It
15950 accepts one of the following values:
15951
15952 0, tff
15953 Assume the top field is first.
15954
15955 1, bff
15956 Assume the bottom field is first.
15957
15958 -1, auto
15959 Enable automatic detection of field parity.
15960
15961 The default value is "auto". If the interlacing is unknown or the
15962 decoder does not export this information, top field first will be
15963 assumed.
15964
15965 deint
15966 Specify which frames to deinterlace. Accepts one of the following
15967 values:
15968
15969 0, all
15970 Deinterlace all frames.
15971
15972 1, interlaced
15973 Only deinterlace frames marked as interlaced.
15974
15975 The default value is "all".
15976
15977 cas
15978 Apply Contrast Adaptive Sharpen filter to video stream.
15979
15980 The filter accepts the following options:
15981
15982 strength
15983 Set the sharpening strength. Default value is 0.
15984
15985 planes
15986 Set planes to filter. Default value is to filter all planes except
15987 alpha plane.
15988
15989 Commands
15990
15991 This filter supports same commands as options.
15992
15993 chromahold
15994 Remove all color information for all colors except for certain one.
15995
15996 The filter accepts the following options:
15997
15998 color
15999 The color which will not be replaced with neutral chroma.
16000
16001 similarity
16002 Similarity percentage with the above color. 0.01 matches only the
16003 exact key color, while 1.0 matches everything.
16004
16005 blend
16006 Blend percentage. 0.0 makes pixels either fully gray, or not gray
16007 at all. Higher values result in more preserved color.
16008
16009 yuv Signals that the color passed is already in YUV instead of RGB.
16010
16011 Literal colors like "green" or "red" don't make sense with this
16012 enabled anymore. This can be used to pass exact YUV values as
16013 hexadecimal numbers.
16014
16015 Commands
16016
16017 This filter supports same commands as options. The command accepts the
16018 same syntax of the corresponding option.
16019
16020 If the specified expression is not valid, it is kept at its current
16021 value.
16022
16023 chromakey
16024 YUV colorspace color/chroma keying.
16025
16026 The filter accepts the following options:
16027
16028 color
16029 The color which will be replaced with transparency.
16030
16031 similarity
16032 Similarity percentage with the key color.
16033
16034 0.01 matches only the exact key color, while 1.0 matches
16035 everything.
16036
16037 blend
16038 Blend percentage.
16039
16040 0.0 makes pixels either fully transparent, or not transparent at
16041 all.
16042
16043 Higher values result in semi-transparent pixels, with a higher
16044 transparency the more similar the pixels color is to the key color.
16045
16046 yuv Signals that the color passed is already in YUV instead of RGB.
16047
16048 Literal colors like "green" or "red" don't make sense with this
16049 enabled anymore. This can be used to pass exact YUV values as
16050 hexadecimal numbers.
16051
16052 Commands
16053
16054 This filter supports same commands as options. The command accepts the
16055 same syntax of the corresponding option.
16056
16057 If the specified expression is not valid, it is kept at its current
16058 value.
16059
16060 Examples
16061
16062 • Make every green pixel in the input image transparent:
16063
16064 ffmpeg -i input.png -vf chromakey=green out.png
16065
16066 • Overlay a greenscreen-video on top of a static black background.
16067
16068 ffmpeg -f lavfi -i color=c=black:s=1280x720 -i video.mp4 -shortest -filter_complex "[1:v]chromakey=0x70de77:0.1:0.2[ckout];[0:v][ckout]overlay[out]" -map "[out]" output.mkv
16069
16070 chromanr
16071 Reduce chrominance noise.
16072
16073 The filter accepts the following options:
16074
16075 thres
16076 Set threshold for averaging chrominance values. Sum of absolute
16077 difference of Y, U and V pixel components of current pixel and
16078 neighbour pixels lower than this threshold will be used in
16079 averaging. Luma component is left unchanged and is copied to
16080 output. Default value is 30. Allowed range is from 1 to 200.
16081
16082 sizew
16083 Set horizontal radius of rectangle used for averaging. Allowed
16084 range is from 1 to 100. Default value is 5.
16085
16086 sizeh
16087 Set vertical radius of rectangle used for averaging. Allowed range
16088 is from 1 to 100. Default value is 5.
16089
16090 stepw
16091 Set horizontal step when averaging. Default value is 1. Allowed
16092 range is from 1 to 50. Mostly useful to speed-up filtering.
16093
16094 steph
16095 Set vertical step when averaging. Default value is 1. Allowed
16096 range is from 1 to 50. Mostly useful to speed-up filtering.
16097
16098 threy
16099 Set Y threshold for averaging chrominance values. Set finer
16100 control for max allowed difference between Y components of current
16101 pixel and neigbour pixels. Default value is 200. Allowed range is
16102 from 1 to 200.
16103
16104 threu
16105 Set U threshold for averaging chrominance values. Set finer
16106 control for max allowed difference between U components of current
16107 pixel and neigbour pixels. Default value is 200. Allowed range is
16108 from 1 to 200.
16109
16110 threv
16111 Set V threshold for averaging chrominance values. Set finer
16112 control for max allowed difference between V components of current
16113 pixel and neigbour pixels. Default value is 200. Allowed range is
16114 from 1 to 200.
16115
16116 distance
16117 Set distance type used in calculations.
16118
16119 manhattan
16120 Absolute difference.
16121
16122 euclidean
16123 Difference squared.
16124
16125 Default distance type is manhattan.
16126
16127 Commands
16128
16129 This filter supports same commands as options. The command accepts the
16130 same syntax of the corresponding option.
16131
16132 chromashift
16133 Shift chroma pixels horizontally and/or vertically.
16134
16135 The filter accepts the following options:
16136
16137 cbh Set amount to shift chroma-blue horizontally.
16138
16139 cbv Set amount to shift chroma-blue vertically.
16140
16141 crh Set amount to shift chroma-red horizontally.
16142
16143 crv Set amount to shift chroma-red vertically.
16144
16145 edge
16146 Set edge mode, can be smear, default, or warp.
16147
16148 Commands
16149
16150 This filter supports the all above options as commands.
16151
16152 ciescope
16153 Display CIE color diagram with pixels overlaid onto it.
16154
16155 The filter accepts the following options:
16156
16157 system
16158 Set color system.
16159
16160 ntsc, 470m
16161 ebu, 470bg
16162 smpte
16163 240m
16164 apple
16165 widergb
16166 cie1931
16167 rec709, hdtv
16168 uhdtv, rec2020
16169 dcip3
16170 cie Set CIE system.
16171
16172 xyy
16173 ucs
16174 luv
16175 gamuts
16176 Set what gamuts to draw.
16177
16178 See "system" option for available values.
16179
16180 size, s
16181 Set ciescope size, by default set to 512.
16182
16183 intensity, i
16184 Set intensity used to map input pixel values to CIE diagram.
16185
16186 contrast
16187 Set contrast used to draw tongue colors that are out of active
16188 color system gamut.
16189
16190 corrgamma
16191 Correct gamma displayed on scope, by default enabled.
16192
16193 showwhite
16194 Show white point on CIE diagram, by default disabled.
16195
16196 gamma
16197 Set input gamma. Used only with XYZ input color space.
16198
16199 codecview
16200 Visualize information exported by some codecs.
16201
16202 Some codecs can export information through frames using side-data or
16203 other means. For example, some MPEG based codecs export motion vectors
16204 through the export_mvs flag in the codec flags2 option.
16205
16206 The filter accepts the following option:
16207
16208 block
16209 Display block partition structure using the luma plane.
16210
16211 mv Set motion vectors to visualize.
16212
16213 Available flags for mv are:
16214
16215 pf forward predicted MVs of P-frames
16216
16217 bf forward predicted MVs of B-frames
16218
16219 bb backward predicted MVs of B-frames
16220
16221 qp Display quantization parameters using the chroma planes.
16222
16223 mv_type, mvt
16224 Set motion vectors type to visualize. Includes MVs from all frames
16225 unless specified by frame_type option.
16226
16227 Available flags for mv_type are:
16228
16229 fp forward predicted MVs
16230
16231 bp backward predicted MVs
16232
16233 frame_type, ft
16234 Set frame type to visualize motion vectors of.
16235
16236 Available flags for frame_type are:
16237
16238 if intra-coded frames (I-frames)
16239
16240 pf predicted frames (P-frames)
16241
16242 bf bi-directionally predicted frames (B-frames)
16243
16244 Examples
16245
16246 • Visualize forward predicted MVs of all frames using ffplay:
16247
16248 ffplay -flags2 +export_mvs input.mp4 -vf codecview=mv_type=fp
16249
16250 • Visualize multi-directionals MVs of P and B-Frames using ffplay:
16251
16252 ffplay -flags2 +export_mvs input.mp4 -vf codecview=mv=pf+bf+bb
16253
16254 colorbalance
16255 Modify intensity of primary colors (red, green and blue) of input
16256 frames.
16257
16258 The filter allows an input frame to be adjusted in the shadows,
16259 midtones or highlights regions for the red-cyan, green-magenta or blue-
16260 yellow balance.
16261
16262 A positive adjustment value shifts the balance towards the primary
16263 color, a negative value towards the complementary color.
16264
16265 The filter accepts the following options:
16266
16267 rs
16268 gs
16269 bs Adjust red, green and blue shadows (darkest pixels).
16270
16271 rm
16272 gm
16273 bm Adjust red, green and blue midtones (medium pixels).
16274
16275 rh
16276 gh
16277 bh Adjust red, green and blue highlights (brightest pixels).
16278
16279 Allowed ranges for options are "[-1.0, 1.0]". Defaults are 0.
16280
16281 pl Preserve lightness when changing color balance. Default is
16282 disabled.
16283
16284 Examples
16285
16286 • Add red color cast to shadows:
16287
16288 colorbalance=rs=.3
16289
16290 Commands
16291
16292 This filter supports the all above options as commands.
16293
16294 colorcontrast
16295 Adjust color contrast between RGB components.
16296
16297 The filter accepts the following options:
16298
16299 rc Set the red-cyan contrast. Defaults is 0.0. Allowed range is from
16300 -1.0 to 1.0.
16301
16302 gm Set the green-magenta contrast. Defaults is 0.0. Allowed range is
16303 from -1.0 to 1.0.
16304
16305 by Set the blue-yellow contrast. Defaults is 0.0. Allowed range is
16306 from -1.0 to 1.0.
16307
16308 rcw
16309 gmw
16310 byw Set the weight of each "rc", "gm", "by" option value. Default value
16311 is 0.0. Allowed range is from 0.0 to 1.0. If all weights are 0.0
16312 filtering is disabled.
16313
16314 pl Set the amount of preserving lightness. Default value is 0.0.
16315 Allowed range is from 0.0 to 1.0.
16316
16317 Commands
16318
16319 This filter supports the all above options as commands.
16320
16321 colorcorrect
16322 Adjust color white balance selectively for blacks and whites. This
16323 filter operates in YUV colorspace.
16324
16325 The filter accepts the following options:
16326
16327 rl Set the red shadow spot. Allowed range is from -1.0 to 1.0.
16328 Default value is 0.
16329
16330 bl Set the blue shadow spot. Allowed range is from -1.0 to 1.0.
16331 Default value is 0.
16332
16333 rh Set the red highlight spot. Allowed range is from -1.0 to 1.0.
16334 Default value is 0.
16335
16336 bh Set the red highlight spot. Allowed range is from -1.0 to 1.0.
16337 Default value is 0.
16338
16339 saturation
16340 Set the amount of saturation. Allowed range is from -3.0 to 3.0.
16341 Default value is 1.
16342
16343 analyze
16344 If set to anything other than "manual" it will analyze every frame
16345 and use derived parameters for filtering output frame.
16346
16347 Possible values are:
16348
16349 manual
16350 average
16351 minmax
16352 median
16353
16354 Default value is "manual".
16355
16356 Commands
16357
16358 This filter supports the all above options as commands.
16359
16360 colorchannelmixer
16361 Adjust video input frames by re-mixing color channels.
16362
16363 This filter modifies a color channel by adding the values associated to
16364 the other channels of the same pixels. For example if the value to
16365 modify is red, the output value will be:
16366
16367 <red>=<red>*<rr> + <blue>*<rb> + <green>*<rg> + <alpha>*<ra>
16368
16369 The filter accepts the following options:
16370
16371 rr
16372 rg
16373 rb
16374 ra Adjust contribution of input red, green, blue and alpha channels
16375 for output red channel. Default is 1 for rr, and 0 for rg, rb and
16376 ra.
16377
16378 gr
16379 gg
16380 gb
16381 ga Adjust contribution of input red, green, blue and alpha channels
16382 for output green channel. Default is 1 for gg, and 0 for gr, gb
16383 and ga.
16384
16385 br
16386 bg
16387 bb
16388 ba Adjust contribution of input red, green, blue and alpha channels
16389 for output blue channel. Default is 1 for bb, and 0 for br, bg and
16390 ba.
16391
16392 ar
16393 ag
16394 ab
16395 aa Adjust contribution of input red, green, blue and alpha channels
16396 for output alpha channel. Default is 1 for aa, and 0 for ar, ag
16397 and ab.
16398
16399 Allowed ranges for options are "[-2.0, 2.0]".
16400
16401 pc Set preserve color mode. The accepted values are:
16402
16403 none
16404 Disable color preserving, this is default.
16405
16406 lum Preserve luminance.
16407
16408 max Preserve max value of RGB triplet.
16409
16410 avg Preserve average value of RGB triplet.
16411
16412 sum Preserve sum value of RGB triplet.
16413
16414 nrm Preserve normalized value of RGB triplet.
16415
16416 pwr Preserve power value of RGB triplet.
16417
16418 pa Set the preserve color amount when changing colors. Allowed range
16419 is from "[0.0, 1.0]". Default is 0.0, thus disabled.
16420
16421 Examples
16422
16423 • Convert source to grayscale:
16424
16425 colorchannelmixer=.3:.4:.3:0:.3:.4:.3:0:.3:.4:.3
16426
16427 • Simulate sepia tones:
16428
16429 colorchannelmixer=.393:.769:.189:0:.349:.686:.168:0:.272:.534:.131
16430
16431 Commands
16432
16433 This filter supports the all above options as commands.
16434
16435 colorize
16436 Overlay a solid color on the video stream.
16437
16438 The filter accepts the following options:
16439
16440 hue Set the color hue. Allowed range is from 0 to 360. Default value
16441 is 0.
16442
16443 saturation
16444 Set the color saturation. Allowed range is from 0 to 1. Default
16445 value is 0.5.
16446
16447 lightness
16448 Set the color lightness. Allowed range is from 0 to 1. Default
16449 value is 0.5.
16450
16451 mix Set the mix of source lightness. By default is set to 1.0. Allowed
16452 range is from 0.0 to 1.0.
16453
16454 Commands
16455
16456 This filter supports the all above options as commands.
16457
16458 colorkey
16459 RGB colorspace color keying. This filter operates on 8-bit RGB format
16460 frames by setting the alpha component of each pixel which falls within
16461 the similarity radius of the key color to 0. The alpha value for pixels
16462 outside the similarity radius depends on the value of the blend option.
16463
16464 The filter accepts the following options:
16465
16466 color
16467 Set the color for which alpha will be set to 0 (full transparency).
16468 See "Color" section in the ffmpeg-utils manual. Default is
16469 "black".
16470
16471 similarity
16472 Set the radius from the key color within which other colors also
16473 have full transparency. The computed distance is related to the
16474 unit fractional distance in 3D space between the RGB values of the
16475 key color and the pixel's color. Range is 0.01 to 1.0. 0.01 matches
16476 within a very small radius around the exact key color, while 1.0
16477 matches everything. Default is 0.01.
16478
16479 blend
16480 Set how the alpha value for pixels that fall outside the similarity
16481 radius is computed. 0.0 makes pixels either fully transparent or
16482 fully opaque. Higher values result in semi-transparent pixels,
16483 with greater transparency the more similar the pixel color is to
16484 the key color. Range is 0.0 to 1.0. Default is 0.0.
16485
16486 Examples
16487
16488 • Make every green pixel in the input image transparent:
16489
16490 ffmpeg -i input.png -vf colorkey=green out.png
16491
16492 • Overlay a greenscreen-video on top of a static background image.
16493
16494 ffmpeg -i background.png -i video.mp4 -filter_complex "[1:v]colorkey=0x3BBD1E:0.3:0.2[ckout];[0:v][ckout]overlay[out]" -map "[out]" output.flv
16495
16496 Commands
16497
16498 This filter supports same commands as options. The command accepts the
16499 same syntax of the corresponding option.
16500
16501 If the specified expression is not valid, it is kept at its current
16502 value.
16503
16504 colorhold
16505 Remove all color information for all RGB colors except for certain one.
16506
16507 The filter accepts the following options:
16508
16509 color
16510 The color which will not be replaced with neutral gray.
16511
16512 similarity
16513 Similarity percentage with the above color. 0.01 matches only the
16514 exact key color, while 1.0 matches everything.
16515
16516 blend
16517 Blend percentage. 0.0 makes pixels fully gray. Higher values
16518 result in more preserved color.
16519
16520 Commands
16521
16522 This filter supports same commands as options. The command accepts the
16523 same syntax of the corresponding option.
16524
16525 If the specified expression is not valid, it is kept at its current
16526 value.
16527
16528 colorlevels
16529 Adjust video input frames using levels.
16530
16531 The filter accepts the following options:
16532
16533 rimin
16534 gimin
16535 bimin
16536 aimin
16537 Adjust red, green, blue and alpha input black point. Allowed
16538 ranges for options are "[-1.0, 1.0]". Defaults are 0.
16539
16540 rimax
16541 gimax
16542 bimax
16543 aimax
16544 Adjust red, green, blue and alpha input white point. Allowed
16545 ranges for options are "[-1.0, 1.0]". Defaults are 1.
16546
16547 Input levels are used to lighten highlights (bright tones), darken
16548 shadows (dark tones), change the balance of bright and dark tones.
16549
16550 romin
16551 gomin
16552 bomin
16553 aomin
16554 Adjust red, green, blue and alpha output black point. Allowed
16555 ranges for options are "[0, 1.0]". Defaults are 0.
16556
16557 romax
16558 gomax
16559 bomax
16560 aomax
16561 Adjust red, green, blue and alpha output white point. Allowed
16562 ranges for options are "[0, 1.0]". Defaults are 1.
16563
16564 Output levels allows manual selection of a constrained output level
16565 range.
16566
16567 preserve
16568 Set preserve color mode. The accepted values are:
16569
16570 none
16571 Disable color preserving, this is default.
16572
16573 lum Preserve luminance.
16574
16575 max Preserve max value of RGB triplet.
16576
16577 avg Preserve average value of RGB triplet.
16578
16579 sum Preserve sum value of RGB triplet.
16580
16581 nrm Preserve normalized value of RGB triplet.
16582
16583 pwr Preserve power value of RGB triplet.
16584
16585 Examples
16586
16587 • Make video output darker:
16588
16589 colorlevels=rimin=0.058:gimin=0.058:bimin=0.058
16590
16591 • Increase contrast:
16592
16593 colorlevels=rimin=0.039:gimin=0.039:bimin=0.039:rimax=0.96:gimax=0.96:bimax=0.96
16594
16595 • Make video output lighter:
16596
16597 colorlevels=rimax=0.902:gimax=0.902:bimax=0.902
16598
16599 • Increase brightness:
16600
16601 colorlevels=romin=0.5:gomin=0.5:bomin=0.5
16602
16603 Commands
16604
16605 This filter supports the all above options as commands.
16606
16607 colormatrix
16608 Convert color matrix.
16609
16610 The filter accepts the following options:
16611
16612 src
16613 dst Specify the source and destination color matrix. Both values must
16614 be specified.
16615
16616 The accepted values are:
16617
16618 bt709
16619 BT.709
16620
16621 fcc FCC
16622
16623 bt601
16624 BT.601
16625
16626 bt470
16627 BT.470
16628
16629 bt470bg
16630 BT.470BG
16631
16632 smpte170m
16633 SMPTE-170M
16634
16635 smpte240m
16636 SMPTE-240M
16637
16638 bt2020
16639 BT.2020
16640
16641 For example to convert from BT.601 to SMPTE-240M, use the command:
16642
16643 colormatrix=bt601:smpte240m
16644
16645 colorspace
16646 Convert colorspace, transfer characteristics or color primaries. Input
16647 video needs to have an even size.
16648
16649 The filter accepts the following options:
16650
16651 all Specify all color properties at once.
16652
16653 The accepted values are:
16654
16655 bt470m
16656 BT.470M
16657
16658 bt470bg
16659 BT.470BG
16660
16661 bt601-6-525
16662 BT.601-6 525
16663
16664 bt601-6-625
16665 BT.601-6 625
16666
16667 bt709
16668 BT.709
16669
16670 smpte170m
16671 SMPTE-170M
16672
16673 smpte240m
16674 SMPTE-240M
16675
16676 bt2020
16677 BT.2020
16678
16679 space
16680 Specify output colorspace.
16681
16682 The accepted values are:
16683
16684 bt709
16685 BT.709
16686
16687 fcc FCC
16688
16689 bt470bg
16690 BT.470BG or BT.601-6 625
16691
16692 smpte170m
16693 SMPTE-170M or BT.601-6 525
16694
16695 smpte240m
16696 SMPTE-240M
16697
16698 ycgco
16699 YCgCo
16700
16701 bt2020ncl
16702 BT.2020 with non-constant luminance
16703
16704 trc Specify output transfer characteristics.
16705
16706 The accepted values are:
16707
16708 bt709
16709 BT.709
16710
16711 bt470m
16712 BT.470M
16713
16714 bt470bg
16715 BT.470BG
16716
16717 gamma22
16718 Constant gamma of 2.2
16719
16720 gamma28
16721 Constant gamma of 2.8
16722
16723 smpte170m
16724 SMPTE-170M, BT.601-6 625 or BT.601-6 525
16725
16726 smpte240m
16727 SMPTE-240M
16728
16729 srgb
16730 SRGB
16731
16732 iec61966-2-1
16733 iec61966-2-1
16734
16735 iec61966-2-4
16736 iec61966-2-4
16737
16738 xvycc
16739 xvycc
16740
16741 bt2020-10
16742 BT.2020 for 10-bits content
16743
16744 bt2020-12
16745 BT.2020 for 12-bits content
16746
16747 primaries
16748 Specify output color primaries.
16749
16750 The accepted values are:
16751
16752 bt709
16753 BT.709
16754
16755 bt470m
16756 BT.470M
16757
16758 bt470bg
16759 BT.470BG or BT.601-6 625
16760
16761 smpte170m
16762 SMPTE-170M or BT.601-6 525
16763
16764 smpte240m
16765 SMPTE-240M
16766
16767 film
16768 film
16769
16770 smpte431
16771 SMPTE-431
16772
16773 smpte432
16774 SMPTE-432
16775
16776 bt2020
16777 BT.2020
16778
16779 jedec-p22
16780 JEDEC P22 phosphors
16781
16782 range
16783 Specify output color range.
16784
16785 The accepted values are:
16786
16787 tv TV (restricted) range
16788
16789 mpeg
16790 MPEG (restricted) range
16791
16792 pc PC (full) range
16793
16794 jpeg
16795 JPEG (full) range
16796
16797 format
16798 Specify output color format.
16799
16800 The accepted values are:
16801
16802 yuv420p
16803 YUV 4:2:0 planar 8-bits
16804
16805 yuv420p10
16806 YUV 4:2:0 planar 10-bits
16807
16808 yuv420p12
16809 YUV 4:2:0 planar 12-bits
16810
16811 yuv422p
16812 YUV 4:2:2 planar 8-bits
16813
16814 yuv422p10
16815 YUV 4:2:2 planar 10-bits
16816
16817 yuv422p12
16818 YUV 4:2:2 planar 12-bits
16819
16820 yuv444p
16821 YUV 4:4:4 planar 8-bits
16822
16823 yuv444p10
16824 YUV 4:4:4 planar 10-bits
16825
16826 yuv444p12
16827 YUV 4:4:4 planar 12-bits
16828
16829 fast
16830 Do a fast conversion, which skips gamma/primary correction. This
16831 will take significantly less CPU, but will be mathematically
16832 incorrect. To get output compatible with that produced by the
16833 colormatrix filter, use fast=1.
16834
16835 dither
16836 Specify dithering mode.
16837
16838 The accepted values are:
16839
16840 none
16841 No dithering
16842
16843 fsb Floyd-Steinberg dithering
16844
16845 wpadapt
16846 Whitepoint adaptation mode.
16847
16848 The accepted values are:
16849
16850 bradford
16851 Bradford whitepoint adaptation
16852
16853 vonkries
16854 von Kries whitepoint adaptation
16855
16856 identity
16857 identity whitepoint adaptation (i.e. no whitepoint adaptation)
16858
16859 iall
16860 Override all input properties at once. Same accepted values as all.
16861
16862 ispace
16863 Override input colorspace. Same accepted values as space.
16864
16865 iprimaries
16866 Override input color primaries. Same accepted values as primaries.
16867
16868 itrc
16869 Override input transfer characteristics. Same accepted values as
16870 trc.
16871
16872 irange
16873 Override input color range. Same accepted values as range.
16874
16875 The filter converts the transfer characteristics, color space and color
16876 primaries to the specified user values. The output value, if not
16877 specified, is set to a default value based on the "all" property. If
16878 that property is also not specified, the filter will log an error. The
16879 output color range and format default to the same value as the input
16880 color range and format. The input transfer characteristics, color
16881 space, color primaries and color range should be set on the input data.
16882 If any of these are missing, the filter will log an error and no
16883 conversion will take place.
16884
16885 For example to convert the input to SMPTE-240M, use the command:
16886
16887 colorspace=smpte240m
16888
16889 colortemperature
16890 Adjust color temperature in video to simulate variations in ambient
16891 color temperature.
16892
16893 The filter accepts the following options:
16894
16895 temperature
16896 Set the temperature in Kelvin. Allowed range is from 1000 to 40000.
16897 Default value is 6500 K.
16898
16899 mix Set mixing with filtered output. Allowed range is from 0 to 1.
16900 Default value is 1.
16901
16902 pl Set the amount of preserving lightness. Allowed range is from 0 to
16903 1. Default value is 0.
16904
16905 Commands
16906
16907 This filter supports same commands as options.
16908
16909 convolution
16910 Apply convolution of 3x3, 5x5, 7x7 or horizontal/vertical up to 49
16911 elements.
16912
16913 The filter accepts the following options:
16914
16915 0m
16916 1m
16917 2m
16918 3m Set matrix for each plane. Matrix is sequence of 9, 25 or 49
16919 signed integers in square mode, and from 1 to 49 odd number of
16920 signed integers in row mode.
16921
16922 0rdiv
16923 1rdiv
16924 2rdiv
16925 3rdiv
16926 Set multiplier for calculated value for each plane. If unset or 0,
16927 it will be sum of all matrix elements.
16928
16929 0bias
16930 1bias
16931 2bias
16932 3bias
16933 Set bias for each plane. This value is added to the result of the
16934 multiplication. Useful for making the overall image brighter or
16935 darker. Default is 0.0.
16936
16937 0mode
16938 1mode
16939 2mode
16940 3mode
16941 Set matrix mode for each plane. Can be square, row or column.
16942 Default is square.
16943
16944 Commands
16945
16946 This filter supports the all above options as commands.
16947
16948 Examples
16949
16950 • Apply sharpen:
16951
16952 convolution="0 -1 0 -1 5 -1 0 -1 0:0 -1 0 -1 5 -1 0 -1 0:0 -1 0 -1 5 -1 0 -1 0:0 -1 0 -1 5 -1 0 -1 0"
16953
16954 • Apply blur:
16955
16956 convolution="1 1 1 1 1 1 1 1 1:1 1 1 1 1 1 1 1 1:1 1 1 1 1 1 1 1 1:1 1 1 1 1 1 1 1 1:1/9:1/9:1/9:1/9"
16957
16958 • Apply edge enhance:
16959
16960 convolution="0 0 0 -1 1 0 0 0 0:0 0 0 -1 1 0 0 0 0:0 0 0 -1 1 0 0 0 0:0 0 0 -1 1 0 0 0 0:5:1:1:1:0:128:128:128"
16961
16962 • Apply edge detect:
16963
16964 convolution="0 1 0 1 -4 1 0 1 0:0 1 0 1 -4 1 0 1 0:0 1 0 1 -4 1 0 1 0:0 1 0 1 -4 1 0 1 0:5:5:5:1:0:128:128:128"
16965
16966 • Apply laplacian edge detector which includes diagonals:
16967
16968 convolution="1 1 1 1 -8 1 1 1 1:1 1 1 1 -8 1 1 1 1:1 1 1 1 -8 1 1 1 1:1 1 1 1 -8 1 1 1 1:5:5:5:1:0:128:128:0"
16969
16970 • Apply emboss:
16971
16972 convolution="-2 -1 0 -1 1 1 0 1 2:-2 -1 0 -1 1 1 0 1 2:-2 -1 0 -1 1 1 0 1 2:-2 -1 0 -1 1 1 0 1 2"
16973
16974 convolve
16975 Apply 2D convolution of video stream in frequency domain using second
16976 stream as impulse.
16977
16978 The filter accepts the following options:
16979
16980 planes
16981 Set which planes to process.
16982
16983 impulse
16984 Set which impulse video frames will be processed, can be first or
16985 all. Default is all.
16986
16987 The "convolve" filter also supports the framesync options.
16988
16989 copy
16990 Copy the input video source unchanged to the output. This is mainly
16991 useful for testing purposes.
16992
16993 coreimage
16994 Video filtering on GPU using Apple's CoreImage API on OSX.
16995
16996 Hardware acceleration is based on an OpenGL context. Usually, this
16997 means it is processed by video hardware. However, software-based OpenGL
16998 implementations exist which means there is no guarantee for hardware
16999 processing. It depends on the respective OSX.
17000
17001 There are many filters and image generators provided by Apple that come
17002 with a large variety of options. The filter has to be referenced by its
17003 name along with its options.
17004
17005 The coreimage filter accepts the following options:
17006
17007 list_filters
17008 List all available filters and generators along with all their
17009 respective options as well as possible minimum and maximum values
17010 along with the default values.
17011
17012 list_filters=true
17013
17014 filter
17015 Specify all filters by their respective name and options. Use
17016 list_filters to determine all valid filter names and options.
17017 Numerical options are specified by a float value and are
17018 automatically clamped to their respective value range. Vector and
17019 color options have to be specified by a list of space separated
17020 float values. Character escaping has to be done. A special option
17021 name "default" is available to use default options for a filter.
17022
17023 It is required to specify either "default" or at least one of the
17024 filter options. All omitted options are used with their default
17025 values. The syntax of the filter string is as follows:
17026
17027 filter=<NAME>@<OPTION>=<VALUE>[@<OPTION>=<VALUE>][@...][#<NAME>@<OPTION>=<VALUE>[@<OPTION>=<VALUE>][@...]][#...]
17028
17029 output_rect
17030 Specify a rectangle where the output of the filter chain is copied
17031 into the input image. It is given by a list of space separated
17032 float values:
17033
17034 output_rect=x\ y\ width\ height
17035
17036 If not given, the output rectangle equals the dimensions of the
17037 input image. The output rectangle is automatically cropped at the
17038 borders of the input image. Negative values are valid for each
17039 component.
17040
17041 output_rect=25\ 25\ 100\ 100
17042
17043 Several filters can be chained for successive processing without GPU-
17044 HOST transfers allowing for fast processing of complex filter chains.
17045 Currently, only filters with zero (generators) or exactly one (filters)
17046 input image and one output image are supported. Also, transition
17047 filters are not yet usable as intended.
17048
17049 Some filters generate output images with additional padding depending
17050 on the respective filter kernel. The padding is automatically removed
17051 to ensure the filter output has the same size as the input image.
17052
17053 For image generators, the size of the output image is determined by the
17054 previous output image of the filter chain or the input image of the
17055 whole filterchain, respectively. The generators do not use the pixel
17056 information of this image to generate their output. However, the
17057 generated output is blended onto this image, resulting in partial or
17058 complete coverage of the output image.
17059
17060 The coreimagesrc video source can be used for generating input images
17061 which are directly fed into the filter chain. By using it, providing
17062 input images by another video source or an input video is not required.
17063
17064 Examples
17065
17066 • List all filters available:
17067
17068 coreimage=list_filters=true
17069
17070 • Use the CIBoxBlur filter with default options to blur an image:
17071
17072 coreimage=filter=CIBoxBlur@default
17073
17074 • Use a filter chain with CISepiaTone at default values and
17075 CIVignetteEffect with its center at 100x100 and a radius of 50
17076 pixels:
17077
17078 coreimage=filter=CIBoxBlur@default#CIVignetteEffect@inputCenter=100\ 100@inputRadius=50
17079
17080 • Use nullsrc and CIQRCodeGenerator to create a QR code for the
17081 FFmpeg homepage, given as complete and escaped command-line for
17082 Apple's standard bash shell:
17083
17084 ffmpeg -f lavfi -i nullsrc=s=100x100,coreimage=filter=CIQRCodeGenerator@inputMessage=https\\\\\://FFmpeg.org/@inputCorrectionLevel=H -frames:v 1 QRCode.png
17085
17086 cover_rect
17087 Cover a rectangular object
17088
17089 It accepts the following options:
17090
17091 cover
17092 Filepath of the optional cover image, needs to be in yuv420.
17093
17094 mode
17095 Set covering mode.
17096
17097 It accepts the following values:
17098
17099 cover
17100 cover it by the supplied image
17101
17102 blur
17103 cover it by interpolating the surrounding pixels
17104
17105 Default value is blur.
17106
17107 Examples
17108
17109 • Cover a rectangular object by the supplied image of a given video
17110 using ffmpeg:
17111
17112 ffmpeg -i file.ts -vf find_rect=newref.pgm,cover_rect=cover.jpg:mode=cover new.mkv
17113
17114 crop
17115 Crop the input video to given dimensions.
17116
17117 It accepts the following parameters:
17118
17119 w, out_w
17120 The width of the output video. It defaults to "iw". This
17121 expression is evaluated only once during the filter configuration,
17122 or when the w or out_w command is sent.
17123
17124 h, out_h
17125 The height of the output video. It defaults to "ih". This
17126 expression is evaluated only once during the filter configuration,
17127 or when the h or out_h command is sent.
17128
17129 x The horizontal position, in the input video, of the left edge of
17130 the output video. It defaults to "(in_w-out_w)/2". This expression
17131 is evaluated per-frame.
17132
17133 y The vertical position, in the input video, of the top edge of the
17134 output video. It defaults to "(in_h-out_h)/2". This expression is
17135 evaluated per-frame.
17136
17137 keep_aspect
17138 If set to 1 will force the output display aspect ratio to be the
17139 same of the input, by changing the output sample aspect ratio. It
17140 defaults to 0.
17141
17142 exact
17143 Enable exact cropping. If enabled, subsampled videos will be
17144 cropped at exact width/height/x/y as specified and will not be
17145 rounded to nearest smaller value. It defaults to 0.
17146
17147 The out_w, out_h, x, y parameters are expressions containing the
17148 following constants:
17149
17150 x
17151 y The computed values for x and y. They are evaluated for each new
17152 frame.
17153
17154 in_w
17155 in_h
17156 The input width and height.
17157
17158 iw
17159 ih These are the same as in_w and in_h.
17160
17161 out_w
17162 out_h
17163 The output (cropped) width and height.
17164
17165 ow
17166 oh These are the same as out_w and out_h.
17167
17168 a same as iw / ih
17169
17170 sar input sample aspect ratio
17171
17172 dar input display aspect ratio, it is the same as (iw / ih) * sar
17173
17174 hsub
17175 vsub
17176 horizontal and vertical chroma subsample values. For example for
17177 the pixel format "yuv422p" hsub is 2 and vsub is 1.
17178
17179 n The number of the input frame, starting from 0.
17180
17181 pos the position in the file of the input frame, NAN if unknown
17182
17183 t The timestamp expressed in seconds. It's NAN if the input timestamp
17184 is unknown.
17185
17186 The expression for out_w may depend on the value of out_h, and the
17187 expression for out_h may depend on out_w, but they cannot depend on x
17188 and y, as x and y are evaluated after out_w and out_h.
17189
17190 The x and y parameters specify the expressions for the position of the
17191 top-left corner of the output (non-cropped) area. They are evaluated
17192 for each frame. If the evaluated value is not valid, it is approximated
17193 to the nearest valid value.
17194
17195 The expression for x may depend on y, and the expression for y may
17196 depend on x.
17197
17198 Examples
17199
17200 • Crop area with size 100x100 at position (12,34).
17201
17202 crop=100:100:12:34
17203
17204 Using named options, the example above becomes:
17205
17206 crop=w=100:h=100:x=12:y=34
17207
17208 • Crop the central input area with size 100x100:
17209
17210 crop=100:100
17211
17212 • Crop the central input area with size 2/3 of the input video:
17213
17214 crop=2/3*in_w:2/3*in_h
17215
17216 • Crop the input video central square:
17217
17218 crop=out_w=in_h
17219 crop=in_h
17220
17221 • Delimit the rectangle with the top-left corner placed at position
17222 100:100 and the right-bottom corner corresponding to the right-
17223 bottom corner of the input image.
17224
17225 crop=in_w-100:in_h-100:100:100
17226
17227 • Crop 10 pixels from the left and right borders, and 20 pixels from
17228 the top and bottom borders
17229
17230 crop=in_w-2*10:in_h-2*20
17231
17232 • Keep only the bottom right quarter of the input image:
17233
17234 crop=in_w/2:in_h/2:in_w/2:in_h/2
17235
17236 • Crop height for getting Greek harmony:
17237
17238 crop=in_w:1/PHI*in_w
17239
17240 • Apply trembling effect:
17241
17242 crop=in_w/2:in_h/2:(in_w-out_w)/2+((in_w-out_w)/2)*sin(n/10):(in_h-out_h)/2 +((in_h-out_h)/2)*sin(n/7)
17243
17244 • Apply erratic camera effect depending on timestamp:
17245
17246 crop=in_w/2:in_h/2:(in_w-out_w)/2+((in_w-out_w)/2)*sin(t*10):(in_h-out_h)/2 +((in_h-out_h)/2)*sin(t*13)"
17247
17248 • Set x depending on the value of y:
17249
17250 crop=in_w/2:in_h/2:y:10+10*sin(n/10)
17251
17252 Commands
17253
17254 This filter supports the following commands:
17255
17256 w, out_w
17257 h, out_h
17258 x
17259 y Set width/height of the output video and the horizontal/vertical
17260 position in the input video. The command accepts the same syntax
17261 of the corresponding option.
17262
17263 If the specified expression is not valid, it is kept at its current
17264 value.
17265
17266 cropdetect
17267 Auto-detect the crop size.
17268
17269 It calculates the necessary cropping parameters and prints the
17270 recommended parameters via the logging system. The detected dimensions
17271 correspond to the non-black area of the input video.
17272
17273 It accepts the following parameters:
17274
17275 limit
17276 Set higher black value threshold, which can be optionally specified
17277 from nothing (0) to everything (255 for 8-bit based formats). An
17278 intensity value greater to the set value is considered non-black.
17279 It defaults to 24. You can also specify a value between 0.0 and
17280 1.0 which will be scaled depending on the bitdepth of the pixel
17281 format.
17282
17283 round
17284 The value which the width/height should be divisible by. It
17285 defaults to 16. The offset is automatically adjusted to center the
17286 video. Use 2 to get only even dimensions (needed for 4:2:2 video).
17287 16 is best when encoding to most video codecs.
17288
17289 skip
17290 Set the number of initial frames for which evaluation is skipped.
17291 Default is 2. Range is 0 to INT_MAX.
17292
17293 reset_count, reset
17294 Set the counter that determines after how many frames cropdetect
17295 will reset the previously detected largest video area and start
17296 over to detect the current optimal crop area. Default value is 0.
17297
17298 This can be useful when channel logos distort the video area. 0
17299 indicates 'never reset', and returns the largest area encountered
17300 during playback.
17301
17302 cue
17303 Delay video filtering until a given wallclock timestamp. The filter
17304 first passes on preroll amount of frames, then it buffers at most
17305 buffer amount of frames and waits for the cue. After reaching the cue
17306 it forwards the buffered frames and also any subsequent frames coming
17307 in its input.
17308
17309 The filter can be used synchronize the output of multiple ffmpeg
17310 processes for realtime output devices like decklink. By putting the
17311 delay in the filtering chain and pre-buffering frames the process can
17312 pass on data to output almost immediately after the target wallclock
17313 timestamp is reached.
17314
17315 Perfect frame accuracy cannot be guaranteed, but the result is good
17316 enough for some use cases.
17317
17318 cue The cue timestamp expressed in a UNIX timestamp in microseconds.
17319 Default is 0.
17320
17321 preroll
17322 The duration of content to pass on as preroll expressed in seconds.
17323 Default is 0.
17324
17325 buffer
17326 The maximum duration of content to buffer before waiting for the
17327 cue expressed in seconds. Default is 0.
17328
17329 curves
17330 Apply color adjustments using curves.
17331
17332 This filter is similar to the Adobe Photoshop and GIMP curves tools.
17333 Each component (red, green and blue) has its values defined by N key
17334 points tied from each other using a smooth curve. The x-axis represents
17335 the pixel values from the input frame, and the y-axis the new pixel
17336 values to be set for the output frame.
17337
17338 By default, a component curve is defined by the two points (0;0) and
17339 (1;1). This creates a straight line where each original pixel value is
17340 "adjusted" to its own value, which means no change to the image.
17341
17342 The filter allows you to redefine these two points and add some more. A
17343 new curve (using a natural cubic spline interpolation) will be define
17344 to pass smoothly through all these new coordinates. The new defined
17345 points needs to be strictly increasing over the x-axis, and their x and
17346 y values must be in the [0;1] interval. If the computed curves
17347 happened to go outside the vector spaces, the values will be clipped
17348 accordingly.
17349
17350 The filter accepts the following options:
17351
17352 preset
17353 Select one of the available color presets. This option can be used
17354 in addition to the r, g, b parameters; in this case, the later
17355 options takes priority on the preset values. Available presets
17356 are:
17357
17358 none
17359 color_negative
17360 cross_process
17361 darker
17362 increase_contrast
17363 lighter
17364 linear_contrast
17365 medium_contrast
17366 negative
17367 strong_contrast
17368 vintage
17369
17370 Default is "none".
17371
17372 master, m
17373 Set the master key points. These points will define a second pass
17374 mapping. It is sometimes called a "luminance" or "value" mapping.
17375 It can be used with r, g, b or all since it acts like a post-
17376 processing LUT.
17377
17378 red, r
17379 Set the key points for the red component.
17380
17381 green, g
17382 Set the key points for the green component.
17383
17384 blue, b
17385 Set the key points for the blue component.
17386
17387 all Set the key points for all components (not including master). Can
17388 be used in addition to the other key points component options. In
17389 this case, the unset component(s) will fallback on this all
17390 setting.
17391
17392 psfile
17393 Specify a Photoshop curves file (".acv") to import the settings
17394 from.
17395
17396 plot
17397 Save Gnuplot script of the curves in specified file.
17398
17399 To avoid some filtergraph syntax conflicts, each key points list need
17400 to be defined using the following syntax: "x0/y0 x1/y1 x2/y2 ...".
17401
17402 Commands
17403
17404 This filter supports same commands as options.
17405
17406 Examples
17407
17408 • Increase slightly the middle level of blue:
17409
17410 curves=blue='0/0 0.5/0.58 1/1'
17411
17412 • Vintage effect:
17413
17414 curves=r='0/0.11 .42/.51 1/0.95':g='0/0 0.50/0.48 1/1':b='0/0.22 .49/.44 1/0.8'
17415
17416 Here we obtain the following coordinates for each components:
17417
17418 red "(0;0.11) (0.42;0.51) (1;0.95)"
17419
17420 green
17421 "(0;0) (0.50;0.48) (1;1)"
17422
17423 blue
17424 "(0;0.22) (0.49;0.44) (1;0.80)"
17425
17426 • The previous example can also be achieved with the associated
17427 built-in preset:
17428
17429 curves=preset=vintage
17430
17431 • Or simply:
17432
17433 curves=vintage
17434
17435 • Use a Photoshop preset and redefine the points of the green
17436 component:
17437
17438 curves=psfile='MyCurvesPresets/purple.acv':green='0/0 0.45/0.53 1/1'
17439
17440 • Check out the curves of the "cross_process" profile using ffmpeg
17441 and gnuplot:
17442
17443 ffmpeg -f lavfi -i color -vf curves=cross_process:plot=/tmp/curves.plt -frames:v 1 -f null -
17444 gnuplot -p /tmp/curves.plt
17445
17446 datascope
17447 Video data analysis filter.
17448
17449 This filter shows hexadecimal pixel values of part of video.
17450
17451 The filter accepts the following options:
17452
17453 size, s
17454 Set output video size.
17455
17456 x Set x offset from where to pick pixels.
17457
17458 y Set y offset from where to pick pixels.
17459
17460 mode
17461 Set scope mode, can be one of the following:
17462
17463 mono
17464 Draw hexadecimal pixel values with white color on black
17465 background.
17466
17467 color
17468 Draw hexadecimal pixel values with input video pixel color on
17469 black background.
17470
17471 color2
17472 Draw hexadecimal pixel values on color background picked from
17473 input video, the text color is picked in such way so its always
17474 visible.
17475
17476 axis
17477 Draw rows and columns numbers on left and top of video.
17478
17479 opacity
17480 Set background opacity.
17481
17482 format
17483 Set display number format. Can be "hex", or "dec". Default is
17484 "hex".
17485
17486 components
17487 Set pixel components to display. By default all pixel components
17488 are displayed.
17489
17490 Commands
17491
17492 This filter supports same commands as options excluding "size" option.
17493
17494 dblur
17495 Apply Directional blur filter.
17496
17497 The filter accepts the following options:
17498
17499 angle
17500 Set angle of directional blur. Default is 45.
17501
17502 radius
17503 Set radius of directional blur. Default is 5.
17504
17505 planes
17506 Set which planes to filter. By default all planes are filtered.
17507
17508 Commands
17509
17510 This filter supports same commands as options. The command accepts the
17511 same syntax of the corresponding option.
17512
17513 If the specified expression is not valid, it is kept at its current
17514 value.
17515
17516 dctdnoiz
17517 Denoise frames using 2D DCT (frequency domain filtering).
17518
17519 This filter is not designed for real time.
17520
17521 The filter accepts the following options:
17522
17523 sigma, s
17524 Set the noise sigma constant.
17525
17526 This sigma defines a hard threshold of "3 * sigma"; every DCT
17527 coefficient (absolute value) below this threshold with be dropped.
17528
17529 If you need a more advanced filtering, see expr.
17530
17531 Default is 0.
17532
17533 overlap
17534 Set number overlapping pixels for each block. Since the filter can
17535 be slow, you may want to reduce this value, at the cost of a less
17536 effective filter and the risk of various artefacts.
17537
17538 If the overlapping value doesn't permit processing the whole input
17539 width or height, a warning will be displayed and according borders
17540 won't be denoised.
17541
17542 Default value is blocksize-1, which is the best possible setting.
17543
17544 expr, e
17545 Set the coefficient factor expression.
17546
17547 For each coefficient of a DCT block, this expression will be
17548 evaluated as a multiplier value for the coefficient.
17549
17550 If this is option is set, the sigma option will be ignored.
17551
17552 The absolute value of the coefficient can be accessed through the c
17553 variable.
17554
17555 n Set the blocksize using the number of bits. "1<<n" defines the
17556 blocksize, which is the width and height of the processed blocks.
17557
17558 The default value is 3 (8x8) and can be raised to 4 for a blocksize
17559 of 16x16. Note that changing this setting has huge consequences on
17560 the speed processing. Also, a larger block size does not
17561 necessarily means a better de-noising.
17562
17563 Examples
17564
17565 Apply a denoise with a sigma of 4.5:
17566
17567 dctdnoiz=4.5
17568
17569 The same operation can be achieved using the expression system:
17570
17571 dctdnoiz=e='gte(c, 4.5*3)'
17572
17573 Violent denoise using a block size of "16x16":
17574
17575 dctdnoiz=15:n=4
17576
17577 deband
17578 Remove banding artifacts from input video. It works by replacing
17579 banded pixels with average value of referenced pixels.
17580
17581 The filter accepts the following options:
17582
17583 1thr
17584 2thr
17585 3thr
17586 4thr
17587 Set banding detection threshold for each plane. Default is 0.02.
17588 Valid range is 0.00003 to 0.5. If difference between current pixel
17589 and reference pixel is less than threshold, it will be considered
17590 as banded.
17591
17592 range, r
17593 Banding detection range in pixels. Default is 16. If positive,
17594 random number in range 0 to set value will be used. If negative,
17595 exact absolute value will be used. The range defines square of
17596 four pixels around current pixel.
17597
17598 direction, d
17599 Set direction in radians from which four pixel will be compared. If
17600 positive, random direction from 0 to set direction will be picked.
17601 If negative, exact of absolute value will be picked. For example
17602 direction 0, -PI or -2*PI radians will pick only pixels on same row
17603 and -PI/2 will pick only pixels on same column.
17604
17605 blur, b
17606 If enabled, current pixel is compared with average value of all
17607 four surrounding pixels. The default is enabled. If disabled
17608 current pixel is compared with all four surrounding pixels. The
17609 pixel is considered banded if only all four differences with
17610 surrounding pixels are less than threshold.
17611
17612 coupling, c
17613 If enabled, current pixel is changed if and only if all pixel
17614 components are banded, e.g. banding detection threshold is
17615 triggered for all color components. The default is disabled.
17616
17617 Commands
17618
17619 This filter supports the all above options as commands.
17620
17621 deblock
17622 Remove blocking artifacts from input video.
17623
17624 The filter accepts the following options:
17625
17626 filter
17627 Set filter type, can be weak or strong. Default is strong. This
17628 controls what kind of deblocking is applied.
17629
17630 block
17631 Set size of block, allowed range is from 4 to 512. Default is 8.
17632
17633 alpha
17634 beta
17635 gamma
17636 delta
17637 Set blocking detection thresholds. Allowed range is 0 to 1.
17638 Defaults are: 0.098 for alpha and 0.05 for the rest. Using higher
17639 threshold gives more deblocking strength. Setting alpha controls
17640 threshold detection at exact edge of block. Remaining options
17641 controls threshold detection near the edge. Each one for
17642 below/above or left/right. Setting any of those to 0 disables
17643 deblocking.
17644
17645 planes
17646 Set planes to filter. Default is to filter all available planes.
17647
17648 Examples
17649
17650 • Deblock using weak filter and block size of 4 pixels.
17651
17652 deblock=filter=weak:block=4
17653
17654 • Deblock using strong filter, block size of 4 pixels and custom
17655 thresholds for deblocking more edges.
17656
17657 deblock=filter=strong:block=4:alpha=0.12:beta=0.07:gamma=0.06:delta=0.05
17658
17659 • Similar as above, but filter only first plane.
17660
17661 deblock=filter=strong:block=4:alpha=0.12:beta=0.07:gamma=0.06:delta=0.05:planes=1
17662
17663 • Similar as above, but filter only second and third plane.
17664
17665 deblock=filter=strong:block=4:alpha=0.12:beta=0.07:gamma=0.06:delta=0.05:planes=6
17666
17667 Commands
17668
17669 This filter supports the all above options as commands.
17670
17671 decimate
17672 Drop duplicated frames at regular intervals.
17673
17674 The filter accepts the following options:
17675
17676 cycle
17677 Set the number of frames from which one will be dropped. Setting
17678 this to N means one frame in every batch of N frames will be
17679 dropped. Default is 5.
17680
17681 dupthresh
17682 Set the threshold for duplicate detection. If the difference metric
17683 for a frame is less than or equal to this value, then it is
17684 declared as duplicate. Default is 1.1
17685
17686 scthresh
17687 Set scene change threshold. Default is 15.
17688
17689 blockx
17690 blocky
17691 Set the size of the x and y-axis blocks used during metric
17692 calculations. Larger blocks give better noise suppression, but
17693 also give worse detection of small movements. Must be a power of
17694 two. Default is 32.
17695
17696 ppsrc
17697 Mark main input as a pre-processed input and activate clean source
17698 input stream. This allows the input to be pre-processed with
17699 various filters to help the metrics calculation while keeping the
17700 frame selection lossless. When set to 1, the first stream is for
17701 the pre-processed input, and the second stream is the clean source
17702 from where the kept frames are chosen. Default is 0.
17703
17704 chroma
17705 Set whether or not chroma is considered in the metric calculations.
17706 Default is 1.
17707
17708 deconvolve
17709 Apply 2D deconvolution of video stream in frequency domain using second
17710 stream as impulse.
17711
17712 The filter accepts the following options:
17713
17714 planes
17715 Set which planes to process.
17716
17717 impulse
17718 Set which impulse video frames will be processed, can be first or
17719 all. Default is all.
17720
17721 noise
17722 Set noise when doing divisions. Default is 0.0000001. Useful when
17723 width and height are not same and not power of 2 or if stream prior
17724 to convolving had noise.
17725
17726 The "deconvolve" filter also supports the framesync options.
17727
17728 dedot
17729 Reduce cross-luminance (dot-crawl) and cross-color (rainbows) from
17730 video.
17731
17732 It accepts the following options:
17733
17734 m Set mode of operation. Can be combination of dotcrawl for cross-
17735 luminance reduction and/or rainbows for cross-color reduction.
17736
17737 lt Set spatial luma threshold. Lower values increases reduction of
17738 cross-luminance.
17739
17740 tl Set tolerance for temporal luma. Higher values increases reduction
17741 of cross-luminance.
17742
17743 tc Set tolerance for chroma temporal variation. Higher values
17744 increases reduction of cross-color.
17745
17746 ct Set temporal chroma threshold. Lower values increases reduction of
17747 cross-color.
17748
17749 deflate
17750 Apply deflate effect to the video.
17751
17752 This filter replaces the pixel by the local(3x3) average by taking into
17753 account only values lower than the pixel.
17754
17755 It accepts the following options:
17756
17757 threshold0
17758 threshold1
17759 threshold2
17760 threshold3
17761 Limit the maximum change for each plane, default is 65535. If 0,
17762 plane will remain unchanged.
17763
17764 Commands
17765
17766 This filter supports the all above options as commands.
17767
17768 deflicker
17769 Remove temporal frame luminance variations.
17770
17771 It accepts the following options:
17772
17773 size, s
17774 Set moving-average filter size in frames. Default is 5. Allowed
17775 range is 2 - 129.
17776
17777 mode, m
17778 Set averaging mode to smooth temporal luminance variations.
17779
17780 Available values are:
17781
17782 am Arithmetic mean
17783
17784 gm Geometric mean
17785
17786 hm Harmonic mean
17787
17788 qm Quadratic mean
17789
17790 cm Cubic mean
17791
17792 pm Power mean
17793
17794 median
17795 Median
17796
17797 bypass
17798 Do not actually modify frame. Useful when one only wants metadata.
17799
17800 dejudder
17801 Remove judder produced by partially interlaced telecined content.
17802
17803 Judder can be introduced, for instance, by pullup filter. If the
17804 original source was partially telecined content then the output of
17805 "pullup,dejudder" will have a variable frame rate. May change the
17806 recorded frame rate of the container. Aside from that change, this
17807 filter will not affect constant frame rate video.
17808
17809 The option available in this filter is:
17810
17811 cycle
17812 Specify the length of the window over which the judder repeats.
17813
17814 Accepts any integer greater than 1. Useful values are:
17815
17816 4 If the original was telecined from 24 to 30 fps (Film to NTSC).
17817
17818 5 If the original was telecined from 25 to 30 fps (PAL to NTSC).
17819
17820 20 If a mixture of the two.
17821
17822 The default is 4.
17823
17824 delogo
17825 Suppress a TV station logo by a simple interpolation of the surrounding
17826 pixels. Just set a rectangle covering the logo and watch it disappear
17827 (and sometimes something even uglier appear - your mileage may vary).
17828
17829 It accepts the following parameters:
17830
17831 x
17832 y Specify the top left corner coordinates of the logo. They must be
17833 specified.
17834
17835 w
17836 h Specify the width and height of the logo to clear. They must be
17837 specified.
17838
17839 show
17840 When set to 1, a green rectangle is drawn on the screen to simplify
17841 finding the right x, y, w, and h parameters. The default value is
17842 0.
17843
17844 The rectangle is drawn on the outermost pixels which will be
17845 (partly) replaced with interpolated values. The values of the next
17846 pixels immediately outside this rectangle in each direction will be
17847 used to compute the interpolated pixel values inside the rectangle.
17848
17849 Examples
17850
17851 • Set a rectangle covering the area with top left corner coordinates
17852 0,0 and size 100x77:
17853
17854 delogo=x=0:y=0:w=100:h=77
17855
17856 derain
17857 Remove the rain in the input image/video by applying the derain methods
17858 based on convolutional neural networks. Supported models:
17859
17860 • Recurrent Squeeze-and-Excitation Context Aggregation Net (RESCAN).
17861 See
17862 <http://openaccess.thecvf.com/content_ECCV_2018/papers/Xia_Li_Recurrent_Squeeze-and-Excitation_Context_ECCV_2018_paper.pdf>.
17863
17864 Training as well as model generation scripts are provided in the
17865 repository at <https://github.com/XueweiMeng/derain_filter.git>.
17866
17867 Native model files (.model) can be generated from TensorFlow model
17868 files (.pb) by using tools/python/convert.py
17869
17870 The filter accepts the following options:
17871
17872 filter_type
17873 Specify which filter to use. This option accepts the following
17874 values:
17875
17876 derain
17877 Derain filter. To conduct derain filter, you need to use a
17878 derain model.
17879
17880 dehaze
17881 Dehaze filter. To conduct dehaze filter, you need to use a
17882 dehaze model.
17883
17884 Default value is derain.
17885
17886 dnn_backend
17887 Specify which DNN backend to use for model loading and execution.
17888 This option accepts the following values:
17889
17890 native
17891 Native implementation of DNN loading and execution.
17892
17893 tensorflow
17894 TensorFlow backend. To enable this backend you need to install
17895 the TensorFlow for C library (see
17896 <https://www.tensorflow.org/install/lang_c>) and configure
17897 FFmpeg with "--enable-libtensorflow"
17898
17899 Default value is native.
17900
17901 model
17902 Set path to model file specifying network architecture and its
17903 parameters. Note that different backends use different file
17904 formats. TensorFlow and native backend can load files for only its
17905 format.
17906
17907 To get full functionality (such as async execution), please use the
17908 dnn_processing filter.
17909
17910 deshake
17911 Attempt to fix small changes in horizontal and/or vertical shift. This
17912 filter helps remove camera shake from hand-holding a camera, bumping a
17913 tripod, moving on a vehicle, etc.
17914
17915 The filter accepts the following options:
17916
17917 x
17918 y
17919 w
17920 h Specify a rectangular area where to limit the search for motion
17921 vectors. If desired the search for motion vectors can be limited
17922 to a rectangular area of the frame defined by its top left corner,
17923 width and height. These parameters have the same meaning as the
17924 drawbox filter which can be used to visualise the position of the
17925 bounding box.
17926
17927 This is useful when simultaneous movement of subjects within the
17928 frame might be confused for camera motion by the motion vector
17929 search.
17930
17931 If any or all of x, y, w and h are set to -1 then the full frame is
17932 used. This allows later options to be set without specifying the
17933 bounding box for the motion vector search.
17934
17935 Default - search the whole frame.
17936
17937 rx
17938 ry Specify the maximum extent of movement in x and y directions in the
17939 range 0-64 pixels. Default 16.
17940
17941 edge
17942 Specify how to generate pixels to fill blanks at the edge of the
17943 frame. Available values are:
17944
17945 blank, 0
17946 Fill zeroes at blank locations
17947
17948 original, 1
17949 Original image at blank locations
17950
17951 clamp, 2
17952 Extruded edge value at blank locations
17953
17954 mirror, 3
17955 Mirrored edge at blank locations
17956
17957 Default value is mirror.
17958
17959 blocksize
17960 Specify the blocksize to use for motion search. Range 4-128 pixels,
17961 default 8.
17962
17963 contrast
17964 Specify the contrast threshold for blocks. Only blocks with more
17965 than the specified contrast (difference between darkest and
17966 lightest pixels) will be considered. Range 1-255, default 125.
17967
17968 search
17969 Specify the search strategy. Available values are:
17970
17971 exhaustive, 0
17972 Set exhaustive search
17973
17974 less, 1
17975 Set less exhaustive search.
17976
17977 Default value is exhaustive.
17978
17979 filename
17980 If set then a detailed log of the motion search is written to the
17981 specified file.
17982
17983 despill
17984 Remove unwanted contamination of foreground colors, caused by reflected
17985 color of greenscreen or bluescreen.
17986
17987 This filter accepts the following options:
17988
17989 type
17990 Set what type of despill to use.
17991
17992 mix Set how spillmap will be generated.
17993
17994 expand
17995 Set how much to get rid of still remaining spill.
17996
17997 red Controls amount of red in spill area.
17998
17999 green
18000 Controls amount of green in spill area. Should be -1 for
18001 greenscreen.
18002
18003 blue
18004 Controls amount of blue in spill area. Should be -1 for
18005 bluescreen.
18006
18007 brightness
18008 Controls brightness of spill area, preserving colors.
18009
18010 alpha
18011 Modify alpha from generated spillmap.
18012
18013 Commands
18014
18015 This filter supports the all above options as commands.
18016
18017 detelecine
18018 Apply an exact inverse of the telecine operation. It requires a
18019 predefined pattern specified using the pattern option which must be the
18020 same as that passed to the telecine filter.
18021
18022 This filter accepts the following options:
18023
18024 first_field
18025 top, t
18026 top field first
18027
18028 bottom, b
18029 bottom field first The default value is "top".
18030
18031 pattern
18032 A string of numbers representing the pulldown pattern you wish to
18033 apply. The default value is 23.
18034
18035 start_frame
18036 A number representing position of the first frame with respect to
18037 the telecine pattern. This is to be used if the stream is cut. The
18038 default value is 0.
18039
18040 dilation
18041 Apply dilation effect to the video.
18042
18043 This filter replaces the pixel by the local(3x3) maximum.
18044
18045 It accepts the following options:
18046
18047 threshold0
18048 threshold1
18049 threshold2
18050 threshold3
18051 Limit the maximum change for each plane, default is 65535. If 0,
18052 plane will remain unchanged.
18053
18054 coordinates
18055 Flag which specifies the pixel to refer to. Default is 255 i.e. all
18056 eight pixels are used.
18057
18058 Flags to local 3x3 coordinates maps like this:
18059
18060 1 2 3
18061 4 5
18062 6 7 8
18063
18064 Commands
18065
18066 This filter supports the all above options as commands.
18067
18068 displace
18069 Displace pixels as indicated by second and third input stream.
18070
18071 It takes three input streams and outputs one stream, the first input is
18072 the source, and second and third input are displacement maps.
18073
18074 The second input specifies how much to displace pixels along the
18075 x-axis, while the third input specifies how much to displace pixels
18076 along the y-axis. If one of displacement map streams terminates, last
18077 frame from that displacement map will be used.
18078
18079 Note that once generated, displacements maps can be reused over and
18080 over again.
18081
18082 A description of the accepted options follows.
18083
18084 edge
18085 Set displace behavior for pixels that are out of range.
18086
18087 Available values are:
18088
18089 blank
18090 Missing pixels are replaced by black pixels.
18091
18092 smear
18093 Adjacent pixels will spread out to replace missing pixels.
18094
18095 wrap
18096 Out of range pixels are wrapped so they point to pixels of
18097 other side.
18098
18099 mirror
18100 Out of range pixels will be replaced with mirrored pixels.
18101
18102 Default is smear.
18103
18104 Examples
18105
18106 • Add ripple effect to rgb input of video size hd720:
18107
18108 ffmpeg -i INPUT -f lavfi -i nullsrc=s=hd720,lutrgb=128:128:128 -f lavfi -i nullsrc=s=hd720,geq='r=128+30*sin(2*PI*X/400+T):g=128+30*sin(2*PI*X/400+T):b=128+30*sin(2*PI*X/400+T)' -lavfi '[0][1][2]displace' OUTPUT
18109
18110 • Add wave effect to rgb input of video size hd720:
18111
18112 ffmpeg -i INPUT -f lavfi -i nullsrc=hd720,geq='r=128+80*(sin(sqrt((X-W/2)*(X-W/2)+(Y-H/2)*(Y-H/2))/220*2*PI+T)):g=128+80*(sin(sqrt((X-W/2)*(X-W/2)+(Y-H/2)*(Y-H/2))/220*2*PI+T)):b=128+80*(sin(sqrt((X-W/2)*(X-W/2)+(Y-H/2)*(Y-H/2))/220*2*PI+T))' -lavfi '[1]split[x][y],[0][x][y]displace' OUTPUT
18113
18114 dnn_classify
18115 Do classification with deep neural networks based on bounding boxes.
18116
18117 The filter accepts the following options:
18118
18119 dnn_backend
18120 Specify which DNN backend to use for model loading and execution.
18121 This option accepts only openvino now, tensorflow backends will be
18122 added.
18123
18124 model
18125 Set path to model file specifying network architecture and its
18126 parameters. Note that different backends use different file
18127 formats.
18128
18129 input
18130 Set the input name of the dnn network.
18131
18132 output
18133 Set the output name of the dnn network.
18134
18135 confidence
18136 Set the confidence threshold (default: 0.5).
18137
18138 labels
18139 Set path to label file specifying the mapping between label id and
18140 name. Each label name is written in one line, tailing spaces and
18141 empty lines are skipped. The first line is the name of label id 0,
18142 and the second line is the name of label id 1, etc. The label id
18143 is considered as name if the label file is not provided.
18144
18145 backend_configs
18146 Set the configs to be passed into backend
18147
18148 For tensorflow backend, you can set its configs with sess_config
18149 options, please use tools/python/tf_sess_config.py to get the
18150 configs for your system.
18151
18152 dnn_detect
18153 Do object detection with deep neural networks.
18154
18155 The filter accepts the following options:
18156
18157 dnn_backend
18158 Specify which DNN backend to use for model loading and execution.
18159 This option accepts only openvino now, tensorflow backends will be
18160 added.
18161
18162 model
18163 Set path to model file specifying network architecture and its
18164 parameters. Note that different backends use different file
18165 formats.
18166
18167 input
18168 Set the input name of the dnn network.
18169
18170 output
18171 Set the output name of the dnn network.
18172
18173 confidence
18174 Set the confidence threshold (default: 0.5).
18175
18176 labels
18177 Set path to label file specifying the mapping between label id and
18178 name. Each label name is written in one line, tailing spaces and
18179 empty lines are skipped. The first line is the name of label id 0
18180 (usually it is 'background'), and the second line is the name of
18181 label id 1, etc. The label id is considered as name if the label
18182 file is not provided.
18183
18184 backend_configs
18185 Set the configs to be passed into backend. To use async execution,
18186 set async (default: set). Roll back to sync execution if the
18187 backend does not support async.
18188
18189 dnn_processing
18190 Do image processing with deep neural networks. It works together with
18191 another filter which converts the pixel format of the Frame to what the
18192 dnn network requires.
18193
18194 The filter accepts the following options:
18195
18196 dnn_backend
18197 Specify which DNN backend to use for model loading and execution.
18198 This option accepts the following values:
18199
18200 native
18201 Native implementation of DNN loading and execution.
18202
18203 tensorflow
18204 TensorFlow backend. To enable this backend you need to install
18205 the TensorFlow for C library (see
18206 <https://www.tensorflow.org/install/lang_c>) and configure
18207 FFmpeg with "--enable-libtensorflow"
18208
18209 openvino
18210 OpenVINO backend. To enable this backend you need to build and
18211 install the OpenVINO for C library (see
18212 <https://github.com/openvinotoolkit/openvino/blob/master/build-instruction.md>)
18213 and configure FFmpeg with "--enable-libopenvino"
18214 (--extra-cflags=-I... --extra-ldflags=-L... might be needed if
18215 the header files and libraries are not installed into system
18216 path)
18217
18218 Default value is native.
18219
18220 model
18221 Set path to model file specifying network architecture and its
18222 parameters. Note that different backends use different file
18223 formats. TensorFlow, OpenVINO and native backend can load files for
18224 only its format.
18225
18226 Native model file (.model) can be generated from TensorFlow model
18227 file (.pb) by using tools/python/convert.py
18228
18229 input
18230 Set the input name of the dnn network.
18231
18232 output
18233 Set the output name of the dnn network.
18234
18235 backend_configs
18236 Set the configs to be passed into backend. To use async execution,
18237 set async (default: set). Roll back to sync execution if the
18238 backend does not support async.
18239
18240 For tensorflow backend, you can set its configs with sess_config
18241 options, please use tools/python/tf_sess_config.py to get the
18242 configs of TensorFlow backend for your system.
18243
18244 Examples
18245
18246 • Remove rain in rgb24 frame with can.pb (see derain filter):
18247
18248 ./ffmpeg -i rain.jpg -vf format=rgb24,dnn_processing=dnn_backend=tensorflow:model=can.pb:input=x:output=y derain.jpg
18249
18250 • Halve the pixel value of the frame with format gray32f:
18251
18252 ffmpeg -i input.jpg -vf format=grayf32,dnn_processing=model=halve_gray_float.model:input=dnn_in:output=dnn_out:dnn_backend=native -y out.native.png
18253
18254 • Handle the Y channel with srcnn.pb (see sr filter) for frame with
18255 yuv420p (planar YUV formats supported):
18256
18257 ./ffmpeg -i 480p.jpg -vf format=yuv420p,scale=w=iw*2:h=ih*2,dnn_processing=dnn_backend=tensorflow:model=srcnn.pb:input=x:output=y -y srcnn.jpg
18258
18259 • Handle the Y channel with espcn.pb (see sr filter), which changes
18260 frame size, for format yuv420p (planar YUV formats supported),
18261 please use tools/python/tf_sess_config.py to get the configs of
18262 TensorFlow backend for your system.
18263
18264 ./ffmpeg -i 480p.jpg -vf format=yuv420p,dnn_processing=dnn_backend=tensorflow:model=espcn.pb:input=x:output=y:backend_configs=sess_config=0x10022805320e09cdccccccccccec3f20012a01303801 -y tmp.espcn.jpg
18265
18266 drawbox
18267 Draw a colored box on the input image.
18268
18269 It accepts the following parameters:
18270
18271 x
18272 y The expressions which specify the top left corner coordinates of
18273 the box. It defaults to 0.
18274
18275 width, w
18276 height, h
18277 The expressions which specify the width and height of the box; if 0
18278 they are interpreted as the input width and height. It defaults to
18279 0.
18280
18281 color, c
18282 Specify the color of the box to write. For the general syntax of
18283 this option, check the "Color" section in the ffmpeg-utils manual.
18284 If the special value "invert" is used, the box edge color is the
18285 same as the video with inverted luma.
18286
18287 thickness, t
18288 The expression which sets the thickness of the box edge. A value
18289 of "fill" will create a filled box. Default value is 3.
18290
18291 See below for the list of accepted constants.
18292
18293 replace
18294 Applicable if the input has alpha. With value 1, the pixels of the
18295 painted box will overwrite the video's color and alpha pixels.
18296 Default is 0, which composites the box onto the input, leaving the
18297 video's alpha intact.
18298
18299 The parameters for x, y, w and h and t are expressions containing the
18300 following constants:
18301
18302 dar The input display aspect ratio, it is the same as (w / h) * sar.
18303
18304 hsub
18305 vsub
18306 horizontal and vertical chroma subsample values. For example for
18307 the pixel format "yuv422p" hsub is 2 and vsub is 1.
18308
18309 in_h, ih
18310 in_w, iw
18311 The input width and height.
18312
18313 sar The input sample aspect ratio.
18314
18315 x
18316 y The x and y offset coordinates where the box is drawn.
18317
18318 w
18319 h The width and height of the drawn box.
18320
18321 box_source
18322 Box source can be set as side_data_detection_bboxes if you want to
18323 use box data in detection bboxes of side data.
18324
18325 If box_source is set, the x, y, width and height will be ignored
18326 and still use box data in detection bboxes of side data. So please
18327 do not use this parameter if you were not sure about the box
18328 source.
18329
18330 t The thickness of the drawn box.
18331
18332 These constants allow the x, y, w, h and t expressions to refer to
18333 each other, so you may for example specify "y=x/dar" or "h=w/dar".
18334
18335 Examples
18336
18337 • Draw a black box around the edge of the input image:
18338
18339 drawbox
18340
18341 • Draw a box with color red and an opacity of 50%:
18342
18343 drawbox=10:20:200:60:red@0.5
18344
18345 The previous example can be specified as:
18346
18347 drawbox=x=10:y=20:w=200:h=60:color=red@0.5
18348
18349 • Fill the box with pink color:
18350
18351 drawbox=x=10:y=10:w=100:h=100:color=pink@0.5:t=fill
18352
18353 • Draw a 2-pixel red 2.40:1 mask:
18354
18355 drawbox=x=-t:y=0.5*(ih-iw/2.4)-t:w=iw+t*2:h=iw/2.4+t*2:t=2:c=red
18356
18357 Commands
18358
18359 This filter supports same commands as options. The command accepts the
18360 same syntax of the corresponding option.
18361
18362 If the specified expression is not valid, it is kept at its current
18363 value.
18364
18365 drawgraph
18366 Draw a graph using input video metadata.
18367
18368 It accepts the following parameters:
18369
18370 m1 Set 1st frame metadata key from which metadata values will be used
18371 to draw a graph.
18372
18373 fg1 Set 1st foreground color expression.
18374
18375 m2 Set 2nd frame metadata key from which metadata values will be used
18376 to draw a graph.
18377
18378 fg2 Set 2nd foreground color expression.
18379
18380 m3 Set 3rd frame metadata key from which metadata values will be used
18381 to draw a graph.
18382
18383 fg3 Set 3rd foreground color expression.
18384
18385 m4 Set 4th frame metadata key from which metadata values will be used
18386 to draw a graph.
18387
18388 fg4 Set 4th foreground color expression.
18389
18390 min Set minimal value of metadata value.
18391
18392 max Set maximal value of metadata value.
18393
18394 bg Set graph background color. Default is white.
18395
18396 mode
18397 Set graph mode.
18398
18399 Available values for mode is:
18400
18401 bar
18402 dot
18403 line
18404
18405 Default is "line".
18406
18407 slide
18408 Set slide mode.
18409
18410 Available values for slide is:
18411
18412 frame
18413 Draw new frame when right border is reached.
18414
18415 replace
18416 Replace old columns with new ones.
18417
18418 scroll
18419 Scroll from right to left.
18420
18421 rscroll
18422 Scroll from left to right.
18423
18424 picture
18425 Draw single picture.
18426
18427 Default is "frame".
18428
18429 size
18430 Set size of graph video. For the syntax of this option, check the
18431 "Video size" section in the ffmpeg-utils manual. The default value
18432 is "900x256".
18433
18434 rate, r
18435 Set the output frame rate. Default value is 25.
18436
18437 The foreground color expressions can use the following variables:
18438
18439 MIN Minimal value of metadata value.
18440
18441 MAX Maximal value of metadata value.
18442
18443 VAL Current metadata key value.
18444
18445 The color is defined as 0xAABBGGRR.
18446
18447 Example using metadata from signalstats filter:
18448
18449 signalstats,drawgraph=lavfi.signalstats.YAVG:min=0:max=255
18450
18451 Example using metadata from ebur128 filter:
18452
18453 ebur128=metadata=1,adrawgraph=lavfi.r128.M:min=-120:max=5
18454
18455 drawgrid
18456 Draw a grid on the input image.
18457
18458 It accepts the following parameters:
18459
18460 x
18461 y The expressions which specify the coordinates of some point of grid
18462 intersection (meant to configure offset). Both default to 0.
18463
18464 width, w
18465 height, h
18466 The expressions which specify the width and height of the grid
18467 cell, if 0 they are interpreted as the input width and height,
18468 respectively, minus "thickness", so image gets framed. Default to
18469 0.
18470
18471 color, c
18472 Specify the color of the grid. For the general syntax of this
18473 option, check the "Color" section in the ffmpeg-utils manual. If
18474 the special value "invert" is used, the grid color is the same as
18475 the video with inverted luma.
18476
18477 thickness, t
18478 The expression which sets the thickness of the grid line. Default
18479 value is 1.
18480
18481 See below for the list of accepted constants.
18482
18483 replace
18484 Applicable if the input has alpha. With 1 the pixels of the painted
18485 grid will overwrite the video's color and alpha pixels. Default is
18486 0, which composites the grid onto the input, leaving the video's
18487 alpha intact.
18488
18489 The parameters for x, y, w and h and t are expressions containing the
18490 following constants:
18491
18492 dar The input display aspect ratio, it is the same as (w / h) * sar.
18493
18494 hsub
18495 vsub
18496 horizontal and vertical chroma subsample values. For example for
18497 the pixel format "yuv422p" hsub is 2 and vsub is 1.
18498
18499 in_h, ih
18500 in_w, iw
18501 The input grid cell width and height.
18502
18503 sar The input sample aspect ratio.
18504
18505 x
18506 y The x and y coordinates of some point of grid intersection (meant
18507 to configure offset).
18508
18509 w
18510 h The width and height of the drawn cell.
18511
18512 t The thickness of the drawn cell.
18513
18514 These constants allow the x, y, w, h and t expressions to refer to
18515 each other, so you may for example specify "y=x/dar" or "h=w/dar".
18516
18517 Examples
18518
18519 • Draw a grid with cell 100x100 pixels, thickness 2 pixels, with
18520 color red and an opacity of 50%:
18521
18522 drawgrid=width=100:height=100:thickness=2:color=red@0.5
18523
18524 • Draw a white 3x3 grid with an opacity of 50%:
18525
18526 drawgrid=w=iw/3:h=ih/3:t=2:c=white@0.5
18527
18528 Commands
18529
18530 This filter supports same commands as options. The command accepts the
18531 same syntax of the corresponding option.
18532
18533 If the specified expression is not valid, it is kept at its current
18534 value.
18535
18536 drawtext
18537 Draw a text string or text from a specified file on top of a video,
18538 using the libfreetype library.
18539
18540 To enable compilation of this filter, you need to configure FFmpeg with
18541 "--enable-libfreetype". To enable default font fallback and the font
18542 option you need to configure FFmpeg with "--enable-libfontconfig". To
18543 enable the text_shaping option, you need to configure FFmpeg with
18544 "--enable-libfribidi".
18545
18546 Syntax
18547
18548 It accepts the following parameters:
18549
18550 box Used to draw a box around text using the background color. The
18551 value must be either 1 (enable) or 0 (disable). The default value
18552 of box is 0.
18553
18554 boxborderw
18555 Set the width of the border to be drawn around the box using
18556 boxcolor. The default value of boxborderw is 0.
18557
18558 boxcolor
18559 The color to be used for drawing box around text. For the syntax of
18560 this option, check the "Color" section in the ffmpeg-utils manual.
18561
18562 The default value of boxcolor is "white".
18563
18564 line_spacing
18565 Set the line spacing in pixels of the border to be drawn around the
18566 box using box. The default value of line_spacing is 0.
18567
18568 borderw
18569 Set the width of the border to be drawn around the text using
18570 bordercolor. The default value of borderw is 0.
18571
18572 bordercolor
18573 Set the color to be used for drawing border around text. For the
18574 syntax of this option, check the "Color" section in the ffmpeg-
18575 utils manual.
18576
18577 The default value of bordercolor is "black".
18578
18579 expansion
18580 Select how the text is expanded. Can be either "none", "strftime"
18581 (deprecated) or "normal" (default). See the drawtext_expansion,
18582 Text expansion section below for details.
18583
18584 basetime
18585 Set a start time for the count. Value is in microseconds. Only
18586 applied in the deprecated strftime expansion mode. To emulate in
18587 normal expansion mode use the "pts" function, supplying the start
18588 time (in seconds) as the second argument.
18589
18590 fix_bounds
18591 If true, check and fix text coords to avoid clipping.
18592
18593 fontcolor
18594 The color to be used for drawing fonts. For the syntax of this
18595 option, check the "Color" section in the ffmpeg-utils manual.
18596
18597 The default value of fontcolor is "black".
18598
18599 fontcolor_expr
18600 String which is expanded the same way as text to obtain dynamic
18601 fontcolor value. By default this option has empty value and is not
18602 processed. When this option is set, it overrides fontcolor option.
18603
18604 font
18605 The font family to be used for drawing text. By default Sans.
18606
18607 fontfile
18608 The font file to be used for drawing text. The path must be
18609 included. This parameter is mandatory if the fontconfig support is
18610 disabled.
18611
18612 alpha
18613 Draw the text applying alpha blending. The value can be a number
18614 between 0.0 and 1.0. The expression accepts the same variables x,
18615 y as well. The default value is 1. Please see fontcolor_expr.
18616
18617 fontsize
18618 The font size to be used for drawing text. The default value of
18619 fontsize is 16.
18620
18621 text_shaping
18622 If set to 1, attempt to shape the text (for example, reverse the
18623 order of right-to-left text and join Arabic characters) before
18624 drawing it. Otherwise, just draw the text exactly as given. By
18625 default 1 (if supported).
18626
18627 ft_load_flags
18628 The flags to be used for loading the fonts.
18629
18630 The flags map the corresponding flags supported by libfreetype, and
18631 are a combination of the following values:
18632
18633 default
18634 no_scale
18635 no_hinting
18636 render
18637 no_bitmap
18638 vertical_layout
18639 force_autohint
18640 crop_bitmap
18641 pedantic
18642 ignore_global_advance_width
18643 no_recurse
18644 ignore_transform
18645 monochrome
18646 linear_design
18647 no_autohint
18648
18649 Default value is "default".
18650
18651 For more information consult the documentation for the FT_LOAD_*
18652 libfreetype flags.
18653
18654 shadowcolor
18655 The color to be used for drawing a shadow behind the drawn text.
18656 For the syntax of this option, check the "Color" section in the
18657 ffmpeg-utils manual.
18658
18659 The default value of shadowcolor is "black".
18660
18661 shadowx
18662 shadowy
18663 The x and y offsets for the text shadow position with respect to
18664 the position of the text. They can be either positive or negative
18665 values. The default value for both is "0".
18666
18667 start_number
18668 The starting frame number for the n/frame_num variable. The default
18669 value is "0".
18670
18671 tabsize
18672 The size in number of spaces to use for rendering the tab. Default
18673 value is 4.
18674
18675 timecode
18676 Set the initial timecode representation in "hh:mm:ss[:;.]ff"
18677 format. It can be used with or without text parameter.
18678 timecode_rate option must be specified.
18679
18680 timecode_rate, rate, r
18681 Set the timecode frame rate (timecode only). Value will be rounded
18682 to nearest integer. Minimum value is "1". Drop-frame timecode is
18683 supported for frame rates 30 & 60.
18684
18685 tc24hmax
18686 If set to 1, the output of the timecode option will wrap around at
18687 24 hours. Default is 0 (disabled).
18688
18689 text
18690 The text string to be drawn. The text must be a sequence of UTF-8
18691 encoded characters. This parameter is mandatory if no file is
18692 specified with the parameter textfile.
18693
18694 textfile
18695 A text file containing text to be drawn. The text must be a
18696 sequence of UTF-8 encoded characters.
18697
18698 This parameter is mandatory if no text string is specified with the
18699 parameter text.
18700
18701 If both text and textfile are specified, an error is thrown.
18702
18703 text_source
18704 Text source should be set as side_data_detection_bboxes if you want
18705 to use text data in detection bboxes of side data.
18706
18707 If text source is set, text and textfile will be ignored and still
18708 use text data in detection bboxes of side data. So please do not
18709 use this parameter if you are not sure about the text source.
18710
18711 reload
18712 If set to 1, the textfile will be reloaded before each frame. Be
18713 sure to update it atomically, or it may be read partially, or even
18714 fail.
18715
18716 x
18717 y The expressions which specify the offsets where text will be drawn
18718 within the video frame. They are relative to the top/left border of
18719 the output image.
18720
18721 The default value of x and y is "0".
18722
18723 See below for the list of accepted constants and functions.
18724
18725 The parameters for x and y are expressions containing the following
18726 constants and functions:
18727
18728 dar input display aspect ratio, it is the same as (w / h) * sar
18729
18730 hsub
18731 vsub
18732 horizontal and vertical chroma subsample values. For example for
18733 the pixel format "yuv422p" hsub is 2 and vsub is 1.
18734
18735 line_h, lh
18736 the height of each text line
18737
18738 main_h, h, H
18739 the input height
18740
18741 main_w, w, W
18742 the input width
18743
18744 max_glyph_a, ascent
18745 the maximum distance from the baseline to the highest/upper grid
18746 coordinate used to place a glyph outline point, for all the
18747 rendered glyphs. It is a positive value, due to the grid's
18748 orientation with the Y axis upwards.
18749
18750 max_glyph_d, descent
18751 the maximum distance from the baseline to the lowest grid
18752 coordinate used to place a glyph outline point, for all the
18753 rendered glyphs. This is a negative value, due to the grid's
18754 orientation, with the Y axis upwards.
18755
18756 max_glyph_h
18757 maximum glyph height, that is the maximum height for all the glyphs
18758 contained in the rendered text, it is equivalent to ascent -
18759 descent.
18760
18761 max_glyph_w
18762 maximum glyph width, that is the maximum width for all the glyphs
18763 contained in the rendered text
18764
18765 n the number of input frame, starting from 0
18766
18767 rand(min, max)
18768 return a random number included between min and max
18769
18770 sar The input sample aspect ratio.
18771
18772 t timestamp expressed in seconds, NAN if the input timestamp is
18773 unknown
18774
18775 text_h, th
18776 the height of the rendered text
18777
18778 text_w, tw
18779 the width of the rendered text
18780
18781 x
18782 y the x and y offset coordinates where the text is drawn.
18783
18784 These parameters allow the x and y expressions to refer to each
18785 other, so you can for example specify "y=x/dar".
18786
18787 pict_type
18788 A one character description of the current frame's picture type.
18789
18790 pkt_pos
18791 The current packet's position in the input file or stream (in
18792 bytes, from the start of the input). A value of -1 indicates this
18793 info is not available.
18794
18795 pkt_duration
18796 The current packet's duration, in seconds.
18797
18798 pkt_size
18799 The current packet's size (in bytes).
18800
18801 Text expansion
18802
18803 If expansion is set to "strftime", the filter recognizes strftime()
18804 sequences in the provided text and expands them accordingly. Check the
18805 documentation of strftime(). This feature is deprecated.
18806
18807 If expansion is set to "none", the text is printed verbatim.
18808
18809 If expansion is set to "normal" (which is the default), the following
18810 expansion mechanism is used.
18811
18812 The backslash character \, followed by any character, always expands to
18813 the second character.
18814
18815 Sequences of the form "%{...}" are expanded. The text between the
18816 braces is a function name, possibly followed by arguments separated by
18817 ':'. If the arguments contain special characters or delimiters (':' or
18818 '}'), they should be escaped.
18819
18820 Note that they probably must also be escaped as the value for the text
18821 option in the filter argument string and as the filter argument in the
18822 filtergraph description, and possibly also for the shell, that makes up
18823 to four levels of escaping; using a text file avoids these problems.
18824
18825 The following functions are available:
18826
18827 expr, e
18828 The expression evaluation result.
18829
18830 It must take one argument specifying the expression to be
18831 evaluated, which accepts the same constants and functions as the x
18832 and y values. Note that not all constants should be used, for
18833 example the text size is not known when evaluating the expression,
18834 so the constants text_w and text_h will have an undefined value.
18835
18836 expr_int_format, eif
18837 Evaluate the expression's value and output as formatted integer.
18838
18839 The first argument is the expression to be evaluated, just as for
18840 the expr function. The second argument specifies the output
18841 format. Allowed values are x, X, d and u. They are treated exactly
18842 as in the "printf" function. The third parameter is optional and
18843 sets the number of positions taken by the output. It can be used
18844 to add padding with zeros from the left.
18845
18846 gmtime
18847 The time at which the filter is running, expressed in UTC. It can
18848 accept an argument: a strftime() format string.
18849
18850 localtime
18851 The time at which the filter is running, expressed in the local
18852 time zone. It can accept an argument: a strftime() format string.
18853
18854 metadata
18855 Frame metadata. Takes one or two arguments.
18856
18857 The first argument is mandatory and specifies the metadata key.
18858
18859 The second argument is optional and specifies a default value, used
18860 when the metadata key is not found or empty.
18861
18862 Available metadata can be identified by inspecting entries starting
18863 with TAG included within each frame section printed by running
18864 "ffprobe -show_frames".
18865
18866 String metadata generated in filters leading to the drawtext filter
18867 are also available.
18868
18869 n, frame_num
18870 The frame number, starting from 0.
18871
18872 pict_type
18873 A one character description of the current picture type.
18874
18875 pts The timestamp of the current frame. It can take up to three
18876 arguments.
18877
18878 The first argument is the format of the timestamp; it defaults to
18879 "flt" for seconds as a decimal number with microsecond accuracy;
18880 "hms" stands for a formatted [-]HH:MM:SS.mmm timestamp with
18881 millisecond accuracy. "gmtime" stands for the timestamp of the
18882 frame formatted as UTC time; "localtime" stands for the timestamp
18883 of the frame formatted as local time zone time.
18884
18885 The second argument is an offset added to the timestamp.
18886
18887 If the format is set to "hms", a third argument "24HH" may be
18888 supplied to present the hour part of the formatted timestamp in 24h
18889 format (00-23).
18890
18891 If the format is set to "localtime" or "gmtime", a third argument
18892 may be supplied: a strftime() format string. By default, YYYY-MM-
18893 DD HH:MM:SS format will be used.
18894
18895 Commands
18896
18897 This filter supports altering parameters via commands:
18898
18899 reinit
18900 Alter existing filter parameters.
18901
18902 Syntax for the argument is the same as for filter invocation, e.g.
18903
18904 fontsize=56:fontcolor=green:text='Hello World'
18905
18906 Full filter invocation with sendcmd would look like this:
18907
18908 sendcmd=c='56.0 drawtext reinit fontsize=56\:fontcolor=green\:text=Hello\\ World'
18909
18910 If the entire argument can't be parsed or applied as valid values then
18911 the filter will continue with its existing parameters.
18912
18913 Examples
18914
18915 • Draw "Test Text" with font FreeSerif, using the default values for
18916 the optional parameters.
18917
18918 drawtext="fontfile=/usr/share/fonts/truetype/freefont/FreeSerif.ttf: text='Test Text'"
18919
18920 • Draw 'Test Text' with font FreeSerif of size 24 at position x=100
18921 and y=50 (counting from the top-left corner of the screen), text is
18922 yellow with a red box around it. Both the text and the box have an
18923 opacity of 20%.
18924
18925 drawtext="fontfile=/usr/share/fonts/truetype/freefont/FreeSerif.ttf: text='Test Text':\
18926 x=100: y=50: fontsize=24: fontcolor=yellow@0.2: box=1: boxcolor=red@0.2"
18927
18928 Note that the double quotes are not necessary if spaces are not
18929 used within the parameter list.
18930
18931 • Show the text at the center of the video frame:
18932
18933 drawtext="fontsize=30:fontfile=FreeSerif.ttf:text='hello world':x=(w-text_w)/2:y=(h-text_h)/2"
18934
18935 • Show the text at a random position, switching to a new position
18936 every 30 seconds:
18937
18938 drawtext="fontsize=30:fontfile=FreeSerif.ttf:text='hello world':x=if(eq(mod(t\,30)\,0)\,rand(0\,(w-text_w))\,x):y=if(eq(mod(t\,30)\,0)\,rand(0\,(h-text_h))\,y)"
18939
18940 • Show a text line sliding from right to left in the last row of the
18941 video frame. The file LONG_LINE is assumed to contain a single line
18942 with no newlines.
18943
18944 drawtext="fontsize=15:fontfile=FreeSerif.ttf:text=LONG_LINE:y=h-line_h:x=-50*t"
18945
18946 • Show the content of file CREDITS off the bottom of the frame and
18947 scroll up.
18948
18949 drawtext="fontsize=20:fontfile=FreeSerif.ttf:textfile=CREDITS:y=h-20*t"
18950
18951 • Draw a single green letter "g", at the center of the input video.
18952 The glyph baseline is placed at half screen height.
18953
18954 drawtext="fontsize=60:fontfile=FreeSerif.ttf:fontcolor=green:text=g:x=(w-max_glyph_w)/2:y=h/2-ascent"
18955
18956 • Show text for 1 second every 3 seconds:
18957
18958 drawtext="fontfile=FreeSerif.ttf:fontcolor=white:x=100:y=x/dar:enable=lt(mod(t\,3)\,1):text='blink'"
18959
18960 • Use fontconfig to set the font. Note that the colons need to be
18961 escaped.
18962
18963 drawtext='fontfile=Linux Libertine O-40\:style=Semibold:text=FFmpeg'
18964
18965 • Draw "Test Text" with font size dependent on height of the video.
18966
18967 drawtext="text='Test Text': fontsize=h/30: x=(w-text_w)/2: y=(h-text_h*2)"
18968
18969 • Print the date of a real-time encoding (see strftime(3)):
18970
18971 drawtext='fontfile=FreeSans.ttf:text=%{localtime\:%a %b %d %Y}'
18972
18973 • Show text fading in and out (appearing/disappearing):
18974
18975 #!/bin/sh
18976 DS=1.0 # display start
18977 DE=10.0 # display end
18978 FID=1.5 # fade in duration
18979 FOD=5 # fade out duration
18980 ffplay -f lavfi "color,drawtext=text=TEST:fontsize=50:fontfile=FreeSerif.ttf:fontcolor_expr=ff0000%{eif\\\\: clip(255*(1*between(t\\, $DS + $FID\\, $DE - $FOD) + ((t - $DS)/$FID)*between(t\\, $DS\\, $DS + $FID) + (-(t - $DE)/$FOD)*between(t\\, $DE - $FOD\\, $DE) )\\, 0\\, 255) \\\\: x\\\\: 2 }"
18981
18982 • Horizontally align multiple separate texts. Note that max_glyph_a
18983 and the fontsize value are included in the y offset.
18984
18985 drawtext=fontfile=FreeSans.ttf:text=DOG:fontsize=24:x=10:y=20+24-max_glyph_a,
18986 drawtext=fontfile=FreeSans.ttf:text=cow:fontsize=24:x=80:y=20+24-max_glyph_a
18987
18988 • Plot special lavf.image2dec.source_basename metadata onto each
18989 frame if such metadata exists. Otherwise, plot the string "NA".
18990 Note that image2 demuxer must have option -export_path_metadata 1
18991 for the special metadata fields to be available for filters.
18992
18993 drawtext="fontsize=20:fontcolor=white:fontfile=FreeSans.ttf:text='%{metadata\:lavf.image2dec.source_basename\:NA}':x=10:y=10"
18994
18995 For more information about libfreetype, check:
18996 <http://www.freetype.org/>.
18997
18998 For more information about fontconfig, check:
18999 <http://freedesktop.org/software/fontconfig/fontconfig-user.html>.
19000
19001 For more information about libfribidi, check: <http://fribidi.org/>.
19002
19003 edgedetect
19004 Detect and draw edges. The filter uses the Canny Edge Detection
19005 algorithm.
19006
19007 The filter accepts the following options:
19008
19009 low
19010 high
19011 Set low and high threshold values used by the Canny thresholding
19012 algorithm.
19013
19014 The high threshold selects the "strong" edge pixels, which are then
19015 connected through 8-connectivity with the "weak" edge pixels
19016 selected by the low threshold.
19017
19018 low and high threshold values must be chosen in the range [0,1],
19019 and low should be lesser or equal to high.
19020
19021 Default value for low is "20/255", and default value for high is
19022 "50/255".
19023
19024 mode
19025 Define the drawing mode.
19026
19027 wires
19028 Draw white/gray wires on black background.
19029
19030 colormix
19031 Mix the colors to create a paint/cartoon effect.
19032
19033 canny
19034 Apply Canny edge detector on all selected planes.
19035
19036 Default value is wires.
19037
19038 planes
19039 Select planes for filtering. By default all available planes are
19040 filtered.
19041
19042 Examples
19043
19044 • Standard edge detection with custom values for the hysteresis
19045 thresholding:
19046
19047 edgedetect=low=0.1:high=0.4
19048
19049 • Painting effect without thresholding:
19050
19051 edgedetect=mode=colormix:high=0
19052
19053 elbg
19054 Apply a posterize effect using the ELBG (Enhanced LBG) algorithm.
19055
19056 For each input image, the filter will compute the optimal mapping from
19057 the input to the output given the codebook length, that is the number
19058 of distinct output colors.
19059
19060 This filter accepts the following options.
19061
19062 codebook_length, l
19063 Set codebook length. The value must be a positive integer, and
19064 represents the number of distinct output colors. Default value is
19065 256.
19066
19067 nb_steps, n
19068 Set the maximum number of iterations to apply for computing the
19069 optimal mapping. The higher the value the better the result and the
19070 higher the computation time. Default value is 1.
19071
19072 seed, s
19073 Set a random seed, must be an integer included between 0 and
19074 UINT32_MAX. If not specified, or if explicitly set to -1, the
19075 filter will try to use a good random seed on a best effort basis.
19076
19077 pal8
19078 Set pal8 output pixel format. This option does not work with
19079 codebook length greater than 256. Default is disabled.
19080
19081 use_alpha
19082 Include alpha values in the quantization calculation. Allows
19083 creating palettized output images (e.g. PNG8) with multiple alpha
19084 smooth blending.
19085
19086 entropy
19087 Measure graylevel entropy in histogram of color channels of video
19088 frames.
19089
19090 It accepts the following parameters:
19091
19092 mode
19093 Can be either normal or diff. Default is normal.
19094
19095 diff mode measures entropy of histogram delta values, absolute
19096 differences between neighbour histogram values.
19097
19098 epx
19099 Apply the EPX magnification filter which is designed for pixel art.
19100
19101 It accepts the following option:
19102
19103 n Set the scaling dimension: 2 for "2xEPX", 3 for "3xEPX". Default
19104 is 3.
19105
19106 eq
19107 Set brightness, contrast, saturation and approximate gamma adjustment.
19108
19109 The filter accepts the following options:
19110
19111 contrast
19112 Set the contrast expression. The value must be a float value in
19113 range "-1000.0" to 1000.0. The default value is "1".
19114
19115 brightness
19116 Set the brightness expression. The value must be a float value in
19117 range "-1.0" to 1.0. The default value is "0".
19118
19119 saturation
19120 Set the saturation expression. The value must be a float in range
19121 0.0 to 3.0. The default value is "1".
19122
19123 gamma
19124 Set the gamma expression. The value must be a float in range 0.1 to
19125 10.0. The default value is "1".
19126
19127 gamma_r
19128 Set the gamma expression for red. The value must be a float in
19129 range 0.1 to 10.0. The default value is "1".
19130
19131 gamma_g
19132 Set the gamma expression for green. The value must be a float in
19133 range 0.1 to 10.0. The default value is "1".
19134
19135 gamma_b
19136 Set the gamma expression for blue. The value must be a float in
19137 range 0.1 to 10.0. The default value is "1".
19138
19139 gamma_weight
19140 Set the gamma weight expression. It can be used to reduce the
19141 effect of a high gamma value on bright image areas, e.g. keep them
19142 from getting overamplified and just plain white. The value must be
19143 a float in range 0.0 to 1.0. A value of 0.0 turns the gamma
19144 correction all the way down while 1.0 leaves it at its full
19145 strength. Default is "1".
19146
19147 eval
19148 Set when the expressions for brightness, contrast, saturation and
19149 gamma expressions are evaluated.
19150
19151 It accepts the following values:
19152
19153 init
19154 only evaluate expressions once during the filter initialization
19155 or when a command is processed
19156
19157 frame
19158 evaluate expressions for each incoming frame
19159
19160 Default value is init.
19161
19162 The expressions accept the following parameters:
19163
19164 n frame count of the input frame starting from 0
19165
19166 pos byte position of the corresponding packet in the input file, NAN if
19167 unspecified
19168
19169 r frame rate of the input video, NAN if the input frame rate is
19170 unknown
19171
19172 t timestamp expressed in seconds, NAN if the input timestamp is
19173 unknown
19174
19175 Commands
19176
19177 The filter supports the following commands:
19178
19179 contrast
19180 Set the contrast expression.
19181
19182 brightness
19183 Set the brightness expression.
19184
19185 saturation
19186 Set the saturation expression.
19187
19188 gamma
19189 Set the gamma expression.
19190
19191 gamma_r
19192 Set the gamma_r expression.
19193
19194 gamma_g
19195 Set gamma_g expression.
19196
19197 gamma_b
19198 Set gamma_b expression.
19199
19200 gamma_weight
19201 Set gamma_weight expression.
19202
19203 The command accepts the same syntax of the corresponding option.
19204
19205 If the specified expression is not valid, it is kept at its current
19206 value.
19207
19208 erosion
19209 Apply erosion effect to the video.
19210
19211 This filter replaces the pixel by the local(3x3) minimum.
19212
19213 It accepts the following options:
19214
19215 threshold0
19216 threshold1
19217 threshold2
19218 threshold3
19219 Limit the maximum change for each plane, default is 65535. If 0,
19220 plane will remain unchanged.
19221
19222 coordinates
19223 Flag which specifies the pixel to refer to. Default is 255 i.e. all
19224 eight pixels are used.
19225
19226 Flags to local 3x3 coordinates maps like this:
19227
19228 1 2 3
19229 4 5
19230 6 7 8
19231
19232 Commands
19233
19234 This filter supports the all above options as commands.
19235
19236 estdif
19237 Deinterlace the input video ("estdif" stands for "Edge Slope Tracing
19238 Deinterlacing Filter").
19239
19240 Spatial only filter that uses edge slope tracing algorithm to
19241 interpolate missing lines. It accepts the following parameters:
19242
19243 mode
19244 The interlacing mode to adopt. It accepts one of the following
19245 values:
19246
19247 frame
19248 Output one frame for each frame.
19249
19250 field
19251 Output one frame for each field.
19252
19253 The default value is "field".
19254
19255 parity
19256 The picture field parity assumed for the input interlaced video. It
19257 accepts one of the following values:
19258
19259 tff Assume the top field is first.
19260
19261 bff Assume the bottom field is first.
19262
19263 auto
19264 Enable automatic detection of field parity.
19265
19266 The default value is "auto". If the interlacing is unknown or the
19267 decoder does not export this information, top field first will be
19268 assumed.
19269
19270 deint
19271 Specify which frames to deinterlace. Accepts one of the following
19272 values:
19273
19274 all Deinterlace all frames.
19275
19276 interlaced
19277 Only deinterlace frames marked as interlaced.
19278
19279 The default value is "all".
19280
19281 rslope
19282 Specify the search radius for edge slope tracing. Default value is
19283 1. Allowed range is from 1 to 15.
19284
19285 redge
19286 Specify the search radius for best edge matching. Default value is
19287 2. Allowed range is from 0 to 15.
19288
19289 ecost
19290 Specify the edge cost for edge matching. Default value is 0.03125.
19291 Allowed range is from 0 to 1.
19292
19293 mcost
19294 Specify the middle cost for edge matching. Default value is 0.5.
19295 Allowed range is from 0 to 1.
19296
19297 dcost
19298 Specify the distance cost for edge matching. Default value is 0.5.
19299 Allowed range is from 0 to 1.
19300
19301 interp
19302 Specify the interpolation used. Default is 4-point interpolation.
19303 It accepts one of the following values:
19304
19305 2p Two-point interpolation.
19306
19307 4p Four-point interpolation.
19308
19309 6p Six-point interpolation.
19310
19311 Commands
19312
19313 This filter supports same commands as options.
19314
19315 exposure
19316 Adjust exposure of the video stream.
19317
19318 The filter accepts the following options:
19319
19320 exposure
19321 Set the exposure correction in EV. Allowed range is from -3.0 to
19322 3.0 EV Default value is 0 EV.
19323
19324 black
19325 Set the black level correction. Allowed range is from -1.0 to 1.0.
19326 Default value is 0.
19327
19328 Commands
19329
19330 This filter supports same commands as options.
19331
19332 extractplanes
19333 Extract color channel components from input video stream into separate
19334 grayscale video streams.
19335
19336 The filter accepts the following option:
19337
19338 planes
19339 Set plane(s) to extract.
19340
19341 Available values for planes are:
19342
19343 y
19344 u
19345 v
19346 a
19347 r
19348 g
19349 b
19350
19351 Choosing planes not available in the input will result in an error.
19352 That means you cannot select "r", "g", "b" planes with "y", "u",
19353 "v" planes at same time.
19354
19355 Examples
19356
19357 • Extract luma, u and v color channel component from input video
19358 frame into 3 grayscale outputs:
19359
19360 ffmpeg -i video.avi -filter_complex 'extractplanes=y+u+v[y][u][v]' -map '[y]' y.avi -map '[u]' u.avi -map '[v]' v.avi
19361
19362 fade
19363 Apply a fade-in/out effect to the input video.
19364
19365 It accepts the following parameters:
19366
19367 type, t
19368 The effect type can be either "in" for a fade-in, or "out" for a
19369 fade-out effect. Default is "in".
19370
19371 start_frame, s
19372 Specify the number of the frame to start applying the fade effect
19373 at. Default is 0.
19374
19375 nb_frames, n
19376 The number of frames that the fade effect lasts. At the end of the
19377 fade-in effect, the output video will have the same intensity as
19378 the input video. At the end of the fade-out transition, the output
19379 video will be filled with the selected color. Default is 25.
19380
19381 alpha
19382 If set to 1, fade only alpha channel, if one exists on the input.
19383 Default value is 0.
19384
19385 start_time, st
19386 Specify the timestamp (in seconds) of the frame to start to apply
19387 the fade effect. If both start_frame and start_time are specified,
19388 the fade will start at whichever comes last. Default is 0.
19389
19390 duration, d
19391 The number of seconds for which the fade effect has to last. At the
19392 end of the fade-in effect the output video will have the same
19393 intensity as the input video, at the end of the fade-out transition
19394 the output video will be filled with the selected color. If both
19395 duration and nb_frames are specified, duration is used. Default is
19396 0 (nb_frames is used by default).
19397
19398 color, c
19399 Specify the color of the fade. Default is "black".
19400
19401 Examples
19402
19403 • Fade in the first 30 frames of video:
19404
19405 fade=in:0:30
19406
19407 The command above is equivalent to:
19408
19409 fade=t=in:s=0:n=30
19410
19411 • Fade out the last 45 frames of a 200-frame video:
19412
19413 fade=out:155:45
19414 fade=type=out:start_frame=155:nb_frames=45
19415
19416 • Fade in the first 25 frames and fade out the last 25 frames of a
19417 1000-frame video:
19418
19419 fade=in:0:25, fade=out:975:25
19420
19421 • Make the first 5 frames yellow, then fade in from frame 5-24:
19422
19423 fade=in:5:20:color=yellow
19424
19425 • Fade in alpha over first 25 frames of video:
19426
19427 fade=in:0:25:alpha=1
19428
19429 • Make the first 5.5 seconds black, then fade in for 0.5 seconds:
19430
19431 fade=t=in:st=5.5:d=0.5
19432
19433 fftdnoiz
19434 Denoise frames using 3D FFT (frequency domain filtering).
19435
19436 The filter accepts the following options:
19437
19438 sigma
19439 Set the noise sigma constant. This sets denoising strength.
19440 Default value is 1. Allowed range is from 0 to 30. Using very high
19441 sigma with low overlap may give blocking artifacts.
19442
19443 amount
19444 Set amount of denoising. By default all detected noise is reduced.
19445 Default value is 1. Allowed range is from 0 to 1.
19446
19447 block
19448 Set size of block, Default is 4, can be 3, 4, 5 or 6. Actual size
19449 of block in pixels is 2 to power of block, so by default block size
19450 in pixels is 2^4 which is 16.
19451
19452 overlap
19453 Set block overlap. Default is 0.5. Allowed range is from 0.2 to
19454 0.8.
19455
19456 prev
19457 Set number of previous frames to use for denoising. By default is
19458 set to 0.
19459
19460 next
19461 Set number of next frames to to use for denoising. By default is
19462 set to 0.
19463
19464 planes
19465 Set planes which will be filtered, by default are all available
19466 filtered except alpha.
19467
19468 fftfilt
19469 Apply arbitrary expressions to samples in frequency domain
19470
19471 dc_Y
19472 Adjust the dc value (gain) of the luma plane of the image. The
19473 filter accepts an integer value in range 0 to 1000. The default
19474 value is set to 0.
19475
19476 dc_U
19477 Adjust the dc value (gain) of the 1st chroma plane of the image.
19478 The filter accepts an integer value in range 0 to 1000. The default
19479 value is set to 0.
19480
19481 dc_V
19482 Adjust the dc value (gain) of the 2nd chroma plane of the image.
19483 The filter accepts an integer value in range 0 to 1000. The default
19484 value is set to 0.
19485
19486 weight_Y
19487 Set the frequency domain weight expression for the luma plane.
19488
19489 weight_U
19490 Set the frequency domain weight expression for the 1st chroma
19491 plane.
19492
19493 weight_V
19494 Set the frequency domain weight expression for the 2nd chroma
19495 plane.
19496
19497 eval
19498 Set when the expressions are evaluated.
19499
19500 It accepts the following values:
19501
19502 init
19503 Only evaluate expressions once during the filter
19504 initialization.
19505
19506 frame
19507 Evaluate expressions for each incoming frame.
19508
19509 Default value is init.
19510
19511 The filter accepts the following variables:
19512
19513 X
19514 Y The coordinates of the current sample.
19515
19516 W
19517 H The width and height of the image.
19518
19519 N The number of input frame, starting from 0.
19520
19521 WS
19522 HS The size of FFT array for horizontal and vertical processing.
19523
19524 Examples
19525
19526 • High-pass:
19527
19528 fftfilt=dc_Y=128:weight_Y='squish(1-(Y+X)/100)'
19529
19530 • Low-pass:
19531
19532 fftfilt=dc_Y=0:weight_Y='squish((Y+X)/100-1)'
19533
19534 • Sharpen:
19535
19536 fftfilt=dc_Y=0:weight_Y='1+squish(1-(Y+X)/100)'
19537
19538 • Blur:
19539
19540 fftfilt=dc_Y=0:weight_Y='exp(-4 * ((Y+X)/(W+H)))'
19541
19542 field
19543 Extract a single field from an interlaced image using stride arithmetic
19544 to avoid wasting CPU time. The output frames are marked as non-
19545 interlaced.
19546
19547 The filter accepts the following options:
19548
19549 type
19550 Specify whether to extract the top (if the value is 0 or "top") or
19551 the bottom field (if the value is 1 or "bottom").
19552
19553 fieldhint
19554 Create new frames by copying the top and bottom fields from surrounding
19555 frames supplied as numbers by the hint file.
19556
19557 hint
19558 Set file containing hints: absolute/relative frame numbers.
19559
19560 There must be one line for each frame in a clip. Each line must
19561 contain two numbers separated by the comma, optionally followed by
19562 "-" or "+". Numbers supplied on each line of file can not be out
19563 of [N-1,N+1] where N is current frame number for "absolute" mode or
19564 out of [-1, 1] range for "relative" mode. First number tells from
19565 which frame to pick up top field and second number tells from which
19566 frame to pick up bottom field.
19567
19568 If optionally followed by "+" output frame will be marked as
19569 interlaced, else if followed by "-" output frame will be marked as
19570 progressive, else it will be marked same as input frame. If
19571 optionally followed by "t" output frame will use only top field, or
19572 in case of "b" it will use only bottom field. If line starts with
19573 "#" or ";" that line is skipped.
19574
19575 mode
19576 Can be item "absolute" or "relative". Default is "absolute".
19577
19578 Example of first several lines of "hint" file for "relative" mode:
19579
19580 0,0 - # first frame
19581 1,0 - # second frame, use third's frame top field and second's frame bottom field
19582 1,0 - # third frame, use fourth's frame top field and third's frame bottom field
19583 1,0 -
19584 0,0 -
19585 0,0 -
19586 1,0 -
19587 1,0 -
19588 1,0 -
19589 0,0 -
19590 0,0 -
19591 1,0 -
19592 1,0 -
19593 1,0 -
19594 0,0 -
19595
19596 fieldmatch
19597 Field matching filter for inverse telecine. It is meant to reconstruct
19598 the progressive frames from a telecined stream. The filter does not
19599 drop duplicated frames, so to achieve a complete inverse telecine
19600 "fieldmatch" needs to be followed by a decimation filter such as
19601 decimate in the filtergraph.
19602
19603 The separation of the field matching and the decimation is notably
19604 motivated by the possibility of inserting a de-interlacing filter
19605 fallback between the two. If the source has mixed telecined and real
19606 interlaced content, "fieldmatch" will not be able to match fields for
19607 the interlaced parts. But these remaining combed frames will be marked
19608 as interlaced, and thus can be de-interlaced by a later filter such as
19609 yadif before decimation.
19610
19611 In addition to the various configuration options, "fieldmatch" can take
19612 an optional second stream, activated through the ppsrc option. If
19613 enabled, the frames reconstruction will be based on the fields and
19614 frames from this second stream. This allows the first input to be pre-
19615 processed in order to help the various algorithms of the filter, while
19616 keeping the output lossless (assuming the fields are matched properly).
19617 Typically, a field-aware denoiser, or brightness/contrast adjustments
19618 can help.
19619
19620 Note that this filter uses the same algorithms as TIVTC/TFM (AviSynth
19621 project) and VIVTC/VFM (VapourSynth project). The later is a light
19622 clone of TFM from which "fieldmatch" is based on. While the semantic
19623 and usage are very close, some behaviour and options names can differ.
19624
19625 The decimate filter currently only works for constant frame rate input.
19626 If your input has mixed telecined (30fps) and progressive content with
19627 a lower framerate like 24fps use the following filterchain to produce
19628 the necessary cfr stream:
19629 "dejudder,fps=30000/1001,fieldmatch,decimate".
19630
19631 The filter accepts the following options:
19632
19633 order
19634 Specify the assumed field order of the input stream. Available
19635 values are:
19636
19637 auto
19638 Auto detect parity (use FFmpeg's internal parity value).
19639
19640 bff Assume bottom field first.
19641
19642 tff Assume top field first.
19643
19644 Note that it is sometimes recommended not to trust the parity
19645 announced by the stream.
19646
19647 Default value is auto.
19648
19649 mode
19650 Set the matching mode or strategy to use. pc mode is the safest in
19651 the sense that it won't risk creating jerkiness due to duplicate
19652 frames when possible, but if there are bad edits or blended fields
19653 it will end up outputting combed frames when a good match might
19654 actually exist. On the other hand, pcn_ub mode is the most risky in
19655 terms of creating jerkiness, but will almost always find a good
19656 frame if there is one. The other values are all somewhere in
19657 between pc and pcn_ub in terms of risking jerkiness and creating
19658 duplicate frames versus finding good matches in sections with bad
19659 edits, orphaned fields, blended fields, etc.
19660
19661 More details about p/c/n/u/b are available in p/c/n/u/b meaning
19662 section.
19663
19664 Available values are:
19665
19666 pc 2-way matching (p/c)
19667
19668 pc_n
19669 2-way matching, and trying 3rd match if still combed (p/c + n)
19670
19671 pc_u
19672 2-way matching, and trying 3rd match (same order) if still
19673 combed (p/c + u)
19674
19675 pc_n_ub
19676 2-way matching, trying 3rd match if still combed, and trying
19677 4th/5th matches if still combed (p/c + n + u/b)
19678
19679 pcn 3-way matching (p/c/n)
19680
19681 pcn_ub
19682 3-way matching, and trying 4th/5th matches if all 3 of the
19683 original matches are detected as combed (p/c/n + u/b)
19684
19685 The parenthesis at the end indicate the matches that would be used
19686 for that mode assuming order=tff (and field on auto or top).
19687
19688 In terms of speed pc mode is by far the fastest and pcn_ub is the
19689 slowest.
19690
19691 Default value is pc_n.
19692
19693 ppsrc
19694 Mark the main input stream as a pre-processed input, and enable the
19695 secondary input stream as the clean source to pick the fields from.
19696 See the filter introduction for more details. It is similar to the
19697 clip2 feature from VFM/TFM.
19698
19699 Default value is 0 (disabled).
19700
19701 field
19702 Set the field to match from. It is recommended to set this to the
19703 same value as order unless you experience matching failures with
19704 that setting. In certain circumstances changing the field that is
19705 used to match from can have a large impact on matching performance.
19706 Available values are:
19707
19708 auto
19709 Automatic (same value as order).
19710
19711 bottom
19712 Match from the bottom field.
19713
19714 top Match from the top field.
19715
19716 Default value is auto.
19717
19718 mchroma
19719 Set whether or not chroma is included during the match comparisons.
19720 In most cases it is recommended to leave this enabled. You should
19721 set this to 0 only if your clip has bad chroma problems such as
19722 heavy rainbowing or other artifacts. Setting this to 0 could also
19723 be used to speed things up at the cost of some accuracy.
19724
19725 Default value is 1.
19726
19727 y0
19728 y1 These define an exclusion band which excludes the lines between y0
19729 and y1 from being included in the field matching decision. An
19730 exclusion band can be used to ignore subtitles, a logo, or other
19731 things that may interfere with the matching. y0 sets the starting
19732 scan line and y1 sets the ending line; all lines in between y0 and
19733 y1 (including y0 and y1) will be ignored. Setting y0 and y1 to the
19734 same value will disable the feature. y0 and y1 defaults to 0.
19735
19736 scthresh
19737 Set the scene change detection threshold as a percentage of maximum
19738 change on the luma plane. Good values are in the "[8.0, 14.0]"
19739 range. Scene change detection is only relevant in case
19740 combmatch=sc. The range for scthresh is "[0.0, 100.0]".
19741
19742 Default value is 12.0.
19743
19744 combmatch
19745 When combatch is not none, "fieldmatch" will take into account the
19746 combed scores of matches when deciding what match to use as the
19747 final match. Available values are:
19748
19749 none
19750 No final matching based on combed scores.
19751
19752 sc Combed scores are only used when a scene change is detected.
19753
19754 full
19755 Use combed scores all the time.
19756
19757 Default is sc.
19758
19759 combdbg
19760 Force "fieldmatch" to calculate the combed metrics for certain
19761 matches and print them. This setting is known as micout in TFM/VFM
19762 vocabulary. Available values are:
19763
19764 none
19765 No forced calculation.
19766
19767 pcn Force p/c/n calculations.
19768
19769 pcnub
19770 Force p/c/n/u/b calculations.
19771
19772 Default value is none.
19773
19774 cthresh
19775 This is the area combing threshold used for combed frame detection.
19776 This essentially controls how "strong" or "visible" combing must be
19777 to be detected. Larger values mean combing must be more visible
19778 and smaller values mean combing can be less visible or strong and
19779 still be detected. Valid settings are from "-1" (every pixel will
19780 be detected as combed) to 255 (no pixel will be detected as
19781 combed). This is basically a pixel difference value. A good range
19782 is "[8, 12]".
19783
19784 Default value is 9.
19785
19786 chroma
19787 Sets whether or not chroma is considered in the combed frame
19788 decision. Only disable this if your source has chroma problems
19789 (rainbowing, etc.) that are causing problems for the combed frame
19790 detection with chroma enabled. Actually, using chroma=0 is usually
19791 more reliable, except for the case where there is chroma only
19792 combing in the source.
19793
19794 Default value is 0.
19795
19796 blockx
19797 blocky
19798 Respectively set the x-axis and y-axis size of the window used
19799 during combed frame detection. This has to do with the size of the
19800 area in which combpel pixels are required to be detected as combed
19801 for a frame to be declared combed. See the combpel parameter
19802 description for more info. Possible values are any number that is
19803 a power of 2 starting at 4 and going up to 512.
19804
19805 Default value is 16.
19806
19807 combpel
19808 The number of combed pixels inside any of the blocky by blockx size
19809 blocks on the frame for the frame to be detected as combed. While
19810 cthresh controls how "visible" the combing must be, this setting
19811 controls "how much" combing there must be in any localized area (a
19812 window defined by the blockx and blocky settings) on the frame.
19813 Minimum value is 0 and maximum is "blocky x blockx" (at which point
19814 no frames will ever be detected as combed). This setting is known
19815 as MI in TFM/VFM vocabulary.
19816
19817 Default value is 80.
19818
19819 p/c/n/u/b meaning
19820
19821 p/c/n
19822
19823 We assume the following telecined stream:
19824
19825 Top fields: 1 2 2 3 4
19826 Bottom fields: 1 2 3 4 4
19827
19828 The numbers correspond to the progressive frame the fields relate to.
19829 Here, the first two frames are progressive, the 3rd and 4th are combed,
19830 and so on.
19831
19832 When "fieldmatch" is configured to run a matching from bottom
19833 (field=bottom) this is how this input stream get transformed:
19834
19835 Input stream:
19836 T 1 2 2 3 4
19837 B 1 2 3 4 4 <-- matching reference
19838
19839 Matches: c c n n c
19840
19841 Output stream:
19842 T 1 2 3 4 4
19843 B 1 2 3 4 4
19844
19845 As a result of the field matching, we can see that some frames get
19846 duplicated. To perform a complete inverse telecine, you need to rely
19847 on a decimation filter after this operation. See for instance the
19848 decimate filter.
19849
19850 The same operation now matching from top fields (field=top) looks like
19851 this:
19852
19853 Input stream:
19854 T 1 2 2 3 4 <-- matching reference
19855 B 1 2 3 4 4
19856
19857 Matches: c c p p c
19858
19859 Output stream:
19860 T 1 2 2 3 4
19861 B 1 2 2 3 4
19862
19863 In these examples, we can see what p, c and n mean; basically, they
19864 refer to the frame and field of the opposite parity:
19865
19866 *<p matches the field of the opposite parity in the previous frame>
19867 *<c matches the field of the opposite parity in the current frame>
19868 *<n matches the field of the opposite parity in the next frame>
19869
19870 u/b
19871
19872 The u and b matching are a bit special in the sense that they match
19873 from the opposite parity flag. In the following examples, we assume
19874 that we are currently matching the 2nd frame (Top:2, bottom:2).
19875 According to the match, a 'x' is placed above and below each matched
19876 fields.
19877
19878 With bottom matching (field=bottom):
19879
19880 Match: c p n b u
19881
19882 x x x x x
19883 Top 1 2 2 1 2 2 1 2 2 1 2 2 1 2 2
19884 Bottom 1 2 3 1 2 3 1 2 3 1 2 3 1 2 3
19885 x x x x x
19886
19887 Output frames:
19888 2 1 2 2 2
19889 2 2 2 1 3
19890
19891 With top matching (field=top):
19892
19893 Match: c p n b u
19894
19895 x x x x x
19896 Top 1 2 2 1 2 2 1 2 2 1 2 2 1 2 2
19897 Bottom 1 2 3 1 2 3 1 2 3 1 2 3 1 2 3
19898 x x x x x
19899
19900 Output frames:
19901 2 2 2 1 2
19902 2 1 3 2 2
19903
19904 Examples
19905
19906 Simple IVTC of a top field first telecined stream:
19907
19908 fieldmatch=order=tff:combmatch=none, decimate
19909
19910 Advanced IVTC, with fallback on yadif for still combed frames:
19911
19912 fieldmatch=order=tff:combmatch=full, yadif=deint=interlaced, decimate
19913
19914 fieldorder
19915 Transform the field order of the input video.
19916
19917 It accepts the following parameters:
19918
19919 order
19920 The output field order. Valid values are tff for top field first or
19921 bff for bottom field first.
19922
19923 The default value is tff.
19924
19925 The transformation is done by shifting the picture content up or down
19926 by one line, and filling the remaining line with appropriate picture
19927 content. This method is consistent with most broadcast field order
19928 converters.
19929
19930 If the input video is not flagged as being interlaced, or it is already
19931 flagged as being of the required output field order, then this filter
19932 does not alter the incoming video.
19933
19934 It is very useful when converting to or from PAL DV material, which is
19935 bottom field first.
19936
19937 For example:
19938
19939 ffmpeg -i in.vob -vf "fieldorder=bff" out.dv
19940
19941 fifo, afifo
19942 Buffer input images and send them when they are requested.
19943
19944 It is mainly useful when auto-inserted by the libavfilter framework.
19945
19946 It does not take parameters.
19947
19948 fillborders
19949 Fill borders of the input video, without changing video stream
19950 dimensions. Sometimes video can have garbage at the four edges and you
19951 may not want to crop video input to keep size multiple of some number.
19952
19953 This filter accepts the following options:
19954
19955 left
19956 Number of pixels to fill from left border.
19957
19958 right
19959 Number of pixels to fill from right border.
19960
19961 top Number of pixels to fill from top border.
19962
19963 bottom
19964 Number of pixels to fill from bottom border.
19965
19966 mode
19967 Set fill mode.
19968
19969 It accepts the following values:
19970
19971 smear
19972 fill pixels using outermost pixels
19973
19974 mirror
19975 fill pixels using mirroring (half sample symmetric)
19976
19977 fixed
19978 fill pixels with constant value
19979
19980 reflect
19981 fill pixels using reflecting (whole sample symmetric)
19982
19983 wrap
19984 fill pixels using wrapping
19985
19986 fade
19987 fade pixels to constant value
19988
19989 margins
19990 fill pixels at top and bottom with weighted averages pixels
19991 near borders
19992
19993 Default is smear.
19994
19995 color
19996 Set color for pixels in fixed or fade mode. Default is black.
19997
19998 Commands
19999
20000 This filter supports same commands as options. The command accepts the
20001 same syntax of the corresponding option.
20002
20003 If the specified expression is not valid, it is kept at its current
20004 value.
20005
20006 find_rect
20007 Find a rectangular object
20008
20009 It accepts the following options:
20010
20011 object
20012 Filepath of the object image, needs to be in gray8.
20013
20014 threshold
20015 Detection threshold, default is 0.5.
20016
20017 mipmaps
20018 Number of mipmaps, default is 3.
20019
20020 xmin, ymin, xmax, ymax
20021 Specifies the rectangle in which to search.
20022
20023 discard
20024 Discard frames where object is not detected. Default is disabled.
20025
20026 Examples
20027
20028 • Cover a rectangular object by the supplied image of a given video
20029 using ffmpeg:
20030
20031 ffmpeg -i file.ts -vf find_rect=newref.pgm,cover_rect=cover.jpg:mode=cover new.mkv
20032
20033 floodfill
20034 Flood area with values of same pixel components with another values.
20035
20036 It accepts the following options:
20037
20038 x Set pixel x coordinate.
20039
20040 y Set pixel y coordinate.
20041
20042 s0 Set source #0 component value.
20043
20044 s1 Set source #1 component value.
20045
20046 s2 Set source #2 component value.
20047
20048 s3 Set source #3 component value.
20049
20050 d0 Set destination #0 component value.
20051
20052 d1 Set destination #1 component value.
20053
20054 d2 Set destination #2 component value.
20055
20056 d3 Set destination #3 component value.
20057
20058 format
20059 Convert the input video to one of the specified pixel formats.
20060 Libavfilter will try to pick one that is suitable as input to the next
20061 filter.
20062
20063 It accepts the following parameters:
20064
20065 pix_fmts
20066 A '|'-separated list of pixel format names, such as
20067 "pix_fmts=yuv420p|monow|rgb24".
20068
20069 Examples
20070
20071 • Convert the input video to the yuv420p format
20072
20073 format=pix_fmts=yuv420p
20074
20075 Convert the input video to any of the formats in the list
20076
20077 format=pix_fmts=yuv420p|yuv444p|yuv410p
20078
20079 fps
20080 Convert the video to specified constant frame rate by duplicating or
20081 dropping frames as necessary.
20082
20083 It accepts the following parameters:
20084
20085 fps The desired output frame rate. It accepts expressions containing
20086 the following constants:
20087
20088 source_fps
20089 The input's frame rate
20090
20091 ntsc
20092 NTSC frame rate of "30000/1001"
20093
20094 pal PAL frame rate of 25.0
20095
20096 film
20097 Film frame rate of 24.0
20098
20099 ntsc_film
20100 NTSC-film frame rate of "24000/1001"
20101
20102 The default is 25.
20103
20104 start_time
20105 Assume the first PTS should be the given value, in seconds. This
20106 allows for padding/trimming at the start of stream. By default, no
20107 assumption is made about the first frame's expected PTS, so no
20108 padding or trimming is done. For example, this could be set to 0
20109 to pad the beginning with duplicates of the first frame if a video
20110 stream starts after the audio stream or to trim any frames with a
20111 negative PTS.
20112
20113 round
20114 Timestamp (PTS) rounding method.
20115
20116 Possible values are:
20117
20118 zero
20119 round towards 0
20120
20121 inf round away from 0
20122
20123 down
20124 round towards -infinity
20125
20126 up round towards +infinity
20127
20128 near
20129 round to nearest
20130
20131 The default is "near".
20132
20133 eof_action
20134 Action performed when reading the last frame.
20135
20136 Possible values are:
20137
20138 round
20139 Use same timestamp rounding method as used for other frames.
20140
20141 pass
20142 Pass through last frame if input duration has not been reached
20143 yet.
20144
20145 The default is "round".
20146
20147 Alternatively, the options can be specified as a flat string:
20148 fps[:start_time[:round]].
20149
20150 See also the setpts filter.
20151
20152 Examples
20153
20154 • A typical usage in order to set the fps to 25:
20155
20156 fps=fps=25
20157
20158 • Sets the fps to 24, using abbreviation and rounding method to round
20159 to nearest:
20160
20161 fps=fps=film:round=near
20162
20163 framepack
20164 Pack two different video streams into a stereoscopic video, setting
20165 proper metadata on supported codecs. The two views should have the same
20166 size and framerate and processing will stop when the shorter video
20167 ends. Please note that you may conveniently adjust view properties with
20168 the scale and fps filters.
20169
20170 It accepts the following parameters:
20171
20172 format
20173 The desired packing format. Supported values are:
20174
20175 sbs The views are next to each other (default).
20176
20177 tab The views are on top of each other.
20178
20179 lines
20180 The views are packed by line.
20181
20182 columns
20183 The views are packed by column.
20184
20185 frameseq
20186 The views are temporally interleaved.
20187
20188 Some examples:
20189
20190 # Convert left and right views into a frame-sequential video
20191 ffmpeg -i LEFT -i RIGHT -filter_complex framepack=frameseq OUTPUT
20192
20193 # Convert views into a side-by-side video with the same output resolution as the input
20194 ffmpeg -i LEFT -i RIGHT -filter_complex [0:v]scale=w=iw/2[left],[1:v]scale=w=iw/2[right],[left][right]framepack=sbs OUTPUT
20195
20196 framerate
20197 Change the frame rate by interpolating new video output frames from the
20198 source frames.
20199
20200 This filter is not designed to function correctly with interlaced
20201 media. If you wish to change the frame rate of interlaced media then
20202 you are required to deinterlace before this filter and re-interlace
20203 after this filter.
20204
20205 A description of the accepted options follows.
20206
20207 fps Specify the output frames per second. This option can also be
20208 specified as a value alone. The default is 50.
20209
20210 interp_start
20211 Specify the start of a range where the output frame will be created
20212 as a linear interpolation of two frames. The range is [0-255], the
20213 default is 15.
20214
20215 interp_end
20216 Specify the end of a range where the output frame will be created
20217 as a linear interpolation of two frames. The range is [0-255], the
20218 default is 240.
20219
20220 scene
20221 Specify the level at which a scene change is detected as a value
20222 between 0 and 100 to indicate a new scene; a low value reflects a
20223 low probability for the current frame to introduce a new scene,
20224 while a higher value means the current frame is more likely to be
20225 one. The default is 8.2.
20226
20227 flags
20228 Specify flags influencing the filter process.
20229
20230 Available value for flags is:
20231
20232 scene_change_detect, scd
20233 Enable scene change detection using the value of the option
20234 scene. This flag is enabled by default.
20235
20236 framestep
20237 Select one frame every N-th frame.
20238
20239 This filter accepts the following option:
20240
20241 step
20242 Select frame after every "step" frames. Allowed values are
20243 positive integers higher than 0. Default value is 1.
20244
20245 freezedetect
20246 Detect frozen video.
20247
20248 This filter logs a message and sets frame metadata when it detects that
20249 the input video has no significant change in content during a specified
20250 duration. Video freeze detection calculates the mean average absolute
20251 difference of all the components of video frames and compares it to a
20252 noise floor.
20253
20254 The printed times and duration are expressed in seconds. The
20255 "lavfi.freezedetect.freeze_start" metadata key is set on the first
20256 frame whose timestamp equals or exceeds the detection duration and it
20257 contains the timestamp of the first frame of the freeze. The
20258 "lavfi.freezedetect.freeze_duration" and
20259 "lavfi.freezedetect.freeze_end" metadata keys are set on the first
20260 frame after the freeze.
20261
20262 The filter accepts the following options:
20263
20264 noise, n
20265 Set noise tolerance. Can be specified in dB (in case "dB" is
20266 appended to the specified value) or as a difference ratio between 0
20267 and 1. Default is -60dB, or 0.001.
20268
20269 duration, d
20270 Set freeze duration until notification (default is 2 seconds).
20271
20272 freezeframes
20273 Freeze video frames.
20274
20275 This filter freezes video frames using frame from 2nd input.
20276
20277 The filter accepts the following options:
20278
20279 first
20280 Set number of first frame from which to start freeze.
20281
20282 last
20283 Set number of last frame from which to end freeze.
20284
20285 replace
20286 Set number of frame from 2nd input which will be used instead of
20287 replaced frames.
20288
20289 frei0r
20290 Apply a frei0r effect to the input video.
20291
20292 To enable the compilation of this filter, you need to install the
20293 frei0r header and configure FFmpeg with "--enable-frei0r".
20294
20295 It accepts the following parameters:
20296
20297 filter_name
20298 The name of the frei0r effect to load. If the environment variable
20299 FREI0R_PATH is defined, the frei0r effect is searched for in each
20300 of the directories specified by the colon-separated list in
20301 FREI0R_PATH. Otherwise, the standard frei0r paths are searched, in
20302 this order: HOME/.frei0r-1/lib/, /usr/local/lib/frei0r-1/,
20303 /usr/lib/frei0r-1/.
20304
20305 filter_params
20306 A '|'-separated list of parameters to pass to the frei0r effect.
20307
20308 A frei0r effect parameter can be a boolean (its value is either "y" or
20309 "n"), a double, a color (specified as R/G/B, where R, G, and B are
20310 floating point numbers between 0.0 and 1.0, inclusive) or a color
20311 description as specified in the "Color" section in the ffmpeg-utils
20312 manual, a position (specified as X/Y, where X and Y are floating point
20313 numbers) and/or a string.
20314
20315 The number and types of parameters depend on the loaded effect. If an
20316 effect parameter is not specified, the default value is set.
20317
20318 Examples
20319
20320 • Apply the distort0r effect, setting the first two double
20321 parameters:
20322
20323 frei0r=filter_name=distort0r:filter_params=0.5|0.01
20324
20325 • Apply the colordistance effect, taking a color as the first
20326 parameter:
20327
20328 frei0r=colordistance:0.2/0.3/0.4
20329 frei0r=colordistance:violet
20330 frei0r=colordistance:0x112233
20331
20332 • Apply the perspective effect, specifying the top left and top right
20333 image positions:
20334
20335 frei0r=perspective:0.2/0.2|0.8/0.2
20336
20337 For more information, see <http://frei0r.dyne.org>
20338
20339 Commands
20340
20341 This filter supports the filter_params option as commands.
20342
20343 fspp
20344 Apply fast and simple postprocessing. It is a faster version of spp.
20345
20346 It splits (I)DCT into horizontal/vertical passes. Unlike the simple
20347 post- processing filter, one of them is performed once per block, not
20348 per pixel. This allows for much higher speed.
20349
20350 The filter accepts the following options:
20351
20352 quality
20353 Set quality. This option defines the number of levels for
20354 averaging. It accepts an integer in the range 4-5. Default value is
20355 4.
20356
20357 qp Force a constant quantization parameter. It accepts an integer in
20358 range 0-63. If not set, the filter will use the QP from the video
20359 stream (if available).
20360
20361 strength
20362 Set filter strength. It accepts an integer in range -15 to 32.
20363 Lower values mean more details but also more artifacts, while
20364 higher values make the image smoother but also blurrier. Default
20365 value is 0 X PSNR optimal.
20366
20367 use_bframe_qp
20368 Enable the use of the QP from the B-Frames if set to 1. Using this
20369 option may cause flicker since the B-Frames have often larger QP.
20370 Default is 0 (not enabled).
20371
20372 gblur
20373 Apply Gaussian blur filter.
20374
20375 The filter accepts the following options:
20376
20377 sigma
20378 Set horizontal sigma, standard deviation of Gaussian blur. Default
20379 is 0.5.
20380
20381 steps
20382 Set number of steps for Gaussian approximation. Default is 1.
20383
20384 planes
20385 Set which planes to filter. By default all planes are filtered.
20386
20387 sigmaV
20388 Set vertical sigma, if negative it will be same as "sigma".
20389 Default is "-1".
20390
20391 Commands
20392
20393 This filter supports same commands as options. The command accepts the
20394 same syntax of the corresponding option.
20395
20396 If the specified expression is not valid, it is kept at its current
20397 value.
20398
20399 geq
20400 Apply generic equation to each pixel.
20401
20402 The filter accepts the following options:
20403
20404 lum_expr, lum
20405 Set the luminance expression.
20406
20407 cb_expr, cb
20408 Set the chrominance blue expression.
20409
20410 cr_expr, cr
20411 Set the chrominance red expression.
20412
20413 alpha_expr, a
20414 Set the alpha expression.
20415
20416 red_expr, r
20417 Set the red expression.
20418
20419 green_expr, g
20420 Set the green expression.
20421
20422 blue_expr, b
20423 Set the blue expression.
20424
20425 The colorspace is selected according to the specified options. If one
20426 of the lum_expr, cb_expr, or cr_expr options is specified, the filter
20427 will automatically select a YCbCr colorspace. If one of the red_expr,
20428 green_expr, or blue_expr options is specified, it will select an RGB
20429 colorspace.
20430
20431 If one of the chrominance expression is not defined, it falls back on
20432 the other one. If no alpha expression is specified it will evaluate to
20433 opaque value. If none of chrominance expressions are specified, they
20434 will evaluate to the luminance expression.
20435
20436 The expressions can use the following variables and functions:
20437
20438 N The sequential number of the filtered frame, starting from 0.
20439
20440 X
20441 Y The coordinates of the current sample.
20442
20443 W
20444 H The width and height of the image.
20445
20446 SW
20447 SH Width and height scale depending on the currently filtered plane.
20448 It is the ratio between the corresponding luma plane number of
20449 pixels and the current plane ones. E.g. for YUV4:2:0 the values are
20450 "1,1" for the luma plane, and "0.5,0.5" for chroma planes.
20451
20452 T Time of the current frame, expressed in seconds.
20453
20454 p(x, y)
20455 Return the value of the pixel at location (x,y) of the current
20456 plane.
20457
20458 lum(x, y)
20459 Return the value of the pixel at location (x,y) of the luminance
20460 plane.
20461
20462 cb(x, y)
20463 Return the value of the pixel at location (x,y) of the blue-
20464 difference chroma plane. Return 0 if there is no such plane.
20465
20466 cr(x, y)
20467 Return the value of the pixel at location (x,y) of the red-
20468 difference chroma plane. Return 0 if there is no such plane.
20469
20470 r(x, y)
20471 g(x, y)
20472 b(x, y)
20473 Return the value of the pixel at location (x,y) of the
20474 red/green/blue component. Return 0 if there is no such component.
20475
20476 alpha(x, y)
20477 Return the value of the pixel at location (x,y) of the alpha plane.
20478 Return 0 if there is no such plane.
20479
20480 psum(x,y), lumsum(x, y), cbsum(x,y), crsum(x,y), rsum(x,y), gsum(x,y),
20481 bsum(x,y), alphasum(x,y)
20482 Sum of sample values in the rectangle from (0,0) to (x,y), this
20483 allows obtaining sums of samples within a rectangle. See the
20484 functions without the sum postfix.
20485
20486 interpolation
20487 Set one of interpolation methods:
20488
20489 nearest, n
20490 bilinear, b
20491
20492 Default is bilinear.
20493
20494 For functions, if x and y are outside the area, the value will be
20495 automatically clipped to the closer edge.
20496
20497 Please note that this filter can use multiple threads in which case
20498 each slice will have its own expression state. If you want to use only
20499 a single expression state because your expressions depend on previous
20500 state then you should limit the number of filter threads to 1.
20501
20502 Examples
20503
20504 • Flip the image horizontally:
20505
20506 geq=p(W-X\,Y)
20507
20508 • Generate a bidimensional sine wave, with angle "PI/3" and a
20509 wavelength of 100 pixels:
20510
20511 geq=128 + 100*sin(2*(PI/100)*(cos(PI/3)*(X-50*T) + sin(PI/3)*Y)):128:128
20512
20513 • Generate a fancy enigmatic moving light:
20514
20515 nullsrc=s=256x256,geq=random(1)/hypot(X-cos(N*0.07)*W/2-W/2\,Y-sin(N*0.09)*H/2-H/2)^2*1000000*sin(N*0.02):128:128
20516
20517 • Generate a quick emboss effect:
20518
20519 format=gray,geq=lum_expr='(p(X,Y)+(256-p(X-4,Y-4)))/2'
20520
20521 • Modify RGB components depending on pixel position:
20522
20523 geq=r='X/W*r(X,Y)':g='(1-X/W)*g(X,Y)':b='(H-Y)/H*b(X,Y)'
20524
20525 • Create a radial gradient that is the same size as the input (also
20526 see the vignette filter):
20527
20528 geq=lum=255*gauss((X/W-0.5)*3)*gauss((Y/H-0.5)*3)/gauss(0)/gauss(0),format=gray
20529
20530 gradfun
20531 Fix the banding artifacts that are sometimes introduced into nearly
20532 flat regions by truncation to 8-bit color depth. Interpolate the
20533 gradients that should go where the bands are, and dither them.
20534
20535 It is designed for playback only. Do not use it prior to lossy
20536 compression, because compression tends to lose the dither and bring
20537 back the bands.
20538
20539 It accepts the following parameters:
20540
20541 strength
20542 The maximum amount by which the filter will change any one pixel.
20543 This is also the threshold for detecting nearly flat regions.
20544 Acceptable values range from .51 to 64; the default value is 1.2.
20545 Out-of-range values will be clipped to the valid range.
20546
20547 radius
20548 The neighborhood to fit the gradient to. A larger radius makes for
20549 smoother gradients, but also prevents the filter from modifying the
20550 pixels near detailed regions. Acceptable values are 8-32; the
20551 default value is 16. Out-of-range values will be clipped to the
20552 valid range.
20553
20554 Alternatively, the options can be specified as a flat string:
20555 strength[:radius]
20556
20557 Examples
20558
20559 • Apply the filter with a 3.5 strength and radius of 8:
20560
20561 gradfun=3.5:8
20562
20563 • Specify radius, omitting the strength (which will fall-back to the
20564 default value):
20565
20566 gradfun=radius=8
20567
20568 graphmonitor
20569 Show various filtergraph stats.
20570
20571 With this filter one can debug complete filtergraph. Especially issues
20572 with links filling with queued frames.
20573
20574 The filter accepts the following options:
20575
20576 size, s
20577 Set video output size. Default is hd720.
20578
20579 opacity, o
20580 Set video opacity. Default is 0.9. Allowed range is from 0 to 1.
20581
20582 mode, m
20583 Set output mode, can be fulll or compact. In compact mode only
20584 filters with some queued frames have displayed stats.
20585
20586 flags, f
20587 Set flags which enable which stats are shown in video.
20588
20589 Available values for flags are:
20590
20591 queue
20592 Display number of queued frames in each link.
20593
20594 frame_count_in
20595 Display number of frames taken from filter.
20596
20597 frame_count_out
20598 Display number of frames given out from filter.
20599
20600 pts Display current filtered frame pts.
20601
20602 time
20603 Display current filtered frame time.
20604
20605 timebase
20606 Display time base for filter link.
20607
20608 format
20609 Display used format for filter link.
20610
20611 size
20612 Display video size or number of audio channels in case of audio
20613 used by filter link.
20614
20615 rate
20616 Display video frame rate or sample rate in case of audio used
20617 by filter link.
20618
20619 eof Display link output status.
20620
20621 sample_count_in
20622 Display number of samples taken from filter.
20623
20624 sample_count_out
20625 Display number of samples given out from filter.
20626
20627 rate, r
20628 Set upper limit for video rate of output stream, Default value is
20629 25. This guarantee that output video frame rate will not be higher
20630 than this value.
20631
20632 grayworld
20633 A color constancy filter that applies color correction based on the
20634 grayworld assumption
20635
20636 See:
20637 <https://www.researchgate.net/publication/275213614_A_New_Color_Correction_Method_for_Underwater_Imaging>
20638
20639 The algorithm uses linear light, so input data should be linearized
20640 beforehand (and possibly correctly tagged).
20641
20642 ffmpeg -i INPUT -vf zscale=transfer=linear,grayworld,zscale=transfer=bt709,format=yuv420p OUTPUT
20643
20644 greyedge
20645 A color constancy variation filter which estimates scene illumination
20646 via grey edge algorithm and corrects the scene colors accordingly.
20647
20648 See: <https://staff.science.uva.nl/th.gevers/pub/GeversTIP07.pdf>
20649
20650 The filter accepts the following options:
20651
20652 difford
20653 The order of differentiation to be applied on the scene. Must be
20654 chosen in the range [0,2] and default value is 1.
20655
20656 minknorm
20657 The Minkowski parameter to be used for calculating the Minkowski
20658 distance. Must be chosen in the range [0,20] and default value is
20659 1. Set to 0 for getting max value instead of calculating Minkowski
20660 distance.
20661
20662 sigma
20663 The standard deviation of Gaussian blur to be applied on the scene.
20664 Must be chosen in the range [0,1024.0] and default value = 1.
20665 floor( sigma * break_off_sigma(3) ) can't be equal to 0 if difford
20666 is greater than 0.
20667
20668 Examples
20669
20670 • Grey Edge:
20671
20672 greyedge=difford=1:minknorm=5:sigma=2
20673
20674 • Max Edge:
20675
20676 greyedge=difford=1:minknorm=0:sigma=2
20677
20678 guided
20679 Apply guided filter for edge-preserving smoothing, dehazing and so on.
20680
20681 The filter accepts the following options:
20682
20683 radius
20684 Set the box radius in pixels. Allowed range is 1 to 20. Default is
20685 3.
20686
20687 eps Set regularization parameter (with square). Allowed range is 0 to
20688 1. Default is 0.01.
20689
20690 mode
20691 Set filter mode. Can be "basic" or "fast". Default is "basic".
20692
20693 sub Set subsampling ratio for "fast" mode. Range is 2 to 64. Default
20694 is 4. No subsampling occurs in "basic" mode.
20695
20696 guidance
20697 Set guidance mode. Can be "off" or "on". Default is "off". If
20698 "off", single input is required. If "on", two inputs of the same
20699 resolution and pixel format are required. The second input serves
20700 as the guidance.
20701
20702 planes
20703 Set planes to filter. Default is first only.
20704
20705 Commands
20706
20707 This filter supports the all above options as commands.
20708
20709 Examples
20710
20711 • Edge-preserving smoothing with guided filter:
20712
20713 ffmpeg -i in.png -vf guided out.png
20714
20715 • Dehazing, structure-transferring filtering, detail enhancement with
20716 guided filter. For the generation of guidance image, refer to
20717 paper "Guided Image Filtering". See:
20718 <http://kaiminghe.com/publications/pami12guidedfilter.pdf>.
20719
20720 ffmpeg -i in.png -i guidance.png -filter_complex guided=guidance=on out.png
20721
20722 haldclut
20723 Apply a Hald CLUT to a video stream.
20724
20725 First input is the video stream to process, and second one is the Hald
20726 CLUT. The Hald CLUT input can be a simple picture or a complete video
20727 stream.
20728
20729 The filter accepts the following options:
20730
20731 shortest
20732 Force termination when the shortest input terminates. Default is 0.
20733
20734 repeatlast
20735 Continue applying the last CLUT after the end of the stream. A
20736 value of 0 disable the filter after the last frame of the CLUT is
20737 reached. Default is 1.
20738
20739 "haldclut" also has the same interpolation options as lut3d (both
20740 filters share the same internals).
20741
20742 This filter also supports the framesync options.
20743
20744 More information about the Hald CLUT can be found on Eskil Steenberg's
20745 website (Hald CLUT author) at
20746 <http://www.quelsolaar.com/technology/clut.html>.
20747
20748 Commands
20749
20750 This filter supports the "interp" option as commands.
20751
20752 Workflow examples
20753
20754 Hald CLUT video stream
20755
20756 Generate an identity Hald CLUT stream altered with various effects:
20757
20758 ffmpeg -f lavfi -i B<haldclutsrc>=8 -vf "hue=H=2*PI*t:s=sin(2*PI*t)+1, curves=cross_process" -t 10 -c:v ffv1 clut.nut
20759
20760 Note: make sure you use a lossless codec.
20761
20762 Then use it with "haldclut" to apply it on some random stream:
20763
20764 ffmpeg -f lavfi -i mandelbrot -i clut.nut -filter_complex '[0][1] haldclut' -t 20 mandelclut.mkv
20765
20766 The Hald CLUT will be applied to the 10 first seconds (duration of
20767 clut.nut), then the latest picture of that CLUT stream will be applied
20768 to the remaining frames of the "mandelbrot" stream.
20769
20770 Hald CLUT with preview
20771
20772 A Hald CLUT is supposed to be a squared image of "Level*Level*Level" by
20773 "Level*Level*Level" pixels. For a given Hald CLUT, FFmpeg will select
20774 the biggest possible square starting at the top left of the picture.
20775 The remaining padding pixels (bottom or right) will be ignored. This
20776 area can be used to add a preview of the Hald CLUT.
20777
20778 Typically, the following generated Hald CLUT will be supported by the
20779 "haldclut" filter:
20780
20781 ffmpeg -f lavfi -i B<haldclutsrc>=8 -vf "
20782 pad=iw+320 [padded_clut];
20783 smptebars=s=320x256, split [a][b];
20784 [padded_clut][a] overlay=W-320:h, curves=color_negative [main];
20785 [main][b] overlay=W-320" -frames:v 1 clut.png
20786
20787 It contains the original and a preview of the effect of the CLUT: SMPTE
20788 color bars are displayed on the right-top, and below the same color
20789 bars processed by the color changes.
20790
20791 Then, the effect of this Hald CLUT can be visualized with:
20792
20793 ffplay input.mkv -vf "movie=clut.png, [in] haldclut"
20794
20795 hflip
20796 Flip the input video horizontally.
20797
20798 For example, to horizontally flip the input video with ffmpeg:
20799
20800 ffmpeg -i in.avi -vf "hflip" out.avi
20801
20802 histeq
20803 This filter applies a global color histogram equalization on a per-
20804 frame basis.
20805
20806 It can be used to correct video that has a compressed range of pixel
20807 intensities. The filter redistributes the pixel intensities to
20808 equalize their distribution across the intensity range. It may be
20809 viewed as an "automatically adjusting contrast filter". This filter is
20810 useful only for correcting degraded or poorly captured source video.
20811
20812 The filter accepts the following options:
20813
20814 strength
20815 Determine the amount of equalization to be applied. As the
20816 strength is reduced, the distribution of pixel intensities more-
20817 and-more approaches that of the input frame. The value must be a
20818 float number in the range [0,1] and defaults to 0.200.
20819
20820 intensity
20821 Set the maximum intensity that can generated and scale the output
20822 values appropriately. The strength should be set as desired and
20823 then the intensity can be limited if needed to avoid washing-out.
20824 The value must be a float number in the range [0,1] and defaults to
20825 0.210.
20826
20827 antibanding
20828 Set the antibanding level. If enabled the filter will randomly vary
20829 the luminance of output pixels by a small amount to avoid banding
20830 of the histogram. Possible values are "none", "weak" or "strong".
20831 It defaults to "none".
20832
20833 histogram
20834 Compute and draw a color distribution histogram for the input video.
20835
20836 The computed histogram is a representation of the color component
20837 distribution in an image.
20838
20839 Standard histogram displays the color components distribution in an
20840 image. Displays color graph for each color component. Shows
20841 distribution of the Y, U, V, A or R, G, B components, depending on
20842 input format, in the current frame. Below each graph a color component
20843 scale meter is shown.
20844
20845 The filter accepts the following options:
20846
20847 level_height
20848 Set height of level. Default value is 200. Allowed range is [50,
20849 2048].
20850
20851 scale_height
20852 Set height of color scale. Default value is 12. Allowed range is
20853 [0, 40].
20854
20855 display_mode
20856 Set display mode. It accepts the following values:
20857
20858 stack
20859 Per color component graphs are placed below each other.
20860
20861 parade
20862 Per color component graphs are placed side by side.
20863
20864 overlay
20865 Presents information identical to that in the "parade", except
20866 that the graphs representing color components are superimposed
20867 directly over one another.
20868
20869 Default is "stack".
20870
20871 levels_mode
20872 Set mode. Can be either "linear", or "logarithmic". Default is
20873 "linear".
20874
20875 components
20876 Set what color components to display. Default is 7.
20877
20878 fgopacity
20879 Set foreground opacity. Default is 0.7.
20880
20881 bgopacity
20882 Set background opacity. Default is 0.5.
20883
20884 colors_mode
20885 Set colors mode. It accepts the following values:
20886
20887 whiteonblack
20888 blackonwhite
20889 whiteongray
20890 blackongray
20891 coloronblack
20892 coloronwhite
20893 colorongray
20894 blackoncolor
20895 whiteoncolor
20896 grayoncolor
20897
20898 Default is "whiteonblack".
20899
20900 Examples
20901
20902 • Calculate and draw histogram:
20903
20904 ffplay -i input -vf histogram
20905
20906 hqdn3d
20907 This is a high precision/quality 3d denoise filter. It aims to reduce
20908 image noise, producing smooth images and making still images really
20909 still. It should enhance compressibility.
20910
20911 It accepts the following optional parameters:
20912
20913 luma_spatial
20914 A non-negative floating point number which specifies spatial luma
20915 strength. It defaults to 4.0.
20916
20917 chroma_spatial
20918 A non-negative floating point number which specifies spatial chroma
20919 strength. It defaults to 3.0*luma_spatial/4.0.
20920
20921 luma_tmp
20922 A floating point number which specifies luma temporal strength. It
20923 defaults to 6.0*luma_spatial/4.0.
20924
20925 chroma_tmp
20926 A floating point number which specifies chroma temporal strength.
20927 It defaults to luma_tmp*chroma_spatial/luma_spatial.
20928
20929 Commands
20930
20931 This filter supports same commands as options. The command accepts the
20932 same syntax of the corresponding option.
20933
20934 If the specified expression is not valid, it is kept at its current
20935 value.
20936
20937 hwdownload
20938 Download hardware frames to system memory.
20939
20940 The input must be in hardware frames, and the output a non-hardware
20941 format. Not all formats will be supported on the output - it may be
20942 necessary to insert an additional format filter immediately following
20943 in the graph to get the output in a supported format.
20944
20945 hwmap
20946 Map hardware frames to system memory or to another device.
20947
20948 This filter has several different modes of operation; which one is used
20949 depends on the input and output formats:
20950
20951 • Hardware frame input, normal frame output
20952
20953 Map the input frames to system memory and pass them to the output.
20954 If the original hardware frame is later required (for example,
20955 after overlaying something else on part of it), the hwmap filter
20956 can be used again in the next mode to retrieve it.
20957
20958 • Normal frame input, hardware frame output
20959
20960 If the input is actually a software-mapped hardware frame, then
20961 unmap it - that is, return the original hardware frame.
20962
20963 Otherwise, a device must be provided. Create new hardware surfaces
20964 on that device for the output, then map them back to the software
20965 format at the input and give those frames to the preceding filter.
20966 This will then act like the hwupload filter, but may be able to
20967 avoid an additional copy when the input is already in a compatible
20968 format.
20969
20970 • Hardware frame input and output
20971
20972 A device must be supplied for the output, either directly or with
20973 the derive_device option. The input and output devices must be of
20974 different types and compatible - the exact meaning of this is
20975 system-dependent, but typically it means that they must refer to
20976 the same underlying hardware context (for example, refer to the
20977 same graphics card).
20978
20979 If the input frames were originally created on the output device,
20980 then unmap to retrieve the original frames.
20981
20982 Otherwise, map the frames to the output device - create new
20983 hardware frames on the output corresponding to the frames on the
20984 input.
20985
20986 The following additional parameters are accepted:
20987
20988 mode
20989 Set the frame mapping mode. Some combination of:
20990
20991 read
20992 The mapped frame should be readable.
20993
20994 write
20995 The mapped frame should be writeable.
20996
20997 overwrite
20998 The mapping will always overwrite the entire frame.
20999
21000 This may improve performance in some cases, as the original
21001 contents of the frame need not be loaded.
21002
21003 direct
21004 The mapping must not involve any copying.
21005
21006 Indirect mappings to copies of frames are created in some cases
21007 where either direct mapping is not possible or it would have
21008 unexpected properties. Setting this flag ensures that the
21009 mapping is direct and will fail if that is not possible.
21010
21011 Defaults to read+write if not specified.
21012
21013 derive_device type
21014 Rather than using the device supplied at initialisation, instead
21015 derive a new device of type type from the device the input frames
21016 exist on.
21017
21018 reverse
21019 In a hardware to hardware mapping, map in reverse - create frames
21020 in the sink and map them back to the source. This may be necessary
21021 in some cases where a mapping in one direction is required but only
21022 the opposite direction is supported by the devices being used.
21023
21024 This option is dangerous - it may break the preceding filter in
21025 undefined ways if there are any additional constraints on that
21026 filter's output. Do not use it without fully understanding the
21027 implications of its use.
21028
21029 hwupload
21030 Upload system memory frames to hardware surfaces.
21031
21032 The device to upload to must be supplied when the filter is
21033 initialised. If using ffmpeg, select the appropriate device with the
21034 -filter_hw_device option or with the derive_device option. The input
21035 and output devices must be of different types and compatible - the
21036 exact meaning of this is system-dependent, but typically it means that
21037 they must refer to the same underlying hardware context (for example,
21038 refer to the same graphics card).
21039
21040 The following additional parameters are accepted:
21041
21042 derive_device type
21043 Rather than using the device supplied at initialisation, instead
21044 derive a new device of type type from the device the input frames
21045 exist on.
21046
21047 hwupload_cuda
21048 Upload system memory frames to a CUDA device.
21049
21050 It accepts the following optional parameters:
21051
21052 device
21053 The number of the CUDA device to use
21054
21055 hqx
21056 Apply a high-quality magnification filter designed for pixel art. This
21057 filter was originally created by Maxim Stepin.
21058
21059 It accepts the following option:
21060
21061 n Set the scaling dimension: 2 for "hq2x", 3 for "hq3x" and 4 for
21062 "hq4x". Default is 3.
21063
21064 hstack
21065 Stack input videos horizontally.
21066
21067 All streams must be of same pixel format and of same height.
21068
21069 Note that this filter is faster than using overlay and pad filter to
21070 create same output.
21071
21072 The filter accepts the following option:
21073
21074 inputs
21075 Set number of input streams. Default is 2.
21076
21077 shortest
21078 If set to 1, force the output to terminate when the shortest input
21079 terminates. Default value is 0.
21080
21081 hsvhold
21082 Turns a certain HSV range into gray values.
21083
21084 This filter measures color difference between set HSV color in options
21085 and ones measured in video stream. Depending on options, output colors
21086 can be changed to be gray or not.
21087
21088 The filter accepts the following options:
21089
21090 hue Set the hue value which will be used in color difference
21091 calculation. Allowed range is from -360 to 360. Default value is
21092 0.
21093
21094 sat Set the saturation value which will be used in color difference
21095 calculation. Allowed range is from -1 to 1. Default value is 0.
21096
21097 val Set the value which will be used in color difference calculation.
21098 Allowed range is from -1 to 1. Default value is 0.
21099
21100 similarity
21101 Set similarity percentage with the key color. Allowed range is
21102 from 0 to 1. Default value is 0.01.
21103
21104 0.00001 matches only the exact key color, while 1.0 matches
21105 everything.
21106
21107 blend
21108 Blend percentage. Allowed range is from 0 to 1. Default value is
21109 0.
21110
21111 0.0 makes pixels either fully gray, or not gray at all.
21112
21113 Higher values result in more gray pixels, with a higher gray pixel
21114 the more similar the pixels color is to the key color.
21115
21116 hsvkey
21117 Turns a certain HSV range into transparency.
21118
21119 This filter measures color difference between set HSV color in options
21120 and ones measured in video stream. Depending on options, output colors
21121 can be changed to transparent by adding alpha channel.
21122
21123 The filter accepts the following options:
21124
21125 hue Set the hue value which will be used in color difference
21126 calculation. Allowed range is from -360 to 360. Default value is
21127 0.
21128
21129 sat Set the saturation value which will be used in color difference
21130 calculation. Allowed range is from -1 to 1. Default value is 0.
21131
21132 val Set the value which will be used in color difference calculation.
21133 Allowed range is from -1 to 1. Default value is 0.
21134
21135 similarity
21136 Set similarity percentage with the key color. Allowed range is
21137 from 0 to 1. Default value is 0.01.
21138
21139 0.00001 matches only the exact key color, while 1.0 matches
21140 everything.
21141
21142 blend
21143 Blend percentage. Allowed range is from 0 to 1. Default value is
21144 0.
21145
21146 0.0 makes pixels either fully transparent, or not transparent at
21147 all.
21148
21149 Higher values result in semi-transparent pixels, with a higher
21150 transparency the more similar the pixels color is to the key color.
21151
21152 hue
21153 Modify the hue and/or the saturation of the input.
21154
21155 It accepts the following parameters:
21156
21157 h Specify the hue angle as a number of degrees. It accepts an
21158 expression, and defaults to "0".
21159
21160 s Specify the saturation in the [-10,10] range. It accepts an
21161 expression and defaults to "1".
21162
21163 H Specify the hue angle as a number of radians. It accepts an
21164 expression, and defaults to "0".
21165
21166 b Specify the brightness in the [-10,10] range. It accepts an
21167 expression and defaults to "0".
21168
21169 h and H are mutually exclusive, and can't be specified at the same
21170 time.
21171
21172 The b, h, H and s option values are expressions containing the
21173 following constants:
21174
21175 n frame count of the input frame starting from 0
21176
21177 pts presentation timestamp of the input frame expressed in time base
21178 units
21179
21180 r frame rate of the input video, NAN if the input frame rate is
21181 unknown
21182
21183 t timestamp expressed in seconds, NAN if the input timestamp is
21184 unknown
21185
21186 tb time base of the input video
21187
21188 Examples
21189
21190 • Set the hue to 90 degrees and the saturation to 1.0:
21191
21192 hue=h=90:s=1
21193
21194 • Same command but expressing the hue in radians:
21195
21196 hue=H=PI/2:s=1
21197
21198 • Rotate hue and make the saturation swing between 0 and 2 over a
21199 period of 1 second:
21200
21201 hue="H=2*PI*t: s=sin(2*PI*t)+1"
21202
21203 • Apply a 3 seconds saturation fade-in effect starting at 0:
21204
21205 hue="s=min(t/3\,1)"
21206
21207 The general fade-in expression can be written as:
21208
21209 hue="s=min(0\, max((t-START)/DURATION\, 1))"
21210
21211 • Apply a 3 seconds saturation fade-out effect starting at 5 seconds:
21212
21213 hue="s=max(0\, min(1\, (8-t)/3))"
21214
21215 The general fade-out expression can be written as:
21216
21217 hue="s=max(0\, min(1\, (START+DURATION-t)/DURATION))"
21218
21219 Commands
21220
21221 This filter supports the following commands:
21222
21223 b
21224 s
21225 h
21226 H Modify the hue and/or the saturation and/or brightness of the input
21227 video. The command accepts the same syntax of the corresponding
21228 option.
21229
21230 If the specified expression is not valid, it is kept at its current
21231 value.
21232
21233 huesaturation
21234 Apply hue-saturation-intensity adjustments to input video stream.
21235
21236 This filter operates in RGB colorspace.
21237
21238 This filter accepts the following options:
21239
21240 hue Set the hue shift in degrees to apply. Default is 0. Allowed range
21241 is from -180 to 180.
21242
21243 saturation
21244 Set the saturation shift. Default is 0. Allowed range is from -1
21245 to 1.
21246
21247 intensity
21248 Set the intensity shift. Default is 0. Allowed range is from -1 to
21249 1.
21250
21251 colors
21252 Set which primary and complementary colors are going to be
21253 adjusted. This options is set by providing one or multiple values.
21254 This can select multiple colors at once. By default all colors are
21255 selected.
21256
21257 r Adjust reds.
21258
21259 y Adjust yellows.
21260
21261 g Adjust greens.
21262
21263 c Adjust cyans.
21264
21265 b Adjust blues.
21266
21267 m Adjust magentas.
21268
21269 a Adjust all colors.
21270
21271 strength
21272 Set strength of filtering. Allowed range is from 0 to 100. Default
21273 value is 1.
21274
21275 rw, gw, bw
21276 Set weight for each RGB component. Allowed range is from 0 to 1.
21277 By default is set to 0.333, 0.334, 0.333. Those options are used
21278 in saturation and lightess processing.
21279
21280 lightness
21281 Set preserving lightness, by default is disabled. Adjusting hues
21282 can change lightness from original RGB triplet, with this option
21283 enabled lightness is kept at same value.
21284
21285 hysteresis
21286 Grow first stream into second stream by connecting components. This
21287 makes it possible to build more robust edge masks.
21288
21289 This filter accepts the following options:
21290
21291 planes
21292 Set which planes will be processed as bitmap, unprocessed planes
21293 will be copied from first stream. By default value 0xf, all planes
21294 will be processed.
21295
21296 threshold
21297 Set threshold which is used in filtering. If pixel component value
21298 is higher than this value filter algorithm for connecting
21299 components is activated. By default value is 0.
21300
21301 The "hysteresis" filter also supports the framesync options.
21302
21303 identity
21304 Obtain the identity score between two input videos.
21305
21306 This filter takes two input videos.
21307
21308 Both input videos must have the same resolution and pixel format for
21309 this filter to work correctly. Also it assumes that both inputs have
21310 the same number of frames, which are compared one by one.
21311
21312 The obtained per component, average, min and max identity score is
21313 printed through the logging system.
21314
21315 The filter stores the calculated identity scores of each frame in frame
21316 metadata.
21317
21318 In the below example the input file main.mpg being processed is
21319 compared with the reference file ref.mpg.
21320
21321 ffmpeg -i main.mpg -i ref.mpg -lavfi identity -f null -
21322
21323 idet
21324 Detect video interlacing type.
21325
21326 This filter tries to detect if the input frames are interlaced,
21327 progressive, top or bottom field first. It will also try to detect
21328 fields that are repeated between adjacent frames (a sign of telecine).
21329
21330 Single frame detection considers only immediately adjacent frames when
21331 classifying each frame. Multiple frame detection incorporates the
21332 classification history of previous frames.
21333
21334 The filter will log these metadata values:
21335
21336 single.current_frame
21337 Detected type of current frame using single-frame detection. One
21338 of: ``tff'' (top field first), ``bff'' (bottom field first),
21339 ``progressive'', or ``undetermined''
21340
21341 single.tff
21342 Cumulative number of frames detected as top field first using
21343 single-frame detection.
21344
21345 multiple.tff
21346 Cumulative number of frames detected as top field first using
21347 multiple-frame detection.
21348
21349 single.bff
21350 Cumulative number of frames detected as bottom field first using
21351 single-frame detection.
21352
21353 multiple.current_frame
21354 Detected type of current frame using multiple-frame detection. One
21355 of: ``tff'' (top field first), ``bff'' (bottom field first),
21356 ``progressive'', or ``undetermined''
21357
21358 multiple.bff
21359 Cumulative number of frames detected as bottom field first using
21360 multiple-frame detection.
21361
21362 single.progressive
21363 Cumulative number of frames detected as progressive using single-
21364 frame detection.
21365
21366 multiple.progressive
21367 Cumulative number of frames detected as progressive using multiple-
21368 frame detection.
21369
21370 single.undetermined
21371 Cumulative number of frames that could not be classified using
21372 single-frame detection.
21373
21374 multiple.undetermined
21375 Cumulative number of frames that could not be classified using
21376 multiple-frame detection.
21377
21378 repeated.current_frame
21379 Which field in the current frame is repeated from the last. One of
21380 ``neither'', ``top'', or ``bottom''.
21381
21382 repeated.neither
21383 Cumulative number of frames with no repeated field.
21384
21385 repeated.top
21386 Cumulative number of frames with the top field repeated from the
21387 previous frame's top field.
21388
21389 repeated.bottom
21390 Cumulative number of frames with the bottom field repeated from the
21391 previous frame's bottom field.
21392
21393 The filter accepts the following options:
21394
21395 intl_thres
21396 Set interlacing threshold.
21397
21398 prog_thres
21399 Set progressive threshold.
21400
21401 rep_thres
21402 Threshold for repeated field detection.
21403
21404 half_life
21405 Number of frames after which a given frame's contribution to the
21406 statistics is halved (i.e., it contributes only 0.5 to its
21407 classification). The default of 0 means that all frames seen are
21408 given full weight of 1.0 forever.
21409
21410 analyze_interlaced_flag
21411 When this is not 0 then idet will use the specified number of
21412 frames to determine if the interlaced flag is accurate, it will not
21413 count undetermined frames. If the flag is found to be accurate it
21414 will be used without any further computations, if it is found to be
21415 inaccurate it will be cleared without any further computations.
21416 This allows inserting the idet filter as a low computational method
21417 to clean up the interlaced flag
21418
21419 il
21420 Deinterleave or interleave fields.
21421
21422 This filter allows one to process interlaced images fields without
21423 deinterlacing them. Deinterleaving splits the input frame into 2 fields
21424 (so called half pictures). Odd lines are moved to the top half of the
21425 output image, even lines to the bottom half. You can process (filter)
21426 them independently and then re-interleave them.
21427
21428 The filter accepts the following options:
21429
21430 luma_mode, l
21431 chroma_mode, c
21432 alpha_mode, a
21433 Available values for luma_mode, chroma_mode and alpha_mode are:
21434
21435 none
21436 Do nothing.
21437
21438 deinterleave, d
21439 Deinterleave fields, placing one above the other.
21440
21441 interleave, i
21442 Interleave fields. Reverse the effect of deinterleaving.
21443
21444 Default value is "none".
21445
21446 luma_swap, ls
21447 chroma_swap, cs
21448 alpha_swap, as
21449 Swap luma/chroma/alpha fields. Exchange even & odd lines. Default
21450 value is 0.
21451
21452 Commands
21453
21454 This filter supports the all above options as commands.
21455
21456 inflate
21457 Apply inflate effect to the video.
21458
21459 This filter replaces the pixel by the local(3x3) average by taking into
21460 account only values higher than the pixel.
21461
21462 It accepts the following options:
21463
21464 threshold0
21465 threshold1
21466 threshold2
21467 threshold3
21468 Limit the maximum change for each plane, default is 65535. If 0,
21469 plane will remain unchanged.
21470
21471 Commands
21472
21473 This filter supports the all above options as commands.
21474
21475 interlace
21476 Simple interlacing filter from progressive contents. This interleaves
21477 upper (or lower) lines from odd frames with lower (or upper) lines from
21478 even frames, halving the frame rate and preserving image height.
21479
21480 Original Original New Frame
21481 Frame 'j' Frame 'j+1' (tff)
21482 ========== =========== ==================
21483 Line 0 --------------------> Frame 'j' Line 0
21484 Line 1 Line 1 ----> Frame 'j+1' Line 1
21485 Line 2 ---------------------> Frame 'j' Line 2
21486 Line 3 Line 3 ----> Frame 'j+1' Line 3
21487 ... ... ...
21488 New Frame + 1 will be generated by Frame 'j+2' and Frame 'j+3' and so on
21489
21490 It accepts the following optional parameters:
21491
21492 scan
21493 This determines whether the interlaced frame is taken from the even
21494 (tff - default) or odd (bff) lines of the progressive frame.
21495
21496 lowpass
21497 Vertical lowpass filter to avoid twitter interlacing and reduce
21498 moire patterns.
21499
21500 0, off
21501 Disable vertical lowpass filter
21502
21503 1, linear
21504 Enable linear filter (default)
21505
21506 2, complex
21507 Enable complex filter. This will slightly less reduce twitter
21508 and moire but better retain detail and subjective sharpness
21509 impression.
21510
21511 kerndeint
21512 Deinterlace input video by applying Donald Graft's adaptive kernel
21513 deinterling. Work on interlaced parts of a video to produce progressive
21514 frames.
21515
21516 The description of the accepted parameters follows.
21517
21518 thresh
21519 Set the threshold which affects the filter's tolerance when
21520 determining if a pixel line must be processed. It must be an
21521 integer in the range [0,255] and defaults to 10. A value of 0 will
21522 result in applying the process on every pixels.
21523
21524 map Paint pixels exceeding the threshold value to white if set to 1.
21525 Default is 0.
21526
21527 order
21528 Set the fields order. Swap fields if set to 1, leave fields alone
21529 if 0. Default is 0.
21530
21531 sharp
21532 Enable additional sharpening if set to 1. Default is 0.
21533
21534 twoway
21535 Enable twoway sharpening if set to 1. Default is 0.
21536
21537 Examples
21538
21539 • Apply default values:
21540
21541 kerndeint=thresh=10:map=0:order=0:sharp=0:twoway=0
21542
21543 • Enable additional sharpening:
21544
21545 kerndeint=sharp=1
21546
21547 • Paint processed pixels in white:
21548
21549 kerndeint=map=1
21550
21551 kirsch
21552 Apply kirsch operator to input video stream.
21553
21554 The filter accepts the following option:
21555
21556 planes
21557 Set which planes will be processed, unprocessed planes will be
21558 copied. By default value 0xf, all planes will be processed.
21559
21560 scale
21561 Set value which will be multiplied with filtered result.
21562
21563 delta
21564 Set value which will be added to filtered result.
21565
21566 Commands
21567
21568 This filter supports the all above options as commands.
21569
21570 lagfun
21571 Slowly update darker pixels.
21572
21573 This filter makes short flashes of light appear longer. This filter
21574 accepts the following options:
21575
21576 decay
21577 Set factor for decaying. Default is .95. Allowed range is from 0 to
21578 1.
21579
21580 planes
21581 Set which planes to filter. Default is all. Allowed range is from 0
21582 to 15.
21583
21584 Commands
21585
21586 This filter supports the all above options as commands.
21587
21588 lenscorrection
21589 Correct radial lens distortion
21590
21591 This filter can be used to correct for radial distortion as can result
21592 from the use of wide angle lenses, and thereby re-rectify the image. To
21593 find the right parameters one can use tools available for example as
21594 part of opencv or simply trial-and-error. To use opencv use the
21595 calibration sample (under samples/cpp) from the opencv sources and
21596 extract the k1 and k2 coefficients from the resulting matrix.
21597
21598 Note that effectively the same filter is available in the open-source
21599 tools Krita and Digikam from the KDE project.
21600
21601 In contrast to the vignette filter, which can also be used to
21602 compensate lens errors, this filter corrects the distortion of the
21603 image, whereas vignette corrects the brightness distribution, so you
21604 may want to use both filters together in certain cases, though you will
21605 have to take care of ordering, i.e. whether vignetting should be
21606 applied before or after lens correction.
21607
21608 Options
21609
21610 The filter accepts the following options:
21611
21612 cx Relative x-coordinate of the focal point of the image, and thereby
21613 the center of the distortion. This value has a range [0,1] and is
21614 expressed as fractions of the image width. Default is 0.5.
21615
21616 cy Relative y-coordinate of the focal point of the image, and thereby
21617 the center of the distortion. This value has a range [0,1] and is
21618 expressed as fractions of the image height. Default is 0.5.
21619
21620 k1 Coefficient of the quadratic correction term. This value has a
21621 range [-1,1]. 0 means no correction. Default is 0.
21622
21623 k2 Coefficient of the double quadratic correction term. This value has
21624 a range [-1,1]. 0 means no correction. Default is 0.
21625
21626 i Set interpolation type. Can be "nearest" or "bilinear". Default is
21627 "nearest".
21628
21629 fc Specify the color of the unmapped pixels. For the syntax of this
21630 option, check the "Color" section in the ffmpeg-utils manual.
21631 Default color is "black@0".
21632
21633 The formula that generates the correction is:
21634
21635 r_src = r_tgt * (1 + k1 * (r_tgt / r_0)^2 + k2 * (r_tgt / r_0)^4)
21636
21637 where r_0 is halve of the image diagonal and r_src and r_tgt are the
21638 distances from the focal point in the source and target images,
21639 respectively.
21640
21641 Commands
21642
21643 This filter supports the all above options as commands.
21644
21645 lensfun
21646 Apply lens correction via the lensfun library
21647 (<http://lensfun.sourceforge.net/>).
21648
21649 The "lensfun" filter requires the camera make, camera model, and lens
21650 model to apply the lens correction. The filter will load the lensfun
21651 database and query it to find the corresponding camera and lens entries
21652 in the database. As long as these entries can be found with the given
21653 options, the filter can perform corrections on frames. Note that
21654 incomplete strings will result in the filter choosing the best match
21655 with the given options, and the filter will output the chosen camera
21656 and lens models (logged with level "info"). You must provide the make,
21657 camera model, and lens model as they are required.
21658
21659 The filter accepts the following options:
21660
21661 make
21662 The make of the camera (for example, "Canon"). This option is
21663 required.
21664
21665 model
21666 The model of the camera (for example, "Canon EOS 100D"). This
21667 option is required.
21668
21669 lens_model
21670 The model of the lens (for example, "Canon EF-S 18-55mm f/3.5-5.6
21671 IS STM"). This option is required.
21672
21673 mode
21674 The type of correction to apply. The following values are valid
21675 options:
21676
21677 vignetting
21678 Enables fixing lens vignetting.
21679
21680 geometry
21681 Enables fixing lens geometry. This is the default.
21682
21683 subpixel
21684 Enables fixing chromatic aberrations.
21685
21686 vig_geo
21687 Enables fixing lens vignetting and lens geometry.
21688
21689 vig_subpixel
21690 Enables fixing lens vignetting and chromatic aberrations.
21691
21692 distortion
21693 Enables fixing both lens geometry and chromatic aberrations.
21694
21695 all Enables all possible corrections.
21696
21697 focal_length
21698 The focal length of the image/video (zoom; expected constant for
21699 video). For example, a 18--55mm lens has focal length range of
21700 [18--55], so a value in that range should be chosen when using that
21701 lens. Default 18.
21702
21703 aperture
21704 The aperture of the image/video (expected constant for video). Note
21705 that aperture is only used for vignetting correction. Default 3.5.
21706
21707 focus_distance
21708 The focus distance of the image/video (expected constant for
21709 video). Note that focus distance is only used for vignetting and
21710 only slightly affects the vignetting correction process. If
21711 unknown, leave it at the default value (which is 1000).
21712
21713 scale
21714 The scale factor which is applied after transformation. After
21715 correction the video is no longer necessarily rectangular. This
21716 parameter controls how much of the resulting image is visible. The
21717 value 0 means that a value will be chosen automatically such that
21718 there is little or no unmapped area in the output image. 1.0 means
21719 that no additional scaling is done. Lower values may result in more
21720 of the corrected image being visible, while higher values may avoid
21721 unmapped areas in the output.
21722
21723 target_geometry
21724 The target geometry of the output image/video. The following values
21725 are valid options:
21726
21727 rectilinear (default)
21728 fisheye
21729 panoramic
21730 equirectangular
21731 fisheye_orthographic
21732 fisheye_stereographic
21733 fisheye_equisolid
21734 fisheye_thoby
21735 reverse
21736 Apply the reverse of image correction (instead of correcting
21737 distortion, apply it).
21738
21739 interpolation
21740 The type of interpolation used when correcting distortion. The
21741 following values are valid options:
21742
21743 nearest
21744 linear (default)
21745 lanczos
21746
21747 Examples
21748
21749 • Apply lens correction with make "Canon", camera model "Canon EOS
21750 100D", and lens model "Canon EF-S 18-55mm f/3.5-5.6 IS STM" with
21751 focal length of "18" and aperture of "8.0".
21752
21753 ffmpeg -i input.mov -vf lensfun=make=Canon:model="Canon EOS 100D":lens_model="Canon EF-S 18-55mm f/3.5-5.6 IS STM":focal_length=18:aperture=8 -c:v h264 -b:v 8000k output.mov
21754
21755 • Apply the same as before, but only for the first 5 seconds of
21756 video.
21757
21758 ffmpeg -i input.mov -vf lensfun=make=Canon:model="Canon EOS 100D":lens_model="Canon EF-S 18-55mm f/3.5-5.6 IS STM":focal_length=18:aperture=8:enable='lte(t\,5)' -c:v h264 -b:v 8000k output.mov
21759
21760 libvmaf
21761 Obtain the VMAF (Video Multi-Method Assessment Fusion) score between
21762 two input videos.
21763
21764 The first input is the encoded video, and the second input is the
21765 reference video.
21766
21767 The obtained VMAF score is printed through the logging system.
21768
21769 It requires Netflix's vmaf library (libvmaf) as a pre-requisite. After
21770 installing the library it can be enabled using: "./configure
21771 --enable-libvmaf". If no model path is specified it uses the default
21772 model: "vmaf_v0.6.1.pkl".
21773
21774 The filter has following options:
21775
21776 model_path
21777 Set the model path which is to be used for SVM. Default value:
21778 "/usr/local/share/model/vmaf_v0.6.1.pkl"
21779
21780 log_path
21781 Set the file path to be used to store logs.
21782
21783 log_fmt
21784 Set the format of the log file (csv, json or xml).
21785
21786 enable_transform
21787 This option can enable/disable the "score_transform" applied to the
21788 final predicted VMAF score, if you have specified score_transform
21789 option in the input parameter file passed to "run_vmaf_training.py"
21790 Default value: "false"
21791
21792 phone_model
21793 Invokes the phone model which will generate VMAF scores higher than
21794 in the regular model, which is more suitable for laptop, TV, etc.
21795 viewing conditions. Default value: "false"
21796
21797 psnr
21798 Enables computing psnr along with vmaf. Default value: "false"
21799
21800 ssim
21801 Enables computing ssim along with vmaf. Default value: "false"
21802
21803 ms_ssim
21804 Enables computing ms_ssim along with vmaf. Default value: "false"
21805
21806 pool
21807 Set the pool method to be used for computing vmaf. Options are
21808 "min", "harmonic_mean" or "mean" (default).
21809
21810 n_threads
21811 Set number of threads to be used when computing vmaf. Default
21812 value: 0, which makes use of all available logical processors.
21813
21814 n_subsample
21815 Set interval for frame subsampling used when computing vmaf.
21816 Default value: 1
21817
21818 enable_conf_interval
21819 Enables confidence interval. Default value: "false"
21820
21821 This filter also supports the framesync options.
21822
21823 Examples
21824
21825 • On the below examples the input file main.mpg being processed is
21826 compared with the reference file ref.mpg.
21827
21828 ffmpeg -i main.mpg -i ref.mpg -lavfi libvmaf -f null -
21829
21830 • Example with options:
21831
21832 ffmpeg -i main.mpg -i ref.mpg -lavfi libvmaf="psnr=1:log_fmt=json" -f null -
21833
21834 • Example with options and different containers:
21835
21836 ffmpeg -i main.mpg -i ref.mkv -lavfi "[0:v]settb=AVTB,setpts=PTS-STARTPTS[main];[1:v]settb=AVTB,setpts=PTS-STARTPTS[ref];[main][ref]libvmaf=psnr=1:log_fmt=json" -f null -
21837
21838 limitdiff
21839 Apply limited difference filter using second and optionally third video
21840 stream.
21841
21842 The filter accepts the following options:
21843
21844 threshold
21845 Set the threshold to use when allowing certain differences between
21846 video streams. Any absolute difference value lower or exact than
21847 this threshold will pick pixel components from first video stream.
21848
21849 elasticity
21850 Set the elasticity of soft thresholding when processing video
21851 streams. This value multiplied with first one sets second
21852 threshold. Any absolute difference value greater or exact than
21853 second threshold will pick pixel components from second video
21854 stream. For values between those two threshold linear interpolation
21855 between first and second video stream will be used.
21856
21857 reference
21858 Enable the reference (third) video stream processing. By default is
21859 disabled. If set, this video stream will be used for calculating
21860 absolute difference with first video stream.
21861
21862 planes
21863 Specify which planes will be processed. Defaults to all available.
21864
21865 Commands
21866
21867 This filter supports the all above options as commands except option
21868 reference.
21869
21870 limiter
21871 Limits the pixel components values to the specified range [min, max].
21872
21873 The filter accepts the following options:
21874
21875 min Lower bound. Defaults to the lowest allowed value for the input.
21876
21877 max Upper bound. Defaults to the highest allowed value for the input.
21878
21879 planes
21880 Specify which planes will be processed. Defaults to all available.
21881
21882 Commands
21883
21884 This filter supports the all above options as commands.
21885
21886 loop
21887 Loop video frames.
21888
21889 The filter accepts the following options:
21890
21891 loop
21892 Set the number of loops. Setting this value to -1 will result in
21893 infinite loops. Default is 0.
21894
21895 size
21896 Set maximal size in number of frames. Default is 0.
21897
21898 start
21899 Set first frame of loop. Default is 0.
21900
21901 Examples
21902
21903 • Loop single first frame infinitely:
21904
21905 loop=loop=-1:size=1:start=0
21906
21907 • Loop single first frame 10 times:
21908
21909 loop=loop=10:size=1:start=0
21910
21911 • Loop 10 first frames 5 times:
21912
21913 loop=loop=5:size=10:start=0
21914
21915 lut1d
21916 Apply a 1D LUT to an input video.
21917
21918 The filter accepts the following options:
21919
21920 file
21921 Set the 1D LUT file name.
21922
21923 Currently supported formats:
21924
21925 cube
21926 Iridas
21927
21928 csp cineSpace
21929
21930 interp
21931 Select interpolation mode.
21932
21933 Available values are:
21934
21935 nearest
21936 Use values from the nearest defined point.
21937
21938 linear
21939 Interpolate values using the linear interpolation.
21940
21941 cosine
21942 Interpolate values using the cosine interpolation.
21943
21944 cubic
21945 Interpolate values using the cubic interpolation.
21946
21947 spline
21948 Interpolate values using the spline interpolation.
21949
21950 Commands
21951
21952 This filter supports the all above options as commands.
21953
21954 lut3d
21955 Apply a 3D LUT to an input video.
21956
21957 The filter accepts the following options:
21958
21959 file
21960 Set the 3D LUT file name.
21961
21962 Currently supported formats:
21963
21964 3dl AfterEffects
21965
21966 cube
21967 Iridas
21968
21969 dat DaVinci
21970
21971 m3d Pandora
21972
21973 csp cineSpace
21974
21975 interp
21976 Select interpolation mode.
21977
21978 Available values are:
21979
21980 nearest
21981 Use values from the nearest defined point.
21982
21983 trilinear
21984 Interpolate values using the 8 points defining a cube.
21985
21986 tetrahedral
21987 Interpolate values using a tetrahedron.
21988
21989 pyramid
21990 Interpolate values using a pyramid.
21991
21992 prism
21993 Interpolate values using a prism.
21994
21995 Commands
21996
21997 This filter supports the "interp" option as commands.
21998
21999 lumakey
22000 Turn certain luma values into transparency.
22001
22002 The filter accepts the following options:
22003
22004 threshold
22005 Set the luma which will be used as base for transparency. Default
22006 value is 0.
22007
22008 tolerance
22009 Set the range of luma values to be keyed out. Default value is
22010 0.01.
22011
22012 softness
22013 Set the range of softness. Default value is 0. Use this to control
22014 gradual transition from zero to full transparency.
22015
22016 Commands
22017
22018 This filter supports same commands as options. The command accepts the
22019 same syntax of the corresponding option.
22020
22021 If the specified expression is not valid, it is kept at its current
22022 value.
22023
22024 lut, lutrgb, lutyuv
22025 Compute a look-up table for binding each pixel component input value to
22026 an output value, and apply it to the input video.
22027
22028 lutyuv applies a lookup table to a YUV input video, lutrgb to an RGB
22029 input video.
22030
22031 These filters accept the following parameters:
22032
22033 c0 set first pixel component expression
22034
22035 c1 set second pixel component expression
22036
22037 c2 set third pixel component expression
22038
22039 c3 set fourth pixel component expression, corresponds to the alpha
22040 component
22041
22042 r set red component expression
22043
22044 g set green component expression
22045
22046 b set blue component expression
22047
22048 a alpha component expression
22049
22050 y set Y/luminance component expression
22051
22052 u set U/Cb component expression
22053
22054 v set V/Cr component expression
22055
22056 Each of them specifies the expression to use for computing the lookup
22057 table for the corresponding pixel component values.
22058
22059 The exact component associated to each of the c* options depends on the
22060 format in input.
22061
22062 The lut filter requires either YUV or RGB pixel formats in input,
22063 lutrgb requires RGB pixel formats in input, and lutyuv requires YUV.
22064
22065 The expressions can contain the following constants and functions:
22066
22067 w
22068 h The input width and height.
22069
22070 val The input value for the pixel component.
22071
22072 clipval
22073 The input value, clipped to the minval-maxval range.
22074
22075 maxval
22076 The maximum value for the pixel component.
22077
22078 minval
22079 The minimum value for the pixel component.
22080
22081 negval
22082 The negated value for the pixel component value, clipped to the
22083 minval-maxval range; it corresponds to the expression
22084 "maxval-clipval+minval".
22085
22086 clip(val)
22087 The computed value in val, clipped to the minval-maxval range.
22088
22089 gammaval(gamma)
22090 The computed gamma correction value of the pixel component value,
22091 clipped to the minval-maxval range. It corresponds to the
22092 expression
22093 "pow((clipval-minval)/(maxval-minval)\,gamma)*(maxval-minval)+minval"
22094
22095 All expressions default to "val".
22096
22097 Commands
22098
22099 This filter supports same commands as options.
22100
22101 Examples
22102
22103 • Negate input video:
22104
22105 lutrgb="r=maxval+minval-val:g=maxval+minval-val:b=maxval+minval-val"
22106 lutyuv="y=maxval+minval-val:u=maxval+minval-val:v=maxval+minval-val"
22107
22108 The above is the same as:
22109
22110 lutrgb="r=negval:g=negval:b=negval"
22111 lutyuv="y=negval:u=negval:v=negval"
22112
22113 • Negate luminance:
22114
22115 lutyuv=y=negval
22116
22117 • Remove chroma components, turning the video into a graytone image:
22118
22119 lutyuv="u=128:v=128"
22120
22121 • Apply a luma burning effect:
22122
22123 lutyuv="y=2*val"
22124
22125 • Remove green and blue components:
22126
22127 lutrgb="g=0:b=0"
22128
22129 • Set a constant alpha channel value on input:
22130
22131 format=rgba,lutrgb=a="maxval-minval/2"
22132
22133 • Correct luminance gamma by a factor of 0.5:
22134
22135 lutyuv=y=gammaval(0.5)
22136
22137 • Discard least significant bits of luma:
22138
22139 lutyuv=y='bitand(val, 128+64+32)'
22140
22141 • Technicolor like effect:
22142
22143 lutyuv=u='(val-maxval/2)*2+maxval/2':v='(val-maxval/2)*2+maxval/2'
22144
22145 lut2, tlut2
22146 The "lut2" filter takes two input streams and outputs one stream.
22147
22148 The "tlut2" (time lut2) filter takes two consecutive frames from one
22149 single stream.
22150
22151 This filter accepts the following parameters:
22152
22153 c0 set first pixel component expression
22154
22155 c1 set second pixel component expression
22156
22157 c2 set third pixel component expression
22158
22159 c3 set fourth pixel component expression, corresponds to the alpha
22160 component
22161
22162 d set output bit depth, only available for "lut2" filter. By default
22163 is 0, which means bit depth is automatically picked from first
22164 input format.
22165
22166 The "lut2" filter also supports the framesync options.
22167
22168 Each of them specifies the expression to use for computing the lookup
22169 table for the corresponding pixel component values.
22170
22171 The exact component associated to each of the c* options depends on the
22172 format in inputs.
22173
22174 The expressions can contain the following constants:
22175
22176 w
22177 h The input width and height.
22178
22179 x The first input value for the pixel component.
22180
22181 y The second input value for the pixel component.
22182
22183 bdx The first input video bit depth.
22184
22185 bdy The second input video bit depth.
22186
22187 All expressions default to "x".
22188
22189 Commands
22190
22191 This filter supports the all above options as commands except option
22192 "d".
22193
22194 Examples
22195
22196 • Highlight differences between two RGB video streams:
22197
22198 lut2='ifnot(x-y,0,pow(2,bdx)-1):ifnot(x-y,0,pow(2,bdx)-1):ifnot(x-y,0,pow(2,bdx)-1)'
22199
22200 • Highlight differences between two YUV video streams:
22201
22202 lut2='ifnot(x-y,0,pow(2,bdx)-1):ifnot(x-y,pow(2,bdx-1),pow(2,bdx)-1):ifnot(x-y,pow(2,bdx-1),pow(2,bdx)-1)'
22203
22204 • Show max difference between two video streams:
22205
22206 lut2='if(lt(x,y),0,if(gt(x,y),pow(2,bdx)-1,pow(2,bdx-1))):if(lt(x,y),0,if(gt(x,y),pow(2,bdx)-1,pow(2,bdx-1))):if(lt(x,y),0,if(gt(x,y),pow(2,bdx)-1,pow(2,bdx-1)))'
22207
22208 maskedclamp
22209 Clamp the first input stream with the second input and third input
22210 stream.
22211
22212 Returns the value of first stream to be between second input stream -
22213 "undershoot" and third input stream + "overshoot".
22214
22215 This filter accepts the following options:
22216
22217 undershoot
22218 Default value is 0.
22219
22220 overshoot
22221 Default value is 0.
22222
22223 planes
22224 Set which planes will be processed as bitmap, unprocessed planes
22225 will be copied from first stream. By default value 0xf, all planes
22226 will be processed.
22227
22228 Commands
22229
22230 This filter supports the all above options as commands.
22231
22232 maskedmax
22233 Merge the second and third input stream into output stream using
22234 absolute differences between second input stream and first input stream
22235 and absolute difference between third input stream and first input
22236 stream. The picked value will be from second input stream if second
22237 absolute difference is greater than first one or from third input
22238 stream otherwise.
22239
22240 This filter accepts the following options:
22241
22242 planes
22243 Set which planes will be processed as bitmap, unprocessed planes
22244 will be copied from first stream. By default value 0xf, all planes
22245 will be processed.
22246
22247 Commands
22248
22249 This filter supports the all above options as commands.
22250
22251 maskedmerge
22252 Merge the first input stream with the second input stream using per
22253 pixel weights in the third input stream.
22254
22255 A value of 0 in the third stream pixel component means that pixel
22256 component from first stream is returned unchanged, while maximum value
22257 (eg. 255 for 8-bit videos) means that pixel component from second
22258 stream is returned unchanged. Intermediate values define the amount of
22259 merging between both input stream's pixel components.
22260
22261 This filter accepts the following options:
22262
22263 planes
22264 Set which planes will be processed as bitmap, unprocessed planes
22265 will be copied from first stream. By default value 0xf, all planes
22266 will be processed.
22267
22268 Commands
22269
22270 This filter supports the all above options as commands.
22271
22272 maskedmin
22273 Merge the second and third input stream into output stream using
22274 absolute differences between second input stream and first input stream
22275 and absolute difference between third input stream and first input
22276 stream. The picked value will be from second input stream if second
22277 absolute difference is less than first one or from third input stream
22278 otherwise.
22279
22280 This filter accepts the following options:
22281
22282 planes
22283 Set which planes will be processed as bitmap, unprocessed planes
22284 will be copied from first stream. By default value 0xf, all planes
22285 will be processed.
22286
22287 Commands
22288
22289 This filter supports the all above options as commands.
22290
22291 maskedthreshold
22292 Pick pixels comparing absolute difference of two video streams with
22293 fixed threshold.
22294
22295 If absolute difference between pixel component of first and second
22296 video stream is equal or lower than user supplied threshold than pixel
22297 component from first video stream is picked, otherwise pixel component
22298 from second video stream is picked.
22299
22300 This filter accepts the following options:
22301
22302 threshold
22303 Set threshold used when picking pixels from absolute difference
22304 from two input video streams.
22305
22306 planes
22307 Set which planes will be processed as bitmap, unprocessed planes
22308 will be copied from second stream. By default value 0xf, all
22309 planes will be processed.
22310
22311 Commands
22312
22313 This filter supports the all above options as commands.
22314
22315 maskfun
22316 Create mask from input video.
22317
22318 For example it is useful to create motion masks after "tblend" filter.
22319
22320 This filter accepts the following options:
22321
22322 low Set low threshold. Any pixel component lower or exact than this
22323 value will be set to 0.
22324
22325 high
22326 Set high threshold. Any pixel component higher than this value will
22327 be set to max value allowed for current pixel format.
22328
22329 planes
22330 Set planes to filter, by default all available planes are filtered.
22331
22332 fill
22333 Fill all frame pixels with this value.
22334
22335 sum Set max average pixel value for frame. If sum of all pixel
22336 components is higher that this average, output frame will be
22337 completely filled with value set by fill option. Typically useful
22338 for scene changes when used in combination with "tblend" filter.
22339
22340 Commands
22341
22342 This filter supports the all above options as commands.
22343
22344 mcdeint
22345 Apply motion-compensation deinterlacing.
22346
22347 It needs one field per frame as input and must thus be used together
22348 with yadif=1/3 or equivalent.
22349
22350 This filter is only available in ffmpeg version 4.4 or earlier.
22351
22352 This filter accepts the following options:
22353
22354 mode
22355 Set the deinterlacing mode.
22356
22357 It accepts one of the following values:
22358
22359 fast
22360 medium
22361 slow
22362 use iterative motion estimation
22363
22364 extra_slow
22365 like slow, but use multiple reference frames.
22366
22367 Default value is fast.
22368
22369 parity
22370 Set the picture field parity assumed for the input video. It must
22371 be one of the following values:
22372
22373 0, tff
22374 assume top field first
22375
22376 1, bff
22377 assume bottom field first
22378
22379 Default value is bff.
22380
22381 qp Set per-block quantization parameter (QP) used by the internal
22382 encoder.
22383
22384 Higher values should result in a smoother motion vector field but
22385 less optimal individual vectors. Default value is 1.
22386
22387 median
22388 Pick median pixel from certain rectangle defined by radius.
22389
22390 This filter accepts the following options:
22391
22392 radius
22393 Set horizontal radius size. Default value is 1. Allowed range is
22394 integer from 1 to 127.
22395
22396 planes
22397 Set which planes to process. Default is 15, which is all available
22398 planes.
22399
22400 radiusV
22401 Set vertical radius size. Default value is 0. Allowed range is
22402 integer from 0 to 127. If it is 0, value will be picked from
22403 horizontal "radius" option.
22404
22405 percentile
22406 Set median percentile. Default value is 0.5. Default value of 0.5
22407 will pick always median values, while 0 will pick minimum values,
22408 and 1 maximum values.
22409
22410 Commands
22411
22412 This filter supports same commands as options. The command accepts the
22413 same syntax of the corresponding option.
22414
22415 If the specified expression is not valid, it is kept at its current
22416 value.
22417
22418 mergeplanes
22419 Merge color channel components from several video streams.
22420
22421 The filter accepts up to 4 input streams, and merge selected input
22422 planes to the output video.
22423
22424 This filter accepts the following options:
22425
22426 mapping
22427 Set input to output plane mapping. Default is 0.
22428
22429 The mappings is specified as a bitmap. It should be specified as a
22430 hexadecimal number in the form 0xAa[Bb[Cc[Dd]]]. 'Aa' describes the
22431 mapping for the first plane of the output stream. 'A' sets the
22432 number of the input stream to use (from 0 to 3), and 'a' the plane
22433 number of the corresponding input to use (from 0 to 3). The rest of
22434 the mappings is similar, 'Bb' describes the mapping for the output
22435 stream second plane, 'Cc' describes the mapping for the output
22436 stream third plane and 'Dd' describes the mapping for the output
22437 stream fourth plane.
22438
22439 format
22440 Set output pixel format. Default is "yuva444p".
22441
22442 Examples
22443
22444 • Merge three gray video streams of same width and height into single
22445 video stream:
22446
22447 [a0][a1][a2]mergeplanes=0x001020:yuv444p
22448
22449 • Merge 1st yuv444p stream and 2nd gray video stream into yuva444p
22450 video stream:
22451
22452 [a0][a1]mergeplanes=0x00010210:yuva444p
22453
22454 • Swap Y and A plane in yuva444p stream:
22455
22456 format=yuva444p,mergeplanes=0x03010200:yuva444p
22457
22458 • Swap U and V plane in yuv420p stream:
22459
22460 format=yuv420p,mergeplanes=0x000201:yuv420p
22461
22462 • Cast a rgb24 clip to yuv444p:
22463
22464 format=rgb24,mergeplanes=0x000102:yuv444p
22465
22466 mestimate
22467 Estimate and export motion vectors using block matching algorithms.
22468 Motion vectors are stored in frame side data to be used by other
22469 filters.
22470
22471 This filter accepts the following options:
22472
22473 method
22474 Specify the motion estimation method. Accepts one of the following
22475 values:
22476
22477 esa Exhaustive search algorithm.
22478
22479 tss Three step search algorithm.
22480
22481 tdls
22482 Two dimensional logarithmic search algorithm.
22483
22484 ntss
22485 New three step search algorithm.
22486
22487 fss Four step search algorithm.
22488
22489 ds Diamond search algorithm.
22490
22491 hexbs
22492 Hexagon-based search algorithm.
22493
22494 epzs
22495 Enhanced predictive zonal search algorithm.
22496
22497 umh Uneven multi-hexagon search algorithm.
22498
22499 Default value is esa.
22500
22501 mb_size
22502 Macroblock size. Default 16.
22503
22504 search_param
22505 Search parameter. Default 7.
22506
22507 midequalizer
22508 Apply Midway Image Equalization effect using two video streams.
22509
22510 Midway Image Equalization adjusts a pair of images to have the same
22511 histogram, while maintaining their dynamics as much as possible. It's
22512 useful for e.g. matching exposures from a pair of stereo cameras.
22513
22514 This filter has two inputs and one output, which must be of same pixel
22515 format, but may be of different sizes. The output of filter is first
22516 input adjusted with midway histogram of both inputs.
22517
22518 This filter accepts the following option:
22519
22520 planes
22521 Set which planes to process. Default is 15, which is all available
22522 planes.
22523
22524 minterpolate
22525 Convert the video to specified frame rate using motion interpolation.
22526
22527 This filter accepts the following options:
22528
22529 fps Specify the output frame rate. This can be rational e.g.
22530 "60000/1001". Frames are dropped if fps is lower than source fps.
22531 Default 60.
22532
22533 mi_mode
22534 Motion interpolation mode. Following values are accepted:
22535
22536 dup Duplicate previous or next frame for interpolating new ones.
22537
22538 blend
22539 Blend source frames. Interpolated frame is mean of previous and
22540 next frames.
22541
22542 mci Motion compensated interpolation. Following options are
22543 effective when this mode is selected:
22544
22545 mc_mode
22546 Motion compensation mode. Following values are accepted:
22547
22548 obmc
22549 Overlapped block motion compensation.
22550
22551 aobmc
22552 Adaptive overlapped block motion compensation. Window
22553 weighting coefficients are controlled adaptively
22554 according to the reliabilities of the neighboring
22555 motion vectors to reduce oversmoothing.
22556
22557 Default mode is obmc.
22558
22559 me_mode
22560 Motion estimation mode. Following values are accepted:
22561
22562 bidir
22563 Bidirectional motion estimation. Motion vectors are
22564 estimated for each source frame in both forward and
22565 backward directions.
22566
22567 bilat
22568 Bilateral motion estimation. Motion vectors are
22569 estimated directly for interpolated frame.
22570
22571 Default mode is bilat.
22572
22573 me The algorithm to be used for motion estimation. Following
22574 values are accepted:
22575
22576 esa Exhaustive search algorithm.
22577
22578 tss Three step search algorithm.
22579
22580 tdls
22581 Two dimensional logarithmic search algorithm.
22582
22583 ntss
22584 New three step search algorithm.
22585
22586 fss Four step search algorithm.
22587
22588 ds Diamond search algorithm.
22589
22590 hexbs
22591 Hexagon-based search algorithm.
22592
22593 epzs
22594 Enhanced predictive zonal search algorithm.
22595
22596 umh Uneven multi-hexagon search algorithm.
22597
22598 Default algorithm is epzs.
22599
22600 mb_size
22601 Macroblock size. Default 16.
22602
22603 search_param
22604 Motion estimation search parameter. Default 32.
22605
22606 vsbmc
22607 Enable variable-size block motion compensation. Motion
22608 estimation is applied with smaller block sizes at object
22609 boundaries in order to make the them less blur. Default is
22610 0 (disabled).
22611
22612 scd Scene change detection method. Scene change leads motion vectors to
22613 be in random direction. Scene change detection replace interpolated
22614 frames by duplicate ones. May not be needed for other modes.
22615 Following values are accepted:
22616
22617 none
22618 Disable scene change detection.
22619
22620 fdiff
22621 Frame difference. Corresponding pixel values are compared and
22622 if it satisfies scd_threshold scene change is detected.
22623
22624 Default method is fdiff.
22625
22626 scd_threshold
22627 Scene change detection threshold. Default is 10..
22628
22629 mix
22630 Mix several video input streams into one video stream.
22631
22632 A description of the accepted options follows.
22633
22634 inputs
22635 The number of inputs. If unspecified, it defaults to 2.
22636
22637 weights
22638 Specify weight of each input video stream as sequence. Each weight
22639 is separated by space. If number of weights is smaller than number
22640 of frames last specified weight will be used for all remaining
22641 unset weights.
22642
22643 scale
22644 Specify scale, if it is set it will be multiplied with sum of each
22645 weight multiplied with pixel values to give final destination pixel
22646 value. By default scale is auto scaled to sum of weights.
22647
22648 duration
22649 Specify how end of stream is determined.
22650
22651 longest
22652 The duration of the longest input. (default)
22653
22654 shortest
22655 The duration of the shortest input.
22656
22657 first
22658 The duration of the first input.
22659
22660 Commands
22661
22662 This filter supports the following commands:
22663
22664 weights
22665 scale
22666 Syntax is same as option with same name.
22667
22668 monochrome
22669 Convert video to gray using custom color filter.
22670
22671 A description of the accepted options follows.
22672
22673 cb Set the chroma blue spot. Allowed range is from -1 to 1. Default
22674 value is 0.
22675
22676 cr Set the chroma red spot. Allowed range is from -1 to 1. Default
22677 value is 0.
22678
22679 size
22680 Set the color filter size. Allowed range is from .1 to 10. Default
22681 value is 1.
22682
22683 high
22684 Set the highlights strength. Allowed range is from 0 to 1. Default
22685 value is 0.
22686
22687 Commands
22688
22689 This filter supports the all above options as commands.
22690
22691 morpho
22692 This filter allows to apply main morphological grayscale transforms,
22693 erode and dilate with arbitrary structures set in second input stream.
22694
22695 Unlike naive implementation and much slower performance in erosion and
22696 dilation filters, when speed is critical "morpho" filter should be used
22697 instead.
22698
22699 A description of accepted options follows,
22700
22701 mode
22702 Set morphological transform to apply, can be:
22703
22704 erode
22705 dilate
22706 open
22707 close
22708 gradient
22709 tophat
22710 blackhat
22711
22712 Default is "erode".
22713
22714 planes
22715 Set planes to filter, by default all planes except alpha are
22716 filtered.
22717
22718 structure
22719 Set which structure video frames will be processed from second
22720 input stream, can be first or all. Default is all.
22721
22722 The "morpho" filter also supports the framesync options.
22723
22724 Commands
22725
22726 This filter supports same commands as options.
22727
22728 mpdecimate
22729 Drop frames that do not differ greatly from the previous frame in order
22730 to reduce frame rate.
22731
22732 The main use of this filter is for very-low-bitrate encoding (e.g.
22733 streaming over dialup modem), but it could in theory be used for fixing
22734 movies that were inverse-telecined incorrectly.
22735
22736 A description of the accepted options follows.
22737
22738 max Set the maximum number of consecutive frames which can be dropped
22739 (if positive), or the minimum interval between dropped frames (if
22740 negative). If the value is 0, the frame is dropped disregarding the
22741 number of previous sequentially dropped frames.
22742
22743 Default value is 0.
22744
22745 hi
22746 lo
22747 frac
22748 Set the dropping threshold values.
22749
22750 Values for hi and lo are for 8x8 pixel blocks and represent actual
22751 pixel value differences, so a threshold of 64 corresponds to 1 unit
22752 of difference for each pixel, or the same spread out differently
22753 over the block.
22754
22755 A frame is a candidate for dropping if no 8x8 blocks differ by more
22756 than a threshold of hi, and if no more than frac blocks (1 meaning
22757 the whole image) differ by more than a threshold of lo.
22758
22759 Default value for hi is 64*12, default value for lo is 64*5, and
22760 default value for frac is 0.33.
22761
22762 msad
22763 Obtain the MSAD (Mean Sum of Absolute Differences) between two input
22764 videos.
22765
22766 This filter takes two input videos.
22767
22768 Both input videos must have the same resolution and pixel format for
22769 this filter to work correctly. Also it assumes that both inputs have
22770 the same number of frames, which are compared one by one.
22771
22772 The obtained per component, average, min and max MSAD is printed
22773 through the logging system.
22774
22775 The filter stores the calculated MSAD of each frame in frame metadata.
22776
22777 In the below example the input file main.mpg being processed is
22778 compared with the reference file ref.mpg.
22779
22780 ffmpeg -i main.mpg -i ref.mpg -lavfi msad -f null -
22781
22782 negate
22783 Negate (invert) the input video.
22784
22785 It accepts the following option:
22786
22787 components
22788 Set components to negate.
22789
22790 Available values for components are:
22791
22792 y
22793 u
22794 v
22795 a
22796 r
22797 g
22798 b
22799 negate_alpha
22800 With value 1, it negates the alpha component, if present. Default
22801 value is 0.
22802
22803 Commands
22804
22805 This filter supports same commands as options.
22806
22807 nlmeans
22808 Denoise frames using Non-Local Means algorithm.
22809
22810 Each pixel is adjusted by looking for other pixels with similar
22811 contexts. This context similarity is defined by comparing their
22812 surrounding patches of size pxp. Patches are searched in an area of rxr
22813 around the pixel.
22814
22815 Note that the research area defines centers for patches, which means
22816 some patches will be made of pixels outside that research area.
22817
22818 The filter accepts the following options.
22819
22820 s Set denoising strength. Default is 1.0. Must be in range [1.0,
22821 30.0].
22822
22823 p Set patch size. Default is 7. Must be odd number in range [0, 99].
22824
22825 pc Same as p but for chroma planes.
22826
22827 The default value is 0 and means automatic.
22828
22829 r Set research size. Default is 15. Must be odd number in range [0,
22830 99].
22831
22832 rc Same as r but for chroma planes.
22833
22834 The default value is 0 and means automatic.
22835
22836 nnedi
22837 Deinterlace video using neural network edge directed interpolation.
22838
22839 This filter accepts the following options:
22840
22841 weights
22842 Mandatory option, without binary file filter can not work.
22843 Currently file can be found here:
22844 https://github.com/dubhater/vapoursynth-nnedi3/blob/master/src/nnedi3_weights.bin
22845
22846 deint
22847 Set which frames to deinterlace, by default it is "all". Can be
22848 "all" or "interlaced".
22849
22850 field
22851 Set mode of operation.
22852
22853 Can be one of the following:
22854
22855 af Use frame flags, both fields.
22856
22857 a Use frame flags, single field.
22858
22859 t Use top field only.
22860
22861 b Use bottom field only.
22862
22863 tf Use both fields, top first.
22864
22865 bf Use both fields, bottom first.
22866
22867 planes
22868 Set which planes to process, by default filter process all frames.
22869
22870 nsize
22871 Set size of local neighborhood around each pixel, used by the
22872 predictor neural network.
22873
22874 Can be one of the following:
22875
22876 s8x6
22877 s16x6
22878 s32x6
22879 s48x6
22880 s8x4
22881 s16x4
22882 s32x4
22883 nns Set the number of neurons in predictor neural network. Can be one
22884 of the following:
22885
22886 n16
22887 n32
22888 n64
22889 n128
22890 n256
22891 qual
22892 Controls the number of different neural network predictions that
22893 are blended together to compute the final output value. Can be
22894 "fast", default or "slow".
22895
22896 etype
22897 Set which set of weights to use in the predictor. Can be one of
22898 the following:
22899
22900 a, abs
22901 weights trained to minimize absolute error
22902
22903 s, mse
22904 weights trained to minimize squared error
22905
22906 pscrn
22907 Controls whether or not the prescreener neural network is used to
22908 decide which pixels should be processed by the predictor neural
22909 network and which can be handled by simple cubic interpolation.
22910 The prescreener is trained to know whether cubic interpolation will
22911 be sufficient for a pixel or whether it should be predicted by the
22912 predictor nn. The computational complexity of the prescreener nn
22913 is much less than that of the predictor nn. Since most pixels can
22914 be handled by cubic interpolation, using the prescreener generally
22915 results in much faster processing. The prescreener is pretty
22916 accurate, so the difference between using it and not using it is
22917 almost always unnoticeable.
22918
22919 Can be one of the following:
22920
22921 none
22922 original
22923 new
22924 new2
22925 new3
22926
22927 Default is "new".
22928
22929 Commands
22930
22931 This filter supports same commands as options, excluding weights
22932 option.
22933
22934 noformat
22935 Force libavfilter not to use any of the specified pixel formats for the
22936 input to the next filter.
22937
22938 It accepts the following parameters:
22939
22940 pix_fmts
22941 A '|'-separated list of pixel format names, such as
22942 pix_fmts=yuv420p|monow|rgb24".
22943
22944 Examples
22945
22946 • Force libavfilter to use a format different from yuv420p for the
22947 input to the vflip filter:
22948
22949 noformat=pix_fmts=yuv420p,vflip
22950
22951 • Convert the input video to any of the formats not contained in the
22952 list:
22953
22954 noformat=yuv420p|yuv444p|yuv410p
22955
22956 noise
22957 Add noise on video input frame.
22958
22959 The filter accepts the following options:
22960
22961 all_seed
22962 c0_seed
22963 c1_seed
22964 c2_seed
22965 c3_seed
22966 Set noise seed for specific pixel component or all pixel components
22967 in case of all_seed. Default value is 123457.
22968
22969 all_strength, alls
22970 c0_strength, c0s
22971 c1_strength, c1s
22972 c2_strength, c2s
22973 c3_strength, c3s
22974 Set noise strength for specific pixel component or all pixel
22975 components in case all_strength. Default value is 0. Allowed range
22976 is [0, 100].
22977
22978 all_flags, allf
22979 c0_flags, c0f
22980 c1_flags, c1f
22981 c2_flags, c2f
22982 c3_flags, c3f
22983 Set pixel component flags or set flags for all components if
22984 all_flags. Available values for component flags are:
22985
22986 a averaged temporal noise (smoother)
22987
22988 p mix random noise with a (semi)regular pattern
22989
22990 t temporal noise (noise pattern changes between frames)
22991
22992 u uniform noise (gaussian otherwise)
22993
22994 Examples
22995
22996 Add temporal and uniform noise to input video:
22997
22998 noise=alls=20:allf=t+u
22999
23000 normalize
23001 Normalize RGB video (aka histogram stretching, contrast stretching).
23002 See: https://en.wikipedia.org/wiki/Normalization_(image_processing)
23003
23004 For each channel of each frame, the filter computes the input range and
23005 maps it linearly to the user-specified output range. The output range
23006 defaults to the full dynamic range from pure black to pure white.
23007
23008 Temporal smoothing can be used on the input range to reduce flickering
23009 (rapid changes in brightness) caused when small dark or bright objects
23010 enter or leave the scene. This is similar to the auto-exposure
23011 (automatic gain control) on a video camera, and, like a video camera,
23012 it may cause a period of over- or under-exposure of the video.
23013
23014 The R,G,B channels can be normalized independently, which may cause
23015 some color shifting, or linked together as a single channel, which
23016 prevents color shifting. Linked normalization preserves hue.
23017 Independent normalization does not, so it can be used to remove some
23018 color casts. Independent and linked normalization can be combined in
23019 any ratio.
23020
23021 The normalize filter accepts the following options:
23022
23023 blackpt
23024 whitept
23025 Colors which define the output range. The minimum input value is
23026 mapped to the blackpt. The maximum input value is mapped to the
23027 whitept. The defaults are black and white respectively. Specifying
23028 white for blackpt and black for whitept will give color-inverted,
23029 normalized video. Shades of grey can be used to reduce the dynamic
23030 range (contrast). Specifying saturated colors here can create some
23031 interesting effects.
23032
23033 smoothing
23034 The number of previous frames to use for temporal smoothing. The
23035 input range of each channel is smoothed using a rolling average
23036 over the current frame and the smoothing previous frames. The
23037 default is 0 (no temporal smoothing).
23038
23039 independence
23040 Controls the ratio of independent (color shifting) channel
23041 normalization to linked (color preserving) normalization. 0.0 is
23042 fully linked, 1.0 is fully independent. Defaults to 1.0 (fully
23043 independent).
23044
23045 strength
23046 Overall strength of the filter. 1.0 is full strength. 0.0 is a
23047 rather expensive no-op. Defaults to 1.0 (full strength).
23048
23049 Commands
23050
23051 This filter supports same commands as options, excluding smoothing
23052 option. The command accepts the same syntax of the corresponding
23053 option.
23054
23055 If the specified expression is not valid, it is kept at its current
23056 value.
23057
23058 Examples
23059
23060 Stretch video contrast to use the full dynamic range, with no temporal
23061 smoothing; may flicker depending on the source content:
23062
23063 normalize=blackpt=black:whitept=white:smoothing=0
23064
23065 As above, but with 50 frames of temporal smoothing; flicker should be
23066 reduced, depending on the source content:
23067
23068 normalize=blackpt=black:whitept=white:smoothing=50
23069
23070 As above, but with hue-preserving linked channel normalization:
23071
23072 normalize=blackpt=black:whitept=white:smoothing=50:independence=0
23073
23074 As above, but with half strength:
23075
23076 normalize=blackpt=black:whitept=white:smoothing=50:independence=0:strength=0.5
23077
23078 Map the darkest input color to red, the brightest input color to cyan:
23079
23080 normalize=blackpt=red:whitept=cyan
23081
23082 null
23083 Pass the video source unchanged to the output.
23084
23085 ocr
23086 Optical Character Recognition
23087
23088 This filter uses Tesseract for optical character recognition. To enable
23089 compilation of this filter, you need to configure FFmpeg with
23090 "--enable-libtesseract".
23091
23092 It accepts the following options:
23093
23094 datapath
23095 Set datapath to tesseract data. Default is to use whatever was set
23096 at installation.
23097
23098 language
23099 Set language, default is "eng".
23100
23101 whitelist
23102 Set character whitelist.
23103
23104 blacklist
23105 Set character blacklist.
23106
23107 The filter exports recognized text as the frame metadata
23108 "lavfi.ocr.text". The filter exports confidence of recognized words as
23109 the frame metadata "lavfi.ocr.confidence".
23110
23111 ocv
23112 Apply a video transform using libopencv.
23113
23114 To enable this filter, install the libopencv library and headers and
23115 configure FFmpeg with "--enable-libopencv".
23116
23117 It accepts the following parameters:
23118
23119 filter_name
23120 The name of the libopencv filter to apply.
23121
23122 filter_params
23123 The parameters to pass to the libopencv filter. If not specified,
23124 the default values are assumed.
23125
23126 Refer to the official libopencv documentation for more precise
23127 information:
23128 <http://docs.opencv.org/master/modules/imgproc/doc/filtering.html>
23129
23130 Several libopencv filters are supported; see the following subsections.
23131
23132 dilate
23133
23134 Dilate an image by using a specific structuring element. It
23135 corresponds to the libopencv function "cvDilate".
23136
23137 It accepts the parameters: struct_el|nb_iterations.
23138
23139 struct_el represents a structuring element, and has the syntax:
23140 colsxrows+anchor_xxanchor_y/shape
23141
23142 cols and rows represent the number of columns and rows of the
23143 structuring element, anchor_x and anchor_y the anchor point, and shape
23144 the shape for the structuring element. shape must be "rect", "cross",
23145 "ellipse", or "custom".
23146
23147 If the value for shape is "custom", it must be followed by a string of
23148 the form "=filename". The file with name filename is assumed to
23149 represent a binary image, with each printable character corresponding
23150 to a bright pixel. When a custom shape is used, cols and rows are
23151 ignored, the number or columns and rows of the read file are assumed
23152 instead.
23153
23154 The default value for struct_el is "3x3+0x0/rect".
23155
23156 nb_iterations specifies the number of times the transform is applied to
23157 the image, and defaults to 1.
23158
23159 Some examples:
23160
23161 # Use the default values
23162 ocv=dilate
23163
23164 # Dilate using a structuring element with a 5x5 cross, iterating two times
23165 ocv=filter_name=dilate:filter_params=5x5+2x2/cross|2
23166
23167 # Read the shape from the file diamond.shape, iterating two times.
23168 # The file diamond.shape may contain a pattern of characters like this
23169 # *
23170 # ***
23171 # *****
23172 # ***
23173 # *
23174 # The specified columns and rows are ignored
23175 # but the anchor point coordinates are not
23176 ocv=dilate:0x0+2x2/custom=diamond.shape|2
23177
23178 erode
23179
23180 Erode an image by using a specific structuring element. It corresponds
23181 to the libopencv function "cvErode".
23182
23183 It accepts the parameters: struct_el:nb_iterations, with the same
23184 syntax and semantics as the dilate filter.
23185
23186 smooth
23187
23188 Smooth the input video.
23189
23190 The filter takes the following parameters:
23191 type|param1|param2|param3|param4.
23192
23193 type is the type of smooth filter to apply, and must be one of the
23194 following values: "blur", "blur_no_scale", "median", "gaussian", or
23195 "bilateral". The default value is "gaussian".
23196
23197 The meaning of param1, param2, param3, and param4 depends on the smooth
23198 type. param1 and param2 accept integer positive values or 0. param3 and
23199 param4 accept floating point values.
23200
23201 The default value for param1 is 3. The default value for the other
23202 parameters is 0.
23203
23204 These parameters correspond to the parameters assigned to the libopencv
23205 function "cvSmooth".
23206
23207 oscilloscope
23208 2D Video Oscilloscope.
23209
23210 Useful to measure spatial impulse, step responses, chroma delays, etc.
23211
23212 It accepts the following parameters:
23213
23214 x Set scope center x position.
23215
23216 y Set scope center y position.
23217
23218 s Set scope size, relative to frame diagonal.
23219
23220 t Set scope tilt/rotation.
23221
23222 o Set trace opacity.
23223
23224 tx Set trace center x position.
23225
23226 ty Set trace center y position.
23227
23228 tw Set trace width, relative to width of frame.
23229
23230 th Set trace height, relative to height of frame.
23231
23232 c Set which components to trace. By default it traces first three
23233 components.
23234
23235 g Draw trace grid. By default is enabled.
23236
23237 st Draw some statistics. By default is enabled.
23238
23239 sc Draw scope. By default is enabled.
23240
23241 Commands
23242
23243 This filter supports same commands as options. The command accepts the
23244 same syntax of the corresponding option.
23245
23246 If the specified expression is not valid, it is kept at its current
23247 value.
23248
23249 Examples
23250
23251 • Inspect full first row of video frame.
23252
23253 oscilloscope=x=0.5:y=0:s=1
23254
23255 • Inspect full last row of video frame.
23256
23257 oscilloscope=x=0.5:y=1:s=1
23258
23259 • Inspect full 5th line of video frame of height 1080.
23260
23261 oscilloscope=x=0.5:y=5/1080:s=1
23262
23263 • Inspect full last column of video frame.
23264
23265 oscilloscope=x=1:y=0.5:s=1:t=1
23266
23267 overlay
23268 Overlay one video on top of another.
23269
23270 It takes two inputs and has one output. The first input is the "main"
23271 video on which the second input is overlaid.
23272
23273 It accepts the following parameters:
23274
23275 A description of the accepted options follows.
23276
23277 x
23278 y Set the expression for the x and y coordinates of the overlaid
23279 video on the main video. Default value is "0" for both expressions.
23280 In case the expression is invalid, it is set to a huge value
23281 (meaning that the overlay will not be displayed within the output
23282 visible area).
23283
23284 eof_action
23285 See framesync.
23286
23287 eval
23288 Set when the expressions for x, and y are evaluated.
23289
23290 It accepts the following values:
23291
23292 init
23293 only evaluate expressions once during the filter initialization
23294 or when a command is processed
23295
23296 frame
23297 evaluate expressions for each incoming frame
23298
23299 Default value is frame.
23300
23301 shortest
23302 See framesync.
23303
23304 format
23305 Set the format for the output video.
23306
23307 It accepts the following values:
23308
23309 yuv420
23310 force YUV420 output
23311
23312 yuv420p10
23313 force YUV420p10 output
23314
23315 yuv422
23316 force YUV422 output
23317
23318 yuv422p10
23319 force YUV422p10 output
23320
23321 yuv444
23322 force YUV444 output
23323
23324 rgb force packed RGB output
23325
23326 gbrp
23327 force planar RGB output
23328
23329 auto
23330 automatically pick format
23331
23332 Default value is yuv420.
23333
23334 repeatlast
23335 See framesync.
23336
23337 alpha
23338 Set format of alpha of the overlaid video, it can be straight or
23339 premultiplied. Default is straight.
23340
23341 The x, and y expressions can contain the following parameters.
23342
23343 main_w, W
23344 main_h, H
23345 The main input width and height.
23346
23347 overlay_w, w
23348 overlay_h, h
23349 The overlay input width and height.
23350
23351 x
23352 y The computed values for x and y. They are evaluated for each new
23353 frame.
23354
23355 hsub
23356 vsub
23357 horizontal and vertical chroma subsample values of the output
23358 format. For example for the pixel format "yuv422p" hsub is 2 and
23359 vsub is 1.
23360
23361 n the number of input frame, starting from 0
23362
23363 pos the position in the file of the input frame, NAN if unknown
23364
23365 t The timestamp, expressed in seconds. It's NAN if the input
23366 timestamp is unknown.
23367
23368 This filter also supports the framesync options.
23369
23370 Note that the n, pos, t variables are available only when evaluation is
23371 done per frame, and will evaluate to NAN when eval is set to init.
23372
23373 Be aware that frames are taken from each input video in timestamp
23374 order, hence, if their initial timestamps differ, it is a good idea to
23375 pass the two inputs through a setpts=PTS-STARTPTS filter to have them
23376 begin in the same zero timestamp, as the example for the movie filter
23377 does.
23378
23379 You can chain together more overlays but you should test the efficiency
23380 of such approach.
23381
23382 Commands
23383
23384 This filter supports the following commands:
23385
23386 x
23387 y Modify the x and y of the overlay input. The command accepts the
23388 same syntax of the corresponding option.
23389
23390 If the specified expression is not valid, it is kept at its current
23391 value.
23392
23393 Examples
23394
23395 • Draw the overlay at 10 pixels from the bottom right corner of the
23396 main video:
23397
23398 overlay=main_w-overlay_w-10:main_h-overlay_h-10
23399
23400 Using named options the example above becomes:
23401
23402 overlay=x=main_w-overlay_w-10:y=main_h-overlay_h-10
23403
23404 • Insert a transparent PNG logo in the bottom left corner of the
23405 input, using the ffmpeg tool with the "-filter_complex" option:
23406
23407 ffmpeg -i input -i logo -filter_complex 'overlay=10:main_h-overlay_h-10' output
23408
23409 • Insert 2 different transparent PNG logos (second logo on bottom
23410 right corner) using the ffmpeg tool:
23411
23412 ffmpeg -i input -i logo1 -i logo2 -filter_complex 'overlay=x=10:y=H-h-10,overlay=x=W-w-10:y=H-h-10' output
23413
23414 • Add a transparent color layer on top of the main video; "WxH" must
23415 specify the size of the main input to the overlay filter:
23416
23417 color=color=red@.3:size=WxH [over]; [in][over] overlay [out]
23418
23419 • Play an original video and a filtered version (here with the
23420 deshake filter) side by side using the ffplay tool:
23421
23422 ffplay input.avi -vf 'split[a][b]; [a]pad=iw*2:ih[src]; [b]deshake[filt]; [src][filt]overlay=w'
23423
23424 The above command is the same as:
23425
23426 ffplay input.avi -vf 'split[b], pad=iw*2[src], [b]deshake, [src]overlay=w'
23427
23428 • Make a sliding overlay appearing from the left to the right top
23429 part of the screen starting since time 2:
23430
23431 overlay=x='if(gte(t,2), -w+(t-2)*20, NAN)':y=0
23432
23433 • Compose output by putting two input videos side to side:
23434
23435 ffmpeg -i left.avi -i right.avi -filter_complex "
23436 nullsrc=size=200x100 [background];
23437 [0:v] setpts=PTS-STARTPTS, scale=100x100 [left];
23438 [1:v] setpts=PTS-STARTPTS, scale=100x100 [right];
23439 [background][left] overlay=shortest=1 [background+left];
23440 [background+left][right] overlay=shortest=1:x=100 [left+right]
23441 "
23442
23443 • Mask 10-20 seconds of a video by applying the delogo filter to a
23444 section
23445
23446 ffmpeg -i test.avi -codec:v:0 wmv2 -ar 11025 -b:v 9000k
23447 -vf '[in]split[split_main][split_delogo];[split_delogo]trim=start=360:end=371,delogo=0:0:640:480[delogoed];[split_main][delogoed]overlay=eof_action=pass[out]'
23448 masked.avi
23449
23450 • Chain several overlays in cascade:
23451
23452 nullsrc=s=200x200 [bg];
23453 testsrc=s=100x100, split=4 [in0][in1][in2][in3];
23454 [in0] lutrgb=r=0, [bg] overlay=0:0 [mid0];
23455 [in1] lutrgb=g=0, [mid0] overlay=100:0 [mid1];
23456 [in2] lutrgb=b=0, [mid1] overlay=0:100 [mid2];
23457 [in3] null, [mid2] overlay=100:100 [out0]
23458
23459 overlay_cuda
23460 Overlay one video on top of another.
23461
23462 This is the CUDA variant of the overlay filter. It only accepts CUDA
23463 frames. The underlying input pixel formats have to match.
23464
23465 It takes two inputs and has one output. The first input is the "main"
23466 video on which the second input is overlaid.
23467
23468 It accepts the following parameters:
23469
23470 x
23471 y Set expressions for the x and y coordinates of the overlaid video
23472 on the main video.
23473
23474 They can contain the following parameters:
23475
23476 main_w, W
23477 main_h, H
23478 The main input width and height.
23479
23480 overlay_w, w
23481 overlay_h, h
23482 The overlay input width and height.
23483
23484 x
23485 y The computed values for x and y. They are evaluated for each
23486 new frame.
23487
23488 n The ordinal index of the main input frame, starting from 0.
23489
23490 pos The byte offset position in the file of the main input frame,
23491 NAN if unknown.
23492
23493 t The timestamp of the main input frame, expressed in seconds,
23494 NAN if unknown.
23495
23496 Default value is "0" for both expressions.
23497
23498 eval
23499 Set when the expressions for x and y are evaluated.
23500
23501 It accepts the following values:
23502
23503 init
23504 Evaluate expressions once during filter initialization or when
23505 a command is processed.
23506
23507 frame
23508 Evaluate expressions for each incoming frame
23509
23510 Default value is frame.
23511
23512 eof_action
23513 See framesync.
23514
23515 shortest
23516 See framesync.
23517
23518 repeatlast
23519 See framesync.
23520
23521 This filter also supports the framesync options.
23522
23523 owdenoise
23524 Apply Overcomplete Wavelet denoiser.
23525
23526 The filter accepts the following options:
23527
23528 depth
23529 Set depth.
23530
23531 Larger depth values will denoise lower frequency components more,
23532 but slow down filtering.
23533
23534 Must be an int in the range 8-16, default is 8.
23535
23536 luma_strength, ls
23537 Set luma strength.
23538
23539 Must be a double value in the range 0-1000, default is 1.0.
23540
23541 chroma_strength, cs
23542 Set chroma strength.
23543
23544 Must be a double value in the range 0-1000, default is 1.0.
23545
23546 pad
23547 Add paddings to the input image, and place the original input at the
23548 provided x, y coordinates.
23549
23550 It accepts the following parameters:
23551
23552 width, w
23553 height, h
23554 Specify an expression for the size of the output image with the
23555 paddings added. If the value for width or height is 0, the
23556 corresponding input size is used for the output.
23557
23558 The width expression can reference the value set by the height
23559 expression, and vice versa.
23560
23561 The default value of width and height is 0.
23562
23563 x
23564 y Specify the offsets to place the input image at within the padded
23565 area, with respect to the top/left border of the output image.
23566
23567 The x expression can reference the value set by the y expression,
23568 and vice versa.
23569
23570 The default value of x and y is 0.
23571
23572 If x or y evaluate to a negative number, they'll be changed so the
23573 input image is centered on the padded area.
23574
23575 color
23576 Specify the color of the padded area. For the syntax of this
23577 option, check the "Color" section in the ffmpeg-utils manual.
23578
23579 The default value of color is "black".
23580
23581 eval
23582 Specify when to evaluate width, height, x and y expression.
23583
23584 It accepts the following values:
23585
23586 init
23587 Only evaluate expressions once during the filter initialization
23588 or when a command is processed.
23589
23590 frame
23591 Evaluate expressions for each incoming frame.
23592
23593 Default value is init.
23594
23595 aspect
23596 Pad to aspect instead to a resolution.
23597
23598 The value for the width, height, x, and y options are expressions
23599 containing the following constants:
23600
23601 in_w
23602 in_h
23603 The input video width and height.
23604
23605 iw
23606 ih These are the same as in_w and in_h.
23607
23608 out_w
23609 out_h
23610 The output width and height (the size of the padded area), as
23611 specified by the width and height expressions.
23612
23613 ow
23614 oh These are the same as out_w and out_h.
23615
23616 x
23617 y The x and y offsets as specified by the x and y expressions, or NAN
23618 if not yet specified.
23619
23620 a same as iw / ih
23621
23622 sar input sample aspect ratio
23623
23624 dar input display aspect ratio, it is the same as (iw / ih) * sar
23625
23626 hsub
23627 vsub
23628 The horizontal and vertical chroma subsample values. For example
23629 for the pixel format "yuv422p" hsub is 2 and vsub is 1.
23630
23631 Examples
23632
23633 • Add paddings with the color "violet" to the input video. The output
23634 video size is 640x480, and the top-left corner of the input video
23635 is placed at column 0, row 40
23636
23637 pad=640:480:0:40:violet
23638
23639 The example above is equivalent to the following command:
23640
23641 pad=width=640:height=480:x=0:y=40:color=violet
23642
23643 • Pad the input to get an output with dimensions increased by 3/2,
23644 and put the input video at the center of the padded area:
23645
23646 pad="3/2*iw:3/2*ih:(ow-iw)/2:(oh-ih)/2"
23647
23648 • Pad the input to get a squared output with size equal to the
23649 maximum value between the input width and height, and put the input
23650 video at the center of the padded area:
23651
23652 pad="max(iw\,ih):ow:(ow-iw)/2:(oh-ih)/2"
23653
23654 • Pad the input to get a final w/h ratio of 16:9:
23655
23656 pad="ih*16/9:ih:(ow-iw)/2:(oh-ih)/2"
23657
23658 • In case of anamorphic video, in order to set the output display
23659 aspect correctly, it is necessary to use sar in the expression,
23660 according to the relation:
23661
23662 (ih * X / ih) * sar = output_dar
23663 X = output_dar / sar
23664
23665 Thus the previous example needs to be modified to:
23666
23667 pad="ih*16/9/sar:ih:(ow-iw)/2:(oh-ih)/2"
23668
23669 • Double the output size and put the input video in the bottom-right
23670 corner of the output padded area:
23671
23672 pad="2*iw:2*ih:ow-iw:oh-ih"
23673
23674 palettegen
23675 Generate one palette for a whole video stream.
23676
23677 It accepts the following options:
23678
23679 max_colors
23680 Set the maximum number of colors to quantize in the palette. Note:
23681 the palette will still contain 256 colors; the unused palette
23682 entries will be black.
23683
23684 reserve_transparent
23685 Create a palette of 255 colors maximum and reserve the last one for
23686 transparency. Reserving the transparency color is useful for GIF
23687 optimization. If not set, the maximum of colors in the palette
23688 will be 256. You probably want to disable this option for a
23689 standalone image. Set by default.
23690
23691 transparency_color
23692 Set the color that will be used as background for transparency.
23693
23694 stats_mode
23695 Set statistics mode.
23696
23697 It accepts the following values:
23698
23699 full
23700 Compute full frame histograms.
23701
23702 diff
23703 Compute histograms only for the part that differs from previous
23704 frame. This might be relevant to give more importance to the
23705 moving part of your input if the background is static.
23706
23707 single
23708 Compute new histogram for each frame.
23709
23710 Default value is full.
23711
23712 use_alpha
23713 Create a palette of colors with alpha components. Setting this,
23714 will automatically disable 'reserve_transparent'.
23715
23716 The filter also exports the frame metadata "lavfi.color_quant_ratio"
23717 ("nb_color_in / nb_color_out") which you can use to evaluate the degree
23718 of color quantization of the palette. This information is also visible
23719 at info logging level.
23720
23721 Examples
23722
23723 • Generate a representative palette of a given video using ffmpeg:
23724
23725 ffmpeg -i input.mkv -vf palettegen palette.png
23726
23727 paletteuse
23728 Use a palette to downsample an input video stream.
23729
23730 The filter takes two inputs: one video stream and a palette. The
23731 palette must be a 256 pixels image.
23732
23733 It accepts the following options:
23734
23735 dither
23736 Select dithering mode. Available algorithms are:
23737
23738 bayer
23739 Ordered 8x8 bayer dithering (deterministic)
23740
23741 heckbert
23742 Dithering as defined by Paul Heckbert in 1982 (simple error
23743 diffusion). Note: this dithering is sometimes considered
23744 "wrong" and is included as a reference.
23745
23746 floyd_steinberg
23747 Floyd and Steingberg dithering (error diffusion)
23748
23749 sierra2
23750 Frankie Sierra dithering v2 (error diffusion)
23751
23752 sierra2_4a
23753 Frankie Sierra dithering v2 "Lite" (error diffusion)
23754
23755 Default is sierra2_4a.
23756
23757 bayer_scale
23758 When bayer dithering is selected, this option defines the scale of
23759 the pattern (how much the crosshatch pattern is visible). A low
23760 value means more visible pattern for less banding, and higher value
23761 means less visible pattern at the cost of more banding.
23762
23763 The option must be an integer value in the range [0,5]. Default is
23764 2.
23765
23766 diff_mode
23767 If set, define the zone to process
23768
23769 rectangle
23770 Only the changing rectangle will be reprocessed. This is
23771 similar to GIF cropping/offsetting compression mechanism. This
23772 option can be useful for speed if only a part of the image is
23773 changing, and has use cases such as limiting the scope of the
23774 error diffusal dither to the rectangle that bounds the moving
23775 scene (it leads to more deterministic output if the scene
23776 doesn't change much, and as a result less moving noise and
23777 better GIF compression).
23778
23779 Default is none.
23780
23781 new Take new palette for each output frame.
23782
23783 alpha_threshold
23784 Sets the alpha threshold for transparency. Alpha values above this
23785 threshold will be treated as completely opaque, and values below
23786 this threshold will be treated as completely transparent.
23787
23788 The option must be an integer value in the range [0,255]. Default
23789 is 128.
23790
23791 use_alpha
23792 Apply the palette by taking alpha values into account. Only useful
23793 with palettes that are containing multiple colors with alpha
23794 components. Setting this will automatically disable
23795 'alpha_treshold'.
23796
23797 Examples
23798
23799 • Use a palette (generated for example with palettegen) to encode a
23800 GIF using ffmpeg:
23801
23802 ffmpeg -i input.mkv -i palette.png -lavfi paletteuse output.gif
23803
23804 perspective
23805 Correct perspective of video not recorded perpendicular to the screen.
23806
23807 A description of the accepted parameters follows.
23808
23809 x0
23810 y0
23811 x1
23812 y1
23813 x2
23814 y2
23815 x3
23816 y3 Set coordinates expression for top left, top right, bottom left and
23817 bottom right corners. Default values are "0:0:W:0:0:H:W:H" with
23818 which perspective will remain unchanged. If the "sense" option is
23819 set to "source", then the specified points will be sent to the
23820 corners of the destination. If the "sense" option is set to
23821 "destination", then the corners of the source will be sent to the
23822 specified coordinates.
23823
23824 The expressions can use the following variables:
23825
23826 W
23827 H the width and height of video frame.
23828
23829 in Input frame count.
23830
23831 on Output frame count.
23832
23833 interpolation
23834 Set interpolation for perspective correction.
23835
23836 It accepts the following values:
23837
23838 linear
23839 cubic
23840
23841 Default value is linear.
23842
23843 sense
23844 Set interpretation of coordinate options.
23845
23846 It accepts the following values:
23847
23848 0, source
23849 Send point in the source specified by the given coordinates to
23850 the corners of the destination.
23851
23852 1, destination
23853 Send the corners of the source to the point in the destination
23854 specified by the given coordinates.
23855
23856 Default value is source.
23857
23858 eval
23859 Set when the expressions for coordinates x0,y0,...x3,y3 are
23860 evaluated.
23861
23862 It accepts the following values:
23863
23864 init
23865 only evaluate expressions once during the filter initialization
23866 or when a command is processed
23867
23868 frame
23869 evaluate expressions for each incoming frame
23870
23871 Default value is init.
23872
23873 phase
23874 Delay interlaced video by one field time so that the field order
23875 changes.
23876
23877 The intended use is to fix PAL movies that have been captured with the
23878 opposite field order to the film-to-video transfer.
23879
23880 A description of the accepted parameters follows.
23881
23882 mode
23883 Set phase mode.
23884
23885 It accepts the following values:
23886
23887 t Capture field order top-first, transfer bottom-first. Filter
23888 will delay the bottom field.
23889
23890 b Capture field order bottom-first, transfer top-first. Filter
23891 will delay the top field.
23892
23893 p Capture and transfer with the same field order. This mode only
23894 exists for the documentation of the other options to refer to,
23895 but if you actually select it, the filter will faithfully do
23896 nothing.
23897
23898 a Capture field order determined automatically by field flags,
23899 transfer opposite. Filter selects among t and b modes on a
23900 frame by frame basis using field flags. If no field information
23901 is available, then this works just like u.
23902
23903 u Capture unknown or varying, transfer opposite. Filter selects
23904 among t and b on a frame by frame basis by analyzing the images
23905 and selecting the alternative that produces best match between
23906 the fields.
23907
23908 T Capture top-first, transfer unknown or varying. Filter selects
23909 among t and p using image analysis.
23910
23911 B Capture bottom-first, transfer unknown or varying. Filter
23912 selects among b and p using image analysis.
23913
23914 A Capture determined by field flags, transfer unknown or varying.
23915 Filter selects among t, b and p using field flags and image
23916 analysis. If no field information is available, then this works
23917 just like U. This is the default mode.
23918
23919 U Both capture and transfer unknown or varying. Filter selects
23920 among t, b and p using image analysis only.
23921
23922 Commands
23923
23924 This filter supports the all above options as commands.
23925
23926 photosensitivity
23927 Reduce various flashes in video, so to help users with epilepsy.
23928
23929 It accepts the following options:
23930
23931 frames, f
23932 Set how many frames to use when filtering. Default is 30.
23933
23934 threshold, t
23935 Set detection threshold factor. Default is 1. Lower is stricter.
23936
23937 skip
23938 Set how many pixels to skip when sampling frames. Default is 1.
23939 Allowed range is from 1 to 1024.
23940
23941 bypass
23942 Leave frames unchanged. Default is disabled.
23943
23944 pixdesctest
23945 Pixel format descriptor test filter, mainly useful for internal
23946 testing. The output video should be equal to the input video.
23947
23948 For example:
23949
23950 format=monow, pixdesctest
23951
23952 can be used to test the monowhite pixel format descriptor definition.
23953
23954 pixscope
23955 Display sample values of color channels. Mainly useful for checking
23956 color and levels. Minimum supported resolution is 640x480.
23957
23958 The filters accept the following options:
23959
23960 x Set scope X position, relative offset on X axis.
23961
23962 y Set scope Y position, relative offset on Y axis.
23963
23964 w Set scope width.
23965
23966 h Set scope height.
23967
23968 o Set window opacity. This window also holds statistics about pixel
23969 area.
23970
23971 wx Set window X position, relative offset on X axis.
23972
23973 wy Set window Y position, relative offset on Y axis.
23974
23975 Commands
23976
23977 This filter supports same commands as options.
23978
23979 pp
23980 Enable the specified chain of postprocessing subfilters using
23981 libpostproc. This library should be automatically selected with a GPL
23982 build ("--enable-gpl"). Subfilters must be separated by '/' and can be
23983 disabled by prepending a '-'. Each subfilter and some options have a
23984 short and a long name that can be used interchangeably, i.e. dr/dering
23985 are the same.
23986
23987 The filters accept the following options:
23988
23989 subfilters
23990 Set postprocessing subfilters string.
23991
23992 All subfilters share common options to determine their scope:
23993
23994 a/autoq
23995 Honor the quality commands for this subfilter.
23996
23997 c/chrom
23998 Do chrominance filtering, too (default).
23999
24000 y/nochrom
24001 Do luminance filtering only (no chrominance).
24002
24003 n/noluma
24004 Do chrominance filtering only (no luminance).
24005
24006 These options can be appended after the subfilter name, separated by a
24007 '|'.
24008
24009 Available subfilters are:
24010
24011 hb/hdeblock[|difference[|flatness]]
24012 Horizontal deblocking filter
24013
24014 difference
24015 Difference factor where higher values mean more deblocking
24016 (default: 32).
24017
24018 flatness
24019 Flatness threshold where lower values mean more deblocking
24020 (default: 39).
24021
24022 vb/vdeblock[|difference[|flatness]]
24023 Vertical deblocking filter
24024
24025 difference
24026 Difference factor where higher values mean more deblocking
24027 (default: 32).
24028
24029 flatness
24030 Flatness threshold where lower values mean more deblocking
24031 (default: 39).
24032
24033 ha/hadeblock[|difference[|flatness]]
24034 Accurate horizontal deblocking filter
24035
24036 difference
24037 Difference factor where higher values mean more deblocking
24038 (default: 32).
24039
24040 flatness
24041 Flatness threshold where lower values mean more deblocking
24042 (default: 39).
24043
24044 va/vadeblock[|difference[|flatness]]
24045 Accurate vertical deblocking filter
24046
24047 difference
24048 Difference factor where higher values mean more deblocking
24049 (default: 32).
24050
24051 flatness
24052 Flatness threshold where lower values mean more deblocking
24053 (default: 39).
24054
24055 The horizontal and vertical deblocking filters share the difference and
24056 flatness values so you cannot set different horizontal and vertical
24057 thresholds.
24058
24059 h1/x1hdeblock
24060 Experimental horizontal deblocking filter
24061
24062 v1/x1vdeblock
24063 Experimental vertical deblocking filter
24064
24065 dr/dering
24066 Deringing filter
24067
24068 tn/tmpnoise[|threshold1[|threshold2[|threshold3]]], temporal noise
24069 reducer
24070 threshold1
24071 larger -> stronger filtering
24072
24073 threshold2
24074 larger -> stronger filtering
24075
24076 threshold3
24077 larger -> stronger filtering
24078
24079 al/autolevels[:f/fullyrange], automatic brightness / contrast
24080 correction
24081 f/fullyrange
24082 Stretch luminance to "0-255".
24083
24084 lb/linblenddeint
24085 Linear blend deinterlacing filter that deinterlaces the given block
24086 by filtering all lines with a "(1 2 1)" filter.
24087
24088 li/linipoldeint
24089 Linear interpolating deinterlacing filter that deinterlaces the
24090 given block by linearly interpolating every second line.
24091
24092 ci/cubicipoldeint
24093 Cubic interpolating deinterlacing filter deinterlaces the given
24094 block by cubically interpolating every second line.
24095
24096 md/mediandeint
24097 Median deinterlacing filter that deinterlaces the given block by
24098 applying a median filter to every second line.
24099
24100 fd/ffmpegdeint
24101 FFmpeg deinterlacing filter that deinterlaces the given block by
24102 filtering every second line with a "(-1 4 2 4 -1)" filter.
24103
24104 l5/lowpass5
24105 Vertically applied FIR lowpass deinterlacing filter that
24106 deinterlaces the given block by filtering all lines with a "(-1 2 6
24107 2 -1)" filter.
24108
24109 fq/forceQuant[|quantizer]
24110 Overrides the quantizer table from the input with the constant
24111 quantizer you specify.
24112
24113 quantizer
24114 Quantizer to use
24115
24116 de/default
24117 Default pp filter combination ("hb|a,vb|a,dr|a")
24118
24119 fa/fast
24120 Fast pp filter combination ("h1|a,v1|a,dr|a")
24121
24122 ac High quality pp filter combination ("ha|a|128|7,va|a,dr|a")
24123
24124 Examples
24125
24126 • Apply horizontal and vertical deblocking, deringing and automatic
24127 brightness/contrast:
24128
24129 pp=hb/vb/dr/al
24130
24131 • Apply default filters without brightness/contrast correction:
24132
24133 pp=de/-al
24134
24135 • Apply default filters and temporal denoiser:
24136
24137 pp=default/tmpnoise|1|2|3
24138
24139 • Apply deblocking on luminance only, and switch vertical deblocking
24140 on or off automatically depending on available CPU time:
24141
24142 pp=hb|y/vb|a
24143
24144 pp7
24145 Apply Postprocessing filter 7. It is variant of the spp filter, similar
24146 to spp = 6 with 7 point DCT, where only the center sample is used after
24147 IDCT.
24148
24149 The filter accepts the following options:
24150
24151 qp Force a constant quantization parameter. It accepts an integer in
24152 range 0 to 63. If not set, the filter will use the QP from the
24153 video stream (if available).
24154
24155 mode
24156 Set thresholding mode. Available modes are:
24157
24158 hard
24159 Set hard thresholding.
24160
24161 soft
24162 Set soft thresholding (better de-ringing effect, but likely
24163 blurrier).
24164
24165 medium
24166 Set medium thresholding (good results, default).
24167
24168 premultiply
24169 Apply alpha premultiply effect to input video stream using first plane
24170 of second stream as alpha.
24171
24172 Both streams must have same dimensions and same pixel format.
24173
24174 The filter accepts the following option:
24175
24176 planes
24177 Set which planes will be processed, unprocessed planes will be
24178 copied. By default value 0xf, all planes will be processed.
24179
24180 inplace
24181 Do not require 2nd input for processing, instead use alpha plane
24182 from input stream.
24183
24184 prewitt
24185 Apply prewitt operator to input video stream.
24186
24187 The filter accepts the following option:
24188
24189 planes
24190 Set which planes will be processed, unprocessed planes will be
24191 copied. By default value 0xf, all planes will be processed.
24192
24193 scale
24194 Set value which will be multiplied with filtered result.
24195
24196 delta
24197 Set value which will be added to filtered result.
24198
24199 Commands
24200
24201 This filter supports the all above options as commands.
24202
24203 pseudocolor
24204 Alter frame colors in video with pseudocolors.
24205
24206 This filter accepts the following options:
24207
24208 c0 set pixel first component expression
24209
24210 c1 set pixel second component expression
24211
24212 c2 set pixel third component expression
24213
24214 c3 set pixel fourth component expression, corresponds to the alpha
24215 component
24216
24217 index, i
24218 set component to use as base for altering colors
24219
24220 preset, p
24221 Pick one of built-in LUTs. By default is set to none.
24222
24223 Available LUTs:
24224
24225 magma
24226 inferno
24227 plasma
24228 viridis
24229 turbo
24230 cividis
24231 range1
24232 range2
24233 shadows
24234 highlights
24235 solar
24236 nominal
24237 preferred
24238 total
24239 opacity
24240 Set opacity of output colors. Allowed range is from 0 to 1.
24241 Default value is set to 1.
24242
24243 Each of the expression options specifies the expression to use for
24244 computing the lookup table for the corresponding pixel component
24245 values.
24246
24247 The expressions can contain the following constants and functions:
24248
24249 w
24250 h The input width and height.
24251
24252 val The input value for the pixel component.
24253
24254 ymin, umin, vmin, amin
24255 The minimum allowed component value.
24256
24257 ymax, umax, vmax, amax
24258 The maximum allowed component value.
24259
24260 All expressions default to "val".
24261
24262 Commands
24263
24264 This filter supports the all above options as commands.
24265
24266 Examples
24267
24268 • Change too high luma values to gradient:
24269
24270 pseudocolor="'if(between(val,ymax,amax),lerp(ymin,ymax,(val-ymax)/(amax-ymax)),-1):if(between(val,ymax,amax),lerp(umax,umin,(val-ymax)/(amax-ymax)),-1):if(between(val,ymax,amax),lerp(vmin,vmax,(val-ymax)/(amax-ymax)),-1):-1'"
24271
24272 psnr
24273 Obtain the average, maximum and minimum PSNR (Peak Signal to Noise
24274 Ratio) between two input videos.
24275
24276 This filter takes in input two input videos, the first input is
24277 considered the "main" source and is passed unchanged to the output. The
24278 second input is used as a "reference" video for computing the PSNR.
24279
24280 Both video inputs must have the same resolution and pixel format for
24281 this filter to work correctly. Also it assumes that both inputs have
24282 the same number of frames, which are compared one by one.
24283
24284 The obtained average PSNR is printed through the logging system.
24285
24286 The filter stores the accumulated MSE (mean squared error) of each
24287 frame, and at the end of the processing it is averaged across all
24288 frames equally, and the following formula is applied to obtain the
24289 PSNR:
24290
24291 PSNR = 10*log10(MAX^2/MSE)
24292
24293 Where MAX is the average of the maximum values of each component of the
24294 image.
24295
24296 The description of the accepted parameters follows.
24297
24298 stats_file, f
24299 If specified the filter will use the named file to save the PSNR of
24300 each individual frame. When filename equals "-" the data is sent to
24301 standard output.
24302
24303 stats_version
24304 Specifies which version of the stats file format to use. Details of
24305 each format are written below. Default value is 1.
24306
24307 stats_add_max
24308 Determines whether the max value is output to the stats log.
24309 Default value is 0. Requires stats_version >= 2. If this is set
24310 and stats_version < 2, the filter will return an error.
24311
24312 This filter also supports the framesync options.
24313
24314 The file printed if stats_file is selected, contains a sequence of
24315 key/value pairs of the form key:value for each compared couple of
24316 frames.
24317
24318 If a stats_version greater than 1 is specified, a header line precedes
24319 the list of per-frame-pair stats, with key value pairs following the
24320 frame format with the following parameters:
24321
24322 psnr_log_version
24323 The version of the log file format. Will match stats_version.
24324
24325 fields
24326 A comma separated list of the per-frame-pair parameters included in
24327 the log.
24328
24329 A description of each shown per-frame-pair parameter follows:
24330
24331 n sequential number of the input frame, starting from 1
24332
24333 mse_avg
24334 Mean Square Error pixel-by-pixel average difference of the compared
24335 frames, averaged over all the image components.
24336
24337 mse_y, mse_u, mse_v, mse_r, mse_g, mse_b, mse_a
24338 Mean Square Error pixel-by-pixel average difference of the compared
24339 frames for the component specified by the suffix.
24340
24341 psnr_y, psnr_u, psnr_v, psnr_r, psnr_g, psnr_b, psnr_a
24342 Peak Signal to Noise ratio of the compared frames for the component
24343 specified by the suffix.
24344
24345 max_avg, max_y, max_u, max_v
24346 Maximum allowed value for each channel, and average over all
24347 channels.
24348
24349 Examples
24350
24351 • For example:
24352
24353 movie=ref_movie.mpg, setpts=PTS-STARTPTS [main];
24354 [main][ref] psnr="stats_file=stats.log" [out]
24355
24356 On this example the input file being processed is compared with the
24357 reference file ref_movie.mpg. The PSNR of each individual frame is
24358 stored in stats.log.
24359
24360 • Another example with different containers:
24361
24362 ffmpeg -i main.mpg -i ref.mkv -lavfi "[0:v]settb=AVTB,setpts=PTS-STARTPTS[main];[1:v]settb=AVTB,setpts=PTS-STARTPTS[ref];[main][ref]psnr" -f null -
24363
24364 pullup
24365 Pulldown reversal (inverse telecine) filter, capable of handling mixed
24366 hard-telecine, 24000/1001 fps progressive, and 30000/1001 fps
24367 progressive content.
24368
24369 The pullup filter is designed to take advantage of future context in
24370 making its decisions. This filter is stateless in the sense that it
24371 does not lock onto a pattern to follow, but it instead looks forward to
24372 the following fields in order to identify matches and rebuild
24373 progressive frames.
24374
24375 To produce content with an even framerate, insert the fps filter after
24376 pullup, use "fps=24000/1001" if the input frame rate is 29.97fps,
24377 "fps=24" for 30fps and the (rare) telecined 25fps input.
24378
24379 The filter accepts the following options:
24380
24381 jl
24382 jr
24383 jt
24384 jb These options set the amount of "junk" to ignore at the left,
24385 right, top, and bottom of the image, respectively. Left and right
24386 are in units of 8 pixels, while top and bottom are in units of 2
24387 lines. The default is 8 pixels on each side.
24388
24389 sb Set the strict breaks. Setting this option to 1 will reduce the
24390 chances of filter generating an occasional mismatched frame, but it
24391 may also cause an excessive number of frames to be dropped during
24392 high motion sequences. Conversely, setting it to -1 will make
24393 filter match fields more easily. This may help processing of video
24394 where there is slight blurring between the fields, but may also
24395 cause there to be interlaced frames in the output. Default value
24396 is 0.
24397
24398 mp Set the metric plane to use. It accepts the following values:
24399
24400 l Use luma plane.
24401
24402 u Use chroma blue plane.
24403
24404 v Use chroma red plane.
24405
24406 This option may be set to use chroma plane instead of the default
24407 luma plane for doing filter's computations. This may improve
24408 accuracy on very clean source material, but more likely will
24409 decrease accuracy, especially if there is chroma noise (rainbow
24410 effect) or any grayscale video. The main purpose of setting mp to
24411 a chroma plane is to reduce CPU load and make pullup usable in
24412 realtime on slow machines.
24413
24414 For best results (without duplicated frames in the output file) it is
24415 necessary to change the output frame rate. For example, to inverse
24416 telecine NTSC input:
24417
24418 ffmpeg -i input -vf pullup -r 24000/1001 ...
24419
24420 qp
24421 Change video quantization parameters (QP).
24422
24423 The filter accepts the following option:
24424
24425 qp Set expression for quantization parameter.
24426
24427 The expression is evaluated through the eval API and can contain, among
24428 others, the following constants:
24429
24430 known
24431 1 if index is not 129, 0 otherwise.
24432
24433 qp Sequential index starting from -129 to 128.
24434
24435 Examples
24436
24437 • Some equation like:
24438
24439 qp=2+2*sin(PI*qp)
24440
24441 random
24442 Flush video frames from internal cache of frames into a random order.
24443 No frame is discarded. Inspired by frei0r nervous filter.
24444
24445 frames
24446 Set size in number of frames of internal cache, in range from 2 to
24447 512. Default is 30.
24448
24449 seed
24450 Set seed for random number generator, must be an integer included
24451 between 0 and "UINT32_MAX". If not specified, or if explicitly set
24452 to less than 0, the filter will try to use a good random seed on a
24453 best effort basis.
24454
24455 readeia608
24456 Read closed captioning (EIA-608) information from the top lines of a
24457 video frame.
24458
24459 This filter adds frame metadata for "lavfi.readeia608.X.cc" and
24460 "lavfi.readeia608.X.line", where "X" is the number of the identified
24461 line with EIA-608 data (starting from 0). A description of each
24462 metadata value follows:
24463
24464 lavfi.readeia608.X.cc
24465 The two bytes stored as EIA-608 data (printed in hexadecimal).
24466
24467 lavfi.readeia608.X.line
24468 The number of the line on which the EIA-608 data was identified and
24469 read.
24470
24471 This filter accepts the following options:
24472
24473 scan_min
24474 Set the line to start scanning for EIA-608 data. Default is 0.
24475
24476 scan_max
24477 Set the line to end scanning for EIA-608 data. Default is 29.
24478
24479 spw Set the ratio of width reserved for sync code detection. Default
24480 is 0.27. Allowed range is "[0.1 - 0.7]".
24481
24482 chp Enable checking the parity bit. In the event of a parity error, the
24483 filter will output 0x00 for that character. Default is false.
24484
24485 lp Lowpass lines prior to further processing. Default is enabled.
24486
24487 Commands
24488
24489 This filter supports the all above options as commands.
24490
24491 Examples
24492
24493 • Output a csv with presentation time and the first two lines of
24494 identified EIA-608 captioning data.
24495
24496 ffprobe -f lavfi -i movie=captioned_video.mov,readeia608 -show_entries frame=pts_time:frame_tags=lavfi.readeia608.0.cc,lavfi.readeia608.1.cc -of csv
24497
24498 readvitc
24499 Read vertical interval timecode (VITC) information from the top lines
24500 of a video frame.
24501
24502 The filter adds frame metadata key "lavfi.readvitc.tc_str" with the
24503 timecode value, if a valid timecode has been detected. Further metadata
24504 key "lavfi.readvitc.found" is set to 0/1 depending on whether timecode
24505 data has been found or not.
24506
24507 This filter accepts the following options:
24508
24509 scan_max
24510 Set the maximum number of lines to scan for VITC data. If the value
24511 is set to "-1" the full video frame is scanned. Default is 45.
24512
24513 thr_b
24514 Set the luma threshold for black. Accepts float numbers in the
24515 range [0.0,1.0], default value is 0.2. The value must be equal or
24516 less than "thr_w".
24517
24518 thr_w
24519 Set the luma threshold for white. Accepts float numbers in the
24520 range [0.0,1.0], default value is 0.6. The value must be equal or
24521 greater than "thr_b".
24522
24523 Examples
24524
24525 • Detect and draw VITC data onto the video frame; if no valid VITC is
24526 detected, draw "--:--:--:--" as a placeholder:
24527
24528 ffmpeg -i input.avi -filter:v 'readvitc,drawtext=fontfile=FreeMono.ttf:text=%{metadata\\:lavfi.readvitc.tc_str\\:--\\\\\\:--\\\\\\:--\\\\\\:--}:x=(w-tw)/2:y=400-ascent'
24529
24530 remap
24531 Remap pixels using 2nd: Xmap and 3rd: Ymap input video stream.
24532
24533 Destination pixel at position (X, Y) will be picked from source (x, y)
24534 position where x = Xmap(X, Y) and y = Ymap(X, Y). If mapping values are
24535 out of range, zero value for pixel will be used for destination pixel.
24536
24537 Xmap and Ymap input video streams must be of same dimensions. Output
24538 video stream will have Xmap/Ymap video stream dimensions. Xmap and
24539 Ymap input video streams are 16bit depth, single channel.
24540
24541 format
24542 Specify pixel format of output from this filter. Can be "color" or
24543 "gray". Default is "color".
24544
24545 fill
24546 Specify the color of the unmapped pixels. For the syntax of this
24547 option, check the "Color" section in the ffmpeg-utils manual.
24548 Default color is "black".
24549
24550 removegrain
24551 The removegrain filter is a spatial denoiser for progressive video.
24552
24553 m0 Set mode for the first plane.
24554
24555 m1 Set mode for the second plane.
24556
24557 m2 Set mode for the third plane.
24558
24559 m3 Set mode for the fourth plane.
24560
24561 Range of mode is from 0 to 24. Description of each mode follows:
24562
24563 0 Leave input plane unchanged. Default.
24564
24565 1 Clips the pixel with the minimum and maximum of the 8 neighbour
24566 pixels.
24567
24568 2 Clips the pixel with the second minimum and maximum of the 8
24569 neighbour pixels.
24570
24571 3 Clips the pixel with the third minimum and maximum of the 8
24572 neighbour pixels.
24573
24574 4 Clips the pixel with the fourth minimum and maximum of the 8
24575 neighbour pixels. This is equivalent to a median filter.
24576
24577 5 Line-sensitive clipping giving the minimal change.
24578
24579 6 Line-sensitive clipping, intermediate.
24580
24581 7 Line-sensitive clipping, intermediate.
24582
24583 8 Line-sensitive clipping, intermediate.
24584
24585 9 Line-sensitive clipping on a line where the neighbours pixels are
24586 the closest.
24587
24588 10 Replaces the target pixel with the closest neighbour.
24589
24590 11 [1 2 1] horizontal and vertical kernel blur.
24591
24592 12 Same as mode 11.
24593
24594 13 Bob mode, interpolates top field from the line where the neighbours
24595 pixels are the closest.
24596
24597 14 Bob mode, interpolates bottom field from the line where the
24598 neighbours pixels are the closest.
24599
24600 15 Bob mode, interpolates top field. Same as 13 but with a more
24601 complicated interpolation formula.
24602
24603 16 Bob mode, interpolates bottom field. Same as 14 but with a more
24604 complicated interpolation formula.
24605
24606 17 Clips the pixel with the minimum and maximum of respectively the
24607 maximum and minimum of each pair of opposite neighbour pixels.
24608
24609 18 Line-sensitive clipping using opposite neighbours whose greatest
24610 distance from the current pixel is minimal.
24611
24612 19 Replaces the pixel with the average of its 8 neighbours.
24613
24614 20 Averages the 9 pixels ([1 1 1] horizontal and vertical blur).
24615
24616 21 Clips pixels using the averages of opposite neighbour.
24617
24618 22 Same as mode 21 but simpler and faster.
24619
24620 23 Small edge and halo removal, but reputed useless.
24621
24622 24 Similar as 23.
24623
24624 removelogo
24625 Suppress a TV station logo, using an image file to determine which
24626 pixels comprise the logo. It works by filling in the pixels that
24627 comprise the logo with neighboring pixels.
24628
24629 The filter accepts the following options:
24630
24631 filename, f
24632 Set the filter bitmap file, which can be any image format supported
24633 by libavformat. The width and height of the image file must match
24634 those of the video stream being processed.
24635
24636 Pixels in the provided bitmap image with a value of zero are not
24637 considered part of the logo, non-zero pixels are considered part of the
24638 logo. If you use white (255) for the logo and black (0) for the rest,
24639 you will be safe. For making the filter bitmap, it is recommended to
24640 take a screen capture of a black frame with the logo visible, and then
24641 using a threshold filter followed by the erode filter once or twice.
24642
24643 If needed, little splotches can be fixed manually. Remember that if
24644 logo pixels are not covered, the filter quality will be much reduced.
24645 Marking too many pixels as part of the logo does not hurt as much, but
24646 it will increase the amount of blurring needed to cover over the image
24647 and will destroy more information than necessary, and extra pixels will
24648 slow things down on a large logo.
24649
24650 repeatfields
24651 This filter uses the repeat_field flag from the Video ES headers and
24652 hard repeats fields based on its value.
24653
24654 reverse
24655 Reverse a video clip.
24656
24657 Warning: This filter requires memory to buffer the entire clip, so
24658 trimming is suggested.
24659
24660 Examples
24661
24662 • Take the first 5 seconds of a clip, and reverse it.
24663
24664 trim=end=5,reverse
24665
24666 rgbashift
24667 Shift R/G/B/A pixels horizontally and/or vertically.
24668
24669 The filter accepts the following options:
24670
24671 rh Set amount to shift red horizontally.
24672
24673 rv Set amount to shift red vertically.
24674
24675 gh Set amount to shift green horizontally.
24676
24677 gv Set amount to shift green vertically.
24678
24679 bh Set amount to shift blue horizontally.
24680
24681 bv Set amount to shift blue vertically.
24682
24683 ah Set amount to shift alpha horizontally.
24684
24685 av Set amount to shift alpha vertically.
24686
24687 edge
24688 Set edge mode, can be smear, default, or warp.
24689
24690 Commands
24691
24692 This filter supports the all above options as commands.
24693
24694 roberts
24695 Apply roberts cross operator to input video stream.
24696
24697 The filter accepts the following option:
24698
24699 planes
24700 Set which planes will be processed, unprocessed planes will be
24701 copied. By default value 0xf, all planes will be processed.
24702
24703 scale
24704 Set value which will be multiplied with filtered result.
24705
24706 delta
24707 Set value which will be added to filtered result.
24708
24709 Commands
24710
24711 This filter supports the all above options as commands.
24712
24713 rotate
24714 Rotate video by an arbitrary angle expressed in radians.
24715
24716 The filter accepts the following options:
24717
24718 A description of the optional parameters follows.
24719
24720 angle, a
24721 Set an expression for the angle by which to rotate the input video
24722 clockwise, expressed as a number of radians. A negative value will
24723 result in a counter-clockwise rotation. By default it is set to
24724 "0".
24725
24726 This expression is evaluated for each frame.
24727
24728 out_w, ow
24729 Set the output width expression, default value is "iw". This
24730 expression is evaluated just once during configuration.
24731
24732 out_h, oh
24733 Set the output height expression, default value is "ih". This
24734 expression is evaluated just once during configuration.
24735
24736 bilinear
24737 Enable bilinear interpolation if set to 1, a value of 0 disables
24738 it. Default value is 1.
24739
24740 fillcolor, c
24741 Set the color used to fill the output area not covered by the
24742 rotated image. For the general syntax of this option, check the
24743 "Color" section in the ffmpeg-utils manual. If the special value
24744 "none" is selected then no background is printed (useful for
24745 example if the background is never shown).
24746
24747 Default value is "black".
24748
24749 The expressions for the angle and the output size can contain the
24750 following constants and functions:
24751
24752 n sequential number of the input frame, starting from 0. It is always
24753 NAN before the first frame is filtered.
24754
24755 t time in seconds of the input frame, it is set to 0 when the filter
24756 is configured. It is always NAN before the first frame is filtered.
24757
24758 hsub
24759 vsub
24760 horizontal and vertical chroma subsample values. For example for
24761 the pixel format "yuv422p" hsub is 2 and vsub is 1.
24762
24763 in_w, iw
24764 in_h, ih
24765 the input video width and height
24766
24767 out_w, ow
24768 out_h, oh
24769 the output width and height, that is the size of the padded area as
24770 specified by the width and height expressions
24771
24772 rotw(a)
24773 roth(a)
24774 the minimal width/height required for completely containing the
24775 input video rotated by a radians.
24776
24777 These are only available when computing the out_w and out_h
24778 expressions.
24779
24780 Examples
24781
24782 • Rotate the input by PI/6 radians clockwise:
24783
24784 rotate=PI/6
24785
24786 • Rotate the input by PI/6 radians counter-clockwise:
24787
24788 rotate=-PI/6
24789
24790 • Rotate the input by 45 degrees clockwise:
24791
24792 rotate=45*PI/180
24793
24794 • Apply a constant rotation with period T, starting from an angle of
24795 PI/3:
24796
24797 rotate=PI/3+2*PI*t/T
24798
24799 • Make the input video rotation oscillating with a period of T
24800 seconds and an amplitude of A radians:
24801
24802 rotate=A*sin(2*PI/T*t)
24803
24804 • Rotate the video, output size is chosen so that the whole rotating
24805 input video is always completely contained in the output:
24806
24807 rotate='2*PI*t:ow=hypot(iw,ih):oh=ow'
24808
24809 • Rotate the video, reduce the output size so that no background is
24810 ever shown:
24811
24812 rotate=2*PI*t:ow='min(iw,ih)/sqrt(2)':oh=ow:c=none
24813
24814 Commands
24815
24816 The filter supports the following commands:
24817
24818 a, angle
24819 Set the angle expression. The command accepts the same syntax of
24820 the corresponding option.
24821
24822 If the specified expression is not valid, it is kept at its current
24823 value.
24824
24825 sab
24826 Apply Shape Adaptive Blur.
24827
24828 The filter accepts the following options:
24829
24830 luma_radius, lr
24831 Set luma blur filter strength, must be a value in range 0.1-4.0,
24832 default value is 1.0. A greater value will result in a more blurred
24833 image, and in slower processing.
24834
24835 luma_pre_filter_radius, lpfr
24836 Set luma pre-filter radius, must be a value in the 0.1-2.0 range,
24837 default value is 1.0.
24838
24839 luma_strength, ls
24840 Set luma maximum difference between pixels to still be considered,
24841 must be a value in the 0.1-100.0 range, default value is 1.0.
24842
24843 chroma_radius, cr
24844 Set chroma blur filter strength, must be a value in range -0.9-4.0.
24845 A greater value will result in a more blurred image, and in slower
24846 processing.
24847
24848 chroma_pre_filter_radius, cpfr
24849 Set chroma pre-filter radius, must be a value in the -0.9-2.0
24850 range.
24851
24852 chroma_strength, cs
24853 Set chroma maximum difference between pixels to still be
24854 considered, must be a value in the -0.9-100.0 range.
24855
24856 Each chroma option value, if not explicitly specified, is set to the
24857 corresponding luma option value.
24858
24859 scale
24860 Scale (resize) the input video, using the libswscale library.
24861
24862 The scale filter forces the output display aspect ratio to be the same
24863 of the input, by changing the output sample aspect ratio.
24864
24865 If the input image format is different from the format requested by the
24866 next filter, the scale filter will convert the input to the requested
24867 format.
24868
24869 Options
24870
24871 The filter accepts the following options, or any of the options
24872 supported by the libswscale scaler.
24873
24874 See the ffmpeg-scaler manual for the complete list of scaler options.
24875
24876 width, w
24877 height, h
24878 Set the output video dimension expression. Default value is the
24879 input dimension.
24880
24881 If the width or w value is 0, the input width is used for the
24882 output. If the height or h value is 0, the input height is used for
24883 the output.
24884
24885 If one and only one of the values is -n with n >= 1, the scale
24886 filter will use a value that maintains the aspect ratio of the
24887 input image, calculated from the other specified dimension. After
24888 that it will, however, make sure that the calculated dimension is
24889 divisible by n and adjust the value if necessary.
24890
24891 If both values are -n with n >= 1, the behavior will be identical
24892 to both values being set to 0 as previously detailed.
24893
24894 See below for the list of accepted constants for use in the
24895 dimension expression.
24896
24897 eval
24898 Specify when to evaluate width and height expression. It accepts
24899 the following values:
24900
24901 init
24902 Only evaluate expressions once during the filter initialization
24903 or when a command is processed.
24904
24905 frame
24906 Evaluate expressions for each incoming frame.
24907
24908 Default value is init.
24909
24910 interl
24911 Set the interlacing mode. It accepts the following values:
24912
24913 1 Force interlaced aware scaling.
24914
24915 0 Do not apply interlaced scaling.
24916
24917 -1 Select interlaced aware scaling depending on whether the source
24918 frames are flagged as interlaced or not.
24919
24920 Default value is 0.
24921
24922 flags
24923 Set libswscale scaling flags. See the ffmpeg-scaler manual for the
24924 complete list of values. If not explicitly specified the filter
24925 applies the default flags.
24926
24927 param0, param1
24928 Set libswscale input parameters for scaling algorithms that need
24929 them. See the ffmpeg-scaler manual for the complete documentation.
24930 If not explicitly specified the filter applies empty parameters.
24931
24932 size, s
24933 Set the video size. For the syntax of this option, check the "Video
24934 size" section in the ffmpeg-utils manual.
24935
24936 in_color_matrix
24937 out_color_matrix
24938 Set in/output YCbCr color space type.
24939
24940 This allows the autodetected value to be overridden as well as
24941 allows forcing a specific value used for the output and encoder.
24942
24943 If not specified, the color space type depends on the pixel format.
24944
24945 Possible values:
24946
24947 auto
24948 Choose automatically.
24949
24950 bt709
24951 Format conforming to International Telecommunication Union
24952 (ITU) Recommendation BT.709.
24953
24954 fcc Set color space conforming to the United States Federal
24955 Communications Commission (FCC) Code of Federal Regulations
24956 (CFR) Title 47 (2003) 73.682 (a).
24957
24958 bt601
24959 bt470
24960 smpte170m
24961 Set color space conforming to:
24962
24963 • ITU Radiocommunication Sector (ITU-R) Recommendation BT.601
24964
24965 • ITU-R Rec. BT.470-6 (1998) Systems B, B1, and G
24966
24967 • Society of Motion Picture and Television Engineers (SMPTE)
24968 ST 170:2004
24969
24970 smpte240m
24971 Set color space conforming to SMPTE ST 240:1999.
24972
24973 bt2020
24974 Set color space conforming to ITU-R BT.2020 non-constant
24975 luminance system.
24976
24977 in_range
24978 out_range
24979 Set in/output YCbCr sample range.
24980
24981 This allows the autodetected value to be overridden as well as
24982 allows forcing a specific value used for the output and encoder. If
24983 not specified, the range depends on the pixel format. Possible
24984 values:
24985
24986 auto/unknown
24987 Choose automatically.
24988
24989 jpeg/full/pc
24990 Set full range (0-255 in case of 8-bit luma).
24991
24992 mpeg/limited/tv
24993 Set "MPEG" range (16-235 in case of 8-bit luma).
24994
24995 force_original_aspect_ratio
24996 Enable decreasing or increasing output video width or height if
24997 necessary to keep the original aspect ratio. Possible values:
24998
24999 disable
25000 Scale the video as specified and disable this feature.
25001
25002 decrease
25003 The output video dimensions will automatically be decreased if
25004 needed.
25005
25006 increase
25007 The output video dimensions will automatically be increased if
25008 needed.
25009
25010 One useful instance of this option is that when you know a specific
25011 device's maximum allowed resolution, you can use this to limit the
25012 output video to that, while retaining the aspect ratio. For
25013 example, device A allows 1280x720 playback, and your video is
25014 1920x800. Using this option (set it to decrease) and specifying
25015 1280x720 to the command line makes the output 1280x533.
25016
25017 Please note that this is a different thing than specifying -1 for w
25018 or h, you still need to specify the output resolution for this
25019 option to work.
25020
25021 force_divisible_by
25022 Ensures that both the output dimensions, width and height, are
25023 divisible by the given integer when used together with
25024 force_original_aspect_ratio. This works similar to using "-n" in
25025 the w and h options.
25026
25027 This option respects the value set for force_original_aspect_ratio,
25028 increasing or decreasing the resolution accordingly. The video's
25029 aspect ratio may be slightly modified.
25030
25031 This option can be handy if you need to have a video fit within or
25032 exceed a defined resolution using force_original_aspect_ratio but
25033 also have encoder restrictions on width or height divisibility.
25034
25035 The values of the w and h options are expressions containing the
25036 following constants:
25037
25038 in_w
25039 in_h
25040 The input width and height
25041
25042 iw
25043 ih These are the same as in_w and in_h.
25044
25045 out_w
25046 out_h
25047 The output (scaled) width and height
25048
25049 ow
25050 oh These are the same as out_w and out_h
25051
25052 a The same as iw / ih
25053
25054 sar input sample aspect ratio
25055
25056 dar The input display aspect ratio. Calculated from "(iw / ih) * sar".
25057
25058 hsub
25059 vsub
25060 horizontal and vertical input chroma subsample values. For example
25061 for the pixel format "yuv422p" hsub is 2 and vsub is 1.
25062
25063 ohsub
25064 ovsub
25065 horizontal and vertical output chroma subsample values. For example
25066 for the pixel format "yuv422p" hsub is 2 and vsub is 1.
25067
25068 n The (sequential) number of the input frame, starting from 0. Only
25069 available with "eval=frame".
25070
25071 t The presentation timestamp of the input frame, expressed as a
25072 number of seconds. Only available with "eval=frame".
25073
25074 pos The position (byte offset) of the frame in the input stream, or NaN
25075 if this information is unavailable and/or meaningless (for example
25076 in case of synthetic video). Only available with "eval=frame".
25077
25078 Examples
25079
25080 • Scale the input video to a size of 200x100
25081
25082 scale=w=200:h=100
25083
25084 This is equivalent to:
25085
25086 scale=200:100
25087
25088 or:
25089
25090 scale=200x100
25091
25092 • Specify a size abbreviation for the output size:
25093
25094 scale=qcif
25095
25096 which can also be written as:
25097
25098 scale=size=qcif
25099
25100 • Scale the input to 2x:
25101
25102 scale=w=2*iw:h=2*ih
25103
25104 • The above is the same as:
25105
25106 scale=2*in_w:2*in_h
25107
25108 • Scale the input to 2x with forced interlaced scaling:
25109
25110 scale=2*iw:2*ih:interl=1
25111
25112 • Scale the input to half size:
25113
25114 scale=w=iw/2:h=ih/2
25115
25116 • Increase the width, and set the height to the same size:
25117
25118 scale=3/2*iw:ow
25119
25120 • Seek Greek harmony:
25121
25122 scale=iw:1/PHI*iw
25123 scale=ih*PHI:ih
25124
25125 • Increase the height, and set the width to 3/2 of the height:
25126
25127 scale=w=3/2*oh:h=3/5*ih
25128
25129 • Increase the size, making the size a multiple of the chroma
25130 subsample values:
25131
25132 scale="trunc(3/2*iw/hsub)*hsub:trunc(3/2*ih/vsub)*vsub"
25133
25134 • Increase the width to a maximum of 500 pixels, keeping the same
25135 aspect ratio as the input:
25136
25137 scale=w='min(500\, iw*3/2):h=-1'
25138
25139 • Make pixels square by combining scale and setsar:
25140
25141 scale='trunc(ih*dar):ih',setsar=1/1
25142
25143 • Make pixels square by combining scale and setsar, making sure the
25144 resulting resolution is even (required by some codecs):
25145
25146 scale='trunc(ih*dar/2)*2:trunc(ih/2)*2',setsar=1/1
25147
25148 Commands
25149
25150 This filter supports the following commands:
25151
25152 width, w
25153 height, h
25154 Set the output video dimension expression. The command accepts the
25155 same syntax of the corresponding option.
25156
25157 If the specified expression is not valid, it is kept at its current
25158 value.
25159
25160 scale_cuda
25161 Scale (resize) and convert (pixel format) the input video, using
25162 accelerated CUDA kernels. Setting the output width and height works in
25163 the same way as for the scale filter.
25164
25165 The filter accepts the following options:
25166
25167 w
25168 h Set the output video dimension expression. Default value is the
25169 input dimension.
25170
25171 Allows for the same expressions as the scale filter.
25172
25173 interp_algo
25174 Sets the algorithm used for scaling:
25175
25176 nearest
25177 Nearest neighbour
25178
25179 Used by default if input parameters match the desired output.
25180
25181 bilinear
25182 Bilinear
25183
25184 bicubic
25185 Bicubic
25186
25187 This is the default.
25188
25189 lanczos
25190 Lanczos
25191
25192 format
25193 Controls the output pixel format. By default, or if none is
25194 specified, the input pixel format is used.
25195
25196 The filter does not support converting between YUV and RGB pixel
25197 formats.
25198
25199 passthrough
25200 If set to 0, every frame is processed, even if no conversion is
25201 neccesary. This mode can be useful to use the filter as a buffer
25202 for a downstream frame-consumer that exhausts the limited decoder
25203 frame pool.
25204
25205 If set to 1, frames are passed through as-is if they match the
25206 desired output parameters. This is the default behaviour.
25207
25208 param
25209 Algorithm-Specific parameter.
25210
25211 Affects the curves of the bicubic algorithm.
25212
25213 force_original_aspect_ratio
25214 force_divisible_by
25215 Work the same as the identical scale filter options.
25216
25217 Examples
25218
25219 • Scale input to 720p, keeping aspect ratio and ensuring the output
25220 is yuv420p.
25221
25222 scale_cuda=-2:720:format=yuv420p
25223
25224 • Upscale to 4K using nearest neighbour algorithm.
25225
25226 scale_cuda=4096:2160:interp_algo=nearest
25227
25228 • Don't do any conversion or scaling, but copy all input frames into
25229 newly allocated ones. This can be useful to deal with a filter and
25230 encode chain that otherwise exhausts the decoders frame pool.
25231
25232 scale_cuda=passthrough=0
25233
25234 scale_npp
25235 Use the NVIDIA Performance Primitives (libnpp) to perform scaling
25236 and/or pixel format conversion on CUDA video frames. Setting the output
25237 width and height works in the same way as for the scale filter.
25238
25239 The following additional options are accepted:
25240
25241 format
25242 The pixel format of the output CUDA frames. If set to the string
25243 "same" (the default), the input format will be kept. Note that
25244 automatic format negotiation and conversion is not yet supported
25245 for hardware frames
25246
25247 interp_algo
25248 The interpolation algorithm used for resizing. One of the
25249 following:
25250
25251 nn Nearest neighbour.
25252
25253 linear
25254 cubic
25255 cubic2p_bspline
25256 2-parameter cubic (B=1, C=0)
25257
25258 cubic2p_catmullrom
25259 2-parameter cubic (B=0, C=1/2)
25260
25261 cubic2p_b05c03
25262 2-parameter cubic (B=1/2, C=3/10)
25263
25264 super
25265 Supersampling
25266
25267 lanczos
25268 force_original_aspect_ratio
25269 Enable decreasing or increasing output video width or height if
25270 necessary to keep the original aspect ratio. Possible values:
25271
25272 disable
25273 Scale the video as specified and disable this feature.
25274
25275 decrease
25276 The output video dimensions will automatically be decreased if
25277 needed.
25278
25279 increase
25280 The output video dimensions will automatically be increased if
25281 needed.
25282
25283 One useful instance of this option is that when you know a specific
25284 device's maximum allowed resolution, you can use this to limit the
25285 output video to that, while retaining the aspect ratio. For
25286 example, device A allows 1280x720 playback, and your video is
25287 1920x800. Using this option (set it to decrease) and specifying
25288 1280x720 to the command line makes the output 1280x533.
25289
25290 Please note that this is a different thing than specifying -1 for w
25291 or h, you still need to specify the output resolution for this
25292 option to work.
25293
25294 force_divisible_by
25295 Ensures that both the output dimensions, width and height, are
25296 divisible by the given integer when used together with
25297 force_original_aspect_ratio. This works similar to using "-n" in
25298 the w and h options.
25299
25300 This option respects the value set for force_original_aspect_ratio,
25301 increasing or decreasing the resolution accordingly. The video's
25302 aspect ratio may be slightly modified.
25303
25304 This option can be handy if you need to have a video fit within or
25305 exceed a defined resolution using force_original_aspect_ratio but
25306 also have encoder restrictions on width or height divisibility.
25307
25308 eval
25309 Specify when to evaluate width and height expression. It accepts
25310 the following values:
25311
25312 init
25313 Only evaluate expressions once during the filter initialization
25314 or when a command is processed.
25315
25316 frame
25317 Evaluate expressions for each incoming frame.
25318
25319 The values of the w and h options are expressions containing the
25320 following constants:
25321
25322 in_w
25323 in_h
25324 The input width and height
25325
25326 iw
25327 ih These are the same as in_w and in_h.
25328
25329 out_w
25330 out_h
25331 The output (scaled) width and height
25332
25333 ow
25334 oh These are the same as out_w and out_h
25335
25336 a The same as iw / ih
25337
25338 sar input sample aspect ratio
25339
25340 dar The input display aspect ratio. Calculated from "(iw / ih) * sar".
25341
25342 n The (sequential) number of the input frame, starting from 0. Only
25343 available with "eval=frame".
25344
25345 t The presentation timestamp of the input frame, expressed as a
25346 number of seconds. Only available with "eval=frame".
25347
25348 pos The position (byte offset) of the frame in the input stream, or NaN
25349 if this information is unavailable and/or meaningless (for example
25350 in case of synthetic video). Only available with "eval=frame".
25351
25352 scale2ref
25353 Scale (resize) the input video, based on a reference video.
25354
25355 See the scale filter for available options, scale2ref supports the same
25356 but uses the reference video instead of the main input as basis.
25357 scale2ref also supports the following additional constants for the w
25358 and h options:
25359
25360 main_w
25361 main_h
25362 The main input video's width and height
25363
25364 main_a
25365 The same as main_w / main_h
25366
25367 main_sar
25368 The main input video's sample aspect ratio
25369
25370 main_dar, mdar
25371 The main input video's display aspect ratio. Calculated from
25372 "(main_w / main_h) * main_sar".
25373
25374 main_hsub
25375 main_vsub
25376 The main input video's horizontal and vertical chroma subsample
25377 values. For example for the pixel format "yuv422p" hsub is 2 and
25378 vsub is 1.
25379
25380 main_n
25381 The (sequential) number of the main input frame, starting from 0.
25382 Only available with "eval=frame".
25383
25384 main_t
25385 The presentation timestamp of the main input frame, expressed as a
25386 number of seconds. Only available with "eval=frame".
25387
25388 main_pos
25389 The position (byte offset) of the frame in the main input stream,
25390 or NaN if this information is unavailable and/or meaningless (for
25391 example in case of synthetic video). Only available with
25392 "eval=frame".
25393
25394 Examples
25395
25396 • Scale a subtitle stream (b) to match the main video (a) in size
25397 before overlaying
25398
25399 'scale2ref[b][a];[a][b]overlay'
25400
25401 • Scale a logo to 1/10th the height of a video, while preserving its
25402 display aspect ratio.
25403
25404 [logo-in][video-in]scale2ref=w=oh*mdar:h=ih/10[logo-out][video-out]
25405
25406 Commands
25407
25408 This filter supports the following commands:
25409
25410 width, w
25411 height, h
25412 Set the output video dimension expression. The command accepts the
25413 same syntax of the corresponding option.
25414
25415 If the specified expression is not valid, it is kept at its current
25416 value.
25417
25418 scale2ref_npp
25419 Use the NVIDIA Performance Primitives (libnpp) to scale (resize) the
25420 input video, based on a reference video.
25421
25422 See the scale_npp filter for available options, scale2ref_npp supports
25423 the same but uses the reference video instead of the main input as
25424 basis. scale2ref_npp also supports the following additional constants
25425 for the w and h options:
25426
25427 main_w
25428 main_h
25429 The main input video's width and height
25430
25431 main_a
25432 The same as main_w / main_h
25433
25434 main_sar
25435 The main input video's sample aspect ratio
25436
25437 main_dar, mdar
25438 The main input video's display aspect ratio. Calculated from
25439 "(main_w / main_h) * main_sar".
25440
25441 main_n
25442 The (sequential) number of the main input frame, starting from 0.
25443 Only available with "eval=frame".
25444
25445 main_t
25446 The presentation timestamp of the main input frame, expressed as a
25447 number of seconds. Only available with "eval=frame".
25448
25449 main_pos
25450 The position (byte offset) of the frame in the main input stream,
25451 or NaN if this information is unavailable and/or meaningless (for
25452 example in case of synthetic video). Only available with
25453 "eval=frame".
25454
25455 Examples
25456
25457 • Scale a subtitle stream (b) to match the main video (a) in size
25458 before overlaying
25459
25460 'scale2ref_npp[b][a];[a][b]overlay_cuda'
25461
25462 • Scale a logo to 1/10th the height of a video, while preserving its
25463 display aspect ratio.
25464
25465 [logo-in][video-in]scale2ref_npp=w=oh*mdar:h=ih/10[logo-out][video-out]
25466
25467 scharr
25468 Apply scharr operator to input video stream.
25469
25470 The filter accepts the following option:
25471
25472 planes
25473 Set which planes will be processed, unprocessed planes will be
25474 copied. By default value 0xf, all planes will be processed.
25475
25476 scale
25477 Set value which will be multiplied with filtered result.
25478
25479 delta
25480 Set value which will be added to filtered result.
25481
25482 Commands
25483
25484 This filter supports the all above options as commands.
25485
25486 scroll
25487 Scroll input video horizontally and/or vertically by constant speed.
25488
25489 The filter accepts the following options:
25490
25491 horizontal, h
25492 Set the horizontal scrolling speed. Default is 0. Allowed range is
25493 from -1 to 1. Negative values changes scrolling direction.
25494
25495 vertical, v
25496 Set the vertical scrolling speed. Default is 0. Allowed range is
25497 from -1 to 1. Negative values changes scrolling direction.
25498
25499 hpos
25500 Set the initial horizontal scrolling position. Default is 0.
25501 Allowed range is from 0 to 1.
25502
25503 vpos
25504 Set the initial vertical scrolling position. Default is 0. Allowed
25505 range is from 0 to 1.
25506
25507 Commands
25508
25509 This filter supports the following commands:
25510
25511 horizontal, h
25512 Set the horizontal scrolling speed.
25513
25514 vertical, v
25515 Set the vertical scrolling speed.
25516
25517 scdet
25518 Detect video scene change.
25519
25520 This filter sets frame metadata with mafd between frame, the scene
25521 score, and forward the frame to the next filter, so they can use these
25522 metadata to detect scene change or others.
25523
25524 In addition, this filter logs a message and sets frame metadata when it
25525 detects a scene change by threshold.
25526
25527 "lavfi.scd.mafd" metadata keys are set with mafd for every frame.
25528
25529 "lavfi.scd.score" metadata keys are set with scene change score for
25530 every frame to detect scene change.
25531
25532 "lavfi.scd.time" metadata keys are set with current filtered frame time
25533 which detect scene change with threshold.
25534
25535 The filter accepts the following options:
25536
25537 threshold, t
25538 Set the scene change detection threshold as a percentage of maximum
25539 change. Good values are in the "[8.0, 14.0]" range. The range for
25540 threshold is "[0., 100.]".
25541
25542 Default value is 10..
25543
25544 sc_pass, s
25545 Set the flag to pass scene change frames to the next filter.
25546 Default value is 0 You can enable it if you want to get snapshot of
25547 scene change frames only.
25548
25549 selectivecolor
25550 Adjust cyan, magenta, yellow and black (CMYK) to certain ranges of
25551 colors (such as "reds", "yellows", "greens", "cyans", ...). The
25552 adjustment range is defined by the "purity" of the color (that is, how
25553 saturated it already is).
25554
25555 This filter is similar to the Adobe Photoshop Selective Color tool.
25556
25557 The filter accepts the following options:
25558
25559 correction_method
25560 Select color correction method.
25561
25562 Available values are:
25563
25564 absolute
25565 Specified adjustments are applied "as-is" (added/subtracted to
25566 original pixel component value).
25567
25568 relative
25569 Specified adjustments are relative to the original component
25570 value.
25571
25572 Default is "absolute".
25573
25574 reds
25575 Adjustments for red pixels (pixels where the red component is the
25576 maximum)
25577
25578 yellows
25579 Adjustments for yellow pixels (pixels where the blue component is
25580 the minimum)
25581
25582 greens
25583 Adjustments for green pixels (pixels where the green component is
25584 the maximum)
25585
25586 cyans
25587 Adjustments for cyan pixels (pixels where the red component is the
25588 minimum)
25589
25590 blues
25591 Adjustments for blue pixels (pixels where the blue component is the
25592 maximum)
25593
25594 magentas
25595 Adjustments for magenta pixels (pixels where the green component is
25596 the minimum)
25597
25598 whites
25599 Adjustments for white pixels (pixels where all components are
25600 greater than 128)
25601
25602 neutrals
25603 Adjustments for all pixels except pure black and pure white
25604
25605 blacks
25606 Adjustments for black pixels (pixels where all components are
25607 lesser than 128)
25608
25609 psfile
25610 Specify a Photoshop selective color file (".asv") to import the
25611 settings from.
25612
25613 All the adjustment settings (reds, yellows, ...) accept up to 4 space
25614 separated floating point adjustment values in the [-1,1] range,
25615 respectively to adjust the amount of cyan, magenta, yellow and black
25616 for the pixels of its range.
25617
25618 Examples
25619
25620 • Increase cyan by 50% and reduce yellow by 33% in every green areas,
25621 and increase magenta by 27% in blue areas:
25622
25623 selectivecolor=greens=.5 0 -.33 0:blues=0 .27
25624
25625 • Use a Photoshop selective color preset:
25626
25627 selectivecolor=psfile=MySelectiveColorPresets/Misty.asv
25628
25629 separatefields
25630 The "separatefields" takes a frame-based video input and splits each
25631 frame into its components fields, producing a new half height clip with
25632 twice the frame rate and twice the frame count.
25633
25634 This filter use field-dominance information in frame to decide which of
25635 each pair of fields to place first in the output. If it gets it wrong
25636 use setfield filter before "separatefields" filter.
25637
25638 setdar, setsar
25639 The "setdar" filter sets the Display Aspect Ratio for the filter output
25640 video.
25641
25642 This is done by changing the specified Sample (aka Pixel) Aspect Ratio,
25643 according to the following equation:
25644
25645 <DAR> = <HORIZONTAL_RESOLUTION> / <VERTICAL_RESOLUTION> * <SAR>
25646
25647 Keep in mind that the "setdar" filter does not modify the pixel
25648 dimensions of the video frame. Also, the display aspect ratio set by
25649 this filter may be changed by later filters in the filterchain, e.g. in
25650 case of scaling or if another "setdar" or a "setsar" filter is applied.
25651
25652 The "setsar" filter sets the Sample (aka Pixel) Aspect Ratio for the
25653 filter output video.
25654
25655 Note that as a consequence of the application of this filter, the
25656 output display aspect ratio will change according to the equation
25657 above.
25658
25659 Keep in mind that the sample aspect ratio set by the "setsar" filter
25660 may be changed by later filters in the filterchain, e.g. if another
25661 "setsar" or a "setdar" filter is applied.
25662
25663 It accepts the following parameters:
25664
25665 r, ratio, dar ("setdar" only), sar ("setsar" only)
25666 Set the aspect ratio used by the filter.
25667
25668 The parameter can be a floating point number string, an expression,
25669 or a string of the form num:den, where num and den are the
25670 numerator and denominator of the aspect ratio. If the parameter is
25671 not specified, it is assumed the value "0". In case the form
25672 "num:den" is used, the ":" character should be escaped.
25673
25674 max Set the maximum integer value to use for expressing numerator and
25675 denominator when reducing the expressed aspect ratio to a rational.
25676 Default value is 100.
25677
25678 The parameter sar is an expression containing the following constants:
25679
25680 E, PI, PHI
25681 These are approximated values for the mathematical constants e
25682 (Euler's number), pi (Greek pi), and phi (the golden ratio).
25683
25684 w, h
25685 The input width and height.
25686
25687 a These are the same as w / h.
25688
25689 sar The input sample aspect ratio.
25690
25691 dar The input display aspect ratio. It is the same as (w / h) * sar.
25692
25693 hsub, vsub
25694 Horizontal and vertical chroma subsample values. For example, for
25695 the pixel format "yuv422p" hsub is 2 and vsub is 1.
25696
25697 Examples
25698
25699 • To change the display aspect ratio to 16:9, specify one of the
25700 following:
25701
25702 setdar=dar=1.77777
25703 setdar=dar=16/9
25704
25705 • To change the sample aspect ratio to 10:11, specify:
25706
25707 setsar=sar=10/11
25708
25709 • To set a display aspect ratio of 16:9, and specify a maximum
25710 integer value of 1000 in the aspect ratio reduction, use the
25711 command:
25712
25713 setdar=ratio=16/9:max=1000
25714
25715 setfield
25716 Force field for the output video frame.
25717
25718 The "setfield" filter marks the interlace type field for the output
25719 frames. It does not change the input frame, but only sets the
25720 corresponding property, which affects how the frame is treated by
25721 following filters (e.g. "fieldorder" or "yadif").
25722
25723 The filter accepts the following options:
25724
25725 mode
25726 Available values are:
25727
25728 auto
25729 Keep the same field property.
25730
25731 bff Mark the frame as bottom-field-first.
25732
25733 tff Mark the frame as top-field-first.
25734
25735 prog
25736 Mark the frame as progressive.
25737
25738 setparams
25739 Force frame parameter for the output video frame.
25740
25741 The "setparams" filter marks interlace and color range for the output
25742 frames. It does not change the input frame, but only sets the
25743 corresponding property, which affects how the frame is treated by
25744 filters/encoders.
25745
25746 field_mode
25747 Available values are:
25748
25749 auto
25750 Keep the same field property (default).
25751
25752 bff Mark the frame as bottom-field-first.
25753
25754 tff Mark the frame as top-field-first.
25755
25756 prog
25757 Mark the frame as progressive.
25758
25759 range
25760 Available values are:
25761
25762 auto
25763 Keep the same color range property (default).
25764
25765 unspecified, unknown
25766 Mark the frame as unspecified color range.
25767
25768 limited, tv, mpeg
25769 Mark the frame as limited range.
25770
25771 full, pc, jpeg
25772 Mark the frame as full range.
25773
25774 color_primaries
25775 Set the color primaries. Available values are:
25776
25777 auto
25778 Keep the same color primaries property (default).
25779
25780 bt709
25781 unknown
25782 bt470m
25783 bt470bg
25784 smpte170m
25785 smpte240m
25786 film
25787 bt2020
25788 smpte428
25789 smpte431
25790 smpte432
25791 jedec-p22
25792 color_trc
25793 Set the color transfer. Available values are:
25794
25795 auto
25796 Keep the same color trc property (default).
25797
25798 bt709
25799 unknown
25800 bt470m
25801 bt470bg
25802 smpte170m
25803 smpte240m
25804 linear
25805 log100
25806 log316
25807 iec61966-2-4
25808 bt1361e
25809 iec61966-2-1
25810 bt2020-10
25811 bt2020-12
25812 smpte2084
25813 smpte428
25814 arib-std-b67
25815 colorspace
25816 Set the colorspace. Available values are:
25817
25818 auto
25819 Keep the same colorspace property (default).
25820
25821 gbr
25822 bt709
25823 unknown
25824 fcc
25825 bt470bg
25826 smpte170m
25827 smpte240m
25828 ycgco
25829 bt2020nc
25830 bt2020c
25831 smpte2085
25832 chroma-derived-nc
25833 chroma-derived-c
25834 ictcp
25835
25836 sharpen_npp
25837 Use the NVIDIA Performance Primitives (libnpp) to perform image
25838 sharpening with border control.
25839
25840 The following additional options are accepted:
25841
25842 border_type
25843 Type of sampling to be used ad frame borders. One of the following:
25844
25845 replicate
25846 Replicate pixel values.
25847
25848 shear
25849 Apply shear transform to input video.
25850
25851 This filter supports the following options:
25852
25853 shx Shear factor in X-direction. Default value is 0. Allowed range is
25854 from -2 to 2.
25855
25856 shy Shear factor in Y-direction. Default value is 0. Allowed range is
25857 from -2 to 2.
25858
25859 fillcolor, c
25860 Set the color used to fill the output area not covered by the
25861 transformed video. For the general syntax of this option, check the
25862 "Color" section in the ffmpeg-utils manual. If the special value
25863 "none" is selected then no background is printed (useful for
25864 example if the background is never shown).
25865
25866 Default value is "black".
25867
25868 interp
25869 Set interpolation type. Can be "bilinear" or "nearest". Default is
25870 "bilinear".
25871
25872 Commands
25873
25874 This filter supports the all above options as commands.
25875
25876 showinfo
25877 Show a line containing various information for each input video frame.
25878 The input video is not modified.
25879
25880 This filter supports the following options:
25881
25882 checksum
25883 Calculate checksums of each plane. By default enabled.
25884
25885 The shown line contains a sequence of key/value pairs of the form
25886 key:value.
25887
25888 The following values are shown in the output:
25889
25890 n The (sequential) number of the input frame, starting from 0.
25891
25892 pts The Presentation TimeStamp of the input frame, expressed as a
25893 number of time base units. The time base unit depends on the filter
25894 input pad.
25895
25896 pts_time
25897 The Presentation TimeStamp of the input frame, expressed as a
25898 number of seconds.
25899
25900 pos The position of the frame in the input stream, or -1 if this
25901 information is unavailable and/or meaningless (for example in case
25902 of synthetic video).
25903
25904 fmt The pixel format name.
25905
25906 sar The sample aspect ratio of the input frame, expressed in the form
25907 num/den.
25908
25909 s The size of the input frame. For the syntax of this option, check
25910 the "Video size" section in the ffmpeg-utils manual.
25911
25912 i The type of interlaced mode ("P" for "progressive", "T" for top
25913 field first, "B" for bottom field first).
25914
25915 iskey
25916 This is 1 if the frame is a key frame, 0 otherwise.
25917
25918 type
25919 The picture type of the input frame ("I" for an I-frame, "P" for a
25920 P-frame, "B" for a B-frame, or "?" for an unknown type). Also
25921 refer to the documentation of the "AVPictureType" enum and of the
25922 "av_get_picture_type_char" function defined in libavutil/avutil.h.
25923
25924 checksum
25925 The Adler-32 checksum (printed in hexadecimal) of all the planes of
25926 the input frame.
25927
25928 plane_checksum
25929 The Adler-32 checksum (printed in hexadecimal) of each plane of the
25930 input frame, expressed in the form "[c0 c1 c2 c3]".
25931
25932 mean
25933 The mean value of pixels in each plane of the input frame,
25934 expressed in the form "[mean0 mean1 mean2 mean3]".
25935
25936 stdev
25937 The standard deviation of pixel values in each plane of the input
25938 frame, expressed in the form "[stdev0 stdev1 stdev2 stdev3]".
25939
25940 showpalette
25941 Displays the 256 colors palette of each frame. This filter is only
25942 relevant for pal8 pixel format frames.
25943
25944 It accepts the following option:
25945
25946 s Set the size of the box used to represent one palette color entry.
25947 Default is 30 (for a "30x30" pixel box).
25948
25949 shuffleframes
25950 Reorder and/or duplicate and/or drop video frames.
25951
25952 It accepts the following parameters:
25953
25954 mapping
25955 Set the destination indexes of input frames. This is space or '|'
25956 separated list of indexes that maps input frames to output frames.
25957 Number of indexes also sets maximal value that each index may have.
25958 '-1' index have special meaning and that is to drop frame.
25959
25960 The first frame has the index 0. The default is to keep the input
25961 unchanged.
25962
25963 Examples
25964
25965 • Swap second and third frame of every three frames of the input:
25966
25967 ffmpeg -i INPUT -vf "shuffleframes=0 2 1" OUTPUT
25968
25969 • Swap 10th and 1st frame of every ten frames of the input:
25970
25971 ffmpeg -i INPUT -vf "shuffleframes=9 1 2 3 4 5 6 7 8 0" OUTPUT
25972
25973 shufflepixels
25974 Reorder pixels in video frames.
25975
25976 This filter accepts the following options:
25977
25978 direction, d
25979 Set shuffle direction. Can be forward or inverse direction.
25980 Default direction is forward.
25981
25982 mode, m
25983 Set shuffle mode. Can be horizontal, vertical or block mode.
25984
25985 width, w
25986 height, h
25987 Set shuffle block_size. In case of horizontal shuffle mode only
25988 width part of size is used, and in case of vertical shuffle mode
25989 only height part of size is used.
25990
25991 seed, s
25992 Set random seed used with shuffling pixels. Mainly useful to set to
25993 be able to reverse filtering process to get original input. For
25994 example, to reverse forward shuffle you need to use same parameters
25995 and exact same seed and to set direction to inverse.
25996
25997 shuffleplanes
25998 Reorder and/or duplicate video planes.
25999
26000 It accepts the following parameters:
26001
26002 map0
26003 The index of the input plane to be used as the first output plane.
26004
26005 map1
26006 The index of the input plane to be used as the second output plane.
26007
26008 map2
26009 The index of the input plane to be used as the third output plane.
26010
26011 map3
26012 The index of the input plane to be used as the fourth output plane.
26013
26014 The first plane has the index 0. The default is to keep the input
26015 unchanged.
26016
26017 Examples
26018
26019 • Swap the second and third planes of the input:
26020
26021 ffmpeg -i INPUT -vf shuffleplanes=0:2:1:3 OUTPUT
26022
26023 signalstats
26024 Evaluate various visual metrics that assist in determining issues
26025 associated with the digitization of analog video media.
26026
26027 By default the filter will log these metadata values:
26028
26029 YMIN
26030 Display the minimal Y value contained within the input frame.
26031 Expressed in range of [0-255].
26032
26033 YLOW
26034 Display the Y value at the 10% percentile within the input frame.
26035 Expressed in range of [0-255].
26036
26037 YAVG
26038 Display the average Y value within the input frame. Expressed in
26039 range of [0-255].
26040
26041 YHIGH
26042 Display the Y value at the 90% percentile within the input frame.
26043 Expressed in range of [0-255].
26044
26045 YMAX
26046 Display the maximum Y value contained within the input frame.
26047 Expressed in range of [0-255].
26048
26049 UMIN
26050 Display the minimal U value contained within the input frame.
26051 Expressed in range of [0-255].
26052
26053 ULOW
26054 Display the U value at the 10% percentile within the input frame.
26055 Expressed in range of [0-255].
26056
26057 UAVG
26058 Display the average U value within the input frame. Expressed in
26059 range of [0-255].
26060
26061 UHIGH
26062 Display the U value at the 90% percentile within the input frame.
26063 Expressed in range of [0-255].
26064
26065 UMAX
26066 Display the maximum U value contained within the input frame.
26067 Expressed in range of [0-255].
26068
26069 VMIN
26070 Display the minimal V value contained within the input frame.
26071 Expressed in range of [0-255].
26072
26073 VLOW
26074 Display the V value at the 10% percentile within the input frame.
26075 Expressed in range of [0-255].
26076
26077 VAVG
26078 Display the average V value within the input frame. Expressed in
26079 range of [0-255].
26080
26081 VHIGH
26082 Display the V value at the 90% percentile within the input frame.
26083 Expressed in range of [0-255].
26084
26085 VMAX
26086 Display the maximum V value contained within the input frame.
26087 Expressed in range of [0-255].
26088
26089 SATMIN
26090 Display the minimal saturation value contained within the input
26091 frame. Expressed in range of [0-~181.02].
26092
26093 SATLOW
26094 Display the saturation value at the 10% percentile within the input
26095 frame. Expressed in range of [0-~181.02].
26096
26097 SATAVG
26098 Display the average saturation value within the input frame.
26099 Expressed in range of [0-~181.02].
26100
26101 SATHIGH
26102 Display the saturation value at the 90% percentile within the input
26103 frame. Expressed in range of [0-~181.02].
26104
26105 SATMAX
26106 Display the maximum saturation value contained within the input
26107 frame. Expressed in range of [0-~181.02].
26108
26109 HUEMED
26110 Display the median value for hue within the input frame. Expressed
26111 in range of [0-360].
26112
26113 HUEAVG
26114 Display the average value for hue within the input frame. Expressed
26115 in range of [0-360].
26116
26117 YDIF
26118 Display the average of sample value difference between all values
26119 of the Y plane in the current frame and corresponding values of the
26120 previous input frame. Expressed in range of [0-255].
26121
26122 UDIF
26123 Display the average of sample value difference between all values
26124 of the U plane in the current frame and corresponding values of the
26125 previous input frame. Expressed in range of [0-255].
26126
26127 VDIF
26128 Display the average of sample value difference between all values
26129 of the V plane in the current frame and corresponding values of the
26130 previous input frame. Expressed in range of [0-255].
26131
26132 YBITDEPTH
26133 Display bit depth of Y plane in current frame. Expressed in range
26134 of [0-16].
26135
26136 UBITDEPTH
26137 Display bit depth of U plane in current frame. Expressed in range
26138 of [0-16].
26139
26140 VBITDEPTH
26141 Display bit depth of V plane in current frame. Expressed in range
26142 of [0-16].
26143
26144 The filter accepts the following options:
26145
26146 stat
26147 out stat specify an additional form of image analysis. out output
26148 video with the specified type of pixel highlighted.
26149
26150 Both options accept the following values:
26151
26152 tout
26153 Identify temporal outliers pixels. A temporal outlier is a
26154 pixel unlike the neighboring pixels of the same field. Examples
26155 of temporal outliers include the results of video dropouts,
26156 head clogs, or tape tracking issues.
26157
26158 vrep
26159 Identify vertical line repetition. Vertical line repetition
26160 includes similar rows of pixels within a frame. In born-digital
26161 video vertical line repetition is common, but this pattern is
26162 uncommon in video digitized from an analog source. When it
26163 occurs in video that results from the digitization of an analog
26164 source it can indicate concealment from a dropout compensator.
26165
26166 brng
26167 Identify pixels that fall outside of legal broadcast range.
26168
26169 color, c
26170 Set the highlight color for the out option. The default color is
26171 yellow.
26172
26173 Examples
26174
26175 • Output data of various video metrics:
26176
26177 ffprobe -f lavfi movie=example.mov,signalstats="stat=tout+vrep+brng" -show_frames
26178
26179 • Output specific data about the minimum and maximum values of the Y
26180 plane per frame:
26181
26182 ffprobe -f lavfi movie=example.mov,signalstats -show_entries frame_tags=lavfi.signalstats.YMAX,lavfi.signalstats.YMIN
26183
26184 • Playback video while highlighting pixels that are outside of
26185 broadcast range in red.
26186
26187 ffplay example.mov -vf signalstats="out=brng:color=red"
26188
26189 • Playback video with signalstats metadata drawn over the frame.
26190
26191 ffplay example.mov -vf signalstats=stat=brng+vrep+tout,drawtext=fontfile=FreeSerif.ttf:textfile=signalstat_drawtext.txt
26192
26193 The contents of signalstat_drawtext.txt used in the command are:
26194
26195 time %{pts:hms}
26196 Y (%{metadata:lavfi.signalstats.YMIN}-%{metadata:lavfi.signalstats.YMAX})
26197 U (%{metadata:lavfi.signalstats.UMIN}-%{metadata:lavfi.signalstats.UMAX})
26198 V (%{metadata:lavfi.signalstats.VMIN}-%{metadata:lavfi.signalstats.VMAX})
26199 saturation maximum: %{metadata:lavfi.signalstats.SATMAX}
26200
26201 signature
26202 Calculates the MPEG-7 Video Signature. The filter can handle more than
26203 one input. In this case the matching between the inputs can be
26204 calculated additionally. The filter always passes through the first
26205 input. The signature of each stream can be written into a file.
26206
26207 It accepts the following options:
26208
26209 detectmode
26210 Enable or disable the matching process.
26211
26212 Available values are:
26213
26214 off Disable the calculation of a matching (default).
26215
26216 full
26217 Calculate the matching for the whole video and output whether
26218 the whole video matches or only parts.
26219
26220 fast
26221 Calculate only until a matching is found or the video ends.
26222 Should be faster in some cases.
26223
26224 nb_inputs
26225 Set the number of inputs. The option value must be a non negative
26226 integer. Default value is 1.
26227
26228 filename
26229 Set the path to which the output is written. If there is more than
26230 one input, the path must be a prototype, i.e. must contain %d or
26231 %0nd (where n is a positive integer), that will be replaced with
26232 the input number. If no filename is specified, no output will be
26233 written. This is the default.
26234
26235 format
26236 Choose the output format.
26237
26238 Available values are:
26239
26240 binary
26241 Use the specified binary representation (default).
26242
26243 xml Use the specified xml representation.
26244
26245 th_d
26246 Set threshold to detect one word as similar. The option value must
26247 be an integer greater than zero. The default value is 9000.
26248
26249 th_dc
26250 Set threshold to detect all words as similar. The option value must
26251 be an integer greater than zero. The default value is 60000.
26252
26253 th_xh
26254 Set threshold to detect frames as similar. The option value must be
26255 an integer greater than zero. The default value is 116.
26256
26257 th_di
26258 Set the minimum length of a sequence in frames to recognize it as
26259 matching sequence. The option value must be a non negative integer
26260 value. The default value is 0.
26261
26262 th_it
26263 Set the minimum relation, that matching frames to all frames must
26264 have. The option value must be a double value between 0 and 1. The
26265 default value is 0.5.
26266
26267 Examples
26268
26269 • To calculate the signature of an input video and store it in
26270 signature.bin:
26271
26272 ffmpeg -i input.mkv -vf signature=filename=signature.bin -map 0:v -f null -
26273
26274 • To detect whether two videos match and store the signatures in XML
26275 format in signature0.xml and signature1.xml:
26276
26277 ffmpeg -i input1.mkv -i input2.mkv -filter_complex "[0:v][1:v] signature=nb_inputs=2:detectmode=full:format=xml:filename=signature%d.xml" -map :v -f null -
26278
26279 smartblur
26280 Blur the input video without impacting the outlines.
26281
26282 It accepts the following options:
26283
26284 luma_radius, lr
26285 Set the luma radius. The option value must be a float number in the
26286 range [0.1,5.0] that specifies the variance of the gaussian filter
26287 used to blur the image (slower if larger). Default value is 1.0.
26288
26289 luma_strength, ls
26290 Set the luma strength. The option value must be a float number in
26291 the range [-1.0,1.0] that configures the blurring. A value included
26292 in [0.0,1.0] will blur the image whereas a value included in
26293 [-1.0,0.0] will sharpen the image. Default value is 1.0.
26294
26295 luma_threshold, lt
26296 Set the luma threshold used as a coefficient to determine whether a
26297 pixel should be blurred or not. The option value must be an integer
26298 in the range [-30,30]. A value of 0 will filter all the image, a
26299 value included in [0,30] will filter flat areas and a value
26300 included in [-30,0] will filter edges. Default value is 0.
26301
26302 chroma_radius, cr
26303 Set the chroma radius. The option value must be a float number in
26304 the range [0.1,5.0] that specifies the variance of the gaussian
26305 filter used to blur the image (slower if larger). Default value is
26306 luma_radius.
26307
26308 chroma_strength, cs
26309 Set the chroma strength. The option value must be a float number in
26310 the range [-1.0,1.0] that configures the blurring. A value included
26311 in [0.0,1.0] will blur the image whereas a value included in
26312 [-1.0,0.0] will sharpen the image. Default value is luma_strength.
26313
26314 chroma_threshold, ct
26315 Set the chroma threshold used as a coefficient to determine whether
26316 a pixel should be blurred or not. The option value must be an
26317 integer in the range [-30,30]. A value of 0 will filter all the
26318 image, a value included in [0,30] will filter flat areas and a
26319 value included in [-30,0] will filter edges. Default value is
26320 luma_threshold.
26321
26322 If a chroma option is not explicitly set, the corresponding luma value
26323 is set.
26324
26325 sobel
26326 Apply sobel operator to input video stream.
26327
26328 The filter accepts the following option:
26329
26330 planes
26331 Set which planes will be processed, unprocessed planes will be
26332 copied. By default value 0xf, all planes will be processed.
26333
26334 scale
26335 Set value which will be multiplied with filtered result.
26336
26337 delta
26338 Set value which will be added to filtered result.
26339
26340 Commands
26341
26342 This filter supports the all above options as commands.
26343
26344 spp
26345 Apply a simple postprocessing filter that compresses and decompresses
26346 the image at several (or - in the case of quality level 6 - all) shifts
26347 and average the results.
26348
26349 The filter accepts the following options:
26350
26351 quality
26352 Set quality. This option defines the number of levels for
26353 averaging. It accepts an integer in the range 0-6. If set to 0, the
26354 filter will have no effect. A value of 6 means the higher quality.
26355 For each increment of that value the speed drops by a factor of
26356 approximately 2. Default value is 3.
26357
26358 qp Force a constant quantization parameter. If not set, the filter
26359 will use the QP from the video stream (if available).
26360
26361 mode
26362 Set thresholding mode. Available modes are:
26363
26364 hard
26365 Set hard thresholding (default).
26366
26367 soft
26368 Set soft thresholding (better de-ringing effect, but likely
26369 blurrier).
26370
26371 use_bframe_qp
26372 Enable the use of the QP from the B-Frames if set to 1. Using this
26373 option may cause flicker since the B-Frames have often larger QP.
26374 Default is 0 (not enabled).
26375
26376 Commands
26377
26378 This filter supports the following commands:
26379
26380 quality, level
26381 Set quality level. The value "max" can be used to set the maximum
26382 level, currently 6.
26383
26384 sr
26385 Scale the input by applying one of the super-resolution methods based
26386 on convolutional neural networks. Supported models:
26387
26388 • Super-Resolution Convolutional Neural Network model (SRCNN). See
26389 <https://arxiv.org/abs/1501.00092>.
26390
26391 • Efficient Sub-Pixel Convolutional Neural Network model (ESPCN).
26392 See <https://arxiv.org/abs/1609.05158>.
26393
26394 Training scripts as well as scripts for model file (.pb) saving can be
26395 found at <https://github.com/XueweiMeng/sr/tree/sr_dnn_native>.
26396 Original repository is at
26397 <https://github.com/HighVoltageRocknRoll/sr.git>.
26398
26399 Native model files (.model) can be generated from TensorFlow model
26400 files (.pb) by using tools/python/convert.py
26401
26402 The filter accepts the following options:
26403
26404 dnn_backend
26405 Specify which DNN backend to use for model loading and execution.
26406 This option accepts the following values:
26407
26408 native
26409 Native implementation of DNN loading and execution.
26410
26411 tensorflow
26412 TensorFlow backend. To enable this backend you need to install
26413 the TensorFlow for C library (see
26414 <https://www.tensorflow.org/install/lang_c>) and configure
26415 FFmpeg with "--enable-libtensorflow"
26416
26417 Default value is native.
26418
26419 model
26420 Set path to model file specifying network architecture and its
26421 parameters. Note that different backends use different file
26422 formats. TensorFlow backend can load files for both formats, while
26423 native backend can load files for only its format.
26424
26425 scale_factor
26426 Set scale factor for SRCNN model. Allowed values are 2, 3 and 4.
26427 Default value is 2. Scale factor is necessary for SRCNN model,
26428 because it accepts input upscaled using bicubic upscaling with
26429 proper scale factor.
26430
26431 To get full functionality (such as async execution), please use the
26432 dnn_processing filter.
26433
26434 ssim
26435 Obtain the SSIM (Structural SImilarity Metric) between two input
26436 videos.
26437
26438 This filter takes in input two input videos, the first input is
26439 considered the "main" source and is passed unchanged to the output. The
26440 second input is used as a "reference" video for computing the SSIM.
26441
26442 Both video inputs must have the same resolution and pixel format for
26443 this filter to work correctly. Also it assumes that both inputs have
26444 the same number of frames, which are compared one by one.
26445
26446 The filter stores the calculated SSIM of each frame.
26447
26448 The description of the accepted parameters follows.
26449
26450 stats_file, f
26451 If specified the filter will use the named file to save the SSIM of
26452 each individual frame. When filename equals "-" the data is sent to
26453 standard output.
26454
26455 The file printed if stats_file is selected, contains a sequence of
26456 key/value pairs of the form key:value for each compared couple of
26457 frames.
26458
26459 A description of each shown parameter follows:
26460
26461 n sequential number of the input frame, starting from 1
26462
26463 Y, U, V, R, G, B
26464 SSIM of the compared frames for the component specified by the
26465 suffix.
26466
26467 All SSIM of the compared frames for the whole frame.
26468
26469 dB Same as above but in dB representation.
26470
26471 This filter also supports the framesync options.
26472
26473 Examples
26474
26475 • For example:
26476
26477 movie=ref_movie.mpg, setpts=PTS-STARTPTS [main];
26478 [main][ref] ssim="stats_file=stats.log" [out]
26479
26480 On this example the input file being processed is compared with the
26481 reference file ref_movie.mpg. The SSIM of each individual frame is
26482 stored in stats.log.
26483
26484 • Another example with both psnr and ssim at same time:
26485
26486 ffmpeg -i main.mpg -i ref.mpg -lavfi "ssim;[0:v][1:v]psnr" -f null -
26487
26488 • Another example with different containers:
26489
26490 ffmpeg -i main.mpg -i ref.mkv -lavfi "[0:v]settb=AVTB,setpts=PTS-STARTPTS[main];[1:v]settb=AVTB,setpts=PTS-STARTPTS[ref];[main][ref]ssim" -f null -
26491
26492 stereo3d
26493 Convert between different stereoscopic image formats.
26494
26495 The filters accept the following options:
26496
26497 in Set stereoscopic image format of input.
26498
26499 Available values for input image formats are:
26500
26501 sbsl
26502 side by side parallel (left eye left, right eye right)
26503
26504 sbsr
26505 side by side crosseye (right eye left, left eye right)
26506
26507 sbs2l
26508 side by side parallel with half width resolution (left eye
26509 left, right eye right)
26510
26511 sbs2r
26512 side by side crosseye with half width resolution (right eye
26513 left, left eye right)
26514
26515 abl
26516 tbl above-below (left eye above, right eye below)
26517
26518 abr
26519 tbr above-below (right eye above, left eye below)
26520
26521 ab2l
26522 tb2l
26523 above-below with half height resolution (left eye above, right
26524 eye below)
26525
26526 ab2r
26527 tb2r
26528 above-below with half height resolution (right eye above, left
26529 eye below)
26530
26531 al alternating frames (left eye first, right eye second)
26532
26533 ar alternating frames (right eye first, left eye second)
26534
26535 irl interleaved rows (left eye has top row, right eye starts on
26536 next row)
26537
26538 irr interleaved rows (right eye has top row, left eye starts on
26539 next row)
26540
26541 icl interleaved columns, left eye first
26542
26543 icr interleaved columns, right eye first
26544
26545 Default value is sbsl.
26546
26547 out Set stereoscopic image format of output.
26548
26549 sbsl
26550 side by side parallel (left eye left, right eye right)
26551
26552 sbsr
26553 side by side crosseye (right eye left, left eye right)
26554
26555 sbs2l
26556 side by side parallel with half width resolution (left eye
26557 left, right eye right)
26558
26559 sbs2r
26560 side by side crosseye with half width resolution (right eye
26561 left, left eye right)
26562
26563 abl
26564 tbl above-below (left eye above, right eye below)
26565
26566 abr
26567 tbr above-below (right eye above, left eye below)
26568
26569 ab2l
26570 tb2l
26571 above-below with half height resolution (left eye above, right
26572 eye below)
26573
26574 ab2r
26575 tb2r
26576 above-below with half height resolution (right eye above, left
26577 eye below)
26578
26579 al alternating frames (left eye first, right eye second)
26580
26581 ar alternating frames (right eye first, left eye second)
26582
26583 irl interleaved rows (left eye has top row, right eye starts on
26584 next row)
26585
26586 irr interleaved rows (right eye has top row, left eye starts on
26587 next row)
26588
26589 arbg
26590 anaglyph red/blue gray (red filter on left eye, blue filter on
26591 right eye)
26592
26593 argg
26594 anaglyph red/green gray (red filter on left eye, green filter
26595 on right eye)
26596
26597 arcg
26598 anaglyph red/cyan gray (red filter on left eye, cyan filter on
26599 right eye)
26600
26601 arch
26602 anaglyph red/cyan half colored (red filter on left eye, cyan
26603 filter on right eye)
26604
26605 arcc
26606 anaglyph red/cyan color (red filter on left eye, cyan filter on
26607 right eye)
26608
26609 arcd
26610 anaglyph red/cyan color optimized with the least squares
26611 projection of dubois (red filter on left eye, cyan filter on
26612 right eye)
26613
26614 agmg
26615 anaglyph green/magenta gray (green filter on left eye, magenta
26616 filter on right eye)
26617
26618 agmh
26619 anaglyph green/magenta half colored (green filter on left eye,
26620 magenta filter on right eye)
26621
26622 agmc
26623 anaglyph green/magenta colored (green filter on left eye,
26624 magenta filter on right eye)
26625
26626 agmd
26627 anaglyph green/magenta color optimized with the least squares
26628 projection of dubois (green filter on left eye, magenta filter
26629 on right eye)
26630
26631 aybg
26632 anaglyph yellow/blue gray (yellow filter on left eye, blue
26633 filter on right eye)
26634
26635 aybh
26636 anaglyph yellow/blue half colored (yellow filter on left eye,
26637 blue filter on right eye)
26638
26639 aybc
26640 anaglyph yellow/blue colored (yellow filter on left eye, blue
26641 filter on right eye)
26642
26643 aybd
26644 anaglyph yellow/blue color optimized with the least squares
26645 projection of dubois (yellow filter on left eye, blue filter on
26646 right eye)
26647
26648 ml mono output (left eye only)
26649
26650 mr mono output (right eye only)
26651
26652 chl checkerboard, left eye first
26653
26654 chr checkerboard, right eye first
26655
26656 icl interleaved columns, left eye first
26657
26658 icr interleaved columns, right eye first
26659
26660 hdmi
26661 HDMI frame pack
26662
26663 Default value is arcd.
26664
26665 Examples
26666
26667 • Convert input video from side by side parallel to anaglyph
26668 yellow/blue dubois:
26669
26670 stereo3d=sbsl:aybd
26671
26672 • Convert input video from above below (left eye above, right eye
26673 below) to side by side crosseye.
26674
26675 stereo3d=abl:sbsr
26676
26677 streamselect, astreamselect
26678 Select video or audio streams.
26679
26680 The filter accepts the following options:
26681
26682 inputs
26683 Set number of inputs. Default is 2.
26684
26685 map Set input indexes to remap to outputs.
26686
26687 Commands
26688
26689 The "streamselect" and "astreamselect" filter supports the following
26690 commands:
26691
26692 map Set input indexes to remap to outputs.
26693
26694 Examples
26695
26696 • Select first 5 seconds 1st stream and rest of time 2nd stream:
26697
26698 sendcmd='5.0 streamselect map 1',streamselect=inputs=2:map=0
26699
26700 • Same as above, but for audio:
26701
26702 asendcmd='5.0 astreamselect map 1',astreamselect=inputs=2:map=0
26703
26704 subtitles
26705 Draw subtitles on top of input video using the libass library.
26706
26707 To enable compilation of this filter you need to configure FFmpeg with
26708 "--enable-libass". This filter also requires a build with libavcodec
26709 and libavformat to convert the passed subtitles file to ASS (Advanced
26710 Substation Alpha) subtitles format.
26711
26712 The filter accepts the following options:
26713
26714 filename, f
26715 Set the filename of the subtitle file to read. It must be
26716 specified.
26717
26718 original_size
26719 Specify the size of the original video, the video for which the ASS
26720 file was composed. For the syntax of this option, check the "Video
26721 size" section in the ffmpeg-utils manual. Due to a misdesign in
26722 ASS aspect ratio arithmetic, this is necessary to correctly scale
26723 the fonts if the aspect ratio has been changed.
26724
26725 fontsdir
26726 Set a directory path containing fonts that can be used by the
26727 filter. These fonts will be used in addition to whatever the font
26728 provider uses.
26729
26730 alpha
26731 Process alpha channel, by default alpha channel is untouched.
26732
26733 charenc
26734 Set subtitles input character encoding. "subtitles" filter only.
26735 Only useful if not UTF-8.
26736
26737 stream_index, si
26738 Set subtitles stream index. "subtitles" filter only.
26739
26740 force_style
26741 Override default style or script info parameters of the subtitles.
26742 It accepts a string containing ASS style format "KEY=VALUE" couples
26743 separated by ",".
26744
26745 If the first key is not specified, it is assumed that the first value
26746 specifies the filename.
26747
26748 For example, to render the file sub.srt on top of the input video, use
26749 the command:
26750
26751 subtitles=sub.srt
26752
26753 which is equivalent to:
26754
26755 subtitles=filename=sub.srt
26756
26757 To render the default subtitles stream from file video.mkv, use:
26758
26759 subtitles=video.mkv
26760
26761 To render the second subtitles stream from that file, use:
26762
26763 subtitles=video.mkv:si=1
26764
26765 To make the subtitles stream from sub.srt appear in 80% transparent
26766 blue "DejaVu Serif", use:
26767
26768 subtitles=sub.srt:force_style='Fontname=DejaVu Serif,PrimaryColour=&HCCFF0000'
26769
26770 super2xsai
26771 Scale the input by 2x and smooth using the Super2xSaI (Scale and
26772 Interpolate) pixel art scaling algorithm.
26773
26774 Useful for enlarging pixel art images without reducing sharpness.
26775
26776 swaprect
26777 Swap two rectangular objects in video.
26778
26779 This filter accepts the following options:
26780
26781 w Set object width.
26782
26783 h Set object height.
26784
26785 x1 Set 1st rect x coordinate.
26786
26787 y1 Set 1st rect y coordinate.
26788
26789 x2 Set 2nd rect x coordinate.
26790
26791 y2 Set 2nd rect y coordinate.
26792
26793 All expressions are evaluated once for each frame.
26794
26795 The all options are expressions containing the following constants:
26796
26797 w
26798 h The input width and height.
26799
26800 a same as w / h
26801
26802 sar input sample aspect ratio
26803
26804 dar input display aspect ratio, it is the same as (w / h) * sar
26805
26806 n The number of the input frame, starting from 0.
26807
26808 t The timestamp expressed in seconds. It's NAN if the input timestamp
26809 is unknown.
26810
26811 pos the position in the file of the input frame, NAN if unknown
26812
26813 Commands
26814
26815 This filter supports the all above options as commands.
26816
26817 swapuv
26818 Swap U & V plane.
26819
26820 tblend
26821 Blend successive video frames.
26822
26823 See blend
26824
26825 telecine
26826 Apply telecine process to the video.
26827
26828 This filter accepts the following options:
26829
26830 first_field
26831 top, t
26832 top field first
26833
26834 bottom, b
26835 bottom field first The default value is "top".
26836
26837 pattern
26838 A string of numbers representing the pulldown pattern you wish to
26839 apply. The default value is 23.
26840
26841 Some typical patterns:
26842
26843 NTSC output (30i):
26844 27.5p: 32222
26845 24p: 23 (classic)
26846 24p: 2332 (preferred)
26847 20p: 33
26848 18p: 334
26849 16p: 3444
26850
26851 PAL output (25i):
26852 27.5p: 12222
26853 24p: 222222222223 ("Euro pulldown")
26854 16.67p: 33
26855 16p: 33333334
26856
26857 thistogram
26858 Compute and draw a color distribution histogram for the input video
26859 across time.
26860
26861 Unlike histogram video filter which only shows histogram of single
26862 input frame at certain time, this filter shows also past histograms of
26863 number of frames defined by "width" option.
26864
26865 The computed histogram is a representation of the color component
26866 distribution in an image.
26867
26868 The filter accepts the following options:
26869
26870 width, w
26871 Set width of single color component output. Default value is 0.
26872 Value of 0 means width will be picked from input video. This also
26873 set number of passed histograms to keep. Allowed range is [0,
26874 8192].
26875
26876 display_mode, d
26877 Set display mode. It accepts the following values:
26878
26879 stack
26880 Per color component graphs are placed below each other.
26881
26882 parade
26883 Per color component graphs are placed side by side.
26884
26885 overlay
26886 Presents information identical to that in the "parade", except
26887 that the graphs representing color components are superimposed
26888 directly over one another.
26889
26890 Default is "stack".
26891
26892 levels_mode, m
26893 Set mode. Can be either "linear", or "logarithmic". Default is
26894 "linear".
26895
26896 components, c
26897 Set what color components to display. Default is 7.
26898
26899 bgopacity, b
26900 Set background opacity. Default is 0.9.
26901
26902 envelope, e
26903 Show envelope. Default is disabled.
26904
26905 ecolor, ec
26906 Set envelope color. Default is "gold".
26907
26908 slide
26909 Set slide mode.
26910
26911 Available values for slide is:
26912
26913 frame
26914 Draw new frame when right border is reached.
26915
26916 replace
26917 Replace old columns with new ones.
26918
26919 scroll
26920 Scroll from right to left.
26921
26922 rscroll
26923 Scroll from left to right.
26924
26925 picture
26926 Draw single picture.
26927
26928 Default is "replace".
26929
26930 threshold
26931 Apply threshold effect to video stream.
26932
26933 This filter needs four video streams to perform thresholding. First
26934 stream is stream we are filtering. Second stream is holding threshold
26935 values, third stream is holding min values, and last, fourth stream is
26936 holding max values.
26937
26938 The filter accepts the following option:
26939
26940 planes
26941 Set which planes will be processed, unprocessed planes will be
26942 copied. By default value 0xf, all planes will be processed.
26943
26944 For example if first stream pixel's component value is less then
26945 threshold value of pixel component from 2nd threshold stream, third
26946 stream value will picked, otherwise fourth stream pixel component value
26947 will be picked.
26948
26949 Using color source filter one can perform various types of
26950 thresholding:
26951
26952 Commands
26953
26954 This filter supports the all options as commands.
26955
26956 Examples
26957
26958 • Binary threshold, using gray color as threshold:
26959
26960 ffmpeg -i 320x240.avi -f lavfi -i color=gray -f lavfi -i color=black -f lavfi -i color=white -lavfi threshold output.avi
26961
26962 • Inverted binary threshold, using gray color as threshold:
26963
26964 ffmpeg -i 320x240.avi -f lavfi -i color=gray -f lavfi -i color=white -f lavfi -i color=black -lavfi threshold output.avi
26965
26966 • Truncate binary threshold, using gray color as threshold:
26967
26968 ffmpeg -i 320x240.avi -f lavfi -i color=gray -i 320x240.avi -f lavfi -i color=gray -lavfi threshold output.avi
26969
26970 • Threshold to zero, using gray color as threshold:
26971
26972 ffmpeg -i 320x240.avi -f lavfi -i color=gray -f lavfi -i color=white -i 320x240.avi -lavfi threshold output.avi
26973
26974 • Inverted threshold to zero, using gray color as threshold:
26975
26976 ffmpeg -i 320x240.avi -f lavfi -i color=gray -i 320x240.avi -f lavfi -i color=white -lavfi threshold output.avi
26977
26978 thumbnail
26979 Select the most representative frame in a given sequence of consecutive
26980 frames.
26981
26982 The filter accepts the following options:
26983
26984 n Set the frames batch size to analyze; in a set of n frames, the
26985 filter will pick one of them, and then handle the next batch of n
26986 frames until the end. Default is 100.
26987
26988 Since the filter keeps track of the whole frames sequence, a bigger n
26989 value will result in a higher memory usage, so a high value is not
26990 recommended.
26991
26992 Examples
26993
26994 • Extract one picture each 50 frames:
26995
26996 thumbnail=50
26997
26998 • Complete example of a thumbnail creation with ffmpeg:
26999
27000 ffmpeg -i in.avi -vf thumbnail,scale=300:200 -frames:v 1 out.png
27001
27002 tile
27003 Tile several successive frames together.
27004
27005 The untile filter can do the reverse.
27006
27007 The filter accepts the following options:
27008
27009 layout
27010 Set the grid size (i.e. the number of lines and columns). For the
27011 syntax of this option, check the "Video size" section in the
27012 ffmpeg-utils manual.
27013
27014 nb_frames
27015 Set the maximum number of frames to render in the given area. It
27016 must be less than or equal to wxh. The default value is 0, meaning
27017 all the area will be used.
27018
27019 margin
27020 Set the outer border margin in pixels.
27021
27022 padding
27023 Set the inner border thickness (i.e. the number of pixels between
27024 frames). For more advanced padding options (such as having
27025 different values for the edges), refer to the pad video filter.
27026
27027 color
27028 Specify the color of the unused area. For the syntax of this
27029 option, check the "Color" section in the ffmpeg-utils manual. The
27030 default value of color is "black".
27031
27032 overlap
27033 Set the number of frames to overlap when tiling several successive
27034 frames together. The value must be between 0 and nb_frames - 1.
27035
27036 init_padding
27037 Set the number of frames to initially be empty before displaying
27038 first output frame. This controls how soon will one get first
27039 output frame. The value must be between 0 and nb_frames - 1.
27040
27041 Examples
27042
27043 • Produce 8x8 PNG tiles of all keyframes (-skip_frame nokey) in a
27044 movie:
27045
27046 ffmpeg -skip_frame nokey -i file.avi -vf 'scale=128:72,tile=8x8' -an -vsync 0 keyframes%03d.png
27047
27048 The -vsync 0 is necessary to prevent ffmpeg from duplicating each
27049 output frame to accommodate the originally detected frame rate.
27050
27051 • Display 5 pictures in an area of "3x2" frames, with 7 pixels
27052 between them, and 2 pixels of initial margin, using mixed flat and
27053 named options:
27054
27055 tile=3x2:nb_frames=5:padding=7:margin=2
27056
27057 tinterlace
27058 Perform various types of temporal field interlacing.
27059
27060 Frames are counted starting from 1, so the first input frame is
27061 considered odd.
27062
27063 The filter accepts the following options:
27064
27065 mode
27066 Specify the mode of the interlacing. This option can also be
27067 specified as a value alone. See below for a list of values for this
27068 option.
27069
27070 Available values are:
27071
27072 merge, 0
27073 Move odd frames into the upper field, even into the lower
27074 field, generating a double height frame at half frame rate.
27075
27076 ------> time
27077 Input:
27078 Frame 1 Frame 2 Frame 3 Frame 4
27079
27080 11111 22222 33333 44444
27081 11111 22222 33333 44444
27082 11111 22222 33333 44444
27083 11111 22222 33333 44444
27084
27085 Output:
27086 11111 33333
27087 22222 44444
27088 11111 33333
27089 22222 44444
27090 11111 33333
27091 22222 44444
27092 11111 33333
27093 22222 44444
27094
27095 drop_even, 1
27096 Only output odd frames, even frames are dropped, generating a
27097 frame with unchanged height at half frame rate.
27098
27099 ------> time
27100 Input:
27101 Frame 1 Frame 2 Frame 3 Frame 4
27102
27103 11111 22222 33333 44444
27104 11111 22222 33333 44444
27105 11111 22222 33333 44444
27106 11111 22222 33333 44444
27107
27108 Output:
27109 11111 33333
27110 11111 33333
27111 11111 33333
27112 11111 33333
27113
27114 drop_odd, 2
27115 Only output even frames, odd frames are dropped, generating a
27116 frame with unchanged height at half frame rate.
27117
27118 ------> time
27119 Input:
27120 Frame 1 Frame 2 Frame 3 Frame 4
27121
27122 11111 22222 33333 44444
27123 11111 22222 33333 44444
27124 11111 22222 33333 44444
27125 11111 22222 33333 44444
27126
27127 Output:
27128 22222 44444
27129 22222 44444
27130 22222 44444
27131 22222 44444
27132
27133 pad, 3
27134 Expand each frame to full height, but pad alternate lines with
27135 black, generating a frame with double height at the same input
27136 frame rate.
27137
27138 ------> time
27139 Input:
27140 Frame 1 Frame 2 Frame 3 Frame 4
27141
27142 11111 22222 33333 44444
27143 11111 22222 33333 44444
27144 11111 22222 33333 44444
27145 11111 22222 33333 44444
27146
27147 Output:
27148 11111 ..... 33333 .....
27149 ..... 22222 ..... 44444
27150 11111 ..... 33333 .....
27151 ..... 22222 ..... 44444
27152 11111 ..... 33333 .....
27153 ..... 22222 ..... 44444
27154 11111 ..... 33333 .....
27155 ..... 22222 ..... 44444
27156
27157 interleave_top, 4
27158 Interleave the upper field from odd frames with the lower field
27159 from even frames, generating a frame with unchanged height at
27160 half frame rate.
27161
27162 ------> time
27163 Input:
27164 Frame 1 Frame 2 Frame 3 Frame 4
27165
27166 11111<- 22222 33333<- 44444
27167 11111 22222<- 33333 44444<-
27168 11111<- 22222 33333<- 44444
27169 11111 22222<- 33333 44444<-
27170
27171 Output:
27172 11111 33333
27173 22222 44444
27174 11111 33333
27175 22222 44444
27176
27177 interleave_bottom, 5
27178 Interleave the lower field from odd frames with the upper field
27179 from even frames, generating a frame with unchanged height at
27180 half frame rate.
27181
27182 ------> time
27183 Input:
27184 Frame 1 Frame 2 Frame 3 Frame 4
27185
27186 11111 22222<- 33333 44444<-
27187 11111<- 22222 33333<- 44444
27188 11111 22222<- 33333 44444<-
27189 11111<- 22222 33333<- 44444
27190
27191 Output:
27192 22222 44444
27193 11111 33333
27194 22222 44444
27195 11111 33333
27196
27197 interlacex2, 6
27198 Double frame rate with unchanged height. Frames are inserted
27199 each containing the second temporal field from the previous
27200 input frame and the first temporal field from the next input
27201 frame. This mode relies on the top_field_first flag. Useful for
27202 interlaced video displays with no field synchronisation.
27203
27204 ------> time
27205 Input:
27206 Frame 1 Frame 2 Frame 3 Frame 4
27207
27208 11111 22222 33333 44444
27209 11111 22222 33333 44444
27210 11111 22222 33333 44444
27211 11111 22222 33333 44444
27212
27213 Output:
27214 11111 22222 22222 33333 33333 44444 44444
27215 11111 11111 22222 22222 33333 33333 44444
27216 11111 22222 22222 33333 33333 44444 44444
27217 11111 11111 22222 22222 33333 33333 44444
27218
27219 mergex2, 7
27220 Move odd frames into the upper field, even into the lower
27221 field, generating a double height frame at same frame rate.
27222
27223 ------> time
27224 Input:
27225 Frame 1 Frame 2 Frame 3 Frame 4
27226
27227 11111 22222 33333 44444
27228 11111 22222 33333 44444
27229 11111 22222 33333 44444
27230 11111 22222 33333 44444
27231
27232 Output:
27233 11111 33333 33333 55555
27234 22222 22222 44444 44444
27235 11111 33333 33333 55555
27236 22222 22222 44444 44444
27237 11111 33333 33333 55555
27238 22222 22222 44444 44444
27239 11111 33333 33333 55555
27240 22222 22222 44444 44444
27241
27242 Numeric values are deprecated but are accepted for backward
27243 compatibility reasons.
27244
27245 Default mode is "merge".
27246
27247 flags
27248 Specify flags influencing the filter process.
27249
27250 Available value for flags is:
27251
27252 low_pass_filter, vlpf
27253 Enable linear vertical low-pass filtering in the filter.
27254 Vertical low-pass filtering is required when creating an
27255 interlaced destination from a progressive source which contains
27256 high-frequency vertical detail. Filtering will reduce interlace
27257 'twitter' and Moire patterning.
27258
27259 complex_filter, cvlpf
27260 Enable complex vertical low-pass filtering. This will slightly
27261 less reduce interlace 'twitter' and Moire patterning but better
27262 retain detail and subjective sharpness impression.
27263
27264 bypass_il
27265 Bypass already interlaced frames, only adjust the frame rate.
27266
27267 Vertical low-pass filtering and bypassing already interlaced frames
27268 can only be enabled for mode interleave_top and interleave_bottom.
27269
27270 tmedian
27271 Pick median pixels from several successive input video frames.
27272
27273 The filter accepts the following options:
27274
27275 radius
27276 Set radius of median filter. Default is 1. Allowed range is from 1
27277 to 127.
27278
27279 planes
27280 Set which planes to filter. Default value is 15, by which all
27281 planes are processed.
27282
27283 percentile
27284 Set median percentile. Default value is 0.5. Default value of 0.5
27285 will pick always median values, while 0 will pick minimum values,
27286 and 1 maximum values.
27287
27288 Commands
27289
27290 This filter supports all above options as commands, excluding option
27291 "radius".
27292
27293 tmidequalizer
27294 Apply Temporal Midway Video Equalization effect.
27295
27296 Midway Video Equalization adjusts a sequence of video frames to have
27297 the same histograms, while maintaining their dynamics as much as
27298 possible. It's useful for e.g. matching exposures from a video frames
27299 sequence.
27300
27301 This filter accepts the following option:
27302
27303 radius
27304 Set filtering radius. Default is 5. Allowed range is from 1 to 127.
27305
27306 sigma
27307 Set filtering sigma. Default is 0.5. This controls strength of
27308 filtering. Setting this option to 0 effectively does nothing.
27309
27310 planes
27311 Set which planes to process. Default is 15, which is all available
27312 planes.
27313
27314 tmix
27315 Mix successive video frames.
27316
27317 A description of the accepted options follows.
27318
27319 frames
27320 The number of successive frames to mix. If unspecified, it defaults
27321 to 3.
27322
27323 weights
27324 Specify weight of each input video frame. Each weight is separated
27325 by space. If number of weights is smaller than number of frames
27326 last specified weight will be used for all remaining unset weights.
27327
27328 scale
27329 Specify scale, if it is set it will be multiplied with sum of each
27330 weight multiplied with pixel values to give final destination pixel
27331 value. By default scale is auto scaled to sum of weights.
27332
27333 Examples
27334
27335 • Average 7 successive frames:
27336
27337 tmix=frames=7:weights="1 1 1 1 1 1 1"
27338
27339 • Apply simple temporal convolution:
27340
27341 tmix=frames=3:weights="-1 3 -1"
27342
27343 • Similar as above but only showing temporal differences:
27344
27345 tmix=frames=3:weights="-1 2 -1":scale=1
27346
27347 Commands
27348
27349 This filter supports the following commands:
27350
27351 weights
27352 scale
27353 Syntax is same as option with same name.
27354
27355 tonemap
27356 Tone map colors from different dynamic ranges.
27357
27358 This filter expects data in single precision floating point, as it
27359 needs to operate on (and can output) out-of-range values. Another
27360 filter, such as zscale, is needed to convert the resulting frame to a
27361 usable format.
27362
27363 The tonemapping algorithms implemented only work on linear light, so
27364 input data should be linearized beforehand (and possibly correctly
27365 tagged).
27366
27367 ffmpeg -i INPUT -vf zscale=transfer=linear,tonemap=clip,zscale=transfer=bt709,format=yuv420p OUTPUT
27368
27369 Options
27370
27371 The filter accepts the following options.
27372
27373 tonemap
27374 Set the tone map algorithm to use.
27375
27376 Possible values are:
27377
27378 none
27379 Do not apply any tone map, only desaturate overbright pixels.
27380
27381 clip
27382 Hard-clip any out-of-range values. Use it for perfect color
27383 accuracy for in-range values, while distorting out-of-range
27384 values.
27385
27386 linear
27387 Stretch the entire reference gamut to a linear multiple of the
27388 display.
27389
27390 gamma
27391 Fit a logarithmic transfer between the tone curves.
27392
27393 reinhard
27394 Preserve overall image brightness with a simple curve, using
27395 nonlinear contrast, which results in flattening details and
27396 degrading color accuracy.
27397
27398 hable
27399 Preserve both dark and bright details better than reinhard, at
27400 the cost of slightly darkening everything. Use it when detail
27401 preservation is more important than color and brightness
27402 accuracy.
27403
27404 mobius
27405 Smoothly map out-of-range values, while retaining contrast and
27406 colors for in-range material as much as possible. Use it when
27407 color accuracy is more important than detail preservation.
27408
27409 Default is none.
27410
27411 param
27412 Tune the tone mapping algorithm.
27413
27414 This affects the following algorithms:
27415
27416 none
27417 Ignored.
27418
27419 linear
27420 Specifies the scale factor to use while stretching. Default to
27421 1.0.
27422
27423 gamma
27424 Specifies the exponent of the function. Default to 1.8.
27425
27426 clip
27427 Specify an extra linear coefficient to multiply into the signal
27428 before clipping. Default to 1.0.
27429
27430 reinhard
27431 Specify the local contrast coefficient at the display peak.
27432 Default to 0.5, which means that in-gamut values will be about
27433 half as bright as when clipping.
27434
27435 hable
27436 Ignored.
27437
27438 mobius
27439 Specify the transition point from linear to mobius transform.
27440 Every value below this point is guaranteed to be mapped 1:1.
27441 The higher the value, the more accurate the result will be, at
27442 the cost of losing bright details. Default to 0.3, which due
27443 to the steep initial slope still preserves in-range colors
27444 fairly accurately.
27445
27446 desat
27447 Apply desaturation for highlights that exceed this level of
27448 brightness. The higher the parameter, the more color information
27449 will be preserved. This setting helps prevent unnaturally blown-out
27450 colors for super-highlights, by (smoothly) turning into white
27451 instead. This makes images feel more natural, at the cost of
27452 reducing information about out-of-range colors.
27453
27454 The default of 2.0 is somewhat conservative and will mostly just
27455 apply to skies or directly sunlit surfaces. A setting of 0.0
27456 disables this option.
27457
27458 This option works only if the input frame has a supported color
27459 tag.
27460
27461 peak
27462 Override signal/nominal/reference peak with this value. Useful when
27463 the embedded peak information in display metadata is not reliable
27464 or when tone mapping from a lower range to a higher range.
27465
27466 tpad
27467 Temporarily pad video frames.
27468
27469 The filter accepts the following options:
27470
27471 start
27472 Specify number of delay frames before input video stream. Default
27473 is 0.
27474
27475 stop
27476 Specify number of padding frames after input video stream. Set to
27477 -1 to pad indefinitely. Default is 0.
27478
27479 start_mode
27480 Set kind of frames added to beginning of stream. Can be either add
27481 or clone. With add frames of solid-color are added. With clone
27482 frames are clones of first frame. Default is add.
27483
27484 stop_mode
27485 Set kind of frames added to end of stream. Can be either add or
27486 clone. With add frames of solid-color are added. With clone
27487 frames are clones of last frame. Default is add.
27488
27489 start_duration, stop_duration
27490 Specify the duration of the start/stop delay. See the Time duration
27491 section in the ffmpeg-utils(1) manual for the accepted syntax.
27492 These options override start and stop. Default is 0.
27493
27494 color
27495 Specify the color of the padded area. For the syntax of this
27496 option, check the "Color" section in the ffmpeg-utils manual.
27497
27498 The default value of color is "black".
27499
27500 transpose
27501 Transpose rows with columns in the input video and optionally flip it.
27502
27503 It accepts the following parameters:
27504
27505 dir Specify the transposition direction.
27506
27507 Can assume the following values:
27508
27509 0, 4, cclock_flip
27510 Rotate by 90 degrees counterclockwise and vertically flip
27511 (default), that is:
27512
27513 L.R L.l
27514 . . -> . .
27515 l.r R.r
27516
27517 1, 5, clock
27518 Rotate by 90 degrees clockwise, that is:
27519
27520 L.R l.L
27521 . . -> . .
27522 l.r r.R
27523
27524 2, 6, cclock
27525 Rotate by 90 degrees counterclockwise, that is:
27526
27527 L.R R.r
27528 . . -> . .
27529 l.r L.l
27530
27531 3, 7, clock_flip
27532 Rotate by 90 degrees clockwise and vertically flip, that is:
27533
27534 L.R r.R
27535 . . -> . .
27536 l.r l.L
27537
27538 For values between 4-7, the transposition is only done if the input
27539 video geometry is portrait and not landscape. These values are
27540 deprecated, the "passthrough" option should be used instead.
27541
27542 Numerical values are deprecated, and should be dropped in favor of
27543 symbolic constants.
27544
27545 passthrough
27546 Do not apply the transposition if the input geometry matches the
27547 one specified by the specified value. It accepts the following
27548 values:
27549
27550 none
27551 Always apply transposition.
27552
27553 portrait
27554 Preserve portrait geometry (when height >= width).
27555
27556 landscape
27557 Preserve landscape geometry (when width >= height).
27558
27559 Default value is "none".
27560
27561 For example to rotate by 90 degrees clockwise and preserve portrait
27562 layout:
27563
27564 transpose=dir=1:passthrough=portrait
27565
27566 The command above can also be specified as:
27567
27568 transpose=1:portrait
27569
27570 transpose_npp
27571 Transpose rows with columns in the input video and optionally flip it.
27572 For more in depth examples see the transpose video filter, which shares
27573 mostly the same options.
27574
27575 It accepts the following parameters:
27576
27577 dir Specify the transposition direction.
27578
27579 Can assume the following values:
27580
27581 cclock_flip
27582 Rotate by 90 degrees counterclockwise and vertically flip.
27583 (default)
27584
27585 clock
27586 Rotate by 90 degrees clockwise.
27587
27588 cclock
27589 Rotate by 90 degrees counterclockwise.
27590
27591 clock_flip
27592 Rotate by 90 degrees clockwise and vertically flip.
27593
27594 passthrough
27595 Do not apply the transposition if the input geometry matches the
27596 one specified by the specified value. It accepts the following
27597 values:
27598
27599 none
27600 Always apply transposition. (default)
27601
27602 portrait
27603 Preserve portrait geometry (when height >= width).
27604
27605 landscape
27606 Preserve landscape geometry (when width >= height).
27607
27608 trim
27609 Trim the input so that the output contains one continuous subpart of
27610 the input.
27611
27612 It accepts the following parameters:
27613
27614 start
27615 Specify the time of the start of the kept section, i.e. the frame
27616 with the timestamp start will be the first frame in the output.
27617
27618 end Specify the time of the first frame that will be dropped, i.e. the
27619 frame immediately preceding the one with the timestamp end will be
27620 the last frame in the output.
27621
27622 start_pts
27623 This is the same as start, except this option sets the start
27624 timestamp in timebase units instead of seconds.
27625
27626 end_pts
27627 This is the same as end, except this option sets the end timestamp
27628 in timebase units instead of seconds.
27629
27630 duration
27631 The maximum duration of the output in seconds.
27632
27633 start_frame
27634 The number of the first frame that should be passed to the output.
27635
27636 end_frame
27637 The number of the first frame that should be dropped.
27638
27639 start, end, and duration are expressed as time duration specifications;
27640 see the Time duration section in the ffmpeg-utils(1) manual for the
27641 accepted syntax.
27642
27643 Note that the first two sets of the start/end options and the duration
27644 option look at the frame timestamp, while the _frame variants simply
27645 count the frames that pass through the filter. Also note that this
27646 filter does not modify the timestamps. If you wish for the output
27647 timestamps to start at zero, insert a setpts filter after the trim
27648 filter.
27649
27650 If multiple start or end options are set, this filter tries to be
27651 greedy and keep all the frames that match at least one of the specified
27652 constraints. To keep only the part that matches all the constraints at
27653 once, chain multiple trim filters.
27654
27655 The defaults are such that all the input is kept. So it is possible to
27656 set e.g. just the end values to keep everything before the specified
27657 time.
27658
27659 Examples:
27660
27661 • Drop everything except the second minute of input:
27662
27663 ffmpeg -i INPUT -vf trim=60:120
27664
27665 • Keep only the first second:
27666
27667 ffmpeg -i INPUT -vf trim=duration=1
27668
27669 unpremultiply
27670 Apply alpha unpremultiply effect to input video stream using first
27671 plane of second stream as alpha.
27672
27673 Both streams must have same dimensions and same pixel format.
27674
27675 The filter accepts the following option:
27676
27677 planes
27678 Set which planes will be processed, unprocessed planes will be
27679 copied. By default value 0xf, all planes will be processed.
27680
27681 If the format has 1 or 2 components, then luma is bit 0. If the
27682 format has 3 or 4 components: for RGB formats bit 0 is green, bit 1
27683 is blue and bit 2 is red; for YUV formats bit 0 is luma, bit 1 is
27684 chroma-U and bit 2 is chroma-V. If present, the alpha channel is
27685 always the last bit.
27686
27687 inplace
27688 Do not require 2nd input for processing, instead use alpha plane
27689 from input stream.
27690
27691 unsharp
27692 Sharpen or blur the input video.
27693
27694 It accepts the following parameters:
27695
27696 luma_msize_x, lx
27697 Set the luma matrix horizontal size. It must be an odd integer
27698 between 3 and 23. The default value is 5.
27699
27700 luma_msize_y, ly
27701 Set the luma matrix vertical size. It must be an odd integer
27702 between 3 and 23. The default value is 5.
27703
27704 luma_amount, la
27705 Set the luma effect strength. It must be a floating point number,
27706 reasonable values lay between -1.5 and 1.5.
27707
27708 Negative values will blur the input video, while positive values
27709 will sharpen it, a value of zero will disable the effect.
27710
27711 Default value is 1.0.
27712
27713 chroma_msize_x, cx
27714 Set the chroma matrix horizontal size. It must be an odd integer
27715 between 3 and 23. The default value is 5.
27716
27717 chroma_msize_y, cy
27718 Set the chroma matrix vertical size. It must be an odd integer
27719 between 3 and 23. The default value is 5.
27720
27721 chroma_amount, ca
27722 Set the chroma effect strength. It must be a floating point number,
27723 reasonable values lay between -1.5 and 1.5.
27724
27725 Negative values will blur the input video, while positive values
27726 will sharpen it, a value of zero will disable the effect.
27727
27728 Default value is 0.0.
27729
27730 All parameters are optional and default to the equivalent of the string
27731 '5:5:1.0:5:5:0.0'.
27732
27733 Examples
27734
27735 • Apply strong luma sharpen effect:
27736
27737 unsharp=luma_msize_x=7:luma_msize_y=7:luma_amount=2.5
27738
27739 • Apply a strong blur of both luma and chroma parameters:
27740
27741 unsharp=7:7:-2:7:7:-2
27742
27743 untile
27744 Decompose a video made of tiled images into the individual images.
27745
27746 The frame rate of the output video is the frame rate of the input video
27747 multiplied by the number of tiles.
27748
27749 This filter does the reverse of tile.
27750
27751 The filter accepts the following options:
27752
27753 layout
27754 Set the grid size (i.e. the number of lines and columns). For the
27755 syntax of this option, check the "Video size" section in the
27756 ffmpeg-utils manual.
27757
27758 Examples
27759
27760 • Produce a 1-second video from a still image file made of 25 frames
27761 stacked vertically, like an analogic film reel:
27762
27763 ffmpeg -r 1 -i image.jpg -vf untile=1x25 movie.mkv
27764
27765 uspp
27766 Apply ultra slow/simple postprocessing filter that compresses and
27767 decompresses the image at several (or - in the case of quality level 8
27768 - all) shifts and average the results.
27769
27770 The way this differs from the behavior of spp is that uspp actually
27771 encodes & decodes each case with libavcodec Snow, whereas spp uses a
27772 simplified intra only 8x8 DCT similar to MJPEG.
27773
27774 This filter is only available in ffmpeg version 4.4 or earlier.
27775
27776 The filter accepts the following options:
27777
27778 quality
27779 Set quality. This option defines the number of levels for
27780 averaging. It accepts an integer in the range 0-8. If set to 0, the
27781 filter will have no effect. A value of 8 means the higher quality.
27782 For each increment of that value the speed drops by a factor of
27783 approximately 2. Default value is 3.
27784
27785 qp Force a constant quantization parameter. If not set, the filter
27786 will use the QP from the video stream (if available).
27787
27788 v360
27789 Convert 360 videos between various formats.
27790
27791 The filter accepts the following options:
27792
27793 input
27794 output
27795 Set format of the input/output video.
27796
27797 Available formats:
27798
27799 e
27800 equirect
27801 Equirectangular projection.
27802
27803 c3x2
27804 c6x1
27805 c1x6
27806 Cubemap with 3x2/6x1/1x6 layout.
27807
27808 Format specific options:
27809
27810 in_pad
27811 out_pad
27812 Set padding proportion for the input/output cubemap. Values
27813 in decimals.
27814
27815 Example values:
27816
27817 0 No padding.
27818
27819 0.01
27820 1% of face is padding. For example, with 1920x1280
27821 resolution face size would be 640x640 and padding would
27822 be 3 pixels from each side. (640 * 0.01 = 6 pixels)
27823
27824 Default value is @samp{0}. Maximum value is @samp{0.1}.
27825
27826 fin_pad
27827 fout_pad
27828 Set fixed padding for the input/output cubemap. Values in
27829 pixels.
27830
27831 Default value is @samp{0}. If greater than zero it
27832 overrides other padding options.
27833
27834 in_forder
27835 out_forder
27836 Set order of faces for the input/output cubemap. Choose one
27837 direction for each position.
27838
27839 Designation of directions:
27840
27841 r right
27842
27843 l left
27844
27845 u up
27846
27847 d down
27848
27849 f forward
27850
27851 b back
27852
27853 Default value is @samp{rludfb}.
27854
27855 in_frot
27856 out_frot
27857 Set rotation of faces for the input/output cubemap. Choose
27858 one angle for each position.
27859
27860 Designation of angles:
27861
27862 0 0 degrees clockwise
27863
27864 1 90 degrees clockwise
27865
27866 2 180 degrees clockwise
27867
27868 3 270 degrees clockwise
27869
27870 Default value is @samp{000000}.
27871
27872 eac Equi-Angular Cubemap.
27873
27874 flat
27875 gnomonic
27876 rectilinear
27877 Regular video.
27878
27879 Format specific options:
27880
27881 h_fov
27882 v_fov
27883 d_fov
27884 Set output horizontal/vertical/diagonal field of view.
27885 Values in degrees.
27886
27887 If diagonal field of view is set it overrides horizontal
27888 and vertical field of view.
27889
27890 ih_fov
27891 iv_fov
27892 id_fov
27893 Set input horizontal/vertical/diagonal field of view.
27894 Values in degrees.
27895
27896 If diagonal field of view is set it overrides horizontal
27897 and vertical field of view.
27898
27899 dfisheye
27900 Dual fisheye.
27901
27902 Format specific options:
27903
27904 h_fov
27905 v_fov
27906 d_fov
27907 Set output horizontal/vertical/diagonal field of view.
27908 Values in degrees.
27909
27910 If diagonal field of view is set it overrides horizontal
27911 and vertical field of view.
27912
27913 ih_fov
27914 iv_fov
27915 id_fov
27916 Set input horizontal/vertical/diagonal field of view.
27917 Values in degrees.
27918
27919 If diagonal field of view is set it overrides horizontal
27920 and vertical field of view.
27921
27922 barrel
27923 fb
27924 barrelsplit
27925 Facebook's 360 formats.
27926
27927 sg Stereographic format.
27928
27929 Format specific options:
27930
27931 h_fov
27932 v_fov
27933 d_fov
27934 Set output horizontal/vertical/diagonal field of view.
27935 Values in degrees.
27936
27937 If diagonal field of view is set it overrides horizontal
27938 and vertical field of view.
27939
27940 ih_fov
27941 iv_fov
27942 id_fov
27943 Set input horizontal/vertical/diagonal field of view.
27944 Values in degrees.
27945
27946 If diagonal field of view is set it overrides horizontal
27947 and vertical field of view.
27948
27949 mercator
27950 Mercator format.
27951
27952 ball
27953 Ball format, gives significant distortion toward the back.
27954
27955 hammer
27956 Hammer-Aitoff map projection format.
27957
27958 sinusoidal
27959 Sinusoidal map projection format.
27960
27961 fisheye
27962 Fisheye projection.
27963
27964 Format specific options:
27965
27966 h_fov
27967 v_fov
27968 d_fov
27969 Set output horizontal/vertical/diagonal field of view.
27970 Values in degrees.
27971
27972 If diagonal field of view is set it overrides horizontal
27973 and vertical field of view.
27974
27975 ih_fov
27976 iv_fov
27977 id_fov
27978 Set input horizontal/vertical/diagonal field of view.
27979 Values in degrees.
27980
27981 If diagonal field of view is set it overrides horizontal
27982 and vertical field of view.
27983
27984 pannini
27985 Pannini projection.
27986
27987 Format specific options:
27988
27989 h_fov
27990 Set output pannini parameter.
27991
27992 ih_fov
27993 Set input pannini parameter.
27994
27995 cylindrical
27996 Cylindrical projection.
27997
27998 Format specific options:
27999
28000 h_fov
28001 v_fov
28002 d_fov
28003 Set output horizontal/vertical/diagonal field of view.
28004 Values in degrees.
28005
28006 If diagonal field of view is set it overrides horizontal
28007 and vertical field of view.
28008
28009 ih_fov
28010 iv_fov
28011 id_fov
28012 Set input horizontal/vertical/diagonal field of view.
28013 Values in degrees.
28014
28015 If diagonal field of view is set it overrides horizontal
28016 and vertical field of view.
28017
28018 perspective
28019 Perspective projection. (output only)
28020
28021 Format specific options:
28022
28023 v_fov
28024 Set perspective parameter.
28025
28026 tetrahedron
28027 Tetrahedron projection.
28028
28029 tsp Truncated square pyramid projection.
28030
28031 he
28032 hequirect
28033 Half equirectangular projection.
28034
28035 equisolid
28036 Equisolid format.
28037
28038 Format specific options:
28039
28040 h_fov
28041 v_fov
28042 d_fov
28043 Set output horizontal/vertical/diagonal field of view.
28044 Values in degrees.
28045
28046 If diagonal field of view is set it overrides horizontal
28047 and vertical field of view.
28048
28049 ih_fov
28050 iv_fov
28051 id_fov
28052 Set input horizontal/vertical/diagonal field of view.
28053 Values in degrees.
28054
28055 If diagonal field of view is set it overrides horizontal
28056 and vertical field of view.
28057
28058 og Orthographic format.
28059
28060 Format specific options:
28061
28062 h_fov
28063 v_fov
28064 d_fov
28065 Set output horizontal/vertical/diagonal field of view.
28066 Values in degrees.
28067
28068 If diagonal field of view is set it overrides horizontal
28069 and vertical field of view.
28070
28071 ih_fov
28072 iv_fov
28073 id_fov
28074 Set input horizontal/vertical/diagonal field of view.
28075 Values in degrees.
28076
28077 If diagonal field of view is set it overrides horizontal
28078 and vertical field of view.
28079
28080 octahedron
28081 Octahedron projection.
28082
28083 cylindricalea
28084 Cylindrical Equal Area projection.
28085
28086 interp
28087 Set interpolation method.Note: more complex interpolation methods
28088 require much more memory to run.
28089
28090 Available methods:
28091
28092 near
28093 nearest
28094 Nearest neighbour.
28095
28096 line
28097 linear
28098 Bilinear interpolation.
28099
28100 lagrange9
28101 Lagrange9 interpolation.
28102
28103 cube
28104 cubic
28105 Bicubic interpolation.
28106
28107 lanc
28108 lanczos
28109 Lanczos interpolation.
28110
28111 sp16
28112 spline16
28113 Spline16 interpolation.
28114
28115 gauss
28116 gaussian
28117 Gaussian interpolation.
28118
28119 mitchell
28120 Mitchell interpolation.
28121
28122 Default value is @samp{line}.
28123
28124 w
28125 h Set the output video resolution.
28126
28127 Default resolution depends on formats.
28128
28129 in_stereo
28130 out_stereo
28131 Set the input/output stereo format.
28132
28133 2d 2D mono
28134
28135 sbs Side by side
28136
28137 tb Top bottom
28138
28139 Default value is @samp{2d} for input and output format.
28140
28141 yaw
28142 pitch
28143 roll
28144 Set rotation for the output video. Values in degrees.
28145
28146 rorder
28147 Set rotation order for the output video. Choose one item for each
28148 position.
28149
28150 y, Y
28151 yaw
28152
28153 p, P
28154 pitch
28155
28156 r, R
28157 roll
28158
28159 Default value is @samp{ypr}.
28160
28161 h_flip
28162 v_flip
28163 d_flip
28164 Flip the output video horizontally(swaps
28165 left-right)/vertically(swaps up-down)/in-depth(swaps back-forward).
28166 Boolean values.
28167
28168 ih_flip
28169 iv_flip
28170 Set if input video is flipped horizontally/vertically. Boolean
28171 values.
28172
28173 in_trans
28174 Set if input video is transposed. Boolean value, by default
28175 disabled.
28176
28177 out_trans
28178 Set if output video needs to be transposed. Boolean value, by
28179 default disabled.
28180
28181 h_offset
28182 v_offset
28183 Set output horizontal/vertical off-axis offset. Default is set to
28184 0. Allowed range is from -1 to 1.
28185
28186 alpha_mask
28187 Build mask in alpha plane for all unmapped pixels by marking them
28188 fully transparent. Boolean value, by default disabled.
28189
28190 reset_rot
28191 Reset rotation of output video. Boolean value, by default disabled.
28192
28193 Examples
28194
28195 • Convert equirectangular video to cubemap with 3x2 layout and 1%
28196 padding using bicubic interpolation:
28197
28198 ffmpeg -i input.mkv -vf v360=e:c3x2:cubic:out_pad=0.01 output.mkv
28199
28200 • Extract back view of Equi-Angular Cubemap:
28201
28202 ffmpeg -i input.mkv -vf v360=eac:flat:yaw=180 output.mkv
28203
28204 • Convert transposed and horizontally flipped Equi-Angular Cubemap in
28205 side-by-side stereo format to equirectangular top-bottom stereo
28206 format:
28207
28208 v360=eac:equirect:in_stereo=sbs:in_trans=1:ih_flip=1:out_stereo=tb
28209
28210 Commands
28211
28212 This filter supports subset of above options as commands.
28213
28214 vaguedenoiser
28215 Apply a wavelet based denoiser.
28216
28217 It transforms each frame from the video input into the wavelet domain,
28218 using Cohen-Daubechies-Feauveau 9/7. Then it applies some filtering to
28219 the obtained coefficients. It does an inverse wavelet transform after.
28220 Due to wavelet properties, it should give a nice smoothed result, and
28221 reduced noise, without blurring picture features.
28222
28223 This filter accepts the following options:
28224
28225 threshold
28226 The filtering strength. The higher, the more filtered the video
28227 will be. Hard thresholding can use a higher threshold than soft
28228 thresholding before the video looks overfiltered. Default value is
28229 2.
28230
28231 method
28232 The filtering method the filter will use.
28233
28234 It accepts the following values:
28235
28236 hard
28237 All values under the threshold will be zeroed.
28238
28239 soft
28240 All values under the threshold will be zeroed. All values above
28241 will be reduced by the threshold.
28242
28243 garrote
28244 Scales or nullifies coefficients - intermediary between (more)
28245 soft and (less) hard thresholding.
28246
28247 Default is garrote.
28248
28249 nsteps
28250 Number of times, the wavelet will decompose the picture. Picture
28251 can't be decomposed beyond a particular point (typically, 8 for a
28252 640x480 frame - as 2^9 = 512 > 480). Valid values are integers
28253 between 1 and 32. Default value is 6.
28254
28255 percent
28256 Partial of full denoising (limited coefficients shrinking), from 0
28257 to 100. Default value is 85.
28258
28259 planes
28260 A list of the planes to process. By default all planes are
28261 processed.
28262
28263 type
28264 The threshold type the filter will use.
28265
28266 It accepts the following values:
28267
28268 universal
28269 Threshold used is same for all decompositions.
28270
28271 bayes
28272 Threshold used depends also on each decomposition coefficients.
28273
28274 Default is universal.
28275
28276 varblur
28277 Apply variable blur filter by using 2nd video stream to set blur
28278 radius. The 2nd stream must have the same dimensions.
28279
28280 This filter accepts the following options:
28281
28282 min_r
28283 Set min allowed radius. Allowed range is from 0 to 254. Default is
28284 0.
28285
28286 max_r
28287 Set max allowed radius. Allowed range is from 1 to 255. Default is
28288 8.
28289
28290 planes
28291 Set which planes to process. By default, all are used.
28292
28293 The "varblur" filter also supports the framesync options.
28294
28295 Commands
28296
28297 This filter supports all the above options as commands.
28298
28299 vectorscope
28300 Display 2 color component values in the two dimensional graph (which is
28301 called a vectorscope).
28302
28303 This filter accepts the following options:
28304
28305 mode, m
28306 Set vectorscope mode.
28307
28308 It accepts the following values:
28309
28310 gray
28311 tint
28312 Gray values are displayed on graph, higher brightness means
28313 more pixels have same component color value on location in
28314 graph. This is the default mode.
28315
28316 color
28317 Gray values are displayed on graph. Surrounding pixels values
28318 which are not present in video frame are drawn in gradient of 2
28319 color components which are set by option "x" and "y". The 3rd
28320 color component is static.
28321
28322 color2
28323 Actual color components values present in video frame are
28324 displayed on graph.
28325
28326 color3
28327 Similar as color2 but higher frequency of same values "x" and
28328 "y" on graph increases value of another color component, which
28329 is luminance by default values of "x" and "y".
28330
28331 color4
28332 Actual colors present in video frame are displayed on graph. If
28333 two different colors map to same position on graph then color
28334 with higher value of component not present in graph is picked.
28335
28336 color5
28337 Gray values are displayed on graph. Similar to "color" but with
28338 3rd color component picked from radial gradient.
28339
28340 x Set which color component will be represented on X-axis. Default is
28341 1.
28342
28343 y Set which color component will be represented on Y-axis. Default is
28344 2.
28345
28346 intensity, i
28347 Set intensity, used by modes: gray, color, color3 and color5 for
28348 increasing brightness of color component which represents frequency
28349 of (X, Y) location in graph.
28350
28351 envelope, e
28352 none
28353 No envelope, this is default.
28354
28355 instant
28356 Instant envelope, even darkest single pixel will be clearly
28357 highlighted.
28358
28359 peak
28360 Hold maximum and minimum values presented in graph over time.
28361 This way you can still spot out of range values without
28362 constantly looking at vectorscope.
28363
28364 peak+instant
28365 Peak and instant envelope combined together.
28366
28367 graticule, g
28368 Set what kind of graticule to draw.
28369
28370 none
28371 green
28372 color
28373 invert
28374 opacity, o
28375 Set graticule opacity.
28376
28377 flags, f
28378 Set graticule flags.
28379
28380 white
28381 Draw graticule for white point.
28382
28383 black
28384 Draw graticule for black point.
28385
28386 name
28387 Draw color points short names.
28388
28389 bgopacity, b
28390 Set background opacity.
28391
28392 lthreshold, l
28393 Set low threshold for color component not represented on X or Y
28394 axis. Values lower than this value will be ignored. Default is 0.
28395 Note this value is multiplied with actual max possible value one
28396 pixel component can have. So for 8-bit input and low threshold
28397 value of 0.1 actual threshold is 0.1 * 255 = 25.
28398
28399 hthreshold, h
28400 Set high threshold for color component not represented on X or Y
28401 axis. Values higher than this value will be ignored. Default is 1.
28402 Note this value is multiplied with actual max possible value one
28403 pixel component can have. So for 8-bit input and high threshold
28404 value of 0.9 actual threshold is 0.9 * 255 = 230.
28405
28406 colorspace, c
28407 Set what kind of colorspace to use when drawing graticule.
28408
28409 auto
28410 601
28411 709
28412
28413 Default is auto.
28414
28415 tint0, t0
28416 tint1, t1
28417 Set color tint for gray/tint vectorscope mode. By default both
28418 options are zero. This means no tint, and output will remain gray.
28419
28420 vidstabdetect
28421 Analyze video stabilization/deshaking. Perform pass 1 of 2, see
28422 vidstabtransform for pass 2.
28423
28424 This filter generates a file with relative translation and rotation
28425 transform information about subsequent frames, which is then used by
28426 the vidstabtransform filter.
28427
28428 To enable compilation of this filter you need to configure FFmpeg with
28429 "--enable-libvidstab".
28430
28431 This filter accepts the following options:
28432
28433 result
28434 Set the path to the file used to write the transforms information.
28435 Default value is transforms.trf.
28436
28437 shakiness
28438 Set how shaky the video is and how quick the camera is. It accepts
28439 an integer in the range 1-10, a value of 1 means little shakiness,
28440 a value of 10 means strong shakiness. Default value is 5.
28441
28442 accuracy
28443 Set the accuracy of the detection process. It must be a value in
28444 the range 1-15. A value of 1 means low accuracy, a value of 15
28445 means high accuracy. Default value is 15.
28446
28447 stepsize
28448 Set stepsize of the search process. The region around minimum is
28449 scanned with 1 pixel resolution. Default value is 6.
28450
28451 mincontrast
28452 Set minimum contrast. Below this value a local measurement field is
28453 discarded. Must be a floating point value in the range 0-1. Default
28454 value is 0.3.
28455
28456 tripod
28457 Set reference frame number for tripod mode.
28458
28459 If enabled, the motion of the frames is compared to a reference
28460 frame in the filtered stream, identified by the specified number.
28461 The idea is to compensate all movements in a more-or-less static
28462 scene and keep the camera view absolutely still.
28463
28464 If set to 0, it is disabled. The frames are counted starting from
28465 1.
28466
28467 show
28468 Show fields and transforms in the resulting frames. It accepts an
28469 integer in the range 0-2. Default value is 0, which disables any
28470 visualization.
28471
28472 Examples
28473
28474 • Use default values:
28475
28476 vidstabdetect
28477
28478 • Analyze strongly shaky movie and put the results in file
28479 mytransforms.trf:
28480
28481 vidstabdetect=shakiness=10:accuracy=15:result="mytransforms.trf"
28482
28483 • Visualize the result of internal transformations in the resulting
28484 video:
28485
28486 vidstabdetect=show=1
28487
28488 • Analyze a video with medium shakiness using ffmpeg:
28489
28490 ffmpeg -i input -vf vidstabdetect=shakiness=5:show=1 dummy.avi
28491
28492 vidstabtransform
28493 Video stabilization/deshaking: pass 2 of 2, see vidstabdetect for pass
28494 1.
28495
28496 Read a file with transform information for each frame and
28497 apply/compensate them. Together with the vidstabdetect filter this can
28498 be used to deshake videos. See also
28499 <http://public.hronopik.de/vid.stab>. It is important to also use the
28500 unsharp filter, see below.
28501
28502 To enable compilation of this filter you need to configure FFmpeg with
28503 "--enable-libvidstab".
28504
28505 Options
28506
28507 input
28508 Set path to the file used to read the transforms. Default value is
28509 transforms.trf.
28510
28511 smoothing
28512 Set the number of frames (value*2 + 1) used for lowpass filtering
28513 the camera movements. Default value is 10.
28514
28515 For example a number of 10 means that 21 frames are used (10 in the
28516 past and 10 in the future) to smoothen the motion in the video. A
28517 larger value leads to a smoother video, but limits the acceleration
28518 of the camera (pan/tilt movements). 0 is a special case where a
28519 static camera is simulated.
28520
28521 optalgo
28522 Set the camera path optimization algorithm.
28523
28524 Accepted values are:
28525
28526 gauss
28527 gaussian kernel low-pass filter on camera motion (default)
28528
28529 avg averaging on transformations
28530
28531 maxshift
28532 Set maximal number of pixels to translate frames. Default value is
28533 -1, meaning no limit.
28534
28535 maxangle
28536 Set maximal angle in radians (degree*PI/180) to rotate frames.
28537 Default value is -1, meaning no limit.
28538
28539 crop
28540 Specify how to deal with borders that may be visible due to
28541 movement compensation.
28542
28543 Available values are:
28544
28545 keep
28546 keep image information from previous frame (default)
28547
28548 black
28549 fill the border black
28550
28551 invert
28552 Invert transforms if set to 1. Default value is 0.
28553
28554 relative
28555 Consider transforms as relative to previous frame if set to 1,
28556 absolute if set to 0. Default value is 0.
28557
28558 zoom
28559 Set percentage to zoom. A positive value will result in a zoom-in
28560 effect, a negative value in a zoom-out effect. Default value is 0
28561 (no zoom).
28562
28563 optzoom
28564 Set optimal zooming to avoid borders.
28565
28566 Accepted values are:
28567
28568 0 disabled
28569
28570 1 optimal static zoom value is determined (only very strong
28571 movements will lead to visible borders) (default)
28572
28573 2 optimal adaptive zoom value is determined (no borders will be
28574 visible), see zoomspeed
28575
28576 Note that the value given at zoom is added to the one calculated
28577 here.
28578
28579 zoomspeed
28580 Set percent to zoom maximally each frame (enabled when optzoom is
28581 set to 2). Range is from 0 to 5, default value is 0.25.
28582
28583 interpol
28584 Specify type of interpolation.
28585
28586 Available values are:
28587
28588 no no interpolation
28589
28590 linear
28591 linear only horizontal
28592
28593 bilinear
28594 linear in both directions (default)
28595
28596 bicubic
28597 cubic in both directions (slow)
28598
28599 tripod
28600 Enable virtual tripod mode if set to 1, which is equivalent to
28601 "relative=0:smoothing=0". Default value is 0.
28602
28603 Use also "tripod" option of vidstabdetect.
28604
28605 debug
28606 Increase log verbosity if set to 1. Also the detected global
28607 motions are written to the temporary file global_motions.trf.
28608 Default value is 0.
28609
28610 Examples
28611
28612 • Use ffmpeg for a typical stabilization with default values:
28613
28614 ffmpeg -i inp.mpeg -vf vidstabtransform,unsharp=5:5:0.8:3:3:0.4 inp_stabilized.mpeg
28615
28616 Note the use of the unsharp filter which is always recommended.
28617
28618 • Zoom in a bit more and load transform data from a given file:
28619
28620 vidstabtransform=zoom=5:input="mytransforms.trf"
28621
28622 • Smoothen the video even more:
28623
28624 vidstabtransform=smoothing=30
28625
28626 vflip
28627 Flip the input video vertically.
28628
28629 For example, to vertically flip a video with ffmpeg:
28630
28631 ffmpeg -i in.avi -vf "vflip" out.avi
28632
28633 vfrdet
28634 Detect variable frame rate video.
28635
28636 This filter tries to detect if the input is variable or constant frame
28637 rate.
28638
28639 At end it will output number of frames detected as having variable
28640 delta pts, and ones with constant delta pts. If there was frames with
28641 variable delta, than it will also show min, max and average delta
28642 encountered.
28643
28644 vibrance
28645 Boost or alter saturation.
28646
28647 The filter accepts the following options:
28648
28649 intensity
28650 Set strength of boost if positive value or strength of alter if
28651 negative value. Default is 0. Allowed range is from -2 to 2.
28652
28653 rbal
28654 Set the red balance. Default is 1. Allowed range is from -10 to 10.
28655
28656 gbal
28657 Set the green balance. Default is 1. Allowed range is from -10 to
28658 10.
28659
28660 bbal
28661 Set the blue balance. Default is 1. Allowed range is from -10 to
28662 10.
28663
28664 rlum
28665 Set the red luma coefficient.
28666
28667 glum
28668 Set the green luma coefficient.
28669
28670 blum
28671 Set the blue luma coefficient.
28672
28673 alternate
28674 If "intensity" is negative and this is set to 1, colors will
28675 change, otherwise colors will be less saturated, more towards gray.
28676
28677 Commands
28678
28679 This filter supports the all above options as commands.
28680
28681 vif
28682 Obtain the average VIF (Visual Information Fidelity) between two input
28683 videos.
28684
28685 This filter takes two input videos.
28686
28687 Both input videos must have the same resolution and pixel format for
28688 this filter to work correctly. Also it assumes that both inputs have
28689 the same number of frames, which are compared one by one.
28690
28691 The obtained average VIF score is printed through the logging system.
28692
28693 The filter stores the calculated VIF score of each frame.
28694
28695 In the below example the input file main.mpg being processed is
28696 compared with the reference file ref.mpg.
28697
28698 ffmpeg -i main.mpg -i ref.mpg -lavfi vif -f null -
28699
28700 vignette
28701 Make or reverse a natural vignetting effect.
28702
28703 The filter accepts the following options:
28704
28705 angle, a
28706 Set lens angle expression as a number of radians.
28707
28708 The value is clipped in the "[0,PI/2]" range.
28709
28710 Default value: "PI/5"
28711
28712 x0
28713 y0 Set center coordinates expressions. Respectively "w/2" and "h/2" by
28714 default.
28715
28716 mode
28717 Set forward/backward mode.
28718
28719 Available modes are:
28720
28721 forward
28722 The larger the distance from the central point, the darker the
28723 image becomes.
28724
28725 backward
28726 The larger the distance from the central point, the brighter
28727 the image becomes. This can be used to reverse a vignette
28728 effect, though there is no automatic detection to extract the
28729 lens angle and other settings (yet). It can also be used to
28730 create a burning effect.
28731
28732 Default value is forward.
28733
28734 eval
28735 Set evaluation mode for the expressions (angle, x0, y0).
28736
28737 It accepts the following values:
28738
28739 init
28740 Evaluate expressions only once during the filter
28741 initialization.
28742
28743 frame
28744 Evaluate expressions for each incoming frame. This is way
28745 slower than the init mode since it requires all the scalers to
28746 be re-computed, but it allows advanced dynamic expressions.
28747
28748 Default value is init.
28749
28750 dither
28751 Set dithering to reduce the circular banding effects. Default is 1
28752 (enabled).
28753
28754 aspect
28755 Set vignette aspect. This setting allows one to adjust the shape of
28756 the vignette. Setting this value to the SAR of the input will make
28757 a rectangular vignetting following the dimensions of the video.
28758
28759 Default is "1/1".
28760
28761 Expressions
28762
28763 The alpha, x0 and y0 expressions can contain the following parameters.
28764
28765 w
28766 h input width and height
28767
28768 n the number of input frame, starting from 0
28769
28770 pts the PTS (Presentation TimeStamp) time of the filtered video frame,
28771 expressed in TB units, NAN if undefined
28772
28773 r frame rate of the input video, NAN if the input frame rate is
28774 unknown
28775
28776 t the PTS (Presentation TimeStamp) of the filtered video frame,
28777 expressed in seconds, NAN if undefined
28778
28779 tb time base of the input video
28780
28781 Examples
28782
28783 • Apply simple strong vignetting effect:
28784
28785 vignette=PI/4
28786
28787 • Make a flickering vignetting:
28788
28789 vignette='PI/4+random(1)*PI/50':eval=frame
28790
28791 vmafmotion
28792 Obtain the average VMAF motion score of a video. It is one of the
28793 component metrics of VMAF.
28794
28795 The obtained average motion score is printed through the logging
28796 system.
28797
28798 The filter accepts the following options:
28799
28800 stats_file
28801 If specified, the filter will use the named file to save the motion
28802 score of each frame with respect to the previous frame. When
28803 filename equals "-" the data is sent to standard output.
28804
28805 Example:
28806
28807 ffmpeg -i ref.mpg -vf vmafmotion -f null -
28808
28809 vstack
28810 Stack input videos vertically.
28811
28812 All streams must be of same pixel format and of same width.
28813
28814 Note that this filter is faster than using overlay and pad filter to
28815 create same output.
28816
28817 The filter accepts the following options:
28818
28819 inputs
28820 Set number of input streams. Default is 2.
28821
28822 shortest
28823 If set to 1, force the output to terminate when the shortest input
28824 terminates. Default value is 0.
28825
28826 w3fdif
28827 Deinterlace the input video ("w3fdif" stands for "Weston 3 Field
28828 Deinterlacing Filter").
28829
28830 Based on the process described by Martin Weston for BBC R&D, and
28831 implemented based on the de-interlace algorithm written by Jim
28832 Easterbrook for BBC R&D, the Weston 3 field deinterlacing filter uses
28833 filter coefficients calculated by BBC R&D.
28834
28835 This filter uses field-dominance information in frame to decide which
28836 of each pair of fields to place first in the output. If it gets it
28837 wrong use setfield filter before "w3fdif" filter.
28838
28839 There are two sets of filter coefficients, so called "simple" and
28840 "complex". Which set of filter coefficients is used can be set by
28841 passing an optional parameter:
28842
28843 filter
28844 Set the interlacing filter coefficients. Accepts one of the
28845 following values:
28846
28847 simple
28848 Simple filter coefficient set.
28849
28850 complex
28851 More-complex filter coefficient set.
28852
28853 Default value is complex.
28854
28855 mode
28856 The interlacing mode to adopt. It accepts one of the following
28857 values:
28858
28859 frame
28860 Output one frame for each frame.
28861
28862 field
28863 Output one frame for each field.
28864
28865 The default value is "field".
28866
28867 parity
28868 The picture field parity assumed for the input interlaced video. It
28869 accepts one of the following values:
28870
28871 tff Assume the top field is first.
28872
28873 bff Assume the bottom field is first.
28874
28875 auto
28876 Enable automatic detection of field parity.
28877
28878 The default value is "auto". If the interlacing is unknown or the
28879 decoder does not export this information, top field first will be
28880 assumed.
28881
28882 deint
28883 Specify which frames to deinterlace. Accepts one of the following
28884 values:
28885
28886 all Deinterlace all frames,
28887
28888 interlaced
28889 Only deinterlace frames marked as interlaced.
28890
28891 Default value is all.
28892
28893 Commands
28894
28895 This filter supports same commands as options.
28896
28897 waveform
28898 Video waveform monitor.
28899
28900 The waveform monitor plots color component intensity. By default
28901 luminance only. Each column of the waveform corresponds to a column of
28902 pixels in the source video.
28903
28904 It accepts the following options:
28905
28906 mode, m
28907 Can be either "row", or "column". Default is "column". In row
28908 mode, the graph on the left side represents color component value 0
28909 and the right side represents value = 255. In column mode, the top
28910 side represents color component value = 0 and bottom side
28911 represents value = 255.
28912
28913 intensity, i
28914 Set intensity. Smaller values are useful to find out how many
28915 values of the same luminance are distributed across input
28916 rows/columns. Default value is 0.04. Allowed range is [0, 1].
28917
28918 mirror, r
28919 Set mirroring mode. 0 means unmirrored, 1 means mirrored. In
28920 mirrored mode, higher values will be represented on the left side
28921 for "row" mode and at the top for "column" mode. Default is 1
28922 (mirrored).
28923
28924 display, d
28925 Set display mode. It accepts the following values:
28926
28927 overlay
28928 Presents information identical to that in the "parade", except
28929 that the graphs representing color components are superimposed
28930 directly over one another.
28931
28932 This display mode makes it easier to spot relative differences
28933 or similarities in overlapping areas of the color components
28934 that are supposed to be identical, such as neutral whites,
28935 grays, or blacks.
28936
28937 stack
28938 Display separate graph for the color components side by side in
28939 "row" mode or one below the other in "column" mode.
28940
28941 parade
28942 Display separate graph for the color components side by side in
28943 "column" mode or one below the other in "row" mode.
28944
28945 Using this display mode makes it easy to spot color casts in
28946 the highlights and shadows of an image, by comparing the
28947 contours of the top and the bottom graphs of each waveform.
28948 Since whites, grays, and blacks are characterized by exactly
28949 equal amounts of red, green, and blue, neutral areas of the
28950 picture should display three waveforms of roughly equal
28951 width/height. If not, the correction is easy to perform by
28952 making level adjustments the three waveforms.
28953
28954 Default is "stack".
28955
28956 components, c
28957 Set which color components to display. Default is 1, which means
28958 only luminance or red color component if input is in RGB
28959 colorspace. If is set for example to 7 it will display all 3 (if)
28960 available color components.
28961
28962 envelope, e
28963 none
28964 No envelope, this is default.
28965
28966 instant
28967 Instant envelope, minimum and maximum values presented in graph
28968 will be easily visible even with small "step" value.
28969
28970 peak
28971 Hold minimum and maximum values presented in graph across time.
28972 This way you can still spot out of range values without
28973 constantly looking at waveforms.
28974
28975 peak+instant
28976 Peak and instant envelope combined together.
28977
28978 filter, f
28979 lowpass
28980 No filtering, this is default.
28981
28982 flat
28983 Luma and chroma combined together.
28984
28985 aflat
28986 Similar as above, but shows difference between blue and red
28987 chroma.
28988
28989 xflat
28990 Similar as above, but use different colors.
28991
28992 yflat
28993 Similar as above, but again with different colors.
28994
28995 chroma
28996 Displays only chroma.
28997
28998 color
28999 Displays actual color value on waveform.
29000
29001 acolor
29002 Similar as above, but with luma showing frequency of chroma
29003 values.
29004
29005 graticule, g
29006 Set which graticule to display.
29007
29008 none
29009 Do not display graticule.
29010
29011 green
29012 Display green graticule showing legal broadcast ranges.
29013
29014 orange
29015 Display orange graticule showing legal broadcast ranges.
29016
29017 invert
29018 Display invert graticule showing legal broadcast ranges.
29019
29020 opacity, o
29021 Set graticule opacity.
29022
29023 flags, fl
29024 Set graticule flags.
29025
29026 numbers
29027 Draw numbers above lines. By default enabled.
29028
29029 dots
29030 Draw dots instead of lines.
29031
29032 scale, s
29033 Set scale used for displaying graticule.
29034
29035 digital
29036 millivolts
29037 ire
29038
29039 Default is digital.
29040
29041 bgopacity, b
29042 Set background opacity.
29043
29044 tint0, t0
29045 tint1, t1
29046 Set tint for output. Only used with lowpass filter and when
29047 display is not overlay and input pixel formats are not RGB.
29048
29049 fitmode, fm
29050 Set sample aspect ratio of video output frames. Can be used to
29051 configure waveform so it is not streched too much in one of
29052 directions.
29053
29054 none
29055 Set sample aspect ration to 1/1.
29056
29057 size
29058 Set sample aspect ratio to match input size of video
29059
29060 Default is none.
29061
29062 weave, doubleweave
29063 The "weave" takes a field-based video input and join each two
29064 sequential fields into single frame, producing a new double height clip
29065 with half the frame rate and half the frame count.
29066
29067 The "doubleweave" works same as "weave" but without halving frame rate
29068 and frame count.
29069
29070 It accepts the following option:
29071
29072 first_field
29073 Set first field. Available values are:
29074
29075 top, t
29076 Set the frame as top-field-first.
29077
29078 bottom, b
29079 Set the frame as bottom-field-first.
29080
29081 Examples
29082
29083 • Interlace video using select and separatefields filter:
29084
29085 separatefields,select=eq(mod(n,4),0)+eq(mod(n,4),3),weave
29086
29087 xbr
29088 Apply the xBR high-quality magnification filter which is designed for
29089 pixel art. It follows a set of edge-detection rules, see
29090 <https://forums.libretro.com/t/xbr-algorithm-tutorial/123>.
29091
29092 It accepts the following option:
29093
29094 n Set the scaling dimension: 2 for "2xBR", 3 for "3xBR" and 4 for
29095 "4xBR". Default is 3.
29096
29097 xcorrelate
29098 Apply normalized cross-correlation between first and second input video
29099 stream.
29100
29101 Second input video stream dimensions must be lower than first input
29102 video stream.
29103
29104 The filter accepts the following options:
29105
29106 planes
29107 Set which planes to process.
29108
29109 secondary
29110 Set which secondary video frames will be processed from second
29111 input video stream, can be first or all. Default is all.
29112
29113 The "xcorrelate" filter also supports the framesync options.
29114
29115 xfade
29116 Apply cross fade from one input video stream to another input video
29117 stream. The cross fade is applied for specified duration.
29118
29119 Both inputs must be constant frame-rate and have the same resolution,
29120 pixel format, frame rate and timebase.
29121
29122 The filter accepts the following options:
29123
29124 transition
29125 Set one of available transition effects:
29126
29127 custom
29128 fade
29129 wipeleft
29130 wiperight
29131 wipeup
29132 wipedown
29133 slideleft
29134 slideright
29135 slideup
29136 slidedown
29137 circlecrop
29138 rectcrop
29139 distance
29140 fadeblack
29141 fadewhite
29142 radial
29143 smoothleft
29144 smoothright
29145 smoothup
29146 smoothdown
29147 circleopen
29148 circleclose
29149 vertopen
29150 vertclose
29151 horzopen
29152 horzclose
29153 dissolve
29154 pixelize
29155 diagtl
29156 diagtr
29157 diagbl
29158 diagbr
29159 hlslice
29160 hrslice
29161 vuslice
29162 vdslice
29163 hblur
29164 fadegrays
29165 wipetl
29166 wipetr
29167 wipebl
29168 wipebr
29169 squeezeh
29170 squeezev
29171 zoomin
29172
29173 Default transition effect is fade.
29174
29175 duration
29176 Set cross fade duration in seconds. Range is 0 to 60 seconds.
29177 Default duration is 1 second.
29178
29179 offset
29180 Set cross fade start relative to first input stream in seconds.
29181 Default offset is 0.
29182
29183 expr
29184 Set expression for custom transition effect.
29185
29186 The expressions can use the following variables and functions:
29187
29188 X
29189 Y The coordinates of the current sample.
29190
29191 W
29192 H The width and height of the image.
29193
29194 P Progress of transition effect.
29195
29196 PLANE
29197 Currently processed plane.
29198
29199 A Return value of first input at current location and plane.
29200
29201 B Return value of second input at current location and plane.
29202
29203 a0(x, y)
29204 a1(x, y)
29205 a2(x, y)
29206 a3(x, y)
29207 Return the value of the pixel at location (x,y) of the
29208 first/second/third/fourth component of first input.
29209
29210 b0(x, y)
29211 b1(x, y)
29212 b2(x, y)
29213 b3(x, y)
29214 Return the value of the pixel at location (x,y) of the
29215 first/second/third/fourth component of second input.
29216
29217 Examples
29218
29219 • Cross fade from one input video to another input video, with fade
29220 transition and duration of transition of 2 seconds starting at
29221 offset of 5 seconds:
29222
29223 ffmpeg -i first.mp4 -i second.mp4 -filter_complex xfade=transition=fade:duration=2:offset=5 output.mp4
29224
29225 xmedian
29226 Pick median pixels from several input videos.
29227
29228 The filter accepts the following options:
29229
29230 inputs
29231 Set number of inputs. Default is 3. Allowed range is from 3 to
29232 255. If number of inputs is even number, than result will be mean
29233 value between two median values.
29234
29235 planes
29236 Set which planes to filter. Default value is 15, by which all
29237 planes are processed.
29238
29239 percentile
29240 Set median percentile. Default value is 0.5. Default value of 0.5
29241 will pick always median values, while 0 will pick minimum values,
29242 and 1 maximum values.
29243
29244 Commands
29245
29246 This filter supports all above options as commands, excluding option
29247 "inputs".
29248
29249 xstack
29250 Stack video inputs into custom layout.
29251
29252 All streams must be of same pixel format.
29253
29254 The filter accepts the following options:
29255
29256 inputs
29257 Set number of input streams. Default is 2.
29258
29259 layout
29260 Specify layout of inputs. This option requires the desired layout
29261 configuration to be explicitly set by the user. This sets position
29262 of each video input in output. Each input is separated by '|'. The
29263 first number represents the column, and the second number
29264 represents the row. Numbers start at 0 and are separated by '_'.
29265 Optionally one can use wX and hX, where X is video input from which
29266 to take width or height. Multiple values can be used when
29267 separated by '+'. In such case values are summed together.
29268
29269 Note that if inputs are of different sizes gaps may appear, as not
29270 all of the output video frame will be filled. Similarly, videos can
29271 overlap each other if their position doesn't leave enough space for
29272 the full frame of adjoining videos.
29273
29274 For 2 inputs, a default layout of "0_0|w0_0" is set. In all other
29275 cases, a layout must be set by the user.
29276
29277 shortest
29278 If set to 1, force the output to terminate when the shortest input
29279 terminates. Default value is 0.
29280
29281 fill
29282 If set to valid color, all unused pixels will be filled with that
29283 color. By default fill is set to none, so it is disabled.
29284
29285 Examples
29286
29287 • Display 4 inputs into 2x2 grid.
29288
29289 Layout:
29290
29291 input1(0, 0) | input3(w0, 0)
29292 input2(0, h0) | input4(w0, h0)
29293
29294
29295
29296 xstack=inputs=4:layout=0_0|0_h0|w0_0|w0_h0
29297
29298 Note that if inputs are of different sizes, gaps or overlaps may
29299 occur.
29300
29301 • Display 4 inputs into 1x4 grid.
29302
29303 Layout:
29304
29305 input1(0, 0)
29306 input2(0, h0)
29307 input3(0, h0+h1)
29308 input4(0, h0+h1+h2)
29309
29310
29311
29312 xstack=inputs=4:layout=0_0|0_h0|0_h0+h1|0_h0+h1+h2
29313
29314 Note that if inputs are of different widths, unused space will
29315 appear.
29316
29317 • Display 9 inputs into 3x3 grid.
29318
29319 Layout:
29320
29321 input1(0, 0) | input4(w0, 0) | input7(w0+w3, 0)
29322 input2(0, h0) | input5(w0, h0) | input8(w0+w3, h0)
29323 input3(0, h0+h1) | input6(w0, h0+h1) | input9(w0+w3, h0+h1)
29324
29325
29326
29327 xstack=inputs=9:layout=0_0|0_h0|0_h0+h1|w0_0|w0_h0|w0_h0+h1|w0+w3_0|w0+w3_h0|w0+w3_h0+h1
29328
29329 Note that if inputs are of different sizes, gaps or overlaps may
29330 occur.
29331
29332 • Display 16 inputs into 4x4 grid.
29333
29334 Layout:
29335
29336 input1(0, 0) | input5(w0, 0) | input9 (w0+w4, 0) | input13(w0+w4+w8, 0)
29337 input2(0, h0) | input6(w0, h0) | input10(w0+w4, h0) | input14(w0+w4+w8, h0)
29338 input3(0, h0+h1) | input7(w0, h0+h1) | input11(w0+w4, h0+h1) | input15(w0+w4+w8, h0+h1)
29339 input4(0, h0+h1+h2)| input8(w0, h0+h1+h2)| input12(w0+w4, h0+h1+h2)| input16(w0+w4+w8, h0+h1+h2)
29340
29341
29342
29343 xstack=inputs=16:layout=0_0|0_h0|0_h0+h1|0_h0+h1+h2|w0_0|w0_h0|w0_h0+h1|w0_h0+h1+h2|w0+w4_0|
29344 w0+w4_h0|w0+w4_h0+h1|w0+w4_h0+h1+h2|w0+w4+w8_0|w0+w4+w8_h0|w0+w4+w8_h0+h1|w0+w4+w8_h0+h1+h2
29345
29346 Note that if inputs are of different sizes, gaps or overlaps may
29347 occur.
29348
29349 yadif
29350 Deinterlace the input video ("yadif" means "yet another deinterlacing
29351 filter").
29352
29353 It accepts the following parameters:
29354
29355 mode
29356 The interlacing mode to adopt. It accepts one of the following
29357 values:
29358
29359 0, send_frame
29360 Output one frame for each frame.
29361
29362 1, send_field
29363 Output one frame for each field.
29364
29365 2, send_frame_nospatial
29366 Like "send_frame", but it skips the spatial interlacing check.
29367
29368 3, send_field_nospatial
29369 Like "send_field", but it skips the spatial interlacing check.
29370
29371 The default value is "send_frame".
29372
29373 parity
29374 The picture field parity assumed for the input interlaced video. It
29375 accepts one of the following values:
29376
29377 0, tff
29378 Assume the top field is first.
29379
29380 1, bff
29381 Assume the bottom field is first.
29382
29383 -1, auto
29384 Enable automatic detection of field parity.
29385
29386 The default value is "auto". If the interlacing is unknown or the
29387 decoder does not export this information, top field first will be
29388 assumed.
29389
29390 deint
29391 Specify which frames to deinterlace. Accepts one of the following
29392 values:
29393
29394 0, all
29395 Deinterlace all frames.
29396
29397 1, interlaced
29398 Only deinterlace frames marked as interlaced.
29399
29400 The default value is "all".
29401
29402 yadif_cuda
29403 Deinterlace the input video using the yadif algorithm, but implemented
29404 in CUDA so that it can work as part of a GPU accelerated pipeline with
29405 nvdec and/or nvenc.
29406
29407 It accepts the following parameters:
29408
29409 mode
29410 The interlacing mode to adopt. It accepts one of the following
29411 values:
29412
29413 0, send_frame
29414 Output one frame for each frame.
29415
29416 1, send_field
29417 Output one frame for each field.
29418
29419 2, send_frame_nospatial
29420 Like "send_frame", but it skips the spatial interlacing check.
29421
29422 3, send_field_nospatial
29423 Like "send_field", but it skips the spatial interlacing check.
29424
29425 The default value is "send_frame".
29426
29427 parity
29428 The picture field parity assumed for the input interlaced video. It
29429 accepts one of the following values:
29430
29431 0, tff
29432 Assume the top field is first.
29433
29434 1, bff
29435 Assume the bottom field is first.
29436
29437 -1, auto
29438 Enable automatic detection of field parity.
29439
29440 The default value is "auto". If the interlacing is unknown or the
29441 decoder does not export this information, top field first will be
29442 assumed.
29443
29444 deint
29445 Specify which frames to deinterlace. Accepts one of the following
29446 values:
29447
29448 0, all
29449 Deinterlace all frames.
29450
29451 1, interlaced
29452 Only deinterlace frames marked as interlaced.
29453
29454 The default value is "all".
29455
29456 yaepblur
29457 Apply blur filter while preserving edges ("yaepblur" means "yet another
29458 edge preserving blur filter"). The algorithm is described in "J. S.
29459 Lee, Digital image enhancement and noise filtering by use of local
29460 statistics, IEEE Trans. Pattern Anal. Mach. Intell. PAMI-2, 1980."
29461
29462 It accepts the following parameters:
29463
29464 radius, r
29465 Set the window radius. Default value is 3.
29466
29467 planes, p
29468 Set which planes to filter. Default is only the first plane.
29469
29470 sigma, s
29471 Set blur strength. Default value is 128.
29472
29473 Commands
29474
29475 This filter supports same commands as options.
29476
29477 zoompan
29478 Apply Zoom & Pan effect.
29479
29480 This filter accepts the following options:
29481
29482 zoom, z
29483 Set the zoom expression. Range is 1-10. Default is 1.
29484
29485 x
29486 y Set the x and y expression. Default is 0.
29487
29488 d Set the duration expression in number of frames. This sets for how
29489 many number of frames effect will last for single input image.
29490 Default is 90.
29491
29492 s Set the output image size, default is 'hd720'.
29493
29494 fps Set the output frame rate, default is '25'.
29495
29496 Each expression can contain the following constants:
29497
29498 in_w, iw
29499 Input width.
29500
29501 in_h, ih
29502 Input height.
29503
29504 out_w, ow
29505 Output width.
29506
29507 out_h, oh
29508 Output height.
29509
29510 in Input frame count.
29511
29512 on Output frame count.
29513
29514 in_time, it
29515 The input timestamp expressed in seconds. It's NAN if the input
29516 timestamp is unknown.
29517
29518 out_time, time, ot
29519 The output timestamp expressed in seconds.
29520
29521 x
29522 y Last calculated 'x' and 'y' position from 'x' and 'y' expression
29523 for current input frame.
29524
29525 px
29526 py 'x' and 'y' of last output frame of previous input frame or 0 when
29527 there was not yet such frame (first input frame).
29528
29529 zoom
29530 Last calculated zoom from 'z' expression for current input frame.
29531
29532 pzoom
29533 Last calculated zoom of last output frame of previous input frame.
29534
29535 duration
29536 Number of output frames for current input frame. Calculated from
29537 'd' expression for each input frame.
29538
29539 pduration
29540 number of output frames created for previous input frame
29541
29542 a Rational number: input width / input height
29543
29544 sar sample aspect ratio
29545
29546 dar display aspect ratio
29547
29548 Examples
29549
29550 • Zoom in up to 1.5x and pan at same time to some spot near center of
29551 picture:
29552
29553 zoompan=z='min(zoom+0.0015,1.5)':d=700:x='if(gte(zoom,1.5),x,x+1/a)':y='if(gte(zoom,1.5),y,y+1)':s=640x360
29554
29555 • Zoom in up to 1.5x and pan always at center of picture:
29556
29557 zoompan=z='min(zoom+0.0015,1.5)':d=700:x='iw/2-(iw/zoom/2)':y='ih/2-(ih/zoom/2)'
29558
29559 • Same as above but without pausing:
29560
29561 zoompan=z='min(max(zoom,pzoom)+0.0015,1.5)':d=1:x='iw/2-(iw/zoom/2)':y='ih/2-(ih/zoom/2)'
29562
29563 • Zoom in 2x into center of picture only for the first second of the
29564 input video:
29565
29566 zoompan=z='if(between(in_time,0,1),2,1)':d=1:x='iw/2-(iw/zoom/2)':y='ih/2-(ih/zoom/2)'
29567
29568 zscale
29569 Scale (resize) the input video, using the z.lib library:
29570 <https://github.com/sekrit-twc/zimg>. To enable compilation of this
29571 filter, you need to configure FFmpeg with "--enable-libzimg".
29572
29573 The zscale filter forces the output display aspect ratio to be the same
29574 as the input, by changing the output sample aspect ratio.
29575
29576 If the input image format is different from the format requested by the
29577 next filter, the zscale filter will convert the input to the requested
29578 format.
29579
29580 Options
29581
29582 The filter accepts the following options.
29583
29584 width, w
29585 height, h
29586 Set the output video dimension expression. Default value is the
29587 input dimension.
29588
29589 If the width or w value is 0, the input width is used for the
29590 output. If the height or h value is 0, the input height is used for
29591 the output.
29592
29593 If one and only one of the values is -n with n >= 1, the zscale
29594 filter will use a value that maintains the aspect ratio of the
29595 input image, calculated from the other specified dimension. After
29596 that it will, however, make sure that the calculated dimension is
29597 divisible by n and adjust the value if necessary.
29598
29599 If both values are -n with n >= 1, the behavior will be identical
29600 to both values being set to 0 as previously detailed.
29601
29602 See below for the list of accepted constants for use in the
29603 dimension expression.
29604
29605 size, s
29606 Set the video size. For the syntax of this option, check the "Video
29607 size" section in the ffmpeg-utils manual.
29608
29609 dither, d
29610 Set the dither type.
29611
29612 Possible values are:
29613
29614 none
29615 ordered
29616 random
29617 error_diffusion
29618
29619 Default is none.
29620
29621 filter, f
29622 Set the resize filter type.
29623
29624 Possible values are:
29625
29626 point
29627 bilinear
29628 bicubic
29629 spline16
29630 spline36
29631 lanczos
29632
29633 Default is bilinear.
29634
29635 range, r
29636 Set the color range.
29637
29638 Possible values are:
29639
29640 input
29641 limited
29642 full
29643
29644 Default is same as input.
29645
29646 primaries, p
29647 Set the color primaries.
29648
29649 Possible values are:
29650
29651 input
29652 709
29653 unspecified
29654 170m
29655 240m
29656 2020
29657
29658 Default is same as input.
29659
29660 transfer, t
29661 Set the transfer characteristics.
29662
29663 Possible values are:
29664
29665 input
29666 709
29667 unspecified
29668 601
29669 linear
29670 2020_10
29671 2020_12
29672 smpte2084
29673 iec61966-2-1
29674 arib-std-b67
29675
29676 Default is same as input.
29677
29678 matrix, m
29679 Set the colorspace matrix.
29680
29681 Possible value are:
29682
29683 input
29684 709
29685 unspecified
29686 470bg
29687 170m
29688 2020_ncl
29689 2020_cl
29690
29691 Default is same as input.
29692
29693 rangein, rin
29694 Set the input color range.
29695
29696 Possible values are:
29697
29698 input
29699 limited
29700 full
29701
29702 Default is same as input.
29703
29704 primariesin, pin
29705 Set the input color primaries.
29706
29707 Possible values are:
29708
29709 input
29710 709
29711 unspecified
29712 170m
29713 240m
29714 2020
29715
29716 Default is same as input.
29717
29718 transferin, tin
29719 Set the input transfer characteristics.
29720
29721 Possible values are:
29722
29723 input
29724 709
29725 unspecified
29726 601
29727 linear
29728 2020_10
29729 2020_12
29730
29731 Default is same as input.
29732
29733 matrixin, min
29734 Set the input colorspace matrix.
29735
29736 Possible value are:
29737
29738 input
29739 709
29740 unspecified
29741 470bg
29742 170m
29743 2020_ncl
29744 2020_cl
29745 chromal, c
29746 Set the output chroma location.
29747
29748 Possible values are:
29749
29750 input
29751 left
29752 center
29753 topleft
29754 top
29755 bottomleft
29756 bottom
29757 chromalin, cin
29758 Set the input chroma location.
29759
29760 Possible values are:
29761
29762 input
29763 left
29764 center
29765 topleft
29766 top
29767 bottomleft
29768 bottom
29769 npl Set the nominal peak luminance.
29770
29771 param_a
29772 Parameter A for scaling filters. Parameter "b" for bicubic, and the
29773 number of filter taps for lanczos.
29774
29775 param_b
29776 Parameter B for scaling filters. Parameter "c" for bicubic.
29777
29778 The values of the w and h options are expressions containing the
29779 following constants:
29780
29781 in_w
29782 in_h
29783 The input width and height
29784
29785 iw
29786 ih These are the same as in_w and in_h.
29787
29788 out_w
29789 out_h
29790 The output (scaled) width and height
29791
29792 ow
29793 oh These are the same as out_w and out_h
29794
29795 a The same as iw / ih
29796
29797 sar input sample aspect ratio
29798
29799 dar The input display aspect ratio. Calculated from "(iw / ih) * sar".
29800
29801 hsub
29802 vsub
29803 horizontal and vertical input chroma subsample values. For example
29804 for the pixel format "yuv422p" hsub is 2 and vsub is 1.
29805
29806 ohsub
29807 ovsub
29808 horizontal and vertical output chroma subsample values. For example
29809 for the pixel format "yuv422p" hsub is 2 and vsub is 1.
29810
29811 Commands
29812
29813 This filter supports the following commands:
29814
29815 width, w
29816 height, h
29817 Set the output video dimension expression. The command accepts the
29818 same syntax of the corresponding option.
29819
29820 If the specified expression is not valid, it is kept at its current
29821 value.
29822
29824 Below is a description of the currently available OpenCL video filters.
29825
29826 To enable compilation of these filters you need to configure FFmpeg
29827 with "--enable-opencl".
29828
29829 Running OpenCL filters requires you to initialize a hardware device and
29830 to pass that device to all filters in any filter graph.
29831
29832 -init_hw_device opencl[=name][:device[,key=value...]]
29833 Initialise a new hardware device of type opencl called name, using
29834 the given device parameters.
29835
29836 -filter_hw_device name
29837 Pass the hardware device called name to all filters in any filter
29838 graph.
29839
29840 For more detailed information see
29841 <https://www.ffmpeg.org/ffmpeg.html#Advanced-Video-options>
29842
29843 • Example of choosing the first device on the second platform and
29844 running avgblur_opencl filter with default parameters on it.
29845
29846 -init_hw_device opencl=gpu:1.0 -filter_hw_device gpu -i INPUT -vf "hwupload, avgblur_opencl, hwdownload" OUTPUT
29847
29848 Since OpenCL filters are not able to access frame data in normal
29849 memory, all frame data needs to be uploaded(hwupload) to hardware
29850 surfaces connected to the appropriate device before being used and then
29851 downloaded(hwdownload) back to normal memory. Note that hwupload will
29852 upload to a surface with the same layout as the software frame, so it
29853 may be necessary to add a format filter immediately before to get the
29854 input into the right format and hwdownload does not support all formats
29855 on the output - it may be necessary to insert an additional format
29856 filter immediately following in the graph to get the output in a
29857 supported format.
29858
29859 avgblur_opencl
29860 Apply average blur filter.
29861
29862 The filter accepts the following options:
29863
29864 sizeX
29865 Set horizontal radius size. Range is "[1, 1024]" and default value
29866 is 1.
29867
29868 planes
29869 Set which planes to filter. Default value is 0xf, by which all
29870 planes are processed.
29871
29872 sizeY
29873 Set vertical radius size. Range is "[1, 1024]" and default value is
29874 0. If zero, "sizeX" value will be used.
29875
29876 Example
29877
29878 • Apply average blur filter with horizontal and vertical size of 3,
29879 setting each pixel of the output to the average value of the 7x7
29880 region centered on it in the input. For pixels on the edges of the
29881 image, the region does not extend beyond the image boundaries, and
29882 so out-of-range coordinates are not used in the calculations.
29883
29884 -i INPUT -vf "hwupload, avgblur_opencl=3, hwdownload" OUTPUT
29885
29886 boxblur_opencl
29887 Apply a boxblur algorithm to the input video.
29888
29889 It accepts the following parameters:
29890
29891 luma_radius, lr
29892 luma_power, lp
29893 chroma_radius, cr
29894 chroma_power, cp
29895 alpha_radius, ar
29896 alpha_power, ap
29897
29898 A description of the accepted options follows.
29899
29900 luma_radius, lr
29901 chroma_radius, cr
29902 alpha_radius, ar
29903 Set an expression for the box radius in pixels used for blurring
29904 the corresponding input plane.
29905
29906 The radius value must be a non-negative number, and must not be
29907 greater than the value of the expression "min(w,h)/2" for the luma
29908 and alpha planes, and of "min(cw,ch)/2" for the chroma planes.
29909
29910 Default value for luma_radius is "2". If not specified,
29911 chroma_radius and alpha_radius default to the corresponding value
29912 set for luma_radius.
29913
29914 The expressions can contain the following constants:
29915
29916 w
29917 h The input width and height in pixels.
29918
29919 cw
29920 ch The input chroma image width and height in pixels.
29921
29922 hsub
29923 vsub
29924 The horizontal and vertical chroma subsample values. For
29925 example, for the pixel format "yuv422p", hsub is 2 and vsub is
29926 1.
29927
29928 luma_power, lp
29929 chroma_power, cp
29930 alpha_power, ap
29931 Specify how many times the boxblur filter is applied to the
29932 corresponding plane.
29933
29934 Default value for luma_power is 2. If not specified, chroma_power
29935 and alpha_power default to the corresponding value set for
29936 luma_power.
29937
29938 A value of 0 will disable the effect.
29939
29940 Examples
29941
29942 Apply boxblur filter, setting each pixel of the output to the average
29943 value of box-radiuses luma_radius, chroma_radius, alpha_radius for each
29944 plane respectively. The filter will apply luma_power, chroma_power,
29945 alpha_power times onto the corresponding plane. For pixels on the edges
29946 of the image, the radius does not extend beyond the image boundaries,
29947 and so out-of-range coordinates are not used in the calculations.
29948
29949 • Apply a boxblur filter with the luma, chroma, and alpha radius set
29950 to 2 and luma, chroma, and alpha power set to 3. The filter will
29951 run 3 times with box-radius set to 2 for every plane of the image.
29952
29953 -i INPUT -vf "hwupload, boxblur_opencl=luma_radius=2:luma_power=3, hwdownload" OUTPUT
29954 -i INPUT -vf "hwupload, boxblur_opencl=2:3, hwdownload" OUTPUT
29955
29956 • Apply a boxblur filter with luma radius set to 2, luma_power to 1,
29957 chroma_radius to 4, chroma_power to 5, alpha_radius to 3 and
29958 alpha_power to 7.
29959
29960 For the luma plane, a 2x2 box radius will be run once.
29961
29962 For the chroma plane, a 4x4 box radius will be run 5 times.
29963
29964 For the alpha plane, a 3x3 box radius will be run 7 times.
29965
29966 -i INPUT -vf "hwupload, boxblur_opencl=2:1:4:5:3:7, hwdownload" OUTPUT
29967
29968 colorkey_opencl
29969 RGB colorspace color keying.
29970
29971 The filter accepts the following options:
29972
29973 color
29974 The color which will be replaced with transparency.
29975
29976 similarity
29977 Similarity percentage with the key color.
29978
29979 0.01 matches only the exact key color, while 1.0 matches
29980 everything.
29981
29982 blend
29983 Blend percentage.
29984
29985 0.0 makes pixels either fully transparent, or not transparent at
29986 all.
29987
29988 Higher values result in semi-transparent pixels, with a higher
29989 transparency the more similar the pixels color is to the key color.
29990
29991 Examples
29992
29993 • Make every semi-green pixel in the input transparent with some
29994 slight blending:
29995
29996 -i INPUT -vf "hwupload, colorkey_opencl=green:0.3:0.1, hwdownload" OUTPUT
29997
29998 convolution_opencl
29999 Apply convolution of 3x3, 5x5, 7x7 matrix.
30000
30001 The filter accepts the following options:
30002
30003 0m
30004 1m
30005 2m
30006 3m Set matrix for each plane. Matrix is sequence of 9, 25 or 49
30007 signed numbers. Default value for each plane is "0 0 0 0 1 0 0 0
30008 0".
30009
30010 0rdiv
30011 1rdiv
30012 2rdiv
30013 3rdiv
30014 Set multiplier for calculated value for each plane. If unset or 0,
30015 it will be sum of all matrix elements. The option value must be a
30016 float number greater or equal to 0.0. Default value is 1.0.
30017
30018 0bias
30019 1bias
30020 2bias
30021 3bias
30022 Set bias for each plane. This value is added to the result of the
30023 multiplication. Useful for making the overall image brighter or
30024 darker. The option value must be a float number greater or equal
30025 to 0.0. Default value is 0.0.
30026
30027 Examples
30028
30029 • Apply sharpen:
30030
30031 -i INPUT -vf "hwupload, convolution_opencl=0 -1 0 -1 5 -1 0 -1 0:0 -1 0 -1 5 -1 0 -1 0:0 -1 0 -1 5 -1 0 -1 0:0 -1 0 -1 5 -1 0 -1 0, hwdownload" OUTPUT
30032
30033 • Apply blur:
30034
30035 -i INPUT -vf "hwupload, convolution_opencl=1 1 1 1 1 1 1 1 1:1 1 1 1 1 1 1 1 1:1 1 1 1 1 1 1 1 1:1 1 1 1 1 1 1 1 1:1/9:1/9:1/9:1/9, hwdownload" OUTPUT
30036
30037 • Apply edge enhance:
30038
30039 -i INPUT -vf "hwupload, convolution_opencl=0 0 0 -1 1 0 0 0 0:0 0 0 -1 1 0 0 0 0:0 0 0 -1 1 0 0 0 0:0 0 0 -1 1 0 0 0 0:5:1:1:1:0:128:128:128, hwdownload" OUTPUT
30040
30041 • Apply edge detect:
30042
30043 -i INPUT -vf "hwupload, convolution_opencl=0 1 0 1 -4 1 0 1 0:0 1 0 1 -4 1 0 1 0:0 1 0 1 -4 1 0 1 0:0 1 0 1 -4 1 0 1 0:5:5:5:1:0:128:128:128, hwdownload" OUTPUT
30044
30045 • Apply laplacian edge detector which includes diagonals:
30046
30047 -i INPUT -vf "hwupload, convolution_opencl=1 1 1 1 -8 1 1 1 1:1 1 1 1 -8 1 1 1 1:1 1 1 1 -8 1 1 1 1:1 1 1 1 -8 1 1 1 1:5:5:5:1:0:128:128:0, hwdownload" OUTPUT
30048
30049 • Apply emboss:
30050
30051 -i INPUT -vf "hwupload, convolution_opencl=-2 -1 0 -1 1 1 0 1 2:-2 -1 0 -1 1 1 0 1 2:-2 -1 0 -1 1 1 0 1 2:-2 -1 0 -1 1 1 0 1 2, hwdownload" OUTPUT
30052
30053 erosion_opencl
30054 Apply erosion effect to the video.
30055
30056 This filter replaces the pixel by the local(3x3) minimum.
30057
30058 It accepts the following options:
30059
30060 threshold0
30061 threshold1
30062 threshold2
30063 threshold3
30064 Limit the maximum change for each plane. Range is "[0, 65535]" and
30065 default value is 65535. If 0, plane will remain unchanged.
30066
30067 coordinates
30068 Flag which specifies the pixel to refer to. Range is "[0, 255]"
30069 and default value is 255, i.e. all eight pixels are used.
30070
30071 Flags to local 3x3 coordinates region centered on "x":
30072
30073 1 2 3
30074
30075 4 x 5
30076
30077 6 7 8
30078
30079 Example
30080
30081 • Apply erosion filter with threshold0 set to 30, threshold1 set 40,
30082 threshold2 set to 50 and coordinates set to 231, setting each pixel
30083 of the output to the local minimum between pixels: 1, 2, 3, 6, 7, 8
30084 of the 3x3 region centered on it in the input. If the difference
30085 between input pixel and local minimum is more then threshold of the
30086 corresponding plane, output pixel will be set to input pixel -
30087 threshold of corresponding plane.
30088
30089 -i INPUT -vf "hwupload, erosion_opencl=30:40:50:coordinates=231, hwdownload" OUTPUT
30090
30091 deshake_opencl
30092 Feature-point based video stabilization filter.
30093
30094 The filter accepts the following options:
30095
30096 tripod
30097 Simulates a tripod by preventing any camera movement whatsoever
30098 from the original frame. Defaults to 0.
30099
30100 debug
30101 Whether or not additional debug info should be displayed, both in
30102 the processed output and in the console.
30103
30104 Note that in order to see console debug output you will also need
30105 to pass "-v verbose" to ffmpeg.
30106
30107 Viewing point matches in the output video is only supported for RGB
30108 input.
30109
30110 Defaults to 0.
30111
30112 adaptive_crop
30113 Whether or not to do a tiny bit of cropping at the borders to cut
30114 down on the amount of mirrored pixels.
30115
30116 Defaults to 1.
30117
30118 refine_features
30119 Whether or not feature points should be refined at a sub-pixel
30120 level.
30121
30122 This can be turned off for a slight performance gain at the cost of
30123 precision.
30124
30125 Defaults to 1.
30126
30127 smooth_strength
30128 The strength of the smoothing applied to the camera path from 0.0
30129 to 1.0.
30130
30131 1.0 is the maximum smoothing strength while values less than that
30132 result in less smoothing.
30133
30134 0.0 causes the filter to adaptively choose a smoothing strength on
30135 a per-frame basis.
30136
30137 Defaults to 0.0.
30138
30139 smooth_window_multiplier
30140 Controls the size of the smoothing window (the number of frames
30141 buffered to determine motion information from).
30142
30143 The size of the smoothing window is determined by multiplying the
30144 framerate of the video by this number.
30145
30146 Acceptable values range from 0.1 to 10.0.
30147
30148 Larger values increase the amount of motion data available for
30149 determining how to smooth the camera path, potentially improving
30150 smoothness, but also increase latency and memory usage.
30151
30152 Defaults to 2.0.
30153
30154 Examples
30155
30156 • Stabilize a video with a fixed, medium smoothing strength:
30157
30158 -i INPUT -vf "hwupload, deshake_opencl=smooth_strength=0.5, hwdownload" OUTPUT
30159
30160 • Stabilize a video with debugging (both in console and in rendered
30161 video):
30162
30163 -i INPUT -filter_complex "[0:v]format=rgba, hwupload, deshake_opencl=debug=1, hwdownload, format=rgba, format=yuv420p" -v verbose OUTPUT
30164
30165 dilation_opencl
30166 Apply dilation effect to the video.
30167
30168 This filter replaces the pixel by the local(3x3) maximum.
30169
30170 It accepts the following options:
30171
30172 threshold0
30173 threshold1
30174 threshold2
30175 threshold3
30176 Limit the maximum change for each plane. Range is "[0, 65535]" and
30177 default value is 65535. If 0, plane will remain unchanged.
30178
30179 coordinates
30180 Flag which specifies the pixel to refer to. Range is "[0, 255]"
30181 and default value is 255, i.e. all eight pixels are used.
30182
30183 Flags to local 3x3 coordinates region centered on "x":
30184
30185 1 2 3
30186
30187 4 x 5
30188
30189 6 7 8
30190
30191 Example
30192
30193 • Apply dilation filter with threshold0 set to 30, threshold1 set 40,
30194 threshold2 set to 50 and coordinates set to 231, setting each pixel
30195 of the output to the local maximum between pixels: 1, 2, 3, 6, 7, 8
30196 of the 3x3 region centered on it in the input. If the difference
30197 between input pixel and local maximum is more then threshold of the
30198 corresponding plane, output pixel will be set to input pixel +
30199 threshold of corresponding plane.
30200
30201 -i INPUT -vf "hwupload, dilation_opencl=30:40:50:coordinates=231, hwdownload" OUTPUT
30202
30203 nlmeans_opencl
30204 Non-local Means denoise filter through OpenCL, this filter accepts same
30205 options as nlmeans.
30206
30207 overlay_opencl
30208 Overlay one video on top of another.
30209
30210 It takes two inputs and has one output. The first input is the "main"
30211 video on which the second input is overlaid. This filter requires same
30212 memory layout for all the inputs. So, format conversion may be needed.
30213
30214 The filter accepts the following options:
30215
30216 x Set the x coordinate of the overlaid video on the main video.
30217 Default value is 0.
30218
30219 y Set the y coordinate of the overlaid video on the main video.
30220 Default value is 0.
30221
30222 Examples
30223
30224 • Overlay an image LOGO at the top-left corner of the INPUT video.
30225 Both inputs are yuv420p format.
30226
30227 -i INPUT -i LOGO -filter_complex "[0:v]hwupload[a], [1:v]format=yuv420p, hwupload[b], [a][b]overlay_opencl, hwdownload" OUTPUT
30228
30229 • The inputs have same memory layout for color channels , the overlay
30230 has additional alpha plane, like INPUT is yuv420p, and the LOGO is
30231 yuva420p.
30232
30233 -i INPUT -i LOGO -filter_complex "[0:v]hwupload[a], [1:v]format=yuva420p, hwupload[b], [a][b]overlay_opencl, hwdownload" OUTPUT
30234
30235 pad_opencl
30236 Add paddings to the input image, and place the original input at the
30237 provided x, y coordinates.
30238
30239 It accepts the following options:
30240
30241 width, w
30242 height, h
30243 Specify an expression for the size of the output image with the
30244 paddings added. If the value for width or height is 0, the
30245 corresponding input size is used for the output.
30246
30247 The width expression can reference the value set by the height
30248 expression, and vice versa.
30249
30250 The default value of width and height is 0.
30251
30252 x
30253 y Specify the offsets to place the input image at within the padded
30254 area, with respect to the top/left border of the output image.
30255
30256 The x expression can reference the value set by the y expression,
30257 and vice versa.
30258
30259 The default value of x and y is 0.
30260
30261 If x or y evaluate to a negative number, they'll be changed so the
30262 input image is centered on the padded area.
30263
30264 color
30265 Specify the color of the padded area. For the syntax of this
30266 option, check the "Color" section in the ffmpeg-utils manual.
30267
30268 aspect
30269 Pad to an aspect instead to a resolution.
30270
30271 The value for the width, height, x, and y options are expressions
30272 containing the following constants:
30273
30274 in_w
30275 in_h
30276 The input video width and height.
30277
30278 iw
30279 ih These are the same as in_w and in_h.
30280
30281 out_w
30282 out_h
30283 The output width and height (the size of the padded area), as
30284 specified by the width and height expressions.
30285
30286 ow
30287 oh These are the same as out_w and out_h.
30288
30289 x
30290 y The x and y offsets as specified by the x and y expressions, or NAN
30291 if not yet specified.
30292
30293 a same as iw / ih
30294
30295 sar input sample aspect ratio
30296
30297 dar input display aspect ratio, it is the same as (iw / ih) * sar
30298
30299 prewitt_opencl
30300 Apply the Prewitt operator
30301 (<https://en.wikipedia.org/wiki/Prewitt_operator>) to input video
30302 stream.
30303
30304 The filter accepts the following option:
30305
30306 planes
30307 Set which planes to filter. Default value is 0xf, by which all
30308 planes are processed.
30309
30310 scale
30311 Set value which will be multiplied with filtered result. Range is
30312 "[0.0, 65535]" and default value is 1.0.
30313
30314 delta
30315 Set value which will be added to filtered result. Range is
30316 "[-65535, 65535]" and default value is 0.0.
30317
30318 Example
30319
30320 • Apply the Prewitt operator with scale set to 2 and delta set to 10.
30321
30322 -i INPUT -vf "hwupload, prewitt_opencl=scale=2:delta=10, hwdownload" OUTPUT
30323
30324 program_opencl
30325 Filter video using an OpenCL program.
30326
30327 source
30328 OpenCL program source file.
30329
30330 kernel
30331 Kernel name in program.
30332
30333 inputs
30334 Number of inputs to the filter. Defaults to 1.
30335
30336 size, s
30337 Size of output frames. Defaults to the same as the first input.
30338
30339 The "program_opencl" filter also supports the framesync options.
30340
30341 The program source file must contain a kernel function with the given
30342 name, which will be run once for each plane of the output. Each run on
30343 a plane gets enqueued as a separate 2D global NDRange with one work-
30344 item for each pixel to be generated. The global ID offset for each
30345 work-item is therefore the coordinates of a pixel in the destination
30346 image.
30347
30348 The kernel function needs to take the following arguments:
30349
30350 • Destination image, __write_only image2d_t.
30351
30352 This image will become the output; the kernel should write all of
30353 it.
30354
30355 • Frame index, unsigned int.
30356
30357 This is a counter starting from zero and increasing by one for each
30358 frame.
30359
30360 • Source images, __read_only image2d_t.
30361
30362 These are the most recent images on each input. The kernel may
30363 read from them to generate the output, but they can't be written
30364 to.
30365
30366 Example programs:
30367
30368 • Copy the input to the output (output must be the same size as the
30369 input).
30370
30371 __kernel void copy(__write_only image2d_t destination,
30372 unsigned int index,
30373 __read_only image2d_t source)
30374 {
30375 const sampler_t sampler = CLK_NORMALIZED_COORDS_FALSE;
30376
30377 int2 location = (int2)(get_global_id(0), get_global_id(1));
30378
30379 float4 value = read_imagef(source, sampler, location);
30380
30381 write_imagef(destination, location, value);
30382 }
30383
30384 • Apply a simple transformation, rotating the input by an amount
30385 increasing with the index counter. Pixel values are linearly
30386 interpolated by the sampler, and the output need not have the same
30387 dimensions as the input.
30388
30389 __kernel void rotate_image(__write_only image2d_t dst,
30390 unsigned int index,
30391 __read_only image2d_t src)
30392 {
30393 const sampler_t sampler = (CLK_NORMALIZED_COORDS_FALSE |
30394 CLK_FILTER_LINEAR);
30395
30396 float angle = (float)index / 100.0f;
30397
30398 float2 dst_dim = convert_float2(get_image_dim(dst));
30399 float2 src_dim = convert_float2(get_image_dim(src));
30400
30401 float2 dst_cen = dst_dim / 2.0f;
30402 float2 src_cen = src_dim / 2.0f;
30403
30404 int2 dst_loc = (int2)(get_global_id(0), get_global_id(1));
30405
30406 float2 dst_pos = convert_float2(dst_loc) - dst_cen;
30407 float2 src_pos = {
30408 cos(angle) * dst_pos.x - sin(angle) * dst_pos.y,
30409 sin(angle) * dst_pos.x + cos(angle) * dst_pos.y
30410 };
30411 src_pos = src_pos * src_dim / dst_dim;
30412
30413 float2 src_loc = src_pos + src_cen;
30414
30415 if (src_loc.x < 0.0f || src_loc.y < 0.0f ||
30416 src_loc.x > src_dim.x || src_loc.y > src_dim.y)
30417 write_imagef(dst, dst_loc, 0.5f);
30418 else
30419 write_imagef(dst, dst_loc, read_imagef(src, sampler, src_loc));
30420 }
30421
30422 • Blend two inputs together, with the amount of each input used
30423 varying with the index counter.
30424
30425 __kernel void blend_images(__write_only image2d_t dst,
30426 unsigned int index,
30427 __read_only image2d_t src1,
30428 __read_only image2d_t src2)
30429 {
30430 const sampler_t sampler = (CLK_NORMALIZED_COORDS_FALSE |
30431 CLK_FILTER_LINEAR);
30432
30433 float blend = (cos((float)index / 50.0f) + 1.0f) / 2.0f;
30434
30435 int2 dst_loc = (int2)(get_global_id(0), get_global_id(1));
30436 int2 src1_loc = dst_loc * get_image_dim(src1) / get_image_dim(dst);
30437 int2 src2_loc = dst_loc * get_image_dim(src2) / get_image_dim(dst);
30438
30439 float4 val1 = read_imagef(src1, sampler, src1_loc);
30440 float4 val2 = read_imagef(src2, sampler, src2_loc);
30441
30442 write_imagef(dst, dst_loc, val1 * blend + val2 * (1.0f - blend));
30443 }
30444
30445 roberts_opencl
30446 Apply the Roberts cross operator
30447 (<https://en.wikipedia.org/wiki/Roberts_cross>) to input video stream.
30448
30449 The filter accepts the following option:
30450
30451 planes
30452 Set which planes to filter. Default value is 0xf, by which all
30453 planes are processed.
30454
30455 scale
30456 Set value which will be multiplied with filtered result. Range is
30457 "[0.0, 65535]" and default value is 1.0.
30458
30459 delta
30460 Set value which will be added to filtered result. Range is
30461 "[-65535, 65535]" and default value is 0.0.
30462
30463 Example
30464
30465 • Apply the Roberts cross operator with scale set to 2 and delta set
30466 to 10
30467
30468 -i INPUT -vf "hwupload, roberts_opencl=scale=2:delta=10, hwdownload" OUTPUT
30469
30470 sobel_opencl
30471 Apply the Sobel operator
30472 (<https://en.wikipedia.org/wiki/Sobel_operator>) to input video stream.
30473
30474 The filter accepts the following option:
30475
30476 planes
30477 Set which planes to filter. Default value is 0xf, by which all
30478 planes are processed.
30479
30480 scale
30481 Set value which will be multiplied with filtered result. Range is
30482 "[0.0, 65535]" and default value is 1.0.
30483
30484 delta
30485 Set value which will be added to filtered result. Range is
30486 "[-65535, 65535]" and default value is 0.0.
30487
30488 Example
30489
30490 • Apply sobel operator with scale set to 2 and delta set to 10
30491
30492 -i INPUT -vf "hwupload, sobel_opencl=scale=2:delta=10, hwdownload" OUTPUT
30493
30494 tonemap_opencl
30495 Perform HDR(PQ/HLG) to SDR conversion with tone-mapping.
30496
30497 It accepts the following parameters:
30498
30499 tonemap
30500 Specify the tone-mapping operator to be used. Same as tonemap
30501 option in tonemap.
30502
30503 param
30504 Tune the tone mapping algorithm. same as param option in tonemap.
30505
30506 desat
30507 Apply desaturation for highlights that exceed this level of
30508 brightness. The higher the parameter, the more color information
30509 will be preserved. This setting helps prevent unnaturally blown-out
30510 colors for super-highlights, by (smoothly) turning into white
30511 instead. This makes images feel more natural, at the cost of
30512 reducing information about out-of-range colors.
30513
30514 The default value is 0.5, and the algorithm here is a little
30515 different from the cpu version tonemap currently. A setting of 0.0
30516 disables this option.
30517
30518 threshold
30519 The tonemapping algorithm parameters is fine-tuned per each scene.
30520 And a threshold is used to detect whether the scene has changed or
30521 not. If the distance between the current frame average brightness
30522 and the current running average exceeds a threshold value, we would
30523 re-calculate scene average and peak brightness. The default value
30524 is 0.2.
30525
30526 format
30527 Specify the output pixel format.
30528
30529 Currently supported formats are:
30530
30531 p010
30532 nv12
30533 range, r
30534 Set the output color range.
30535
30536 Possible values are:
30537
30538 tv/mpeg
30539 pc/jpeg
30540
30541 Default is same as input.
30542
30543 primaries, p
30544 Set the output color primaries.
30545
30546 Possible values are:
30547
30548 bt709
30549 bt2020
30550
30551 Default is same as input.
30552
30553 transfer, t
30554 Set the output transfer characteristics.
30555
30556 Possible values are:
30557
30558 bt709
30559 bt2020
30560
30561 Default is bt709.
30562
30563 matrix, m
30564 Set the output colorspace matrix.
30565
30566 Possible value are:
30567
30568 bt709
30569 bt2020
30570
30571 Default is same as input.
30572
30573 Example
30574
30575 • Convert HDR(PQ/HLG) video to bt2020-transfer-characteristic p010
30576 format using linear operator.
30577
30578 -i INPUT -vf "format=p010,hwupload,tonemap_opencl=t=bt2020:tonemap=linear:format=p010,hwdownload,format=p010" OUTPUT
30579
30580 unsharp_opencl
30581 Sharpen or blur the input video.
30582
30583 It accepts the following parameters:
30584
30585 luma_msize_x, lx
30586 Set the luma matrix horizontal size. Range is "[1, 23]" and
30587 default value is 5.
30588
30589 luma_msize_y, ly
30590 Set the luma matrix vertical size. Range is "[1, 23]" and default
30591 value is 5.
30592
30593 luma_amount, la
30594 Set the luma effect strength. Range is "[-10, 10]" and default
30595 value is 1.0.
30596
30597 Negative values will blur the input video, while positive values
30598 will sharpen it, a value of zero will disable the effect.
30599
30600 chroma_msize_x, cx
30601 Set the chroma matrix horizontal size. Range is "[1, 23]" and
30602 default value is 5.
30603
30604 chroma_msize_y, cy
30605 Set the chroma matrix vertical size. Range is "[1, 23]" and
30606 default value is 5.
30607
30608 chroma_amount, ca
30609 Set the chroma effect strength. Range is "[-10, 10]" and default
30610 value is 0.0.
30611
30612 Negative values will blur the input video, while positive values
30613 will sharpen it, a value of zero will disable the effect.
30614
30615 All parameters are optional and default to the equivalent of the string
30616 '5:5:1.0:5:5:0.0'.
30617
30618 Examples
30619
30620 • Apply strong luma sharpen effect:
30621
30622 -i INPUT -vf "hwupload, unsharp_opencl=luma_msize_x=7:luma_msize_y=7:luma_amount=2.5, hwdownload" OUTPUT
30623
30624 • Apply a strong blur of both luma and chroma parameters:
30625
30626 -i INPUT -vf "hwupload, unsharp_opencl=7:7:-2:7:7:-2, hwdownload" OUTPUT
30627
30628 xfade_opencl
30629 Cross fade two videos with custom transition effect by using OpenCL.
30630
30631 It accepts the following options:
30632
30633 transition
30634 Set one of possible transition effects.
30635
30636 custom
30637 Select custom transition effect, the actual transition
30638 description will be picked from source and kernel options.
30639
30640 fade
30641 wipeleft
30642 wiperight
30643 wipeup
30644 wipedown
30645 slideleft
30646 slideright
30647 slideup
30648 slidedown
30649 Default transition is fade.
30650
30651 source
30652 OpenCL program source file for custom transition.
30653
30654 kernel
30655 Set name of kernel to use for custom transition from program source
30656 file.
30657
30658 duration
30659 Set duration of video transition.
30660
30661 offset
30662 Set time of start of transition relative to first video.
30663
30664 The program source file must contain a kernel function with the given
30665 name, which will be run once for each plane of the output. Each run on
30666 a plane gets enqueued as a separate 2D global NDRange with one work-
30667 item for each pixel to be generated. The global ID offset for each
30668 work-item is therefore the coordinates of a pixel in the destination
30669 image.
30670
30671 The kernel function needs to take the following arguments:
30672
30673 • Destination image, __write_only image2d_t.
30674
30675 This image will become the output; the kernel should write all of
30676 it.
30677
30678 • First Source image, __read_only image2d_t. Second Source image,
30679 __read_only image2d_t.
30680
30681 These are the most recent images on each input. The kernel may
30682 read from them to generate the output, but they can't be written
30683 to.
30684
30685 • Transition progress, float. This value is always between 0 and 1
30686 inclusive.
30687
30688 Example programs:
30689
30690 • Apply dots curtain transition effect:
30691
30692 __kernel void blend_images(__write_only image2d_t dst,
30693 __read_only image2d_t src1,
30694 __read_only image2d_t src2,
30695 float progress)
30696 {
30697 const sampler_t sampler = (CLK_NORMALIZED_COORDS_FALSE |
30698 CLK_FILTER_LINEAR);
30699 int2 p = (int2)(get_global_id(0), get_global_id(1));
30700 float2 rp = (float2)(get_global_id(0), get_global_id(1));
30701 float2 dim = (float2)(get_image_dim(src1).x, get_image_dim(src1).y);
30702 rp = rp / dim;
30703
30704 float2 dots = (float2)(20.0, 20.0);
30705 float2 center = (float2)(0,0);
30706 float2 unused;
30707
30708 float4 val1 = read_imagef(src1, sampler, p);
30709 float4 val2 = read_imagef(src2, sampler, p);
30710 bool next = distance(fract(rp * dots, &unused), (float2)(0.5, 0.5)) < (progress / distance(rp, center));
30711
30712 write_imagef(dst, p, next ? val1 : val2);
30713 }
30714
30716 VAAPI Video filters are usually used with VAAPI decoder and VAAPI
30717 encoder. Below is a description of VAAPI video filters.
30718
30719 To enable compilation of these filters you need to configure FFmpeg
30720 with "--enable-vaapi".
30721
30722 To use vaapi filters, you need to setup the vaapi device correctly. For
30723 more information, please read
30724 <https://trac.ffmpeg.org/wiki/Hardware/VAAPI>
30725
30726 tonemap_vaapi
30727 Perform HDR(High Dynamic Range) to SDR(Standard Dynamic Range)
30728 conversion with tone-mapping. It maps the dynamic range of HDR10
30729 content to the SDR content. It currently only accepts HDR10 as input.
30730
30731 It accepts the following parameters:
30732
30733 format
30734 Specify the output pixel format.
30735
30736 Currently supported formats are:
30737
30738 p010
30739 nv12
30740
30741 Default is nv12.
30742
30743 primaries, p
30744 Set the output color primaries.
30745
30746 Default is same as input.
30747
30748 transfer, t
30749 Set the output transfer characteristics.
30750
30751 Default is bt709.
30752
30753 matrix, m
30754 Set the output colorspace matrix.
30755
30756 Default is same as input.
30757
30758 Example
30759
30760 • Convert HDR(HDR10) video to bt2020-transfer-characteristic p010
30761 format
30762
30763 tonemap_vaapi=format=p010:t=bt2020-10
30764
30766 Below is a description of the currently available video sources.
30767
30768 buffer
30769 Buffer video frames, and make them available to the filter chain.
30770
30771 This source is mainly intended for a programmatic use, in particular
30772 through the interface defined in libavfilter/buffersrc.h.
30773
30774 It accepts the following parameters:
30775
30776 video_size
30777 Specify the size (width and height) of the buffered video frames.
30778 For the syntax of this option, check the "Video size" section in
30779 the ffmpeg-utils manual.
30780
30781 width
30782 The input video width.
30783
30784 height
30785 The input video height.
30786
30787 pix_fmt
30788 A string representing the pixel format of the buffered video
30789 frames. It may be a number corresponding to a pixel format, or a
30790 pixel format name.
30791
30792 time_base
30793 Specify the timebase assumed by the timestamps of the buffered
30794 frames.
30795
30796 frame_rate
30797 Specify the frame rate expected for the video stream.
30798
30799 pixel_aspect, sar
30800 The sample (pixel) aspect ratio of the input video.
30801
30802 sws_param
30803 This option is deprecated and ignored. Prepend "sws_flags=flags;"
30804 to the filtergraph description to specify swscale flags for
30805 automatically inserted scalers. See Filtergraph syntax.
30806
30807 hw_frames_ctx
30808 When using a hardware pixel format, this should be a reference to
30809 an AVHWFramesContext describing input frames.
30810
30811 For example:
30812
30813 buffer=width=320:height=240:pix_fmt=yuv410p:time_base=1/24:sar=1
30814
30815 will instruct the source to accept video frames with size 320x240 and
30816 with format "yuv410p", assuming 1/24 as the timestamps timebase and
30817 square pixels (1:1 sample aspect ratio). Since the pixel format with
30818 name "yuv410p" corresponds to the number 6 (check the enum
30819 AVPixelFormat definition in libavutil/pixfmt.h), this example
30820 corresponds to:
30821
30822 buffer=size=320x240:pixfmt=6:time_base=1/24:pixel_aspect=1/1
30823
30824 Alternatively, the options can be specified as a flat string, but this
30825 syntax is deprecated:
30826
30827 width:height:pix_fmt:time_base.num:time_base.den:pixel_aspect.num:pixel_aspect.den
30828
30829 cellauto
30830 Create a pattern generated by an elementary cellular automaton.
30831
30832 The initial state of the cellular automaton can be defined through the
30833 filename and pattern options. If such options are not specified an
30834 initial state is created randomly.
30835
30836 At each new frame a new row in the video is filled with the result of
30837 the cellular automaton next generation. The behavior when the whole
30838 frame is filled is defined by the scroll option.
30839
30840 This source accepts the following options:
30841
30842 filename, f
30843 Read the initial cellular automaton state, i.e. the starting row,
30844 from the specified file. In the file, each non-whitespace
30845 character is considered an alive cell, a newline will terminate the
30846 row, and further characters in the file will be ignored.
30847
30848 pattern, p
30849 Read the initial cellular automaton state, i.e. the starting row,
30850 from the specified string.
30851
30852 Each non-whitespace character in the string is considered an alive
30853 cell, a newline will terminate the row, and further characters in
30854 the string will be ignored.
30855
30856 rate, r
30857 Set the video rate, that is the number of frames generated per
30858 second. Default is 25.
30859
30860 random_fill_ratio, ratio
30861 Set the random fill ratio for the initial cellular automaton row.
30862 It is a floating point number value ranging from 0 to 1, defaults
30863 to 1/PHI.
30864
30865 This option is ignored when a file or a pattern is specified.
30866
30867 random_seed, seed
30868 Set the seed for filling randomly the initial row, must be an
30869 integer included between 0 and UINT32_MAX. If not specified, or if
30870 explicitly set to -1, the filter will try to use a good random seed
30871 on a best effort basis.
30872
30873 rule
30874 Set the cellular automaton rule, it is a number ranging from 0 to
30875 255. Default value is 110.
30876
30877 size, s
30878 Set the size of the output video. For the syntax of this option,
30879 check the "Video size" section in the ffmpeg-utils manual.
30880
30881 If filename or pattern is specified, the size is set by default to
30882 the width of the specified initial state row, and the height is set
30883 to width * PHI.
30884
30885 If size is set, it must contain the width of the specified pattern
30886 string, and the specified pattern will be centered in the larger
30887 row.
30888
30889 If a filename or a pattern string is not specified, the size value
30890 defaults to "320x518" (used for a randomly generated initial
30891 state).
30892
30893 scroll
30894 If set to 1, scroll the output upward when all the rows in the
30895 output have been already filled. If set to 0, the new generated row
30896 will be written over the top row just after the bottom row is
30897 filled. Defaults to 1.
30898
30899 start_full, full
30900 If set to 1, completely fill the output with generated rows before
30901 outputting the first frame. This is the default behavior, for
30902 disabling set the value to 0.
30903
30904 stitch
30905 If set to 1, stitch the left and right row edges together. This is
30906 the default behavior, for disabling set the value to 0.
30907
30908 Examples
30909
30910 • Read the initial state from pattern, and specify an output of size
30911 200x400.
30912
30913 cellauto=f=pattern:s=200x400
30914
30915 • Generate a random initial row with a width of 200 cells, with a
30916 fill ratio of 2/3:
30917
30918 cellauto=ratio=2/3:s=200x200
30919
30920 • Create a pattern generated by rule 18 starting by a single alive
30921 cell centered on an initial row with width 100:
30922
30923 cellauto=p=@s=100x400:full=0:rule=18
30924
30925 • Specify a more elaborated initial pattern:
30926
30927 cellauto=p='@@ @ @@':s=100x400:full=0:rule=18
30928
30929 coreimagesrc
30930 Video source generated on GPU using Apple's CoreImage API on OSX.
30931
30932 This video source is a specialized version of the coreimage video
30933 filter. Use a core image generator at the beginning of the applied
30934 filterchain to generate the content.
30935
30936 The coreimagesrc video source accepts the following options:
30937
30938 list_generators
30939 List all available generators along with all their respective
30940 options as well as possible minimum and maximum values along with
30941 the default values.
30942
30943 list_generators=true
30944
30945 size, s
30946 Specify the size of the sourced video. For the syntax of this
30947 option, check the "Video size" section in the ffmpeg-utils manual.
30948 The default value is "320x240".
30949
30950 rate, r
30951 Specify the frame rate of the sourced video, as the number of
30952 frames generated per second. It has to be a string in the format
30953 frame_rate_num/frame_rate_den, an integer number, a floating point
30954 number or a valid video frame rate abbreviation. The default value
30955 is "25".
30956
30957 sar Set the sample aspect ratio of the sourced video.
30958
30959 duration, d
30960 Set the duration of the sourced video. See the Time duration
30961 section in the ffmpeg-utils(1) manual for the accepted syntax.
30962
30963 If not specified, or the expressed duration is negative, the video
30964 is supposed to be generated forever.
30965
30966 Additionally, all options of the coreimage video filter are accepted.
30967 A complete filterchain can be used for further processing of the
30968 generated input without CPU-HOST transfer. See coreimage documentation
30969 and examples for details.
30970
30971 Examples
30972
30973 • Use CIQRCodeGenerator to create a QR code for the FFmpeg homepage,
30974 given as complete and escaped command-line for Apple's standard
30975 bash shell:
30976
30977 ffmpeg -f lavfi -i coreimagesrc=s=100x100:filter=CIQRCodeGenerator@inputMessage=https\\\\\://FFmpeg.org/@inputCorrectionLevel=H -frames:v 1 QRCode.png
30978
30979 This example is equivalent to the QRCode example of coreimage
30980 without the need for a nullsrc video source.
30981
30982 gradients
30983 Generate several gradients.
30984
30985 size, s
30986 Set frame size. For the syntax of this option, check the "Video
30987 size" section in the ffmpeg-utils manual. Default value is
30988 "640x480".
30989
30990 rate, r
30991 Set frame rate, expressed as number of frames per second. Default
30992 value is "25".
30993
30994 c0, c1, c2, c3, c4, c5, c6, c7
30995 Set 8 colors. Default values for colors is to pick random one.
30996
30997 x0, y0, y0, y1
30998 Set gradient line source and destination points. If negative or out
30999 of range, random ones are picked.
31000
31001 nb_colors, n
31002 Set number of colors to use at once. Allowed range is from 2 to 8.
31003 Default value is 2.
31004
31005 seed
31006 Set seed for picking gradient line points.
31007
31008 duration, d
31009 Set the duration of the sourced video. See the Time duration
31010 section in the ffmpeg-utils(1) manual for the accepted syntax.
31011
31012 If not specified, or the expressed duration is negative, the video
31013 is supposed to be generated forever.
31014
31015 speed
31016 Set speed of gradients rotation.
31017
31018 mandelbrot
31019 Generate a Mandelbrot set fractal, and progressively zoom towards the
31020 point specified with start_x and start_y.
31021
31022 This source accepts the following options:
31023
31024 end_pts
31025 Set the terminal pts value. Default value is 400.
31026
31027 end_scale
31028 Set the terminal scale value. Must be a floating point value.
31029 Default value is 0.3.
31030
31031 inner
31032 Set the inner coloring mode, that is the algorithm used to draw the
31033 Mandelbrot fractal internal region.
31034
31035 It shall assume one of the following values:
31036
31037 black
31038 Set black mode.
31039
31040 convergence
31041 Show time until convergence.
31042
31043 mincol
31044 Set color based on point closest to the origin of the
31045 iterations.
31046
31047 period
31048 Set period mode.
31049
31050 Default value is mincol.
31051
31052 bailout
31053 Set the bailout value. Default value is 10.0.
31054
31055 maxiter
31056 Set the maximum of iterations performed by the rendering algorithm.
31057 Default value is 7189.
31058
31059 outer
31060 Set outer coloring mode. It shall assume one of following values:
31061
31062 iteration_count
31063 Set iteration count mode.
31064
31065 normalized_iteration_count
31066 set normalized iteration count mode.
31067
31068 Default value is normalized_iteration_count.
31069
31070 rate, r
31071 Set frame rate, expressed as number of frames per second. Default
31072 value is "25".
31073
31074 size, s
31075 Set frame size. For the syntax of this option, check the "Video
31076 size" section in the ffmpeg-utils manual. Default value is
31077 "640x480".
31078
31079 start_scale
31080 Set the initial scale value. Default value is 3.0.
31081
31082 start_x
31083 Set the initial x position. Must be a floating point value between
31084 -100 and 100. Default value is
31085 -0.743643887037158704752191506114774.
31086
31087 start_y
31088 Set the initial y position. Must be a floating point value between
31089 -100 and 100. Default value is
31090 -0.131825904205311970493132056385139.
31091
31092 mptestsrc
31093 Generate various test patterns, as generated by the MPlayer test
31094 filter.
31095
31096 The size of the generated video is fixed, and is 256x256. This source
31097 is useful in particular for testing encoding features.
31098
31099 This source accepts the following options:
31100
31101 rate, r
31102 Specify the frame rate of the sourced video, as the number of
31103 frames generated per second. It has to be a string in the format
31104 frame_rate_num/frame_rate_den, an integer number, a floating point
31105 number or a valid video frame rate abbreviation. The default value
31106 is "25".
31107
31108 duration, d
31109 Set the duration of the sourced video. See the Time duration
31110 section in the ffmpeg-utils(1) manual for the accepted syntax.
31111
31112 If not specified, or the expressed duration is negative, the video
31113 is supposed to be generated forever.
31114
31115 test, t
31116 Set the number or the name of the test to perform. Supported tests
31117 are:
31118
31119 dc_luma
31120 dc_chroma
31121 freq_luma
31122 freq_chroma
31123 amp_luma
31124 amp_chroma
31125 cbp
31126 mv
31127 ring1
31128 ring2
31129 all
31130 max_frames, m
31131 Set the maximum number of frames generated for each test,
31132 default value is 30.
31133
31134 Default value is "all", which will cycle through the list of all
31135 tests.
31136
31137 Some examples:
31138
31139 mptestsrc=t=dc_luma
31140
31141 will generate a "dc_luma" test pattern.
31142
31143 frei0r_src
31144 Provide a frei0r source.
31145
31146 To enable compilation of this filter you need to install the frei0r
31147 header and configure FFmpeg with "--enable-frei0r".
31148
31149 This source accepts the following parameters:
31150
31151 size
31152 The size of the video to generate. For the syntax of this option,
31153 check the "Video size" section in the ffmpeg-utils manual.
31154
31155 framerate
31156 The framerate of the generated video. It may be a string of the
31157 form num/den or a frame rate abbreviation.
31158
31159 filter_name
31160 The name to the frei0r source to load. For more information
31161 regarding frei0r and how to set the parameters, read the frei0r
31162 section in the video filters documentation.
31163
31164 filter_params
31165 A '|'-separated list of parameters to pass to the frei0r source.
31166
31167 For example, to generate a frei0r partik0l source with size 200x200 and
31168 frame rate 10 which is overlaid on the overlay filter main input:
31169
31170 frei0r_src=size=200x200:framerate=10:filter_name=partik0l:filter_params=1234 [overlay]; [in][overlay] overlay
31171
31172 life
31173 Generate a life pattern.
31174
31175 This source is based on a generalization of John Conway's life game.
31176
31177 The sourced input represents a life grid, each pixel represents a cell
31178 which can be in one of two possible states, alive or dead. Every cell
31179 interacts with its eight neighbours, which are the cells that are
31180 horizontally, vertically, or diagonally adjacent.
31181
31182 At each interaction the grid evolves according to the adopted rule,
31183 which specifies the number of neighbor alive cells which will make a
31184 cell stay alive or born. The rule option allows one to specify the rule
31185 to adopt.
31186
31187 This source accepts the following options:
31188
31189 filename, f
31190 Set the file from which to read the initial grid state. In the
31191 file, each non-whitespace character is considered an alive cell,
31192 and newline is used to delimit the end of each row.
31193
31194 If this option is not specified, the initial grid is generated
31195 randomly.
31196
31197 rate, r
31198 Set the video rate, that is the number of frames generated per
31199 second. Default is 25.
31200
31201 random_fill_ratio, ratio
31202 Set the random fill ratio for the initial random grid. It is a
31203 floating point number value ranging from 0 to 1, defaults to 1/PHI.
31204 It is ignored when a file is specified.
31205
31206 random_seed, seed
31207 Set the seed for filling the initial random grid, must be an
31208 integer included between 0 and UINT32_MAX. If not specified, or if
31209 explicitly set to -1, the filter will try to use a good random seed
31210 on a best effort basis.
31211
31212 rule
31213 Set the life rule.
31214
31215 A rule can be specified with a code of the kind "SNS/BNB", where NS
31216 and NB are sequences of numbers in the range 0-8, NS specifies the
31217 number of alive neighbor cells which make a live cell stay alive,
31218 and NB the number of alive neighbor cells which make a dead cell to
31219 become alive (i.e. to "born"). "s" and "b" can be used in place of
31220 "S" and "B", respectively.
31221
31222 Alternatively a rule can be specified by an 18-bits integer. The 9
31223 high order bits are used to encode the next cell state if it is
31224 alive for each number of neighbor alive cells, the low order bits
31225 specify the rule for "borning" new cells. Higher order bits encode
31226 for an higher number of neighbor cells. For example the number
31227 6153 = "(12<<9)+9" specifies a stay alive rule of 12 and a born
31228 rule of 9, which corresponds to "S23/B03".
31229
31230 Default value is "S23/B3", which is the original Conway's game of
31231 life rule, and will keep a cell alive if it has 2 or 3 neighbor
31232 alive cells, and will born a new cell if there are three alive
31233 cells around a dead cell.
31234
31235 size, s
31236 Set the size of the output video. For the syntax of this option,
31237 check the "Video size" section in the ffmpeg-utils manual.
31238
31239 If filename is specified, the size is set by default to the same
31240 size of the input file. If size is set, it must contain the size
31241 specified in the input file, and the initial grid defined in that
31242 file is centered in the larger resulting area.
31243
31244 If a filename is not specified, the size value defaults to
31245 "320x240" (used for a randomly generated initial grid).
31246
31247 stitch
31248 If set to 1, stitch the left and right grid edges together, and the
31249 top and bottom edges also. Defaults to 1.
31250
31251 mold
31252 Set cell mold speed. If set, a dead cell will go from death_color
31253 to mold_color with a step of mold. mold can have a value from 0 to
31254 255.
31255
31256 life_color
31257 Set the color of living (or new born) cells.
31258
31259 death_color
31260 Set the color of dead cells. If mold is set, this is the first
31261 color used to represent a dead cell.
31262
31263 mold_color
31264 Set mold color, for definitely dead and moldy cells.
31265
31266 For the syntax of these 3 color options, check the "Color" section
31267 in the ffmpeg-utils manual.
31268
31269 Examples
31270
31271 • Read a grid from pattern, and center it on a grid of size 300x300
31272 pixels:
31273
31274 life=f=pattern:s=300x300
31275
31276 • Generate a random grid of size 200x200, with a fill ratio of 2/3:
31277
31278 life=ratio=2/3:s=200x200
31279
31280 • Specify a custom rule for evolving a randomly generated grid:
31281
31282 life=rule=S14/B34
31283
31284 • Full example with slow death effect (mold) using ffplay:
31285
31286 ffplay -f lavfi life=s=300x200:mold=10:r=60:ratio=0.1:death_color=#C83232:life_color=#00ff00,scale=1200:800:flags=16
31287
31288 allrgb, allyuv, color, colorspectrum, haldclutsrc, nullsrc, pal75bars,
31289 pal100bars, rgbtestsrc, smptebars, smptehdbars, testsrc, testsrc2,
31290 yuvtestsrc
31291 The "allrgb" source returns frames of size 4096x4096 of all rgb colors.
31292
31293 The "allyuv" source returns frames of size 4096x4096 of all yuv colors.
31294
31295 The "color" source provides an uniformly colored input.
31296
31297 The "colorspectrum" source provides a color spectrum input.
31298
31299 The "haldclutsrc" source provides an identity Hald CLUT. See also
31300 haldclut filter.
31301
31302 The "nullsrc" source returns unprocessed video frames. It is mainly
31303 useful to be employed in analysis / debugging tools, or as the source
31304 for filters which ignore the input data.
31305
31306 The "pal75bars" source generates a color bars pattern, based on EBU PAL
31307 recommendations with 75% color levels.
31308
31309 The "pal100bars" source generates a color bars pattern, based on EBU
31310 PAL recommendations with 100% color levels.
31311
31312 The "rgbtestsrc" source generates an RGB test pattern useful for
31313 detecting RGB vs BGR issues. You should see a red, green and blue
31314 stripe from top to bottom.
31315
31316 The "smptebars" source generates a color bars pattern, based on the
31317 SMPTE Engineering Guideline EG 1-1990.
31318
31319 The "smptehdbars" source generates a color bars pattern, based on the
31320 SMPTE RP 219-2002.
31321
31322 The "testsrc" source generates a test video pattern, showing a color
31323 pattern, a scrolling gradient and a timestamp. This is mainly intended
31324 for testing purposes.
31325
31326 The "testsrc2" source is similar to testsrc, but supports more pixel
31327 formats instead of just "rgb24". This allows using it as an input for
31328 other tests without requiring a format conversion.
31329
31330 The "yuvtestsrc" source generates an YUV test pattern. You should see a
31331 y, cb and cr stripe from top to bottom.
31332
31333 The sources accept the following parameters:
31334
31335 level
31336 Specify the level of the Hald CLUT, only available in the
31337 "haldclutsrc" source. A level of "N" generates a picture of "N*N*N"
31338 by "N*N*N" pixels to be used as identity matrix for 3D lookup
31339 tables. Each component is coded on a "1/(N*N)" scale.
31340
31341 color, c
31342 Specify the color of the source, only available in the "color"
31343 source. For the syntax of this option, check the "Color" section in
31344 the ffmpeg-utils manual.
31345
31346 size, s
31347 Specify the size of the sourced video. For the syntax of this
31348 option, check the "Video size" section in the ffmpeg-utils manual.
31349 The default value is "320x240".
31350
31351 This option is not available with the "allrgb", "allyuv", and
31352 "haldclutsrc" filters.
31353
31354 rate, r
31355 Specify the frame rate of the sourced video, as the number of
31356 frames generated per second. It has to be a string in the format
31357 frame_rate_num/frame_rate_den, an integer number, a floating point
31358 number or a valid video frame rate abbreviation. The default value
31359 is "25".
31360
31361 duration, d
31362 Set the duration of the sourced video. See the Time duration
31363 section in the ffmpeg-utils(1) manual for the accepted syntax.
31364
31365 If not specified, or the expressed duration is negative, the video
31366 is supposed to be generated forever.
31367
31368 Since the frame rate is used as time base, all frames including the
31369 last one will have their full duration. If the specified duration
31370 is not a multiple of the frame duration, it will be rounded up.
31371
31372 sar Set the sample aspect ratio of the sourced video.
31373
31374 alpha
31375 Specify the alpha (opacity) of the background, only available in
31376 the "testsrc2" source. The value must be between 0 (fully
31377 transparent) and 255 (fully opaque, the default).
31378
31379 decimals, n
31380 Set the number of decimals to show in the timestamp, only available
31381 in the "testsrc" source.
31382
31383 The displayed timestamp value will correspond to the original
31384 timestamp value multiplied by the power of 10 of the specified
31385 value. Default value is 0.
31386
31387 type
31388 Set the type of the color spectrum, only available in the
31389 "colorspectrum" source. Can be one of the following:
31390
31391 black
31392 white
31393 all
31394
31395 Examples
31396
31397 • Generate a video with a duration of 5.3 seconds, with size 176x144
31398 and a frame rate of 10 frames per second:
31399
31400 testsrc=duration=5.3:size=qcif:rate=10
31401
31402 • The following graph description will generate a red source with an
31403 opacity of 0.2, with size "qcif" and a frame rate of 10 frames per
31404 second:
31405
31406 color=c=red@0.2:s=qcif:r=10
31407
31408 • If the input content is to be ignored, "nullsrc" can be used. The
31409 following command generates noise in the luminance plane by
31410 employing the "geq" filter:
31411
31412 nullsrc=s=256x256, geq=random(1)*255:128:128
31413
31414 Commands
31415
31416 The "color" source supports the following commands:
31417
31418 c, color
31419 Set the color of the created image. Accepts the same syntax of the
31420 corresponding color option.
31421
31422 openclsrc
31423 Generate video using an OpenCL program.
31424
31425 source
31426 OpenCL program source file.
31427
31428 kernel
31429 Kernel name in program.
31430
31431 size, s
31432 Size of frames to generate. This must be set.
31433
31434 format
31435 Pixel format to use for the generated frames. This must be set.
31436
31437 rate, r
31438 Number of frames generated every second. Default value is '25'.
31439
31440 For details of how the program loading works, see the program_opencl
31441 filter.
31442
31443 Example programs:
31444
31445 • Generate a colour ramp by setting pixel values from the position of
31446 the pixel in the output image. (Note that this will work with all
31447 pixel formats, but the generated output will not be the same.)
31448
31449 __kernel void ramp(__write_only image2d_t dst,
31450 unsigned int index)
31451 {
31452 int2 loc = (int2)(get_global_id(0), get_global_id(1));
31453
31454 float4 val;
31455 val.xy = val.zw = convert_float2(loc) / convert_float2(get_image_dim(dst));
31456
31457 write_imagef(dst, loc, val);
31458 }
31459
31460 • Generate a Sierpinski carpet pattern, panning by a single pixel
31461 each frame.
31462
31463 __kernel void sierpinski_carpet(__write_only image2d_t dst,
31464 unsigned int index)
31465 {
31466 int2 loc = (int2)(get_global_id(0), get_global_id(1));
31467
31468 float4 value = 0.0f;
31469 int x = loc.x + index;
31470 int y = loc.y + index;
31471 while (x > 0 || y > 0) {
31472 if (x % 3 == 1 && y % 3 == 1) {
31473 value = 1.0f;
31474 break;
31475 }
31476 x /= 3;
31477 y /= 3;
31478 }
31479
31480 write_imagef(dst, loc, value);
31481 }
31482
31483 sierpinski
31484 Generate a Sierpinski carpet/triangle fractal, and randomly pan around.
31485
31486 This source accepts the following options:
31487
31488 size, s
31489 Set frame size. For the syntax of this option, check the "Video
31490 size" section in the ffmpeg-utils manual. Default value is
31491 "640x480".
31492
31493 rate, r
31494 Set frame rate, expressed as number of frames per second. Default
31495 value is "25".
31496
31497 seed
31498 Set seed which is used for random panning.
31499
31500 jump
31501 Set max jump for single pan destination. Allowed range is from 1 to
31502 10000.
31503
31504 type
31505 Set fractal type, can be default "carpet" or "triangle".
31506
31508 Below is a description of the currently available video sinks.
31509
31510 buffersink
31511 Buffer video frames, and make them available to the end of the filter
31512 graph.
31513
31514 This sink is mainly intended for programmatic use, in particular
31515 through the interface defined in libavfilter/buffersink.h or the
31516 options system.
31517
31518 It accepts a pointer to an AVBufferSinkContext structure, which defines
31519 the incoming buffers' formats, to be passed as the opaque parameter to
31520 "avfilter_init_filter" for initialization.
31521
31522 nullsink
31523 Null video sink: do absolutely nothing with the input video. It is
31524 mainly useful as a template and for use in analysis / debugging tools.
31525
31527 Below is a description of the currently available multimedia filters.
31528
31529 abitscope
31530 Convert input audio to a video output, displaying the audio bit scope.
31531
31532 The filter accepts the following options:
31533
31534 rate, r
31535 Set frame rate, expressed as number of frames per second. Default
31536 value is "25".
31537
31538 size, s
31539 Specify the video size for the output. For the syntax of this
31540 option, check the "Video size" section in the ffmpeg-utils manual.
31541 Default value is "1024x256".
31542
31543 colors
31544 Specify list of colors separated by space or by '|' which will be
31545 used to draw channels. Unrecognized or missing colors will be
31546 replaced by white color.
31547
31548 adrawgraph
31549 Draw a graph using input audio metadata.
31550
31551 See drawgraph
31552
31553 agraphmonitor
31554 See graphmonitor.
31555
31556 ahistogram
31557 Convert input audio to a video output, displaying the volume histogram.
31558
31559 The filter accepts the following options:
31560
31561 dmode
31562 Specify how histogram is calculated.
31563
31564 It accepts the following values:
31565
31566 single
31567 Use single histogram for all channels.
31568
31569 separate
31570 Use separate histogram for each channel.
31571
31572 Default is "single".
31573
31574 rate, r
31575 Set frame rate, expressed as number of frames per second. Default
31576 value is "25".
31577
31578 size, s
31579 Specify the video size for the output. For the syntax of this
31580 option, check the "Video size" section in the ffmpeg-utils manual.
31581 Default value is "hd720".
31582
31583 scale
31584 Set display scale.
31585
31586 It accepts the following values:
31587
31588 log logarithmic
31589
31590 sqrt
31591 square root
31592
31593 cbrt
31594 cubic root
31595
31596 lin linear
31597
31598 rlog
31599 reverse logarithmic
31600
31601 Default is "log".
31602
31603 ascale
31604 Set amplitude scale.
31605
31606 It accepts the following values:
31607
31608 log logarithmic
31609
31610 lin linear
31611
31612 Default is "log".
31613
31614 acount
31615 Set how much frames to accumulate in histogram. Default is 1.
31616 Setting this to -1 accumulates all frames.
31617
31618 rheight
31619 Set histogram ratio of window height.
31620
31621 slide
31622 Set sonogram sliding.
31623
31624 It accepts the following values:
31625
31626 replace
31627 replace old rows with new ones.
31628
31629 scroll
31630 scroll from top to bottom.
31631
31632 Default is "replace".
31633
31634 aphasemeter
31635 Measures phase of input audio, which is exported as metadata
31636 "lavfi.aphasemeter.phase", representing mean phase of current audio
31637 frame. A video output can also be produced and is enabled by default.
31638 The audio is passed through as first output.
31639
31640 Audio will be rematrixed to stereo if it has a different channel
31641 layout. Phase value is in range "[-1, 1]" where "-1" means left and
31642 right channels are completely out of phase and 1 means channels are in
31643 phase.
31644
31645 The filter accepts the following options, all related to its video
31646 output:
31647
31648 rate, r
31649 Set the output frame rate. Default value is 25.
31650
31651 size, s
31652 Set the video size for the output. For the syntax of this option,
31653 check the "Video size" section in the ffmpeg-utils manual. Default
31654 value is "800x400".
31655
31656 rc
31657 gc
31658 bc Specify the red, green, blue contrast. Default values are 2, 7 and
31659 1. Allowed range is "[0, 255]".
31660
31661 mpc Set color which will be used for drawing median phase. If color is
31662 "none" which is default, no median phase value will be drawn.
31663
31664 video
31665 Enable video output. Default is enabled.
31666
31667 phasing detection
31668
31669 The filter also detects out of phase and mono sequences in stereo
31670 streams. It logs the sequence start, end and duration when it lasts
31671 longer or as long as the minimum set.
31672
31673 The filter accepts the following options for this detection:
31674
31675 phasing
31676 Enable mono and out of phase detection. Default is disabled.
31677
31678 tolerance, t
31679 Set phase tolerance for mono detection, in amplitude ratio. Default
31680 is 0. Allowed range is "[0, 1]".
31681
31682 angle, a
31683 Set angle threshold for out of phase detection, in degree. Default
31684 is 170. Allowed range is "[90, 180]".
31685
31686 duration, d
31687 Set mono or out of phase duration until notification, expressed in
31688 seconds. Default is 2.
31689
31690 Examples
31691
31692 • Complete example with ffmpeg to detect 1 second of mono with 0.001
31693 phase tolerance:
31694
31695 ffmpeg -i stereo.wav -af aphasemeter=video=0:phasing=1:duration=1:tolerance=0.001 -f null -
31696
31697 avectorscope
31698 Convert input audio to a video output, representing the audio vector
31699 scope.
31700
31701 The filter is used to measure the difference between channels of stereo
31702 audio stream. A monaural signal, consisting of identical left and right
31703 signal, results in straight vertical line. Any stereo separation is
31704 visible as a deviation from this line, creating a Lissajous figure. If
31705 the straight (or deviation from it) but horizontal line appears this
31706 indicates that the left and right channels are out of phase.
31707
31708 The filter accepts the following options:
31709
31710 mode, m
31711 Set the vectorscope mode.
31712
31713 Available values are:
31714
31715 lissajous
31716 Lissajous rotated by 45 degrees.
31717
31718 lissajous_xy
31719 Same as above but not rotated.
31720
31721 polar
31722 Shape resembling half of circle.
31723
31724 Default value is lissajous.
31725
31726 size, s
31727 Set the video size for the output. For the syntax of this option,
31728 check the "Video size" section in the ffmpeg-utils manual. Default
31729 value is "400x400".
31730
31731 rate, r
31732 Set the output frame rate. Default value is 25.
31733
31734 rc
31735 gc
31736 bc
31737 ac Specify the red, green, blue and alpha contrast. Default values are
31738 40, 160, 80 and 255. Allowed range is "[0, 255]".
31739
31740 rf
31741 gf
31742 bf
31743 af Specify the red, green, blue and alpha fade. Default values are 15,
31744 10, 5 and 5. Allowed range is "[0, 255]".
31745
31746 zoom
31747 Set the zoom factor. Default value is 1. Allowed range is "[0,
31748 10]". Values lower than 1 will auto adjust zoom factor to maximal
31749 possible value.
31750
31751 draw
31752 Set the vectorscope drawing mode.
31753
31754 Available values are:
31755
31756 dot Draw dot for each sample.
31757
31758 line
31759 Draw line between previous and current sample.
31760
31761 Default value is dot.
31762
31763 scale
31764 Specify amplitude scale of audio samples.
31765
31766 Available values are:
31767
31768 lin Linear.
31769
31770 sqrt
31771 Square root.
31772
31773 cbrt
31774 Cubic root.
31775
31776 log Logarithmic.
31777
31778 swap
31779 Swap left channel axis with right channel axis.
31780
31781 mirror
31782 Mirror axis.
31783
31784 none
31785 No mirror.
31786
31787 x Mirror only x axis.
31788
31789 y Mirror only y axis.
31790
31791 xy Mirror both axis.
31792
31793 Examples
31794
31795 • Complete example using ffplay:
31796
31797 ffplay -f lavfi 'amovie=input.mp3, asplit [a][out1];
31798 [a] avectorscope=zoom=1.3:rc=2:gc=200:bc=10:rf=1:gf=8:bf=7 [out0]'
31799
31800 Commands
31801
31802 This filter supports the all above options as commands except options
31803 "size" and "rate".
31804
31805 bench, abench
31806 Benchmark part of a filtergraph.
31807
31808 The filter accepts the following options:
31809
31810 action
31811 Start or stop a timer.
31812
31813 Available values are:
31814
31815 start
31816 Get the current time, set it as frame metadata (using the key
31817 "lavfi.bench.start_time"), and forward the frame to the next
31818 filter.
31819
31820 stop
31821 Get the current time and fetch the "lavfi.bench.start_time"
31822 metadata from the input frame metadata to get the time
31823 difference. Time difference, average, maximum and minimum time
31824 (respectively "t", "avg", "max" and "min") are then printed.
31825 The timestamps are expressed in seconds.
31826
31827 Examples
31828
31829 • Benchmark selectivecolor filter:
31830
31831 bench=start,selectivecolor=reds=-.2 .12 -.49,bench=stop
31832
31833 concat
31834 Concatenate audio and video streams, joining them together one after
31835 the other.
31836
31837 The filter works on segments of synchronized video and audio streams.
31838 All segments must have the same number of streams of each type, and
31839 that will also be the number of streams at output.
31840
31841 The filter accepts the following options:
31842
31843 n Set the number of segments. Default is 2.
31844
31845 v Set the number of output video streams, that is also the number of
31846 video streams in each segment. Default is 1.
31847
31848 a Set the number of output audio streams, that is also the number of
31849 audio streams in each segment. Default is 0.
31850
31851 unsafe
31852 Activate unsafe mode: do not fail if segments have a different
31853 format.
31854
31855 The filter has v+a outputs: first v video outputs, then a audio
31856 outputs.
31857
31858 There are nx(v+a) inputs: first the inputs for the first segment, in
31859 the same order as the outputs, then the inputs for the second segment,
31860 etc.
31861
31862 Related streams do not always have exactly the same duration, for
31863 various reasons including codec frame size or sloppy authoring. For
31864 that reason, related synchronized streams (e.g. a video and its audio
31865 track) should be concatenated at once. The concat filter will use the
31866 duration of the longest stream in each segment (except the last one),
31867 and if necessary pad shorter audio streams with silence.
31868
31869 For this filter to work correctly, all segments must start at timestamp
31870 0.
31871
31872 All corresponding streams must have the same parameters in all
31873 segments; the filtering system will automatically select a common pixel
31874 format for video streams, and a common sample format, sample rate and
31875 channel layout for audio streams, but other settings, such as
31876 resolution, must be converted explicitly by the user.
31877
31878 Different frame rates are acceptable but will result in variable frame
31879 rate at output; be sure to configure the output file to handle it.
31880
31881 Examples
31882
31883 • Concatenate an opening, an episode and an ending, all in bilingual
31884 version (video in stream 0, audio in streams 1 and 2):
31885
31886 ffmpeg -i opening.mkv -i episode.mkv -i ending.mkv -filter_complex \
31887 '[0:0] [0:1] [0:2] [1:0] [1:1] [1:2] [2:0] [2:1] [2:2]
31888 concat=n=3:v=1:a=2 [v] [a1] [a2]' \
31889 -map '[v]' -map '[a1]' -map '[a2]' output.mkv
31890
31891 • Concatenate two parts, handling audio and video separately, using
31892 the (a)movie sources, and adjusting the resolution:
31893
31894 movie=part1.mp4, scale=512:288 [v1] ; amovie=part1.mp4 [a1] ;
31895 movie=part2.mp4, scale=512:288 [v2] ; amovie=part2.mp4 [a2] ;
31896 [v1] [v2] concat [outv] ; [a1] [a2] concat=v=0:a=1 [outa]
31897
31898 Note that a desync will happen at the stitch if the audio and video
31899 streams do not have exactly the same duration in the first file.
31900
31901 Commands
31902
31903 This filter supports the following commands:
31904
31905 next
31906 Close the current segment and step to the next one
31907
31908 ebur128
31909 EBU R128 scanner filter. This filter takes an audio stream and analyzes
31910 its loudness level. By default, it logs a message at a frequency of
31911 10Hz with the Momentary loudness (identified by "M"), Short-term
31912 loudness ("S"), Integrated loudness ("I") and Loudness Range ("LRA").
31913
31914 The filter can only analyze streams which have sample format is double-
31915 precision floating point. The input stream will be converted to this
31916 specification, if needed. Users may need to insert aformat and/or
31917 aresample filters after this filter to obtain the original parameters.
31918
31919 The filter also has a video output (see the video option) with a real
31920 time graph to observe the loudness evolution. The graphic contains the
31921 logged message mentioned above, so it is not printed anymore when this
31922 option is set, unless the verbose logging is set. The main graphing
31923 area contains the short-term loudness (3 seconds of analysis), and the
31924 gauge on the right is for the momentary loudness (400 milliseconds),
31925 but can optionally be configured to instead display short-term loudness
31926 (see gauge).
31927
31928 The green area marks a +/- 1LU target range around the target loudness
31929 (-23LUFS by default, unless modified through target).
31930
31931 More information about the Loudness Recommendation EBU R128 on
31932 <http://tech.ebu.ch/loudness>.
31933
31934 The filter accepts the following options:
31935
31936 video
31937 Activate the video output. The audio stream is passed unchanged
31938 whether this option is set or no. The video stream will be the
31939 first output stream if activated. Default is 0.
31940
31941 size
31942 Set the video size. This option is for video only. For the syntax
31943 of this option, check the "Video size" section in the ffmpeg-utils
31944 manual. Default and minimum resolution is "640x480".
31945
31946 meter
31947 Set the EBU scale meter. Default is 9. Common values are 9 and 18,
31948 respectively for EBU scale meter +9 and EBU scale meter +18. Any
31949 other integer value between this range is allowed.
31950
31951 metadata
31952 Set metadata injection. If set to 1, the audio input will be
31953 segmented into 100ms output frames, each of them containing various
31954 loudness information in metadata. All the metadata keys are
31955 prefixed with "lavfi.r128.".
31956
31957 Default is 0.
31958
31959 framelog
31960 Force the frame logging level.
31961
31962 Available values are:
31963
31964 info
31965 information logging level
31966
31967 verbose
31968 verbose logging level
31969
31970 By default, the logging level is set to info. If the video or the
31971 metadata options are set, it switches to verbose.
31972
31973 peak
31974 Set peak mode(s).
31975
31976 Available modes can be cumulated (the option is a "flag" type).
31977 Possible values are:
31978
31979 none
31980 Disable any peak mode (default).
31981
31982 sample
31983 Enable sample-peak mode.
31984
31985 Simple peak mode looking for the higher sample value. It logs a
31986 message for sample-peak (identified by "SPK").
31987
31988 true
31989 Enable true-peak mode.
31990
31991 If enabled, the peak lookup is done on an over-sampled version
31992 of the input stream for better peak accuracy. It logs a message
31993 for true-peak. (identified by "TPK") and true-peak per frame
31994 (identified by "FTPK"). This mode requires a build with
31995 "libswresample".
31996
31997 dualmono
31998 Treat mono input files as "dual mono". If a mono file is intended
31999 for playback on a stereo system, its EBU R128 measurement will be
32000 perceptually incorrect. If set to "true", this option will
32001 compensate for this effect. Multi-channel input files are not
32002 affected by this option.
32003
32004 panlaw
32005 Set a specific pan law to be used for the measurement of dual mono
32006 files. This parameter is optional, and has a default value of
32007 -3.01dB.
32008
32009 target
32010 Set a specific target level (in LUFS) used as relative zero in the
32011 visualization. This parameter is optional and has a default value
32012 of -23LUFS as specified by EBU R128. However, material published
32013 online may prefer a level of -16LUFS (e.g. for use with podcasts or
32014 video platforms).
32015
32016 gauge
32017 Set the value displayed by the gauge. Valid values are "momentary"
32018 and s "shortterm". By default the momentary value will be used, but
32019 in certain scenarios it may be more useful to observe the short
32020 term value instead (e.g. live mixing).
32021
32022 scale
32023 Sets the display scale for the loudness. Valid parameters are
32024 "absolute" (in LUFS) or "relative" (LU) relative to the target.
32025 This only affects the video output, not the summary or continuous
32026 log output.
32027
32028 Examples
32029
32030 • Real-time graph using ffplay, with a EBU scale meter +18:
32031
32032 ffplay -f lavfi -i "amovie=input.mp3,ebur128=video=1:meter=18 [out0][out1]"
32033
32034 • Run an analysis with ffmpeg:
32035
32036 ffmpeg -nostats -i input.mp3 -filter_complex ebur128 -f null -
32037
32038 interleave, ainterleave
32039 Temporally interleave frames from several inputs.
32040
32041 "interleave" works with video inputs, "ainterleave" with audio.
32042
32043 These filters read frames from several inputs and send the oldest
32044 queued frame to the output.
32045
32046 Input streams must have well defined, monotonically increasing frame
32047 timestamp values.
32048
32049 In order to submit one frame to output, these filters need to enqueue
32050 at least one frame for each input, so they cannot work in case one
32051 input is not yet terminated and will not receive incoming frames.
32052
32053 For example consider the case when one input is a "select" filter which
32054 always drops input frames. The "interleave" filter will keep reading
32055 from that input, but it will never be able to send new frames to output
32056 until the input sends an end-of-stream signal.
32057
32058 Also, depending on inputs synchronization, the filters will drop frames
32059 in case one input receives more frames than the other ones, and the
32060 queue is already filled.
32061
32062 These filters accept the following options:
32063
32064 nb_inputs, n
32065 Set the number of different inputs, it is 2 by default.
32066
32067 duration
32068 How to determine the end-of-stream.
32069
32070 longest
32071 The duration of the longest input. (default)
32072
32073 shortest
32074 The duration of the shortest input.
32075
32076 first
32077 The duration of the first input.
32078
32079 Examples
32080
32081 • Interleave frames belonging to different streams using ffmpeg:
32082
32083 ffmpeg -i bambi.avi -i pr0n.mkv -filter_complex "[0:v][1:v] interleave" out.avi
32084
32085 • Add flickering blur effect:
32086
32087 select='if(gt(random(0), 0.2), 1, 2)':n=2 [tmp], boxblur=2:2, [tmp] interleave
32088
32089 latency, alatency
32090 Measure filtering latency.
32091
32092 Report previous filter filtering latency, delay in number of audio
32093 samples for audio filters or number of video frames for video filters.
32094
32095 On end of input stream, filter will report min and max measured latency
32096 for previous running filter in filtergraph.
32097
32098 metadata, ametadata
32099 Manipulate frame metadata.
32100
32101 This filter accepts the following options:
32102
32103 mode
32104 Set mode of operation of the filter.
32105
32106 Can be one of the following:
32107
32108 select
32109 If both "value" and "key" is set, select frames which have such
32110 metadata. If only "key" is set, select every frame that has
32111 such key in metadata.
32112
32113 add Add new metadata "key" and "value". If key is already available
32114 do nothing.
32115
32116 modify
32117 Modify value of already present key.
32118
32119 delete
32120 If "value" is set, delete only keys that have such value.
32121 Otherwise, delete key. If "key" is not set, delete all metadata
32122 values in the frame.
32123
32124 print
32125 Print key and its value if metadata was found. If "key" is not
32126 set print all metadata values available in frame.
32127
32128 key Set key used with all modes. Must be set for all modes except
32129 "print" and "delete".
32130
32131 value
32132 Set metadata value which will be used. This option is mandatory for
32133 "modify" and "add" mode.
32134
32135 function
32136 Which function to use when comparing metadata value and "value".
32137
32138 Can be one of following:
32139
32140 same_str
32141 Values are interpreted as strings, returns true if metadata
32142 value is same as "value".
32143
32144 starts_with
32145 Values are interpreted as strings, returns true if metadata
32146 value starts with the "value" option string.
32147
32148 less
32149 Values are interpreted as floats, returns true if metadata
32150 value is less than "value".
32151
32152 equal
32153 Values are interpreted as floats, returns true if "value" is
32154 equal with metadata value.
32155
32156 greater
32157 Values are interpreted as floats, returns true if metadata
32158 value is greater than "value".
32159
32160 expr
32161 Values are interpreted as floats, returns true if expression
32162 from option "expr" evaluates to true.
32163
32164 ends_with
32165 Values are interpreted as strings, returns true if metadata
32166 value ends with the "value" option string.
32167
32168 expr
32169 Set expression which is used when "function" is set to "expr". The
32170 expression is evaluated through the eval API and can contain the
32171 following constants:
32172
32173 VALUE1, FRAMEVAL
32174 Float representation of "value" from metadata key.
32175
32176 VALUE2, USERVAL
32177 Float representation of "value" as supplied by user in "value"
32178 option.
32179
32180 file
32181 If specified in "print" mode, output is written to the named file.
32182 Instead of plain filename any writable url can be specified.
32183 Filename ``-'' is a shorthand for standard output. If "file" option
32184 is not set, output is written to the log with AV_LOG_INFO loglevel.
32185
32186 direct
32187 Reduces buffering in print mode when output is written to a URL set
32188 using file.
32189
32190 Examples
32191
32192 • Print all metadata values for frames with key
32193 "lavfi.signalstats.YDIF" with values between 0 and 1.
32194
32195 signalstats,metadata=print:key=lavfi.signalstats.YDIF:value=0:function=expr:expr='between(VALUE1,0,1)'
32196
32197 • Print silencedetect output to file metadata.txt.
32198
32199 silencedetect,ametadata=mode=print:file=metadata.txt
32200
32201 • Direct all metadata to a pipe with file descriptor 4.
32202
32203 metadata=mode=print:file='pipe\:4'
32204
32205 perms, aperms
32206 Set read/write permissions for the output frames.
32207
32208 These filters are mainly aimed at developers to test direct path in the
32209 following filter in the filtergraph.
32210
32211 The filters accept the following options:
32212
32213 mode
32214 Select the permissions mode.
32215
32216 It accepts the following values:
32217
32218 none
32219 Do nothing. This is the default.
32220
32221 ro Set all the output frames read-only.
32222
32223 rw Set all the output frames directly writable.
32224
32225 toggle
32226 Make the frame read-only if writable, and writable if read-
32227 only.
32228
32229 random
32230 Set each output frame read-only or writable randomly.
32231
32232 seed
32233 Set the seed for the random mode, must be an integer included
32234 between 0 and "UINT32_MAX". If not specified, or if explicitly set
32235 to "-1", the filter will try to use a good random seed on a best
32236 effort basis.
32237
32238 Note: in case of auto-inserted filter between the permission filter and
32239 the following one, the permission might not be received as expected in
32240 that following filter. Inserting a format or aformat filter before the
32241 perms/aperms filter can avoid this problem.
32242
32243 realtime, arealtime
32244 Slow down filtering to match real time approximately.
32245
32246 These filters will pause the filtering for a variable amount of time to
32247 match the output rate with the input timestamps. They are similar to
32248 the re option to "ffmpeg".
32249
32250 They accept the following options:
32251
32252 limit
32253 Time limit for the pauses. Any pause longer than that will be
32254 considered a timestamp discontinuity and reset the timer. Default
32255 is 2 seconds.
32256
32257 speed
32258 Speed factor for processing. The value must be a float larger than
32259 zero. Values larger than 1.0 will result in faster than realtime
32260 processing, smaller will slow processing down. The limit is
32261 automatically adapted accordingly. Default is 1.0.
32262
32263 A processing speed faster than what is possible without these
32264 filters cannot be achieved.
32265
32266 segment, asegment
32267 Split single input stream into multiple streams.
32268
32269 This filter does opposite of concat filters.
32270
32271 "segment" works on video frames, "asegment" on audio samples.
32272
32273 This filter accepts the following options:
32274
32275 timestamps
32276 Timestamps of output segments separated by '|'. The first segment
32277 will run from the beginning of the input stream. The last segment
32278 will run until the end of the input stream
32279
32280 frames, samples
32281 Exact frame/sample count to split the segments.
32282
32283 In all cases, prefixing an each segment with '+' will make it relative
32284 to the previous segment.
32285
32286 Examples
32287
32288 • Split input audio stream into three output audio streams, starting
32289 at start of input audio stream and storing that in 1st output audio
32290 stream, then following at 60th second and storing than in 2nd
32291 output audio stream, and last after 150th second of input audio
32292 stream store in 3rd output audio stream:
32293
32294 asegment=timestamps="60|150"
32295
32296 select, aselect
32297 Select frames to pass in output.
32298
32299 This filter accepts the following options:
32300
32301 expr, e
32302 Set expression, which is evaluated for each input frame.
32303
32304 If the expression is evaluated to zero, the frame is discarded.
32305
32306 If the evaluation result is negative or NaN, the frame is sent to
32307 the first output; otherwise it is sent to the output with index
32308 "ceil(val)-1", assuming that the input index starts from 0.
32309
32310 For example a value of 1.2 corresponds to the output with index
32311 "ceil(1.2)-1 = 2-1 = 1", that is the second output.
32312
32313 outputs, n
32314 Set the number of outputs. The output to which to send the selected
32315 frame is based on the result of the evaluation. Default value is 1.
32316
32317 The expression can contain the following constants:
32318
32319 n The (sequential) number of the filtered frame, starting from 0.
32320
32321 selected_n
32322 The (sequential) number of the selected frame, starting from 0.
32323
32324 prev_selected_n
32325 The sequential number of the last selected frame. It's NAN if
32326 undefined.
32327
32328 TB The timebase of the input timestamps.
32329
32330 pts The PTS (Presentation TimeStamp) of the filtered frame, expressed
32331 in TB units. It's NAN if undefined.
32332
32333 t The PTS of the filtered frame, expressed in seconds. It's NAN if
32334 undefined.
32335
32336 prev_pts
32337 The PTS of the previously filtered frame. It's NAN if undefined.
32338
32339 prev_selected_pts
32340 The PTS of the last previously filtered frame. It's NAN if
32341 undefined.
32342
32343 prev_selected_t
32344 The PTS of the last previously selected frame, expressed in
32345 seconds. It's NAN if undefined.
32346
32347 start_pts
32348 The first PTS in the stream which is not NAN. It remains NAN if not
32349 found.
32350
32351 start_t
32352 The first PTS, in seconds, in the stream which is not NAN. It
32353 remains NAN if not found.
32354
32355 pict_type (video only)
32356 The type of the filtered frame. It can assume one of the following
32357 values:
32358
32359 I
32360 P
32361 B
32362 S
32363 SI
32364 SP
32365 BI
32366 interlace_type (video only)
32367 The frame interlace type. It can assume one of the following
32368 values:
32369
32370 PROGRESSIVE
32371 The frame is progressive (not interlaced).
32372
32373 TOPFIRST
32374 The frame is top-field-first.
32375
32376 BOTTOMFIRST
32377 The frame is bottom-field-first.
32378
32379 consumed_sample_n (audio only)
32380 the number of selected samples before the current frame
32381
32382 samples_n (audio only)
32383 the number of samples in the current frame
32384
32385 sample_rate (audio only)
32386 the input sample rate
32387
32388 key This is 1 if the filtered frame is a key-frame, 0 otherwise.
32389
32390 pos the position in the file of the filtered frame, -1 if the
32391 information is not available (e.g. for synthetic video)
32392
32393 scene (video only)
32394 value between 0 and 1 to indicate a new scene; a low value reflects
32395 a low probability for the current frame to introduce a new scene,
32396 while a higher value means the current frame is more likely to be
32397 one (see the example below)
32398
32399 concatdec_select
32400 The concat demuxer can select only part of a concat input file by
32401 setting an inpoint and an outpoint, but the output packets may not
32402 be entirely contained in the selected interval. By using this
32403 variable, it is possible to skip frames generated by the concat
32404 demuxer which are not exactly contained in the selected interval.
32405
32406 This works by comparing the frame pts against the
32407 lavf.concat.start_time and the lavf.concat.duration packet metadata
32408 values which are also present in the decoded frames.
32409
32410 The concatdec_select variable is -1 if the frame pts is at least
32411 start_time and either the duration metadata is missing or the frame
32412 pts is less than start_time + duration, 0 otherwise, and NaN if the
32413 start_time metadata is missing.
32414
32415 That basically means that an input frame is selected if its pts is
32416 within the interval set by the concat demuxer.
32417
32418 The default value of the select expression is "1".
32419
32420 Examples
32421
32422 • Select all frames in input:
32423
32424 select
32425
32426 The example above is the same as:
32427
32428 select=1
32429
32430 • Skip all frames:
32431
32432 select=0
32433
32434 • Select only I-frames:
32435
32436 select='eq(pict_type\,I)'
32437
32438 • Select one frame every 100:
32439
32440 select='not(mod(n\,100))'
32441
32442 • Select only frames contained in the 10-20 time interval:
32443
32444 select=between(t\,10\,20)
32445
32446 • Select only I-frames contained in the 10-20 time interval:
32447
32448 select=between(t\,10\,20)*eq(pict_type\,I)
32449
32450 • Select frames with a minimum distance of 10 seconds:
32451
32452 select='isnan(prev_selected_t)+gte(t-prev_selected_t\,10)'
32453
32454 • Use aselect to select only audio frames with samples number > 100:
32455
32456 aselect='gt(samples_n\,100)'
32457
32458 • Create a mosaic of the first scenes:
32459
32460 ffmpeg -i video.avi -vf select='gt(scene\,0.4)',scale=160:120,tile -frames:v 1 preview.png
32461
32462 Comparing scene against a value between 0.3 and 0.5 is generally a
32463 sane choice.
32464
32465 • Send even and odd frames to separate outputs, and compose them:
32466
32467 select=n=2:e='mod(n, 2)+1' [odd][even]; [odd] pad=h=2*ih [tmp]; [tmp][even] overlay=y=h
32468
32469 • Select useful frames from an ffconcat file which is using inpoints
32470 and outpoints but where the source files are not intra frame only.
32471
32472 ffmpeg -copyts -vsync 0 -segment_time_metadata 1 -i input.ffconcat -vf select=concatdec_select -af aselect=concatdec_select output.avi
32473
32474 sendcmd, asendcmd
32475 Send commands to filters in the filtergraph.
32476
32477 These filters read commands to be sent to other filters in the
32478 filtergraph.
32479
32480 "sendcmd" must be inserted between two video filters, "asendcmd" must
32481 be inserted between two audio filters, but apart from that they act the
32482 same way.
32483
32484 The specification of commands can be provided in the filter arguments
32485 with the commands option, or in a file specified by the filename
32486 option.
32487
32488 These filters accept the following options:
32489
32490 commands, c
32491 Set the commands to be read and sent to the other filters.
32492
32493 filename, f
32494 Set the filename of the commands to be read and sent to the other
32495 filters.
32496
32497 Commands syntax
32498
32499 A commands description consists of a sequence of interval
32500 specifications, comprising a list of commands to be executed when a
32501 particular event related to that interval occurs. The occurring event
32502 is typically the current frame time entering or leaving a given time
32503 interval.
32504
32505 An interval is specified by the following syntax:
32506
32507 <START>[-<END>] <COMMANDS>;
32508
32509 The time interval is specified by the START and END times. END is
32510 optional and defaults to the maximum time.
32511
32512 The current frame time is considered within the specified interval if
32513 it is included in the interval [START, END), that is when the time is
32514 greater or equal to START and is lesser than END.
32515
32516 COMMANDS consists of a sequence of one or more command specifications,
32517 separated by ",", relating to that interval. The syntax of a command
32518 specification is given by:
32519
32520 [<FLAGS>] <TARGET> <COMMAND> <ARG>
32521
32522 FLAGS is optional and specifies the type of events relating to the time
32523 interval which enable sending the specified command, and must be a non-
32524 null sequence of identifier flags separated by "+" or "|" and enclosed
32525 between "[" and "]".
32526
32527 The following flags are recognized:
32528
32529 enter
32530 The command is sent when the current frame timestamp enters the
32531 specified interval. In other words, the command is sent when the
32532 previous frame timestamp was not in the given interval, and the
32533 current is.
32534
32535 leave
32536 The command is sent when the current frame timestamp leaves the
32537 specified interval. In other words, the command is sent when the
32538 previous frame timestamp was in the given interval, and the current
32539 is not.
32540
32541 expr
32542 The command ARG is interpreted as expression and result of
32543 expression is passed as ARG.
32544
32545 The expression is evaluated through the eval API and can contain
32546 the following constants:
32547
32548 POS Original position in the file of the frame, or undefined if
32549 undefined for the current frame.
32550
32551 PTS The presentation timestamp in input.
32552
32553 N The count of the input frame for video or audio, starting from
32554 0.
32555
32556 T The time in seconds of the current frame.
32557
32558 TS The start time in seconds of the current command interval.
32559
32560 TE The end time in seconds of the current command interval.
32561
32562 TI The interpolated time of the current command interval, TI = (T
32563 - TS) / (TE - TS).
32564
32565 If FLAGS is not specified, a default value of "[enter]" is assumed.
32566
32567 TARGET specifies the target of the command, usually the name of the
32568 filter class or a specific filter instance name.
32569
32570 COMMAND specifies the name of the command for the target filter.
32571
32572 ARG is optional and specifies the optional list of argument for the
32573 given COMMAND.
32574
32575 Between one interval specification and another, whitespaces, or
32576 sequences of characters starting with "#" until the end of line, are
32577 ignored and can be used to annotate comments.
32578
32579 A simplified BNF description of the commands specification syntax
32580 follows:
32581
32582 <COMMAND_FLAG> ::= "enter" | "leave"
32583 <COMMAND_FLAGS> ::= <COMMAND_FLAG> [(+|"|")<COMMAND_FLAG>]
32584 <COMMAND> ::= ["[" <COMMAND_FLAGS> "]"] <TARGET> <COMMAND> [<ARG>]
32585 <COMMANDS> ::= <COMMAND> [,<COMMANDS>]
32586 <INTERVAL> ::= <START>[-<END>] <COMMANDS>
32587 <INTERVALS> ::= <INTERVAL>[;<INTERVALS>]
32588
32589 Examples
32590
32591 • Specify audio tempo change at second 4:
32592
32593 asendcmd=c='4.0 atempo tempo 1.5',atempo
32594
32595 • Target a specific filter instance:
32596
32597 asendcmd=c='4.0 atempo@my tempo 1.5',atempo@my
32598
32599 • Specify a list of drawtext and hue commands in a file.
32600
32601 # show text in the interval 5-10
32602 5.0-10.0 [enter] drawtext reinit 'fontfile=FreeSerif.ttf:text=hello world',
32603 [leave] drawtext reinit 'fontfile=FreeSerif.ttf:text=';
32604
32605 # desaturate the image in the interval 15-20
32606 15.0-20.0 [enter] hue s 0,
32607 [enter] drawtext reinit 'fontfile=FreeSerif.ttf:text=nocolor',
32608 [leave] hue s 1,
32609 [leave] drawtext reinit 'fontfile=FreeSerif.ttf:text=color';
32610
32611 # apply an exponential saturation fade-out effect, starting from time 25
32612 25 [enter] hue s exp(25-t)
32613
32614 A filtergraph allowing to read and process the above command list
32615 stored in a file test.cmd, can be specified with:
32616
32617 sendcmd=f=test.cmd,drawtext=fontfile=FreeSerif.ttf:text='',hue
32618
32619 setpts, asetpts
32620 Change the PTS (presentation timestamp) of the input frames.
32621
32622 "setpts" works on video frames, "asetpts" on audio frames.
32623
32624 This filter accepts the following options:
32625
32626 expr
32627 The expression which is evaluated for each frame to construct its
32628 timestamp.
32629
32630 The expression is evaluated through the eval API and can contain the
32631 following constants:
32632
32633 FRAME_RATE, FR
32634 frame rate, only defined for constant frame-rate video
32635
32636 PTS The presentation timestamp in input
32637
32638 N The count of the input frame for video or the number of consumed
32639 samples, not including the current frame for audio, starting from
32640 0.
32641
32642 NB_CONSUMED_SAMPLES
32643 The number of consumed samples, not including the current frame
32644 (only audio)
32645
32646 NB_SAMPLES, S
32647 The number of samples in the current frame (only audio)
32648
32649 SAMPLE_RATE, SR
32650 The audio sample rate.
32651
32652 STARTPTS
32653 The PTS of the first frame.
32654
32655 STARTT
32656 the time in seconds of the first frame
32657
32658 INTERLACED
32659 State whether the current frame is interlaced.
32660
32661 T the time in seconds of the current frame
32662
32663 POS original position in the file of the frame, or undefined if
32664 undefined for the current frame
32665
32666 PREV_INPTS
32667 The previous input PTS.
32668
32669 PREV_INT
32670 previous input time in seconds
32671
32672 PREV_OUTPTS
32673 The previous output PTS.
32674
32675 PREV_OUTT
32676 previous output time in seconds
32677
32678 RTCTIME
32679 The wallclock (RTC) time in microseconds. This is deprecated, use
32680 time(0) instead.
32681
32682 RTCSTART
32683 The wallclock (RTC) time at the start of the movie in microseconds.
32684
32685 TB The timebase of the input timestamps.
32686
32687 Examples
32688
32689 • Start counting PTS from zero
32690
32691 setpts=PTS-STARTPTS
32692
32693 • Apply fast motion effect:
32694
32695 setpts=0.5*PTS
32696
32697 • Apply slow motion effect:
32698
32699 setpts=2.0*PTS
32700
32701 • Set fixed rate of 25 frames per second:
32702
32703 setpts=N/(25*TB)
32704
32705 • Set fixed rate 25 fps with some jitter:
32706
32707 setpts='1/(25*TB) * (N + 0.05 * sin(N*2*PI/25))'
32708
32709 • Apply an offset of 10 seconds to the input PTS:
32710
32711 setpts=PTS+10/TB
32712
32713 • Generate timestamps from a "live source" and rebase onto the
32714 current timebase:
32715
32716 setpts='(RTCTIME - RTCSTART) / (TB * 1000000)'
32717
32718 • Generate timestamps by counting samples:
32719
32720 asetpts=N/SR/TB
32721
32722 setrange
32723 Force color range for the output video frame.
32724
32725 The "setrange" filter marks the color range property for the output
32726 frames. It does not change the input frame, but only sets the
32727 corresponding property, which affects how the frame is treated by
32728 following filters.
32729
32730 The filter accepts the following options:
32731
32732 range
32733 Available values are:
32734
32735 auto
32736 Keep the same color range property.
32737
32738 unspecified, unknown
32739 Set the color range as unspecified.
32740
32741 limited, tv, mpeg
32742 Set the color range as limited.
32743
32744 full, pc, jpeg
32745 Set the color range as full.
32746
32747 settb, asettb
32748 Set the timebase to use for the output frames timestamps. It is mainly
32749 useful for testing timebase configuration.
32750
32751 It accepts the following parameters:
32752
32753 expr, tb
32754 The expression which is evaluated into the output timebase.
32755
32756 The value for tb is an arithmetic expression representing a rational.
32757 The expression can contain the constants "AVTB" (the default timebase),
32758 "intb" (the input timebase) and "sr" (the sample rate, audio only).
32759 Default value is "intb".
32760
32761 Examples
32762
32763 • Set the timebase to 1/25:
32764
32765 settb=expr=1/25
32766
32767 • Set the timebase to 1/10:
32768
32769 settb=expr=0.1
32770
32771 • Set the timebase to 1001/1000:
32772
32773 settb=1+0.001
32774
32775 • Set the timebase to 2*intb:
32776
32777 settb=2*intb
32778
32779 • Set the default timebase value:
32780
32781 settb=AVTB
32782
32783 showcqt
32784 Convert input audio to a video output representing frequency spectrum
32785 logarithmically using Brown-Puckette constant Q transform algorithm
32786 with direct frequency domain coefficient calculation (but the transform
32787 itself is not really constant Q, instead the Q factor is actually
32788 variable/clamped), with musical tone scale, from E0 to D#10.
32789
32790 The filter accepts the following options:
32791
32792 size, s
32793 Specify the video size for the output. It must be even. For the
32794 syntax of this option, check the "Video size" section in the
32795 ffmpeg-utils manual. Default value is "1920x1080".
32796
32797 fps, rate, r
32798 Set the output frame rate. Default value is 25.
32799
32800 bar_h
32801 Set the bargraph height. It must be even. Default value is "-1"
32802 which computes the bargraph height automatically.
32803
32804 axis_h
32805 Set the axis height. It must be even. Default value is "-1" which
32806 computes the axis height automatically.
32807
32808 sono_h
32809 Set the sonogram height. It must be even. Default value is "-1"
32810 which computes the sonogram height automatically.
32811
32812 fullhd
32813 Set the fullhd resolution. This option is deprecated, use size, s
32814 instead. Default value is 1.
32815
32816 sono_v, volume
32817 Specify the sonogram volume expression. It can contain variables:
32818
32819 bar_v
32820 the bar_v evaluated expression
32821
32822 frequency, freq, f
32823 the frequency where it is evaluated
32824
32825 timeclamp, tc
32826 the value of timeclamp option
32827
32828 and functions:
32829
32830 a_weighting(f)
32831 A-weighting of equal loudness
32832
32833 b_weighting(f)
32834 B-weighting of equal loudness
32835
32836 c_weighting(f)
32837 C-weighting of equal loudness.
32838
32839 Default value is 16.
32840
32841 bar_v, volume2
32842 Specify the bargraph volume expression. It can contain variables:
32843
32844 sono_v
32845 the sono_v evaluated expression
32846
32847 frequency, freq, f
32848 the frequency where it is evaluated
32849
32850 timeclamp, tc
32851 the value of timeclamp option
32852
32853 and functions:
32854
32855 a_weighting(f)
32856 A-weighting of equal loudness
32857
32858 b_weighting(f)
32859 B-weighting of equal loudness
32860
32861 c_weighting(f)
32862 C-weighting of equal loudness.
32863
32864 Default value is "sono_v".
32865
32866 sono_g, gamma
32867 Specify the sonogram gamma. Lower gamma makes the spectrum more
32868 contrast, higher gamma makes the spectrum having more range.
32869 Default value is 3. Acceptable range is "[1, 7]".
32870
32871 bar_g, gamma2
32872 Specify the bargraph gamma. Default value is 1. Acceptable range is
32873 "[1, 7]".
32874
32875 bar_t
32876 Specify the bargraph transparency level. Lower value makes the
32877 bargraph sharper. Default value is 1. Acceptable range is "[0,
32878 1]".
32879
32880 timeclamp, tc
32881 Specify the transform timeclamp. At low frequency, there is trade-
32882 off between accuracy in time domain and frequency domain. If
32883 timeclamp is lower, event in time domain is represented more
32884 accurately (such as fast bass drum), otherwise event in frequency
32885 domain is represented more accurately (such as bass guitar).
32886 Acceptable range is "[0.002, 1]". Default value is 0.17.
32887
32888 attack
32889 Set attack time in seconds. The default is 0 (disabled). Otherwise,
32890 it limits future samples by applying asymmetric windowing in time
32891 domain, useful when low latency is required. Accepted range is "[0,
32892 1]".
32893
32894 basefreq
32895 Specify the transform base frequency. Default value is
32896 20.01523126408007475, which is frequency 50 cents below E0.
32897 Acceptable range is "[10, 100000]".
32898
32899 endfreq
32900 Specify the transform end frequency. Default value is
32901 20495.59681441799654, which is frequency 50 cents above D#10.
32902 Acceptable range is "[10, 100000]".
32903
32904 coeffclamp
32905 This option is deprecated and ignored.
32906
32907 tlength
32908 Specify the transform length in time domain. Use this option to
32909 control accuracy trade-off between time domain and frequency domain
32910 at every frequency sample. It can contain variables:
32911
32912 frequency, freq, f
32913 the frequency where it is evaluated
32914
32915 timeclamp, tc
32916 the value of timeclamp option.
32917
32918 Default value is "384*tc/(384+tc*f)".
32919
32920 count
32921 Specify the transform count for every video frame. Default value is
32922 6. Acceptable range is "[1, 30]".
32923
32924 fcount
32925 Specify the transform count for every single pixel. Default value
32926 is 0, which makes it computed automatically. Acceptable range is
32927 "[0, 10]".
32928
32929 fontfile
32930 Specify font file for use with freetype to draw the axis. If not
32931 specified, use embedded font. Note that drawing with font file or
32932 embedded font is not implemented with custom basefreq and endfreq,
32933 use axisfile option instead.
32934
32935 font
32936 Specify fontconfig pattern. This has lower priority than fontfile.
32937 The ":" in the pattern may be replaced by "|" to avoid unnecessary
32938 escaping.
32939
32940 fontcolor
32941 Specify font color expression. This is arithmetic expression that
32942 should return integer value 0xRRGGBB. It can contain variables:
32943
32944 frequency, freq, f
32945 the frequency where it is evaluated
32946
32947 timeclamp, tc
32948 the value of timeclamp option
32949
32950 and functions:
32951
32952 midi(f)
32953 midi number of frequency f, some midi numbers: E0(16), C1(24),
32954 C2(36), A4(69)
32955
32956 r(x), g(x), b(x)
32957 red, green, and blue value of intensity x.
32958
32959 Default value is "st(0, (midi(f)-59.5)/12); st(1,
32960 if(between(ld(0),0,1), 0.5-0.5*cos(2*PI*ld(0)), 0)); r(1-ld(1)) +
32961 b(ld(1))".
32962
32963 axisfile
32964 Specify image file to draw the axis. This option override fontfile
32965 and fontcolor option.
32966
32967 axis, text
32968 Enable/disable drawing text to the axis. If it is set to 0, drawing
32969 to the axis is disabled, ignoring fontfile and axisfile option.
32970 Default value is 1.
32971
32972 csp Set colorspace. The accepted values are:
32973
32974 unspecified
32975 Unspecified (default)
32976
32977 bt709
32978 BT.709
32979
32980 fcc FCC
32981
32982 bt470bg
32983 BT.470BG or BT.601-6 625
32984
32985 smpte170m
32986 SMPTE-170M or BT.601-6 525
32987
32988 smpte240m
32989 SMPTE-240M
32990
32991 bt2020ncl
32992 BT.2020 with non-constant luminance
32993
32994 cscheme
32995 Set spectrogram color scheme. This is list of floating point values
32996 with format "left_r|left_g|left_b|right_r|right_g|right_b". The
32997 default is "1|0.5|0|0|0.5|1".
32998
32999 Examples
33000
33001 • Playing audio while showing the spectrum:
33002
33003 ffplay -f lavfi 'amovie=a.mp3, asplit [a][out1]; [a] showcqt [out0]'
33004
33005 • Same as above, but with frame rate 30 fps:
33006
33007 ffplay -f lavfi 'amovie=a.mp3, asplit [a][out1]; [a] showcqt=fps=30:count=5 [out0]'
33008
33009 • Playing at 1280x720:
33010
33011 ffplay -f lavfi 'amovie=a.mp3, asplit [a][out1]; [a] showcqt=s=1280x720:count=4 [out0]'
33012
33013 • Disable sonogram display:
33014
33015 sono_h=0
33016
33017 • A1 and its harmonics: A1, A2, (near)E3, A3:
33018
33019 ffplay -f lavfi 'aevalsrc=0.1*sin(2*PI*55*t)+0.1*sin(4*PI*55*t)+0.1*sin(6*PI*55*t)+0.1*sin(8*PI*55*t),
33020 asplit[a][out1]; [a] showcqt [out0]'
33021
33022 • Same as above, but with more accuracy in frequency domain:
33023
33024 ffplay -f lavfi 'aevalsrc=0.1*sin(2*PI*55*t)+0.1*sin(4*PI*55*t)+0.1*sin(6*PI*55*t)+0.1*sin(8*PI*55*t),
33025 asplit[a][out1]; [a] showcqt=timeclamp=0.5 [out0]'
33026
33027 • Custom volume:
33028
33029 bar_v=10:sono_v=bar_v*a_weighting(f)
33030
33031 • Custom gamma, now spectrum is linear to the amplitude.
33032
33033 bar_g=2:sono_g=2
33034
33035 • Custom tlength equation:
33036
33037 tc=0.33:tlength='st(0,0.17); 384*tc / (384 / ld(0) + tc*f /(1-ld(0))) + 384*tc / (tc*f / ld(0) + 384 /(1-ld(0)))'
33038
33039 • Custom fontcolor and fontfile, C-note is colored green, others are
33040 colored blue:
33041
33042 fontcolor='if(mod(floor(midi(f)+0.5),12), 0x0000FF, g(1))':fontfile=myfont.ttf
33043
33044 • Custom font using fontconfig:
33045
33046 font='Courier New,Monospace,mono|bold'
33047
33048 • Custom frequency range with custom axis using image file:
33049
33050 axisfile=myaxis.png:basefreq=40:endfreq=10000
33051
33052 showfreqs
33053 Convert input audio to video output representing the audio power
33054 spectrum. Audio amplitude is on Y-axis while frequency is on X-axis.
33055
33056 The filter accepts the following options:
33057
33058 size, s
33059 Specify size of video. For the syntax of this option, check the
33060 "Video size" section in the ffmpeg-utils manual. Default is
33061 "1024x512".
33062
33063 mode
33064 Set display mode. This set how each frequency bin will be
33065 represented.
33066
33067 It accepts the following values:
33068
33069 line
33070 bar
33071 dot
33072
33073 Default is "bar".
33074
33075 ascale
33076 Set amplitude scale.
33077
33078 It accepts the following values:
33079
33080 lin Linear scale.
33081
33082 sqrt
33083 Square root scale.
33084
33085 cbrt
33086 Cubic root scale.
33087
33088 log Logarithmic scale.
33089
33090 Default is "log".
33091
33092 fscale
33093 Set frequency scale.
33094
33095 It accepts the following values:
33096
33097 lin Linear scale.
33098
33099 log Logarithmic scale.
33100
33101 rlog
33102 Reverse logarithmic scale.
33103
33104 Default is "lin".
33105
33106 win_size
33107 Set window size. Allowed range is from 16 to 65536.
33108
33109 Default is 2048
33110
33111 win_func
33112 Set windowing function.
33113
33114 It accepts the following values:
33115
33116 rect
33117 bartlett
33118 hanning
33119 hamming
33120 blackman
33121 welch
33122 flattop
33123 bharris
33124 bnuttall
33125 bhann
33126 sine
33127 nuttall
33128 lanczos
33129 gauss
33130 tukey
33131 dolph
33132 cauchy
33133 parzen
33134 poisson
33135 bohman
33136
33137 Default is "hanning".
33138
33139 overlap
33140 Set window overlap. In range "[0, 1]". Default is 1, which means
33141 optimal overlap for selected window function will be picked.
33142
33143 averaging
33144 Set time averaging. Setting this to 0 will display current maximal
33145 peaks. Default is 1, which means time averaging is disabled.
33146
33147 colors
33148 Specify list of colors separated by space or by '|' which will be
33149 used to draw channel frequencies. Unrecognized or missing colors
33150 will be replaced by white color.
33151
33152 cmode
33153 Set channel display mode.
33154
33155 It accepts the following values:
33156
33157 combined
33158 separate
33159
33160 Default is "combined".
33161
33162 minamp
33163 Set minimum amplitude used in "log" amplitude scaler.
33164
33165 data
33166 Set data display mode.
33167
33168 It accepts the following values:
33169
33170 magnitude
33171 phase
33172 delay
33173
33174 Default is "magnitude".
33175
33176 showspatial
33177 Convert stereo input audio to a video output, representing the spatial
33178 relationship between two channels.
33179
33180 The filter accepts the following options:
33181
33182 size, s
33183 Specify the video size for the output. For the syntax of this
33184 option, check the "Video size" section in the ffmpeg-utils manual.
33185 Default value is "512x512".
33186
33187 win_size
33188 Set window size. Allowed range is from 1024 to 65536. Default size
33189 is 4096.
33190
33191 win_func
33192 Set window function.
33193
33194 It accepts the following values:
33195
33196 rect
33197 bartlett
33198 hann
33199 hanning
33200 hamming
33201 blackman
33202 welch
33203 flattop
33204 bharris
33205 bnuttall
33206 bhann
33207 sine
33208 nuttall
33209 lanczos
33210 gauss
33211 tukey
33212 dolph
33213 cauchy
33214 parzen
33215 poisson
33216 bohman
33217
33218 Default value is "hann".
33219
33220 overlap
33221 Set ratio of overlap window. Default value is 0.5. When value is 1
33222 overlap is set to recommended size for specific window function
33223 currently used.
33224
33225 showspectrum
33226 Convert input audio to a video output, representing the audio frequency
33227 spectrum.
33228
33229 The filter accepts the following options:
33230
33231 size, s
33232 Specify the video size for the output. For the syntax of this
33233 option, check the "Video size" section in the ffmpeg-utils manual.
33234 Default value is "640x512".
33235
33236 slide
33237 Specify how the spectrum should slide along the window.
33238
33239 It accepts the following values:
33240
33241 replace
33242 the samples start again on the left when they reach the right
33243
33244 scroll
33245 the samples scroll from right to left
33246
33247 fullframe
33248 frames are only produced when the samples reach the right
33249
33250 rscroll
33251 the samples scroll from left to right
33252
33253 lreplace
33254 the samples start again on the right when they reach the left
33255
33256 Default value is "replace".
33257
33258 mode
33259 Specify display mode.
33260
33261 It accepts the following values:
33262
33263 combined
33264 all channels are displayed in the same row
33265
33266 separate
33267 all channels are displayed in separate rows
33268
33269 Default value is combined.
33270
33271 color
33272 Specify display color mode.
33273
33274 It accepts the following values:
33275
33276 channel
33277 each channel is displayed in a separate color
33278
33279 intensity
33280 each channel is displayed using the same color scheme
33281
33282 rainbow
33283 each channel is displayed using the rainbow color scheme
33284
33285 moreland
33286 each channel is displayed using the moreland color scheme
33287
33288 nebulae
33289 each channel is displayed using the nebulae color scheme
33290
33291 fire
33292 each channel is displayed using the fire color scheme
33293
33294 fiery
33295 each channel is displayed using the fiery color scheme
33296
33297 fruit
33298 each channel is displayed using the fruit color scheme
33299
33300 cool
33301 each channel is displayed using the cool color scheme
33302
33303 magma
33304 each channel is displayed using the magma color scheme
33305
33306 green
33307 each channel is displayed using the green color scheme
33308
33309 viridis
33310 each channel is displayed using the viridis color scheme
33311
33312 plasma
33313 each channel is displayed using the plasma color scheme
33314
33315 cividis
33316 each channel is displayed using the cividis color scheme
33317
33318 terrain
33319 each channel is displayed using the terrain color scheme
33320
33321 Default value is channel.
33322
33323 scale
33324 Specify scale used for calculating intensity color values.
33325
33326 It accepts the following values:
33327
33328 lin linear
33329
33330 sqrt
33331 square root, default
33332
33333 cbrt
33334 cubic root
33335
33336 log logarithmic
33337
33338 4thrt
33339 4th root
33340
33341 5thrt
33342 5th root
33343
33344 Default value is sqrt.
33345
33346 fscale
33347 Specify frequency scale.
33348
33349 It accepts the following values:
33350
33351 lin linear
33352
33353 log logarithmic
33354
33355 Default value is lin.
33356
33357 saturation
33358 Set saturation modifier for displayed colors. Negative values
33359 provide alternative color scheme. 0 is no saturation at all.
33360 Saturation must be in [-10.0, 10.0] range. Default value is 1.
33361
33362 win_func
33363 Set window function.
33364
33365 It accepts the following values:
33366
33367 rect
33368 bartlett
33369 hann
33370 hanning
33371 hamming
33372 blackman
33373 welch
33374 flattop
33375 bharris
33376 bnuttall
33377 bhann
33378 sine
33379 nuttall
33380 lanczos
33381 gauss
33382 tukey
33383 dolph
33384 cauchy
33385 parzen
33386 poisson
33387 bohman
33388
33389 Default value is "hann".
33390
33391 orientation
33392 Set orientation of time vs frequency axis. Can be "vertical" or
33393 "horizontal". Default is "vertical".
33394
33395 overlap
33396 Set ratio of overlap window. Default value is 0. When value is 1
33397 overlap is set to recommended size for specific window function
33398 currently used.
33399
33400 gain
33401 Set scale gain for calculating intensity color values. Default
33402 value is 1.
33403
33404 data
33405 Set which data to display. Can be "magnitude", default or "phase",
33406 or unwrapped phase: "uphase".
33407
33408 rotation
33409 Set color rotation, must be in [-1.0, 1.0] range. Default value is
33410 0.
33411
33412 start
33413 Set start frequency from which to display spectrogram. Default is
33414 0.
33415
33416 stop
33417 Set stop frequency to which to display spectrogram. Default is 0.
33418
33419 fps Set upper frame rate limit. Default is "auto", unlimited.
33420
33421 legend
33422 Draw time and frequency axes and legends. Default is disabled.
33423
33424 drange
33425 Set dynamic range used to calculate intensity color values. Default
33426 is 120 dBFS. Allowed range is from 10 to 200.
33427
33428 limit
33429 Set upper limit of input audio samples volume in dBFS. Default is 0
33430 dBFS. Allowed range is from -100 to 100.
33431
33432 The usage is very similar to the showwaves filter; see the examples in
33433 that section.
33434
33435 Examples
33436
33437 • Large window with logarithmic color scaling:
33438
33439 showspectrum=s=1280x480:scale=log
33440
33441 • Complete example for a colored and sliding spectrum per channel
33442 using ffplay:
33443
33444 ffplay -f lavfi 'amovie=input.mp3, asplit [a][out1];
33445 [a] showspectrum=mode=separate:color=intensity:slide=1:scale=cbrt [out0]'
33446
33447 showspectrumpic
33448 Convert input audio to a single video frame, representing the audio
33449 frequency spectrum.
33450
33451 The filter accepts the following options:
33452
33453 size, s
33454 Specify the video size for the output. For the syntax of this
33455 option, check the "Video size" section in the ffmpeg-utils manual.
33456 Default value is "4096x2048".
33457
33458 mode
33459 Specify display mode.
33460
33461 It accepts the following values:
33462
33463 combined
33464 all channels are displayed in the same row
33465
33466 separate
33467 all channels are displayed in separate rows
33468
33469 Default value is combined.
33470
33471 color
33472 Specify display color mode.
33473
33474 It accepts the following values:
33475
33476 channel
33477 each channel is displayed in a separate color
33478
33479 intensity
33480 each channel is displayed using the same color scheme
33481
33482 rainbow
33483 each channel is displayed using the rainbow color scheme
33484
33485 moreland
33486 each channel is displayed using the moreland color scheme
33487
33488 nebulae
33489 each channel is displayed using the nebulae color scheme
33490
33491 fire
33492 each channel is displayed using the fire color scheme
33493
33494 fiery
33495 each channel is displayed using the fiery color scheme
33496
33497 fruit
33498 each channel is displayed using the fruit color scheme
33499
33500 cool
33501 each channel is displayed using the cool color scheme
33502
33503 magma
33504 each channel is displayed using the magma color scheme
33505
33506 green
33507 each channel is displayed using the green color scheme
33508
33509 viridis
33510 each channel is displayed using the viridis color scheme
33511
33512 plasma
33513 each channel is displayed using the plasma color scheme
33514
33515 cividis
33516 each channel is displayed using the cividis color scheme
33517
33518 terrain
33519 each channel is displayed using the terrain color scheme
33520
33521 Default value is intensity.
33522
33523 scale
33524 Specify scale used for calculating intensity color values.
33525
33526 It accepts the following values:
33527
33528 lin linear
33529
33530 sqrt
33531 square root, default
33532
33533 cbrt
33534 cubic root
33535
33536 log logarithmic
33537
33538 4thrt
33539 4th root
33540
33541 5thrt
33542 5th root
33543
33544 Default value is log.
33545
33546 fscale
33547 Specify frequency scale.
33548
33549 It accepts the following values:
33550
33551 lin linear
33552
33553 log logarithmic
33554
33555 Default value is lin.
33556
33557 saturation
33558 Set saturation modifier for displayed colors. Negative values
33559 provide alternative color scheme. 0 is no saturation at all.
33560 Saturation must be in [-10.0, 10.0] range. Default value is 1.
33561
33562 win_func
33563 Set window function.
33564
33565 It accepts the following values:
33566
33567 rect
33568 bartlett
33569 hann
33570 hanning
33571 hamming
33572 blackman
33573 welch
33574 flattop
33575 bharris
33576 bnuttall
33577 bhann
33578 sine
33579 nuttall
33580 lanczos
33581 gauss
33582 tukey
33583 dolph
33584 cauchy
33585 parzen
33586 poisson
33587 bohman
33588
33589 Default value is "hann".
33590
33591 orientation
33592 Set orientation of time vs frequency axis. Can be "vertical" or
33593 "horizontal". Default is "vertical".
33594
33595 gain
33596 Set scale gain for calculating intensity color values. Default
33597 value is 1.
33598
33599 legend
33600 Draw time and frequency axes and legends. Default is enabled.
33601
33602 rotation
33603 Set color rotation, must be in [-1.0, 1.0] range. Default value is
33604 0.
33605
33606 start
33607 Set start frequency from which to display spectrogram. Default is
33608 0.
33609
33610 stop
33611 Set stop frequency to which to display spectrogram. Default is 0.
33612
33613 drange
33614 Set dynamic range used to calculate intensity color values. Default
33615 is 120 dBFS. Allowed range is from 10 to 200.
33616
33617 limit
33618 Set upper limit of input audio samples volume in dBFS. Default is 0
33619 dBFS. Allowed range is from -100 to 100.
33620
33621 Examples
33622
33623 • Extract an audio spectrogram of a whole audio track in a 1024x1024
33624 picture using ffmpeg:
33625
33626 ffmpeg -i audio.flac -lavfi showspectrumpic=s=1024x1024 spectrogram.png
33627
33628 showvolume
33629 Convert input audio volume to a video output.
33630
33631 The filter accepts the following options:
33632
33633 rate, r
33634 Set video rate.
33635
33636 b Set border width, allowed range is [0, 5]. Default is 1.
33637
33638 w Set channel width, allowed range is [80, 8192]. Default is 400.
33639
33640 h Set channel height, allowed range is [1, 900]. Default is 20.
33641
33642 f Set fade, allowed range is [0, 1]. Default is 0.95.
33643
33644 c Set volume color expression.
33645
33646 The expression can use the following variables:
33647
33648 VOLUME
33649 Current max volume of channel in dB.
33650
33651 PEAK
33652 Current peak.
33653
33654 CHANNEL
33655 Current channel number, starting from 0.
33656
33657 t If set, displays channel names. Default is enabled.
33658
33659 v If set, displays volume values. Default is enabled.
33660
33661 o Set orientation, can be horizontal: "h" or vertical: "v", default
33662 is "h".
33663
33664 s Set step size, allowed range is [0, 5]. Default is 0, which means
33665 step is disabled.
33666
33667 p Set background opacity, allowed range is [0, 1]. Default is 0.
33668
33669 m Set metering mode, can be peak: "p" or rms: "r", default is "p".
33670
33671 ds Set display scale, can be linear: "lin" or log: "log", default is
33672 "lin".
33673
33674 dm In second. If set to > 0., display a line for the max level in the
33675 previous seconds. default is disabled: 0.
33676
33677 dmc The color of the max line. Use when "dm" option is set to > 0.
33678 default is: "orange"
33679
33680 showwaves
33681 Convert input audio to a video output, representing the samples waves.
33682
33683 The filter accepts the following options:
33684
33685 size, s
33686 Specify the video size for the output. For the syntax of this
33687 option, check the "Video size" section in the ffmpeg-utils manual.
33688 Default value is "600x240".
33689
33690 mode
33691 Set display mode.
33692
33693 Available values are:
33694
33695 point
33696 Draw a point for each sample.
33697
33698 line
33699 Draw a vertical line for each sample.
33700
33701 p2p Draw a point for each sample and a line between them.
33702
33703 cline
33704 Draw a centered vertical line for each sample.
33705
33706 Default value is "point".
33707
33708 n Set the number of samples which are printed on the same column. A
33709 larger value will decrease the frame rate. Must be a positive
33710 integer. This option can be set only if the value for rate is not
33711 explicitly specified.
33712
33713 rate, r
33714 Set the (approximate) output frame rate. This is done by setting
33715 the option n. Default value is "25".
33716
33717 split_channels
33718 Set if channels should be drawn separately or overlap. Default
33719 value is 0.
33720
33721 colors
33722 Set colors separated by '|' which are going to be used for drawing
33723 of each channel.
33724
33725 scale
33726 Set amplitude scale.
33727
33728 Available values are:
33729
33730 lin Linear.
33731
33732 log Logarithmic.
33733
33734 sqrt
33735 Square root.
33736
33737 cbrt
33738 Cubic root.
33739
33740 Default is linear.
33741
33742 draw
33743 Set the draw mode. This is mostly useful to set for high n.
33744
33745 Available values are:
33746
33747 scale
33748 Scale pixel values for each drawn sample.
33749
33750 full
33751 Draw every sample directly.
33752
33753 Default value is "scale".
33754
33755 Examples
33756
33757 • Output the input file audio and the corresponding video
33758 representation at the same time:
33759
33760 amovie=a.mp3,asplit[out0],showwaves[out1]
33761
33762 • Create a synthetic signal and show it with showwaves, forcing a
33763 frame rate of 30 frames per second:
33764
33765 aevalsrc=sin(1*2*PI*t)*sin(880*2*PI*t):cos(2*PI*200*t),asplit[out0],showwaves=r=30[out1]
33766
33767 showwavespic
33768 Convert input audio to a single video frame, representing the samples
33769 waves.
33770
33771 The filter accepts the following options:
33772
33773 size, s
33774 Specify the video size for the output. For the syntax of this
33775 option, check the "Video size" section in the ffmpeg-utils manual.
33776 Default value is "600x240".
33777
33778 split_channels
33779 Set if channels should be drawn separately or overlap. Default
33780 value is 0.
33781
33782 colors
33783 Set colors separated by '|' which are going to be used for drawing
33784 of each channel.
33785
33786 scale
33787 Set amplitude scale.
33788
33789 Available values are:
33790
33791 lin Linear.
33792
33793 log Logarithmic.
33794
33795 sqrt
33796 Square root.
33797
33798 cbrt
33799 Cubic root.
33800
33801 Default is linear.
33802
33803 draw
33804 Set the draw mode.
33805
33806 Available values are:
33807
33808 scale
33809 Scale pixel values for each drawn sample.
33810
33811 full
33812 Draw every sample directly.
33813
33814 Default value is "scale".
33815
33816 filter
33817 Set the filter mode.
33818
33819 Available values are:
33820
33821 average
33822 Use average samples values for each drawn sample.
33823
33824 peak
33825 Use peak samples values for each drawn sample.
33826
33827 Default value is "average".
33828
33829 Examples
33830
33831 • Extract a channel split representation of the wave form of a whole
33832 audio track in a 1024x800 picture using ffmpeg:
33833
33834 ffmpeg -i audio.flac -lavfi showwavespic=split_channels=1:s=1024x800 waveform.png
33835
33836 sidedata, asidedata
33837 Delete frame side data, or select frames based on it.
33838
33839 This filter accepts the following options:
33840
33841 mode
33842 Set mode of operation of the filter.
33843
33844 Can be one of the following:
33845
33846 select
33847 Select every frame with side data of "type".
33848
33849 delete
33850 Delete side data of "type". If "type" is not set, delete all
33851 side data in the frame.
33852
33853 type
33854 Set side data type used with all modes. Must be set for "select"
33855 mode. For the list of frame side data types, refer to the
33856 "AVFrameSideDataType" enum in libavutil/frame.h. For example, to
33857 choose "AV_FRAME_DATA_PANSCAN" side data, you must specify
33858 "PANSCAN".
33859
33860 spectrumsynth
33861 Synthesize audio from 2 input video spectrums, first input stream
33862 represents magnitude across time and second represents phase across
33863 time. The filter will transform from frequency domain as displayed in
33864 videos back to time domain as presented in audio output.
33865
33866 This filter is primarily created for reversing processed showspectrum
33867 filter outputs, but can synthesize sound from other spectrograms too.
33868 But in such case results are going to be poor if the phase data is not
33869 available, because in such cases phase data need to be recreated,
33870 usually it's just recreated from random noise. For best results use
33871 gray only output ("channel" color mode in showspectrum filter) and
33872 "log" scale for magnitude video and "lin" scale for phase video. To
33873 produce phase, for 2nd video, use "data" option. Inputs videos should
33874 generally use "fullframe" slide mode as that saves resources needed for
33875 decoding video.
33876
33877 The filter accepts the following options:
33878
33879 sample_rate
33880 Specify sample rate of output audio, the sample rate of audio from
33881 which spectrum was generated may differ.
33882
33883 channels
33884 Set number of channels represented in input video spectrums.
33885
33886 scale
33887 Set scale which was used when generating magnitude input spectrum.
33888 Can be "lin" or "log". Default is "log".
33889
33890 slide
33891 Set slide which was used when generating inputs spectrums. Can be
33892 "replace", "scroll", "fullframe" or "rscroll". Default is
33893 "fullframe".
33894
33895 win_func
33896 Set window function used for resynthesis.
33897
33898 overlap
33899 Set window overlap. In range "[0, 1]". Default is 1, which means
33900 optimal overlap for selected window function will be picked.
33901
33902 orientation
33903 Set orientation of input videos. Can be "vertical" or "horizontal".
33904 Default is "vertical".
33905
33906 Examples
33907
33908 • First create magnitude and phase videos from audio, assuming audio
33909 is stereo with 44100 sample rate, then resynthesize videos back to
33910 audio with spectrumsynth:
33911
33912 ffmpeg -i input.flac -lavfi showspectrum=mode=separate:scale=log:overlap=0.875:color=channel:slide=fullframe:data=magnitude -an -c:v rawvideo magnitude.nut
33913 ffmpeg -i input.flac -lavfi showspectrum=mode=separate:scale=lin:overlap=0.875:color=channel:slide=fullframe:data=phase -an -c:v rawvideo phase.nut
33914 ffmpeg -i magnitude.nut -i phase.nut -lavfi spectrumsynth=channels=2:sample_rate=44100:win_func=hann:overlap=0.875:slide=fullframe output.flac
33915
33916 split, asplit
33917 Split input into several identical outputs.
33918
33919 "asplit" works with audio input, "split" with video.
33920
33921 The filter accepts a single parameter which specifies the number of
33922 outputs. If unspecified, it defaults to 2.
33923
33924 Examples
33925
33926 • Create two separate outputs from the same input:
33927
33928 [in] split [out0][out1]
33929
33930 • To create 3 or more outputs, you need to specify the number of
33931 outputs, like in:
33932
33933 [in] asplit=3 [out0][out1][out2]
33934
33935 • Create two separate outputs from the same input, one cropped and
33936 one padded:
33937
33938 [in] split [splitout1][splitout2];
33939 [splitout1] crop=100:100:0:0 [cropout];
33940 [splitout2] pad=200:200:100:100 [padout];
33941
33942 • Create 5 copies of the input audio with ffmpeg:
33943
33944 ffmpeg -i INPUT -filter_complex asplit=5 OUTPUT
33945
33946 zmq, azmq
33947 Receive commands sent through a libzmq client, and forward them to
33948 filters in the filtergraph.
33949
33950 "zmq" and "azmq" work as a pass-through filters. "zmq" must be inserted
33951 between two video filters, "azmq" between two audio filters. Both are
33952 capable to send messages to any filter type.
33953
33954 To enable these filters you need to install the libzmq library and
33955 headers and configure FFmpeg with "--enable-libzmq".
33956
33957 For more information about libzmq see: <http://www.zeromq.org/>
33958
33959 The "zmq" and "azmq" filters work as a libzmq server, which receives
33960 messages sent through a network interface defined by the bind_address
33961 (or the abbreviation "b") option. Default value of this option is
33962 tcp://localhost:5555. You may want to alter this value to your needs,
33963 but do not forget to escape any ':' signs (see filtergraph escaping).
33964
33965 The received message must be in the form:
33966
33967 <TARGET> <COMMAND> [<ARG>]
33968
33969 TARGET specifies the target of the command, usually the name of the
33970 filter class or a specific filter instance name. The default filter
33971 instance name uses the pattern Parsed_<filter_name>_<index>, but you
33972 can override this by using the filter_name@id syntax (see Filtergraph
33973 syntax).
33974
33975 COMMAND specifies the name of the command for the target filter.
33976
33977 ARG is optional and specifies the optional argument list for the given
33978 COMMAND.
33979
33980 Upon reception, the message is processed and the corresponding command
33981 is injected into the filtergraph. Depending on the result, the filter
33982 will send a reply to the client, adopting the format:
33983
33984 <ERROR_CODE> <ERROR_REASON>
33985 <MESSAGE>
33986
33987 MESSAGE is optional.
33988
33989 Examples
33990
33991 Look at tools/zmqsend for an example of a zmq client which can be used
33992 to send commands processed by these filters.
33993
33994 Consider the following filtergraph generated by ffplay. In this
33995 example the last overlay filter has an instance name. All other filters
33996 will have default instance names.
33997
33998 ffplay -dumpgraph 1 -f lavfi "
33999 color=s=100x100:c=red [l];
34000 color=s=100x100:c=blue [r];
34001 nullsrc=s=200x100, zmq [bg];
34002 [bg][l] overlay [bg+l];
34003 [bg+l][r] overlay@my=x=100 "
34004
34005 To change the color of the left side of the video, the following
34006 command can be used:
34007
34008 echo Parsed_color_0 c yellow | tools/zmqsend
34009
34010 To change the right side:
34011
34012 echo Parsed_color_1 c pink | tools/zmqsend
34013
34014 To change the position of the right side:
34015
34016 echo overlay@my x 150 | tools/zmqsend
34017
34019 Below is a description of the currently available multimedia sources.
34020
34021 amovie
34022 This is the same as movie source, except it selects an audio stream by
34023 default.
34024
34025 movie
34026 Read audio and/or video stream(s) from a movie container.
34027
34028 It accepts the following parameters:
34029
34030 filename
34031 The name of the resource to read (not necessarily a file; it can
34032 also be a device or a stream accessed through some protocol).
34033
34034 format_name, f
34035 Specifies the format assumed for the movie to read, and can be
34036 either the name of a container or an input device. If not
34037 specified, the format is guessed from movie_name or by probing.
34038
34039 seek_point, sp
34040 Specifies the seek point in seconds. The frames will be output
34041 starting from this seek point. The parameter is evaluated with
34042 "av_strtod", so the numerical value may be suffixed by an IS
34043 postfix. The default value is "0".
34044
34045 streams, s
34046 Specifies the streams to read. Several streams can be specified,
34047 separated by "+". The source will then have as many outputs, in the
34048 same order. The syntax is explained in the "Stream specifiers"
34049 section in the ffmpeg manual. Two special names, "dv" and "da"
34050 specify respectively the default (best suited) video and audio
34051 stream. Default is "dv", or "da" if the filter is called as
34052 "amovie".
34053
34054 stream_index, si
34055 Specifies the index of the video stream to read. If the value is
34056 -1, the most suitable video stream will be automatically selected.
34057 The default value is "-1". Deprecated. If the filter is called
34058 "amovie", it will select audio instead of video.
34059
34060 loop
34061 Specifies how many times to read the stream in sequence. If the
34062 value is 0, the stream will be looped infinitely. Default value is
34063 "1".
34064
34065 Note that when the movie is looped the source timestamps are not
34066 changed, so it will generate non monotonically increasing
34067 timestamps.
34068
34069 discontinuity
34070 Specifies the time difference between frames above which the point
34071 is considered a timestamp discontinuity which is removed by
34072 adjusting the later timestamps.
34073
34074 dec_threads
34075 Specifies the number of threads for decoding
34076
34077 format_opts
34078 Specify format options for the opened file. Format options can be
34079 specified as a list of key=value pairs separated by ':'. The
34080 following example shows how to add protocol_whitelist and
34081 protocol_blacklist options:
34082
34083 ffplay -f lavfi
34084 "movie=filename='1.sdp':format_opts='protocol_whitelist=file,rtp,udp\:protocol_blacklist=http'"
34085
34086 It allows overlaying a second video on top of the main input of a
34087 filtergraph, as shown in this graph:
34088
34089 input -----------> deltapts0 --> overlay --> output
34090 ^
34091 |
34092 movie --> scale--> deltapts1 -------+
34093
34094 Examples
34095
34096 • Skip 3.2 seconds from the start of the AVI file in.avi, and overlay
34097 it on top of the input labelled "in":
34098
34099 movie=in.avi:seek_point=3.2, scale=180:-1, setpts=PTS-STARTPTS [over];
34100 [in] setpts=PTS-STARTPTS [main];
34101 [main][over] overlay=16:16 [out]
34102
34103 • Read from a video4linux2 device, and overlay it on top of the input
34104 labelled "in":
34105
34106 movie=/dev/video0:f=video4linux2, scale=180:-1, setpts=PTS-STARTPTS [over];
34107 [in] setpts=PTS-STARTPTS [main];
34108 [main][over] overlay=16:16 [out]
34109
34110 • Read the first video stream and the audio stream with id 0x81 from
34111 dvd.vob; the video is connected to the pad named "video" and the
34112 audio is connected to the pad named "audio":
34113
34114 movie=dvd.vob:s=v:0+#0x81 [video] [audio]
34115
34116 Commands
34117
34118 Both movie and amovie support the following commands:
34119
34120 seek
34121 Perform seek using "av_seek_frame". The syntax is: seek
34122 stream_index|timestamp|flags
34123
34124 • stream_index: If stream_index is -1, a default stream is
34125 selected, and timestamp is automatically converted from
34126 AV_TIME_BASE units to the stream specific time_base.
34127
34128 • timestamp: Timestamp in AVStream.time_base units or, if no
34129 stream is specified, in AV_TIME_BASE units.
34130
34131 • flags: Flags which select direction and seeking mode.
34132
34133 get_duration
34134 Get movie duration in AV_TIME_BASE units.
34135
34137 FFmpeg can be hooked up with a number of external libraries to add
34138 support for more formats. None of them are used by default, their use
34139 has to be explicitly requested by passing the appropriate flags to
34140 ./configure.
34141
34142 Alliance for Open Media (AOM)
34143 FFmpeg can make use of the AOM library for AV1 decoding and encoding.
34144
34145 Go to <http://aomedia.org/> and follow the instructions for installing
34146 the library. Then pass "--enable-libaom" to configure to enable it.
34147
34148 AMD AMF/VCE
34149 FFmpeg can use the AMD Advanced Media Framework library for accelerated
34150 H.264 and HEVC(only windows) encoding on hardware with Video Coding
34151 Engine (VCE).
34152
34153 To enable support you must obtain the AMF framework header
34154 files(version 1.4.9+) from
34155 <https://github.com/GPUOpen-LibrariesAndSDKs/AMF.git>.
34156
34157 Create an "AMF/" directory in the system include path. Copy the
34158 contents of "AMF/amf/public/include/" into that directory. Then
34159 configure FFmpeg with "--enable-amf".
34160
34161 Initialization of amf encoder occurs in this order: 1) trying to
34162 initialize through dx11(only windows) 2) trying to initialize through
34163 dx9(only windows) 3) trying to initialize through vulkan
34164
34165 To use h.264(AMD VCE) encoder on linux amdgru-pro version 19.20+ and
34166 amf-amdgpu-pro package(amdgru-pro contains, but does not install
34167 automatically) are required.
34168
34169 This driver can be installed using amdgpu-pro-install script in
34170 official amd driver archive.
34171
34172 AviSynth
34173 FFmpeg can read AviSynth scripts as input. To enable support, pass
34174 "--enable-avisynth" to configure after installing the headers provided
34175 by <https://github.com/AviSynth/AviSynthPlus>. AviSynth+ can be
34176 configured to install only the headers by either passing
34177 "-DHEADERS_ONLY:bool=on" to the normal CMake-based build system, or by
34178 using the supplied "GNUmakefile".
34179
34180 For Windows, supported AviSynth variants are <http://avisynth.nl> for
34181 32-bit builds and <http://avisynth.nl/index.php/AviSynth+> for 32-bit
34182 and 64-bit builds.
34183
34184 For Linux, macOS, and BSD, the only supported AviSynth variant is
34185 <https://github.com/AviSynth/AviSynthPlus>, starting with version 3.5.
34186
34187 In 2016, AviSynth+ added support for building with GCC. However,
34188 due to the eccentricities of Windows' calling conventions, 32-bit
34189 GCC builds of AviSynth+ are not compatible with typical 32-bit
34190 builds of FFmpeg.
34191
34192 By default, FFmpeg assumes compatibility with 32-bit MSVC builds of
34193 AviSynth+ since that is the most widely-used and entrenched build
34194 configuration. Users can override this and enable support for
34195 32-bit GCC builds of AviSynth+ by passing "-DAVSC_WIN32_GCC32" to
34196 "--extra-cflags" when configuring FFmpeg.
34197
34198 64-bit builds of FFmpeg are not affected, and can use either MSVC
34199 or GCC builds of AviSynth+ without any special flags.
34200
34201 AviSynth(+) is loaded dynamically. Distributors can build FFmpeg
34202 with "--enable-avisynth", and the binaries will work regardless of
34203 the end user having AviSynth installed. If/when an end user would
34204 like to use AviSynth scripts, then they can install AviSynth(+) and
34205 FFmpeg will be able to find and use it to open scripts.
34206
34207 Chromaprint
34208 FFmpeg can make use of the Chromaprint library for generating audio
34209 fingerprints. Pass "--enable-chromaprint" to configure to enable it.
34210 See <https://acoustid.org/chromaprint>.
34211
34212 codec2
34213 FFmpeg can make use of the codec2 library for codec2 decoding and
34214 encoding. There is currently no native decoder, so libcodec2 must be
34215 used for decoding.
34216
34217 Go to <http://freedv.org/>, download "Codec 2 source archive". Build
34218 and install using CMake. Debian users can install the libcodec2-dev
34219 package instead. Once libcodec2 is installed you can pass
34220 "--enable-libcodec2" to configure to enable it.
34221
34222 The easiest way to use codec2 is with .c2 files, since they contain the
34223 mode information required for decoding. To encode such a file, use a
34224 .c2 file extension and give the libcodec2 encoder the -mode option:
34225 "ffmpeg -i input.wav -mode 700C output.c2". Playback is as simple as
34226 "ffplay output.c2". For a list of supported modes, run "ffmpeg -h
34227 encoder=libcodec2". Raw codec2 files are also supported. To make
34228 sense of them the mode in use needs to be specified as a format option:
34229 "ffmpeg -f codec2raw -mode 1300 -i input.raw output.wav".
34230
34231 dav1d
34232 FFmpeg can make use of the dav1d library for AV1 video decoding.
34233
34234 Go to <https://code.videolan.org/videolan/dav1d> and follow the
34235 instructions for installing the library. Then pass "--enable-libdav1d"
34236 to configure to enable it.
34237
34238 davs2
34239 FFmpeg can make use of the davs2 library for AVS2-P2/IEEE1857.4 video
34240 decoding.
34241
34242 Go to <https://github.com/pkuvcl/davs2> and follow the instructions for
34243 installing the library. Then pass "--enable-libdavs2" to configure to
34244 enable it.
34245
34246 libdavs2 is under the GNU Public License Version 2 or later (see
34247 <http://www.gnu.org/licenses/old-licenses/gpl-2.0.html> for
34248 details), you must upgrade FFmpeg's license to GPL in order to use
34249 it.
34250
34251 uavs3d
34252 FFmpeg can make use of the uavs3d library for AVS3-P2/IEEE1857.10 video
34253 decoding.
34254
34255 Go to <https://github.com/uavs3/uavs3d> and follow the instructions for
34256 installing the library. Then pass "--enable-libuavs3d" to configure to
34257 enable it.
34258
34259 Game Music Emu
34260 FFmpeg can make use of the Game Music Emu library to read audio from
34261 supported video game music file formats. Pass "--enable-libgme" to
34262 configure to enable it. See
34263 <https://bitbucket.org/mpyne/game-music-emu/overview>.
34264
34265 Intel QuickSync Video
34266 FFmpeg can use Intel QuickSync Video (QSV) for accelerated decoding and
34267 encoding of multiple codecs. To use QSV, FFmpeg must be linked against
34268 the "libmfx" dispatcher, which loads the actual decoding libraries.
34269
34270 The dispatcher is open source and can be downloaded from
34271 <https://github.com/lu-zero/mfx_dispatch.git>. FFmpeg needs to be
34272 configured with the "--enable-libmfx" option and "pkg-config" needs to
34273 be able to locate the dispatcher's ".pc" files.
34274
34275 Kvazaar
34276 FFmpeg can make use of the Kvazaar library for HEVC encoding.
34277
34278 Go to <https://github.com/ultravideo/kvazaar> and follow the
34279 instructions for installing the library. Then pass
34280 "--enable-libkvazaar" to configure to enable it.
34281
34282 LAME
34283 FFmpeg can make use of the LAME library for MP3 encoding.
34284
34285 Go to <http://lame.sourceforge.net/> and follow the instructions for
34286 installing the library. Then pass "--enable-libmp3lame" to configure
34287 to enable it.
34288
34289 libilbc
34290 iLBC is a narrowband speech codec that has been made freely available
34291 by Google as part of the WebRTC project. libilbc is a packaging
34292 friendly copy of the iLBC codec. FFmpeg can make use of the libilbc
34293 library for iLBC decoding and encoding.
34294
34295 Go to <https://github.com/TimothyGu/libilbc> and follow the
34296 instructions for installing the library. Then pass "--enable-libilbc"
34297 to configure to enable it.
34298
34299 libvpx
34300 FFmpeg can make use of the libvpx library for VP8/VP9 decoding and
34301 encoding.
34302
34303 Go to <http://www.webmproject.org/> and follow the instructions for
34304 installing the library. Then pass "--enable-libvpx" to configure to
34305 enable it.
34306
34307 ModPlug
34308 FFmpeg can make use of this library, originating in Modplug-XMMS, to
34309 read from MOD-like music files. See
34310 <https://github.com/Konstanty/libmodplug>. Pass "--enable-libmodplug"
34311 to configure to enable it.
34312
34313 OpenCORE, VisualOn, and Fraunhofer libraries
34314 Spun off Google Android sources, OpenCore, VisualOn and Fraunhofer
34315 libraries provide encoders for a number of audio codecs.
34316
34317 OpenCORE and VisualOn libraries are under the Apache License 2.0
34318 (see <http://www.apache.org/licenses/LICENSE-2.0> for details),
34319 which is incompatible to the LGPL version 2.1 and GPL version 2.
34320 You have to upgrade FFmpeg's license to LGPL version 3 (or if you
34321 have enabled GPL components, GPL version 3) by passing
34322 "--enable-version3" to configure in order to use it.
34323
34324 The license of the Fraunhofer AAC library is incompatible with the
34325 GPL. Therefore, for GPL builds, you have to pass
34326 "--enable-nonfree" to configure in order to use it. To the best of
34327 our knowledge, it is compatible with the LGPL.
34328
34329 OpenCORE AMR
34330
34331 FFmpeg can make use of the OpenCORE libraries for AMR-NB
34332 decoding/encoding and AMR-WB decoding.
34333
34334 Go to <http://sourceforge.net/projects/opencore-amr/> and follow the
34335 instructions for installing the libraries. Then pass
34336 "--enable-libopencore-amrnb" and/or "--enable-libopencore-amrwb" to
34337 configure to enable them.
34338
34339 VisualOn AMR-WB encoder library
34340
34341 FFmpeg can make use of the VisualOn AMR-WBenc library for AMR-WB
34342 encoding.
34343
34344 Go to <http://sourceforge.net/projects/opencore-amr/> and follow the
34345 instructions for installing the library. Then pass
34346 "--enable-libvo-amrwbenc" to configure to enable it.
34347
34348 Fraunhofer AAC library
34349
34350 FFmpeg can make use of the Fraunhofer AAC library for AAC decoding &
34351 encoding.
34352
34353 Go to <http://sourceforge.net/projects/opencore-amr/> and follow the
34354 instructions for installing the library. Then pass
34355 "--enable-libfdk-aac" to configure to enable it.
34356
34357 OpenH264
34358 FFmpeg can make use of the OpenH264 library for H.264 decoding and
34359 encoding.
34360
34361 Go to <http://www.openh264.org/> and follow the instructions for
34362 installing the library. Then pass "--enable-libopenh264" to configure
34363 to enable it.
34364
34365 For decoding, this library is much more limited than the built-in
34366 decoder in libavcodec; currently, this library lacks support for
34367 decoding B-frames and some other main/high profile features. (It
34368 currently only supports constrained baseline profile and CABAC.) Using
34369 it is mostly useful for testing and for taking advantage of Cisco's
34370 patent portfolio license
34371 (<http://www.openh264.org/BINARY_LICENSE.txt>).
34372
34373 OpenJPEG
34374 FFmpeg can use the OpenJPEG libraries for decoding/encoding J2K videos.
34375 Go to <http://www.openjpeg.org/> to get the libraries and follow the
34376 installation instructions. To enable using OpenJPEG in FFmpeg, pass
34377 "--enable-libopenjpeg" to ./configure.
34378
34379 rav1e
34380 FFmpeg can make use of rav1e (Rust AV1 Encoder) via its C bindings to
34381 encode videos. Go to <https://github.com/xiph/rav1e/> and follow the
34382 instructions to build the C library. To enable using rav1e in FFmpeg,
34383 pass "--enable-librav1e" to ./configure.
34384
34385 SVT-AV1
34386 FFmpeg can make use of the Scalable Video Technology for AV1 library
34387 for AV1 encoding.
34388
34389 Go to <https://gitlab.com/AOMediaCodec/SVT-AV1/> and follow the
34390 instructions for installing the library. Then pass "--enable-libsvtav1"
34391 to configure to enable it.
34392
34393 TwoLAME
34394 FFmpeg can make use of the TwoLAME library for MP2 encoding.
34395
34396 Go to <http://www.twolame.org/> and follow the instructions for
34397 installing the library. Then pass "--enable-libtwolame" to configure
34398 to enable it.
34399
34400 VapourSynth
34401 FFmpeg can read VapourSynth scripts as input. To enable support, pass
34402 "--enable-vapoursynth" to configure. Vapoursynth is detected via
34403 "pkg-config". Versions 42 or greater supported. See
34404 <http://www.vapoursynth.com/>.
34405
34406 Due to security concerns, Vapoursynth scripts will not be autodetected
34407 so the input format has to be forced. For ff* CLI tools, add "-f
34408 vapoursynth" before the input "-i yourscript.vpy".
34409
34410 x264
34411 FFmpeg can make use of the x264 library for H.264 encoding.
34412
34413 Go to <http://www.videolan.org/developers/x264.html> and follow the
34414 instructions for installing the library. Then pass "--enable-libx264"
34415 to configure to enable it.
34416
34417 x264 is under the GNU Public License Version 2 or later (see
34418 <http://www.gnu.org/licenses/old-licenses/gpl-2.0.html> for
34419 details), you must upgrade FFmpeg's license to GPL in order to use
34420 it.
34421
34422 x265
34423 FFmpeg can make use of the x265 library for HEVC encoding.
34424
34425 Go to <http://x265.org/developers.html> and follow the instructions for
34426 installing the library. Then pass "--enable-libx265" to configure to
34427 enable it.
34428
34429 x265 is under the GNU Public License Version 2 or later (see
34430 <http://www.gnu.org/licenses/old-licenses/gpl-2.0.html> for
34431 details), you must upgrade FFmpeg's license to GPL in order to use
34432 it.
34433
34434 xavs
34435 FFmpeg can make use of the xavs library for AVS encoding.
34436
34437 Go to <http://xavs.sf.net/> and follow the instructions for installing
34438 the library. Then pass "--enable-libxavs" to configure to enable it.
34439
34440 xavs2
34441 FFmpeg can make use of the xavs2 library for AVS2-P2/IEEE1857.4 video
34442 encoding.
34443
34444 Go to <https://github.com/pkuvcl/xavs2> and follow the instructions for
34445 installing the library. Then pass "--enable-libxavs2" to configure to
34446 enable it.
34447
34448 libxavs2 is under the GNU Public License Version 2 or later (see
34449 <http://www.gnu.org/licenses/old-licenses/gpl-2.0.html> for
34450 details), you must upgrade FFmpeg's license to GPL in order to use
34451 it.
34452
34453 ZVBI
34454 ZVBI is a VBI decoding library which can be used by FFmpeg to decode
34455 DVB teletext pages and DVB teletext subtitles.
34456
34457 Go to <http://sourceforge.net/projects/zapping/> and follow the
34458 instructions for installing the library. Then pass "--enable-libzvbi"
34459 to configure to enable it.
34460
34462 You can use the "-formats" and "-codecs" options to have an exhaustive
34463 list.
34464
34465 File Formats
34466 FFmpeg supports the following file formats through the "libavformat"
34467 library:
34468
34469 Name : Encoding @tab Decoding @tab Comments
34470 3dostr : @tab X
34471 4xm : @tab X
34472 @tab 4X Technologies format, used in some games.
34473
34474 8088flex TMV : @tab X
34475 AAX : @tab X
34476 @tab Audible Enhanced Audio format, used in audiobooks.
34477
34478 AA : @tab X
34479 @tab Audible Format 2, 3, and 4, used in audiobooks.
34480
34481 ACT Voice : @tab X
34482 @tab contains G.729 audio
34483
34484 Adobe Filmstrip : X @tab X
34485 Audio IFF (AIFF) : X @tab X
34486 American Laser Games MM : @tab X
34487 @tab Multimedia format used in games like Mad Dog McCree.
34488
34489 3GPP AMR : X @tab X
34490 Amazing Studio Packed Animation File : @tab X
34491 @tab Multimedia format used in game Heart Of Darkness.
34492
34493 Apple HTTP Live Streaming : @tab X
34494 Artworx Data Format : @tab X
34495 Interplay ACM : @tab X
34496 @tab Audio only format used in some Interplay games.
34497
34498 ADP : @tab X
34499 @tab Audio format used on the Nintendo Gamecube.
34500
34501 AFC : @tab X
34502 @tab Audio format used on the Nintendo Gamecube.
34503
34504 ADS/SS2 : @tab X
34505 @tab Audio format used on the PS2.
34506
34507 APNG : X @tab X
34508 ASF : X @tab X
34509 @tab Advanced / Active Streaming Format.
34510
34511 AST : X @tab X
34512 @tab Audio format used on the Nintendo Wii.
34513
34514 AVI : X @tab X
34515 AviSynth : @tab X
34516 AVR : @tab X
34517 @tab Audio format used on Mac.
34518
34519 AVS : @tab X
34520 @tab Multimedia format used by the Creature Shock game.
34521
34522 Beam Software SIFF : @tab X
34523 @tab Audio and video format used in some games by Beam Software.
34524
34525 Bethesda Softworks VID : @tab X
34526 @tab Used in some games from Bethesda Softworks.
34527
34528 Binary text : @tab X
34529 Bink : @tab X
34530 @tab Multimedia format used by many games.
34531
34532 Bink Audio : @tab X
34533 @tab Audio only multimedia format used by some games.
34534
34535 Bitmap Brothers JV : @tab X
34536 @tab Used in Z and Z95 games.
34537
34538 BRP : @tab X
34539 @tab Argonaut Games format.
34540
34541 Brute Force & Ignorance : @tab X
34542 @tab Used in the game Flash Traffic: City of Angels.
34543
34544 BFSTM : @tab X
34545 @tab Audio format used on the Nintendo WiiU (based on BRSTM).
34546
34547 BRSTM : @tab X
34548 @tab Audio format used on the Nintendo Wii.
34549
34550 BW64 : @tab X
34551 @tab Broadcast Wave 64bit.
34552
34553 BWF : X @tab X
34554 codec2 (raw) : X @tab X
34555 @tab Must be given -mode format option to decode correctly.
34556
34557 codec2 (.c2 files) : X @tab X
34558 @tab Contains header with version and mode info, simplifying playback.
34559
34560 CRI ADX : X @tab X
34561 @tab Audio-only format used in console video games.
34562
34563 CRI AIX : @tab X
34564 CRI HCA : @tab X
34565 @tab Audio-only format used in console video games.
34566
34567 Discworld II BMV : @tab X
34568 Interplay C93 : @tab X
34569 @tab Used in the game Cyberia from Interplay.
34570
34571 Delphine Software International CIN : @tab X
34572 @tab Multimedia format used by Delphine Software games.
34573
34574 Digital Speech Standard (DSS) : @tab X
34575 CD+G : @tab X
34576 @tab Video format used by CD+G karaoke disks
34577
34578 Phantom Cine : @tab X
34579 Commodore CDXL : @tab X
34580 @tab Amiga CD video format
34581
34582 Core Audio Format : X @tab X
34583 @tab Apple Core Audio Format
34584
34585 CRC testing format : X @tab
34586 Creative Voice : X @tab X
34587 @tab Created for the Sound Blaster Pro.
34588
34589 CRYO APC : @tab X
34590 @tab Audio format used in some games by CRYO Interactive Entertainment.
34591
34592 D-Cinema audio : X @tab X
34593 Deluxe Paint Animation : @tab X
34594 DCSTR : @tab X
34595 DFA : @tab X
34596 @tab This format is used in Chronomaster game
34597
34598 DirectDraw Surface : @tab X
34599 DSD Stream File (DSF) : @tab X
34600 DV video : X @tab X
34601 DXA : @tab X
34602 @tab This format is used in the non-Windows version of the Feeble Files
34603 game and different game cutscenes repacked for use with ScummVM.
34604
34605 Electronic Arts cdata : @tab X
34606 Electronic Arts Multimedia : @tab X
34607 @tab Used in various EA games; files have extensions like WVE and UV2.
34608
34609 Ensoniq Paris Audio File : @tab X
34610 FFM (FFserver live feed) : X @tab X
34611 Flash (SWF) : X @tab X
34612 Flash 9 (AVM2) : X @tab X
34613 @tab Only embedded audio is decoded.
34614
34615 FLI/FLC/FLX animation : @tab X
34616 @tab .fli/.flc files
34617
34618 Flash Video (FLV) : X @tab X
34619 @tab Macromedia Flash video files
34620
34621 framecrc testing format : X @tab
34622 FunCom ISS : @tab X
34623 @tab Audio format used in various games from FunCom like The Longest Journey.
34624
34625 G.723.1 : X @tab X
34626 G.726 : @tab X @tab Both left- and right-
34627 justified.
34628 G.729 BIT : X @tab X
34629 G.729 raw : @tab X
34630 GENH : @tab X
34631 @tab Audio format for various games.
34632
34633 GIF Animation : X @tab X
34634 GXF : X @tab X
34635 @tab General eXchange Format SMPTE 360M, used by Thomson Grass Valley
34636 playout servers.
34637
34638 HNM : @tab X
34639 @tab Only version 4 supported, used in some games from Cryo Interactive
34640
34641 iCEDraw File : @tab X
34642 ICO : X @tab X
34643 @tab Microsoft Windows ICO
34644
34645 id Quake II CIN video : @tab X
34646 id RoQ : X @tab X
34647 @tab Used in Quake III, Jedi Knight 2 and other computer games.
34648
34649 IEC61937 encapsulation : X @tab X
34650 IFF : @tab X
34651 @tab Interchange File Format
34652
34653 IFV : @tab X
34654 @tab A format used by some old CCTV DVRs.
34655
34656 iLBC : X @tab X
34657 Interplay MVE : @tab X
34658 @tab Format used in various Interplay computer games.
34659
34660 Iterated Systems ClearVideo : @tab X
34661 @tab I-frames only
34662
34663 IV8 : @tab X
34664 @tab A format generated by IndigoVision 8000 video server.
34665
34666 IVF (On2) : X @tab X
34667 @tab A format used by libvpx
34668
34669 Internet Video Recording : @tab X
34670 IRCAM : X @tab X
34671 LATM : X @tab X
34672 LMLM4 : @tab X
34673 @tab Used by Linux Media Labs MPEG-4 PCI boards
34674
34675 LOAS : @tab X
34676 @tab contains LATM multiplexed AAC audio
34677
34678 LRC : X @tab X
34679 LVF : @tab X
34680 LXF : @tab X
34681 @tab VR native stream format, used by Leitch/Harris' video servers.
34682
34683 Magic Lantern Video (MLV) : @tab X
34684 Matroska : X @tab X
34685 Matroska audio : X @tab
34686 FFmpeg metadata : X @tab X
34687 @tab Metadata in text format.
34688
34689 MAXIS XA : @tab X
34690 @tab Used in Sim City 3000; file extension .xa.
34691
34692 MCA : @tab X
34693 @tab Used in some games from Capcom; file extension .mca.
34694
34695 MD Studio : @tab X
34696 Metal Gear Solid: The Twin Snakes : @tab X
34697 Megalux Frame : @tab X
34698 @tab Used by Megalux Ultimate Paint
34699
34700 Mobotix .mxg : @tab X
34701 Monkey's Audio : @tab X
34702 Motion Pixels MVI : @tab X
34703 MOV/QuickTime/MP4 : X @tab X
34704 @tab 3GP, 3GP2, PSP, iPod variants supported
34705
34706 MP2 : X @tab X
34707 MP3 : X @tab X
34708 MPEG-1 System : X @tab X
34709 @tab muxed audio and video, VCD format supported
34710
34711 MPEG-PS (program stream) : X @tab X
34712 @tab also known as C<VOB> file, SVCD and DVD format supported
34713
34714 MPEG-TS (transport stream) : X @tab X
34715 @tab also known as DVB Transport Stream
34716
34717 MPEG-4 : X @tab X
34718 @tab MPEG-4 is a variant of QuickTime.
34719
34720 MSF : @tab X
34721 @tab Audio format used on the PS3.
34722
34723 Mirillis FIC video : @tab X
34724 @tab No cursor rendering.
34725
34726 MIDI Sample Dump Standard : @tab X
34727 MIME multipart JPEG : X @tab
34728 MSN TCP webcam : @tab X
34729 @tab Used by MSN Messenger webcam streams.
34730
34731 MTV : @tab X
34732 Musepack : @tab X
34733 Musepack SV8 : @tab X
34734 Material eXchange Format (MXF) : X @tab X
34735 @tab SMPTE 377M, used by D-Cinema, broadcast industry.
34736
34737 Material eXchange Format (MXF), D-10 Mapping : X @tab X
34738 @tab SMPTE 386M, D-10/IMX Mapping.
34739
34740 NC camera feed : @tab X
34741 @tab NC (AVIP NC4600) camera streams
34742
34743 NIST SPeech HEader REsources : @tab X
34744 Computerized Speech Lab NSP : @tab X
34745 NTT TwinVQ (VQF) : @tab X
34746 @tab Nippon Telegraph and Telephone Corporation TwinVQ.
34747
34748 Nullsoft Streaming Video : @tab X
34749 NuppelVideo : @tab X
34750 NUT : X @tab X
34751 @tab NUT Open Container Format
34752
34753 Ogg : X @tab X
34754 Playstation Portable PMP : @tab X
34755 Portable Voice Format : @tab X
34756 TechnoTrend PVA : @tab X
34757 @tab Used by TechnoTrend DVB PCI boards.
34758
34759 QCP : @tab X
34760 raw ADTS (AAC) : X @tab X
34761 raw AC-3 : X @tab X
34762 raw AMR-NB : @tab X
34763 raw AMR-WB : @tab X
34764 raw aptX : X @tab X
34765 raw aptX HD : X @tab X
34766 raw Chinese AVS video : X @tab X
34767 raw Dirac : X @tab X
34768 raw DNxHD : X @tab X
34769 raw DTS : X @tab X
34770 raw DTS-HD : @tab X
34771 raw E-AC-3 : X @tab X
34772 raw FLAC : X @tab X
34773 raw GSM : @tab X
34774 raw H.261 : X @tab X
34775 raw H.263 : X @tab X
34776 raw H.264 : X @tab X
34777 raw HEVC : X @tab X
34778 raw Ingenient MJPEG : @tab X
34779 raw MJPEG : X @tab X
34780 raw MLP : @tab X
34781 raw MPEG : @tab X
34782 raw MPEG-1 : @tab X
34783 raw MPEG-2 : @tab X
34784 raw MPEG-4 : X @tab X
34785 raw NULL : X @tab
34786 raw video : X @tab X
34787 raw id RoQ : X @tab
34788 raw OBU : X @tab X
34789 raw SBC : X @tab X
34790 raw Shorten : @tab X
34791 raw TAK : @tab X
34792 raw TrueHD : X @tab X
34793 raw VC-1 : X @tab X
34794 raw PCM A-law : X @tab X
34795 raw PCM mu-law : X @tab X
34796 raw PCM Archimedes VIDC : X @tab X
34797 raw PCM signed 8 bit : X @tab X
34798 raw PCM signed 16 bit big-endian : X @tab X
34799 raw PCM signed 16 bit little-endian : X @tab X
34800 raw PCM signed 24 bit big-endian : X @tab X
34801 raw PCM signed 24 bit little-endian : X @tab X
34802 raw PCM signed 32 bit big-endian : X @tab X
34803 raw PCM signed 32 bit little-endian : X @tab X
34804 raw PCM signed 64 bit big-endian : X @tab X
34805 raw PCM signed 64 bit little-endian : X @tab X
34806 raw PCM unsigned 8 bit : X @tab X
34807 raw PCM unsigned 16 bit big-endian : X @tab X
34808 raw PCM unsigned 16 bit little-endian : X @tab X
34809 raw PCM unsigned 24 bit big-endian : X @tab X
34810 raw PCM unsigned 24 bit little-endian : X @tab X
34811 raw PCM unsigned 32 bit big-endian : X @tab X
34812 raw PCM unsigned 32 bit little-endian : X @tab X
34813 raw PCM 16.8 floating point little-endian : @tab X
34814 raw PCM 24.0 floating point little-endian : @tab X
34815 raw PCM floating-point 32 bit big-endian : X @tab X
34816 raw PCM floating-point 32 bit little-endian : X @tab X
34817 raw PCM floating-point 64 bit big-endian : X @tab X
34818 raw PCM floating-point 64 bit little-endian : X @tab X
34819 RDT : @tab X
34820 REDCODE R3D : @tab X
34821 @tab File format used by RED Digital cameras, contains JPEG 2000 frames and PCM audio.
34822
34823 RealMedia : X @tab X
34824 Redirector : @tab X
34825 RedSpark : @tab X
34826 Renderware TeXture Dictionary : @tab X
34827 Resolume DXV : @tab X
34828 RF64 : @tab X
34829 RL2 : @tab X
34830 @tab Audio and video format used in some games by Entertainment Software Partners.
34831
34832 RPL/ARMovie : @tab X
34833 Lego Mindstorms RSO : X @tab X
34834 RSD : @tab X
34835 RTMP : X @tab X
34836 @tab Output is performed by publishing stream to RTMP server
34837
34838 RTP : X @tab X
34839 RTSP : X @tab X
34840 Sample Dump eXchange : @tab X
34841 SAP : X @tab X
34842 SBG : @tab X
34843 SDP : @tab X
34844 SER : @tab X
34845 Sega FILM/CPK : X @tab X
34846 @tab Used in many Sega Saturn console games.
34847
34848 Silicon Graphics Movie : @tab X
34849 Sierra SOL : @tab X
34850 @tab .sol files used in Sierra Online games.
34851
34852 Sierra VMD : @tab X
34853 @tab Used in Sierra CD-ROM games.
34854
34855 Smacker : @tab X
34856 @tab Multimedia format used by many games.
34857
34858 SMJPEG : X @tab X
34859 @tab Used in certain Loki game ports.
34860
34861 SMPTE 337M encapsulation : @tab X
34862 Smush : @tab X
34863 @tab Multimedia format used in some LucasArts games.
34864
34865 Sony OpenMG (OMA) : X @tab X
34866 @tab Audio format used in Sony Sonic Stage and Sony Vegas.
34867
34868 Sony PlayStation STR : @tab X
34869 Sony Wave64 (W64) : X @tab X
34870 SoX native format : X @tab X
34871 SUN AU format : X @tab X
34872 SUP raw PGS subtitles : X @tab X
34873 SVAG : @tab X
34874 @tab Audio format used in Konami PS2 games.
34875
34876 TDSC : @tab X
34877 Text files : @tab X
34878 THP : @tab X
34879 @tab Used on the Nintendo GameCube.
34880
34881 Tiertex Limited SEQ : @tab X
34882 @tab Tiertex .seq files used in the DOS CD-ROM version of the game Flashback.
34883
34884 True Audio : X @tab X
34885 VAG : @tab X
34886 @tab Audio format used in many Sony PS2 games.
34887
34888 VC-1 test bitstream : X @tab X
34889 Vidvox Hap : X @tab X
34890 Vivo : @tab X
34891 VPK : @tab X
34892 @tab Audio format used in Sony PS games.
34893
34894 WAV : X @tab X
34895 WavPack : X @tab X
34896 WebM : X @tab X
34897 Windows Televison (WTV) : X @tab X
34898 Wing Commander III movie : @tab X
34899 @tab Multimedia format used in Origin's Wing Commander III computer game.
34900
34901 Westwood Studios audio : X @tab X
34902 @tab Multimedia format used in Westwood Studios games.
34903
34904 Westwood Studios VQA : @tab X
34905 @tab Multimedia format used in Westwood Studios games.
34906
34907 Wideband Single-bit Data (WSD) : @tab X
34908 WVE : @tab X
34909 XMV : @tab X
34910 @tab Microsoft video container used in Xbox games.
34911
34912 XVAG : @tab X
34913 @tab Audio format used on the PS3.
34914
34915 xWMA : @tab X
34916 @tab Microsoft audio container used by XAudio 2.
34917
34918 eXtended BINary text (XBIN) : @tab X
34919 YUV4MPEG pipe : X @tab X
34920 Psygnosis YOP : @tab X
34921
34922 "X" means that the feature in that column (encoding / decoding) is
34923 supported.
34924
34925 Image Formats
34926 FFmpeg can read and write images for each frame of a video sequence.
34927 The following image formats are supported:
34928
34929 Name : Encoding @tab Decoding @tab Comments
34930 .Y.U.V : X @tab X
34931 @tab one raw file per component
34932
34933 Alias PIX : X @tab X
34934 @tab Alias/Wavefront PIX image format
34935
34936 animated GIF : X @tab X
34937 APNG : X @tab X
34938 @tab Animated Portable Network Graphics
34939
34940 BMP : X @tab X
34941 @tab Microsoft BMP image
34942
34943 BRender PIX : @tab X
34944 @tab Argonaut BRender 3D engine image format.
34945
34946 CRI : @tab X
34947 @tab Cintel RAW
34948
34949 DPX : X @tab X
34950 @tab Digital Picture Exchange
34951
34952 EXR : @tab X
34953 @tab OpenEXR
34954
34955 FITS : X @tab X
34956 @tab Flexible Image Transport System
34957
34958 IMG : @tab X
34959 @tab GEM Raster image
34960
34961 JPEG : X @tab X
34962 @tab Progressive JPEG is not supported.
34963
34964 JPEG 2000 : X @tab X
34965 JPEG-LS : X @tab X
34966 LJPEG : X @tab
34967 @tab Lossless JPEG
34968
34969 MSP : @tab X
34970 @tab Microsoft Paint image
34971
34972 PAM : X @tab X
34973 @tab PAM is a PNM extension with alpha support.
34974
34975 PBM : X @tab X
34976 @tab Portable BitMap image
34977
34978 PCD : @tab X
34979 @tab PhotoCD
34980
34981 PCX : X @tab X
34982 @tab PC Paintbrush
34983
34984 PFM : X @tab X
34985 @tab Portable FloatMap image
34986
34987 PGM : X @tab X
34988 @tab Portable GrayMap image
34989
34990 PGMYUV : X @tab X
34991 @tab PGM with U and V components in YUV 4:2:0
34992
34993 PGX : @tab X
34994 @tab PGX file decoder
34995
34996 PIC : @tab X
34997 @tab Pictor/PC Paint
34998
34999 PNG : X @tab X
35000 @tab Portable Network Graphics image
35001
35002 PPM : X @tab X
35003 @tab Portable PixelMap image
35004
35005 PSD : @tab X
35006 @tab Photoshop
35007
35008 PTX : @tab X
35009 @tab V.Flash PTX format
35010
35011 SGI : X @tab X
35012 @tab SGI RGB image format
35013
35014 Sun Rasterfile : X @tab X
35015 @tab Sun RAS image format
35016
35017 TIFF : X @tab X
35018 @tab YUV, JPEG and some extension is not supported yet.
35019
35020 Truevision Targa : X @tab X
35021 @tab Targa (.TGA) image format
35022
35023 WebP : E @tab X
35024 @tab WebP image format, encoding supported through external library libwebp
35025
35026 XBM : X @tab X
35027 @tab X BitMap image format
35028
35029 XFace : X @tab X
35030 @tab X-Face image format
35031
35032 XPM : @tab X
35033 @tab X PixMap image format
35034
35035 XWD : X @tab X
35036 @tab X Window Dump image format
35037
35038 "X" means that the feature in that column (encoding / decoding) is
35039 supported.
35040
35041 "E" means that support is provided through an external library.
35042
35043 Video Codecs
35044 Name : Encoding @tab Decoding @tab Comments
35045 4X Movie : @tab X
35046 @tab Used in certain computer games.
35047
35048 8088flex TMV : @tab X
35049 A64 multicolor : X @tab
35050 @tab Creates video suitable to be played on a commodore 64 (multicolor mode).
35051
35052 Amazing Studio PAF Video : @tab X
35053 American Laser Games MM : @tab X
35054 @tab Used in games like Mad Dog McCree.
35055
35056 Amuse Graphics Movie : @tab X
35057 AMV Video : X @tab X
35058 @tab Used in Chinese MP3 players.
35059
35060 ANSI/ASCII art : @tab X
35061 Apple Intermediate Codec : @tab X
35062 Apple MJPEG-B : @tab X
35063 Apple Pixlet : @tab X
35064 Apple ProRes : X @tab X
35065 @tab fourcc: apch,apcn,apcs,apco,ap4h,ap4x
35066
35067 Apple QuickDraw : @tab X
35068 @tab fourcc: qdrw
35069
35070 Argonaut Video : @tab X
35071 @tab Used in some Argonaut games.
35072
35073 Asus v1 : X @tab X
35074 @tab fourcc: ASV1
35075
35076 Asus v2 : X @tab X
35077 @tab fourcc: ASV2
35078
35079 ATI VCR1 : @tab X
35080 @tab fourcc: VCR1
35081
35082 ATI VCR2 : @tab X
35083 @tab fourcc: VCR2
35084
35085 Auravision Aura : @tab X
35086 Auravision Aura 2 : @tab X
35087 Autodesk Animator Flic video : @tab X
35088 Autodesk RLE : @tab X
35089 @tab fourcc: AASC
35090
35091 AV1 : E @tab E
35092 @tab Supported through external libraries libaom, libdav1d, librav1e and libsvtav1
35093
35094 Avid 1:1 10-bit RGB Packer : X @tab X
35095 @tab fourcc: AVrp
35096
35097 AVS (Audio Video Standard) video : @tab X
35098 @tab Video encoding used by the Creature Shock game.
35099
35100 AVS2-P2/IEEE1857.4 : E @tab E
35101 @tab Supported through external libraries libxavs2 and libdavs2
35102
35103 AVS3-P2/IEEE1857.10 : @tab E
35104 @tab Supported through external library libuavs3d
35105
35106 AYUV : X @tab X
35107 @tab Microsoft uncompressed packed 4:4:4:4
35108
35109 Beam Software VB : @tab X
35110 Bethesda VID video : @tab X
35111 @tab Used in some games from Bethesda Softworks.
35112
35113 Bink Video : @tab X
35114 BitJazz SheerVideo : @tab X
35115 Bitmap Brothers JV video : @tab X
35116 y41p Brooktree uncompressed 4:1:1 12-bit : X @tab X
35117 Brooktree ProSumer Video : @tab X
35118 @tab fourcc: BT20
35119
35120 Brute Force & Ignorance : @tab X
35121 @tab Used in the game Flash Traffic: City of Angels.
35122
35123 C93 video : @tab X
35124 @tab Codec used in Cyberia game.
35125
35126 CamStudio : @tab X
35127 @tab fourcc: CSCD
35128
35129 CD+G : @tab X
35130 @tab Video codec for CD+G karaoke disks
35131
35132 CDXL : @tab X
35133 @tab Amiga CD video codec
35134
35135 Chinese AVS video : E @tab X
35136 @tab AVS1-P2, JiZhun profile, encoding through external library libxavs
35137
35138 Delphine Software International CIN video : @tab X
35139 @tab Codec used in Delphine Software International games.
35140
35141 Discworld II BMV Video : @tab X
35142 CineForm HD : X @tab X
35143 Canopus HQ : @tab X
35144 Canopus HQA : @tab X
35145 Canopus HQX : @tab X
35146 Canopus Lossless Codec : @tab X
35147 CDToons : @tab X
35148 @tab Codec used in various Broderbund games.
35149
35150 Cinepak : @tab X
35151 Cirrus Logic AccuPak : X @tab X
35152 @tab fourcc: CLJR
35153
35154 CPiA Video Format : @tab X
35155 Creative YUV (CYUV) : @tab X
35156 DFA : @tab X
35157 @tab Codec used in Chronomaster game.
35158
35159 Dirac : E @tab X
35160 @tab supported though the native vc2 (Dirac Pro) encoder
35161
35162 Deluxe Paint Animation : @tab X
35163 DNxHD : X @tab X
35164 @tab aka SMPTE VC3
35165
35166 Duck TrueMotion 1.0 : @tab X
35167 @tab fourcc: DUCK
35168
35169 Duck TrueMotion 2.0 : @tab X
35170 @tab fourcc: TM20
35171
35172 Duck TrueMotion 2.0 RT : @tab X
35173 @tab fourcc: TR20
35174
35175 DV (Digital Video) : X @tab X
35176 Dxtory capture format : @tab X
35177 Feeble Files/ScummVM DXA : @tab X
35178 @tab Codec originally used in Feeble Files game.
35179
35180 Electronic Arts CMV video : @tab X
35181 @tab Used in NHL 95 game.
35182
35183 Electronic Arts Madcow video : @tab X
35184 Electronic Arts TGV video : @tab X
35185 Electronic Arts TGQ video : @tab X
35186 Electronic Arts TQI video : @tab X
35187 Escape 124 : @tab X
35188 Escape 130 : @tab X
35189 FFmpeg video codec #1 : X @tab X
35190 @tab lossless codec (fourcc: FFV1)
35191
35192 Flash Screen Video v1 : X @tab X
35193 @tab fourcc: FSV1
35194
35195 Flash Screen Video v2 : X @tab X
35196 Flash Video (FLV) : X @tab X
35197 @tab Sorenson H.263 used in Flash
35198
35199 FM Screen Capture Codec : @tab X
35200 Forward Uncompressed : @tab X
35201 Fraps : @tab X
35202 Go2Meeting : @tab X
35203 @tab fourcc: G2M2, G2M3
35204
35205 Go2Webinar : @tab X
35206 @tab fourcc: G2M4
35207
35208 Gremlin Digital Video : @tab X
35209 H.261 : X @tab X
35210 H.263 / H.263-1996 : X @tab X
35211 H.263+ / H.263-1998 / H.263 version 2 : X @tab X
35212 H.264 / AVC / MPEG-4 AVC / MPEG-4 part 10 : E @tab X
35213 @tab encoding supported through external library libx264 and OpenH264
35214
35215 HEVC : X @tab X
35216 @tab encoding supported through external library libx265 and libkvazaar
35217
35218 HNM version 4 : @tab X
35219 HuffYUV : X @tab X
35220 HuffYUV FFmpeg variant : X @tab X
35221 IBM Ultimotion : @tab X
35222 @tab fourcc: ULTI
35223
35224 id Cinematic video : @tab X
35225 @tab Used in Quake II.
35226
35227 id RoQ video : X @tab X
35228 @tab Used in Quake III, Jedi Knight 2, other computer games.
35229
35230 IFF ILBM : @tab X
35231 @tab IFF interleaved bitmap
35232
35233 IFF ByteRun1 : @tab X
35234 @tab IFF run length encoded bitmap
35235
35236 Infinity IMM4 : @tab X
35237 Intel H.263 : @tab X
35238 Intel Indeo 2 : @tab X
35239 Intel Indeo 3 : @tab X
35240 Intel Indeo 4 : @tab X
35241 Intel Indeo 5 : @tab X
35242 Interplay C93 : @tab X
35243 @tab Used in the game Cyberia from Interplay.
35244
35245 Interplay MVE video : @tab X
35246 @tab Used in Interplay .MVE files.
35247
35248 J2K : X @tab X
35249 Karl Morton's video codec : @tab X
35250 @tab Codec used in Worms games.
35251
35252 Kega Game Video (KGV1) : @tab X
35253 @tab Kega emulator screen capture codec.
35254
35255 Lagarith : @tab X
35256 LCL (LossLess Codec Library) MSZH : @tab X
35257 LCL (LossLess Codec Library) ZLIB : E @tab E
35258 LOCO : @tab X
35259 LucasArts SANM/Smush : @tab X
35260 @tab Used in LucasArts games / SMUSH animations.
35261
35262 lossless MJPEG : X @tab X
35263 MagicYUV Video : X @tab X
35264 Mandsoft Screen Capture Codec : @tab X
35265 Microsoft ATC Screen : @tab X
35266 @tab Also known as Microsoft Screen 3.
35267
35268 Microsoft Expression Encoder Screen : @tab X
35269 @tab Also known as Microsoft Titanium Screen 2.
35270
35271 Microsoft RLE : @tab X
35272 Microsoft Screen 1 : @tab X
35273 @tab Also known as Windows Media Video V7 Screen.
35274
35275 Microsoft Screen 2 : @tab X
35276 @tab Also known as Windows Media Video V9 Screen.
35277
35278 Microsoft Video 1 : @tab X
35279 Mimic : @tab X
35280 @tab Used in MSN Messenger Webcam streams.
35281
35282 Miro VideoXL : @tab X
35283 @tab fourcc: VIXL
35284
35285 MJPEG (Motion JPEG) : X @tab X
35286 Mobotix MxPEG video : @tab X
35287 Motion Pixels video : @tab X
35288 MPEG-1 video : X @tab X
35289 MPEG-2 video : X @tab X
35290 MPEG-4 part 2 : X @tab X
35291 @tab libxvidcore can be used alternatively for encoding.
35292
35293 MPEG-4 part 2 Microsoft variant version 1 : @tab X
35294 MPEG-4 part 2 Microsoft variant version 2 : X @tab X
35295 MPEG-4 part 2 Microsoft variant version 3 : X @tab X
35296 Newtek SpeedHQ : X @tab X
35297 Nintendo Gamecube THP video : @tab X
35298 NotchLC : @tab X
35299 NuppelVideo/RTjpeg : @tab X
35300 @tab Video encoding used in NuppelVideo files.
35301
35302 On2 VP3 : @tab X
35303 @tab still experimental
35304
35305 On2 VP4 : @tab X
35306 @tab fourcc: VP40
35307
35308 On2 VP5 : @tab X
35309 @tab fourcc: VP50
35310
35311 On2 VP6 : @tab X
35312 @tab fourcc: VP60,VP61,VP62
35313
35314 On2 VP7 : @tab X
35315 @tab fourcc: VP70,VP71
35316
35317 VP8 : E @tab X
35318 @tab fourcc: VP80, encoding supported through external library libvpx
35319
35320 VP9 : E @tab X
35321 @tab encoding supported through external library libvpx
35322
35323 Pinnacle TARGA CineWave YUV16 : @tab X
35324 @tab fourcc: Y216
35325
35326 Q-team QPEG : @tab X
35327 @tab fourccs: QPEG, Q1.0, Q1.1
35328
35329 QuickTime 8BPS video : @tab X
35330 QuickTime Animation (RLE) video : X @tab X
35331 @tab fourcc: 'rle '
35332
35333 QuickTime Graphics (SMC) : X @tab X
35334 @tab fourcc: 'smc '
35335
35336 QuickTime video (RPZA) : X @tab X
35337 @tab fourcc: rpza
35338
35339 R10K AJA Kona 10-bit RGB Codec : X @tab X
35340 R210 Quicktime Uncompressed RGB 10-bit : X @tab X
35341 Raw Video : X @tab X
35342 RealVideo 1.0 : X @tab X
35343 RealVideo 2.0 : X @tab X
35344 RealVideo 3.0 : @tab X
35345 @tab still far from ideal
35346
35347 RealVideo 4.0 : @tab X
35348 Renderware TXD (TeXture Dictionary) : @tab X
35349 @tab Texture dictionaries used by the Renderware Engine.
35350
35351 RL2 video : @tab X
35352 @tab used in some games by Entertainment Software Partners
35353
35354 ScreenPressor : @tab X
35355 Screenpresso : @tab X
35356 Screen Recorder Gold Codec : @tab X
35357 Sierra VMD video : @tab X
35358 @tab Used in Sierra VMD files.
35359
35360 Silicon Graphics Motion Video Compressor 1 (MVC1) : @tab X
35361 Silicon Graphics Motion Video Compressor 2 (MVC2) : @tab X
35362 Silicon Graphics RLE 8-bit video : @tab X
35363 Smacker video : @tab X
35364 @tab Video encoding used in Smacker.
35365
35366 SMPTE VC-1 : @tab X
35367 Snow : X @tab X
35368 @tab experimental wavelet codec (fourcc: SNOW)
35369
35370 Sony PlayStation MDEC (Motion DECoder) : @tab X
35371 Sorenson Vector Quantizer 1 : X @tab X
35372 @tab fourcc: SVQ1
35373
35374 Sorenson Vector Quantizer 3 : @tab X
35375 @tab fourcc: SVQ3
35376
35377 Sunplus JPEG (SP5X) : @tab X
35378 @tab fourcc: SP5X
35379
35380 TechSmith Screen Capture Codec : @tab X
35381 @tab fourcc: TSCC
35382
35383 TechSmith Screen Capture Codec 2 : @tab X
35384 @tab fourcc: TSC2
35385
35386 Theora : E @tab X
35387 @tab encoding supported through external library libtheora
35388
35389 Tiertex Limited SEQ video : @tab X
35390 @tab Codec used in DOS CD-ROM FlashBack game.
35391
35392 Ut Video : X @tab X
35393 v210 QuickTime uncompressed 4:2:2 10-bit : X @tab X
35394 v308 QuickTime uncompressed 4:4:4 : X @tab X
35395 v408 QuickTime uncompressed 4:4:4:4 : X @tab X
35396 v410 QuickTime uncompressed 4:4:4 10-bit : X @tab X
35397 VBLE Lossless Codec : @tab X
35398 VMware Screen Codec / VMware Video : @tab X
35399 @tab Codec used in videos captured by VMware.
35400
35401 Westwood Studios VQA (Vector Quantized Animation) video : @tab
35402 X
35403 Windows Media Image : @tab X
35404 Windows Media Video 7 : X @tab X
35405 Windows Media Video 8 : X @tab X
35406 Windows Media Video 9 : @tab X
35407 @tab not completely working
35408
35409 Wing Commander III / Xan : @tab X
35410 @tab Used in Wing Commander III .MVE files.
35411
35412 Wing Commander IV / Xan : @tab X
35413 @tab Used in Wing Commander IV.
35414
35415 Winnov WNV1 : @tab X
35416 WMV7 : X @tab X
35417 YAMAHA SMAF : X @tab X
35418 Psygnosis YOP Video : @tab X
35419 yuv4 : X @tab X
35420 @tab libquicktime uncompressed packed 4:2:0
35421
35422 ZeroCodec Lossless Video : @tab X
35423 ZLIB : X @tab X
35424 @tab part of LCL, encoder experimental
35425
35426 Zip Motion Blocks Video : X @tab X
35427 @tab Encoder works only in PAL8.
35428
35429 "X" means that the feature in that column (encoding / decoding) is
35430 supported.
35431
35432 "E" means that support is provided through an external library.
35433
35434 Audio Codecs
35435 Name : Encoding @tab Decoding @tab Comments
35436 8SVX exponential : @tab X
35437 8SVX fibonacci : @tab X
35438 AAC : EX @tab X
35439 @tab encoding supported through internal encoder and external library libfdk-aac
35440
35441 AAC+ : E @tab IX
35442 @tab encoding supported through external library libfdk-aac
35443
35444 AC-3 : IX @tab IX
35445 ACELP.KELVIN : @tab X
35446 ADPCM 4X Movie : @tab X
35447 ADPCM Yamaha AICA : @tab X
35448 ADPCM AmuseGraphics Movie : @tab X
35449 ADPCM Argonaut Games : X @tab X
35450 ADPCM CDROM XA : @tab X
35451 ADPCM Creative Technology : @tab X
35452 @tab 16 -E<gt> 4, 8 -E<gt> 4, 8 -E<gt> 3, 8 -E<gt> 2
35453
35454 ADPCM Electronic Arts : @tab X
35455 @tab Used in various EA titles.
35456
35457 ADPCM Electronic Arts Maxis CDROM XS : @tab X
35458 @tab Used in Sim City 3000.
35459
35460 ADPCM Electronic Arts R1 : @tab X
35461 ADPCM Electronic Arts R2 : @tab X
35462 ADPCM Electronic Arts R3 : @tab X
35463 ADPCM Electronic Arts XAS : @tab X
35464 ADPCM G.722 : X @tab X
35465 ADPCM G.726 : X @tab X
35466 ADPCM IMA Acorn Replay : @tab X
35467 ADPCM IMA AMV : X @tab X
35468 @tab Used in AMV files
35469
35470 ADPCM IMA Cunning Developments : @tab X
35471 ADPCM IMA Electronic Arts EACS : @tab X
35472 ADPCM IMA Electronic Arts SEAD : @tab X
35473 ADPCM IMA Funcom : @tab X
35474 ADPCM IMA High Voltage Software ALP : X @tab X
35475 ADPCM IMA QuickTime : X @tab X
35476 ADPCM IMA Simon & Schuster Interactive : X @tab X
35477 ADPCM IMA Ubisoft APM : X @tab X
35478 ADPCM IMA Loki SDL MJPEG : @tab X
35479 ADPCM IMA WAV : X @tab X
35480 ADPCM IMA Westwood : @tab X
35481 ADPCM ISS IMA : @tab X
35482 @tab Used in FunCom games.
35483
35484 ADPCM IMA Dialogic : @tab X
35485 ADPCM IMA Duck DK3 : @tab X
35486 @tab Used in some Sega Saturn console games.
35487
35488 ADPCM IMA Duck DK4 : @tab X
35489 @tab Used in some Sega Saturn console games.
35490
35491 ADPCM IMA Radical : @tab X
35492 ADPCM Microsoft : X @tab X
35493 ADPCM MS IMA : X @tab X
35494 ADPCM Nintendo Gamecube AFC : @tab X
35495 ADPCM Nintendo Gamecube DTK : @tab X
35496 ADPCM Nintendo THP : @tab X
35497 ADPCM Playstation : @tab X
35498 ADPCM QT IMA : X @tab X
35499 ADPCM SEGA CRI ADX : X @tab X
35500 @tab Used in Sega Dreamcast games.
35501
35502 ADPCM Shockwave Flash : X @tab X
35503 ADPCM Sound Blaster Pro 2-bit : @tab X
35504 ADPCM Sound Blaster Pro 2.6-bit : @tab X
35505 ADPCM Sound Blaster Pro 4-bit : @tab X
35506 ADPCM VIMA : @tab X
35507 @tab Used in LucasArts SMUSH animations.
35508
35509 ADPCM Westwood Studios IMA : X @tab X
35510 @tab Used in Westwood Studios games like Command and Conquer.
35511
35512 ADPCM Yamaha : X @tab X
35513 ADPCM Zork : @tab X
35514 AMR-NB : E @tab X
35515 @tab encoding supported through external library libopencore-amrnb
35516
35517 AMR-WB : E @tab X
35518 @tab encoding supported through external library libvo-amrwbenc
35519
35520 Amazing Studio PAF Audio : @tab X
35521 Apple lossless audio : X @tab X
35522 @tab QuickTime fourcc 'alac'
35523
35524 aptX : X @tab X
35525 @tab Used in Bluetooth A2DP
35526
35527 aptX HD : X @tab X
35528 @tab Used in Bluetooth A2DP
35529
35530 ATRAC1 : @tab X
35531 ATRAC3 : @tab X
35532 ATRAC3+ : @tab X
35533 ATRAC9 : @tab X
35534 Bink Audio : @tab X
35535 @tab Used in Bink and Smacker files in many games.
35536
35537 CELT : @tab E
35538 @tab decoding supported through external library libcelt
35539
35540 codec2 : E @tab E
35541 @tab en/decoding supported through external library libcodec2
35542
35543 CRI HCA : @tab X
35544 Delphine Software International CIN audio : @tab X
35545 @tab Codec used in Delphine Software International games.
35546
35547 Digital Speech Standard - Standard Play mode (DSS SP) : @tab X
35548 Discworld II BMV Audio : @tab X
35549 COOK : @tab X
35550 @tab All versions except 5.1 are supported.
35551
35552 DCA (DTS Coherent Acoustics) : X @tab X
35553 @tab supported extensions: XCh, XXCH, X96, XBR, XLL, LBR (partially)
35554
35555 Dolby E : @tab X
35556 DPCM Gremlin : @tab X
35557 DPCM id RoQ : X @tab X
35558 @tab Used in Quake III, Jedi Knight 2 and other computer games.
35559
35560 DPCM Interplay : @tab X
35561 @tab Used in various Interplay computer games.
35562
35563 DPCM Squareroot-Delta-Exact : @tab X
35564 @tab Used in various games.
35565
35566 DPCM Sierra Online : @tab X
35567 @tab Used in Sierra Online game audio files.
35568
35569 DPCM Sol : @tab X
35570 DPCM Xan : @tab X
35571 @tab Used in Origin's Wing Commander IV AVI files.
35572
35573 DPCM Xilam DERF : @tab X
35574 DSD (Direct Stream Digital), least significant bit first : @tab X
35575 DSD (Direct Stream Digital), most significant bit first : @tab X
35576 DSD (Direct Stream Digital), least significant bit first, planar :
35577 @tab X
35578 DSD (Direct Stream Digital), most significant bit first, planar :
35579 @tab X
35580 DSP Group TrueSpeech : @tab X
35581 DST (Direct Stream Transfer) : @tab X
35582 DV audio : @tab X
35583 Enhanced AC-3 : X @tab X
35584 EVRC (Enhanced Variable Rate Codec) : @tab X
35585 FLAC (Free Lossless Audio Codec) : X @tab IX
35586 G.723.1 : X @tab X
35587 G.729 : @tab X
35588 GSM : E @tab X
35589 @tab encoding supported through external library libgsm
35590
35591 GSM Microsoft variant : E @tab X
35592 @tab encoding supported through external library libgsm
35593
35594 IAC (Indeo Audio Coder) : @tab X
35595 iLBC (Internet Low Bitrate Codec) : E @tab EX
35596 @tab encoding and decoding supported through external library libilbc
35597
35598 IMC (Intel Music Coder) : @tab X
35599 Interplay ACM : @tab X
35600 MACE (Macintosh Audio Compression/Expansion) 3:1 : @tab X
35601 MACE (Macintosh Audio Compression/Expansion) 6:1 : @tab X
35602 MLP (Meridian Lossless Packing) : X @tab X
35603 @tab Used in DVD-Audio discs.
35604
35605 Monkey's Audio : @tab X
35606 MP1 (MPEG audio layer 1) : @tab IX
35607 MP2 (MPEG audio layer 2) : IX @tab IX
35608 @tab encoding supported also through external library TwoLAME
35609
35610 MP3 (MPEG audio layer 3) : E @tab IX
35611 @tab encoding supported through external library LAME, ADU MP3 and MP3onMP4 also supported
35612
35613 MPEG-4 Audio Lossless Coding (ALS) : @tab X
35614 Musepack SV7 : @tab X
35615 Musepack SV8 : @tab X
35616 Nellymoser Asao : X @tab X
35617 On2 AVC (Audio for Video Codec) : @tab X
35618 Opus : E @tab X
35619 @tab encoding supported through external library libopus
35620
35621 PCM A-law : X @tab X
35622 PCM mu-law : X @tab X
35623 PCM Archimedes VIDC : X @tab X
35624 PCM signed 8-bit planar : X @tab X
35625 PCM signed 16-bit big-endian planar : X @tab X
35626 PCM signed 16-bit little-endian planar : X @tab X
35627 PCM signed 24-bit little-endian planar : X @tab X
35628 PCM signed 32-bit little-endian planar : X @tab X
35629 PCM 32-bit floating point big-endian : X @tab X
35630 PCM 32-bit floating point little-endian : X @tab X
35631 PCM 64-bit floating point big-endian : X @tab X
35632 PCM 64-bit floating point little-endian : X @tab X
35633 PCM D-Cinema audio signed 24-bit : X @tab X
35634 PCM signed 8-bit : X @tab X
35635 PCM signed 16-bit big-endian : X @tab X
35636 PCM signed 16-bit little-endian : X @tab X
35637 PCM signed 24-bit big-endian : X @tab X
35638 PCM signed 24-bit little-endian : X @tab X
35639 PCM signed 32-bit big-endian : X @tab X
35640 PCM signed 32-bit little-endian : X @tab X
35641 PCM signed 16/20/24-bit big-endian in MPEG-TS : @tab X
35642 PCM unsigned 8-bit : X @tab X
35643 PCM unsigned 16-bit big-endian : X @tab X
35644 PCM unsigned 16-bit little-endian : X @tab X
35645 PCM unsigned 24-bit big-endian : X @tab X
35646 PCM unsigned 24-bit little-endian : X @tab X
35647 PCM unsigned 32-bit big-endian : X @tab X
35648 PCM unsigned 32-bit little-endian : X @tab X
35649 QCELP / PureVoice : @tab X
35650 QDesign Music Codec 1 : @tab X
35651 QDesign Music Codec 2 : @tab X
35652 @tab There are still some distortions.
35653
35654 RealAudio 1.0 (14.4K) : X @tab X
35655 @tab Real 14400 bit/s codec
35656
35657 RealAudio 2.0 (28.8K) : @tab X
35658 @tab Real 28800 bit/s codec
35659
35660 RealAudio 3.0 (dnet) : IX @tab X
35661 @tab Real low bitrate AC-3 codec
35662
35663 RealAudio Lossless : @tab X
35664 RealAudio SIPR / ACELP.NET : @tab X
35665 SBC (low-complexity subband codec) : X @tab X
35666 @tab Used in Bluetooth A2DP
35667
35668 Shorten : @tab X
35669 Sierra VMD audio : @tab X
35670 @tab Used in Sierra VMD files.
35671
35672 Smacker audio : @tab X
35673 SMPTE 302M AES3 audio : X @tab X
35674 Sonic : X @tab X
35675 @tab experimental codec
35676
35677 Sonic lossless : X @tab X
35678 @tab experimental codec
35679
35680 Speex : E @tab EX
35681 @tab supported through external library libspeex
35682
35683 TAK (Tom's lossless Audio Kompressor) : @tab X
35684 True Audio (TTA) : X @tab X
35685 TrueHD : X @tab X
35686 @tab Used in HD-DVD and Blu-Ray discs.
35687
35688 TwinVQ (VQF flavor) : @tab X
35689 VIMA : @tab X
35690 @tab Used in LucasArts SMUSH animations.
35691
35692 Vorbis : E @tab X
35693 @tab A native but very primitive encoder exists.
35694
35695 Voxware MetaSound : @tab X
35696 WavPack : X @tab X
35697 Westwood Audio (SND1) : @tab X
35698 Windows Media Audio 1 : X @tab X
35699 Windows Media Audio 2 : X @tab X
35700 Windows Media Audio Lossless : @tab X
35701 Windows Media Audio Pro : @tab X
35702 Windows Media Audio Voice : @tab X
35703 Xbox Media Audio 1 : @tab X
35704 Xbox Media Audio 2 : @tab X
35705
35706 "X" means that the feature in that column (encoding / decoding) is
35707 supported.
35708
35709 "E" means that support is provided through an external library.
35710
35711 "I" means that an integer-only version is available, too (ensures high
35712 performance on systems without hardware floating point support).
35713
35714 Subtitle Formats
35715 Name : Muxing @tab Demuxing @tab Encoding @tab Decoding
35716 3GPP Timed Text : @tab @tab X @tab X
35717 AQTitle : @tab X @tab @tab X
35718 DVB : X @tab X @tab X @tab X
35719 DVB teletext : @tab X @tab @tab E
35720 DVD : X @tab X @tab X @tab X
35721 JACOsub : X @tab X @tab @tab X
35722 MicroDVD : X @tab X @tab @tab X
35723 MPL2 : @tab X @tab @tab X
35724 MPsub (MPlayer) : @tab X @tab @tab X
35725 PGS : @tab @tab @tab X
35726 PJS (Phoenix) : @tab X @tab @tab X
35727 RealText : @tab X @tab @tab X
35728 SAMI : @tab X @tab @tab X
35729 Spruce format (STL) : @tab X @tab @tab X
35730 SSA/ASS : X @tab X @tab X @tab X
35731 SubRip (SRT) : X @tab X @tab X @tab X
35732 SubViewer v1 : @tab X @tab @tab X
35733 SubViewer : @tab X @tab @tab X
35734 TED Talks captions : @tab X @tab @tab X
35735 TTML : X @tab @tab X @tab
35736 VobSub (IDX+SUB) : @tab X @tab @tab X
35737 VPlayer : @tab X @tab @tab X
35738 WebVTT : X @tab X @tab X @tab X
35739 XSUB : @tab @tab X @tab X
35740
35741 "X" means that the feature is supported.
35742
35743 "E" means that support is provided through an external library.
35744
35745 Network Protocols
35746 Name : Support
35747 AMQP : E
35748 file : X
35749 FTP : X
35750 Gopher : X
35751 Gophers : X
35752 HLS : X
35753 HTTP : X
35754 HTTPS : X
35755 Icecast : X
35756 MMSH : X
35757 MMST : X
35758 pipe : X
35759 Pro-MPEG FEC : X
35760 RTMP : X
35761 RTMPE : X
35762 RTMPS : X
35763 RTMPT : X
35764 RTMPTE : X
35765 RTMPTS : X
35766 RTP : X
35767 SAMBA : E
35768 SCTP : X
35769 SFTP : E
35770 TCP : X
35771 TLS : X
35772 UDP : X
35773 ZMQ : E
35774
35775 "X" means that the protocol is supported.
35776
35777 "E" means that support is provided through an external library.
35778
35779 Input/Output Devices
35780 Name : Input @tab Output
35781 ALSA : X @tab X
35782 BKTR : X @tab
35783 caca : @tab X
35784 DV1394 : X @tab
35785 Lavfi virtual device : X @tab
35786 Linux framebuffer : X @tab X
35787 JACK : X @tab
35788 LIBCDIO : X
35789 LIBDC1394 : X @tab
35790 OpenAL : X
35791 OpenGL : @tab X
35792 OSS : X @tab X
35793 PulseAudio : X @tab X
35794 SDL : @tab X
35795 Video4Linux2 : X @tab X
35796 VfW capture : X @tab
35797 X11 grabbing : X @tab
35798 Win32 grabbing : X @tab
35799
35800 "X" means that input/output is supported.
35801
35802 Timecode
35803 Codec/format : Read @tab Write
35804 AVI : X @tab X
35805 DV : X @tab X
35806 GXF : X @tab X
35807 MOV : X @tab X
35808 MPEG1/2 : X @tab X
35809 MXF : X @tab X
35810
35812 ffplay(1), ffmpeg(1), ffprobe(1), ffmpeg-utils(1), ffmpeg-scaler(1),
35813 ffmpeg-resampler(1), ffmpeg-codecs(1), ffmpeg-bitstream-filters(1),
35814 ffmpeg-formats(1), ffmpeg-devices(1), ffmpeg-protocols(1),
35815 ffmpeg-filters(1)
35816
35818 The FFmpeg developers.
35819
35820 For details about the authorship, see the Git history of the project
35821 (git://source.ffmpeg.org/ffmpeg), e.g. by typing the command git log in
35822 the FFmpeg source directory, or browsing the online repository at
35823 <http://source.ffmpeg.org>.
35824
35825 Maintainers for the specific components are listed in the file
35826 MAINTAINERS in the source code tree.
35827
35828
35829
35830 FFPLAY-ALL(1)