トップQs
タイムライン
チャット
視点

Algebraic Code Excited Linear Prediction

ウィキペディアから

Remove ads

Algebraic Code Excited Linear Predictionalgebraic CELP、代数CELP、代数符号励振線形予測)あるいは ACELP とは、CELPを応用した音声符号化アルゴリズムである。効率が良いため、VoIP携帯電話などの音声コーデックで広く用いられている。

ACELP はITU-T G.723.1(5.3kbps)、G.729(8kbps)、G.722.2(6.6-23.85kbps)、及び携帯電話用の GSM AMRGSM/W-CDMA用)、AMR-WBW-CDMA用、AMRのワイドバンド版)、EVRCCDMA2000用)、VMR-WBCDMA2000用のワイドバンド版)、SMVCDMA2000用)、PDC-EFR(PDC用)などで使用されている。

概要

ACELP のベースである CELP線形予測符号 (LPC) から派生した音声符号化アルゴリズムで、線形予測フィルターの入力として適応型と固定型のコードブックに登録された信号を使う。 ACELP は、代数的に決められた位置に配置した振幅が+1/-1のパルスの組み合わせからなる固定型コードブックと、この CELP のアルゴリズムとを組み合わせた方式である。以下の特徴がある。

  • 代数的な性格よりコード探索の効率が良い。
  • コードブック全体をテーブルとして用意する必要が無いためメモリが削減できる。
  • 柔軟性があり大きなサイズのコードブックを容易に実現できる。

ACELP の基本的なアイデアは1987年に発表され [1]、その後、疎な(スパース)代数コードを使うよう改良が加えられ [2]、計算量が低減された。 1990年代以降、その効率性のため ACELP のコードブックの表現方式は最もよく使われている [3]

Remove ads

技術

要約
視点

ACELP アルゴリズムのベースである CELP は、「合成による分析」の手法を用い音声波形を再合成し聴感補正を行った後の信号と元の信号とを比較することで、コードブックから誤差が最小になるものを探索する。これを単純に実行すると探索に大きな計算量が必要で、計算量を減らすための工夫が必要になる。またコードブックのサイズが大きくなると多量のメモリも必要である。ACELP はこれらを改善するために考案された。

ACELP で使われているコードブックの基本的なアイデアは、ハミング符号など誤り訂正符号の考え方に近い[3]ハミング符号などでは符号空間内に特定の規則を用いて距離(たとえばハミング距離)が等しくなるよう符号を割り当て、誤ったビットパターンに対して最も距離が近い符号を正しい符号(訂正済み符号)と見なす。同様に、ACELP で使われているコードブックは振幅が+1/-1のパルスを一定の規則で割り当てたものを用い、その中で誤差が最小になるものを符号化結果とする。規則的に生成したコードブックはメモリを消費せず、誤差が最小になるものを探索するのにも合理的である。

ACELP では振幅が固定のパルスを使うため、1つのパルスでの線形予測フィルターの出力を求めておけば全てのパルスの和による出力はそれらの合成により求められ、計算量を削減できる。 また、一般に誤差を最小にするために必要な+1/-1パルスは少数でよいことが分かっており、これを利用しさらにアルゴリズムを効率化している[2]

以下にITU G.722.2 コーデック(12.65kbpsモード時)の固定コードブックの例を示す [4]。 64 サンプルからなる処理単位(サブフレーム)を以下の 4 トラックに分け、それぞれに対して 2 ビット(全体で 8 ビット)の+1/-1パルスを割り当てる。

さらに見る トラック, 値 ...

ITU G.722.2 は複数のビットレートをサポートするが、高ビットレートでは1トラックに割り当てるパルスの数を増やし、低ビットレートの場合は1トラックに割り当てるパルスの数を減らしたりトラックの数を減らしたりする。固定コードブックをこのように柔軟に再構成できるのは ACELP の特徴の1つである。

Remove ads

応用

要約
視点

以下ではACELP を応用したアルゴリズムについて述べる。

CS-ACELP

ACELP を応用したアルゴリズムの代表的なものとして、ITU-T G.729(8kbps)で使用されている CS-ACELPconjugate structure - ACELP、共役構造ACELP)がある。

一般に、共役構造とはコードブックを以下のように2つのコードブックの線形結合で表すものでベクトル量子化のために使用され、最初は CELP の応用である CS-CELP で使用された。ここで ci , cj はそれぞれコードブックを、α は係数を表す。

この方法は2ステージのベクトル量子化によく似た方法で、単純なベクトル量子化と比べビット誤りに強くなり、コードブックのために必要なメモリが減り、計算の複雑さを減らす効果がある[5]

CS-ACELP は ACELP に共役構造のコードブックを組み合わせたものである。ITU-T G.729 では2つのコードブックの単純な和の形で表されている。

脚注

Loading content...

参考文献

Loading content...

関連項目

外部リンク

Loading content...
Loading related searches...

Wikiwand - on

Seamless Wikipedia browsing. On steroids.

Remove ads