文脈自由文法の紹介

Definition −有限の文法規則のセットで構成される文脈自由文法(CFG)は4倍です (N, T, P, S) どこ

  • N 非終端記号のセットです。

  • T は端末のセットです。 N ∩ T = NULL.

  • P ルールのセットです、 P: N → (N ∪ T)*、つまり、プロダクションルールの左側 P 右のコンテキストまたは左のコンテキストがあります。

  • S 開始記号です。

Example

  • 文法({A}、{a、b、c}、P、A)、P:A→aA、A→abc。
  • 文法({S、a、b}、{a、b}、P、S)、P:S→aSa、S→bSb、S→ε
  • 文法({S、F}、{0、1}、P、S)、P:S→00S | 11F、F→00F | ε

派生ツリーの生成

派生ツリーまたは解析ツリーは、文脈自由文法から派生した文字列のセマンティック情報をグラフィカルに表す、順序付けられたルートツリーです。

表現テクニック

  • Root vertex −開始記号でラベル付けする必要があります。

  • Vertex −非終端記号でラベル付けされています。

  • Leaves −終端記号またはεでラベル付けされています。

S場合→X 1、X 2 ...... X nはCFGにおける生成規則であり、次のように解析木/派生ツリーになります-

派生ツリーを描画するには、2つの異なるアプローチがあります-

Top-down Approach −

  • 開始記号で始まります S

  • プロダクションを使用して木の葉に降りる

Bottom-up Approach −

  • 木の葉から始まります

  • 開始記号であるルートまで上向きに進みます S

木の派生または収量

解析ツリーの派生または歩留まりは、ヌルを無視して、ツリーの葉のラベルを左から右に連結することによって取得される最終的な文字列です。ただし、すべての葉がNullの場合、派生はNullです。

Example

CFG {N、T、P、S}を

N = {S}、T = {a、b}、開始記号= S、P = S→SS | aSb | ε

上記のCFGからの派生の1つは、「abaabb」です。

S→SS→aSbS→abS→abaSb→abaaSbb→abaabb

センテンスフォームと部分派生ツリー

部分派生ツリーは、派生ツリー/解析ツリーのサブツリーであり、そのすべての子がサブツリーにあるか、サブツリーに含まれていないかのいずれかです。

Example

いずれかのCFGの場合、プロダクションは-

S→AB、A→aaA | ε、B→Bb | ε

部分的な派生ツリーは次のようになります-

部分的な派生ツリーにルートSが含まれている場合、それは sentential form。上記のサブツリーもセンテンス形式です。

文字列の左端と右端の派生

  • Leftmost derivation −左端の派生は、各ステップで左端の変数に生成を適用することによって取得されます。

  • Rightmost derivation −右端の派生は、各ステップで右端の変数に生成を適用することによって取得されます。

Example

CFGの生産規則の任意のセットを

X→X + X | X * X | X | a

アルファベット{a}の上。

文字列の左端の派生 "a+a*a" かもしれません-

X→X + X→a + X→a + X * X→a + a * X→a + a * a

上記の文字列の段階的な導出を以下に示します-

上記の文字列の右端の派生 "a+a*a" かもしれません-

X→X * X→X * a→X + X * a→X + a * a→a + a * a

上記の文字列の段階的な導出を以下に示します-

左右の再帰文法

文脈自由文法で G、フォームにプロダクションがある場合 X → Xa どこ X 非終端記号であり、 ‘a’ は端末の文字列であり、 left recursive production。左再帰的生成を持つ文法は、left recursive grammar

そして、文脈自由文法の場合 G、プロダクションがある場合はフォームにあります X → aX どこ X 非終端記号であり、 ‘a’ は端末の文字列であり、 right recursive production。正しい再帰的生成を持つ文法は、right recursive grammar