コンテンツにスキップ
Wikipedia

形式言語

出典: フリー百科事典『ウィキペディア(Wikipedia)』
印刷用ページはサポート対象外です。表示エラーが発生する可能性があります。ブラウザーのブックマークを更新し、印刷にはブラウザーの印刷機能を使用してください。

形式言語(けいしきげんご、: formal language)とは、文法構文, 統語論などが、すべて形式的に与えられている言語である。人工言語の一種[1]

→「形式体系」も参照

形式的でないために、しばしば曖昧さが残されたり、話者集団によって用法がうつろいていったりする自然言語に対して、形式言語は、用法の変化に関しては非常に厳格である。

この記事では、形式的な統語論すなわち構文の形式的な定義と形式文法について述べる。形式的な意味論については形式意味論の記事を参照。

定義

形式言語の理論、特にオートマトン理論と関連したそれにおいては、言語はアルファベットの列(語 word) の集合である[2]

L Σ = { σ 1 , σ 2 , . . . | σ i Σ } {\displaystyle L\subset \Sigma ^{*}=\{\langle \sigma _{1},\sigma _{2},...\rangle |\sigma _{i}\in \Sigma \}} {\displaystyle L\subset \Sigma ^{*}=\{\langle \sigma _{1},\sigma _{2},...\rangle |\sigma _{i}\in \Sigma \}}

ただし、長さゼロの空単語(Empty Word, 記号 e {\displaystyle e} {\displaystyle e} ϵ {\displaystyle \epsilon } {\displaystyle \epsilon } Λ {\displaystyle \Lambda } {\displaystyle \Lambda })も含む。 チューリングマシンの言語は単なる文字列なので、数学的構造(他のチューリングマシンを含む)を扱うには符号化(エンコード)し、その数値を解釈するプログラムを埋め込む必要がある。 チューリング完全機械は十分強力なので、この手法であらゆる列挙可能な構造を扱うことができる。チューリングマシンの数値表現については(チューリングマシンの)表記(description)という。

あるチューリングマシンが存在して、言語に属するすべての語 w に対して動作させると受理状態で停止し、属さない語には受理しないようなとき、その言語はチューリング認識可能という。 また、言語に属さないときは必ず拒否状態で停止する場合、その言語はチューリング判別可能であるという。(この2つの違いは、一部の入力に対してチューリングマシンが停止しない場合があるかどうかである) また、チューリングマシンTMの言語 L(TM) とは、テープに w をセットしたあと、TMを動作させると受理状態に入って停止するような w の集合からなる言語(TM認識可能な言語)のことである。

この言語には以下のような演算が定義される。ここで、 L 1 {\displaystyle L_{1}} {\displaystyle L_{1}} L 2 {\displaystyle L_{2}} {\displaystyle L_{2}} は共通のアルファベットから構成される言語であるとする。

  • 「連結」 L 1 L 2 {\displaystyle L_{1}L_{2}\quad } {\displaystyle L_{1}L_{2}\quad } は、文字列群 v w {\displaystyle vw} {\displaystyle vw} から構成される。ここで、 v {\displaystyle v} {\displaystyle v} L 1 {\displaystyle L_{1}} {\displaystyle L_{1}} に含まれる文字列で、 w {\displaystyle w} {\displaystyle w} L 2 {\displaystyle L_{2}} {\displaystyle L_{2}} に含まれる文字列である。
  • 「積集合」 L 1 L 2 {\displaystyle L_{1}\cap L_{2}} {\displaystyle L_{1}\cap L_{2}} は、 L 1 {\displaystyle L_{1}} {\displaystyle L_{1}} にも L 2 {\displaystyle L_{2}} {\displaystyle L_{2}} にも含まれる文字列の集合である。
  • 「和集合」 L 1 L 2 {\displaystyle L_{1}\cup L_{2}} {\displaystyle L_{1}\cup L_{2}} は、 L 1 {\displaystyle L_{1}} {\displaystyle L_{1}} L 2 {\displaystyle L_{2}} {\displaystyle L_{2}} に含まれる文字列の集合である。
  • L 1 {\displaystyle L_{1}} {\displaystyle L_{1}} の「補集合」は、 L 1 {\displaystyle L_{1}} {\displaystyle L_{1}} に含まれない全ての文字列の集合である。
  • 「商集合」 L 1 / L 2 {\displaystyle L_{1}/L_{2}\quad } {\displaystyle L_{1}/L_{2}\quad } は、 L 1 {\displaystyle L_{1}} {\displaystyle L_{1}} に含まれる文字列 v w {\displaystyle vw} {\displaystyle vw} に対して、 L 2 {\displaystyle L_{2}} {\displaystyle L_{2}} に含まれる文字列 w {\displaystyle w} {\displaystyle w} が存在するときに、全ての v {\displaystyle v} {\displaystyle v} に相当する文字列群から構成される。
  • クリーネスター L 1 {\displaystyle L_{1}^{*}} {\displaystyle L_{1}^{*}} は、 w 1 w 2 . . . w n {\displaystyle w_{1}w_{2}...w_{n}} {\displaystyle w_{1}w_{2}...w_{n}} という形式の全文字列群から構成される。ただし、 w i {\displaystyle w_{i}} {\displaystyle w_{i}} L 1 {\displaystyle L_{1}} {\displaystyle L_{1}} に含まれ、 n 0 {\displaystyle n\geq 0} {\displaystyle n\geq 0} である。注意すべきは、 n = 0 {\displaystyle n=0} {\displaystyle n=0} の場合もあるので、空文字列 ϵ {\displaystyle \epsilon } {\displaystyle \epsilon } も含まれるという点である。
  • 「反転」 L 1 R {\displaystyle L_{1}^{R}} {\displaystyle L_{1}^{R}} は、 L 1 {\displaystyle L_{1}} {\displaystyle L_{1}} の全文字列を反転させた文字列群から構成される。
  • L 1 {\displaystyle L_{1}} {\displaystyle L_{1}} L 2 {\displaystyle L_{2}} {\displaystyle L_{2}} の「シャッフル」とは、 v 1 w 1 v 2 w 2 . . . v n w n {\displaystyle v_{1}w_{1}v_{2}w_{2}...v_{n}w_{n}} {\displaystyle v_{1}w_{1}v_{2}w_{2}...v_{n}w_{n}} で表される全文字列から構成される。ここで、 n 1 {\displaystyle n\geq 1} {\displaystyle n\geq 1} で、 v 1 , . . . , v n {\displaystyle v_{1},...,v_{n}} {\displaystyle v_{1},...,v_{n}} を連結した v 1 . . . v n {\displaystyle v_{1}...v_{n}} {\displaystyle v_{1}...v_{n}} L 1 {\displaystyle L_{1}} {\displaystyle L_{1}} に含まれる文字列であり、 w 1 , . . . , w n {\displaystyle w_{1},...,w_{n}} {\displaystyle w_{1},...,w_{n}} を連結した w 1 . . . w n {\displaystyle w_{1}...w_{n}} {\displaystyle w_{1}...w_{n}} L 2 {\displaystyle L_{2}} {\displaystyle L_{2}} に含まれる文字列である。

