Compare commits

...

44 Commits

Author SHA1 Message Date
Ashley
b45b2d79e1 Merge pull request #405 from amiaopensource/recipe_list
update recipe list
2019-10-18 13:18:36 -04:00
Reto Kromer
e95d915869 update recipe list 2019-10-18 19:15:12 +02:00
Ashley
059faba357 Merge pull request #403 from amiaopensource/weaver-branch
standardize dither method
2019-10-18 12:59:40 -04:00
Ashley
614b28fd9a Merge pull request #404 from amiaopensource/update_to_h5
update to `<h5>`
2019-10-18 12:51:58 -04:00
Reto Kromer
e51199bc53 update to h5 2019-10-18 18:46:43 +02:00
weaver
c1aff3fd69 standardize dither method 2019-10-17 13:28:55 -07:00
Ashley
ca0f2a8d0a Merge pull request #402 from EG-tech/qemu-qed
add QEMU QED to sister projects
2019-10-09 11:30:39 -04:00
EG-tech
640672b6f6 fix markdown render
forgot to add double space in README for proper line break
2019-10-09 10:58:00 -04:00
EG-tech
84c6f127a2 add QEMU QED to sister projects
in README and main index.html
2019-10-09 10:52:29 -04:00
Ashley
d180012261 Merge pull request #401 from amiaopensource/kfrn/fix
Docs: correct nesting in Articles list, fix typo
2019-10-08 09:18:29 -04:00
Katherine Frances Nagels
6d9d4fc596 Fix typo 2019-10-08 18:45:58 +13:00
Katherine Frances Nagels
4e0e369bbb Docs: correct nesting in Articles list 2019-10-08 18:43:23 +13:00
Katherine Frances Nagels
96b221642f Merge pull request #400 from amiaopensource/kn/cool-things
Add articles and mentions and cool things
2019-10-08 18:42:00 +13:00
Katherine Frances Nagels
309a8e7c8d Fix typo 2019-10-08 18:37:52 +13:00
kfrn
9c3c807af0 Docs: add Table of Contents 2019-10-07 21:08:11 +13:00
kfrn
aee386d889 Docs: add list of articles, successes, and cool things
Let's celebrate our successes :)
2019-10-07 21:08:06 +13:00
Ashley
6267c1c19a Merge pull request #398 from Anushka-codergirl/gh-pages
Changes h3 to h5
2019-10-03 11:39:36 -04:00
Anushka Raj
5a1aee1cf2 Update index.html 2019-10-03 11:43:42 +05:30
Anushka Raj
46fad11207 Update index.html 2019-10-03 11:22:39 +05:30
Ashley
782b1a992a Merge pull request #396 from amiaopensource/extract_recipes
simplify recipe extraction
2019-09-26 14:54:35 -04:00
Reto Kromer
9f6e6846e0 change h3 to h5 2019-09-26 18:07:51 +02:00
Reto Kromer
c4bd6a9191 add h5 2019-09-26 18:04:55 +02:00
Katherine Frances Nagels
8b48abf751 Merge pull request #394 from amiaopensource/kn/stream-mapping
Add note to Stream Mapping entry about mapping with a failsafe
2019-08-07 07:42:46 +12:00
kfrn
54aab85937 Add note to Stream Mapping entry about mapping with a failsafe
Following Ben Turkus' comment here:
https://github.com/amiaopensource/ffmprovisr/issues/383#issuecomment-516847829
2019-08-03 13:10:04 +12:00
kfrn
51ca7a4200 Revert "Add note to Stream Mapping entry about mapping with a failsafe"
This reverts commit 76c3fe1f88.
2019-08-02 19:25:27 +12:00
kfrn
76c3fe1f88 Add note to Stream Mapping entry about mapping with a failsafe
Following Ben Turkus' comment here:
https://github.com/amiaopensource/ffmprovisr/issues/383#issuecomment-516847829
2019-08-02 19:21:58 +12:00
Katherine Frances Nagels
839d50111e Merge pull request #393 from amiaopensource/kn/remove-unnecessary-command
Remove MKV → MP4 command
2019-08-01 07:32:51 +12:00
Reto Kromer
a6dd9c203c update recipe list 2019-07-31 16:50:39 +02:00
kfrn
3402d968a7 Remove MKV → MP4 command
Addressing user feedback received by Andrew Weaver (@privatezero).

When the source file is ffv1 in MKV, the command will fail on the `-c:v copy` flag, since MP4s can't house ffv1.
Therefore, the command is misleading, and has limited value from an archival perspective.

We already have a basic rewrap command (which includes a note addressing the possibility of stream/wrapper incompability), so I think our bases are covered with that.

See https://github.com/amiaopensource/ffmprovisr/issues/392
2019-07-31 23:37:53 +12:00
Reto Kromer
283756f8cf Merge pull request #390 (Revert "update recipe list") 2019-07-19 19:34:49 +02:00
Ashley
d28ae29f5c Merge pull request #389 from amiaopensource/revert-387-issue-383
Revert "Adds mapping all audio to access script"
2019-07-19 13:33:24 -04:00
Reto Kromer
2be5576012 Revert "update recipe list" 2019-07-19 19:25:01 +02:00
Ashley
43c98527a7 Revert "Adds mapping all audio to access script" 2019-07-19 13:11:06 -04:00
Reto Kromer
164d757309 Merge pull request #388 (update recipe list) 2019-07-17 19:14:07 +02:00
Ashley
2a87a120c3 Merge pull request #387 from amiaopensource/issue-383
Adds mapping all audio to access script
2019-07-17 12:42:07 -04:00
Ashley
fbe5f216a7 patch linebreaks 2019-07-17 12:40:50 -04:00
Reto Kromer
f93922a9c3 update recipe list 2019-07-17 18:34:00 +02:00
Ashley Blewer
e06a76f559 Adds mapping all audio to access script 2019-07-17 12:08:14 -04:00
Ashley
0279c1d842 Merge pull request #385 from amiaopensource/fix-intrapage-anchor-bug
Fix intrapage anchor bug
2019-07-15 11:49:40 -04:00
Ashley Blewer
7e72b1c254 Links updates within categories #384 2019-07-13 21:38:38 -04:00
Ashley Blewer
07fe8bf966 Move repeated JS into functions 2019-07-13 18:41:44 -04:00
Ashley Blewer
c32a7f44ad Supports intralinking for recipes 2019-07-13 17:52:49 -04:00
Ashley
ea2c29a38c Merge pull request #382 from mipops/gh-pages
Add Micropops to Sister Projects
2019-07-02 18:26:14 -04:00
A. Lavigne
d624a3fc11 Add Micropops to Sister Projects 2019-07-02 15:08:23 -07:00
6 changed files with 175 additions and 158 deletions

View File

@@ -105,7 +105,7 @@ h2 {
margin: 6px 0px 12px 0px; margin: 6px 0px 12px 0px;
} }
h3 { h3, h5 {
font-size: 1.5em; font-size: 1.5em;
} }

View File

