CFG 단순화

CFG에서 문자열 파생에 모든 생산 규칙과 기호가 필요하지 않을 수 있습니다. 게다가, 일부 무효 제작 및 단위 제작이있을 수 있습니다. 이러한 제작물과 상징의 제거를simplification of CFGs. 단순화는 본질적으로 다음 단계로 구성됩니다.

  • CFG 감소
  • 단위 생산 제거
  • Null 프로덕션 제거

CFG 감소

CFG는 두 단계로 감소합니다.

Phase 1 − 동등한 문법의 유도, G’, CFG에서 G, 각 변수는 일부 터미널 문자열을 파생시킵니다.

Derivation Procedure

1 단계-모든 기호 포함, W1, 일부 터미널을 파생하고 초기화합니다. i=1.

2 단계-모든 기호 포함, Wi+1, 그 파생 Wi.

3 단계-증분 i 2 단계를 반복합니다. Wi+1 = Wi.

4 단계- Wi 그것에.

Phase 2 − 동등한 문법의 유도, G”, CFG에서 G’, 각 기호가 감각적 형식으로 표시되도록합니다.

Derivation Procedure

1 단계-시작 기호 포함 Y1 및 초기화 i = 1.

2 단계-모든 기호 포함, Yi+1, 파생 될 수있는 Yi 적용된 모든 생산 규칙을 ​​포함합니다.

3 단계-증분 i 2 단계를 반복합니다. Yi+1 = Yi.

문제

생산 규칙이있는 문법 G에 해당하는 축약 된 문법 찾기 P : S → AC | B, A → a, C → c | BC, E → aA | 이자형

해결책

Phase 1

T = {a, c, e}

W 1 = {A, C, E} 규칙 A → a, C → c 및 E → aA

W 2 = {A, C, E} U {S} 규칙 S → AC

3 = {A, C, E, S} U ∅

W 2 = W 3 이므로 G '를 다음과 같이 유도 할 수 있습니다.

G '= {{A, C, E, S}, {a, c, e}, P, {S}}

여기서 P : S → AC, A → a, C → c, E → aA | 이자형

Phase 2

Y 1 = {S}

Y 2 = {S, A, C} 규칙 S → AC

Y 3 = {S, A, C, a, c} 규칙 A → a 및 C → c

Y 4 = {S, A, C, a, c}

Y 3 = Y 4 이므로 G”를 다음과 같이 유도 할 수 있습니다.

G”= {{A, C, S}, {a, c}, P, {S}}

여기서 P : S → AC, A → a, C → c

단위 생산 제거

A → B 형식의 모든 생산 규칙 (A, B ∈ 비 터미널이 호출 됨) unit production..

제거 절차-

Step 1 − 제거하려면 A → B, 프로덕션 추가 A → x 문법 규칙에 B → x문법에서 발생합니다. [x ∈ 터미널, x는 Null 일 수 있음]

Step 2 − 삭제 A → B 문법에서.

Step 3 − 모든 단위 생산이 제거 될 때까지 1 단계부터 반복합니다.

Problem

다음에서 단위 생산을 제거하십시오-

S → XY, X → a, Y → Z | b, Z → M, M → N, N → a

Solution

문법에는 3 개의 단위 제작이 있습니다.

Y → Z, Z → M 및 M → N

At first, we will remove M → N.

N → a로 M → a를 추가하고 M → N을 제거합니다.

생산 세트는

S → XY, X → a, Y → Z | b, Z → M, M → a, N → a

Now we will remove Z → M.

M → a로 Z → a를 추가하고 Z → M을 제거합니다.

생산 세트는

S → XY, X → a, Y → Z | b, Z → a, M → a, N → a

Now we will remove Y → Z.

Z → a로 Y → a를 추가하고 Y → Z를 제거합니다.

생산 세트는

S → XY, X → a, Y → a | b, Z → a, M → a, N → a

이제 Z, M 및 N에 연결할 수 없으므로 제거 할 수 있습니다.

최종 CFG는 단위 생산이 필요 없습니다.

S → XY, X → a, Y → a | 비

Null 프로덕션 제거

CFG에서 비 터미널 기호 ‘A’ 프로덕션이있는 경우 nullable 변수입니다. A → ε 또는 다음에서 시작하는 파생이 있습니다. A 그리고 마지막으로

ε : A → .......… → ε

제거 절차

Step 1 − ε을 도출하는 nullable 비 말단 변수를 찾습니다.

Step 2 − 각 제작 A → a, 모든 프로덕션 구성 A → x 어디 x 에서 얻은 ‘a’ 1 단계에서 하나 또는 여러 개의 비 터미널을 제거하여

Step 3 − 원본 제작물을 2 단계의 결과와 결합하고 제거 ε - productions.

Problem

다음에서 null 생산을 제거하십시오-

S → ASA | aB | b, A → B, B → b | ∈

Solution

두 개의 nullable 변수가 있습니다- AB

At first, we will remove B → ε.

제거 후 B → ε, 생산 세트는-

S → ASA | aB | b | a, A ε B | b | 엡실론, B → b

Now we will remove A → ε.

제거 후 A → ε, 생산 세트는-

S → ASA | aB | b | a | SA | 그대로 | S, A → B | b, B → b

이것은 null 전환이없는 최종 프로덕션 세트입니다.