モデル理論においては、言語は定数記号、関数記号、述語記号の集合である[3]

L = { c 0 , c 1 , . . . } { f 0 , f 1 , . . . } { p 0 , p 1 , . . . } {\displaystyle L=\{c_{0},c_{1},...\}\cup \{f_{0},f_{1},...\}\cup \{p_{0},p_{1},...\}} {\displaystyle L=\{c_{0},c_{1},...\}\cup \{f_{0},f_{1},...\}\cup \{p_{0},p_{1},...\}}

形式文法

→詳細は「形式文法」を参照

形式言語は、形式文法と密接な関係がある。例として、次のような文脈自由文法の構文規則があるとき、

  • 名詞句 ::= 名詞 | 形容詞 名詞 | 名詞句 "を" 動詞 "ている" 名詞句
  • 動詞 ::= "見"
  • 名詞 ::= "猿" | "飼育員"
  • 形容詞 ::= "小さい"

以下のように規則を再帰的に適用して、その言語の要素(名詞句)を列挙することができる。

  1. (猿 飼育員 小さい猿 小さい飼育員)
  2. (猿 飼育員 小さい猿 小さい飼育員 猿を見ている猿 猿を見ている飼育員 猿を見ている小さい猿 ... 小さい猿を見ている猿 ...)
  3. (猿 飼育員 小さい猿 小さい飼育員 猿を見ている猿 ... 猿をみている猿を見ている猿 ... 小さい猿を見ている猿を見ている小さい飼育員を見ている猿 ...)

...

すなわち、このような操作の任意回の繰り返しによって、その言語(文の集合)が得られる。

また、形式文法が階層をなすというチョムスキー階層は、生成する言語では言語の認識に必要な最小のオートマトンが階層をなすという形で現れる。

その他

この節には独自研究が含まれているおそれがあります。 問題箇所を検証出典を追加して、記事の改善にご協力ください。議論はノートを参照してください。(2015年11月)

言及される分野

形式言語は、「人や計算機の如何なる記号変換能力から如何なる思考能力や計算能力が生まれるか」の学としての広義の数理論理学の研究対象であり、従って形式言語は、哲学言語学計算機科学数学基礎論数理心理学等々において重要な役割を演ずる。 それらの学問分野では、如何なる形式言語を研究すべきかの文法論(構文論・統辞論)や形式言語の意味論演繹論が研究される。

形式手法という場合には、形式言語に加えて、模擬試験、検証・証明などの仕組みを込みで言う場合が有る。

自然言語への応用

→「生成文法」および「句構造文法」を参照

自然言語を比較的単純な形式言語のモデルにあてはめて分析する言語学は、チョムスキーによって提唱された。音素語幹などを素記号として考える。 実際の自然言語の構文規則(あるいは文法)は、文字通り自然発生的のものであり、形式言語における構文規則のように明確に規定するのは難しい。

ただ、素朴な文法論の主張は、形式言語の理論とみなすことができる。 素朴な文法論は、例えば次のようなものである。

  • 品詞にはこのようなのものがある。
  • この語はあの品詞に属す。
  • この品詞に属す語をこの活用組み合わせ順序とで並べると文(や)になる。

こういう文法論はすなわち、素記号とは何かを定め、それらから文を作る構文規則を定めるのだから、まさに形式言語の理論である。

こういう形式言語論的な文法論は、実際の言語と比較することで自然言語の特徴を浮き彫りにし、自然言語のより深い理解へと導くことを可能とすることもなくはない。言語そのものではなく、言語行動の深層をなす人間精神を探るためには、むしろこういう文法論を数学化し、更に意味論・文法論を伴った論理学にまで推し進めることが有意義ともいえよう。

脚注

  1. ^ 言語学 その1~当たり前過ぎて意識しなくなっていること
  2. ^ Micael Sipser (2005). Introduction to the Theory of Computation. ISBN 0534950973  
  3. ^ 坪井明人 (2011年). "数学基礎論サマースクール モデル理論入門". 2012年2月18日閲覧。
ウィキメディア・コモンズには、形式言語 に関連するカテゴリがあります。
 
関連項目
学術的領域
基本概念
 
基幹
名辞論理学 (英語版)
命題論理ブール論理
述語論理
標準形
集合論
モデル理論
証明論
再帰理論
表現
カテゴリ カテゴリ

AltStyle によって変換されたページ (->オリジナル) /