POHON PENURUNAN.

Slides:



Advertisements
Presentasi serupa
Kuliah 03 – Pengenalan Analisa Sintak
Advertisements

KONSEP dan NOTASI BAHASA
CONTEXT-FREE GRAMMAR (CFG) DAN PARSING
Standar Kompetensi Kompetensi Dasar
Penguraian Bawah-Atas (Bottom-up Parsing)
Teori Bahasa dan Automata
Pengantar Teknik Kompilasi
PENGHILANGAN REKURSIF KIRI
Pohon Urai (parse) dan Derivasi
Teori Bahasa dan Otomata 2 sks
Teori Bahasa & OTOMATA.
TATA BAHASA BEBAS KONTEKS (CONTEXT FREE GRAMMAR)
TEORI BAHASA DAN OTOMATA
Syntax Analyzer (Parser) - Dasar
Chapter 6: Operator precedence parsing
Natural Language Processing (Pemroses Bahasa Alami)
Pohon penurunan dan Penyederhanaan Tata Bahasa Bebas Konteks
Komponen sebuah Kompilator
Pertemuan 3 BAHASA REGULAR
Analisis Leksikal.
STRUKTUR COMPILLER.
CONTEXT-FREE GRAMMAR (CFG) DAN PARSING
Pengurai Prediktif & Bottom Up Parsing (penguraian bawah atas)
Komponen sebuah Kompilator
KONSEP GRAMMAR & HIRARKI CHOMSKY
Teori-Bahasa-dan-Otomata
Teori-Bahasa-dan-Otomata
TEORI BAHASA DAN AUTOMATA TATA BAHASA LEVEL BAHASA
ATURAN PRODUKSI TATA BAHASA REGULER
TATA BAHASA BEBAS KONTEKS (CONTEXT FREE GRAMMAR)
Bahasa Type 2 (CONTEXT FREE GRAMMAR)
TEKNIK PENURUNAN.
By : Lisda Juliana Pangaribuan
Pengantar Teknik Kompilasi
Teori-Bahasa-dan-Otomata
GRAMMER ATAU TATA BAHASA
PENGHILANGAN REKURSIF KIRI
Bahasa Context Free.
AP untuk CFG PERTEMUAN KE-12 & 13.
MATERI PERKULIAHAN TEKNIK KOMPILASI
Teori-Bahasa-dan-Otomata
Pengantar Teknik Kompilasi
Analisis Sintaks (Parsing)
MATERI PERKULIAHAN TEKNIK KOMPILASI
MATERI PERKULIAHAN TEKNIK KOMPILASI
MATERI PERKULIAHAN TEKNIK KOMPILASI
Pengantar Teknik Kompilasi
ALGORITMA & PEMROGRAMAN 1C
Istiqomah, S.Kom [Teknik Kompilasi UNIKOM 2013]
MATERI PERKULIAHAN TEKNIK KOMPILASI
Penyederhanaan Tata Bahasa Bebas Konteks
MATERI PERKULIAHAN TEKNIK KOMPILASI
MATERI PERKULIAHAN TEKNIK KOMPILASI
Pengantar Teknik Kompilasi
Tata Bahasa Kelas Tata Bahasa
Pengantar Teknik Kompilasi
MATERI PERKULIAHAN TEKNIK KOMPILASI
Pengantar Teknik Kompilasi
CONTEXT-FREE GRAMMAR (CFG) DAN PARSING
Pengantar Teknik Kompilasi
Analisis Sintaksis By: Kustanto, S.T., M.Eng.
Automata Hingga Deterministik (AHD)
Pengantar Teknik Kompilasi
Brute force 2/16/2019 Materi ke 5.
Grammar dan Bahasa Automata
Aturan Produksi untuk CFG
CONTEXT-FREE GRAMMAR (CFG) DAN PARSING
Pengantar Teknik Kompilasi
Aturan Produksi (AP) untuk Contex Free Grammar (CFG)
CONTEXT-FREE GRAMMAR (CFG) DAN PARSING
Transcript presentasi:

POHON PENURUNAN

PENDAHULUAN Bentuk umum produksi CFG adalah : α → β, α ∈ V N , β ∈ (V N VT )* Analisis sintaks adalah penelusuran sebuah kalimat (atau sentensial) sampai pada simbol awal grammar. Analisis sintaks dapat dilakukan melalui derivasi atau parsing. Penelusuran melalui parsing menghasilkan pohon sintaks.

