I have a collection of about ~110 4K Blu-Ray movies that I’ve ripped and I want to take the time to compress and store them for use on a future Jellyfin server.

I know some very basics about ffmpeg and general codec information, but I have a very specific set of goals in mind I’m hoping someone could point me in the right direction with:

  1. Smaller file size (obviously)
  2. Image quality good enough that I cannot spot the difference, even on a high-end TV or projector
  3. Preserved audio
  4. Preserved HDR metadata

In a perfect world, I would love to be able to convert the proprietary HDR into an open standard, and the Dolby Atmos audio into an open standard, but a good compromise is this.

Assuming that I have the hardware necessary to do the initial encoding, and my server will be powerful enough for transcoding in that format, any tips or pointers?

  • shrugal@lemm.ee
    link
    fedilink
    English
    arrow-up
    12
    ·
    7 months ago

    Best tip I can give is to use a tool that’s made for this task, like Tdarr/FileFlows/Unmanic. They take care of all the complicated issues like encoders, ffmpeg parameters and parallel processing on multiple nodes, so you only have to handle the things you actually care about.

    • dan@upvote.au
      link
      fedilink
      English
      arrow-up
      3
      ·
      7 months ago

      Unmanic is way easier to understand than Tdarr. I use it to transcode DVR recordings recorded using Plex and a HDHomeRun tuner. Digital TV uses MPEG2 which has pretty large file sizes.

  • RvTV95XBeo@sh.itjust.works
    link
    fedilink
    English
    arrow-up
    9
    arrow-down
    1
    ·
    7 months ago

    You’re about to embark on a massive journey and I wish you the best of luck :D

    Compressing 110 4K movies is going to be a long encode time, but it will be so nice to digitize that collection.

    First question: if you already have them ripped and stored, do you even need to re-encode them? If you have a powerful enough Jellyfin server for transcoding, that may be enough.

    That said, if you’re looking to optimize for space and quality, there’s some questions to ask:

    • proprietary (but ubiquitous) HEVC or the emerging open standard AV1? It’s going to be a lot easier finding tips/guides for HEVC.

    • Constant Rate Factor (CRF), or Average Bit Rate (ABR). CRF tends to be more straightforward if you have a varied collection of content because it let’s the encoder choose settings to deliver consistent quality. 2-pass average bit rate is good if you have a target size or compatibility in mind - great for squeezing out the absolute optimal quality if you’re trying to fit on a Blu-Ray disc or meet certain streaming criteria, but 2x the encode time (hence “2-pass”) can be a tough sell.

    Stick with software encoding, steer clear of hardware solutions like NVENC. They’re crazy fast, but inconsistent quality.

    There’s some guides out there on converting DV to HDR 10+ etc, but I don’t have a lot of experience with that process.

    • fenndev@leminal.spaceOP
      link
      fedilink
      English
      arrow-up
      3
      ·
      7 months ago

      The issue is storage costs. Currently they (and some Blu-ray shows I ripped) are taking up just over 12TB. I bought all of these movies when I had money to spend on stuff like that, but money is short and times are tough. “Storage is cheap” but my wallet is cheaper right now, aha.

      • RvTV95XBeo@sh.itjust.works
        link
        fedilink
        English
        arrow-up
        3
        ·
        7 months ago

        Look, I definitely get it, but just a note, encoding 100+ 4k HEVC movies is going to take months of time at full PC loads. It’s a subtle cost, but depending on your electricity rate, running a 200W PC 24/7 for 3 months straight may hurt your bottom line more than it helps.

        If you already have the storage, the cheapest option may be just to keep it. If you’re looking to increase the size of your collection it may be about even to save 6 TB via encode and to buy an extra 6TB disc, depending on your setup

        • jbrains@sh.itjust.works
          link
          fedilink
          English
          arrow-up
          3
          ·
          7 months ago

          I am definitely keeping an eye on my electricity bill right now, since I have Unmanic running full speed and it’s about 3 weeks into a 4-month job that might only save 1 TB.

  • DaGeek247@fedia.io
    link
    fedilink
    arrow-up
    6
    ·
    7 months ago

    I did a comparison trying to find where my personal “good enough” and techinically indistinguishable crf levels were at a little while ago. It may be worth looking into as a start. I’ve never really touched hdr before though.

    Comparing compression levels

  • authorinthedark@lemmy.sdf.org
    link
    fedilink
    English
    arrow-up
    5
    ·
    edit-2
    7 months ago

    oh hey I’ve actually done this recently so a lot of this is fresh for me. Now I had a slightly different use case than you, I had a bunch of AV1 files that wouldn’t run on my pi so I had to convert them to something less GPU intensive. I was finding x265 was indistinguishable for me from AV1, and had a HUGE file size drop, close to a half or even a third. x264 had a larger file size than 265 and looked worse so I don’t recommend it. I did not try VP9 once I was satisfied with 265 but you could try it out and see how it compares. My recommendation is to pick one (shorter) file and run a couple of different transforms on it till you’re satisfied before trying to transform your entire library

    Preserving audio and metadata is trivial, just use -c:a copy for audio and -c:d copy for metadata

    EDIT: I feel dishonest not mentioning the important caveats regarding my own experiments. My files were 1080p, so the difference between codecs might be less noticeable at that resolution. It was also anime, which is similarly going to be easier to compress and be less distinct between codecs. This is why I cannot recommend x264 because if you can ruin 1080p anime it’ll ruin whatever you’re working with. This is why I recommend picking a sample video and spend a day running a couple test transformations on it to see what you like

    • DaGeek247@fedia.io
      link
      fedilink
      arrow-up
      3
      ·
      7 months ago

      Skipping the audio encode from a blu-ray will lose op out on a surprisingly large amount of space, especially with 110 source disks. I checked one of my two hour blu-ray backups. Audio will net you about nine audio tracks (english, french, etc). A single 5.1 448kbs audio track will take about 380MB of space per movie. Multiply that by nine (the number of different tracks in my sample choice) and you’ll get 3420MB per disk. That means about 376GB of space is used on audio alone for ops collection. A third of a terabyte. You can save a lot of space by cutting out the languages you don’t need, and also by compressing that source audio to ogg or similar.

      By running the following ffmpeg command; ffmpeg -i out-audio.ac3 -codec:a libvorbis -qscale:a 3 small-audio.ogv I got my 382MB source audio track down to 200MB. Combine that with only keeping the language you need, and you end up dropping from 376GB down to 22GB total.

      You can likely save even more space by skimping on subtitles. They’re stored as images, so they take up a chunk of space too.

      • the_third@feddit.de
        link
        fedilink
        English
        arrow-up
        6
        ·
        7 months ago

        Please use Opus instead of Vorbis. Vorbis is old and had been superseded by Opus.

    • marci33@feddit.it
      link
      fedilink
      English
      arrow-up
      1
      ·
      7 months ago

      Since you’re talking about anime, how did you solve the subtitles problem? My pi doesn’t transcode fast enough but I haven’t found a tdarr extension to do that automatically (nor a command)

      • authorinthedark@lemmy.sdf.org
        link
        fedilink
        English
        arrow-up
        2
        ·
        7 months ago

        I’m sorry my subtitles worked fine from the beginning so I don’t know what to tell you. I’ve got a pi4 running osmc as my media center if that makes any difference.

      • DaGeek247@fedia.io
        link
        fedilink
        arrow-up
        13
        arrow-down
        1
        ·
        7 months ago

        God no. X264 is way worse than x265 is way worse than av1 for quality by size.

        Yes, everything made in the past 15 years can do x264, but that does not mean it is a good idea. Only do x264 if you have a specific device that needs it. Otherwise, x265 is a better choice for long term storage.

        • fenndev@leminal.spaceOP
          link
          fedilink
          English
          arrow-up
          5
          ·
          7 months ago

          AV1 is definitely what I’d like to do. I’m not aiming for maximum compatibility; small file size and high quality encodes are my goal. I can transcode if needed.

          • Lemmchen@feddit.de
            link
            fedilink
            English
            arrow-up
            4
            ·
            7 months ago

            Keep in mind at least your server should be able to decode whatever you choose in hardware, so AV1 might still not be a good idea depending on your current hardware and upgrade plans.

        • Lemmchen@feddit.de
          link
          fedilink
          English
          arrow-up
          2
          ·
          edit-2
          7 months ago

          You’re right, I forgot about the on-the-fly transcoding abilities of Jellyfin for a moment. But still, the server should be able to handle whatever codec they choose in hardware.

          • dan@upvote.au
            link
            fedilink
            English
            arrow-up
            2
            ·
            edit-2
            6 months ago

            How many of those are you streaming video to, though?

            Intel iGPUs have supported H265 since 7th gen, which is 8 years old now (released in 2016). Nvidia added support the same year, starting with the GTX1050. Even the Raspberry Pi 4 supports hardware-accelerated H265.