Presentasi sedang didownload. Silahkan tunggu

Presentasi sedang didownload. Silahkan tunggu

Kelompok 4.  Ragil Satria Wicaksana  Arita Windi Astuti  M. Salahudin  Endra Setiawan  Vidya Noer Firdausy  Dinda Sigmawaty.

Presentasi serupa


Presentasi berjudul: "Kelompok 4.  Ragil Satria Wicaksana  Arita Windi Astuti  M. Salahudin  Endra Setiawan  Vidya Noer Firdausy  Dinda Sigmawaty."— Transcript presentasi:

1 Kelompok 4

2  Ragil Satria Wicaksana  Arita Windi Astuti  M. Salahudin  Endra Setiawan  Vidya Noer Firdausy  Dinda Sigmawaty

3 Tata Bahasa Bebas Konteks (Context Free Grammar) Tata bahasa bebas konteks, selanjutnya disingkat CFG, tidak mempunyai batasan pada hasil produksinya. Pada aturan produksi    yang dibatasi hanya ruas kiri saja atau  yang merupakan sebuah simbol variabel. Contoh aturan produksi CFG, B  CDeFg D  BcDe

4 Tata bahasa bebas konteks digunakan sebagai cara untuk menunjukkan bagaimana menghasilkan untai- untai dalam sebuah bahasa. Pada saat menurunkan untai, simbol-simbol variabel akan mewakili bagian-bagian yang belum diturunkan dari untai tersebut. Bahasa bebas konteks menjadi dasar dalam membentuk suatu parser / proses analisis sintaksis.

5 Parsing Berikut sebuah pohon (tree) yang menguraikan kalimat “The quick brown fox jumped over the lazy dog”

6 sentence subject predicate noun phrase verb phrase noun phrase article noun phrase adjective the quick adjective noun phrase brown noun fox verb jumped adverbial phrase proposision noun phrase over adjective noun phrase the dog noun noun phrase adjective lazy “The quick brown fox jumped over the lazy dog”

7 Pohon Penurunan Pohon penurunan berguna untuk memperoleh untai dengan cara menurunkan variabel-variabel menjadi simbol-simbol terminal. Contoh : Misal terdapat tata bahasa bebas konteks (simbol awal S) dengan aturan produksi: S  AB A  aA | a B  bB | b Gambarkan pohon penurunan untuk memperoleh untai ‘aabbb’

8 S  AB A  aA | a B  bB | b S A a a b B B b A B b

9 Proses penurunan ( parsing) Proses penurunan dapat dilakukan dengan cara: A.Penurunan terkiri (leftmost derivation) Penurunan terkiri dilakukan dengan menurunkan variabel terkiri terlebih dahulu. B.Penurunan terkanan (rightmost derivation) Penurunan terkanan dilakukan dengan menurunkan variabel terkanan terlebih dahulu. Contoh 9.2 Dari aturan produksi: S  aAS | a A  SbA| ba, gambarkan pohon penurunan terkiri dan terkanan untuk mendapatkan untai ‘aabbaa’

10 S a S S A A b a a b a S a S S A A b a a b a Penurunan terkiri Penurunan terkanan Proses penurunan juga dapat dilakukan dengan cara: S  aAS  aSbAS  aabAS  aabbaS  aabbaa Atau: S  aAS  aAa  aSbAa  aSbbaa  aabbaa

11 Ambiguitas Jika dari aturan produksi tata bahasa bebas konteks terdapat lebih dari satu cara membuat pohon penurunan untuk memperoleh suatu untai, maka dikatakan bahasa bebas konteks tersebut ambigu. Contoh 9.3 Buktikan bahwa tata bahasa bebas konteks berikut ambigu, S  SbS | ScS | a Penyelesaian: Misal kita akan menurunkan untai ‘abaca’

