プッシュダウン・オートマトン

オートマトン理論

プッシュダウン・オートマトン: pushdown automaton, PDA)は、オートマトンの一種であり、文脈自由言語を認識する抽象機械である。

ある意味では、プッシュダウン・オートマトンは有限オートマトンと無限の容量のスタックを組み合せたシステムである。

概要

プッシュダウンオートマトンは通常の有限オートマトンとは以下の二点で異なる。

  1. スタックのトップを使って成すべき状態遷移を判断する。
  2. 遷移実行の一部としてスタック操作を行うことが出来る。

プッシュダウン・オートマトンは入力信号、現在状態、スタックのトップを使って状態遷移表内の位置を指定することで遷移先を選択する。通常の有限オートマトンは現在状態と入力信号しかなく、スタックは持たない。プッシュダウン・オートマトンはスタックを遷移先選択のパラメータに加える。つまり、入力信号と現在状態とスタックのトップにある文字から遷移先を選択する。

プッシュダウン・オートマトンは、遷移を実行する動作の一部としてスタックを操作することもできる。通常の有限オートマトンは遷移の結果として新しい状態を選択する。スタック操作とはある特定の文字をスタックにプッシュすることやスタックのトップをポップすることを意味する。また、プッシュダウン・オートマトンはスタックを操作せずにそのままにしておくこともできる。どう操作するかは状態遷移表によって決定される。

まとめると、入力信号と現在状態とスタック上の文字によって状態遷移すると共に、必要に応じてスタック操作を行う。

有限オートマトンでも特に非決定性有限オートマトンに基づいている場合、「非決定性プッシュダウン・オートマトン」(NPDA、nondeterministic pushdown automaton)と呼ばれる。決定性有限オートマトンに基づいている場合、「決定性プッシュダウン・オートマトン(英語版)」(DPDA、deterministic pushdown automaton)と呼ばれる。非決定性とは、入力信号と状態とスタック上の文字を与えられても次の遷移先が一意に決定されない場合があることを意味する。

有限オートマトンにふたつのスタックを接続することもでき、これは事実上チューリングマシンと等価な非常に強力なデバイスとなる。線形拘束オートマトンはプッシュダウン・オートマトンよりも強力だが、チューリングマシンよりは非力である。

形式的定義

形式的には、PDA は以下の6-タプルで定義される。

M = ( Q ,   Σ ,   Γ ,   δ ,   q 0 ,   F ) {\displaystyle M=(Q,\ \Sigma ,\ \Gamma ,\ \delta ,\ q_{0},\ F)}

ここで、

  • Q {\displaystyle \,Q} は状態の有限集合
  • Σ {\displaystyle \,\Sigma } は入力アルファベットの有限集合
  • Γ {\displaystyle \,\Gamma } はスタック上のアルファベットの有限集合
  • δ {\displaystyle \,\delta } : Q × Σ ϵ × Γ ϵ P ( Q × Γ ϵ ) {\displaystyle Q\times \Sigma _{\epsilon }\times \Gamma _{\epsilon }\longrightarrow P(Q\times \Gamma _{\epsilon })} は遷移関数
  • q 0 {\displaystyle q_{0}} は開始状態
  • F Q {\displaystyle F\subset Q} は受容(受理)状態の集合
  • Γ ϵ = Γ { ϵ } {\displaystyle \Gamma _{\epsilon }=\Gamma \cup \{\epsilon \}}
  • Σ ϵ = Σ { ϵ } {\displaystyle \Sigma _{\epsilon }=\Sigma \cup \{\epsilon \}}

計算定義 1

