Langsung ke konten utama

Finite State Automata


Finite State Automata adalah mesin automata dari bahasa regule. FSA bukan suatu mesin fisik melainkan suatu model matematika dari suatu sistem yang menirima output dan input diskrit. FSA memiliki state yang banyaknya berhingga, dan dapat berpindah dari suatu state ke state lainnya. Sebagai sebuah mesin maka FSA akan bekerja jika diberikan suatu masukan. Hasil proses adalah suatu nilai kebenaran diterima atau tidaknya masukan yang diberikan. FSA memiliki state yang banyaknya berhingga, jika diberikan suatu simbol input maka dapat terjadi suatu perpindahan dari sebuah state ke state lainnya. Perubahan state tersebut dinyatakan oleh suatu simbol transisi. Mekanisme FSA tidak memiliki memori sehingga selalu mendasarkan prosesnya pada posisi state “saat ini”. Misalnya pada mekanisme kontrol pada sebuah lift, selalu didasari pada posisi lift saat itu pada suatu lantai, pergerakan ke atas atau ke bawah dan sekumpulan permintaan yang belum terpenuhi.


Finite State Automata dinyatakan oleh pasangan 5 tuple, yaitu:


M=(Q , Σ , δ , S , F )

Q = himpunan state

Σ = himpunan simbol input

δ = fungsi transisi δ : Q × Σ

S = state awal / initial state , S Q

F = state akhir, F Q



Karakteristik Finite Automata

  • Setiap Finite Automata memiliki keadaan dan transisi yang terbatas.
  • Transisi dari satu keadaan ke keadaan lainnya dapat bersifat deterministik atau non-deterministik.
  • Setiap Finite Automata selalu memiliki keadaan awal.
  • Finite Automata dapat memiliki lebih dari satu keadaan akhir. jika setelah pemrosesan seluruh string, keadaan akhir dicapai, artinya otomata menerima string tersebut.

Setiap FSA memiliki

  1. Himpunan berhingga (finite) status (state) Satu buah status sebagai status awal (initial state), biasa dinyatakan q0. Beberapa buah status sebagai status akhir (final state).
  2. Himpunan berhingga simbol masukan
  3. Fungsi transisi Menentukan status berikutnya dari setiap pasang status dan sebuah simbol masukan.

Cara Kerja Finite State Automata

Finite State Automata bekerja dengan cara mesin membaca memori masukan berupa tape yaitu 1 karakter tiap saat (dari kiri ke kanan) menggunakan head baca yang dikendalikan oleh kotak kendali state berhingga dimana pada mesin terdapat sejumlah state berhingga.

Finite Automata selalu dalam kondisi yang disebut state awal (initial state) pada saat Finite Automata mulai membaca tape. Perubahan state terjadi pada mesin ketika sebuah karakter berikutnya dibaca. Ketika head telah sampai pada akhir tape dan kondisi yang ditemui adalah state akhir, maka string yang terdapat pada tape dikatakan diterima Finite Automata (String-string merupakan milik bahasa bila diterima Finite Automata bahasa tersebut).


Finite State Diagram (FSD)

Finite State Automata dapat dimodelkan dengan Finite State Diagram (FSD) dapat juga disebut State Transition Diagram. Sistem transisi adalah sistem yang tingkah lakunya disajikan dalam bentuk keadaan-keadaan (states). Sistem tersebut dapat bergerak dari state yang satu ke state lainnya sesuai dengan input yang diberikan padanya.Fungsi Transisi (d) adalah representasi matematis atas transisi keadaan.

S = himpunan alfabet.

Q = himpunan keadaan-keadaan.

δ = Q x S -> Q




Jenis FSA

Ada dua jenis FSA :

1. Deterministic Finite Automata (DFA) : dari suatu state ada tepat satu state berikutnya untuk setiap simbol masukan yang diterima. Deterministik artinya tertentu/sudah tertentu fungsi transisinya.


Notasi matematis DFA:

• M = nama DFA

• Q = himpunan keadaan DFA

• Σ = himpunan simbol input

• δ = fungsi transisi, dimana δ ϵ Q x Σ -> Q

• S = keadaan awal

• F = keadaan akhir

M = (Q, Σ, δ, S, F)


2. Non-deterministic Finite Automata (NFA) : dari suatu state ada 0, 1 atau lebih state berikutnya untuk setiap simbol masukan yang diterima.

Non-Deterministic Finite Automata:

• Otomata berhingga yang tidak pasti untuk setiap pasangan state input, bisa memiliki 0 (nol) atau lebih pilihan untuk state berikutnya.

• Untuk setiap state tidak selalu tepat ada satu state berikutnya untuk setiap simbol input yang ada.

• Dari suatu state bisa terdapat 0,1 atau lebih busur keluar (transisi) berlabel simbol input yang sama.

• Untuk NFA harus dicoba semua kemungkinan yang ada sampai terdapat satu yang mencapai state akhir.

• Suatu string x dinyatakan diterima oleh bahasa NFA, M= (Q, Σ, δ, S, F) bila {x | d (S,x) memuat sebuah state di dalam F}


Notasi matematis NFA:

• M = nama NFA

• Q = himpunan keadaan NFA

• Σ = himpunan simbol input

• δ = fungsi transisi, dimana δ ϵ Q x (Σ U ε) -> P(Q)

• S = keadaan awal

• F = keadaan akhir

M = (Q, Σ, δ, S, F)