12 Penurunan terkiri Penurunan terkanan Proses penurunan juga dapat dilakukan dengan cara: S  SbS  abS  abScS  abacS  abaca Atau: S  ScS  Sca  SbSca  Sbaca  abaca S b c S S a S S S c b S S a S S aa a a

13 Karena bentuk pohon penurunan sebelah kiri berbeda dengan pohon penurunan sebelah kanan, maka dikatakan bahwa tata bahasa bebas konteks S  SbS | ScS | a ambigu

14 Latihan Dari aturan produksi: S  aS | bS | a | b, gambarkan pohon penurunan untuk mendapatkan untai ‘abbab’.

15  Melakukan pembatasan sehingga tidak menghasilkan pohon penurunan yang memiliki kerumitan yang tak perlu atau aturan produksi yang tidak berarti. contoh : S  AB | a A  a Kelemahannya : aturan produksi AB menjadi tidak berarti karena B tidak memiliki penurunan.

16  Untuk CFG berikut : S  A A  B B  C C  D D  a | A  Memiliki kelemahan terlalu panjang jalannya padahal berujung pada S  a, produksi D  A juga menyebabkan kerumitan.

17 Suatu tata bahasa bebas konteks dapat disederhanakan dengan melakukan cara berikut ini : 1. Penghilangan produksi useless 2. Penghilangan produksi unit 3. Penghilangan produksi ℰ

18 Produksi useless adalah :  Produksi yang memuat simbol variabel yang tidak memiliki penurunan yang akan menghasilkan terminal-terminal seluruhnya.  Produksi yang tidak akan pernah dicapai dengan penurunan apapun dari simbol awal.

19 Contoh : Terdapat aturan produksi sebagai berikut : S -> aBD B -> cD | Ab D -> ef A -> Ed F -> dc

20  Analisa : 1) Pada aturan produksi A -> Ed, E tidak memiliki penurunan. sehingga dapat dihilangkan 2) Aturan produksi F -> dc, redudan. sehingga aturan produksi tersebut dapat dihilangkan Sisa aturan produksi yang telah disederhanakan adalah sebagai berikut : S -> aBD B -> cD | Ab D -> ef

21  Analisa kembali : aturan produksi B -> Ab, A tidak memiliki penurunan. sehingga didapat penyederhanaan lagi menjadi S -> aBD B-> cD D -> ef Kesimpulannya adalah bahwa produk useless yang dihilangkan adalah : A-> Ed F -> dc B-> Ab

22  Produksi Unit adalah produksi dimana ruas kiri dan kanan aturan produksi hanya berupa satu simbol variabel. Contoh : A -> B, C -> D Contoh : S  Sb S  C C  D C  ef D  dd

23  Kita lakukan penggantian berurutan mulai dari aturan produksi paling dekat menuju terminal- terminal C  D  C  dd S  C  S  dd | ef sehingga aturan produksi setelah penyederhanaan : S  Sb S  dd | ef C  dd C  ef D  dd

24  Produksi ℰ adalah produksi dalam bentuk  atau bisa dianggap sebagai produksi kosong.  Penghilangan produksi dilakukan dengan penggantian produksi yang memuat variabel yang bisa menuju produksi atau biasa disebut nullable.

25 Contoh : S  bcAd A  Pada kasus diatas A nullable, maka variabel A bisa ditiadakan. Hasil penyederhanaan S  bcd

26 Contoh : S  bcAd | bcd A  bd | Hasil penyederhanaan S  bcAd | bcd A  bd

27 CFG Penghilangan Produksi ℰ Penghilangan Produksi Unit Penghilangan produksi useless CFG yang sudah disederhanakan

28 Contoh : S  A A  B S  aBD B  CD| ab D  ef A  Ed C  F  dc Sederhanakan.


Download ppt "Kelompok 4.  Ragil Satria Wicaksana  Arita Windi Astuti  M. Salahudin  Endra Setiawan  Vidya Noer Firdausy  Dinda Sigmawaty."

Presentasi serupa


Iklan oleh Google