任意のPDA、 M = ( Q ,   Σ ,   Γ ,   δ ,   q 0 ,   F ) {\displaystyle M=(Q,\ \Sigma ,\ \Gamma ,\ \delta ,\ q_{0},\ F)} について、計算経路の順序は (n+1)-タプル ( q 0 , q 1 , . . . . , q n ) {\displaystyle (q_{0},\,q_{1},....,\,q_{n})} で表され(ここで q i Q , n {\displaystyle q_{i}\in Q,n\geq } 0 )、以下の条件が成り立つ。

  1. i = 0 , 1 , 2 , , n 1 {\displaystyle i=0,1,2,\dots ,n-1} について、     ( q i + 1 , b i + 1 ) δ ( q i , w i + 1 , a i + 1 ) {\displaystyle \ \ (q_{i+1},b_{i+1})\in \delta (q_{i},w_{i+1},a_{i+1})}
    ここで w i + 1 Σ ϵ ,   a i + 1 ,   b i + 1 Γ ϵ {\displaystyle w_{i+1}\in \Sigma _{\epsilon },\ a_{i+1},\ b_{i+1}\in \Gamma _{\epsilon }}
  2. s 0 , s 1 , s 2 , s 3 , , s n Γ {\displaystyle \exists \,s_{0},\,s_{1},\,s_{2},\,s_{3},\,\dots ,\,s_{n}\,\in \Gamma ^{*}} について s i = a i + 1 t i , s i + 1 = b i + 1 t i , t i Γ {\displaystyle s_{i}=a_{i+1}t_{i},\,s_{i+1}=b_{i+1}t_{i},\,t_{i}\in \Gamma ^{*}}

直観的に、PDA での計算の任意の時点で、スタックのトップから記号を読み取ってそれを他の記号に置換するか、置換せずに単にスタックのトップを削除するか、あるいは読み取らずにスタックに新たに記号を追加するか、なにもしないかという選択肢がある。これらは連立方程式 s i = a i + 1 t i a n d s i + 1 = b i + 1 t i {\displaystyle s_{i}=a_{i+1}t_{i}\,and\,s_{i+1}=b_{i+1}t_{i}} で制御される。 s i {\displaystyle \,s_{i}} は、(i+1)番目の状態遷移の直前のスタックの内容であり、 a i + 1 {\displaystyle a_{i+1}} はスタックのトップから除去される記号である。 s i + 1 {\displaystyle s_{i+1}} は (i+1)番目の状態遷移の直後のスタックの内容であり、 b i + 1 {\displaystyle b_{i+1}} は (i+1)番目の状態遷移に伴ってスタックに追加される記号である。

a i + 1 {\displaystyle a_{i+1}} b i + 1 {\displaystyle b_{i+1}} ϵ {\displaystyle \epsilon } の可能性もある。

  • a i + 1 ϵ {\displaystyle a_{i+1}\neq \epsilon } かつ b i + 1 ϵ {\displaystyle b_{i+1}\neq \epsilon } なら、PDA はスタックから記号を読み取り、それを別の記号に置換する。
  • a i + 1 ϵ {\displaystyle a_{i+1}\neq \epsilon } かつ b i + 1 = ϵ {\displaystyle b_{i+1}=\epsilon } なら、PDA はスタックから記号を読み取り、単にそれを削除する。
  • a i + 1 = ϵ {\displaystyle a_{i+1}=\epsilon } かつ b i + 1 ϵ {\displaystyle b_{i+1}\neq \epsilon } なら、PDA は単に記号をスタックに追加する。
  • a i + 1 = ϵ {\displaystyle a_{i+1}=\epsilon } かつ b i + 1 = ϵ {\displaystyle b_{i+1}=\epsilon } なら、PDA はスタックを更新しない。

n = 0 {\displaystyle n=0} の場合、計算経路はシングルトンとなる ( q 0 ) {\displaystyle (q_{0})}

計算定義 2

