Satz von Arden

Um einen regulären Ausdruck eines endlichen Automaten herauszufinden, verwenden wir den Satz von Arden zusammen mit den Eigenschaften regulärer Ausdrücke.

Statement - -

Lassen P und Q seien zwei reguläre Ausdrücke.

Wenn P enthält also keine Nullzeichenfolge R = Q + RP hat eine einzigartige Lösung, die ist R = QP*

Proof - -

R = Q + (Q + RP) P [Nach Eingabe des Wertes R = Q + RP]

= Q + QP + RPP

Wenn wir den Wert von setzen R Immer wieder erhalten wir rekursiv die folgende Gleichung:

R = Q + QP + QP 2 + QP 3 … ..

R = Q (ε + P + P 2 + P 3 + ...)

R = QP * [Wie P * darstellt (ε + P + P2 + P3 +….)]

Daher bewiesen.

Annahmen zur Anwendung des Satzes von Arden

  • Das Übergangsdiagramm darf keine NULL-Übergänge haben
  • Es darf nur einen Ausgangszustand haben

Methode

Step 1- Erstellen Sie Gleichungen wie folgt für alle Zustände des DFA mit n Zuständen mit dem Anfangszustand q 1 .

q 1 = q 1 R 11 + q 2 R 21 +… + q n R n1 + ε

q 2 = q 1 R 12 + q 2 R 22 +… + q n R n2

…………………………

…………………………

…………………………

…………………………

q n = q 1 R 1n + q 2 R 2n +… + q n R nn

Rij repräsentiert den Satz von Beschriftungen von Kanten von qi zu qjWenn keine solche Kante vorhanden ist, dann Rij = ∅

Step 2 - Lösen Sie diese Gleichungen, um die Gleichung für den Endzustand in Bezug auf zu erhalten Rij

Problem

Konstruieren Sie einen regulären Ausdruck, der den unten angegebenen Automaten entspricht -

Solution - -

Hier ist der Anfangs- und Endzustand q1.

Die Gleichungen für die drei Zustände q1, q2 und q3 lauten wie folgt:

q 1 = q 1 a + q 3 a + ε (ε Bewegung ist, weil q1 der Anfangszustand 0 ist

q 2 = q 1 b + q 2 b + q 3 b

q 3 = q 2 a

Nun werden wir diese drei Gleichungen lösen -

q 2 = q 1 b + q 2 b + q 3 b

= q 1 b + q 2 b + (q 2 a) b (Ersatzwert von q 3 )

= q 1 b + q 2 (b + ab)

= q 1 b (b + ab) * (Anwendung des Ardenschen Theorems)

q 1 = q 1 a + q 3 a + ε

= q 1 a + q 2 aa + ε (Ersatzwert von q 3 )

= q 1 a + q 1 b (b + ab *) aa + ε (Substitutionswert von q 2 )

= q 1 (a + b (b + ab) * aa) + ε

= ε (a + b (b + ab) * aa) *

= (a + b (b + ab) * aa) *

Daher ist der reguläre Ausdruck (a + b (b + ab) * aa) *.

Problem

Konstruieren Sie einen regulären Ausdruck, der den unten angegebenen Automaten entspricht -

Solution - -

Hier ist der Anfangszustand q 1 und der Endzustand ist q 2

Jetzt schreiben wir die Gleichungen auf -

q 1 = q 1 0 + ε

q 2 = q 1 1 + q 2 0

q 3 = q 2 1 + q 3 0 + q 3 1

Nun werden wir diese drei Gleichungen lösen -

q 1 = & epsi; 0 * [As, & epsi; R = R]

Also ist q 1 = 0 *

q 2 = 0 * 1 + q 2 0

Also, q 2 = 0 * 1 (0) * [Nach dem Satz von Arden]

Daher ist der reguläre Ausdruck 0 * 10 *.