CONTOH 1 Diketahui grammar G 1 = {I → HI HIA, H → abc...z, A → 012...9} dengan I adalah simbol awal. Berikut ini kedua cara analisa sintaks untuk kalimat x23b.

CONTOH 2 Diketahui grammar G 2 = {S → SOSA , O → *+, A → 012...9} Kalimat : 2*3+7 mempunyai dua pohon sintaks berikut :

Metoda Parsing Ada 2 metoda parsing : top-down dan bottom-up. Parsing top-down : Diberikan kalimat x sebagai input. Parsing dimulai dari simbol awal S sampai kalimat x nyata (atau tidak nyata jika kalimat x memang tidak bisa diturunkan dari S) dari pembacaan semua leaf dari pohon parsing jika dibaca dari kiri ke kanan. Parsing bottom-up : Diberikan kalimat x sebagai input. Parsing dimulai dari kalimat x yang nyata dari pembacaan semua leaf pohon parsing dari kiri ke kanan sampai tiba di simbol awal S (atau tidak sampai di S jika kalimat x memang tidak bisa diturunkan dari S).

Parsing Top-down Ada 2 kelas metoda parsing top-down, yaitu: Kelas metoda dengan backup, contoh metoda kelas dengan backup adalah metoda Brute-Force, Kelas metoda tanpa backup, contoh metoda kelas tanpa backup adalah metoda recursive descent.

Metoda Brute-Force Kelas metoda dengan backup, termasuk metoda Brute-Force, adalah kelas metoda parsing yang menggunakan produksi alternatif, jika ada, ketika hasil penggunaan sebuah produksi tidak sesuai dengan simbol input. Penggunaan produksi sesuai dengan nomor urut produksi.

CONTOH Diberikan grammar G = {S → aAdaB, A → bc, B → ccdddc}. Gunakan metoda Brute-Force untuk melakukan analisis sintaks terhadap kalimat x = accd.

Metoda Brute-Force tidak dapat menggunakan grammar rekursi kiri, yaitu grammar yang mengandung produksi rekursi kiri (left recursion) : A → A∝. Produksi rekursi kiri akan menyebabkan parsing mengalami looping tak hingga.

Metoda Recursive-Descent Kelas metoda tanpa backup, termasuk metoda recursive descent, adalah kelas metoda parsing yang tidak menggunakan produksi alternatif ketika hasil akibat penggunaan sebuah produksi tidak sesuai dengan simbol input. Jika produksi A mempunyai dua buah ruas kanan atau lebih maka produksi yang dipilih untuk digunakan adalah produksi dengan simbol pertama ruas kanannya sama dengan input yang sedang dibaca. Jika tidak ada produksi yang demikian maka dikatakan bahwa parsing tidak dapat dilakukan.

Ketentuan produksi yang digunakan metoda recursive descent adalah : Jika terdapat dua atau lebih produksi dengan ruas kiri yang sama maka karakter pertama dari semua ruas kanan produksi tersebut tidak boleh sama. Ketentuan ini tidak melarang adanya produksi yang bersifat rekursi kiri.

CONTOH Diketahui grammar G = {S → aBA, A → a, B → bd}. Gunakan metoda recursive descent untuk melakukan analisis sintaks terhadap kalimat x = ac.

Parsing Bottom-Up Salah satu contoh menarik dari parsing bottom-up adalah parsing pada grammar preseden sederhana (GPS). Sebelum sampai ke parsing tersebut, akan dikemukakan beberapa pengertian dasar serta relasi yang ada pada GPS.

Pengertian Dasar Jika α dan x keduanya diderivasi dari simbol awal grammar tertentu, maka α disebut sentensial jika α ∈ (V T  V N )*, dan x disebut kalimat jika x ∈ (V T )* Misalkan α = Q 1 β Q 2 adalah sentensial dan A ∈ V N : - β adalah frase dari sentensial α jika : S ⇒ … ⇒ Q 1 A Q 2 dan A⇒ … ⇒ β - β adalah simple frase dari sentensial α jika : S ⇒ … ⇒ Q 1 A Q 2 dan A⇒ β - Simple frase terkiri dinamakan handel - frase, simple frase, dan handel adalah string dengan panjang 0 atau lebih..