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 *.