@@ -62,7 +62,9 @@
<span class="intro-lead">Sister projects</span> <span class="intro-lead">Sister projects</span>
<p><a href="https://dd388.github.io/crals/" target="_blank">Script Ahoy</a>: Community Resource for Archivists and Librarians Scripting</p> <p><a href="https://dd388.github.io/crals/" target="_blank">Script Ahoy</a>: Community Resource for Archivists and Librarians Scripting</p>
<p><a href="https://datapraxis.github.io/sourcecaster/" target="_blank">The Sourcecaster</a>: an app that helps you use the command line to work through common challenges that come up when working with digital primary sources.</p> <p><a href="https://datapraxis.github.io/sourcecaster/" target="_blank">The Sourcecaster</a>: an app that helps you use the command line to work through common challenges that come up when working with digital primary sources.</p>
<p><a href="https://pugetsoundandvision.github.io/micropops/" target="_blank">Micropops</a>: One liners and automation tools from Moving Image Preservation of Puget Sound</p>
<p><a href="https://amiaopensource.github.io/cable-bible/" target="_blank">Cable Bible</a>: A Guide to Cables and Connectors Used for Audiovisual Tech</p> <p><a href="https://amiaopensource.github.io/cable-bible/" target="_blank">Cable Bible</a>: A Guide to Cables and Connectors Used for Audiovisual Tech</p>
<p><a href="https://eaasi.gitlab.io/qemu-qed/" target="_blank">QEMU QED</a>: instructions for using QEMU (Quick EMUlator), a command line application for computer emulation and virtualization</p>
</div> </div>
<div class="well"> <div class="well">
@@ -71,7 +73,7 @@
<label class="recipe" for="basic-structure">Basic structure of an FFmpeg command</label> <label class="recipe" for="basic-structure">Basic structure of an FFmpeg command</label>
<input type="checkbox" id="basic-structure"> <input type="checkbox" id="basic-structure">
<div class="hiding"> <div class="hiding">
<h3>Basic structure of an FFmpeg command</h3> <h5>Basic structure of an FFmpeg command</h5>
<p>At its basis, an FFmpeg command is relatively simple. After you have installed FFmpeg (see instructions <a href="https://avpres.net/FFmpeg/#ch1" target="_blank">here</a>), the program is invoked simply by typing <code>ffmpeg</code> at the command prompt.</p> <p>At its basis, an FFmpeg command is relatively simple. After you have installed FFmpeg (see instructions <a href="https://avpres.net/FFmpeg/#ch1" target="_blank">here</a>), the program is invoked simply by typing <code>ffmpeg</code> at the command prompt.</p>
<p>Subsequently, each instruction that you supply to FFmpeg is actually a pair: a flag, which designates the <em>type</em> of action you want to carry out; and then the specifics of that action. Flags are always prepended with a hyphen.</p> <p>Subsequently, each instruction that you supply to FFmpeg is actually a pair: a flag, which designates the <em>type</em> of action you want to carry out; and then the specifics of that action. Flags are always prepended with a hyphen.</p>
<p>For example, in the instruction <code>-i <em>input_file.ext</em></code>, the <code>-i</code> flag tells FFmpeg that you are supplying an input file, and <code>input_file.ext</code> states which file it is.</p> <p>For example, in the instruction <code>-i <em>input_file.ext</em></code>, the <code>-i</code> flag tells FFmpeg that you are supplying an input file, and <code>input_file.ext</code> states which file it is.</p>
@@ -92,7 +94,7 @@
<label class="recipe" for="streaming-saving">Streaming vs. Saving</label> <label class="recipe" for="streaming-saving">Streaming vs. Saving</label>
<input type="checkbox" id="streaming-saving"> <input type="checkbox" id="streaming-saving">
<div class="hiding"> <div class="hiding">
<h3>Streaming vs. Saving</h3> <h5>Streaming vs. Saving</h5>
<p>FFplay allows you to stream created video and FFmpeg allows you to save video.</p> <p>FFplay allows you to stream created video and FFmpeg allows you to save video.</p>
<p>The following command creates and saves a 10-second video of SMPTE bars:</p> <p>The following command creates and saves a 10-second video of SMPTE bars:</p>
<p><code>ffmpeg -f lavfi -i smptebars=size=640x480 -t 5 output_file</code></p> <p><code>ffmpeg -f lavfi -i smptebars=size=640x480 -t 5 output_file</code></p>
@@ -110,7 +112,7 @@
<label class="recipe" for="codec-defaults">Codec defaults</label> <label class="recipe" for="codec-defaults">Codec defaults</label>
<input type="checkbox" id="codec-defaults"> <input type="checkbox" id="codec-defaults">
<div class="hiding"> <div class="hiding">
<h3>Codec Defaults</h3> <h5>Codec Defaults</h5>
<p>Unless specified, FFmpeg will automatically set codec choices and codec parameters based off of internal defaults. These defaults are applied based on the file type used in the output (for example <code>.mov</code> or <code>.wav</code>).</p> <p>Unless specified, FFmpeg will automatically set codec choices and codec parameters based off of internal defaults. These defaults are applied based on the file type used in the output (for example <code>.mov</code> or <code>.wav</code>).</p>
<p>When creating or transcoding files with FFmpeg, it is important to consider codec settings for both audio and video, as the default options may not be desirable in your particular context. The following is a brief list of codec defaults for some common file types:</p> <p>When creating or transcoding files with FFmpeg, it is important to consider codec settings for both audio and video, as the default options may not be desirable in your particular context. The following is a brief list of codec defaults for some common file types:</p>
<ul> <ul>
@@ -129,7 +131,7 @@
<label class="recipe" for="filtergraphs">Filtergraphs</label> <label class="recipe" for="filtergraphs">Filtergraphs</label>
<input type="checkbox" id="filtergraphs"> <input type="checkbox" id="filtergraphs">
<div class="hiding"> <div class="hiding">
<h3>Filtergraphs</h3> <h5>Filtergraphs</h5>
<p>Many FFmpeg commands use filters that manipulate the video or audio stream in some way: for example, <a href="https://ffmpeg.org/ffmpeg-filters.html#hflip" target="_blank">hflip</a> to horizontally flip a video, or <a href="https://ffmpeg.org/ffmpeg-filters.html#amerge-1" target="_blank">amerge</a> to merge two or more audio tracks into a single stream.</p> <p>Many FFmpeg commands use filters that manipulate the video or audio stream in some way: for example, <a href="https://ffmpeg.org/ffmpeg-filters.html#hflip" target="_blank">hflip</a> to horizontally flip a video, or <a href="https://ffmpeg.org/ffmpeg-filters.html#amerge-1" target="_blank">amerge</a> to merge two or more audio tracks into a single stream.</p>
<p>The use of a filter is signaled by the flag <code>-vf</code> (video filter) or <code>-af</code> (audio filter), followed by the name and options of the filter itself. For example, take the <a href="#convert-colorspace">convert colorspace</a> command:</p> <p>The use of a filter is signaled by the flag <code>-vf</code> (video filter) or <code>-af</code> (audio filter), followed by the name and options of the filter itself. For example, take the <a href="#convert-colorspace">convert colorspace</a> command:</p>
<p><code>ffmpeg -i <em>input_file</em> -c:v libx264 -vf colormatrix=<em>src</em>:<em>dst</em> <em>output_file</em></code> <p><code>ffmpeg -i <em>input_file</em> -c:v libx264 -vf colormatrix=<em>src</em>:<em>dst</em> <em>output_file</em></code>
@@ -160,7 +162,7 @@
<label class="recipe" for="stream-mapping">Stream mapping</label> <label class="recipe" for="stream-mapping">Stream mapping</label>
<input type="checkbox" id="stream-mapping"> <input type="checkbox" id="stream-mapping">
<div class="hiding"> <div class="hiding">
<h3>Stream mapping</h3> <h5>Stream mapping</h5>
<p>Stream mapping is the practice of defining which of the streams (e.g., video or audio tracks) present in an input file will be present in the output file. FFmpeg recognizes five stream types:</p> <p>Stream mapping is the practice of defining which of the streams (e.g., video or audio tracks) present in an input file will be present in the output file. FFmpeg recognizes five stream types:</p>
<ul> <ul>
<li><code>a</code> - audio</li> <li><code>a</code> - audio</li>
@@ -177,8 +179,12 @@
<li><code>-map 0:0 -map 0:2</code> means take the first and third streams from the first input file.</li> <li><code>-map 0:0 -map 0:2</code> means take the first and third streams from the first input file.</li>
<li><code>-map 0:1 -map 1:0</code> means take the second stream from the first input file and the first stream from the second input file.</li> <li><code>-map 0:1 -map 1:0</code> means take the second stream from the first input file and the first stream from the second input file.</li>
</ul> </ul>
<p>To map <em>all</em> streams in the input file to the output file, use <code>-map 0</code>. However, note that not all container formats can include all stream types: for example, .mp4 cannot contain timecode.</p>
<p>When no mapping is specified in an ffmpeg command, the default for video files is to take just one video and one audio stream for the output: other stream types, such as timecode or subtitles, will not be copied to the output file by default. If multiple video or audio streams are present, the best quality one is automatically selected by FFmpeg.</p> <p>When no mapping is specified in an ffmpeg command, the default for video files is to take just one video and one audio stream for the output: other stream types, such as timecode or subtitles, will not be copied to the output file by default. If multiple video or audio streams are present, the best quality one is automatically selected by FFmpeg.</p>
<p>To map <em>all</em> streams in the input file to the output file, use <code>-map 0</code>. However, note that not all container formats can include all stream types: for example, .mp4 cannot contain timecode.</p>
<h4>Mapping with a failsafe</h4>
<p>To safely process files that may or may not contain given a type of stream, you can add a trailing <code>?</code> to your map commands: for example, <code>-map 0:a?</code> instead of <code>-map 0:a</code>.</p>
<p>This makes the map optional: audio streams will be mapped over if they are present in the file—but if the file contains no audio streams, the transcode will precede as usual, minus the audio stream mapping. Without adding the trailing <code>?</code>, FFmpeg will exit with an error on that file.</p>
<p>This is especially recommended when batch processing video files: it ensures that all files in your batch will be transcoded, whether or not they contain audio streams.</p>
<p>For more information, check out the FFmpeg wiki <a href="https://trac.ffmpeg.org/wiki/Map" target="_blank">Map</a> page, and the official FFmpeg <a href="https://ffmpeg.org/ffmpeg.html#Advanced-options" target="_blank">documentation on <code>-map</code></a>.</p> <p>For more information, check out the FFmpeg wiki <a href="https://trac.ffmpeg.org/wiki/Map" target="_blank">Map</a> page, and the official FFmpeg <a href="https://ffmpeg.org/ffmpeg.html#Advanced-options" target="_blank">documentation on <code>-map</code></a>.</p>
<p class="link"></p> <p class="link"></p>
</div> </div>
@@ -192,7 +198,7 @@
<label class="recipe" for="basic-rewrap">Basic rewrap command</label> <label class="recipe" for="basic-rewrap">Basic rewrap command</label>
<input type="checkbox" id="basic-rewrap"> <input type="checkbox" id="basic-rewrap">
<div class="hiding"> <div class="hiding">
<h3>Rewrap a file</h3> <h5>Rewrap a file</h5>
<p><code>ffmpeg -i <em>input_file.ext</em> -c copy -map 0 <em>output_file.ext</em></code></p> <p><code>ffmpeg -i <em>input_file.ext</em> -c copy -map 0 <em>output_file.ext</em></code></p>
<p>This script will rewrap a video file. It will create a new video video file where the inner content (the video, audio, and subtitle data) of the original file is unchanged, but these streams are rehoused within a different container format.</p> <p>This script will rewrap a video file. It will create a new video video file where the inner content (the video, audio, and subtitle data) of the original file is unchanged, but these streams are rehoused within a different container format.</p>
<p><strong>Note:</strong> rewrapping is also known as remuxing, short for re-multiplexing.</p> <p><strong>Note:</strong> rewrapping is also known as remuxing, short for re-multiplexing.</p>
@@ -212,33 +218,11 @@
</div> </div>
<!-- End Basic rewrap command --> <!-- End Basic rewrap command -->
<!-- MKV to MP4 -->
<label class="recipe" for="mkv_to_mp4">Convert Matroska (MKV) to MP4</label>
<input type="checkbox" id="mkv_to_mp4">
<div class="hiding">
<h3>MKV to MP4</h3>
<p><code>ffmpeg -i <em>input_file</em>.mkv -c:v copy -c:a aac <em>output_file</em>.mp4</code></p>
<p>This will convert your Matroska (MKV) files to MP4 files.</p>
<dl>
<dt>ffmpeg</dt><dd>starts the command</dd>
<dt>-i <em>input_file</em></dt><dd>path and name of the input file<br>
The extension for the Matroska container is <code>.mkv</code>.</dd>
<dt>-c:v copy</dt><dd>copies the video stream without re-encoding it</dd>
<dt>-c:a aac</dt><dd>re-encodes the audio stream using the AAC audio codec<br>
Note that sadly MP4 cannot contain sound encoded by a PCM (Pulse-Code Modulation) audio codec.<br>
For silent videos you can replace <code>-c:a aac</code> by <code>-an</code>, which means that there will be no audio track in the output file.</dd>
<dt><em>output_file</em></dt><dd>path and name of the output file<br>
The extension for the MP4 container is <code>.mp4</code>.</dd>
</dl>
<p class="link"></p>
</div>
<!-- ends MKV to MP4 -->
<!-- Rewrap DV --> <!-- Rewrap DV -->
<label class="recipe" for="rewrap-dv">Rewrap DV video to .dv file</label> <label class="recipe" for="rewrap-dv">Rewrap DV video to .dv file</label>
<input type="checkbox" id="rewrap-dv"> <input type="checkbox" id="rewrap-dv">
<div class="hiding"> <div class="hiding">
<h3>Rewrap DV video to .dv file</h3> <h5>Rewrap DV video to .dv file</h5>
<p><code>ffmpeg -i <em>input_file</em> -f rawvideo -c:v copy <em>output_file.dv</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -f rawvideo -c:v copy <em>output_file.dv</em></code></p>
<p>This script will take a video that is encoded in the <a href="https://en.wikipedia.org/wiki/DV" target="_blank">DV Codec</a> but wrapped in a different container (such as MOV) and rewrap it into a raw DV file (with the .dv extension). Since DV files potentially contain a great deal of provenance metadata within the DV stream, it is necessary to rewrap files in this method to avoid unintentional stripping of this metadata.</p> <p>This script will take a video that is encoded in the <a href="https://en.wikipedia.org/wiki/DV" target="_blank">DV Codec</a> but wrapped in a different container (such as MOV) and rewrap it into a raw DV file (with the .dv extension). Since DV files potentially contain a great deal of provenance metadata within the DV stream, it is necessary to rewrap files in this method to avoid unintentional stripping of this metadata.</p>
<dl> <dl>
@@ -260,7 +244,7 @@
<label class="recipe" for="to_prores">Transcode to deinterlaced Apple ProRes LT</label> <label class="recipe" for="to_prores">Transcode to deinterlaced Apple ProRes LT</label>
<input type="checkbox" id="to_prores"> <input type="checkbox" id="to_prores">
<div class="hiding"> <div class="hiding">
<h3>Transcode into a deinterlaced Apple ProRes LT</h3> <h5>Transcode into a deinterlaced Apple ProRes LT</h5>
<p><code>ffmpeg -i <em>input_file</em> -c:v prores -profile:v 1 -vf yadif -c:a pcm_s16le <em>output_file</em>.mov</code></p> <p><code>ffmpeg -i <em>input_file</em> -c:v prores -profile:v 1 -vf yadif -c:a pcm_s16le <em>output_file</em>.mov</code></p>
<p>This command transcodes an input file into a deinterlaced Apple ProRes 422 LT file with 16-bit linear PCM encoded audio. The file is deinterlaced using the yadif filter (Yet Another De-Interlacing Filter).</p> <p>This command transcodes an input file into a deinterlaced Apple ProRes 422 LT file with 16-bit linear PCM encoded audio. The file is deinterlaced using the yadif filter (Yet Another De-Interlacing Filter).</p>
<dl> <dl>
@@ -292,7 +276,7 @@
<label class="recipe" for="transcode_h264">Transcode to an H.264 access file</label> <label class="recipe" for="transcode_h264">Transcode to an H.264 access file</label>
<input type="checkbox" id="transcode_h264"> <input type="checkbox" id="transcode_h264">
<div class="hiding"> <div class="hiding">
<h3>Transcode to H.264</h3> <h5>Transcode to H.264</h5>
<p><code>ffmpeg -i <em>input_file</em> -c:v libx264 -pix_fmt yuv420p -c:a aac <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -c:v libx264 -pix_fmt yuv420p -c:a aac <em>output_file</em></code></p>
<p>This command takes an input file and transcodes it to H.264 with an .mp4 wrapper, audio is transcoded to AAC. The libx264 codec defaults to a “medium” preset for compression quality and a CRF of 23. CRF stands for constant rate factor and determines the quality and file size of the resulting H.264 video. A low CRF means high quality and large file size; a high CRF means the opposite.</p> <p>This command takes an input file and transcodes it to H.264 with an .mp4 wrapper, audio is transcoded to AAC. The libx264 codec defaults to a “medium” preset for compression quality and a CRF of 23. CRF stands for constant rate factor and determines the quality and file size of the resulting H.264 video. A low CRF means high quality and large file size; a high CRF means the opposite.</p>
<dl> <dl>
@@ -326,7 +310,7 @@
<label class="recipe" for="dcp_to_h264">Transcode from DCP to an H.264 access file</label> <label class="recipe" for="dcp_to_h264">Transcode from DCP to an H.264 access file</label>
<input type="checkbox" id="dcp_to_h264"> <input type="checkbox" id="dcp_to_h264">
<div class="hiding"> <div class="hiding">
<h3>H.264 from DCP</h3> <h5>H.264 from DCP</h5>
<p><code>ffmpeg -i <em>input_video_file</em>.mxf -i <em>input_audio_file</em>.mxf -c:v libx264 -pix_fmt yuv420p -c:a aac <em>output_file.mp4</em></code></p> <p><code>ffmpeg -i <em>input_video_file</em>.mxf -i <em>input_audio_file</em>.mxf -c:v libx264 -pix_fmt yuv420p -c:a aac <em>output_file.mp4</em></code></p>
<p>This will transcode MXF wrapped video and audio files to an H.264 encoded MP4 file. Please note this only works for unencrypted, single reel DCPs.</p> <p>This will transcode MXF wrapped video and audio files to an H.264 encoded MP4 file. Please note this only works for unencrypted, single reel DCPs.</p>
<dl> <dl>
@@ -353,7 +337,7 @@
<label class="recipe" for="create_FFV1_mkv">Transcode your file with the FFV1 Version 3 Codec in a Matroska container</label> <label class="recipe" for="create_FFV1_mkv">Transcode your file with the FFV1 Version 3 Codec in a Matroska container</label>
<input type="checkbox" id="create_FFV1_mkv"> <input type="checkbox" id="create_FFV1_mkv">
<div class="hiding"> <div class="hiding">
<h3>Create FFV1 Version 3 video in a Matroska container with framemd5 of input</h3> <h5>Create FFV1 Version 3 video in a Matroska container with framemd5 of input</h5>
<p><code>ffmpeg -i <em>input_file</em> -map 0 -dn -c:v ffv1 -level 3 -g 1 -slicecrc 1 -slices 16 -c:a copy <em>output_file</em>.mkv -f framemd5 -an <em>framemd5_output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -map 0 -dn -c:v ffv1 -level 3 -g 1 -slicecrc 1 -slices 16 -c:a copy <em>output_file</em>.mkv -f framemd5 -an <em>framemd5_output_file</em></code></p>
<p>This will losslessly transcode your video with the FFV1 Version 3 codec in a Matroska container. In order to verify losslessness, a framemd5 of the source video is also generated. For more information on FFV1 encoding, <a href="https://trac.ffmpeg.org/wiki/Encode/FFV1" target="_blank">try the FFmpeg wiki</a>.</p> <p>This will losslessly transcode your video with the FFV1 Version 3 codec in a Matroska container. In order to verify losslessness, a framemd5 of the source video is also generated. For more information on FFV1 encoding, <a href="https://trac.ffmpeg.org/wiki/Encode/FFV1" target="_blank">try the FFmpeg wiki</a>.</p>
<dl> <dl>
@@ -380,7 +364,7 @@
<label class="recipe" for="dvd_to_file">Convert DVD to H.264</label> <label class="recipe" for="dvd_to_file">Convert DVD to H.264</label>
<input type="checkbox" id="dvd_to_file"> <input type="checkbox" id="dvd_to_file">
<div class="hiding"> <div class="hiding">
<h3>Convert DVD to H.264</h3> <h5>Convert DVD to H.264</h5>
<p><code>ffmpeg -i concat:<em>input_file_1</em>\|<em>input_file_2</em>\|<em>input_file_3</em> -c:v libx264 -c:a aac <em>output_file</em>.mp4</code></p> <p><code>ffmpeg -i concat:<em>input_file_1</em>\|<em>input_file_2</em>\|<em>input_file_3</em> -c:v libx264 -c:a aac <em>output_file</em>.mp4</code></p>
<p>This command allows you to create an H.264 file from a DVD source that is not copy-protected.</p> <p>This command allows you to create an H.264 file from a DVD source that is not copy-protected.</p>
<p>Before encoding, youll need to establish which of the .VOB files on the DVD or .iso contain the content that you wish to encode. Inside the VIDEO_TS directory, you will see a series of files with names like VTS_01_0.VOB, VTS_01_1.VOB, etc. Some of the .VOB files will contain menus, special features, etc, so locate the ones that contain target content by playing them back in VLC.</p> <p>Before encoding, youll need to establish which of the .VOB files on the DVD or .iso contain the content that you wish to encode. Inside the VIDEO_TS directory, you will see a series of files with names like VTS_01_0.VOB, VTS_01_1.VOB, etc. Some of the .VOB files will contain menus, special features, etc, so locate the ones that contain target content by playing them back in VLC.</p>
@@ -414,7 +398,7 @@
<label class="recipe" for="transcode_h265">Transcode to an H.265/HEVC MP4</label> <label class="recipe" for="transcode_h265">Transcode to an H.265/HEVC MP4</label>
<input type="checkbox" id="transcode_h265"> <input type="checkbox" id="transcode_h265">
<div class="hiding"> <div class="hiding">
<h3>Transcode to H.265/HEVC</h3> <h5>Transcode to H.265/HEVC</h5>
<p><code>ffmpeg -i <em>input_file</em> -c:v libx265 -pix_fmt yuv420p -c:a copy <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -c:v libx265 -pix_fmt yuv420p -c:a copy <em>output_file</em></code></p>
<p>This command takes an input file and transcodes it to H.265/HEVC in an .mp4 wrapper, keeping the audio codec the same as in the original file.</p> <p>This command takes an input file and transcodes it to H.265/HEVC in an .mp4 wrapper, keeping the audio codec the same as in the original file.</p>
<p><strong>Note:</strong> FFmpeg must be compiled with libx265, the library of the H.265 codec, for this script to work. (Add the flag <code>--with-x265</code> if using the <code>brew install ffmpeg</code> method).</p> <p><strong>Note:</strong> FFmpeg must be compiled with libx265, the library of the H.265 codec, for this script to work. (Add the flag <code>--with-x265</code> if using the <code>brew install ffmpeg</code> method).</p>
@@ -442,7 +426,7 @@
<label class="recipe" for="transcode_ogg">Transcode to an Ogg Theora</label> <label class="recipe" for="transcode_ogg">Transcode to an Ogg Theora</label>
<input type="checkbox" id="transcode_ogg"> <input type="checkbox" id="transcode_ogg">
<div class="hiding"> <div class="hiding">
<h3>Transcode to Ogg/Theora</h3> <h5>Transcode to Ogg/Theora</h5>
<p><code>ffmpeg -i <em>input_file</em> -acodec libvorbis -b:v 690k <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -acodec libvorbis -b:v 690k <em>output_file</em></code></p>
<p>This command takes an input file and transcodes it to Ogg/Theora in an .ogv wrapper with 690k video bitrate.</p> <p>This command takes an input file and transcodes it to Ogg/Theora in an .ogv wrapper with 690k video bitrate.</p>
<p><strong>Note:</strong> FFmpeg must be installed with support for Ogg Theora. If you are using Homebrew, you can check with <code>brew info ffmpeg</code> and then update it with <code>brew upgrade ffmpeg --with-theora --with-libvorbis</code> if necessary.</p> <p><strong>Note:</strong> FFmpeg must be installed with support for Ogg Theora. If you are using Homebrew, you can check with <code>brew info ffmpeg</code> and then update it with <code>brew upgrade ffmpeg --with-theora --with-libvorbis</code> if necessary.</p>
@@ -465,15 +449,15 @@
<label class="recipe" for="wav_to_mp3">Convert WAV to MP3</label> <label class="recipe" for="wav_to_mp3">Convert WAV to MP3</label>
<input type="checkbox" id="wav_to_mp3"> <input type="checkbox" id="wav_to_mp3">
<div class="hiding"> <div class="hiding">
<h3>WAV to MP3</h3> <h5>WAV to MP3</h5>
<p><code>ffmpeg -i <em>input_file</em>.wav -write_id3v1 1 -id3v2_version 3 -dither_method rectangular -out_sample_rate 48k -qscale:a 1 <em>output_file</em>.mp3</code></p> <p><code>ffmpeg -i <em>input_file</em>.wav -write_id3v1 1 -id3v2_version 3 -dither_method triangular -out_sample_rate 48k -qscale:a 1 <em>output_file</em>.mp3</code></p>
<p>This will convert your WAV files to MP3s.</p> <p>This will convert your WAV files to MP3s.</p>
<dl> <dl>
<dt>ffmpeg</dt><dd>starts the command</dd> <dt>ffmpeg</dt><dd>starts the command</dd>
<dt>-i <em>input_file</em></dt><dd>path and name of the input file</dd> <dt>-i <em>input_file</em></dt><dd>path and name of the input file</dd>
<dt>-write_id3v1 1</dt><dd>This will write metadata to an ID3v1 tag at the head of the file, assuming youve embedded metadata into the WAV file.</dd> <dt>-write_id3v1 1</dt><dd>This will write metadata to an ID3v1 tag at the head of the file, assuming youve embedded metadata into the WAV file.</dd>
<dt>-id3v2_version 3</dt><dd>This will write metadata to an ID3v2.3 tag at the tail of the file, assuming youve embedded metadata into the WAV file.</dd> <dt>-id3v2_version 3</dt><dd>This will write metadata to an ID3v2.3 tag at the tail of the file, assuming youve embedded metadata into the WAV file.</dd>
<dt>-dither_method rectangular</dt><dd>Dither makes sure you dont unnecessarily truncate the dynamic range of your audio.</dd> <dt>-dither_method triangular</dt><dd>Dither makes sure you dont unnecessarily truncate the dynamic range of your audio.</dd>
<dt>-out_sample_rate 48k</dt><dd>Sets the audio sampling frequency to 48 kHz. This can be omitted to use the same sampling frequency as the input.</dd> <dt>-out_sample_rate 48k</dt><dd>Sets the audio sampling frequency to 48 kHz. This can be omitted to use the same sampling frequency as the input.</dd>
<dt>-qscale:a 1</dt><dd>This sets the encoder to use a constant quality with a variable bitrate of between 190-250kbit/s. If you would prefer to use a constant bitrate, this could be replaced with <code>-b:a 320k</code> to set to the maximum bitrate allowed by the MP3 format. For more detailed discussion on variable vs constant bitrates see <a href="https://trac.ffmpeg.org/wiki/Encode/MP3" target="_blank">here.</a></dd> <dt>-qscale:a 1</dt><dd>This sets the encoder to use a constant quality with a variable bitrate of between 190-250kbit/s. If you would prefer to use a constant bitrate, this could be replaced with <code>-b:a 320k</code> to set to the maximum bitrate allowed by the MP3 format. For more detailed discussion on variable vs constant bitrates see <a href="https://trac.ffmpeg.org/wiki/Encode/MP3" target="_blank">here.</a></dd>
<dt><em>output_file</em></dt><dd>path and name of the output file</dd> <dt><em>output_file</em></dt><dd>path and name of the output file</dd>
@@ -491,8 +475,8 @@
<label class="recipe" for="append_mp3">Generate two access MP3s (with and without copyright)</label> <label class="recipe" for="append_mp3">Generate two access MP3s (with and without copyright)</label>
<input type="checkbox" id="append_mp3"> <input type="checkbox" id="append_mp3">
<div class="hiding"> <div class="hiding">
<h3>Generate two access MP3s from input. One with appended audio (such as a copyright notice) and one unmodified.</h3> <h5>Generate two access MP3s from input. One with appended audio (such as a copyright notice) and one unmodified.</h5>
<p><code>ffmpeg -i <em>input_file</em> -i <em>input_file_to_append</em> -filter_complex "[0:a:0]asplit=2[a][b];[b]afifo[bb];[1:a:0][bb]concat=n=2:v=0:a=1[concatout]" -map "[a]" -codec:a libmp3lame -dither_method modified_e_weighted -qscale:a 2 <em>output_file.mp3</em> -map "[concatout]" -codec:a libmp3lame -dither_method modified_e_weighted -qscale:a 2 <em>output_file_appended.mp3</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -i <em>input_file_to_append</em> -filter_complex "[0:a:0]asplit=2[a][b];[b]afifo[bb];[1:a:0][bb]concat=n=2:v=0:a=1[concatout]" -map "[a]" -codec:a libmp3lame -dither_method triangular -qscale:a 2 <em>output_file.mp3</em> -map "[concatout]" -codec:a libmp3lame -dither_method triangular -qscale:a 2 <em>output_file_appended.mp3</em></code></p>
<p>This script allows you to generate two derivative audio files from a master while appending audio from a separate file (for example a copyright or institutional notice) to one of them.</p> <p>This script allows you to generate two derivative audio files from a master while appending audio from a separate file (for example a copyright or institutional notice) to one of them.</p>
<dl> <dl>
<dt>ffmpeg</dt><dd>starts the command</dd> <dt>ffmpeg</dt><dd>starts the command</dd>
@@ -503,10 +487,10 @@
<dt>[b]afifo[bb];</dt><dd>this buffers the stream "b" to help prevent dropped samples and renames stream to "bb"</dd> <dt>[b]afifo[bb];</dt><dd>this buffers the stream "b" to help prevent dropped samples and renames stream to "bb"</dd>
<dt>[1:a:0][bb]concat=n=2:v=0:a=1[concatout]</dt><dd><code>concat</code> is used to join files. <code>n=2</code> tells the filter there are two inputs. <code>v=0:a=1</code> Tells the filter there are 0 video outputs and 1 audio output. This command appends the audio from the second input to the beginning of stream "bb" and names the output "concatout"</dd> <dt>[1:a:0][bb]concat=n=2:v=0:a=1[concatout]</dt><dd><code>concat</code> is used to join files. <code>n=2</code> tells the filter there are two inputs. <code>v=0:a=1</code> Tells the filter there are 0 video outputs and 1 audio output. This command appends the audio from the second input to the beginning of stream "bb" and names the output "concatout"</dd>
<dt>-map "[a]"</dt><dd>this maps the unmodified audio stream to the first output</dd> <dt>-map "[a]"</dt><dd>this maps the unmodified audio stream to the first output</dd>
<dt>-codec:a libmp3lame -dither_method modified_e_weighted -qscale:a 2</dt><dd>sets up MP3 options (using constant quality)</dd> <dt>-codec:a libmp3lame -dither_method triangular -qscale:a 2</dt><dd>sets up MP3 options (using constant quality)</dd>
<dt><em>output_file</em></dt><dd>path, name and extension of the output file (unmodified)</dd> <dt><em>output_file</em></dt><dd>path, name and extension of the output file (unmodified)</dd>
<dt>-map "[concatout]"</dt><dd>this maps the modified stream to the second output</dd> <dt>-map "[concatout]"</dt><dd>this maps the modified stream to the second output</dd>
<dt>-codec:a libmp3lame -dither_method modified_e_weighted -qscale:a 2</dt><dd>sets up MP3 options (using constant quality)</dd> <dt>-codec:a libmp3lame -dither_method triangular -qscale:a 2</dt><dd>sets up MP3 options (using constant quality)</dd>
<dt><em>output_file_appended</em></dt><dd>path, name and extension of the output file (with appended notice)</dd> <dt><em>output_file_appended</em></dt><dd>path, name and extension of the output file (with appended notice)</dd>
</dl> </dl>
<p class="link"></p> <p class="link"></p>
@@ -517,15 +501,15 @@
<label class="recipe" for="wav_to_mp4">Convert WAV to AAC/MP4</label> <label class="recipe" for="wav_to_mp4">Convert WAV to AAC/MP4</label>
<input type="checkbox" id="wav_to_mp4"> <input type="checkbox" id="wav_to_mp4">
<div class="hiding"> <div class="hiding">
<h3>WAV to AAC/MP4</h3> <h5>WAV to AAC/MP4</h5>
<p><code>ffmpeg -i <em>input_file</em>.wav -c:a aac -b:a 128k -dither_method rectangular -ar 44100 <em>output_file</em>.mp4</code></p> <p><code>ffmpeg -i <em>input_file</em>.wav -c:a aac -b:a 128k -dither_method triangular -ar 44100 <em>output_file</em>.mp4</code></p>
<p>This will convert your WAV file to AAC/MP4.</p> <p>This will convert your WAV file to AAC/MP4.</p>
<dl> <dl>
<dt>ffmpeg</dt><dd>starts the command</dd> <dt>ffmpeg</dt><dd>starts the command</dd>
<dt>-i <em>input_file</em></dt><dd>path and name of the input file</dd> <dt>-i <em>input_file</em></dt><dd>path and name of the input file</dd>
<dt>-c:a aac</dt><dd>sets the audio codec to AAC</dd> <dt>-c:a aac</dt><dd>sets the audio codec to AAC</dd>
<dt>-b:a 128k</dt><dd>sets the bitrate of the audio to 128k</dd> <dt>-b:a 128k</dt><dd>sets the bitrate of the audio to 128k</dd>
<dt>-dither_method rectangular</dt><dd>Dither makes sure you dont unnecessarily truncate the dynamic range of your audio.</dd> <dt>-dither_method triangular</dt><dd>Dither makes sure you dont unnecessarily truncate the dynamic range of your audio.</dd>
<dt>-ar 44100</dt><dd>sets the audio sampling frequency to 44100 Hz, or 44.1 kHz, or “CD quality”</dd> <dt>-ar 44100</dt><dd>sets the audio sampling frequency to 44100 Hz, or 44.1 kHz, or “CD quality”</dd>
<dt><em>output_file</em></dt><dd>path and name of the output file</dd> <dt><em>output_file</em></dt><dd>path and name of the output file</dd>
</dl> </dl>
@@ -542,7 +526,7 @@
<label class="recipe" for="SD_HD">Transform 4:3 aspect ratio into 16:9 with pillarbox</label> <label class="recipe" for="SD_HD">Transform 4:3 aspect ratio into 16:9 with pillarbox</label>
<input type="checkbox" id="SD_HD"> <input type="checkbox" id="SD_HD">
<div class="hiding"> <div class="hiding">
<h3>Transform 4:3 aspect ratio into 16:9 with pillarbox</h3> <h5>Transform 4:3 aspect ratio into 16:9 with pillarbox</h5>
<p>Transform a video file with 4:3 aspect ratio into a video file with 16:9 aspect ratio by correct pillarboxing.</p> <p>Transform a video file with 4:3 aspect ratio into a video file with 16:9 aspect ratio by correct pillarboxing.</p>
<p><code>ffmpeg -i <em>input_file</em> -filter:v "pad=ih*16/9:ih:(ow-iw)/2:(oh-ih)/2" -c:a copy <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -filter:v "pad=ih*16/9:ih:(ow-iw)/2:(oh-ih)/2" -c:a copy <em>output_file</em></code></p>
<dl> <dl>
@@ -561,7 +545,7 @@
<label class="recipe" for="HD_SD">Transform 16:9 aspect ratio video into 4:3 with letterbox</label> <label class="recipe" for="HD_SD">Transform 16:9 aspect ratio video into 4:3 with letterbox</label>
<input type="checkbox" id="HD_SD"> <input type="checkbox" id="HD_SD">
<div class="hiding"> <div class="hiding">
<h3>Transform 16:9 aspect ratio video into 4:3 with letterbox</h3> <h5>Transform 16:9 aspect ratio video into 4:3 with letterbox</h5>
<p>Transform a video file with 16:9 aspect ratio into a video file with 4:3 aspect ratio by correct letterboxing.</p> <p>Transform a video file with 16:9 aspect ratio into a video file with 4:3 aspect ratio by correct letterboxing.</p>
<p><code>ffmpeg -i <em>input_file</em> -filter:v "pad=iw:iw*3/4:(ow-iw)/2:(oh-ih)/2" -c:a copy <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -filter:v "pad=iw:iw*3/4:(ow-iw)/2:(oh-ih)/2" -c:a copy <em>output_file</em></code></p>
<dl> <dl>
@@ -581,7 +565,7 @@
<label class="recipe" for="flip_image">Flip video image</label> <label class="recipe" for="flip_image">Flip video image</label>
<input type="checkbox" id="flip_image"> <input type="checkbox" id="flip_image">
<div class="hiding"> <div class="hiding">
<h3>Flip the video image horizontally and/or vertically</h3> <h5>Flip the video image horizontally and/or vertically</h5>
<p><code>ffmpeg -i <em>input_file</em> -filter:v "hflip,vflip" -c:a copy <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -filter:v "hflip,vflip" -c:a copy <em>output_file</em></code></p>
<dl> <dl>
<dt>ffmpeg</dt><dd>starts the command</dd> <dt>ffmpeg</dt><dd>starts the command</dd>
@@ -599,7 +583,7 @@
<label class="recipe" for="SD_HD_2">Transform SD to HD with pillarbox</label> <label class="recipe" for="SD_HD_2">Transform SD to HD with pillarbox</label>
<input type="checkbox" id="SD_HD_2"> <input type="checkbox" id="SD_HD_2">
<div class="hiding"> <div class="hiding">
<h3>Transform SD into HD with pillarbox</h3> <h5>Transform SD into HD with pillarbox</h5>
<p>Transform a SD video file with 4:3 aspect ratio into an HD video file with 16:9 aspect ratio by correct pillarboxing.</p> <p>Transform a SD video file with 4:3 aspect ratio into an HD video file with 16:9 aspect ratio by correct pillarboxing.</p>
<p><code>ffmpeg -i <em>input_file</em> -filter:v "colormatrix=bt601:bt709, scale=1440:1080:flags=lanczos, pad=1920:1080:240:0" -c:a copy <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -filter:v "colormatrix=bt601:bt709, scale=1440:1080:flags=lanczos, pad=1920:1080:240:0" -c:a copy <em>output_file</em></code></p>
<dl> <dl>
@@ -623,7 +607,7 @@
<label class="recipe" for="change_DAR">Change display aspect ratio without re-encoding</label> <label class="recipe" for="change_DAR">Change display aspect ratio without re-encoding</label>
<input type="checkbox" id="change_DAR"> <input type="checkbox" id="change_DAR">
<div class="hiding"> <div class="hiding">
<h3>Change Display Aspect Ratio without re-encoding video</h3> <h5>Change Display Aspect Ratio without re-encoding video</h5>
<p><code>ffmpeg -i <em>input_file</em> -c:v copy -aspect 4:3 <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -c:v copy -aspect 4:3 <em>output_file</em></code></p>
<dl> <dl>
<dt>ffmpeg</dt><dd>starts the command</dd> <dt>ffmpeg</dt><dd>starts the command</dd>
@@ -640,7 +624,7 @@
<label class="recipe" for="convert-colorspace">Convert colorspace of video</label> <label class="recipe" for="convert-colorspace">Convert colorspace of video</label>
<input type="checkbox" id="convert-colorspace"> <input type="checkbox" id="convert-colorspace">
<div class="hiding"> <div class="hiding">
<h3>Transcode video to a different colorspace</h3> <h5>Transcode video to a different colorspace</h5>
<p>This command uses a filter to convert the video to a different colorspace.</p> <p>This command uses a filter to convert the video to a different colorspace.</p>
<p><code>ffmpeg -i <em>input_file</em> -c:v libx264 -vf colormatrix=src:dst <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -c:v libx264 -vf colormatrix=src:dst <em>output_file</em></code></p>
<dl> <dl>
@@ -693,7 +677,7 @@
<label class="recipe" for="modify_speed">Modify image and sound speed</label> <label class="recipe" for="modify_speed">Modify image and sound speed</label>
<input type="checkbox" id="modify_speed"> <input type="checkbox" id="modify_speed">
<div class="hiding"> <div class="hiding">
<h3>Modify image and sound speed</h3> <h5>Modify image and sound speed</h5>
<p>E.g. for converting 24fps to 25fps with audio pitch compensation for PAL access copies. (Thanks @kieranjol!)</p> <p>E.g. for converting 24fps to 25fps with audio pitch compensation for PAL access copies. (Thanks @kieranjol!)</p>
<p><code>ffmpeg -i <em>input_file</em> -r <em>output_fps</em> -filter_complex "[0:v]setpts=<em>input_fps</em>/<em>output_fps</em>*PTS[v]; [0:a]atempo=<em>output_fps</em>/<em>input_fps</em>[a]" -map "[v]" -map "[a]" <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -r <em>output_fps</em> -filter_complex "[0:v]setpts=<em>input_fps</em>/<em>output_fps</em>*PTS[v]; [0:a]atempo=<em>output_fps</em>/<em>input_fps</em>[a]" -map "[v]" -map "[a]" <em>output_file</em></code></p>
<dl> <dl>
@@ -718,7 +702,7 @@
<label class="recipe" for="sync_streams">Synchronize video and audio streams</label> <label class="recipe" for="sync_streams">Synchronize video and audio streams</label>
<input type="checkbox" id="sync_streams"> <input type="checkbox" id="sync_streams">
<div class="hiding"> <div class="hiding">
<h3>Synchronize video and audio streams</h3> <h5>Synchronize video and audio streams</h5>
<p><code>ffmpeg -i <em>input_file</em> -itsoffset 0.125 -i <em>input_file</em> -map 1:v -map 0:a -c copy <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -itsoffset 0.125 -i <em>input_file</em> -map 1:v -map 0:a -c copy <em>output_file</em></code></p>
<p>A command to slip the video channel approximate 2 frames (0.125 for a 25fps timeline) to align video and audio drift, if generated during video tape capture for example.</p> <p>A command to slip the video channel approximate 2 frames (0.125 for a 25fps timeline) to align video and audio drift, if generated during video tape capture for example.</p>
<dl> <dl>
@@ -738,7 +722,7 @@
<label class="recipe" for="clarify_stream">Clarify stream properties</label> <label class="recipe" for="clarify_stream">Clarify stream properties</label>
<input type="checkbox" id="clarify_stream"> <input type="checkbox" id="clarify_stream">
<div class="hiding"> <div class="hiding">
<h3>Set stream properties</h3> <h5>Set stream properties</h5>
<h2>Find undetermined or unknown stream properties</h2> <h2>Find undetermined or unknown stream properties</h2>
<p>These examples use QuickTime inputs and outputs. The strategy will vary or may not be possible in other file formats. In the case of these examples it is the intention to make a lossless copy while clarifying an unknown characteristic of the stream.</p> <p>These examples use QuickTime inputs and outputs. The strategy will vary or may not be possible in other file formats. In the case of these examples it is the intention to make a lossless copy while clarifying an unknown characteristic of the stream.</p>
<p><code>ffprobe <em>input_file</em> -show_streams</code></p> <p><code>ffprobe <em>input_file</em> -show_streams</code></p>
@@ -775,7 +759,7 @@
<label class="recipe" for="crop_video">Crop video</label> <label class="recipe" for="crop_video">Crop video</label>
<input type="checkbox" id="crop_video"> <input type="checkbox" id="crop_video">
<div class="hiding"> <div class="hiding">
<h3>Crop video</h3> <h5>Crop video</h5>
<p><code>ffmpeg -i <em>input_file</em> -vf "crop=<em>width</em>:<em>height</em>" <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -vf "crop=<em>width</em>:<em>height</em>" <em>output_file</em></code></p>
<p>This command crops the input video to the dimensions defined</p> <p>This command crops the input video to the dimensions defined</p>
<dl> <dl>
@@ -788,7 +772,7 @@
</dl> </dl>
<p>It's also possible to specify the crop position by adding the x and y coordinates representing the top left of your cropped area to your crop filter, as such:</p> <p>It's also possible to specify the crop position by adding the x and y coordinates representing the top left of your cropped area to your crop filter, as such:</p>
<p><code>ffmpeg -i <em>input_file</em> -vf "crop=<em>width</em>:<em>height</em>[:<em>x_position</em>:<em>y_position</em>]" <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -vf "crop=<em>width</em>:<em>height</em>[:<em>x_position</em>:<em>y_position</em>]" <em>output_file</em></code></p>
<h3>Examples</h3> <h5>Examples</h5>
<p>The original frame, a screenshot of the SMPTE colorbars:</p> <p>The original frame, a screenshot of the SMPTE colorbars:</p>
<img class="sample-image" src="img/crop_example_orig.png" alt="VLC screenshot of Maggie Cheung"> <img class="sample-image" src="img/crop_example_orig.png" alt="VLC screenshot of Maggie Cheung">
<p>Result of the command <code>ffmpeg -i <em>smpte_colorsbars.mov</em> -vf "crop=500:500" <em>output_file</em></code>:</p> <p>Result of the command <code>ffmpeg -i <em>smpte_colorsbars.mov</em> -vf "crop=500:500" <em>output_file</em></code>:</p>
@@ -805,7 +789,7 @@
<label class="recipe" for="col_change">Change video color to black and white</label> <label class="recipe" for="col_change">Change video color to black and white</label>
<input type="checkbox" id="col_change"> <input type="checkbox" id="col_change">
<div class="hiding"> <div class="hiding">
<h3>Change video color to black and white</h3> <h5>Change video color to black and white</h5>
<p><code>ffmpeg -i <em>input_file</em> -filter_complex hue=s=0 -c:a copy <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -filter_complex hue=s=0 -c:a copy <em>output_file</em></code></p>
<p>A basic command to alter color hue to black and white using filter_complex (credit @FFMPEG via Twitter).</p> <p>A basic command to alter color hue to black and white using filter_complex (credit @FFMPEG via Twitter).</p>
<dl> <dl>
@@ -838,7 +822,7 @@
<label class="recipe" for="extract_audio">Extract audio without loss from an AV file</label> <label class="recipe" for="extract_audio">Extract audio without loss from an AV file</label>
<input type="checkbox" id="extract_audio"> <input type="checkbox" id="extract_audio">
<div class="hiding"> <div class="hiding">
<h3>Extract audio from an AV file</h3> <h5>Extract audio from an AV file</h5>
<p><code>ffmpeg -i <em>input_file</em> -c:a copy -vn <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -c:a copy -vn <em>output_file</em></code></p>
<p>This command extracts the audio stream without loss from an audiovisual file.</p> <p>This command extracts the audio stream without loss from an audiovisual file.</p>
<dl> <dl>
@@ -856,7 +840,7 @@
<label class="recipe" for="combine_audio">Combine audio tracks</label> <label class="recipe" for="combine_audio">Combine audio tracks</label>
<input type="checkbox" id="combine_audio"> <input type="checkbox" id="combine_audio">
<div class="hiding"> <div class="hiding">
<h3>Combine audio tracks into one in a video file</h3> <h5>Combine audio tracks into one in a video file</h5>
<p><code>ffmpeg -i <em>input_file</em> -filter_complex "[0:a:0][0:a:1]amerge[out]" -map 0:v -map "[out]" -c:v copy -shortest <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -filter_complex "[0:a:0][0:a:1]amerge[out]" -map 0:v -map "[out]" -c:v copy -shortest <em>output_file</em></code></p>
<p>This command combines two audio tracks present in a video file into one stream. It can be useful in situations where a downstream process, like YouTubes automatic captioning, expect one audio track. To ensure that youre mapping the right audio tracks run ffprobe before writing the script to identify which tracks are desired. More than two audio streams can be combined by extending the pattern present in the -filter_complex option.</p> <p>This command combines two audio tracks present in a video file into one stream. It can be useful in situations where a downstream process, like YouTubes automatic captioning, expect one audio track. To ensure that youre mapping the right audio tracks run ffprobe before writing the script to identify which tracks are desired. More than two audio streams can be combined by extending the pattern present in the -filter_complex option.</p>
<dl> <dl>
@@ -880,7 +864,7 @@
<label class="recipe" for="phase_shift">Inverses the audio phase of the second channel</label> <label class="recipe" for="phase_shift">Inverses the audio phase of the second channel</label>
<input type="checkbox" id="phase_shift"> <input type="checkbox" id="phase_shift">
<div class="hiding"> <div class="hiding">
<h3>Flip audio phase shift</h3> <h5>Flip audio phase shift</h5>
<p><code>ffmpeg -i <em>input_file</em> -af pan="stereo|c0=c0|c1=-1*c1" <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -af pan="stereo|c0=c0|c1=-1*c1" <em>output_file</em></code></p>
<p>This command inverses the audio phase of the second channel by rotating it 180°.</p> <p>This command inverses the audio phase of the second channel by rotating it 180°.</p>
<dl> <dl>
@@ -899,7 +883,7 @@
<label class="recipe" for="loudnorm_metadata">Calculate Loudness Levels</label> <label class="recipe" for="loudnorm_metadata">Calculate Loudness Levels</label>
<input type="checkbox" id="loudnorm_metadata"> <input type="checkbox" id="loudnorm_metadata">
<div class="hiding"> <div class="hiding">
<h3>Calculate Loudness Levels</h3> <h5>Calculate Loudness Levels</h5>
<p><code>ffmpeg -i <em>input_file</em> -af loudnorm=print_format=json -f null -</code></p> <p><code>ffmpeg -i <em>input_file</em> -af loudnorm=print_format=json -f null -</code></p>
<p>This filter calculates and outputs loudness information in json about an input file (labeled input) as well as what the levels would be if loudnorm were applied in its one pass mode (labeled output). The values generated can be used as inputs for a 'second pass' of the loudnorm filter allowing more accurate loudness normalization than if it is used in a single pass.</p> <p>This filter calculates and outputs loudness information in json about an input file (labeled input) as well as what the levels would be if loudnorm were applied in its one pass mode (labeled output). The values generated can be used as inputs for a 'second pass' of the loudnorm filter allowing more accurate loudness normalization than if it is used in a single pass.</p>
<p>These instructions use the loudnorm defaults, which align well with PBS recommendations for target loudness. More information can be found at the <a href="https://ffmpeg.org/ffmpeg-filters.html#loudnorm" target="_blank">loudnorm documentation</a>.</p> <p>These instructions use the loudnorm defaults, which align well with PBS recommendations for target loudness. More information can be found at the <a href="https://ffmpeg.org/ffmpeg-filters.html#loudnorm" target="_blank">loudnorm documentation</a>.</p>
@@ -919,7 +903,7 @@
<label class="recipe" for="riaa_eq">RIAA Equalization</label> <label class="recipe" for="riaa_eq">RIAA Equalization</label>
<input type="checkbox" id="riaa_eq"> <input type="checkbox" id="riaa_eq">
<div class="hiding"> <div class="hiding">
<h3>RIAA Equalization</h3> <h5>RIAA Equalization</h5>
<p><code>ffmpeg -i <em>input_file</em> -af aemphasis=type=riaa <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -af aemphasis=type=riaa <em>output_file</em></code></p>
<p>This will apply RIAA equalization to an input file allowing correct listening of audio transferred 'flat' (without EQ) from records that used this EQ curve. For more information about RIAA equalization see the <a href="https://en.wikipedia.org/wiki/RIAA_equalization" target="_blank">Wikipedia page</a> on the subject.</p> <p>This will apply RIAA equalization to an input file allowing correct listening of audio transferred 'flat' (without EQ) from records that used this EQ curve. For more information about RIAA equalization see the <a href="https://en.wikipedia.org/wiki/RIAA_equalization" target="_blank">Wikipedia page</a> on the subject.</p>
<dl> <dl>
@@ -936,7 +920,7 @@
<label class="recipe" for="cd_eq">Reverse CD Pre-Emphasis</label> <label class="recipe" for="cd_eq">Reverse CD Pre-Emphasis</label>
<input type="checkbox" id="cd_eq"> <input type="checkbox" id="cd_eq">
<div class="hiding"> <div class="hiding">
<h3>Reverse CD Pre-Emphasis</h3> <h5>Reverse CD Pre-Emphasis</h5>
<p><code>ffmpeg -i <em>input_file</em> -af aemphasis=type=cd <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -af aemphasis=type=cd <em>output_file</em></code></p>
<p>This will apply de-emphasis to reverse the effects of CD pre-emphasis in the somewhat rare case of CDs that were created with this technology. Use this command to create more accurate listening copies of files that were ripped 'flat' (without any de-emphasis) where the original source utilized emphasis. For more information about CD pre-emphasis see the <a href="https://wiki.hydrogenaud.io/index.php?title=Pre-emphasis" target="_blank">Hydrogen Audio page</a> on this subject.</p> <p>This will apply de-emphasis to reverse the effects of CD pre-emphasis in the somewhat rare case of CDs that were created with this technology. Use this command to create more accurate listening copies of files that were ripped 'flat' (without any de-emphasis) where the original source utilized emphasis. For more information about CD pre-emphasis see the <a href="https://wiki.hydrogenaud.io/index.php?title=Pre-emphasis" target="_blank">Hydrogen Audio page</a> on this subject.</p>
<dl> <dl>
@@ -953,7 +937,7 @@
<label class="recipe" for="loudnorm_one_pass">One Pass Loudness Normalization</label> <label class="recipe" for="loudnorm_one_pass">One Pass Loudness Normalization</label>
<input type="checkbox" id="loudnorm_one_pass"> <input type="checkbox" id="loudnorm_one_pass">
<div class="hiding"> <div class="hiding">
<h3>One Pass Loudness Normalization</h3> <h5>One Pass Loudness Normalization</h5>
<p><code>ffmpeg -i <em>input_file</em> -af loudnorm=dual_mono=true -ar 48k <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -af loudnorm=dual_mono=true -ar 48k <em>output_file</em></code></p>
<p>This will normalize the loudness of an input using one pass, which is quicker but less accurate than using two passes. This command uses the loudnorm filter defaults for target loudness. These defaults align well with PBS recommendations, but loudnorm does allow targeting of specific loudness levels. More information can be found at the <a href="https://ffmpeg.org/ffmpeg-filters.html#loudnorm" target="_blank">loudnorm documentation</a>.</p> <p>This will normalize the loudness of an input using one pass, which is quicker but less accurate than using two passes. This command uses the loudnorm filter defaults for target loudness. These defaults align well with PBS recommendations, but loudnorm does allow targeting of specific loudness levels. More information can be found at the <a href="https://ffmpeg.org/ffmpeg-filters.html#loudnorm" target="_blank">loudnorm documentation</a>.</p>
<p>Information about PBS loudness standards can be found in the <a href="https://www-tc.pbs.org/capt/Producing/TOS-2012-Pt2-Distribution.pdf" target="_blank">PBS Technical Operating Specifications</a> document. Information about EBU loudness standards can be found in the <a href="https://tech.ebu.ch/docs/r/r128-2014.pdf" target="_blank">EBU R 128</a> recommendation document.</p> <p>Information about PBS loudness standards can be found in the <a href="https://www-tc.pbs.org/capt/Producing/TOS-2012-Pt2-Distribution.pdf" target="_blank">PBS Technical Operating Specifications</a> document. Information about EBU loudness standards can be found in the <a href="https://tech.ebu.ch/docs/r/r128-2014.pdf" target="_blank">EBU R 128</a> recommendation document.</p>
@@ -973,7 +957,7 @@
<label class="recipe" for="loudnorm_two_pass">Two Pass Loudness Normalization</label> <label class="recipe" for="loudnorm_two_pass">Two Pass Loudness Normalization</label>
<input type="checkbox" id="loudnorm_two_pass"> <input type="checkbox" id="loudnorm_two_pass">
<div class="hiding"> <div class="hiding">
<h3>Two Pass Loudness Normalization</h3> <h5>Two Pass Loudness Normalization</h5>
<p><code>ffmpeg -i <em>input_file</em> -af loudnorm=dual_mono=true:measured_I=<em>input_i</em>:measured_TP=<em>input_tp</em>:measured_LRA=<em>input_lra</em>:measured_thresh=<em>input_thresh</em>:offset=<em>target_offset</em>:linear=true -ar 48k <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -af loudnorm=dual_mono=true:measured_I=<em>input_i</em>:measured_TP=<em>input_tp</em>:measured_LRA=<em>input_lra</em>:measured_thresh=<em>input_thresh</em>:offset=<em>target_offset</em>:linear=true -ar 48k <em>output_file</em></code></p>
<p>This command allows using the levels calculated using a <a href="#loudnorm_metadata">first pass of the loudnorm filter</a> to more accurately normalize loudness. This command uses the loudnorm filter defaults for target loudness. These defaults align well with PBS recommendations, but loudnorm does allow targeting of specific loudness levels. More information can be found at the <a href="https://ffmpeg.org/ffmpeg-filters.html#loudnorm" target="_blank">loudnorm documentation</a>.</p> <p>This command allows using the levels calculated using a <a href="#loudnorm_metadata">first pass of the loudnorm filter</a> to more accurately normalize loudness. This command uses the loudnorm filter defaults for target loudness. These defaults align well with PBS recommendations, but loudnorm does allow targeting of specific loudness levels. More information can be found at the <a href="https://ffmpeg.org/ffmpeg-filters.html#loudnorm" target="_blank">loudnorm documentation</a>.</p>
<p>Information about PBS loudness standards can be found in the <a href="https://www-tc.pbs.org/capt/Producing/TOS-2012-Pt2-Distribution.pdf" target="_blank">PBS Technical Operating Specifications</a> document. Information about EBU loudness standards can be found in the <a href="https://tech.ebu.ch/docs/r/r128-2014.pdf" target="_blank">EBU R 128</a> recommendation document.</p> <p>Information about PBS loudness standards can be found in the <a href="https://www-tc.pbs.org/capt/Producing/TOS-2012-Pt2-Distribution.pdf" target="_blank">PBS Technical Operating Specifications</a> document. Information about EBU loudness standards can be found in the <a href="https://tech.ebu.ch/docs/r/r128-2014.pdf" target="_blank">EBU R 128</a> recommendation document.</p>
@@ -999,7 +983,7 @@
<label class="recipe" for="avsync_aresample">Fix A/V sync issues by resampling audio</label> <label class="recipe" for="avsync_aresample">Fix A/V sync issues by resampling audio</label>
<input type="checkbox" id="avsync_aresample"> <input type="checkbox" id="avsync_aresample">
<div class="hiding"> <div class="hiding">
<h3>Fix AV Sync: Resample audio</h3> <h5>Fix AV Sync: Resample audio</h5>
<p><code>ffmpeg -i <em>input_file</em> -c:v copy -c:a pcm_s16le -af "aresample=async=1000" <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -c:v copy -c:a pcm_s16le -af "aresample=async=1000" <em>output_file</em></code></p>
<dl> <dl>
<dt>ffmpeg</dt><dd>starts the command</dd> <dt>ffmpeg</dt><dd>starts the command</dd>
@@ -1021,7 +1005,7 @@
<label class="recipe" for="join_files">Join (concatenate) two or more files of the same type</label> <label class="recipe" for="join_files">Join (concatenate) two or more files of the same type</label>
<input type="checkbox" id="join_files"> <input type="checkbox" id="join_files">
<div class="hiding"> <div class="hiding">
<h3>Join files together</h3> <h5>Join files together</h5>
<p><code>ffmpeg -f concat -i mylist.txt -c copy <em>output_file</em></code></p> <p><code>ffmpeg -f concat -i mylist.txt -c copy <em>output_file</em></code></p>
<p>This command takes two or more files of the same file type and joins them together to make a single file. All that the program needs is a text file with a list specifying the files that should be joined. However, it only works properly if the files to be combined have the exact same codec and technical specifications. Be careful, FFmpeg may appear to have successfully joined two video files with different codecs, but may only bring over the audio from the second file or have other weird behaviors. Dont use this command for joining files with different codecs and technical specs and always preview your resulting video file!</p> <p>This command takes two or more files of the same file type and joins them together to make a single file. All that the program needs is a text file with a list specifying the files that should be joined. However, it only works properly if the files to be combined have the exact same codec and technical specifications. Be careful, FFmpeg may appear to have successfully joined two video files with different codecs, but may only bring over the audio from the second file or have other weird behaviors. Dont use this command for joining files with different codecs and technical specs and always preview your resulting video file!</p>
<dl> <dl>
@@ -1048,7 +1032,7 @@
<label class="recipe" for="join_different_files">Join (concatenate) two or more files of different types</label> <label class="recipe" for="join_different_files">Join (concatenate) two or more files of different types</label>
<input type="checkbox" id="join_different_files"> <input type="checkbox" id="join_different_files">
<div class="hiding"> <div class="hiding">
<h3>Join files together</h3> <h5>Join files together</h5>
<p><code>ffmpeg -i input_1.avi -i input_2.mp4 -filter_complex "[0:v:0][0:a:0][1:v:0][1:a:0]concat=n=2:v=1:a=1[video_out][audio_out]" -map "[video_out]" -map "[audio_out]" <em>output_file</em></code></p> <p><code>ffmpeg -i input_1.avi -i input_2.mp4 -filter_complex "[0:v:0][0:a:0][1:v:0][1:a:0]concat=n=2:v=1:a=1[video_out][audio_out]" -map "[video_out]" -map "[audio_out]" <em>output_file</em></code></p>
<p>This command takes two or more files of the different file types and joins them together to make a single file.</p> <p>This command takes two or more files of the different file types and joins them together to make a single file.</p>
<p>The input files may differ in many respects - container, codec, chroma subsampling scheme, framerate, etc. However, the above command only works properly if the files to be combined have the same dimensions (e.g., 720x576). Also note that if the input files have different framerates, then the output file will be of variable framerate.</p> <p>The input files may differ in many respects - container, codec, chroma subsampling scheme, framerate, etc. However, the above command only works properly if the files to be combined have the same dimensions (e.g., 720x576). Also note that if the input files have different framerates, then the output file will be of variable framerate.</p>
@@ -1082,7 +1066,7 @@
<p>For example, to ensure that the video stream of the output file is visually lossless H.264 with a 4:2:0 chroma subsampling scheme, the command above could be amended to include the following:<br> <p>For example, to ensure that the video stream of the output file is visually lossless H.264 with a 4:2:0 chroma subsampling scheme, the command above could be amended to include the following:<br>
<code>-map "[video_out]" -c:v libx264 -pix_fmt yuv420p -preset veryslow -crf 18</code></p> <code>-map "[video_out]" -c:v libx264 -pix_fmt yuv420p -preset veryslow -crf 18</code></p>
<p>Likewise, to encode the output audio stream as mp3, the command could include the following:<br> <p>Likewise, to encode the output audio stream as mp3, the command could include the following:<br>
<code>-map "[audio_out]" -c:a libmp3lame -dither_method modified_e_weighted -qscale:a 2</code></p> <code>-map "[audio_out]" -c:a libmp3lame -dither_method triangular -qscale:a 2</code></p>
<h4>Variation: concatenating files of different resolutions</h4> <h4>Variation: concatenating files of different resolutions</h4>
<p>To concatenate files of different resolutions, you need to resize the videos to have matching resolutions prior to concatenation. The most basic way to do this is by using a scale filter and giving the dimensions of the file you wish to match:</p> <p>To concatenate files of different resolutions, you need to resize the videos to have matching resolutions prior to concatenation. The most basic way to do this is by using a scale filter and giving the dimensions of the file you wish to match:</p>
<p><code>-vf scale=1920:1080:flags=lanczos</code></p> <p><code>-vf scale=1920:1080:flags=lanczos</code></p>
@@ -1107,7 +1091,7 @@
<label class="recipe" for="segment_file">Split one file into several smaller segments</label> <label class="recipe" for="segment_file">Split one file into several smaller segments</label>
<input type="checkbox" id="segment_file"> <input type="checkbox" id="segment_file">
<div class="hiding"> <div class="hiding">
<h3>Split file into segments</h3> <h5>Split file into segments</h5>
<p><code>ffmpeg -i <em>input_file</em> -c copy -map 0 -f segment -segment_time 60 -reset_timestamps 1 <em>output_file-%03d.mkv</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -c copy -map 0 -f segment -segment_time 60 -reset_timestamps 1 <em>output_file-%03d.mkv</em></code></p>
<dl> <dl>
<dt>ffmpeg</dt><dd>Starts the command.</dd> <dt>ffmpeg</dt><dd>Starts the command.</dd>
@@ -1138,7 +1122,7 @@
<label class="recipe" for="trim">Trim file</label> <label class="recipe" for="trim">Trim file</label>
<input type="checkbox" id="trim"> <input type="checkbox" id="trim">
<div class="hiding"> <div class="hiding">
<h3>Trim a video without re-encoding</h3> <h5>Trim a video without re-encoding</h5>
<p><code>ffmpeg -i <em>input_file</em> -ss 00:02:00 -to 00:55:00 -c copy -map 0 <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -ss 00:02:00 -to 00:55:00 -c copy -map 0 <em>output_file</em></code></p>
<p>This command allows you to create an excerpt from a file without re-encoding the audiovisual data.</p> <p>This command allows you to create an excerpt from a file without re-encoding the audiovisual data.</p>
<dl> <dl>
@@ -1165,7 +1149,7 @@
<label class="recipe" for="excerpt_from_start">Create an excerpt, starting from the beginning of the file</label> <label class="recipe" for="excerpt_from_start">Create an excerpt, starting from the beginning of the file</label>
<input type="checkbox" id="excerpt_from_start"> <input type="checkbox" id="excerpt_from_start">
<div class="hiding"> <div class="hiding">
<h3>Excerpt from beginning</h3> <h5>Excerpt from beginning</h5>
<p><code>ffmpeg -i <em>input_file</em> -t <em>5</em> -c copy -map 0 <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -t <em>5</em> -c copy -map 0 <em>output_file</em></code></p>
<p>This command captures a certain portion of a file, starting from the beginning and continuing for the amount of time (in seconds) specified in the script. This can be used to create a preview file, or to remove unwanted content from the end of the file. To be more specific, use timecode, such as 00:00:05.</p> <p>This command captures a certain portion of a file, starting from the beginning and continuing for the amount of time (in seconds) specified in the script. This can be used to create a preview file, or to remove unwanted content from the end of the file. To be more specific, use timecode, such as 00:00:05.</p>
<dl> <dl>
@@ -1184,7 +1168,7 @@
<label class="recipe" for="excerpt_to_end">Create a new file with the first five seconds trimmed off the original</label> <label class="recipe" for="excerpt_to_end">Create a new file with the first five seconds trimmed off the original</label>
<input type="checkbox" id="excerpt_to_end"> <input type="checkbox" id="excerpt_to_end">
<div class="hiding"> <div class="hiding">
<h3>Excerpt to end</h3> <h5>Excerpt to end</h5>
<p><code>ffmpeg -i <em>input_file</em> -ss <em>5</em> -c copy -map 0 <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -ss <em>5</em> -c copy -map 0 <em>output_file</em></code></p>
<p>This command copies a file starting from a specified time, removing the first few seconds from the output. This can be used to create an excerpt, or remove unwanted content from the beginning of a file.</p> <p>This command copies a file starting from a specified time, removing the first few seconds from the output. This can be used to create an excerpt, or remove unwanted content from the beginning of a file.</p>
<dl> <dl>
@@ -1203,7 +1187,7 @@
<label class="recipe" for="excerpt_from_end">Create a new file with the final five seconds of the original</label> <label class="recipe" for="excerpt_from_end">Create a new file with the final five seconds of the original</label>
<input type="checkbox" id="excerpt_from_end"> <input type="checkbox" id="excerpt_from_end">
<div class="hiding"> <div class="hiding">
<h3>Excerpt from end</h3> <h5>Excerpt from end</h5>
<p><code>ffmpeg -sseof <em>-5</em> -i <em>input_file</em> -c copy -map 0 <em>output_file</em></code></p> <p><code>ffmpeg -sseof <em>-5</em> -i <em>input_file</em> -c copy -map 0 <em>output_file</em></code></p>
<p>This command copies a file starting from a specified time before the end of the file, removing everything before from the output. This can be used to create an excerpt, or extract content from the end of a file (e.g. for extracting the closing credits).</p> <p>This command copies a file starting from a specified time before the end of the file, removing everything before from the output. This can be used to create an excerpt, or extract content from the end of a file (e.g. for extracting the closing credits).</p>
<dl> <dl>
@@ -1222,7 +1206,7 @@
<label class="recipe" for="trim_start_silence">Trim silence from beginning of an audio file</label> <label class="recipe" for="trim_start_silence">Trim silence from beginning of an audio file</label>
<input type="checkbox" id="trim_start_silence"> <input type="checkbox" id="trim_start_silence">
<div class="hiding"> <div class="hiding">
<h3>Remove silent portion at the beginning of an audio file</h3> <h5>Remove silent portion at the beginning of an audio file</h5>
<p><code>ffmpeg -i <em>input_file</em> -af silenceremove=start_threshold=-57dB:start_duration=1:start_periods=1 -c:a <em>your_codec_choice</em> -ar <em>your_sample_rate_choice</em> <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -af silenceremove=start_threshold=-57dB:start_duration=1:start_periods=1 -c:a <em>your_codec_choice</em> -ar <em>your_sample_rate_choice</em> <em>output_file</em></code></p>
<p>This command will automatically remove silence at the beginning of an audio file. The threshold for what qualifies as silence can be changed - this example uses anything under -57 dB, which is a decent level for accounting for analogue hiss.</p> <p>This command will automatically remove silence at the beginning of an audio file. The threshold for what qualifies as silence can be changed - this example uses anything under -57 dB, which is a decent level for accounting for analogue hiss.</p>
<p><strong>Note:</strong> Since this command uses a filter, the audio stream will be re-encoded for the output. If you do not specify a sample rate or codec, this command will use the sample rate from your input and <a href='#codec-defaults'>the codec defaults for your output format</a>. Take care that you are getting your intended results!</p> <p><strong>Note:</strong> Since this command uses a filter, the audio stream will be re-encoded for the output. If you do not specify a sample rate or codec, this command will use the sample rate from your input and <a href='#codec-defaults'>the codec defaults for your output format</a>. Take care that you are getting your intended results!</p>
@@ -1243,7 +1227,7 @@
<label class="recipe" for="trim_end_silence">Trim silence from the end of an audio file</label> <label class="recipe" for="trim_end_silence">Trim silence from the end of an audio file</label>
<input type="checkbox" id="trim_end_silence"> <input type="checkbox" id="trim_end_silence">
<div class="hiding"> <div class="hiding">
<h3>Remove silent portion from the end of an audio file</h3> <h5>Remove silent portion from the end of an audio file</h5>
<p><code>ffmpeg -i <em>input_file</em> -af areverse,silenceremove=start_threshold=-57dB:start_duration=1:start_periods=1,areverse -c:a <em>your_codec_choice</em> -ar <em>your_sample_rate_choice</em> <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -af areverse,silenceremove=start_threshold=-57dB:start_duration=1:start_periods=1,areverse -c:a <em>your_codec_choice</em> -ar <em>your_sample_rate_choice</em> <em>output_file</em></code></p>
<p>This command will automatically remove silence at the end of an audio file. Since the <code>silenceremove</code> filter is best at removing silence from the beginning of files, this command used the <code>areverse</code> filter twice to reverse the input, remove silence and then restore correct orientation.</p> <p>This command will automatically remove silence at the end of an audio file. Since the <code>silenceremove</code> filter is best at removing silence from the beginning of files, this command used the <code>areverse</code> filter twice to reverse the input, remove silence and then restore correct orientation.</p>
<p><strong>Note:</strong> Since this command uses a filter, the audio stream will be re-encoded for the output. If you do not specify a sample rate or codec, this command will use the sample rate from your input and <a href='#codec-defaults'>the codec defaults for your output format</a>. Take care that you are getting your intended results!</p> <p><strong>Note:</strong> Since this command uses a filter, the audio stream will be re-encoded for the output. If you do not specify a sample rate or codec, this command will use the sample rate from your input and <a href='#codec-defaults'>the codec defaults for your output format</a>. Take care that you are getting your intended results!</p>
@@ -1270,7 +1254,7 @@
<label class="recipe" for="ntsc_to_h264">Upscaled, pillar-boxed HD H.264 access files from SD NTSC source</label> <label class="recipe" for="ntsc_to_h264">Upscaled, pillar-boxed HD H.264 access files from SD NTSC source</label>
<input type="checkbox" id="ntsc_to_h264"> <input type="checkbox" id="ntsc_to_h264">
<div class="hiding"> <div class="hiding">
<h3>Upscaled, Pillar-boxed HD H.264 Access Files from SD NTSC source</h3> <h5>Upscaled, Pillar-boxed HD H.264 Access Files from SD NTSC source</h5>
<p><code>ffmpeg -i <em>input_file</em> -c:v libx264 -filter:v "yadif, scale=1440:1080:flags=lanczos, pad=1920:1080:(ow-iw)/2:(oh-ih)/2, format=yuv420p" <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -c:v libx264 -filter:v "yadif, scale=1440:1080:flags=lanczos, pad=1920:1080:(ow-iw)/2:(oh-ih)/2, format=yuv420p" <em>output_file</em></code></p>
<dl> <dl>
<dt>ffmpeg</dt><dd>starts the command</dd> <dt>ffmpeg</dt><dd>starts the command</dd>
@@ -1295,7 +1279,7 @@
<label class="recipe" for="deinterlace">Deinterlace video</label> <label class="recipe" for="deinterlace">Deinterlace video</label>
<input type="checkbox" id="deinterlace"> <input type="checkbox" id="deinterlace">
<div class="hiding"> <div class="hiding">
<h3>Deinterlace a video</h3> <h5>Deinterlace a video</h5>
<p><code>ffmpeg -i <em>input_file</em> -c:v libx264 -vf "yadif,format=yuv420p" <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -c:v libx264 -vf "yadif,format=yuv420p" <em>output_file</em></code></p>
<p>This command takes an interlaced input file and outputs a deinterlaced H.264 MP4.</p> <p>This command takes an interlaced input file and outputs a deinterlaced H.264 MP4.</p>
<dl> <dl>
@@ -1330,7 +1314,7 @@
<label class="recipe" for="inverse-telecine">Inverse telecine</label> <label class="recipe" for="inverse-telecine">Inverse telecine</label>
<input type="checkbox" id="inverse-telecine"> <input type="checkbox" id="inverse-telecine">
<div class="hiding"> <div class="hiding">
<h3>Inverse telecine a video file</h3> <h5>Inverse telecine a video file</h5>
<p><code>ffmpeg -i <em>input_file</em> -c:v libx264 -vf "fieldmatch,yadif,decimate" <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -c:v libx264 -vf "fieldmatch,yadif,decimate" <em>output_file</em></code></p>
<p>The inverse telecine procedure reverses the <a href="https://en.wikipedia.org/wiki/Three-two_pull_down" target="_blank">3:2 pull down</a> process, restoring 29.97fps interlaced video to the 24fps frame rate of the original film source.</p> <p>The inverse telecine procedure reverses the <a href="https://en.wikipedia.org/wiki/Three-two_pull_down" target="_blank">3:2 pull down</a> process, restoring 29.97fps interlaced video to the 24fps frame rate of the original film source.</p>
<dl> <dl>
@@ -1361,7 +1345,7 @@
<label class="recipe" for="set_field_order">Set field order for interlaced video</label> <label class="recipe" for="set_field_order">Set field order for interlaced video</label>
<input type="checkbox" id="set_field_order"> <input type="checkbox" id="set_field_order">
<div class="hiding"> <div class="hiding">
<h3>Change field order of an interlaced video</h3> <h5>Change field order of an interlaced video</h5>
<p><code>ffmpeg -i <em>input_file</em> -c:v <em>video_codec</em> -filter:v setfield=tff <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -c:v <em>video_codec</em> -filter:v setfield=tff <em>output_file</em></code></p>
<dl> <dl>
<dt>ffmpeg</dt><dd>starts the command</dd> <dt>ffmpeg</dt><dd>starts the command</dd>
@@ -1378,7 +1362,7 @@
<label class="recipe" for="check_interlacement">Identify interlacement patterns in a video file</label> <label class="recipe" for="check_interlacement">Identify interlacement patterns in a video file</label>
<input type="checkbox" id="check_interlacement"> <input type="checkbox" id="check_interlacement">
<div class="hiding"> <div class="hiding">
<h3>Check video file interlacement patterns</h3> <h5>Check video file interlacement patterns</h5>
<p><code>ffmpeg -i <em>input file</em> -filter:v idet -f null -</code></p> <p><code>ffmpeg -i <em>input file</em> -filter:v idet -f null -</code></p>
<dl> <dl>
<dt>ffmpeg</dt><dd>starts the command</dd> <dt>ffmpeg</dt><dd>starts the command</dd>
@@ -1399,7 +1383,7 @@
<label class="recipe" for="text_watermark">Create opaque centered text watermark</label> <label class="recipe" for="text_watermark">Create opaque centered text watermark</label>
<input type="checkbox" id="text_watermark"> <input type="checkbox" id="text_watermark">
<div class="hiding"> <div class="hiding">
<h3>Create centered, transparent text watermark</h3> <h5>Create centered, transparent text watermark</h5>
<p>E.g For creating access copies with your institutions name</p> <p>E.g For creating access copies with your institutions name</p>
<p><code>ffmpeg -i <em>input_file</em> -vf drawtext="fontfile=<em>font_path</em>:fontsize=<em>font_size</em>:text=<em>watermark_text</em>:fontcolor=<em>font_color</em>:alpha=0.4:x=(w-text_w)/2:y=(h-text_h)/2" <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -vf drawtext="fontfile=<em>font_path</em>:fontsize=<em>font_size</em>:text=<em>watermark_text</em>:fontcolor=<em>font_color</em>:alpha=0.4:x=(w-text_w)/2:y=(h-text_h)/2" <em>output_file</em></code></p>
<dl> <dl>
@@ -1425,7 +1409,7 @@
<label class="recipe" for="image_watermark">Overlay image watermark on video</label> <label class="recipe" for="image_watermark">Overlay image watermark on video</label>
<input type="checkbox" id="image_watermark"> <input type="checkbox" id="image_watermark">
<div class="hiding"> <div class="hiding">
<h3>Overlay image watermark on video</h3> <h5>Overlay image watermark on video</h5>
<p><code>ffmpeg -i <em>input_video file</em> -i <em>input_image_file</em> -filter_complex overlay=main_w-overlay_w-5:5 <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_video file</em> -i <em>input_image_file</em> -filter_complex overlay=main_w-overlay_w-5:5 <em>output_file</em></code></p>
<dl> <dl>
<dt>ffmpeg</dt><dd>starts the command</dd> <dt>ffmpeg</dt><dd>starts the command</dd>
@@ -1442,7 +1426,7 @@
<label class="recipe" for="burn_in_timecode">Burn in timecode</label> <label class="recipe" for="burn_in_timecode">Burn in timecode</label>
<input type="checkbox" id="burn_in_timecode"> <input type="checkbox" id="burn_in_timecode">
<div class="hiding"> <div class="hiding">
<h3>Create a burnt in timecode on your image</h3> <h5>Create a burnt in timecode on your image</h5>
<p><code>ffmpeg -i <em>input_file</em> -vf drawtext="fontfile=<em>font_path</em>:fontsize=<em>font_size</em>:timecode=<em>starting_timecode</em>:fontcolor=<em>font_colour</em>:box=1:boxcolor=<em>box_colour</em>:rate=<em>timecode_rate</em>:x=(w-text_w)/2:y=h/1.2" <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -vf drawtext="fontfile=<em>font_path</em>:fontsize=<em>font_size</em>:timecode=<em>starting_timecode</em>:fontcolor=<em>font_colour</em>:box=1:boxcolor=<em>box_colour</em>:rate=<em>timecode_rate</em>:x=(w-text_w)/2:y=h/1.2" <em>output_file</em></code></p>
<dl> <dl>
<dt>ffmpeg</dt><dd>starts the command</dd> <dt>ffmpeg</dt><dd>starts the command</dd>
@@ -1469,7 +1453,7 @@
<label class="recipe" for="embed_subtitles">Embed subtitles</label> <label class="recipe" for="embed_subtitles">Embed subtitles</label>
<input type="checkbox" id="embed_subtitles"> <input type="checkbox" id="embed_subtitles">
<div class="hiding"> <div class="hiding">
<h3>Embed a subtitle file into a movie file </h3> <h5>Embed a subtitle file into a movie file </h5>
<p><code>ffmpeg -i <em>input_file</em> -i <em>subtitles_file</em> -c copy -c:s mov_text <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -i <em>subtitles_file</em> -c copy -c:s mov_text <em>output_file</em></code></p>
<dl> <dl>
<dt>ffmpeg</dt><dd>starts the command</dd> <dt>ffmpeg</dt><dd>starts the command</dd>
@@ -1492,7 +1476,7 @@
<label class="recipe" for="one_thumbnail">Export one thumbnail per video file</label> <label class="recipe" for="one_thumbnail">Export one thumbnail per video file</label>
<input type="checkbox" id="one_thumbnail"> <input type="checkbox" id="one_thumbnail">
<div class="hiding"> <div class="hiding">
<h3>One thumbnail</h3> <h5>One thumbnail</h5>
<p><code>ffmpeg -i <em>input_file</em> -ss 00:00:20 -vframes 1 thumb.png</code></p> <p><code>ffmpeg -i <em>input_file</em> -ss 00:00:20 -vframes 1 thumb.png</code></p>
<p>This command will grab a thumbnail 20 seconds into the video.</p> <p>This command will grab a thumbnail 20 seconds into the video.</p>
<dl> <dl>
@@ -1510,7 +1494,7 @@
<label class="recipe" for="multi_thumbnail">Export many thumbnails per video file</label> <label class="recipe" for="multi_thumbnail">Export many thumbnails per video file</label>
<input type="checkbox" id="multi_thumbnail"> <input type="checkbox" id="multi_thumbnail">
<div class="hiding"> <div class="hiding">
<h3>Many thumbnails</h3> <h5>Many thumbnails</h5>
<p><code>ffmpeg -i <em>input_file</em> -vf fps=1/60 out%d.png</code></p> <p><code>ffmpeg -i <em>input_file</em> -vf fps=1/60 out%d.png</code></p>
<p>This will grab a thumbnail every minute and output sequential png files.</p> <p>This will grab a thumbnail every minute and output sequential png files.</p>
<dl> <dl>
@@ -1528,7 +1512,7 @@
<label class="recipe" for="img_to_gif">Create GIF from still images</label> <label class="recipe" for="img_to_gif">Create GIF from still images</label>
<input type="checkbox" id="img_to_gif"> <input type="checkbox" id="img_to_gif">
<div class="hiding"> <div class="hiding">
<h3>Images to GIF</h3> <h5>Images to GIF</h5>
<p><code>ffmpeg -f image2 -framerate 9 -pattern_type glob -i <em>"input_image_*.jpg"</em> -vf scale=250x250 <em>output_file</em>.gif</code></p> <p><code>ffmpeg -f image2 -framerate 9 -pattern_type glob -i <em>"input_image_*.jpg"</em> -vf scale=250x250 <em>output_file</em>.gif</code></p>
<p>This will convert a series of image files into a GIF.</p> <p>This will convert a series of image files into a GIF.</p>
<dl> <dl>
@@ -1549,7 +1533,7 @@
<label class="recipe" for="create_gif">Create GIF from a video</label> <label class="recipe" for="create_gif">Create GIF from a video</label>
<input type="checkbox" id="create_gif"> <input type="checkbox" id="create_gif">
<div class="hiding"> <div class="hiding">
<h3>Create GIF</h3> <h5>Create GIF</h5>
<p>Create high quality GIF</p> <p>Create high quality GIF</p>
<p><code>ffmpeg -ss HH:MM:SS -i <em>input_file</em> -filter_complex "fps=10,scale=500:-1:flags=lanczos,palettegen" -t 3 <em>palette.png</em></code></p> <p><code>ffmpeg -ss HH:MM:SS -i <em>input_file</em> -filter_complex "fps=10,scale=500:-1:flags=lanczos,palettegen" -t 3 <em>palette.png</em></code></p>
<p><code>ffmpeg -ss HH:MM:SS -i <em>input_file</em> -i palette.png -filter_complex "[0:v]fps=10, scale=500:-1:flags=lanczos[v], [v][1:v]paletteuse" -t 3 -loop 6 <em>output_file</em></code></p> <p><code>ffmpeg -ss HH:MM:SS -i <em>input_file</em> -i palette.png -filter_complex "[0:v]fps=10, scale=500:-1:flags=lanczos[v], [v][1:v]paletteuse" -t 3 -loop 6 <em>output_file</em></code></p>
@@ -1586,7 +1570,7 @@
<label class="recipe" for="images_2_video">Transcode an image sequence into uncompressed 10-bit video</label> <label class="recipe" for="images_2_video">Transcode an image sequence into uncompressed 10-bit video</label>
<input type="checkbox" id="images_2_video"> <input type="checkbox" id="images_2_video">
<div class="hiding"> <div class="hiding">
<h3>Transcode an image sequence into uncompressed 10-bit video</h3> <h5>Transcode an image sequence into uncompressed 10-bit video</h5>
<p><code>ffmpeg -f image2 -framerate 24 -i <em>input_file_%06d.ext</em> -c:v v210 <em>output_file</em></code></p> <p><code>ffmpeg -f image2 -framerate 24 -i <em>input_file_%06d.ext</em> -c:v v210 <em>output_file</em></code></p>
<dl> <dl>
<dt>ffmpeg</dt><dd>starts the command</dd> <dt>ffmpeg</dt><dd>starts the command</dd>
@@ -1605,7 +1589,7 @@
<label class="recipe" for="image-audio">Create video from image and audio</label> <label class="recipe" for="image-audio">Create video from image and audio</label>
<input type="checkbox" id="image-audio"> <input type="checkbox" id="image-audio">
<div class="hiding"> <div class="hiding">
<h3>Create a video from an image and audio file.</h3> <h5>Create a video from an image and audio file.</h5>
<p><code>ffmpeg -r 1 -loop 1 -i <em>image_file</em> -i <em>audio_file</em> -acodec copy -shortest -vf scale=1280:720 <em>output_file</em></code></p> <p><code>ffmpeg -r 1 -loop 1 -i <em>image_file</em> -i <em>audio_file</em> -acodec copy -shortest -vf scale=1280:720 <em>output_file</em></code></p>
<p>This command will take an image file (e.g. image.jpg) and an audio file (e.g. audio.mp3) and combine them into a video file that contains the audio track with the image used as the video. It can be useful in a situation where you might want to upload an audio file to a platform like YouTube. You may want to adjust the scaling with -vf to suit your needs.</p> <p>This command will take an image file (e.g. image.jpg) and an audio file (e.g. audio.mp3) and combine them into a video file that contains the audio track with the image used as the video. It can be useful in a situation where you might want to upload an audio file to a platform like YouTube. You may want to adjust the scaling with -vf to suit your needs.</p>
<dl> <dl>
@@ -1631,7 +1615,7 @@
<label class="recipe" for="abitscope">Audio Bitscope</label> <label class="recipe" for="abitscope">Audio Bitscope</label>
<input type="checkbox" id="abitscope"> <input type="checkbox" id="abitscope">
<div class="hiding"> <div class="hiding">
<h3>Creates a visualization of the bits in an audio stream</h3> <h5>Creates a visualization of the bits in an audio stream</h5>
<p><code>ffplay -f lavfi "amovie=<em>input_file</em>, asplit=2[out1][a], [a]abitscope=colors=purple|yellow[out0]"</code></p> <p><code>ffplay -f lavfi "amovie=<em>input_file</em>, asplit=2[out1][a], [a]abitscope=colors=purple|yellow[out0]"</code></p>
<p>This filter allows visual analysis of the information held in various bit depths of an audio stream. This can aid with identifying when a file that is nominally of a higher bit depth actually has been 'padded' with null information. The provided GIF shows a 16 bit WAV file (left) and then the results of converting that same WAV to 32 bit (right). Note that in the 32 bit version, there is still only information in the first 16 bits.</p> <p>This filter allows visual analysis of the information held in various bit depths of an audio stream. This can aid with identifying when a file that is nominally of a higher bit depth actually has been 'padded' with null information. The provided GIF shows a 16 bit WAV file (left) and then the results of converting that same WAV to 32 bit (right). Note that in the 32 bit version, there is still only information in the first 16 bits.</p>
<dl> <dl>
@@ -1654,7 +1638,7 @@
<label class="recipe" for="astats">Play a graphical output showing decibel levels of an input file</label> <label class="recipe" for="astats">Play a graphical output showing decibel levels of an input file</label>
<input type="checkbox" id="astats"> <input type="checkbox" id="astats">
<div class="hiding"> <div class="hiding">
<h3>Plays a graphical output showing decibel levels of an input file</h3> <h5>Plays a graphical output showing decibel levels of an input file</h5>
<p><code>ffplay -f lavfi "amovie='input.mp3', astats=metadata=1:reset=1, adrawgraph=lavfi.astats.Overall.Peak_level:max=0:min=-30.0:size=700x256:bg=Black[out]"</code></p> <p><code>ffplay -f lavfi "amovie='input.mp3', astats=metadata=1:reset=1, adrawgraph=lavfi.astats.Overall.Peak_level:max=0:min=-30.0:size=700x256:bg=Black[out]"</code></p>
<dl> <dl>
<dt>ffplay</dt><dd>starts the command</dd> <dt>ffplay</dt><dd>starts the command</dd>
@@ -1683,7 +1667,7 @@
<label class="recipe" for="brng">Identify pixels out of broadcast range</label> <label class="recipe" for="brng">Identify pixels out of broadcast range</label>
<input type="checkbox" id="brng"> <input type="checkbox" id="brng">
<div class="hiding"> <div class="hiding">
<h3>Shows all pixels outside of broadcast range</h3> <h5>Shows all pixels outside of broadcast range</h5>
<p><code>ffplay -f lavfi "movie='<em>input.mp4</em>', signalstats=out=brng:color=cyan[out]"</code></p> <p><code>ffplay -f lavfi "movie='<em>input.mp4</em>', signalstats=out=brng:color=cyan[out]"</code></p>
<dl> <dl>
<dt>ffplay</dt><dd>starts the command</dd> <dt>ffplay</dt><dd>starts the command</dd>
@@ -1708,7 +1692,7 @@
<label class="recipe" for="vectorscope">Vectorscope from video to screen</label> <label class="recipe" for="vectorscope">Vectorscope from video to screen</label>
<input type="checkbox" id="vectorscope"> <input type="checkbox" id="vectorscope">
<div class="hiding"> <div class="hiding">
<h3>Plays vectorscope of video</h3> <h5>Plays vectorscope of video</h5>
<p><code>ffplay <em>input_file</em> -vf "split=2[m][v], [v]vectorscope=b=0.7:m=color3:g=green[v], [m][v]overlay=x=W-w:y=H-h"</code></p> <p><code>ffplay <em>input_file</em> -vf "split=2[m][v], [v]vectorscope=b=0.7:m=color3:g=green[v], [m][v]overlay=x=W-w:y=H-h"</code></p>
<dl> <dl>
<dt>ffplay</dt><dd>starts the command</dd> <dt>ffplay</dt><dd>starts the command</dd>
@@ -1730,7 +1714,7 @@
<label class="recipe" for="tempdif">Side by Side Videos/Temporal Difference Filter</label> <label class="recipe" for="tempdif">Side by Side Videos/Temporal Difference Filter</label>
<input type="checkbox" id="tempdif"> <input type="checkbox" id="tempdif">
<div class="hiding"> <div class="hiding">
<h3>This will play two input videos side by side while also applying the temporal difference filter to them</h3> <h5>This will play two input videos side by side while also applying the temporal difference filter to them</h5>
<p><code>ffmpeg -i input01 -i input02 -filter_complex "[0:v:0]tblend=all_mode=difference128[a];[1:v:0]tblend=all_mode=difference128[b];[a][b]hstack[out]" -map [out] -f nut -c:v rawvideo - | ffplay -</code></p> <p><code>ffmpeg -i input01 -i input02 -filter_complex "[0:v:0]tblend=all_mode=difference128[a];[1:v:0]tblend=all_mode=difference128[b];[a][b]hstack[out]" -map [out] -f nut -c:v rawvideo - | ffplay -</code></p>
<dl> <dl>
<dt>ffmpeg</dt><dd>starts the command</dd> <dt>ffmpeg</dt><dd>starts the command</dd>
@@ -1760,7 +1744,7 @@
<label class="recipe" for="xstack">Use xstack to arrange output layout of multiple video sources</label> <label class="recipe" for="xstack">Use xstack to arrange output layout of multiple video sources</label>
<input type="checkbox" id="xstack"> <input type="checkbox" id="xstack">
<div class="hiding"> <div class="hiding">
<h3>This filter enables vertical and horizontal stacking of multiple video sources into one output.</h3> <h5>This filter enables vertical and horizontal stacking of multiple video sources into one output.</h5>
<p>This filter is useful for the creation of output windows such as the one utilized in <a href="https://github.com/amiaopensource/vrecord" target="_blank">vrecord.</a></p> <p>This filter is useful for the creation of output windows such as the one utilized in <a href="https://github.com/amiaopensource/vrecord" target="_blank">vrecord.</a></p>
<p><code>ffplay -f lavfi -i <em>testsrc</em> -vf "split=3[a][b][c],[a][b][c]xstack=inputs=3:layout=0_0|0_h0|0_h0+h1[out]"</code></p> <p><code>ffplay -f lavfi -i <em>testsrc</em> -vf "split=3[a][b][c],[a][b][c]xstack=inputs=3:layout=0_0|0_h0|0_h0+h1[out]"</code></p>
<p>The following example uses the 'testsrc' virtual input combined with the <a href="https://ffmpeg.org/ffmpeg-filters.html#split_002c-asplit" target="_blank">split filter</a> to generate the multiple inputs.</p> <p>The following example uses the 'testsrc' virtual input combined with the <a href="https://ffmpeg.org/ffmpeg-filters.html#split_002c-asplit" target="_blank">split filter</a> to generate the multiple inputs.</p>
@@ -1787,7 +1771,7 @@
<label class="recipe" for="pull_specs">Pull specs from video file</label> <label class="recipe" for="pull_specs">Pull specs from video file</label>
<input type="checkbox" id="pull_specs"> <input type="checkbox" id="pull_specs">
<div class="hiding"> <div class="hiding">
<h3>Pull specs from video file</h3> <h5>Pull specs from video file</h5>
<p><code>ffprobe -i <em>input_file</em> -show_format -show_streams -show_data -print_format xml</code></p> <p><code>ffprobe -i <em>input_file</em> -show_format -show_streams -show_data -print_format xml</code></p>
<p>This command extracts technical metadata from a video file and displays it in xml.</p> <p>This command extracts technical metadata from a video file and displays it in xml.</p>
<dl> <dl>
@@ -1807,7 +1791,7 @@
<label class="recipe" for="strip_metadata">Strip metadata</label> <label class="recipe" for="strip_metadata">Strip metadata</label>
<input type="checkbox" id="strip_metadata"> <input type="checkbox" id="strip_metadata">
<div class="hiding"> <div class="hiding">
<h3>Strips metadata from video file</h3> <h5>Strips metadata from video file</h5>
<p><code>ffmpeg -i <em>input_file</em> -map_metadata -1 -c:v copy -c:a copy <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -map_metadata -1 -c:v copy -c:a copy <em>output_file</em></code></p>
<dl> <dl>
<dt>ffmpeg</dt><dd>starts the command</dd> <dt>ffmpeg</dt><dd>starts the command</dd>
@@ -1830,7 +1814,7 @@
<label class="recipe" for="batch_processing_bash">Batch processing (Mac/Linux)</label> <label class="recipe" for="batch_processing_bash">Batch processing (Mac/Linux)</label>
<input type="checkbox" id="batch_processing_bash"> <input type="checkbox" id="batch_processing_bash">
<div class="hiding"> <div class="hiding">
<h3>Create Bash script to batch process with FFmpeg</h3> <h5>Create Bash script to batch process with FFmpeg</h5>
<p>Bash scripts are plain text files saved with a .sh extension. This entry explains how they work with the example of a bash script named “Rewrap-MXF.sh”, which rewraps .mxf files in a given directory to .mov files.</p> <p>Bash scripts are plain text files saved with a .sh extension. This entry explains how they work with the example of a bash script named “Rewrap-MXF.sh”, which rewraps .mxf files in a given directory to .mov files.</p>
<p>“Rewrap-MXF.sh” contains the following text:</p> <p>“Rewrap-MXF.sh” contains the following text:</p>
<p><code>for file in *.mxf; do ffmpeg -i "$file" -map 0 -c copy "${file%.mxf}.mov"; done</code></p> <p><code>for file in *.mxf; do ffmpeg -i "$file" -map 0 -c copy "${file%.mxf}.mov"; done</code></p>
@@ -1860,7 +1844,7 @@
<label class="recipe" for="batch_processing_win">Batch processing (Windows)</label> <label class="recipe" for="batch_processing_win">Batch processing (Windows)</label>
<input type="checkbox" id="batch_processing_win"> <input type="checkbox" id="batch_processing_win">
<div class="hiding"> <div class="hiding">
<h3>Create PowerShell script to batch process with FFmpeg</h3> <h5>Create PowerShell script to batch process with FFmpeg</h5>
<p>As of Windows 10, it is possible to run Bash via <a href="https://msdn.microsoft.com/en-us/commandline/wsl/about" target="_blank">Bash on Ubuntu on Windows</a>, allowing you to use <a href="#batch_processing_bash">bash scripting</a>. To enable Bash on Windows, see <a href="https://msdn.microsoft.com/en-us/commandline/wsl/install_guide" target="_blank">these instructions</a>.</p> <p>As of Windows 10, it is possible to run Bash via <a href="https://msdn.microsoft.com/en-us/commandline/wsl/about" target="_blank">Bash on Ubuntu on Windows</a>, allowing you to use <a href="#batch_processing_bash">bash scripting</a>. To enable Bash on Windows, see <a href="https://msdn.microsoft.com/en-us/commandline/wsl/install_guide" target="_blank">these instructions</a>.</p>
<p>On Windows, the primary native command line program is <strong>PowerShell</strong>. PowerShell scripts are plain text files saved with a .ps1 extension. This entry explains how they work with the example of a PowerShell script named “rewrap-mp4.ps1”, which rewraps .mp4 files in a given directory to .mkv files.</p> <p>On Windows, the primary native command line program is <strong>PowerShell</strong>. PowerShell scripts are plain text files saved with a .ps1 extension. This entry explains how they work with the example of a PowerShell script named “rewrap-mp4.ps1”, which rewraps .mp4 files in a given directory to .mkv files.</p>
<p>“rewrap-mp4.ps1” contains the following text:</p> <p>“rewrap-mp4.ps1” contains the following text:</p>
@@ -1894,7 +1878,7 @@
<label class="recipe" for="check_decoder_errors">Check decoder errors</label> <label class="recipe" for="check_decoder_errors">Check decoder errors</label>
<input type="checkbox" id="check_decoder_errors"> <input type="checkbox" id="check_decoder_errors">
<div class="hiding"> <div class="hiding">
<h3>Check decoder errors</h3> <h5>Check decoder errors</h5>
<p><code>ffmpeg -i <em>input_file</em> -f null -</code></p> <p><code>ffmpeg -i <em>input_file</em> -f null -</code></p>
<p>This decodes your video and prints any errors or found issues to the screen.</p> <p>This decodes your video and prints any errors or found issues to the screen.</p>
<dl> <dl>
@@ -1930,7 +1914,7 @@
<label class="recipe" for="create_frame_md5s_v">Create MD5 checksums (video frames)</label> <label class="recipe" for="create_frame_md5s_v">Create MD5 checksums (video frames)</label>
<input type="checkbox" id="create_frame_md5s_v"> <input type="checkbox" id="create_frame_md5s_v">
<div class="hiding"> <div class="hiding">
<h3>Create MD5 checksums (video frames)</h3> <h5>Create MD5 checksums (video frames)</h5>
<p><code>ffmpeg -i <em>input_file</em> -f framemd5 -an <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -f framemd5 -an <em>output_file</em></code></p>
<p>This will create an MD5 checksum per video frame.</p> <p>This will create an MD5 checksum per video frame.</p>
<dl> <dl>
@@ -1949,7 +1933,7 @@
<label class="recipe" for="create_frame_md5s_a">Create MD5 checksums (audio samples)</label> <label class="recipe" for="create_frame_md5s_a">Create MD5 checksums (audio samples)</label>
<input type="checkbox" id="create_frame_md5s_a"> <input type="checkbox" id="create_frame_md5s_a">
<div class="hiding"> <div class="hiding">
<h3>Create MD5 checksums (audio samples)</h3> <h5>Create MD5 checksums (audio samples)</h5>
<p><code>ffmpeg -i <em>input_file</em> -af "asetnsamples=n=48000" -f framemd5 -vn <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -af "asetnsamples=n=48000" -f framemd5 -vn <em>output_file</em></code></p>
<p>This will create an MD5 checksum for each group of 48000 audio samples.<br> <p>This will create an MD5 checksum for each group of 48000 audio samples.<br>
The number of samples per group can be set arbitrarily, but it's good practice to match the samplerate of the media file (so you will get one checksum per second).</p> The number of samples per group can be set arbitrarily, but it's good practice to match the samplerate of the media file (so you will get one checksum per second).</p>
@@ -1976,7 +1960,7 @@
<label class="recipe" for="create_stream_md5s">Create MD5 checksum(s) for A/V stream data only</label> <label class="recipe" for="create_stream_md5s">Create MD5 checksum(s) for A/V stream data only</label>
<input type="checkbox" id="create_stream_md5s"> <input type="checkbox" id="create_stream_md5s">
<div class="hiding"> <div class="hiding">
<h3>Create stream MD5s</h3> <h5>Create stream MD5s</h5>
<p><code>ffmpeg -i <em>input_file</em> -map 0:v:0 -c:v copy -f md5 <em>output_file_1</em> -map 0:a:0 -c:a copy -f md5 <em>output_file_2</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -map 0:v:0 -c:v copy -f md5 <em>output_file_1</em> -map 0:a:0 -c:a copy -f md5 <em>output_file_2</em></code></p>
<p>This will create MD5 checksums for the first video and the first audio stream in a file. If only one of these is necessary (for example if used on a WAV file) either part of the command can be excluded to create the desired MD5 only. Use of this kind of checksum enables integrity of the A/V information to be verified independently of any changes to surrounding metadata.</p> <p>This will create MD5 checksums for the first video and the first audio stream in a file. If only one of these is necessary (for example if used on a WAV file) either part of the command can be excluded to create the desired MD5 only. Use of this kind of checksum enables integrity of the A/V information to be verified independently of any changes to surrounding metadata.</p>
<dl> <dl>
@@ -1998,7 +1982,7 @@
<label class="recipe" for="get_stream_checksum">Get checksum for video/audio stream</label> <label class="recipe" for="get_stream_checksum">Get checksum for video/audio stream</label>
<input type="checkbox" id="get_stream_checksum"> <input type="checkbox" id="get_stream_checksum">
<div class="hiding"> <div class="hiding">
<h3>Get checksum for video/audio stream</h3> <h5>Get checksum for video/audio stream</h5>
<p><code>ffmpeg -loglevel error -i <em>input_file</em> -map 0:v:0 -f hash -hash md5 -</code></p> <p><code>ffmpeg -loglevel error -i <em>input_file</em> -map 0:v:0 -f hash -hash md5 -</code></p>
<p>This script will perform a fixity check on a specified audio or video stream of the file, useful for checking that the content within a video has not changed even if the container format has changed.</p> <p>This script will perform a fixity check on a specified audio or video stream of the file, useful for checking that the content within a video has not changed even if the container format has changed.</p>
<dl> <dl>
@@ -2017,7 +2001,7 @@
<label class="recipe" for="qctools">QCTools report (with audio)</label> <label class="recipe" for="qctools">QCTools report (with audio)</label>
<input type="checkbox" id="qctools"> <input type="checkbox" id="qctools">
<div class="hiding"> <div class="hiding">
<h3>Creates a QCTools report</h3> <h5>Creates a QCTools report</h5>
<p><code>ffprobe -f lavfi -i "movie=<em>input_file</em>:s=v+a[in0][in1], [in0]signalstats=stat=tout+vrep+brng, cropdetect=reset=1:round=1, idet=half_life=1, split[a][b];[a]field=top[a1];[b]field=bottom, split[b1][b2];[a1][b1]psnr[c1];[c1][b2]ssim[out0];[in1]ebur128=metadata=1, astats=metadata=1:reset=1:length=0.4[out1]" -show_frames -show_versions -of xml=x=1:q=1 -noprivate | gzip > <em>input_file</em>.qctools.xml.gz</code></p> <p><code>ffprobe -f lavfi -i "movie=<em>input_file</em>:s=v+a[in0][in1], [in0]signalstats=stat=tout+vrep+brng, cropdetect=reset=1:round=1, idet=half_life=1, split[a][b];[a]field=top[a1];[b]field=bottom, split[b1][b2];[a1][b1]psnr[c1];[c1][b2]ssim[out0];[in1]ebur128=metadata=1, astats=metadata=1:reset=1:length=0.4[out1]" -show_frames -show_versions -of xml=x=1:q=1 -noprivate | gzip > <em>input_file</em>.qctools.xml.gz</code></p>
<p>This will create an XML report for use in <a href="https://github.com/bavc/qctools" target="_blank">QCTools</a> for a video file with one video track and one audio track. See also the <a href="https://github.com/bavc/qctools/blob/master/docs/data_format.md#creating-a-qctools-document" target="_blank">QCTools documentation</a>.</p> <p>This will create an XML report for use in <a href="https://github.com/bavc/qctools" target="_blank">QCTools</a> for a video file with one video track and one audio track. See also the <a href="https://github.com/bavc/qctools/blob/master/docs/data_format.md#creating-a-qctools-document" target="_blank">QCTools documentation</a>.</p>
<dl> <dl>
@@ -2042,7 +2026,7 @@
<label class="recipe" for="qctools_no_audio">QCTools report (no audio)</label> <label class="recipe" for="qctools_no_audio">QCTools report (no audio)</label>
<input type="checkbox" id="qctools_no_audio"> <input type="checkbox" id="qctools_no_audio">
<div class="hiding"> <div class="hiding">
<h3>Creates a QCTools report</h3> <h5>Creates a QCTools report</h5>
<p><code>ffprobe -f lavfi -i "movie=<em>input_file</em>,signalstats=stat=tout+vrep+brng, cropdetect=reset=1:round=1, idet=half_life=1, split[a][b];[a]field=top[a1];[b]field=bottom,split[b1][b2];[a1][b1]psnr[c1];[c1][b2]ssim" -show_frames -show_versions -of xml=x=1:q=1 -noprivate | gzip > <em>input_file</em>.qctools.xml.gz</code></p> <p><code>ffprobe -f lavfi -i "movie=<em>input_file</em>,signalstats=stat=tout+vrep+brng, cropdetect=reset=1:round=1, idet=half_life=1, split[a][b];[a]field=top[a1];[b]field=bottom,split[b1][b2];[a1][b1]psnr[c1];[c1][b2]ssim" -show_frames -show_versions -of xml=x=1:q=1 -noprivate | gzip > <em>input_file</em>.qctools.xml.gz</code></p>
<p>This will create an XML report for use in <a href="https://github.com/bavc/qctools" target="_blank">QCTools</a> for a video file with one video track and NO audio track. See also the <a href="https://github.com/bavc/qctools/blob/master/docs/data_format.md#creating-a-qctools-document" target="_blank">QCTools documentation</a>.</p> <p>This will create an XML report for use in <a href="https://github.com/bavc/qctools" target="_blank">QCTools</a> for a video file with one video track and NO audio track. See also the <a href="https://github.com/bavc/qctools/blob/master/docs/data_format.md#creating-a-qctools-document" target="_blank">QCTools documentation</a>.</p>
<dl> <dl>
@@ -2067,7 +2051,7 @@
<label class="recipe" for="readeia608">Read/Extract EIA-608 Closed Captioning</label> <label class="recipe" for="readeia608">Read/Extract EIA-608 Closed Captioning</label>
<input type="checkbox" id="readeia608"> <input type="checkbox" id="readeia608">
<div class="hiding"> <div class="hiding">
<h3>Read/Extract EIA-608 (Line 21) closed captioning</h3> <h5>Read/Extract EIA-608 (Line 21) closed captioning</h5>
<p><code>ffprobe -f lavfi -i movie=<em>input_file</em>,readeia608 -show_entries frame=pkt_pts_time:frame_tags=lavfi.readeia608.0.line,lavfi.readeia608.0.cc,lavfi.readeia608.1.line,lavfi.readeia608.1.cc -of csv > <em>input_file</em>.csv</code></p> <p><code>ffprobe -f lavfi -i movie=<em>input_file</em>,readeia608 -show_entries frame=pkt_pts_time:frame_tags=lavfi.readeia608.0.line,lavfi.readeia608.0.cc,lavfi.readeia608.1.line,lavfi.readeia608.1.cc -of csv > <em>input_file</em>.csv</code></p>
<p>This command uses FFmpeg's <a href="https://ffmpeg.org/ffmpeg-filters.html#readeia608" target="_blank">readeia608</a> filter to extract the hexadecimal values hidden within <a href="https://en.wikipedia.org/wiki/EIA-608" target="_blank">EIA-608 (Line 21)</a> Closed Captioning, outputting a csv file. For more information about EIA-608, check out Adobe's <a href="https://www.adobe.com/content/dam/Adobe/en/devnet/video/pdfs/introduction_to_closed_captions.pdf" target="_blank">Introduction to Closed Captions</a>.</p> <p>This command uses FFmpeg's <a href="https://ffmpeg.org/ffmpeg-filters.html#readeia608" target="_blank">readeia608</a> filter to extract the hexadecimal values hidden within <a href="https://en.wikipedia.org/wiki/EIA-608" target="_blank">EIA-608 (Line 21)</a> Closed Captioning, outputting a csv file. For more information about EIA-608, check out Adobe's <a href="https://www.adobe.com/content/dam/Adobe/en/devnet/video/pdfs/introduction_to_closed_captions.pdf" target="_blank">Introduction to Closed Captions</a>.</p>
<p>If hex isn't your thing, closed captioning <a href="http://www.theneitherworld.com/mcpoodle/SCC_TOOLS/DOCS/CC_CHARS.HTML" target="_blank">character</a> and <a href="http://www.theneitherworld.com/mcpoodle/SCC_TOOLS/DOCS/CC_CODES.HTML" target="_blank">code</a> sets can be found in the documentation for SCTools.</p> <p>If hex isn't your thing, closed captioning <a href="http://www.theneitherworld.com/mcpoodle/SCC_TOOLS/DOCS/CC_CHARS.HTML" target="_blank">character</a> and <a href="http://www.theneitherworld.com/mcpoodle/SCC_TOOLS/DOCS/CC_CODES.HTML" target="_blank">code</a> sets can be found in the documentation for SCTools.</p>
@@ -2096,7 +2080,7 @@
<label class="recipe" for="mandelbrot">Make a mandelbrot test pattern video</label> <label class="recipe" for="mandelbrot">Make a mandelbrot test pattern video</label>
<input type="checkbox" id="mandelbrot"> <input type="checkbox" id="mandelbrot">
<div class="hiding"> <div class="hiding">
<h3>Makes a mandelbrot test pattern video</h3> <h5>Makes a mandelbrot test pattern video</h5>
<p><code>ffmpeg -f lavfi -i mandelbrot=size=1280x720:rate=25 -c:v libx264 -t 10 <em>output_file</em></code></p> <p><code>ffmpeg -f lavfi -i mandelbrot=size=1280x720:rate=25 -c:v libx264 -t 10 <em>output_file</em></code></p>
<dl> <dl>
<dt>ffmpeg</dt><dd>starts the command</dd> <dt>ffmpeg</dt><dd>starts the command</dd>
@@ -2132,7 +2116,7 @@
<label class="recipe" for="test">Make a test pattern video</label> <label class="recipe" for="test">Make a test pattern video</label>
<input type="checkbox" id="test"> <input type="checkbox" id="test">
<div class="hiding"> <div class="hiding">
<h3>Make a test pattern video</h3> <h5>Make a test pattern video</h5>
<p><code>ffmpeg -f lavfi -i testsrc=size=720x576:rate=25 -c:v v210 -t 10 <em>output_file</em></code></p> <p><code>ffmpeg -f lavfi -i testsrc=size=720x576:rate=25 -c:v v210 -t 10 <em>output_file</em></code></p>
<dl> <dl>
<dt>ffmpeg</dt><dd>starts the command</dd> <dt>ffmpeg</dt><dd>starts the command</dd>
@@ -2151,7 +2135,7 @@
<label class="recipe" for="play_hd_smpte">Play HD SMPTE bars</label> <label class="recipe" for="play_hd_smpte">Play HD SMPTE bars</label>
<input type="checkbox" id="play_hd_smpte"> <input type="checkbox" id="play_hd_smpte">
<div class="hiding"> <div class="hiding">
<h3>Play HD SMPTE bars</h3> <h5>Play HD SMPTE bars</h5>
<p>Test an HD video projector by playing the SMPTE color bars pattern.</p> <p>Test an HD video projector by playing the SMPTE color bars pattern.</p>
<p><code>ffplay -f lavfi -i smptehdbars=size=1920x1080</code></p> <p><code>ffplay -f lavfi -i smptehdbars=size=1920x1080</code></p>
<dl> <dl>
@@ -2167,7 +2151,7 @@
<label class="recipe" for="play_vga_smpte">Play VGA SMPTE bars</label> <label class="recipe" for="play_vga_smpte">Play VGA SMPTE bars</label>
<input type="checkbox" id="play_vga_smpte"> <input type="checkbox" id="play_vga_smpte">
<div class="hiding"> <div class="hiding">
<h3>Play VGA SMPTE bars</h3> <h5>Play VGA SMPTE bars</h5>
<p>Test a VGA (SD) video projector by playing the SMPTE color bars pattern.</p> <p>Test a VGA (SD) video projector by playing the SMPTE color bars pattern.</p>
<p><code>ffplay -f lavfi -i smptebars=size=640x480</code></p> <p><code>ffplay -f lavfi -i smptebars=size=640x480</code></p>
<dl> <dl>
@@ -2183,7 +2167,7 @@
<label class="recipe" for="sine_wave">Generate a sine wave test audio file</label> <label class="recipe" for="sine_wave">Generate a sine wave test audio file</label>
<input type="checkbox" id="sine_wave"> <input type="checkbox" id="sine_wave">
<div class="hiding"> <div class="hiding">
<h3>Sine wave</h3> <h5>Sine wave</h5>
<p>Generate a test audio file playing a sine wave.</p> <p>Generate a test audio file playing a sine wave.</p>
<p><code>ffmpeg -f lavfi -i "sine=frequency=1000:sample_rate=48000:duration=5" -c:a pcm_s16le <em>output_file</em>.wav</code></p> <p><code>ffmpeg -f lavfi -i "sine=frequency=1000:sample_rate=48000:duration=5" -c:a pcm_s16le <em>output_file</em>.wav</code></p>
<dl> <dl>
@@ -2201,7 +2185,7 @@
<label class="recipe" for="smpte_bars_and_sine_wave">SMPTE bars + Sine wave audio</label> <label class="recipe" for="smpte_bars_and_sine_wave">SMPTE bars + Sine wave audio</label>
<input type="checkbox" id="smpte_bars_and_sine_wave"> <input type="checkbox" id="smpte_bars_and_sine_wave">
<div class="hiding"> <div class="hiding">
<h3>SMPTE bars + Sine wave audio</h3> <h5>SMPTE bars + Sine wave audio</h5>
<p>Generate a SMPTE bars test video + a 1kHz sine wave as audio testsignal.</p> <p>Generate a SMPTE bars test video + a 1kHz sine wave as audio testsignal.</p>
<p><code>ffmpeg -f lavfi -i "smptebars=size=720x576:rate=25" -f lavfi -i "sine=frequency=1000:sample_rate=48000" -c:a pcm_s16le -t 10 -c:v ffv1 <em>output_file</em></code></p> <p><code>ffmpeg -f lavfi -i "smptebars=size=720x576:rate=25" -f lavfi -i "sine=frequency=1000:sample_rate=48000" -c:a pcm_s16le -t 10 -c:v ffv1 <em>output_file</em></code></p>
<dl> <dl>
@@ -2223,7 +2207,7 @@
<label class="recipe" for="broken_file">Make a broken file</label> <label class="recipe" for="broken_file">Make a broken file</label>
<input type="checkbox" id="broken_file"> <input type="checkbox" id="broken_file">
<div class="hiding"> <div class="hiding">
<h3>Makes a broken test file</h3> <h5>Makes a broken test file</h5>
<p>Modifies an existing, functioning file and intentionally breaks it for testing purposes.</p> <p>Modifies an existing, functioning file and intentionally breaks it for testing purposes.</p>
<p><code>ffmpeg -i <em>input_file</em> -bsf noise=1 -c copy <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -bsf noise=1 -c copy <em>output_file</em></code></p>
<dl> <dl>
@@ -2241,7 +2225,7 @@
<label class="recipe" for="game_of_life">Conway's Game of Life</label> <label class="recipe" for="game_of_life">Conway's Game of Life</label>
<input type="checkbox" id="game_of_life"> <input type="checkbox" id="game_of_life">
<div class="hiding"> <div class="hiding">
<h3>Conway's Game of Life</h3> <h5>Conway's Game of Life</h5>
<p>Simulates <a href="https://en.wikipedia.org/wiki/Conway%27s_Game_of_Life" target="_blank">Conway's Game of Life</a></p> <p>Simulates <a href="https://en.wikipedia.org/wiki/Conway%27s_Game_of_Life" target="_blank">Conway's Game of Life</a></p>
<p><code>ffplay -f lavfi life=s=300x200:mold=10:r=60:ratio=0.1:death_color=#c83232:life_color=#00ff00,scale=1200:800</code></p> <p><code>ffplay -f lavfi life=s=300x200:mold=10:r=60:ratio=0.1:death_color=#c83232:life_color=#00ff00,scale=1200:800</code></p>
<dl> <dl>
@@ -2270,7 +2254,7 @@
<label class="recipe" for="ocr_on_top">Play video with OCR</label> <label class="recipe" for="ocr_on_top">Play video with OCR</label>
<input type="checkbox" id="ocr_on_top"> <input type="checkbox" id="ocr_on_top">
<div class="hiding"> <div class="hiding">
<h3>Plays video with OCR on top</h3> <h5>Plays video with OCR on top</h5>
<p>Note: ffmpeg must be compiled with the tesseract library for this script to work (<code>--with-tesseract</code> if using the <code>brew install ffmpeg</code> method).</p> <p>Note: ffmpeg must be compiled with the tesseract library for this script to work (<code>--with-tesseract</code> if using the <code>brew install ffmpeg</code> method).</p>
<p><code>ffplay input_file -vf "ocr,drawtext=fontfile=/Library/Fonts/Andale Mono.ttf:text=%{metadata\\\:lavfi.ocr.text}:fontcolor=white"</code></p> <p><code>ffplay input_file -vf "ocr,drawtext=fontfile=/Library/Fonts/Andale Mono.ttf:text=%{metadata\\\:lavfi.ocr.text}:fontcolor=white"</code></p>
<dl> <dl>
@@ -2294,7 +2278,7 @@
<label class="recipe" for="ffprobe_ocr">Export OCR from video to screen</label> <label class="recipe" for="ffprobe_ocr">Export OCR from video to screen</label>
<input type="checkbox" id="ffprobe_ocr"> <input type="checkbox" id="ffprobe_ocr">
<div class="hiding"> <div class="hiding">
<h3>Exports OCR data to screen</h3> <h5>Exports OCR data to screen</h5>
<p>Note: FFmpeg must be compiled with the tesseract library for this script to work (<code>--with-tesseract</code> if using the <code>brew install ffmpeg</code> method)</p> <p>Note: FFmpeg must be compiled with the tesseract library for this script to work (<code>--with-tesseract</code> if using the <code>brew install ffmpeg</code> method)</p>
<p><code>ffprobe -show_entries frame_tags=lavfi.ocr.text -f lavfi -i "movie=<em>input_file</em>,ocr"</code></p> <p><code>ffprobe -show_entries frame_tags=lavfi.ocr.text -f lavfi -i "movie=<em>input_file</em>,ocr"</code></p>
<dl> <dl>
@@ -2316,7 +2300,7 @@
<label class="recipe" for="compare_video_fingerprints">Compare Video Fingerprints</label> <label class="recipe" for="compare_video_fingerprints">Compare Video Fingerprints</label>
<input type="checkbox" id="compare_video_fingerprints"> <input type="checkbox" id="compare_video_fingerprints">
<div class="hiding"> <div class="hiding">
<h3>Compare two video files for content similarity using perceptual hashing</h3> <h5>Compare two video files for content similarity using perceptual hashing</h5>
<p><code>ffmpeg -i <em>input_one</em> -i <em>input_two</em> -filter_complex signature=detectmode=full:nb_inputs=2 -f null -</code></p> <p><code>ffmpeg -i <em>input_one</em> -i <em>input_two</em> -filter_complex signature=detectmode=full:nb_inputs=2 -f null -</code></p>
<dl> <dl>
<dt>ffmpeg</dt><dd>starts the command</dd> <dt>ffmpeg</dt><dd>starts the command</dd>
@@ -2334,7 +2318,7 @@
<label class="recipe" for="generate_video_fingerprint">Generate Video Fingerprint</label> <label class="recipe" for="generate_video_fingerprint">Generate Video Fingerprint</label>
<input type="checkbox" id="generate_video_fingerprint"> <input type="checkbox" id="generate_video_fingerprint">
<div class="hiding"> <div class="hiding">
<h3>Generate a perceptual hash for an input video file</h3> <h5>Generate a perceptual hash for an input video file</h5>
<p><code>ffmpeg -i <em>input</em> -vf signature=format=xml:filename="output.xml" -an -f null -</code></p> <p><code>ffmpeg -i <em>input</em> -vf signature=format=xml:filename="output.xml" -an -f null -</code></p>
<dl> <dl>
<dt>ffmpeg -i <em>input</em></dt><dd>starts the command using your input file</dd> <dt>ffmpeg -i <em>input</em></dt><dd>starts the command using your input file</dd>
@@ -2355,7 +2339,7 @@
<label class="recipe" for="play_im_seq">Play an image sequence</label> <label class="recipe" for="play_im_seq">Play an image sequence</label>
<input type="checkbox" id="play_im_seq"> <input type="checkbox" id="play_im_seq">
<div class="hiding"> <div class="hiding">
<h3>Play an image sequence</h3> <h5>Play an image sequence</h5>
<p>Play an image sequence directly as moving images, without having to create a video first.</p> <p>Play an image sequence directly as moving images, without having to create a video first.</p>
<p><code>ffplay -framerate 5 <em>input_file_%06d.ext</em></code></p> <p><code>ffplay -framerate 5 <em>input_file_%06d.ext</em></code></p>
<dl> <dl>
@@ -2377,7 +2361,7 @@
<label class="recipe" for="split_audio_video">Split audio and video tracks</label> <label class="recipe" for="split_audio_video">Split audio and video tracks</label>
<input type="checkbox" id="split_audio_video"> <input type="checkbox" id="split_audio_video">
<div class="hiding"> <div class="hiding">
<h3>Split audio and video tracks</h3> <h5>Split audio and video tracks</h5>
<p><code>ffmpeg -i <em>input_file</em> -map 0:v:0 <em>video_output_file</em> -map 0:a:0 <em>audio_output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -map 0:v:0 <em>video_output_file</em> -map 0:a:0 <em>audio_output_file</em></code></p>
<p>This command splits the original input file into a video and audio stream. The -map command identifies which streams are mapped to which file. To ensure that youre mapping the right streams to the right file, run ffprobe before writing the script to identify which streams are desired.</p> <p>This command splits the original input file into a video and audio stream. The -map command identifies which streams are mapped to which file. To ensure that youre mapping the right streams to the right file, run ffprobe before writing the script to identify which streams are desired.</p>
<dl> <dl>
@@ -2420,7 +2404,7 @@
<label class="recipe" for="create_iso">Create ISO files for DVD access</label> <label class="recipe" for="create_iso">Create ISO files for DVD access</label>
<input type="checkbox" id="create_iso"> <input type="checkbox" id="create_iso">
<div class="hiding"> <div class="hiding">
<h3>Create ISO files for DVD access</h3> <h5>Create ISO files for DVD access</h5>
<p>Create an ISO file that can be used to burn a DVD. Please note, you will have to install dvdauthor. To install dvd author using Homebrew run: <code>brew install dvdauthor</code></p> <p>Create an ISO file that can be used to burn a DVD. Please note, you will have to install dvdauthor. To install dvd author using Homebrew run: <code>brew install dvdauthor</code></p>
<p><code>ffmpeg -i <em>input_file</em> -aspect <em>4:3</em> -target ntsc-dvd <em>output_file</em>.mpg</code></p> <p><code>ffmpeg -i <em>input_file</em> -aspect <em>4:3</em> -target ntsc-dvd <em>output_file</em>.mpg</code></p>
<p>This command will take any file and create an MPEG file that dvdauthor can use to create an ISO.</p> <p>This command will take any file and create an MPEG file that dvdauthor can use to create an ISO.</p>
@@ -2439,7 +2423,7 @@
<label class="recipe" for="csv-ydif">CSV with timecodes and YDIF</label> <label class="recipe" for="csv-ydif">CSV with timecodes and YDIF</label>
<input type="checkbox" id="csv-ydif"> <input type="checkbox" id="csv-ydif">
<div class="hiding"> <div class="hiding">
<h3>Exports CSV for scene detection using YDIF</h3> <h5>Exports CSV for scene detection using YDIF</h5>
<p><code>ffprobe -f lavfi -i movie=<em>input_file</em>,signalstats -show_entries frame=pkt_pts_time:frame_tags=lavfi.signalstats.YDIF -of csv</code></p> <p><code>ffprobe -f lavfi -i movie=<em>input_file</em>,signalstats -show_entries frame=pkt_pts_time:frame_tags=lavfi.signalstats.YDIF -of csv</code></p>
<p>This ffprobe command prints a CSV correlating timestamps and their YDIF values, useful for determining cuts.</p> <p>This ffprobe command prints a CSV correlating timestamps and their YDIF values, useful for determining cuts.</p>
<dl> <dl>
@@ -2460,7 +2444,7 @@
<label class="recipe" for="cover_head">Cover head switching noise</label> <label class="recipe" for="cover_head">Cover head switching noise</label>
<input type="checkbox" id="cover_head"> <input type="checkbox" id="cover_head">
<div class="hiding"> <div class="hiding">
<h3>Cover head switching noise</h3> <h5>Cover head switching noise</h5>
<p><code>ffmpeg -i <em>input_file</em> -filter:v drawbox=w=iw:h=7:y=ih-h:t=max <em>output_file</em></code></p> <p><code>ffmpeg -i <em>input_file</em> -filter:v drawbox=w=iw:h=7:y=ih-h:t=max <em>output_file</em></code></p>
<p>This command will draw a black box over a small area of the bottom of the frame, which can be used to cover up head switching noise.</p> <p>This command will draw a black box over a small area of the bottom of the frame, which can be used to cover up head switching noise.</p>
<dl> <dl>
@@ -2485,7 +2469,7 @@
<label class="recipe" for="record-and-stream">Record and live-stream simultaneously</label> <label class="recipe" for="record-and-stream">Record and live-stream simultaneously</label>
<input type="checkbox" id="record-and-stream"> <input type="checkbox" id="record-and-stream">
<div class="hiding"> <div class="hiding">
<h3>Record and live-stream simultaneously</h3> <h5>Record and live-stream simultaneously</h5>
<p><code>ffmpeg -re -i <em>${INPUTFILE}</em> -map 0 -flags +global_header -vf scale="1280:-1,format=yuv420p" -pix_fmt yuv420p -level 3.1 -vsync passthrough -crf 26 -g 50 -bufsize 3500k -maxrate 1800k -c:v libx264 -c:a aac -b:a 128000 -r:a 44100 -ac 2 -t ${STREAMDURATION} -f tee <em>"[movflags=+faststart]${TARGETFILE}|[f=flv]${STREAMTARGET}"</em></code></p> <p><code>ffmpeg -re -i <em>${INPUTFILE}</em> -map 0 -flags +global_header -vf scale="1280:-1,format=yuv420p" -pix_fmt yuv420p -level 3.1 -vsync passthrough -crf 26 -g 50 -bufsize 3500k -maxrate 1800k -c:v libx264 -c:a aac -b:a 128000 -r:a 44100 -ac 2 -t ${STREAMDURATION} -f tee <em>"[movflags=+faststart]${TARGETFILE}|[f=flv]${STREAMTARGET}"</em></code></p>
<p>I use this script to stream to a RTMP target and record the stream locally as .mp4 with only one ffmpeg-instance.</p> <p>I use this script to stream to a RTMP target and record the stream locally as .mp4 with only one ffmpeg-instance.</p>
<p>As input, I use <code>bmdcapture</code> which is piped to ffmpeg. But it can also be used with a static videofile as input.</p> <p>As input, I use <code>bmdcapture</code> which is piped to ffmpeg. But it can also be used with a static videofile as input.</p>
@@ -2526,7 +2510,7 @@
<label class="recipe" for="view_subprogram_info">View FFmpeg subprogram information</label> <label class="recipe" for="view_subprogram_info">View FFmpeg subprogram information</label>
<input type="checkbox" id="view_subprogram_info"> <input type="checkbox" id="view_subprogram_info">
<div class="hiding"> <div class="hiding">
<h3>View information about a specific decoder, encoder, demuxer, muxer, or filter</h3> <h5>View information about a specific decoder, encoder, demuxer, muxer, or filter</h5>
<p><code>ffmpeg -h <em>type=name</em></code></p> <p><code>ffmpeg -h <em>type=name</em></code></p>
<dl> <dl>
<dt>ffmpeg</dt><dd>starts the command</dd> <dt>ffmpeg</dt><dd>starts the command</dd>
@@ -2560,7 +2544,7 @@
<label class="recipe" for="find-offset">Find Drive Offset for Exact CD Ripping</label> <label class="recipe" for="find-offset">Find Drive Offset for Exact CD Ripping</label>
<input type="checkbox" id="find-offset"> <input type="checkbox" id="find-offset">
<div class="hiding"> <div class="hiding">
<h3>Find Drive Offset for Exact CD Ripping</h3> <h5>Find Drive Offset for Exact CD Ripping</h5>
<p>If you want to make CD rips that can be verified via checksums to other rips of the same content, you need to know the offset of your CD drive. Put simply, different models of CD drives have different offsets, meaning they start reading in slightly different locations. This must be compensated for in order for files created on different (model) drives to generate the same checksum. For a more detailed explanation of drive offsets see the explanation <a href="https://dbpoweramp.com/spoons-audio-guide-cd-ripping.htm" target="_blank">here.</a> In order to find your drive offset, first you will need to know exactly what model your drive is, then you can look it up in the list of drive offsets by Accurate Rip.</p> <p>If you want to make CD rips that can be verified via checksums to other rips of the same content, you need to know the offset of your CD drive. Put simply, different models of CD drives have different offsets, meaning they start reading in slightly different locations. This must be compensated for in order for files created on different (model) drives to generate the same checksum. For a more detailed explanation of drive offsets see the explanation <a href="https://dbpoweramp.com/spoons-audio-guide-cd-ripping.htm" target="_blank">here.</a> In order to find your drive offset, first you will need to know exactly what model your drive is, then you can look it up in the list of drive offsets by Accurate Rip.</p>
<p>Often it can be difficult to tell what model your drive is simply by looking at it - it may be housed inside your computer or have external branding that is different from the actual drive manufacturer. For this reason, it can be useful to query your drive with CD ripping software in order to ID it. The following commands should give you a better idea of what drive you have.</p> <p>Often it can be difficult to tell what model your drive is simply by looking at it - it may be housed inside your computer or have external branding that is different from the actual drive manufacturer. For this reason, it can be useful to query your drive with CD ripping software in order to ID it. The following commands should give you a better idea of what drive you have.</p>
<p><strong>Cdda2wav:</strong> <code>cdda2wav -scanbus</code> or simply <code>cdda2wav</code></p> <p><strong>Cdda2wav:</strong> <code>cdda2wav -scanbus</code> or simply <code>cdda2wav</code></p>
@@ -2575,7 +2559,7 @@
<label class="recipe" for="cdparanoia">Rip a CD with CD Paranoia</label> <label class="recipe" for="cdparanoia">Rip a CD with CD Paranoia</label>
<input type="checkbox" id="cdparanoia"> <input type="checkbox" id="cdparanoia">
<div class="hiding"> <div class="hiding">
<h3>Rip a CD with CD Paranoia</h3> <h5>Rip a CD with CD Paranoia</h5>
<p><code>cdparanoia -L -B -O <em>[Drive Offset]</em> <em>[Starting Track Number]</em>-<em>[Ending Track Number]</em> <em>output_file.wav</em></code></p> <p><code>cdparanoia -L -B -O <em>[Drive Offset]</em> <em>[Starting Track Number]</em>-<em>[Ending Track Number]</em> <em>output_file.wav</em></code></p>
<p>This command will use CD Paranoia to rip a CD into separate tracks while compensating for the sample offset of the CD drive. (For more information about drive offset see <a href="#find-offset">the related ffmprovisr command.</a>)</p> <p>This command will use CD Paranoia to rip a CD into separate tracks while compensating for the sample offset of the CD drive. (For more information about drive offset see <a href="#find-offset">the related ffmprovisr command.</a>)</p>
<dl> <dl>
@@ -2594,7 +2578,7 @@
<label class="recipe" for="cdda2wav">Rip a CD with Cdda2wav</label> <label class="recipe" for="cdda2wav">Rip a CD with Cdda2wav</label>
<input type="checkbox" id="cdda2wav"> <input type="checkbox" id="cdda2wav">
<div class="hiding"> <div class="hiding">
<h3>Rip a CD with Cdda2wav</h3> <h5>Rip a CD with Cdda2wav</h5>
<p><code>cdda2wav -L0 -t all -cuefile -paranoia paraopts=retries=200,readahead=600,minoverlap=sectors-per-request-1 -verbose-level all <em>output.wav</em></code></p> <p><code>cdda2wav -L0 -t all -cuefile -paranoia paraopts=retries=200,readahead=600,minoverlap=sectors-per-request-1 -verbose-level all <em>output.wav</em></code></p>
<p>Cdda2wav is a tool that uses the <a href="https://www.xiph.org/paranoia/">Paranoia library</a> to facilitate accurate ripping of audio CDs (CDDA). It can be installed via Homebrew with the command <code> brew install cdrtools</code>. This command will accurately rip an audio CD into a single wave file, while querying the CDDB database for track information and creating a cue sheet. This cue sheet can then be used either for playback of the WAV file or to split it into individual access files. Any <a href="https://en.wikipedia.org/wiki/CD-Text">cdtext</a> information that is discovered will be stored as a sidecar. For more information about cue sheets see <a href="https://en.wikipedia.org/wiki/Cue_sheet_(computing)">this Wikipedia article.</a></p> <p>Cdda2wav is a tool that uses the <a href="https://www.xiph.org/paranoia/">Paranoia library</a> to facilitate accurate ripping of audio CDs (CDDA). It can be installed via Homebrew with the command <code> brew install cdrtools</code>. This command will accurately rip an audio CD into a single wave file, while querying the CDDB database for track information and creating a cue sheet. This cue sheet can then be used either for playback of the WAV file or to split it into individual access files. Any <a href="https://en.wikipedia.org/wiki/CD-Text">cdtext</a> information that is discovered will be stored as a sidecar. For more information about cue sheets see <a href="https://en.wikipedia.org/wiki/Cue_sheet_(computing)">this Wikipedia article.</a></p>
<p><strong>Notes: </strong>On macOS the CD must be unmounted before this command is run. This can be done with the command <code>sudo umount '/Volumes/Name_of_CD'</code></p> <p><strong>Notes: </strong>On macOS the CD must be unmounted before this command is run. This can be done with the command <code>sudo umount '/Volumes/Name_of_CD'</code></p>
@@ -2617,7 +2601,7 @@
<label class="recipe" for="cd-emph-check">Check/Compensate for CD Emphasis</label> <label class="recipe" for="cd-emph-check">Check/Compensate for CD Emphasis</label>
<input type="checkbox" id="cd-emph-check"> <input type="checkbox" id="cd-emph-check">
<div class="hiding"> <div class="hiding">
<h3>Check/Compensate for CD Emphasis</h3> <h5>Check/Compensate for CD Emphasis</h5>
<p>While somewhat rare, certain CDs had 'emphasis' applied as a form of noise reduction. This seems to mostly affect early (1980s) era CDs and some CDs pressed in Japan. Emphasis is part of the <a href="https://en.wikipedia.org/wiki/Compact_Disc_Digital_Audio#Standard">Red Book standard</a> and, if present, must be compensated for to ensure accurate playback. CDs that use emphasis contain flags on tracks that tell the CD player to de-emphasize the audio on playback. When ripping a CD with emphasis, it is important to take this into account and either apply de-emphasis while ripping, or if storing a 'flat' copy, create another de-emphasized listening copy.</p> <p>While somewhat rare, certain CDs had 'emphasis' applied as a form of noise reduction. This seems to mostly affect early (1980s) era CDs and some CDs pressed in Japan. Emphasis is part of the <a href="https://en.wikipedia.org/wiki/Compact_Disc_Digital_Audio#Standard">Red Book standard</a> and, if present, must be compensated for to ensure accurate playback. CDs that use emphasis contain flags on tracks that tell the CD player to de-emphasize the audio on playback. When ripping a CD with emphasis, it is important to take this into account and either apply de-emphasis while ripping, or if storing a 'flat' copy, create another de-emphasized listening copy.</p>
<p>The following commands will output information about the presence of emphasis when run on a target CD:</p> <p>The following commands will output information about the presence of emphasis when run on a target CD:</p>
<p><strong>Cdda2wav:</strong> <code>cdda2wav -J</code></p> <p><strong>Cdda2wav:</strong> <code>cdda2wav -J</code></p>
@@ -2636,7 +2620,7 @@
<label class="recipe" for="im-basics">About ImageMagick</label> <label class="recipe" for="im-basics">About ImageMagick</label>
<input type="checkbox" id="im-basics"> <input type="checkbox" id="im-basics">
<div class="hiding"> <div class="hiding">
<h3>About ImageMagick</h3> <h5>About ImageMagick</h5>
<p>ImageMagick is a free and open-source software suite for displaying, converting, and editing raster image and vector image files.</p> <p>ImageMagick is a free and open-source software suite for displaying, converting, and editing raster image and vector image files.</p>
<p>It's official website can be found <a href="https://www.imagemagick.org/script/index.php" target="_blank">here</a>.</p> <p>It's official website can be found <a href="https://www.imagemagick.org/script/index.php" target="_blank">here</a>.</p>
<p>Another great resource with lots of supplemental explanations of filters is available at <a href="http://www.fmwconcepts.com/imagemagick/index.php" target="_blank">Fred's ImageMagick Scripts</a>.</p> <p>Another great resource with lots of supplemental explanations of filters is available at <a href="http://www.fmwconcepts.com/imagemagick/index.php" target="_blank">Fred's ImageMagick Scripts</a>.</p>
@@ -2649,7 +2633,7 @@
<label class="recipe" for="im_compare">Compare two images</label> <label class="recipe" for="im_compare">Compare two images</label>
<input type="checkbox" id="im_compare"> <input type="checkbox" id="im_compare">
<div class="hiding"> <div class="hiding">
<h3>Compare two images</h3> <h5>Compare two images</h5>
<p><code>compare -metric ae <em>image1.ext image2.ext</em> null:</code></p> <p><code>compare -metric ae <em>image1.ext image2.ext</em> null:</code></p>
<p>Compares two images to each other.</p> <p>Compares two images to each other.</p>
<dl> <dl>
@@ -2666,7 +2650,7 @@
<label class="recipe" for="im_thumbs">Create thumbnails of images</label> <label class="recipe" for="im_thumbs">Create thumbnails of images</label>
<input type="checkbox" id="im_thumbs"> <input type="checkbox" id="im_thumbs">
<div class="hiding"> <div class="hiding">
<h3>Create thumbnails</h3> <h5>Create thumbnails</h5>
<p>Creates thumbnails for all files in a folder and saves them in that folder.</p> <p>Creates thumbnails for all files in a folder and saves them in that folder.</p>
<p><code>mogrify -resize 80x80 -format jpg -quality 75 -path thumbs *.jpg</code></p> <p><code>mogrify -resize 80x80 -format jpg -quality 75 -path thumbs *.jpg</code></p>
<dl> <dl>
@@ -2703,7 +2687,7 @@
<label class="recipe" for="im_sig_data">Get file signature data</label> <label class="recipe" for="im_sig_data">Get file signature data</label>
<input type="checkbox" id="im_sig_data"> <input type="checkbox" id="im_sig_data">
<div class="hiding"> <div class="hiding">
<h3>Get file signature data</h3> <h5>Get file signature data</h5>
<p><code>convert -verbose <em>input_file.ext</em> | grep -i signature </code></p> <p><code>convert -verbose <em>input_file.ext</em> | grep -i signature </code></p>
<p>Gets signature data from an image file, which is a hash that can be used to uniquely identify the image.</p> <p>Gets signature data from an image file, which is a hash that can be used to uniquely identify the image.</p>
<dl> <dl>
@@ -2722,7 +2706,7 @@
<label class="recipe" for="im_strip">Removes exif metadata</label> <label class="recipe" for="im_strip">Removes exif metadata</label>
<input type="checkbox" id="im_strip"> <input type="checkbox" id="im_strip">
<div class="hiding"> <div class="hiding">
<h3>Remove exif data</h3> <h5>Remove exif data</h5>
<p><code>mogrify -path ./stripped/ -strip *.jpg</code></p> <p><code>mogrify -path ./stripped/ -strip *.jpg</code></p>
<p>Removes (strips) exif data and moves clean files to a new folder.</p> <p>Removes (strips) exif data and moves clean files to a new folder.</p>
<dl> <dl>
@@ -2739,7 +2723,7 @@
<label class="recipe" for="im_resize">Resizes image to specific pixel width</label> <label class="recipe" for="im_resize">Resizes image to specific pixel width</label>
<input type="checkbox" id="im_resize"> <input type="checkbox" id="im_resize">
<div class="hiding"> <div class="hiding">
<h3>Resize to width</h3> <h5>Resize to width</h5>
<p><code>convert <em>input_file.ext</em> -resize 750 <em>output_file.ext</em></code></p> <p><code>convert <em>input_file.ext</em> -resize 750 <em>output_file.ext</em></code></p>
<p>This script will also convert the file format, if the output has a different file extension than the input.</p> <p>This script will also convert the file format, if the output has a different file extension than the input.</p>
<dl> <dl>
@@ -2758,7 +2742,7 @@
<label class="recipe" for="flac-tool">Transcoding to/from FLAC</label> <label class="recipe" for="flac-tool">Transcoding to/from FLAC</label>
<input type="checkbox" id="flac-tool"> <input type="checkbox" id="flac-tool">
<div class="hiding"> <div class="hiding">
<h3>About flac tool</h3> <h5>About flac tool</h5>
<p>The flac tool is the tool created by the FLAC project to transcode to/from FLAC and to manipulate metadata in FLAC files. One advantage it has over other tools used to transcode into FLAC is the capability of embedding foreign metadata (such as BWF metadata). This means that it is possible to compress a BWF file into FLAC and maintain the ability to transcode back into an identical BWF, metadata and all. For a more detailed explanation, see <a href="http://dericed.com/2013/flac-in-the-archives/" target="_blank">Dave Rice's article</a> on the topic, from which the following commands are adapted.</p> <p>The flac tool is the tool created by the FLAC project to transcode to/from FLAC and to manipulate metadata in FLAC files. One advantage it has over other tools used to transcode into FLAC is the capability of embedding foreign metadata (such as BWF metadata). This means that it is possible to compress a BWF file into FLAC and maintain the ability to transcode back into an identical BWF, metadata and all. For a more detailed explanation, see <a href="http://dericed.com/2013/flac-in-the-archives/" target="_blank">Dave Rice's article</a> on the topic, from which the following commands are adapted.</p>
<h3>Transcode to FLAC</h3> <h3>Transcode to FLAC</h3>
<p>Use this command to transcode from WAV to FLAC while maintaining BWF metadata</p> <p>Use this command to transcode from WAV to FLAC while maintaining BWF metadata</p>

