Aritalab:Lecture/Bioinformatics/Alignment
|
- このページで説明するアルゴリズムの Java コード
Needleman-Wunsch (-Sellers) アルゴリズム
1970年、分子生物学者の Saul B. NeedlemanとChristian D. Wunsch は、大域アライメントのアルゴリズムを Journal of Molecular Biology誌 (1970) 48: 443-453 に発表しました。いまでは誤って Needleman-Wunsch アルゴリズムと呼ばれるようになりましたが、論文は効率が悪い手法、O(n3) 時間、を紹介しています。ここで紹介されるアルゴリズムの原型を作ったのは Peter Sellers (1974) です[1]。したがって正確には Needleman-Wunsch-Sellers アルゴリズムと呼ぶべきでしょう [2]。
基本は最長共通部分列(LCS)アルゴリズムと同じで、動的計画法によるLCSのページで紹介した以下の漸化式に基づいてスコア行列を計算します。ギャップとミスマッチに対してそれぞれペナルティスコア (gap penalty σ, mismatch penalty μ)が与えられています。
ここではギャップペナルティを 2、ミスマッチペナルティを 1 として、2つの配列 gctagg と aattgaagg の間のアライメントを考えてみましょう。スコア行列は右のようになります。 1行目と1列目は 0, -2, -4, -6, ... -18 とギャップペナルティに基づく等差数列ができています。これは左隣(または上)のセルからギャップペナルティ 2 を順次マイナスしてできる部分です。大域アライメントでは配列の最初と最後を揃えるために、初期状態としてギャップの数に比例するペナルティを与えます。 残りのセルは動的計画法に基づいてスコアが埋められ、最適アライメントは以下のようになります。 1:aattgaagg:9 | | || 1:gct--a-gg:6 右図のトレースバックと見比べてみてください。大域アライメントのスコアは マッチ 4 × 1 + ミスマッチ 2 × (-1) + ギャップ 3 × (-2) = -4 となっています。大域アライメントにおけるギャップの数は配列長の差になります。具体的なアルゴリズムとJavaコードはこのページを参照してください。 |
|
Smith-Waterman アルゴリズム
バイオインフォマティクスの草分けである Temple F. Smith と Michael S. Waterman が 1981 年に Journal of Molecular Biology誌 (147: 195–197) に発表した局所アライメントを求めるアルゴリズムです。MS Waterman は動的計画法を RNA 二次構造の解析などに応用して活躍した数学者ですが、TF Smithは配列アライメントに関する実績もなく、このアルゴリズムをWalther Goad から聞いて論文にしたといわれる曰くつきのアルゴリズムです[3]。FASTAパッケージ(後述)の中では SSEARCH の名前で実装されていました。局所アライメントは以下のように定義されます。
局所アライメント = 与えられた2つの配列それぞれの全ての部分配列のペア中で、大域アライメントのスコアを最大にするもの
この定義だとすべての部分配列を列挙して大域アライメントを施す必要が思えますが、そうではありません。動的計画法において常にスコア 0 を候補に置くだけで、同じ計算時間で局所アライメントを求められるところが大変エレガントなアルゴリズムです。オリジナル論文はアフィンギャップ関数(後述)という、生物学的に意味のあるギャップペナルティを採用しています。
ここではギャップペナルティを 2、ミスマッチペナルティを 1 として、2つの配列 gctagg と aattgaagg の間のアライメントを考えてみましょう。スコア行列は右のようになります。 どこからアライメントを初めてもよいため 1 行目と 1 列目はすべて 0 にします[4]。 残りのセルは動的計画法に基づいてスコアが埋められ、最適アライメントは以下のようになります。この例は説明の都合上、大域アライメントと同じ配列のため、たまたま右下部分が最大値になっています。アルゴリズム自体は最適値がスコア行列の任意の箇所に出てもよいことに注意してください。 7:agg:9 ||| 4:agg:6 具体的なアルゴリズムとJavaコードはこのページを参照してください。 |
|
アフィンギャップと Gotoh アルゴリズム
上記のアルゴリズムでは、ギャップとして欠失する塩基数に比例したペナルティが課されますが、配列進化の観点では不適切なスコアです。 ギャップは配列が切断されることを意味しますが、その間に挿入される配列の長さは配列の切断というイベントに比較して重要ではありません。そのため、実用のアルゴリズムでは
- ギャップ開始 (open) ペナルティ σo
- ギャップ伸長 (extension) ペナルティ σx
を導入し、長さ n のギャップに対し σo + (n-1) σx のコストとします。ギャップ伸長ペナルティの値は開始ペナルティよりもずっと小さくします。ギャップ長に比例する値でコストが増加するペナルティ方式を(平行移動のアフィン変換にちなんで)アフィンギャップと呼びます。計算量を O(n2) に抑えたままアフィンギャップコストを計算するアルゴリズムを最初に示したのは日本の後藤修(ごとうおさむ)先生です[5]。
この関数を使うと、アライメントスコアは
(マッチ数) − μ(ミスマッチ数) − σo(ギャップ開始数) − σx(ギャップスペース数)
と書けます。
まずスコア行列と同じサイズのギャップ管理用行列 P (横方向用)、Q (縦方向用) を用意します。それらの初期値は位置 ( i , 0 ), ( 0 , j ) に対してそれぞれ −σo − i σx と −σo − j σx とします。ここでは σo = 2, σx = 0.1 で計算してあります。そして以下の漸化式を用います。
|
位置 (i , j) にいるとき、スコアの求め方を考えましょう。普通に考えるとセル (i , j) の左側全部と上側全部のセル(薄い影がかかっている領域)全ての位置から、ギャップが入る可能性を検討しなくてはなりません。それを素直に実行すると各セルの値を計算するのに O(n) 時間かかるため、全体で O(n3) 時間の計算量になります。その手間を省くために行列 P, Q を導入します。 行列 P, Q はそれぞれ位置 (i , j) が横方向および縦方向のギャップに含まれる際のスコアを記録しておく部分です。P と Q の漸化式をみると、それまで続いていたギャップを延長するか (P なら位置 i をスキップし、Q なら位置 j をスキップ)、新たに位置 i , j からギャップを開くか判断しています。これらの行列に前の方からギャップを伸長した場合のスコアを記録してあり、通常のスコアとの比較をおこないます。 |
- 参考文献
- ↑ P Sellers "On the theory and computation of evolutionary distances" SIAM J. Appl. Math. 26:787–793, 1974 にアルゴリズムが紹介されています。
- ↑ 1970年当時の様子は David Sankoff "The early introduction of dynamic programming into computational biology" Bioinformatics 16(1):41-47 (pdf)を見るとよいでしょう。
- ↑ Walter Goad は後日 W Goad "Sequence Analysis: Contributions by Ulam to Molecular Genetics" Los Alamos Science (special issue) 288-291, 1987 (pdf) に、自分のほうが先に見つけたと言いたげな記述をしています。
- ↑ 本当は漸化式の中に0を含めるのでどんな正値でも良いのですが、分かりやすさのためにどの本を見ても0で埋めると書いてあります。
- ↑ O Gotoh "An improved algorithm for matching bilogical sequences" J Mol Biol 162:705-8, 1982 (pdf)