Finite Automaton non-deterministik

Di NDFA, untuk simbol input tertentu, mesin dapat berpindah ke kombinasi status apa pun di mesin. Dengan kata lain, keadaan pasti pergerakan mesin tidak dapat ditentukan. Karenanya, ini disebutNon-deterministic Automaton. Karena ia memiliki jumlah status yang terbatas, mesin tersebut dipanggilNon-deterministic Finite Machine atau Non-deterministic Finite Automaton.

Definisi Formal dari NDFA

Sebuah NDFA dapat diwakili oleh 5-tupel (Q, ∑, δ, q 0 , F) di mana -

  • Q adalah sekumpulan negara yang terbatas.

  • adalah seperangkat simbol terbatas yang disebut huruf.

  • δadalah fungsi transisi di mana δ: Q × ∑ → 2 Q

    (Di sini kumpulan daya Q (2 Q ) telah diambil karena dalam kasus NDFA, dari suatu keadaan, transisi dapat terjadi ke kombinasi keadaan Q apa ​​pun)

  • q0adalah keadaan awal dari mana input diproses (q 0 ∈ Q).

  • F adalah himpunan keadaan akhir / kondisi Q (F ⊆ Q).

Representasi Grafis NDFA: (sama seperti DFA)

NDFA diwakili oleh digraf yang disebut diagram keadaan.

  • Simpul mewakili negara bagian.
  • Busur yang diberi label alfabet masukan menunjukkan transisi.
  • Keadaan awal dilambangkan dengan busur masuk tunggal yang kosong.
  • Keadaan akhir ditunjukkan oleh lingkaran ganda.

Example

Biarkan robot terbatas non-deterministik menjadi →

  • Q = {a, b, c}
  • ∑ = {0, 1}
  • q 0 = {a}
  • F = {c}

Fungsi transisi δ seperti yang ditunjukkan di bawah ini -

Keadaan Sekarang Status Berikutnya untuk Input 0 Status Berikutnya untuk Input 1
Sebuah a, b b
b c a, c
c b, c c

Representasi grafisnya adalah sebagai berikut -

DFA vs NDFA

Tabel berikut mencantumkan perbedaan antara DFA dan NDFA.

DFA NDFA
Transisi dari suatu keadaan adalah ke keadaan tertentu berikutnya untuk setiap simbol masukan. Oleh karena itu disebut deterministik . Transisi dari suatu keadaan dapat menjadi beberapa keadaan berikutnya untuk setiap simbol masukan. Oleh karena itu disebut non-deterministik .
Transisi string kosong tidak terlihat di DFA. NDFA mengizinkan transisi string kosong.
Melacak balik diperbolehkan di DFA Di NDFA, mundur tidak selalu memungkinkan.
Membutuhkan lebih banyak ruang. Membutuhkan lebih sedikit ruang.
Sebuah string diterima oleh DFA, jika ditransfer ke status akhir. Sebuah string diterima oleh NDFA, jika setidaknya satu dari semua kemungkinan transisi berakhir dalam keadaan akhir.

Akseptor, Pengklasifikasi, dan Transduser

Penerima (Pengenal)

Otomat yang menghitung fungsi Boolean disebut acceptor. Semua status akseptor menerima atau menolak masukan yang diberikan kepadanya.

Penggolong

SEBUAH classifier memiliki lebih dari dua status akhir dan memberikan satu keluaran saat berakhir.

Transduser

Sebuah otomat yang menghasilkan keluaran berdasarkan masukan saat ini dan / atau keadaan sebelumnya disebut a transducer. Transduser dapat terdiri dari dua jenis -

  • Mealy Machine - Output tergantung pada kondisi saat ini dan input saat ini.

  • Moore Machine - Outputnya hanya bergantung pada kondisi saat ini.

Penerimaan oleh DFA dan NDFA

Sebuah string diterima oleh DFA / NDFA jika DFA / NDFA yang dimulai dari status awal berakhir dalam status menerima (salah satu status akhir) setelah seluruh string membaca.

Senar S diterima oleh DFA / NDFA (Q, ∑, δ, q 0 , F), iff

δ*(q0, S) ∈ F

Bahasa L diterima oleh DFA / NDFA adalah

{S | S ∈ ∑* and δ*(q0, S) ∈ F}

String S ′ tidak diterima oleh DFA / NDFA (Q, ∑, δ, q 0 , F), iff

δ*(q0, S′) ∉ F

Bahasa L 'tidak diterima oleh DFA / NDFA (Pelengkap bahasa yang diterima L) adalah

{S | S ∈ ∑* and δ*(q0, S) ∉ F}

Example

Mari kita pertimbangkan DFA yang ditunjukkan pada Gambar 1.3. Dari DFA, string yang dapat diterima dapat diturunkan.

String yang diterima oleh DFA di atas: {0, 00, 11, 010, 101, ...........}

String tidak diterima oleh DFA di atas: {1, 011, 111, ........}