View File

@@ -1,23 +1,38 @@
$(document).ready(function() { $(document).ready(function() {
function appendLink(id) {
$(id).next('div').find('.link').empty();
$(id).next('div').find('.link').append("<small>Link to this command: <a href='https://amiaopensource.github.io/ffmprovisr/index.html" + id + "'>https://amiaopensource.github.io/ffmprovisr/index.html" + id + "</a></small>");
}
function moveToRecipe(id) {
document.getElementById(id.substring(1)).checked = true;
$('html, body').animate({ scrollTop: $(id).offset().top }, 1000);
appendLink(id)
}
// open recipe window if a hash is found in URL // open recipe window if a hash is found in URL
if (window.location.hash) { if (window.location.hash) {
id = window.location.hash id = window.location.hash
console.log(id.substring(1)) moveToRecipe(id)
document.getElementById(id.substring(1)).checked = true;
$('html, body').animate({ scrollTop: $(id).offset().top}, 1000);
$(id).closest('div').find('.link').empty();
$(id).closest('div').find('.link').append("<small>Link to this command: <a href='https://amiaopensource.github.io/ffmprovisr/index.html"+window.location.hash+"'>https://amiaopensource.github.io/ffmprovisr/index.html"+window.location.hash+"</a></small>");
} }
// add hash URL when recipe is opened // add hash URL when recipe is opened
$('label[class="recipe"]').on("click", function(){ $('label[class="recipe"]').on("click", function(){
id = $(this).attr("for"); id = $(this).attr("for");
window.location.hash = ('#' + id) window.location.hash = ('#' + id)
$('#' + id).closest('div').find('.link').empty(); appendLink('#' + id)
$('#' + id).closest('div').find('.link').append("<small>Link to this command: <a href='https://amiaopensource.github.io/ffmprovisr/index.html"+window.location.hash+"'>https://amiaopensource.github.io/ffmprovisr/index.html"+window.location.hash+"</a></small>"); })
});
// open recipe when clicked
$('a').on("click", function(){
intralink = $(this).attr("href")
if (intralink[0] == "#") {
moveToRecipe(intralink)
}
})
// open all windows if button is clicked
$('#open-all').on("click", function(){ $('#open-all').on("click", function(){
$('input[type=checkbox]').each(function(){ $('input[type=checkbox]').each(function(){
this.checked = !this.checked; this.checked = !this.checked;

View File

@@ -2,6 +2,17 @@
Repository of useful FFmpeg command lines for archivists! Repository of useful FFmpeg command lines for archivists!
* [What is this?](#what-is-this)
* [How do I see it?](#how-do-i-see-it)
* [How do I contribute?](#how-do-i-contribute)
* [Code of conduct](#code-of-conduct)
* [Maintainers](#maintainers)
* [Contributors](#contributors)
* [AVHack Team](#avhack-team)
* [Sister projects](#sister-projects)
* [Awards and mentions](#articles-and-mentions)
* [License](#license)
## What is this? ## What is this?
#### Project Objective #### Project Objective
@@ -137,9 +148,18 @@ Last updated: 2019-02-11
## Sister projects ## Sister projects
[The Cable Bible](https://amiaopensource.github.io/cable-bible/): A Guide to Cables and Connectors Used for Audiovisual Tech [The Cable Bible](https://amiaopensource.github.io/cable-bible/): A Guide to Cables and Connectors Used for Audiovisual Tech
[QEMU QED](https://eaasi.gitlab.io/qemu-qed): instructions for using QEMU (Quick EMUlator), a command line application for computer emulation and virtualization
[Script Ahoy](http://dd388.github.io/crals/): Community Resource for Archivists and Librarians Scripting [Script Ahoy](http://dd388.github.io/crals/): Community Resource for Archivists and Librarians Scripting
[sourcecaster](https://datapraxis.github.io/sourcecaster/): helps you use the command line to work through common challenges that come up when working with digital primary sources. [sourcecaster](https://datapraxis.github.io/sourcecaster/): helps you use the command line to work through common challenges that come up when working with digital primary sources.
## Articles and mentions
* 2019-09: **Andrew Weaver & Ashley Blewer**, [Sustainability through community: ffmprovisr and the Case for Collaborative Knowledge Transfer](https://ipres2019.org/static/pdf/iPres2019_paper_97.pdf) (PDF), iPRES 2019
- Andrew Weaver [won](https://twitter.com/iPRES2019/status/1177136202144768000) iPres' Best First Time Contribution Award for his work on this paper :)
* 2018-11: ffmprovisr is mentioned in [a job advert](http://web.library.emory.edu/documents/pa_staff_Audiovisual%20Conservator_Nov2018.pdf)!
* 2017-10: **Ashley Blewer & Katherine Nagels**, [ffmprovisr gets a redesign](https://bits.ashleyblewer.com/blog/2017/10/31/ffmprovisr-redesign/)
* 2015-11: **AMIA & DLF Hack Day 2015**, [ffmprovsr](https://wiki.curatecamp.org/index.php/Association_of_Moving_Image_Archivists_&_Digital_Library_Federation_Hack_Day_2015#ffmprovsr) - the genesis of ffmprovisr (then spelled without the 'i')
## License ## License
<a rel="license" href="http://creativecommons.org/licenses/by/4.0/"><img alt="Creative Commons License" style="border-width:0" src="https://i.creativecommons.org/l/by/4.0/80x15.png"></a><br> <a rel="license" href="http://creativecommons.org/licenses/by/4.0/"><img alt="Creative Commons License" style="border-width:0" src="https://i.creativecommons.org/l/by/4.0/80x15.png"></a><br>

View File

@@ -1,7 +1,5 @@
# Basic rewrap command # Basic rewrap command
ffmpeg -i input_file.ext -c copy -map 0 output_file.ext ffmpeg -i input_file.ext -c copy -map 0 output_file.ext
# Convert Matroska (MKV) to MP4
ffmpeg -i input_file.mkv -c:v copy -c:a aac output_file.mp4
# Rewrap DV video to .dv file # Rewrap DV video to .dv file
ffmpeg -i input_file -f rawvideo -c:v copy output_file.dv ffmpeg -i input_file -f rawvideo -c:v copy output_file.dv
# Transcode to deinterlaced Apple ProRes LT # Transcode to deinterlaced Apple ProRes LT
@@ -19,11 +17,11 @@ ffmpeg -i input_file -c:v libx265 -pix_fmt yuv420p -c:a copy output_file
# Transcode to an Ogg Theora # Transcode to an Ogg Theora
ffmpeg -i input_file -acodec libvorbis -b:v 690k output_file ffmpeg -i input_file -acodec libvorbis -b:v 690k output_file
# Convert WAV to MP3 # Convert WAV to MP3
ffmpeg -i input_file.wav -write_id3v1 1 -id3v2_version 3 -dither_method rectangular -out_sample_rate 48k -qscale:a 1 output_file.mp3 ffmpeg -i input_file.wav -write_id3v1 1 -id3v2_version 3 -dither_method triangular -out_sample_rate 48k -qscale:a 1 output_file.mp3
# Generate two access MP3s (with and without copyright). # Generate two access MP3s (with and without copyright).
ffmpeg -i input_file -i input_file_to_append -filter_complex "[0:a:0]asplit=2[a][b];[b]afifo[bb];[1:a:0][bb]concat=n=2:v=0:a=1[concatout]" -map "[a]" -codec:a libmp3lame -dither_method modified_e_weighted -qscale:a 2 output_file.mp3 -map "[concatout]" -codec:a libmp3lame -dither_method modified_e_weighted -qscale:a 2 output_file_appended.mp3 ffmpeg -i input_file -i input_file_to_append -filter_complex "[0:a:0]asplit=2[a][b];[b]afifo[bb];[1:a:0][bb]concat=n=2:v=0:a=1[concatout]" -map "[a]" -codec:a libmp3lame -dither_method triangular -qscale:a 2 output_file.mp3 -map "[concatout]" -codec:a libmp3lame -dither_method triangular -qscale:a 2 output_file_appended.mp3
# Convert WAV to AAC/MP4 # Convert WAV to AAC/MP4
ffmpeg -i input_file.wav -c:a aac -b:a 128k -dither_method rectangular -ar 44100 output_file.mp4 ffmpeg -i input_file.wav -c:a aac -b:a 128k -dither_method triangular -ar 44100 output_file.mp4
# Transform 4:3 aspect ratio into 16:9 with pillarbox # Transform 4:3 aspect ratio into 16:9 with pillarbox
ffmpeg -i input_file -filter:v "pad=ih*16/9:ih:(ow-iw)/2:(oh-ih)/2" -c:a copy output_file ffmpeg -i input_file -filter:v "pad=ih*16/9:ih:(ow-iw)/2:(oh-ih)/2" -c:a copy output_file
# Transform 16:9 aspect ratio video into 4:3 with letterbox # Transform 16:9 aspect ratio video into 4:3 with letterbox

View File

@@ -1 +1 @@
curl https://amiaopensource.github.io/ffmprovisr/ -s | grep -E '<h3>.*</h3>|<p><code>.*</code></p>' | sed 's/.*<code>\(.*\)<\/code>/\1/' | sed 's/.*<h3>\(.*\)<\/h3>/# \1/' | grep -v '\*\*\*' | sed -e 's/<[^>]*>//g' curl https://amiaopensource.github.io/ffmprovisr/ -s | grep -E '<h5>.*</h5>|<p><code>.*</code></p>' | sed 's/.*<code>\(.*\)<\/code>/\1/' | sed 's/.*<h5>\(.*\)<\/h5>/# \1/' | grep -v '\*\*\*' | sed -e 's/<[^>]*>//g'