簡潔データ構造
From Wikipedia, the free encyclopedia
簡潔データ構造 (かんけつデータこうぞう、英: succinct data structure) とは計算機科学の用語で、情報理論的下界に「近い」領域量だけを使いつつ、(他の圧縮形式とは異なり)効率的に質問を受け付けることができるデータ構造を指す。その概念は最初 Jacobson [1] によってビット配列、木、平面的グラフを符号化するために導入された。通常のロスなしデータ圧縮アルゴリズムとは異なり、簡潔データ構造は事前の展開操作をせずに使用することができる。圧縮データ構造は関連する考え方に基づいているが、圧縮データ構造ではデータ構造のサイズは表現しようとする特定のデータに依存する。
あるデータを保持するために必要な情報理論的に最小のビット数がだとする。このデータの表現形式は、
- ビットの領域を必要とする場合、implicit、
- ビットの領域を必要とする場合、簡潔 (succinct)、
- ビットの領域を必要とする場合、コンパクト (compact)
であると呼ばれる。
implicit データ構造は通常、なんらかの順列を用いて情報を保持することに帰着される。よく知られる事例としてはヒープが挙げられる。
エントロピー圧縮型辞書
簡潔索引つき辞書(簡潔ビットベクトル、完備辞書とも呼ぶ)は、rank/select 辞書とも呼ばれ、二分木、分木、多重集合[2]や、接尾辞木、接尾辞配列などの多数の簡潔表現手法の基礎をなしている[3]。基本的な問題設定は、 の空間中で部分集合を保持するというものであり、通常 iff とするビット配列として部分集合を表現する。索引つき辞書は通常の辞書の操作(参照、および動的辞書の場合は挿入と削除)に加えて、次の二つの操作をサポートする。
ただし、とする。
ある単純な表現方法 [4] では ビットの領域(元のビット配列と、 の補助データ構造)を使って rank と select を定数時間でサポートできる。この方法はRange Minimum Queryと似た考え方に基づいており、固定サイズの部分問題に行き着くまでに定数回数の再帰呼び出しだけで済む。ビット配列 はサイズ の大ブロックとサイズの小ブロックに分割される。大ブロック一つごとに、最初のビットのrankが別の表 に保持される。この表の各エントリには ビットが必要で、合計 ビットの領域を使う。大ブロックの中では、もう一つの表 を使って、そのブロックに含まれる 個の小ブロックのrankを保持する。ここでの違いは、各エントリで、そのエントリが入っている大ブロックの最初のビットのrankからの差分だけを保持すればよいので、 ビットだけが必要になることである。このため、この表は合計 ビットになる。そして、小ブロック内の ビットに対しては、 ビットの全てのビット列に対するrank質問の答えを保持するルックアップ表 を使うことができる。このテーブルには ビットの領域を必要とする。 これらの補助表は の領域だけを使うため、このデータ構造はrank質問を 時間と ビットの領域でサポートする。
次の定数時間アルゴリズムを用いると、の質問に定数時間で答えることができる。
実用上は、ルックアップ表 をビット命令とより小さい表で置き換え、小ブロックで立っているビットの数を調べるようにすることができる。多くの場合、こうすることで大きなデータセットで簡潔データ構造を用いる際の、キャッシュミスの増大とそれによって起こるルックアップ表がキャッシュから追い出されるという問題に対処できる[5]。select質問は、rankに用いたものと同じ補助データ構造と二分探索とを合わせることで容易にサポートできるが、そのやり方では最悪の場合 の時間がかかる。 ビットの追加領域を用いる、より複雑なデータ構造により、selectは定数時間でサポートできる[6]。こうした解決法の多くでは、実用上、漸近的な特長が効果を発揮する至らない場合、記法に隠れた定数が支配的となる。その場合、長ワード命令とワードサイズに揃えたブロックを利用した実装のほうが効率的であることが多い[7]。
の領域のアプローチは、 のなかには異なる -部分集合が(言い換えるなら、長さでちょうど個の1があるビット列が) 個あることに注意すると、さらに改善できる。このとき、を保持するのに必要なビット数の情報理論的下界は、である。この下界を達成する(静的な)簡潔辞書は存在し、 必要とする領域は である[8]。そのデータ構造はさらに、の領域量でrankとselectをサポートするように拡張することができる[2]。この下界は、辞書を保持する領域を とし、質問に必要な時間を とすることで領域と時間のトレードオフに帰着させることができる[9]。