From 6639ccf8528f67b1645fc42f74a6f87838e937a6 Mon Sep 17 00:00:00 2001 From: Galen Lynch Date: Mon, 4 Nov 2024 09:33:56 -0800 Subject: [PATCH] Clarify effect of GPU encoder and fast presets on visual quality --- README.md | 31 +++++++++++++++++++------------ 1 file changed, 19 insertions(+), 12 deletions(-) diff --git a/README.md b/README.md index 76cec17..ca1ca60 100644 --- a/README.md +++ b/README.md @@ -52,25 +52,32 @@ Additionally, this package should provide an easy to use interface that: ## Brief benchmarks on video compression with CPU-based encoders and GPU-based encoders -A perhaps surprising fact is that video encoders implementing the same algorithm -written for different compute resources -_do not have the same visual performance_, in that for a given compression ratio -they do not retain the same amount of visual detail. +A surprising fact is that video encoders implementing the same algorithm written +for different compute resources _do not have the same visual performance_; for a +given compression ratio, or similar settings, they do not retain the same amount +of visual detail. This is also true for different presets of the same encoder +and compute resource with otherwise identical settings and compression ratio. +For example, `-preset fast` and `-preset veryslow` of the encoder `libx264` +produce videos with the same compression ratio, but differing visual quality. This can be seen in the plot below, where the GPU encoder and CPU encoders -retain different amounts of visual detail, as assessed with VMAF. +retain different amounts of visual detail, as assessed with visual +perception-based metric +[VMAF](https://en.wikipedia.org/wiki/Video_Multimethod_Assessment_Fusion). ![visual performance vs compress ratio](/assets/compression-vs-quality.png) -This also shows that different presets of the same encoder, like _CPU Slow_ and -_CPU Fast_, also have different performance. For comrpession ratios greater than -100, it often makes sense to take your time and use a slow preset of a CPU-based -encoder to retain as much visual information for a given amount of compression. +This figure shows that for comrpession ratios greater than 100, it often makes +sense to take your time and use a slow preset of a CPU-based encoder to retain +as much visual information for a given amount of compression. While it may be tempting to select a faster preset, or faster compute resource -like GPU for dramatic speedups shown below, the lossy compression and intent to -delete the original means that taking time to do it right once might well be -worth it. +like GPU for dramatic speedups shown below, doing will degrade the quality of +the resulting video. + +Because the output of this package are permanent video artifacts, the +compression is lossy, and the intent is to delete the original, taking the CPU +time to produce the highest quality video possible might well be worth it. ![throughput vs compress ratio](/assets/compression-vs-speed.png)