Skip to content

Set of flows for Tdarr. Also lots of ffmpeg resources on how to use various encoders

Notifications You must be signed in to change notification settings

samssausages/Tdarr-One-Flow

Repository files navigation

Tdarr - One Flow - To Rule Them All

Goal to have One Flow (set of flows) to Rule all your Media!

I accomplish this by using Library Variables. This allows us to change our quality and encoding settings in the library. This is much easier than trying to edit the flow every time we want to encode differently. I have a library for low quality, high quality, Animation, Movies. Each has their own quality settings. Then I just move the files I'm processing into the corresponding library folder and tdarr will process as needed.

  • While I have ran thousands of files through this flow, please consider this beta! Do not trust it with your media library until you have ran a bunch of various files through it and understand how it operates! Let me know if you run into unexpected behavior!
  • Do not use with DV or HDR+. Could cause playback error. Works fine with basic HDR (Fix for DV is on the roadmap)
  • CPU & QSV need more testing, as I don't use them often. NVENC is well tested.
  • This Flow is designed to be used with an input and output directory
  • Uses the -vbr method to obtain a predictable bitrate. With cq as a fallback method, or when we decide the bitrate is too low for -vbr to work well.
  • Languages not defined in the audio_language variable are removed

Features

  • Uses Library Variables for Quality Settings. This way you can have different libraries for different quality settings
  • Uses Centralized Flow Variables for configurables in one location (1 - Input) No need to hunt the entire flow for configurables
  • We calculate things like -maxrate based on your target bitrate. Simplifying user imput
  • Lots of notes & documentation in the flow
  • Extensive logging and use of icons to make tracking down failures a breeze
  • Works with Nvidia, Intel QuickSync and CPU (Help me add others by sharing your ffmpeg command)
  • Strip audio to where only the tracks you want remain
  • If a lossless audio track exists, encode in opus (can disable, still needs refinement, as sometimes encodes high bitrate non-lossless tracks)
  • Deinterlace .ts files. (tv DVR broadcasts)
  • Export Embedded Subtitles (Could use more testing and refinement)

I broke it down into 5 steps/flows:

1 - Input (Define Flow Variables & Configurables. Tags files that may need special processing down the stack)

2 - Prep (Standardizes the File so it is less likely to fail encoding later)

3 - Audio (Clean audio and encode to Opus, if enabled)

4 - Video (Define desired bitrate by resolution, fall back on cq)

5 - Save (final checks and move operations)

Installation

  1. Create a new flow for each of the above steps (1-5) by:

    a. Go to Tdarr Flows

    b. Click "add flow"

    c. Scoll to bottom and copy/paste json into "Import JSON Template"

  2. Create a new Library with the Variables listed below (Make Sure your library has an input folder defined & output folders exist)

  3. Profit

Tweaks

  • All the configurable Flow Settings can be edited in flow 1 - Input
  • If you have an Nvidia 2000 series or up, enable flow plugin fl_nvenc_b-frames in the 1-Input flow. (1660 Super as well)
  • You can disable audio processing with library variable do_audio = false

Library variables you need to add, with example setting:

Variable Notes:

Audio bitrates and cutoff are set PER CHANNEL. We use that to calculate based on number of channels in the audio stream.

Required Fields

test_mode true # true = will not delete source file.  False = will delete source file.  Without source files won't delete.

output_dir_done /media/4_done # path from within tdarr

output_dir_review /media/4_done_review # if something didn't go right, we move to review folder.

v_cq 20 # quality setting for cq fallback method. Scale of 0-51.  Where 0 is lossless and 51 is the lowest quality.  16-18 is often considered indistinguishable.  18-24 is usually a sane range.

bitrate_480p 1250k # bitrate you want for given resolution

bitrate_576p 1400k

bitrate_720p 2000k

bitrate_1080p 2500k

bitrate_1440p 3800k

bitrate_4k 10000k

bitrate_4k_hdr 12500k

bitrate_audio 160k # Audio bitrate we will encode to.  This is PER CHANNEL.

bitrate_audio_cutoff 192k # will not encode source audio under this bitrate.  This is PER CHANNEL

audio_language und,un,eng,en,ger,deu,de,zho,zh,chi,jpn,ja,kor,ko,spa,es,cpe,  # languages that you want to keep

do_audio true # process audio? Currently Opus

do_hevc = false # process hevc?

Optional Fields

disable_cq = false # Disable Fallback encoding method

disable_video = false # Optional - Only needed if you want to disable video processing - Set to True

Quality Examples

Peoples opinions vary greatly on this. Also content will have a big impact on what is optimal. If you think you have good settings, share them!

Low Quality:

v_cq 24 # quality setting for cq fallback method. Scale of 0-51.  Where 0 is lossless and 51 is the lowest quality.  16-18 is often considered indistinguishable.  18-24 is usually a sane range.

bitrate_480p 1250k # bitrate you want for given resolution

bitrate_576p 1400k

bitrate_720p 2000k

bitrate_1080p 2500k

bitrate_1440p 3800k

bitrate_4k 10000k

bitrate_4k_hdr 12500k

bitrate_audio 160k # Audio bitrate we will encode to.  This is PER CHANNEL.

bitrate_audio_cutoff 192k # will not encode source audio under this bitrate.  This is PER CHANNEL

Mid-High Quality:

v_cq 20 # quality setting for cq fallback method. Scale of 0-51.  Where 0 is lossless and 51 is the lowest quality.  16-18 is often considered indistinguishable.  18-24 is usually a sane range.

bitrate_480p 1750k # bitrate you want for given resolution

bitrate_576p 2000k

bitrate_720p 3000k

bitrate_1080p 4000k

bitrate_1440p 6000k

bitrate_4k 17500k

bitrate_4k_hdr 20000k

bitrate_audio 256k # Audio bitrate we will encode to.  This is PER CHANNEL

bitrate_audio_cutoff 384k # will not encode source audio under this bitrate.  This is PER CHANNEL

Flow Screenshot

The flow is huge, but here is an example.

Video Example Input Example

About

Set of flows for Tdarr. Also lots of ffmpeg resources on how to use various encoders

Topics

Resources

Stars

Watchers

Forks

Packages

No packages published