Teorema Arden

Untuk mengetahui ekspresi reguler dari Finite Automaton, kami menggunakan Teorema Arden bersama dengan properti ekspresi reguler.

Statement -

Membiarkan P dan Q menjadi dua ekspresi reguler.

Jika P tidak mengandung string nol, maka R = Q + RP memiliki solusi unik yaitu R = QP*

Proof -

R = Q + (Q + RP) P [Setelah meletakkan nilai R = Q + RP]

= Q + QP + RPP

Saat kami memberi nilai R secara rekursif lagi dan lagi, kita mendapatkan persamaan berikut -

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

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

R = QP * [Karena P * mewakili (ε + P + P2 + P3 +….)]

Makanya, terbukti.

Asumsi Penerapan Teorema Arden

  • Diagram transisi tidak boleh memiliki transisi NULL
  • Ini harus memiliki hanya satu keadaan awal

metode

Step 1- Buat persamaan sebagai bentuk berikut untuk semua status DFA yang memiliki n status awal 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 mewakili himpunan label tepi dari qi untuk qj, jika tidak ada tepi seperti itu, maka Rij = ∅

Step 2 - Selesaikan persamaan ini untuk mendapatkan persamaan keadaan akhir dalam bentuk Rij

Problem

Buat ekspresi reguler yang sesuai dengan automata yang diberikan di bawah ini -

Solution -

Di sini keadaan awal dan keadaan akhir adalah q1.

Persamaan untuk ketiga status q1, q2, dan q3 adalah sebagai berikut -

q 1 = q 1 a + q 3 a + ε (ε bergerak karena q1 adalah keadaan awal0

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

q 3 = q 2 a

Sekarang, kita akan menyelesaikan ketiga persamaan ini -

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

= q 1 b + q 2 b + (q 2 a) b (Mengganti nilai q 3 )

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

= q 1 b (b + ab) * (Menerapkan Teorema Arden)

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

= q 1 a + q 2 aa + ε (Mengganti nilai q 3 )

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

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

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

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

Oleh karena itu, ekspresi regulernya adalah (a + b (b + ab) * aa) *.

Problem

Buat ekspresi reguler yang sesuai dengan automata yang diberikan di bawah ini -

Solution -

Di sini keadaan awal adalah q 1 dan keadaan terakhir adalah q 2

Sekarang kita tulis persamaannya -

q 1 = q 1 0 + ε

q 2 = q 1 1 + q 2 0

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

Sekarang, kita akan menyelesaikan ketiga persamaan ini -

q 1 = ε0 * [Sebagai, εR = R]

Jadi, q 1 = 0 *

q 2 = 0 * 1 + q 2 0

Jadi, q 2 = 0 * 1 (0) * [Menurut teorema Arden]

Karenanya, ekspresi regulernya adalah 0 * 10 *.