スペースを確保するために、ビデオライブラリをHEVC形式に変換しようとしています。ライブラリ内のすべてのビデオファイルに対して次のコマンドを実行します。
#!/bin/bash
for i in *.mp4;
do
#Output new files by prepending "X265" to the names
avconv -i "$i" -c:v libx265 -c:a copy X265_"$i"
done
現在、ほとんどのビデオはうまく変換され、品質は以前と同じです。ただし、一部の非常に高品質のビデオ(5GBの映画のコピーなど)は品質が低下し、ビデオはすべてピクセル化されます。
この状況でどうすればいいかわかりません。crf
コマンドラインでパラメータを変更する必要がありますか?それとも別のものですか?
問題は、バッチ変換を実行していることです。したがって、avconv
ビデオごとに調整する必要があるパラメータを自動的に調整する方法が必要です。
アップデート1
私はこれがcrf
私が調整する必要があるハンドルであることがわかりました。デフォルトのCRFは28です。より良い品質を得るには、28未満の値を使用できます。たとえば、
avconv -i input.mp4 -c:v libx265 -x265-params crf=23 -c:a copy output.mp4
しかし、問題は、一部のビデオではCRF値28で十分ですが、一部のビデオではCRFが低いことが必要です。大きな映像の小さな部分を変換して手動で確認しなければならない部分です。ところで、一括変換時に各映像を手動でどのように確認できますか?avconv
入力ビデオに基づいてCRFをインテリジェントに調整する方法はありますか?
アップデート2
--lossless
x265にオプションがあることがわかりました。http://x265.readthedocs.org/en/default/lossless.html。
しかし、正しく使用する方法がわかりません。私は次のように試しましたが、反対の結果が出ました(ビデオがよりピクセル化されました)。
avconv -i input.mp4 -c:v libx265 -x265-params lossless -c:a copy output.mp4
答え1
私の経験によれば、品質の低下がまったく発生しないようにしたい場合は、ロスレスが欲しいです。
わかりませんが、avconv
入力したコマンドは私が使用したコマンドと同じように見えますFFmpeg
。次のパラメータを渡すことができますFFmpeg
。
ffmpeg -i INPUT.mkv -c:v libx265 -preset ultrafast -x265-params lossless=1 OUTPUT.mkv
ほとんどのスイッチ(値のないオプション)はこの方法で指定できます(バイナリでのみ直接使用されるx265
CLIを使用するスイッチを除く)。x265
その意味で、私は私のコーディング経験を共有したいと思いますx265
。ほとんどのビデオ(WMV、MPEG、またはAVC / H.264)の場合crf=23
。x265
ただし、ビデオ全体をトランスコードする前に、通常は問題のビデオの一部を変換して設定をテストします。以下は、mkvファイルを想定した例です。ここで、ストリーム0はビデオ、ストリーム1はDTSオーディオ、ストリーム2は字幕です。
ffmpeg -hide_banner \
-ss 0 \
-i "INPUT.mkv" \
-attach "COVER.jpg" \
-map_metadata 0 \
-map_chapters 0 \
-metadata title="TITLE" \
-map 0:0 -metadata:s:v:0 language=eng \
-map 0:1 -metadata:s:a:0 language=eng -metadata:s:a:0 title="Surround 5.1 (DTS)" \
-map 0:2 -metadata:s:s:0 language=eng -metadata:s:s:0 title="English" \
-metadata:s:t:0 filename="Cover.jpg" -metadata:s:t:0 mimetype="image/jpeg" \
-c:v libx265 -preset ultrafast -x265-params \
crf=22:qcomp=0.8:aq-mode=1:aq_strength=1.0:qg-size=16:psy-rd=0.7:psy-rdoq=5.0:rdoq-level=1:merange=44 \
-c:a copy \
-c:s copy \
-t 120 \
"OUTPUT.HEVC.DTS.Sample.mkv"
バックスラッシュは長いコマンドで改行文字を表します。これは、複雑なCLI入力のさまざまなビットを追跡するのに役立ちます。 1行ずつ説明する前に、画像の小さな部分だけを変換する部分が2番目と最後の2行です。-ss 0
入力デコードを開始する前に0秒を探すことを意味し、-t 120
120秒後に出力への書き込みを停止するという意味です。 。 hh:mm:ssまたはhh:mm:ss.sss時間形式を使用することもできます。
今1行ずつ:
-hide_banner
FFmpeg
起動時にビルド情報が表示されないようにします。コンソールで上にスクロールするときにそれを見たくないだけです。-ss 0
入力デコードを開始する前に0秒間探します。このパラメータが提供されている場合は注意してください。後ろに入力ファイルと今後出力ファイルは出力オプションそして、ffmpeg
x秒まで入力をデコードし、無視して出力書き込みを開始します。入力オプションとして精度は低下しますが(ほとんどのコンテナ形式の照会は正確ではないため)、時間がかかりません。出力オプションとして非常に正確ですが、指定された時間より前にすべてのストリームをデコードするのに多くの時間が必要であるため、テスト目的で無駄にしたくありません。-i "INPUT.mkv"
:入力ファイルを指定します。-attach "COVER.jpg"
:印刷物にカバーアート(サムネイル、ポスターなど)を追加します。カバーアートは通常ファイルエクスプローラに表示されます。-map_metadata 0
:入力0のすべてのメタデータをコピーします。例では、入力したばかりです。-map_chapters 0
:入力0(存在する場合)から章情報をコピーします。-metadata title="TITLE"
:ビデオタイトルの設定。-map 0:0 ...
:入力0のストリーム0をマッピングします。つまり、入力の最初のストリームが出力に書き込まれることを意味します。ストリームはビデオストリームなので最初です。動画流入出力したがって、ストリーム指定子:s:v:0
。言語タグを英語に設定します。-map 0:1 ...
:8行目と同様に、2番目のコードストリーム(DTSオーディオ)をマッピングし、言語とタイトルを設定します(プレーヤーが選択したときに簡単に識別できるように)。-map 0:2 ...
:ストリームが字幕であることを除いて、9行に似ています。-metadata:s:t:0 ...
:表紙アートのメタデータを設定します。これは mkv コンテナ形式に必要です。-c:v libx265 ...
:ビデオコーデックオプション。長すぎて2行に分けました。この設定は、グラデーションのバンディングが最小限に抑えられた高品質のブルーレイビデオ(1080p)に適しています(x265はこの場合は悪い)。 DVD、テレビ番組、電話ビデオの場合、これはおそらく過剰です。この設定のほとんどはこのDoom 9の投稿;crf=22:...
:ビデオコーデックパラメータの連続。上記のフォーラム投稿をご覧ください。-c:a copy
:オーディオコピー。-c:s copy
:字幕コピー。-t 120
:120秒後に出力書き込みを停止します。これにより、トランスコーディング品質をプレビューできる2分の長さのクリップが提供されます。"OUTPUT.HEVC.DTS.Sample.mkv"
:出力ファイル名です。ビデオコーデックとデフォルトのオーディオコーデックでファイル名にタグを付けます。
呼ぶこれが最初の答えです。欠落しているものがあればメッセージを残してください。私はビデオ制作の専門家ではなく、プレーヤーにディスクを入れて映画を見るにはあまりにも怠惰な人です。
PS。この質問はUnixやLinuxとはあまり関係がないので、他の質問に属することもできます。
答え2
私は最近、ビデオディレクトリ全体をHEVCにトランスコードするのに苦労しました。私は使うhttps://github.com/FallingSnow/h265ize次の設定を使用します。
h265ize -v -m 中間 -q 20 -x --no-sao --aq-mode 3 --delete --stats
-V- 詳細出力
-m中間- 適切なエンコーディング速度
-q 20- CRFを使用すると、20はx264の18程度に似ていますが、こんにちは。これは1080pコンテンツ(マイテレビの90%)で動作し、4Kムービーには22を使用する傾向があります。
- X- 中央で定義されたx265コマンドの使用
- 野生の売春婦サンプル適応オフセットをオフにする(エンコード速度を上げる)
--aq-モード 3- 特に暗い領域で8ビットエンコーディングをサポートする自動分散を含む適応量子化を使用して、可能な限りのバンディングを防ぎます(エンコーディングに時間がかかります)。
- 削除- エンコードされたファイルをエンコードされたファイルに置き換えます(このファイルを使用する前にテスト)
--統計データ- 実行パスのルートにあるcsvファイルに統計を記録します。
私のデバイスでは、エンコード速度は約30fpsです(ほとんどの1080pエントリの場合)。 Dual Xeon E5 2687W v2が、FFMPEGプロセスがプロセッサの1つの最初の側面を使用しないように強制します。 (これは私のPlexサーバーなので、再生などに必要なときにトランスコーディングオーバーヘッドがあることを確認する必要があります。)
はい、ほとんどのコンテンツを変換するのに少し時間がかかりました。現在、その日付のコンテンツをx265にエンコードするために1日に2回実行されるスケジュールされたタスクがあります。
節約されたスペースは膨大です。私の元のSAN使用量は20Tbでしたが、今は約12Tbですが、明らかに6ヶ月分のコンテンツが追加されました。
また、すべてのムービーのトランスコーディングを開始しましたが、品質レベルを識別し(幸いにもRadarrでフラグを指定する)、3つのトランスコーディング設定のいずれかを使用する必要があるため、進行中のプロセスです。
-m slower -q 18 -x --no-sao --aq-mode 3
720pトランスコード
-m medium -q 20 -x --no-sao --aq-mode 3
1080p
-m medium -q 22 -x --no-sao
2160p
これが何人かの人々に役立つことを願っています。これらすべてを設定するのに役立つ必要がある人がいる場合は、私に叫んでください。すべてをx265でエンコードする前に再生を検討してください。クライアントがネイティブx265をサポートしていない場合、トランスコーディングはCPUと品質の面で高価です。
答え3
ffmpegでx265エンコーダのロスレスモードを有効にする正しい構文は次のとおりです-x265-params lossless=1
(追加する必要があります=1
)。
しかし、ロスレスエンコーディングの場合、より良いコーデック選択があります。テストを通して見つけたFFV1少なくとも一部のビデオタイプでは、圧縮がはるかに優れています(ファイルサイズ= x 265の約80%)(両方のコーデックに最適な設定を選択した場合)。また、より速く実行され(私が知っている限り)、特許によって妨げられません。つまり、ビデオアーカイブのあらゆる面でロスレスH.265よりも優れています。しかし、妥協点は現在、再生ソフトウェアとハードウェアとの互換性です。