Qiita Teams that are logged in
You are not logged in to any team

Log in to Qiita Team
Community
OrganizationAdvent CalendarQiitadon (β)
Service
Qiita JobsQiita ZineQiita Blog
Help us understand the problem. What is going on with this article?

音楽ファイルが96kbpsになる日――Opus音声コーデックの実力

More than 3 years have passed since last update.

視覚的にもっとわかりやすくした解説はこちら

Opusとは

新しい音声コーデックで、IETF標準であり、WebRTCの実装で利用される。レイテンシが非常に低くでき、VoIP用途にも利用できるが、一般的な音楽ファイルにも有用な高性能コーデック。YouTubeにも採用されている。

ほとんどの人は96kbpsのOpusとオリジナルの区別をつけることが難しいのではないか?
Cf. http://d.hatena.ne.jp/kamedo2/20150721/1437496134 画像出展

比較

  • 44.1kHz、モノラルで比較
    • (モノラルなので、joint stereoなどの性能比較は含まないものとなる。以下で記載されているビットレートを大体2倍すればステレオの場合として考えられる。)
  • 以下に載せるOpusは全部モノラル/48kbps近辺のビットレートになっている。
  • スペクトログラムでコーデックを比較するのは良くないのはわかっているが、視覚的にわかりやすいのでこの比較を行う。
    • 実際には二重盲検法、ABXテストしたほうがいいが、時間と根気が必要なのでパット見でわかる便利さは重要だと思う。
  • X軸が時間、Y軸が周波数、色の濃さがZ軸であり、黒いほど音がないことを示す。

低ビットレート比較

ステレオ換算で96kbps程度。

  • めうめうぺったんたん!! (ひなビタ) 0:17〜0:27
    • FLAC 16bit 44.1kHz (オリジナル) meumeu_flac.png
      • シンセが鳴りまくる場面
    • MP3 LAME ABR 60 (57kbps) meumeu_mp3.png
      • MP3は比較対象中一番ビットレート高いのに、さすがに厳しい
    • Ogg xiph.org oggenc q0.5 (53kbps) meumeu_ogg.png
      • Oggは低ビットレートに強いと前々から言われていたし、割とリーズナブルな結果。
    • AAC XLD(QuickTIme) CVBR 48kbps (49kbps) meumeu_aac.png
      • このビットレートではLC-AACはあまり強くないようだ。
    • Opus xiph.org opusenc VBR 46kbps (48kbps) meumeu_opus.png
      • 綺麗なスペクトログラム。Opus、強すぎる

中ビットレート比較

ステレオ換算で128kbps(Ogg)〜165kbps(MP3) vs Opus 96kbpsの比較

  • Hello, Goodbye (The Beatles) 0:55〜1:05

    • FLAC 24bit 44.1kHz (オリジナル) 07 - Hello, Goodbye (2009 Digital Remaster)_flac.png
      • ビートルズのリマスター盤。ちょうどライドシンバルが鳴る場面。
    • MP3 LAME VBR V4 (80kbps) 07 - Hello, Goodbye (2009 Digital Remaster)_mp3.png
      • LPFでカットして、可聴域の解像度を高める戦略だが、可聴域に黒点が見え、劣化となる。
    • Ogg xiph.org oggenc q4 (75kbps) 07 - Hello, Goodbye (2009 Digital Remaster)_ogg.png
      • MP3よりはいくぶんかマシになる。
    • Opus xiph.org opusenc VBR 48kbps (49kbps) 07 - Hello, Goodbye (2009 Digital Remaster)_opus.png
      • 他のコーデックとOpusで1.6倍程度もの大きなビットレート差があるが、見劣りしない。
  • 金の波 千の波 (新居昭乃) 0:55〜1:05

    • FLAC 16bit 44.1kHz (オリジナル) 015. 新居昭乃-金の波 千の波_flac.png
      • 歯擦音が目立つ場面。
    • MP3 LAME VBR V4 (82kbps) 015. 新居昭乃-金の波 千の波_mp3.png
      • LPFで16k以上は綺麗にカット、4k程度の音域でも黒点が見える。
    • Ogg xiph.org oggenc q4 (77kbps) 015. 新居昭乃-金の波 千の波_ogg.png
      • MP3よりは良好。
    • Opus xiph.org opusenc VBR 48kbps (50kbps)015. 新居昭乃-金の波 千の波_opus.png
      • Opus。Vorbisより解像度はいい感じだけど16k以上で何か線が入っている。とはいえビットレートは低いにもかかわらず、他に比べて明らかに良い。

高ビットレート比較

