RE에서 FA 구성

Thompson 's Construction을 사용하여 정규 표현식에서 유한 오토 마톤을 찾을 수 있습니다. 정규 표현식을 가장 작은 정규 표현식으로 줄이고이를 NFA로 변환하고 마지막으로 DFA로 변환합니다.

일부 기본 RA 표현식은 다음과 같습니다.

Case 1 − 정규식 'a'의 경우 다음 FA를 구성 할 수 있습니다. −

Case 2 − 정규 표현식 'ab'의 경우 다음 FA를 구성 할 수 있습니다. −

Case 3 − 정규 표현식 (a + b)의 경우 다음 FA를 구성 할 수 있습니다. −

Case 4 − 정규 표현식 (a + b) *의 경우 다음 FA를 구성 할 수 있습니다. −

방법

Step 1 주어진 정규식에서 Null 이동을 사용하여 NFA를 구성합니다.

Step 2 NFA에서 Null 전환을 제거하고 동등한 DFA로 변환합니다.

Problem

다음 RA를 동등한 DFA − 1 (0 + 1) * 0으로 변환합니다.

Solution

세 가지 표현 "1", "(0 + 1) *"및 "0"을 연결합니다.

이제 우리는 ε전환. 제거 후ε NDFA에서 전환하면 다음을 얻습니다.

RE − 1 (0 + 1) * 0에 해당하는 NDFA입니다. DFA로 변환하려면 1 장에서 설명한 NDFA를 DFA로 변환하는 방법을 적용하면됩니다.

Null 동작이있는 유한 오토마타 (NFA-ε)

Null 이동 (FA-ε)이있는 유한 오토 마톤은 알파벳 세트에서 입력을 제공 한 후뿐만 아니라 입력 기호없이 이동합니다. 입력이없는이 전환을null move.

NFA-ε은 공식적으로 5- 튜플 (Q, ∑, δ, q 0 , F)로 표현되며

  • Q − 유한 한 상태 집합

  • − 유한 한 입력 기호 집합

  • δ− 전이 함수 δ : Q × (∑ ∪ {ε}) → 2 Q

  • q0− 초기 상태 q 0 ∈ Q

  • F − Q의 최종 상태 / 상태 세트 (F⊆Q).

(FA-ε) 문자열 세트 허용-{0, 1, 01}

유한 오토마타에서 Null 동작 제거

NDFA에서 정점 X와 정점 Y 사이에 ϵ- 이동이있는 경우 다음 단계를 사용하여 제거 할 수 있습니다.

  • Y에서 나가는 모든 가장자리를 찾습니다.
  • 가장자리 레이블을 변경하지 않고 X에서 시작하는 모든 가장자리를 복사합니다.
  • X가 초기 상태이면 Y도 초기 상태로 만듭니다.
  • Y가 최종 상태이면 X도 최종 상태로 만듭니다.

Problem

Null 이동없이 다음 NFA-ε을 NFA로 변환합니다.

Solution

Step 1

여기서 ε 전이는 q1q2, 그럼 q1 이다 Xqf 이다 Y.

여기서 q f 에서 나가는 에지는 입력 0과 1에 대해 q f 입니다.

Step 2

이제 우리는 q f 에서 가장자리를 변경하지 않고 q 1 에서 모든 가장자리를 복사 하고 다음 FA를 얻습니다.

Step 3

여기서 q 1 은 초기 상태이므로 q f 를 초기 상태로 만듭니다.

그래서 FA는-

Step 4

여기서 q f 는 최종 상태이므로 q 1 도 최종 상태로 만듭니다.

그래서 FA는-