This page intentionally left blank. ⬇️, ➡️, or spacebar 🛰 to start slidedeck. --- class: middle, center .center[![ffmpeg](/img/ffmpeg.png)] # FFmpeg --- # What is FFmpeg? “A complete, cross-platform solution to record, convert, and stream audio and video.” FFmpeg is the de-facto audiovisual file manipulation tool, used in countless programs. Here are a few: VLC, Handbrake, YouTube, Audacity. And, in the avpres world: QCTools, vrecord. --- # Why is FFmpeg important? Audiovisual preservationists need to be able to * make access copies of files * inspect files * store preservation metadata for files * handle weird media And FFmpeg can do all of this and more! --- # Things FFmpeg can do * Make derivatives * Re-wrap files * Edit files * Generate checksums * Visualize metadata * Manipulate streams * Generate test sources * Add video/audio effects * More, more, more! --- # Basic command A very basic FFmpeg command looks like this:
ffmpeg -i input_file.ext -flag some_action output_file.ext
--- # Basic command, explained #### **`ffmpeg`** starts the command #### **`-i input_file.ext`** path and name of the input file #### **`-flag some_action`** tell FFmpeg to do something, by supplying a valid flag and action #### **`output_file.ext`** path and name of the output file. --- # Installation The biggest hurdle for learning and using FFmpeg is the installation process. It will be the hardest part! After FFmpeg is installed, it gets a lot easier from there. 😘 --- # Basic installation #### Option 1 (direct download) - Go to https://ffmpeg.org/download.html - Click on the download icon that says Download ffmpeg-7.1.tar.bz2 (or current) - Save to downloads and extract from downloads folder to desired location on computer. - This program is run through command line. #### Extended directions for Windows installation - https://blog.gregzaal.com/how-to-install-ffmpeg-on-windows/ #### More options (Mac) - Homebrew: `brew install ffmpeg` (see next page for customization) - Guide to installing ffmpeg on Mac: https://trac.ffmpeg.org/wiki/CompilationGuide/MacOSX --- # Better installation General advice on installation from Reto Kromer: [ffmpeg cookbook](https://avpres.net/FFmpeg/#ch1) `brew tap avpres/formulae` `brew install --with-openjpeg --with-x265 --with-rubberband --with-svt-av1 --with-tesseract avpres/formulae/ffmpeg` #### What does this mean? These flags, used during install, allow for... - *openjpg* include JPEG2000 encoding/decoding - *x265* include H.265(HEVC) encoding - *rubberband* include audio filtering - *svt-av1* include Scalable Video Technology for AV1 (SVT-AV1 encoder and decoder) - *tesseract* include optical character recognition (OCR) --- # Checking your installation Is your installation working properly? If so, you should be able to type ## `ffmpeg -version` into your terminal and get a bundle of information back as the result. If you get something like ## `-bash: ffmpeg: command not found` then there is a problem! --- # Normal Installation ``` ffmpeg version 7.1 Copyright (c) 2000-2024 the FFmpeg developers built with Apple clang version 16.0.0 (clang-1600.0.26.4) configuration: --prefix=/usr/local/Cellar/ffmpeg/7.1_2 --enable-shared --enable-pthreads --enable-version3 --cc=clang --host-cflags= --host-ldflags= --enable-ffplay --enable-gnutls --enable-gpl --enable-libaom --enable-libaribb24 --enable-libbluray --enable-libdav1d --enable-libharfbuzz --enable-libjxl --enable-libmp3lame --enable-libopus --enable-librav1e --enable-librist --enable-librubberband --enable-libsnappy --enable-libsrt --enable-libssh --enable-libsvtav1 --enable-libtesseract --enable-libtheora --enable-libvidstab --enable-libvmaf --enable-libvorbis --enable-libvpx --enable-libwebp --enable-libx264 --enable-libx265 --enable-libxml2 --enable-libxvid --enable-lzma --enable-libfontconfig --enable-libfreetype --enable-frei0r --enable-libass --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libopenjpeg --enable-libspeex --enable-libsoxr --enable-libzmq --enable-libzimg --disable-libjack --disable-indev=jack libavutil 59. 39.100 / 59. 39.100 libavcodec 61. 19.100 / 61. 19.100 libavformat 61. 7.100 / 61. 7.100 libavdevice 61. 3.100 / 61. 3.100 libavfilter 10. 4.100 / 10. 4.100 libswscale 8. 3.100 / 8. 3.100 libswresample 5. 3.100 / 5. 3.100 libpostproc 58. 3.100 / 58. 3.100 ``` --- # Not installed? Get a sample of what to expect with this ffmpeg in the browser demo (may take some time to load): [Videoconverter.js demo](https://bgrins.github.io/videoconverter.js/demo/) --- # Example 1 Make a file out of nothing! `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 libx264 new_file.mov` This makes a file that plays SMPTE bars and a 1kHz audio testsignal sine wave for 10 seconds. .center[![ffmpeg](/img/smpte.png)] --- # Example 1 (breaking it down) **`ffmpeg`** starts the command **`-f lavfi`** tells FFmpeg to use the libavfilter input virtual device **`-i smptebars=size=720x576:rate=25`** asks for the smptebars test filter as input. Adjusting the size and rate options allows you to choose a specific frame size and framerate. **`-f lavfi`** use libavfilter again, but now for audio **`-i "sine=frequency=1000:sample_rate=48000"`** Sets the signal to 1000 Hz, sampling at 48 kHz. **`-c:a pcm_s16le`** encodes the audio codec in pcm_s16le (the default encoding for wav files). pcm represents pulse-code modulation format (raw bytes), 16 means 16 bits per sample, and le means "little endian" **`-t 10`** specifies recording time of 10 seconds **`-c:v libx264`** Encodes to libx264. Alter this setting to set your desired codec, like `ffv1` or `v210`. **`new_file.mkv`** path, name and extension of the output file. This can be set to any video container's file extension. Here, we are using .mkv, but something like .avi also works. --- # Example 1 (learning about codecs) In the previous example, we are encoding the file to the h.264 codec, a popular codec that is read by most video players. If you adjust the video codec to something else, it might have a harder time playing on major commercial media players. Encoding to `ffv1` will create a file that cannot be played in Quicktime Player. Encoding to `v210` will make a file that cannot be played back in the default Windows media player. I recommend [VLC media player](https://www.videolan.org/vlc/) for playing back a large and diverse video set and for testing videos. Your version of FFmpeg may be installed with `ffplay`, which can also be used to play video files (`ffplay your-video-here`). --- # Example 2: Re-wrapping ## First! What does re-wrapping mean? -- To re-wrap a file is to change the file's **container**. --- # Example 2: Re-wrapping `ffmpeg -i new_file.mkv -c copy -map 0 new_file.avi` .center[![ffmpeg](/img/smpte.png)] --- # Example 2: Re-wrapping (breaking it down) `ffmpeg -i new_file.mkv -c copy -map 0 new_file.avi` **`ffmpeg`** starts the command **`-i input_file.ext`** path and name of the input file **`-c copy`** copy the streams directly, without re-encoding. **`-map 0`** map all streams of the input to the output. By default, FFmpeg will only map one stream of each type (video, audio, subtitles) to the output file. However, files may have multiple streams of a given type - for example, a video may have several audio tracks for different languages. Therefore, if you want to preserve all the streams in the original, it's necessary to use this option. **`output_file.ext`** path and name of the output file. The new container you are rewrapping to is defined by the filename extension used here, e.g. .mkv, .mp4, .mov. --- # Example 3: Transcoding ## First! What is transcoding? -- Transcoding is changing a media file's encoding format (commonly referred to as its **codec**) from one type to another. --- # Example 3: Transcoding `ffmpeg -i new_file.avi -c:v prores -profile:v 1 -vf yadif -c:a pcm_s16le new_file.mov` .center[![ffmpeg](/img/smpte.png)] --- # Example 3: Transcoding (breaking it down) `ffmpeg -i new_file.avi -c:v prores -profile:v 1 -vf yadif -c:a pcm_s16le new_file.mov` **`ffmpeg`** starts the command **`-i new_file.avi`** path, name and extension of the input file **`-c:v prores`** tells FFmpeg to transcode the video stream into Apple ProRes 422 **`-profile:v`** 1 Declares profile of ProRes you want to use. The profiles are: 0 = ProRes 422 (Proxy); 1 = ProRes 422 (LT); 2 = ProRes 422 (Standard); 3 = ProRes 422 (HQ) **`-vf yadif`** Runs a deinterlacing video filter (yet another deinterlacing filter) on the new file. -vf is an alias for -filter:v. **`-c:a pcm_s16le`** tells FFmpeg to encode the audio stream in 16-bit linear PCM **`new_file.mov`** path, name and extension of the output file The extension for the QuickTime container is .mov. --- # Bonus: Do both! The following command re-wraps the file and transcodes at the same time. `ffmpeg -i new_file.mov -c:v libx264 -c:a aac new_file.mp4` .center[![ffmpeg](/img/smpte.png)] --- # Bonus bonus: an easy one! `ffmpeg -i new_file.mp4 new_file2.avi` Sometimes ffmpeg knows what to do and you don't need to be explicit to get the file to work. However, this could result in unexpected codec changes. .center[![ffmpeg](/img/smpte.png)] --- # Additional Resources - [ffmprovisr](https://amiaopensource.github.io/ffmprovisr/) - [ffmpeg documentation](https://www.ffmpeg.org/ffmpeg.html) - [Andrew Weaver: Demystifying ffmpeg](https://github.com/privatezero/NDSR/blob/master/Demystifying_FFmpeg_Slides.pdf) (Andrew Weaver) - [Ben Turkus: ffmpeg](https://docs.google.com/presentation/d/1NuusF948E6-gNTN04Lj0YHcVV9-30PTvkh_7mqyPPv4/edit#slide=id.g2974defaca_0_231) (Ben Turkus) - [Dave Rodriguez: Introduction to FFmpeg](https://figshare.com/articles/Introduction_to_FFmpeg/6060194) --- # Learning more - [FFmpeg & Art](/presentations/ffmpeg-art.html) - [FFmpeg & Preservation](/presentations/ffmpeg-preservation.html) - [FFplay](/presentations/ffplay.html) - [FFprobe](/presentations/ffprobe.html) [Home](/)