ステレオ換算で192kbps(Ogg)〜225kbps(MP3) vs Opus 96kbpsの比較

  • ホントノトコロ (名瀬ゆかな) 1〜11秒
    • FLAC 16bit 44.1kHz (オリジナル) 001_flac.png
      • オリジナルファイル(可逆圧縮、基準)
    • MP3 LAME VBR V1 (117kbps) 001_mp3.png
      • 16kHz付近以上を犠牲にして可聴域の音質を高めている。可聴域の解像度はスペクトログラムでオリジナルとの違いがわからず良好。
    • Ogg xiph.org oggenc q6 (101kbps) 001_ogg.png
      • 20k以上の超音波領域を削っている。可聴域にはところどころ黒点が見える。
    • Opus xiph.org opusenc VBR 48kbps (52kbps) 001_opus.png
      • 他のコーデックよりかなり低い48kbps(ステレオで約96kbps)で、この解像度を誇る。6.6秒の18k付近で原音の線が間延びしているように見える。Opusは、このビットレートの16k以上はアーチファクトが現れると思われる。
  • さよならを教えて (MELL)
    • FLAC 16bit 44.1kHz 0. Track_27_flac.png
    • MP3 LAME VBR V1 (126kbps) 0. Track_27_mp3.png
      • 16k以上はところどころ捨てられる。時々黒点がめだつ。
    • Ogg xiph.org oggenc q6 (102kbps) 0. Track_27_ogg.png
      • MP3よりはがんばっているようだが可聴域に黒点が見える。
    • Opus xiph.org opusenc VBR 48kbps (49kbps) 0. Track_27_opus.png
      • Opusは他の半分以下のビットレートだが、ぱっと見は悪くない印象。まあ、さすがにオリジナルと見比べると可聴域に若干粗があり、見比べると分かる。

さすがにOpusと他のコーデックのビットレートに差がありすぎて、Opusで若干情報の欠落が見えるが、オリジナルと聞き分けはつかない。96kbps(モノラル48kbps)で試してみよう。

コード

flac -f -d -o "/tmp/$1.wav" "$1.flac" 
sox "/tmp/$1.wav" "/tmp/$1-mono.wav" trim 55 10 remix -
sox "/tmp/$1-mono.wav" -n spectrogram -x 1200 -o "${1}_flac.png"

oggenc -q4.000000 "/tmp/$1-mono.wav" -o "/tmp/$1.ogg" && sox "/tmp/$1.ogg" -n spectrogram -x 1200 -o "${1}_ogg.png"

opusenc --bitrate 48 --vbr "/tmp/$1-mono.wav" - | opusdec --quiet - "/tmp/$1.opus.wav" && sox "/tmp/$1.opus.wav" -n spectrogram -x 1200  -o "${1}_opus.png"

lame -m m -V4 "/tmp/$1-mono.wav" - | mpg123 -w "/tmp/$1-mp3.wav" - && sox "/tmp/$1-mp3.wav" -n spectrogram  -x 1200 -o "${1}_mp3.png" 
rm "/tmp/$1.wav" "/tmp/$1-mono.wav" "/tmp/$1.ogg" "/tmp/$1.opus.wav" "/tmp/$1-mp3.wav"

Opusまとめ

  • VBRが基本、CBRは無駄で使う必要はない。
    • なお、libopus 1.1.1 VBRでは、オルゴールの音になると異常にビットレートを使うので注意
  • (今回は書いてないけど)ボイスだけなら48kbpsもあれば原音と区別つかないはず。24kbpsでも割と問題ない。
    • ボイスのエンコードにはSkypeが開発したSILKが利用される
  • ビットレート(ステレオの場合)
    • たぶん打ち込み系、ポップス、ロック等は96kbpsくらいで割と良い
      • 96kbpsに於いては16kHz以上の原音再現度はそれほど高くない
        • ただし人間が聴いて分からない、気にならないレベル
    • 静かな曲は128kbpsくらいはあってもいいかもしれない
      • YouTubeでは、最近は Opus 160kbps を多くの動画で採用している
      • ぶっちゃけ、それ以上を割り当てたりしても、無音が多かったりすると、同じ音源のFLACの場合のほうが小さくなったりすることもある。どれほど多くてもVBR 160kbpsで良く、256kbpsあればオーバーキル気味。
    • それ以上はどのコーデックにしても人間の耳で聞き分けることは不可能(断言)
  • ハイレゾとOpus 128kbpsがABXテストで聴き分けられたら、ぜひ自慢してください!たぶんできませんが。

視覚的にもっとわかりやすくした解説「音声コーデック 音質比較 AAC vs MP3 vs Opus vs Vorbis」

keiya
筑波大生です
Why not register and get more from Qiita?
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away