任意の入力 w = w 1 w 2 w m {\displaystyle w=w_{1}w_{2}\dots w_{m}} について、 w i Σ , m 0 {\displaystyle w_{i}\in \Sigma ,m\geq 0} であり、M が w を受容するのは、計算経路 ( q 0 , q 1 , . . . . , q n ) {\displaystyle (q_{0},\,q_{1},....,\,q_{n})} と有限の状態列 r 0 , r 1 , r 2 , , r m Q , m n {\displaystyle r_{0},r_{1},r_{2},\dots ,r_{m}\in Q,m\leq n} が存在し、以下が成り立つ場合である。

  1. i = 0 , 1 , 2 , , m {\displaystyle i=0,1,2,\dots ,m} の各々について、 r i {\displaystyle r_{i}} が計算経路上にある。すなわち、
    ある f ( i ) {\displaystyle f(i)} が存在し、 i f ( i ) n {\displaystyle i\leq f(i)\leq n} で、 r i = q f ( i ) {\displaystyle r_{i}=q_{f(i)}} が成り立つ。
  2. i = 0 , 1 , 2 , , m 1 {\displaystyle i=0,1,2,\dots ,m-1} の各々について、 ( q f ( i ) + 1 , b f ( i ) + 1 ) δ ( r i , w i + 1 , a f ( i ) + 1 ) {\displaystyle (q_{f(i)+1},b_{f(i)+1})\in \delta (r_{i},w_{i+1},a_{f(i)+1})}
    ここで a f ( i ) + 1 {\displaystyle a_{f(i)+1}} b f ( i ) + 1 {\displaystyle b_{f(i)+1}} は計算定義 1 で定義されたもの。
  3. q j { r 0 , r 1 , r m } {\displaystyle q_{j}\notin \{r_{0},r_{1},\dots r_{m}\}} であるとき、 ( q j + 1 , b j + 1 ) δ ( q j , ϵ , a j + 1 ) {\displaystyle (q_{j+1},b_{j+1})\in \delta (q_{j},\epsilon ,a_{j+1})}
    ここで a j + 1 {\displaystyle a_{j+1}} b j + 1 {\displaystyle b_{j+1}} は計算定義 1 で定義されたもの。
  4. r m = q n {\displaystyle r_{m}=q_{n}} かつ r m F {\displaystyle r_{m}\in F}

これら定義はスタックが空かどうかの判定機構を提供していない点に注意。スタックが空かどうかを判定するには、計算前にスタックに特殊記号を書いておき、PDA がスタックを読んでその記号が読み取れた場合は空であると判断する。形式的には、 δ ( q 0 , ϵ , ϵ ) = { ( q 1 , $ ) } {\displaystyle \delta (q_{0},\epsilon ,\,\epsilon )=\{(q_{1},\$)\}} という遷移を導入する。ここで、$ はその特殊記号である。

言語 { 0 n 1 n | n 0 } {\displaystyle \{0^{n}1^{n}|n\geq 0\}} を認識するPDAの形式定義は以下の通りである。

M = ( Q ,   Σ ,   Γ ,   δ ,   q 1 ,   F ) {\displaystyle M=(Q,\ \Sigma ,\ \Gamma ,\ \delta ,\ q_{1},\ F)}

Q = { q 1 , q 2 , q 3 , q 4 } {\displaystyle Q=\{q_{1},q_{2},q_{3},q_{4}\}}

Σ = { 0 , 1 } {\displaystyle \Sigma =\{0,1\}}

Γ = { 0 , $ } {\displaystyle \Gamma =\{0,\$\}}

F = { q 1 , q 4 } {\displaystyle F=\{q_{1},q_{4}\}}

δ ( q 1 , ϵ , ϵ ) = { ( q 2 , $ ) , ( q 1 , ϵ ) } {\displaystyle \delta (q_{1},\epsilon ,\epsilon )=\{(q_{2},\$),(q_{1},\epsilon )\}}

δ ( q 2 , 0 , ϵ ) = { ( q 2 , 0 ) } {\displaystyle \delta (q_{2},0,\epsilon )=\{(q_{2},0)\}}

δ ( q 2 , 1 , 0 ) = { ( q 3 , ϵ ) } {\displaystyle \delta (q_{2},1,0)=\{(q_{3},\epsilon )\}}

δ ( q 3 , 1 , 0 ) = { ( q 3 , ϵ ) } {\displaystyle \delta (q_{3},1,0)=\{(q_{3},\epsilon )\}}

δ ( q 3 , ϵ , $ ) = { ( q 4 , ϵ ) } {\displaystyle \delta (q_{3},\epsilon ,\$)=\{(q_{4},\epsilon )\}}

上記以外の状態、入力、スタック記号については常に δ ( q , w , a ) = Φ {\displaystyle \delta (q,w,a)=\Phi } である。

参考文献

  • Michael Sipser (1997年). Introduction to the Theory of Computation. PWS Publishing. ISBN 0-534-94728-X  Section 2.2: Pushdown Automata, pp.101–114.

関連項目

外部リンク

  • non-deterministic pushdown automaton on Planet Math.
  • JFLAP - 数種類のオートマトンのシミュレータ。非決定性プッシュダウンオートマトンも含まれている。