IMPLEMENTASI ALGORITMA GREEDY BEST FIRST SEARCH PADA APLIKASI PERMAINAN CONGKLAK UNTUK OPTIMASI PEMILIHAN LUBANG DENGAN POLA BERFIKIR DINAMIS

dokumen-dokumen yang mirip
Strategi Perancangan Bot Player pada Permainan Tradisional Congklak dengan Algoritma Greedy

IMPLEMENTASI ALGORITMA GREEDY PADA PERMAINAN CONGKLAK

Penerapan Algoritma Greedy dalam Permainan Bantumi

IMPLEMENTASI ALGORITMA GREEDY PADA PERMAINAN OTHELLO

Penerapan Algoritma Greedy dalam Permainan Tradisional Congklak

Penerapan Algoritma Greedy dalam Pembuatan Artificial Intelligence Permainan Reversi

BAB I PENDAHULUAN Latar Belakang Masalah

Penyelesaian Permainan Sliding Puzzle 3x3 Menggunakan Algoritma Greedy Dengan Dua Fungsi Heuristik

BAB I PENDAHULUAN. Permainan antara manusia melawan komputer menjadi sangat populer

Algoritma Greedy untuk Pengambilan Keputusan dalam Permainan Kartu Hearts

ISSN: X 39 SIRKUIT HAMILTON DALAM PERMAINAN CONGKLAK

BAB 1 PENDAHULUAN. 1.1 Latar Belakang

Penerapan Algoritma Greedy dalam Penyetokan Barang

Pemilihan Monster yang Akan Digunakan dalam Permainan Yu-Gi-Oh! Capsule Monster Coliseum

BAB I PENDAHULUAN. Paud Jateng Pengertian Bermain dan Permainan Anak by Para Ahli dalam (Diunduh 26 Maret 2016)

ALGORITMA GREEDY DALAM PERMAINAN DOTS AND BOXES

Penggunaan Algoritma Greedy Untuk Menyelesaikan Permainan Cluedo

BAB 3 METODOLOGI 3.1. Analisis Kebutuhan dan Masalah Analisis Kebutuhan

Penerapan Algoritma Greedy dalam Permainan Othello

Penerapan Algoritma Greedy dan Breadth First Search pada Permainan Kartu Sevens

PERBANDINGAN APLIKASI ALGORITMA BRUTE-FORCE DAN KOMBINASI ALGORITMA BREADTH FIRST SEARCH DAN GREEDY DALAM PENCARIAN SOLUSI PERMAINAN TREASURE HUNT

Penggunaan Algoritma Greedy Dalam Perancangan Papan Teka Teki Silang

Penerapan Algoritma Greedy Pada Permainan Kartu Truf

BAB 1 PENDAHULUAN Latar Belakang

Implementasi Algoritma Greedy pada Permainan Ludo

APLIKASI ALGORITMA GREEDY DALAM PERMAINAN CAPSA BANTING

Penerapan Algoritma Greedy untuk Permainan Halma

Pencarian Solusi Optimal dalam Permainan Congklak dengan Program Dinamis

PENERAPAN ALGORITMA BIDIRECTIONAL A* PADA MOBILE NAVIGATION SYSTEM

Penerapan Algoritma Greedy untuk Permainan Flood It

Penggunaan Algoritma Greedy untuk Menyelesaikan Permainan UNO Kartu (Klasik)

ANALISIS DAN IMPLEMENTASI ALGORITMA BACKTRACKING PADA PERMAINAN CONGKLAK SKRIPSI ADHHAL HUDA BAKRI

Penerapan Algoritma Greedy dan Backtrackng Dalam Penyelesaian Masalah Rubik s Cube

BAB I PENDAHULUAN. remaja maupun orang dewasa. Game ini terdiri dari game tradisional dan

MODIFIKASI METODE BACKTRACKING UNTUK MEMBANTU MENCARI PENYELESAIAN PERMAINAN PEG SOLITAIRE

Algoritma Greedy dalam Artificial Intelligence Permainan Tic Tac Toe

PENERAPAN ALGORITMA GREEDY DALAM PENCARIAN SOLUSI TERBAIK PADA PERMAINAN TETRIS

APLIKASI ALGORITMA GREEDY DALAM PERMAINAN JAWBREAKER

Rancangan Permainan Othello Berbasis Android Menggunakan Algoritma Depth-First Search

Penerapan Algoritma Greedy dalam Algoritma Penjadwalan Prosesor Tunggal Shortest Job First

BAB 1 PENDAHULUAN 1.1 Latar Belakang Masalah

BAB III ANALISIS DAN PERANCANGAN SISTEM

Optimisasi Penjadwalan Proses Pada Central Processing Unit Dengan Menggunakan Algoritma Greedy

Penentuan Keputusan dalam Permainan Gomoku dengan Program Dinamis dan Algoritma Greedy

Penggunaan Algoritma Greedy untuk Mencari Solusi Optimal dalam Permainan Brick Breaker

BAB II TINJAUAN PUSTAKA. operasi penjumlahan dan pengurangan. sebagai hasil dari pembawaan dan latihan. anak untuk menyelesaikan suatu tugas.

BAB I PENDAHULUAN 1.1 Latar Belakang

BAB 1 PENDAHULUAN 1.1. Latar Belakang

BAB I PENDAHULUAN. Permainan papan atau biasa disebut dengan Board Games hampir tidak

BAB 1 PENDAHULUAN 1.1 Latar Belakang

Algoritma Greedy pada Board Game Saboteur

APLIKASI GAME TIC TAC TOE 6X6 BERBASIS ANDROID MENGGUNAKAN ALGORITMA MINIMAX DAN HEURISTIC EVALUATION

Penerapan Algoritma Greedy pada Intelegensia Buatan untuk Transfer Pemain dalam Permainan Simulasi Sepakbola

Solusi Terbaik Permainan Rocket Mania Deluxe dengan Pendekatan Algoritma BFS dan Algoritma Greedy

Algoritma Exhaustive Search Dalam Permainan Congklak

Algoritma Greedy untuk AI dalam Permainan DotA

UKDW BAB 1 PENDAHULUAN Latar Belakang

Penerapan Algoritma Greedy pada Permainan Kartu 100

Perangkat Lunak Simulasi Langkah Kuda Dalam Permainan Catur

KI Kecerdasan Buatan Materi 6: Pencarian dgn. Lihat Status Lawan (Adversarial Search)

Penerapan Algoritma Greedy Pada Game Tower Defense: Tower of Greece

Perbandinganan Penggunaan Algoritma Greedy dan Modifikasi Algoritma Brute Force pada Permainan Collapse XXL

PEMBUATAN GAME CONGKLAK DENGAN ALGORITMA ALPHA BETA PRUNNING BERBASIS ANDROID NASKAH PUBLIKASI. diajukan oleh Nofarianto Sihite

BAB 1 PENDAHULUAN. 1.1 Latar Belakang

Penerapan Algoritma Greedy dan Algoritma BFS untuk AI pada Permainan Greedy Spiders

Penentuan Rute Belanja dengan TSP dan Algoritma Greedy

Pertemuan-07 INFORMATIKA FASILKOM UNIVERSITAS IGM

Penyempurnaan Intelegensa Buatan Mode AI ++ Ragnapolis dengan Langkah Penjualan Kota Berbasiskan Algoritma Greedy

PENGEMBANGAN GAME CONGKLAK BERBASIS ANDROID TUGAS AKHIR

Algoritma Greedy dalam Strategi Permainan Centipede

Penyelesaian Permainan Bantumi dengan Algoritma Expand, Mark and Select

Implementasi Algoritma Greedy dalam Pembagian kerja pada Mesin yang Identik

Jurusan Matematika Fakultas Matematika dan Ilmu Pengetahuan Alam Institut Teknologi Sepuluh Nopember Surabaya 2011

IMPLEMENTASI ALGORITMA STOCHASTIC HILL CLIMBING PADA PERMAINAN MASTERMIND

Pemodelan AI dalam Permainan Snake dengan Algoritma Branch and Bound

UKDW BAB 1 PENDAHULUAN. 1.1 Latar Belakang Masalah

BAB I PENDAHULUAN. Dalam beberapa tahun terakhir Artificial Intelligence (AI) atau kecerdasan

TUGAS RESUME MATERI KULIAH ALGORITMA DAN STRUKTUR DATA STRATEGI ALGORITMA : H

Penerapan Algoritma Greedy dalam Permainan Connect 4

Perbandingan Penerapan Algoritma Minimax Dengan Algoritma Alpha-Beta Pruning Pada Permainan Othello

Implementasi Algoritma Greedy Dua Sisi pada Permainan 2048

Aplikasi Algoritma Greedy dalam Permainan Kartu Yu-Gi-Oh!

ANALISIS DAN IMPLEMENTASI PENYELESAIAN GAME MINESWEEPER MENGGUNAKAN ALGORITMA GREEDY BEST FIRST SEARCH SKRIPSI IRMA Y N SIGIRO

PENERAPAN ALGORITMA A* UNTUK PENCARIAN SOLUSI TERBAIK PADA GAME CONGKLAK

Penggunaan Algoritma Greedy untuk menyelesaikan Permainan Othello

Perancangan Algoritma Greedy pada AI Permainan Turn Based Strategy

Penerapan Algoritma Greedy pada Permainan Tower Defense

Sistem Informasi Pemotongan Kayu menggunakan Algoritma Greedy

BAB 1 PENDAHULUAN. 1.1 Latar Belakang

Penerapan Algoritma Greedy pada Permainan Bubble Breaker

ANALISIS ALGORITMA A* DAN BDA* PADA PERMASALAHAN PLANNING (STUDI KASUS: LOGISTIK)

IMPLEMENTASI SISTEM PARKIR CERDAS DI UNIVERSITAS TELKOM. SUBSISTEM : APLIKASI MOBILE

BAB III ANALISIS MASALAH DAN RANCANGAN PROGRAM

Sistem Kecerdasan Buatan. Masalah, Ruang Masalah dan Pencarian Solusi. Masalah. Masalah Sebagai Ruang Keadaan 10/7/2015

Penerapan Algoritma Greedy pada Artificial Inteligence dalam Permainan Defence of the Ancient

BAB I PENDAHULUAN 1.1 Latar Belakang Masalah

BAB I PENDAHULUAN. 1.1 Latar belakang masalah

HALMA 2D MULTIPLAYER BERBASIS APLIKASI DESKTOP TUGAS AKHIR. Disusun Oleh : YUDI HENDRADINATA NPM

Penerapan Algoritma Greedy Best First Search untuk Menyelesaikan Permainan Chroma Test : Brain Challenge

TK36301 PENGANTAR KECERDASAN BUATAN

Transkripsi:

IMPLEMENTASI ALGORITMA GREEDY BEST FIRST SEARCH PADA APLIKASI PERMAINAN CONGKLAK UNTUK OPTIMASI PEMILIHAN LUBANG DENGAN POLA BERFIKIR DINAMIS Galih Hermawan Jurusan Teknik Informatika, Universitas Komputer Indonesia, Bandung galih.hermawan@yahoo.co.id Abstract Congklak or Dakon is one of an traditional game in Indonesia that is generally played by two players with the goal of obtaining congklak seeds as much as possible by following the congklak game s rules. In this paper we discuss the use of greedy best-first search algorithm that used by the computer s player for selecting the hole that can produce an optimal solution. The player can make a choice whether to get a seed as much as possible or maintain the vulnerable contains holes that can be shot by the opponent. The test results show that the greedy algorithm is able to produce a quite good local solutions, although not necessarily optimal global solutions. Keywords: congklak, greedy algorithm, artificial intelligence, traditional game, game design. 1. Pendahuluan Congklak atau Dakon merupakan salah satu permainan tradisional yang ada di Indonesia. Permainan ini umumnya dimainkan oleh dua orang dengan memanfaatkan sebuah papan congklak yang memiliki 14 buah lubang kecil dan 2 buah lubang besar untuk dapat diisi oleh biji congklak. Tujuan permainan adalah memperoleh biji congklak sebanyakbanyaknya pada lubang besarnya, tentunya dengan mengikuti peraturan permainan congklak yang telah disepakati. Sebuah permainan umumnya dilakukan oleh masyarakat sebagai salah satu media bersenang-senang, melepas kepenatan sejenak, dan ajang berkumpul bersama teman-teman atau sanak saudara. Permainan congklak ternyata juga dapat dijadikan sebagai media latihan para pemainnya dalam mengasah kemampuan berhitung dan menyusun strategi. Permainan congklak dengan menggunakan papan dan biji congklak sudah mulai jarang terlihat dimainkan di tengahtengah masyarakat Indonesia. Penggunaan papan dan biji congklak sebagai sarana bermain dan diharuskannya dimainkan oleh dua orang yang mungkin cukup merepotkan, nampaknya turut andil dalam mengurangi daya tarik atau keinginan masyarakat dalam bermain congklak. Implementasi permainan dalam bentuk perangkat lunak pada komputer diharapkan dapat membantu masyarakat untuk terus bermain congklak tanpa harus susah payah menyediakan papan dan biji congklak. Permainan digital yang dibangun tidak juga mewajibkan pemainnya harus dua orang, disebabkan salah satu pemain dapat dimainkan oleh komputer yang sudah menggunakan artificial intelligence (AI) untuk mengambil keputusan dalam pemilihan lubang. Salah satu algoritmayang dapat digunakan untuk optimasi pemilihan lubang yang dapat menghasilkan jumlah biji terbanyak dalam satu putaran permainan adalah algoritma greedy best first search. Disertai dengan pola berfikir dinamis sehingga memungkinkan pemain (AI) juga dapat mempertimbangkan apakah mengejar target menghasilkan biji terbanyak atau bertahan. Istilah bertahan dalam hal ini adalah mengamankan lubang di areanya yang memiliki jumlah biji relatif banyak yang rawan dipikul atau ditembak oleh pihak lawan. 2. Landasan Teori Dalam bagian ini akan dibahas konsep permainan congklak dan algoritma greedy. 2.1 Congklak Berdasarkan informasi yang tertulis di website Expat (2012a), Congklak adalah suatu permainan tradisional yang dikenal dengan berbagai macam nama di seluruh Indonesia. Biasanya dalam permainan, sejenis cangkang kerang digunakan sebagai biji congklak dan jika tidak ada, kadangkala digunakan juga biji-bijian dari tumbuh-tumbuhan. Gambar 1. Papan congklak (Expat, 2012a). Di Malaysia permainan ini lebih dikenal dengan nama congkak dan istilah ini juga dikenal di beberapa daerah di Sumatera dengan kebudayaan Melayu. Di Jawa, permainan ini lebih dikenal dengan nama congklak, dakon, dhakon atau Teknik Informatika / Universitas Surabaya Halaman 1

dhakonan. Selain itu di Lampung permainan ini lebih dikenal dengan nama dentuman lamban sedangkan di Sulawesi permainan ini lebih dikenal dengan nama Mokaotan, Maggaleceng, Aggalacang dan Nogarata. Dalam bahasa Inggris, permainan ini disebut Mancala. Masih bersumber dari informasi pada website yang sama (Expat, 2012b), permainan congklak dilakukan oleh dua orang. Dalam permainan mereka menggunakan papan yang dinamakan papan congklak dan 98 (14 x 7) buah biji yang dinamakan biji congklak atau buah congklak. Umumnya papan congklak terbuat dari kayu dan plastik, sedangkan bijinya terbuat dari cangkang kerang, biji-bijian, batubatuan, kelereng atau plastik. Pada papan congklak terdapat 16 buah lubang yang terdiri atas 14 lubang kecil yang saling berhadapan dan 2 lubang besar di kedua sisinya. Setiap 7 lubang kecil di sisi pemain dan lubang besar di sisi kanannya dianggap sebagai milik sang pemain. Pada awal permainan setiap lubang kecil diisi dengan tujuh buah biji. Dua orang pemain yang berhadapan, salah seorang yang memulai dapat memilih lubang yang akan diambil dan meletakkan satu ke lubang di sebelah kanannya dan seterusnya. Bila biji habis di lubang kecil yang berisi biji lainnya, ia dapat mengambil biji-biji tersebut dan melanjutkan mengisi, bisa habis di lubang besar miliknya maka ia dapat melanjutkan dengan memilih lubang kecil di sisinya. bila habis di lubang kecil di sisinya maka ia berhenti dan mengambil seluruh biji di sisi yang berhadapan. Tetapi bila berhenti di lubang kosong di sisi lawan maka ia berhenti dan tidak mendapatkan apa-apa. Permainan dianggap selesai bila sudah tidak ada biji lagi yang dapat dimabil (seluruh biji ada di lubang besar kedua pemain). Pemenangnya adalah yang mendapatkan biji terbanyak. 2.2 Algoritma Greedy Best First Search Metode inform search dalam AI menggunakan heuristic untuk menentukan kualitas dari keadaan manapun dalam sebuah ruang pencarian (search space) (Jones, 2008). Metode best first search menggunakan fungsi evaluasi yang terdiri atas dua bagian, yaitu fungsi heuristik h(n) dan perkiraan biaya g(n), dimana f(n) = g(n) + h(n) (1) Algoritma Greedy Best First Search atau disingkat algoritma greedy merupakan metode yang cukup populer untuk memecahkan masalah optimasi. Secara harfiah, greedy berarti tamak atau rakus. Algoritma greedy menggunakan fungsi evaluasi dengan meniadakan perkiraan biaya g(n), dimana f(n) = h(n) (2) Prinsip dari algoritma greedy (Russel dan Norvig, 2003) adalah mengambil setiap kesempatan yang ada saat itu juga, tanpa memperhatikan konsekuensi kedepannya. Algoritma greedy membentuk solusi dari langkah demi langkah, dan pada setiap langkah harus dibuat keputusan yang terbaik dalam menentukan pilihan. Di setiap langkahnya algoritma greedy mengambil pilihan yang terbaik yang dapat diperoleh pada saat itu tanpa memperhatikan konsekuensi kedepan. Setiap keputusan yang diambil diharapkan merupakan langkah optimum pada langkah tersebut, dikenali sebagai solusi optimum lokal, kemudian dengan setiap langkah yang ditempuh diharapkan dapat memperoleh solusi optimum di akhir proses, yaitu solusi optimum global. Skema umum algoritma greedy adalah: a. himpunan kandidat, himpunan ini berisi seluruh elemen pembentuk solusi; b. himpunan solusi, berisi kandidat-kandidat yang terpilih sebagai solusi persoalan; c. fungsi seleksi, fungsi yang pada setiap langkah memilih kandidat yang paling memungkinkan mencapai solusi optimal; d. fungsi kelayakan, fungsi yang memeriksa apakah suatu kandidat yang terpilih dapat memberikan solusi yang layak, yaitu kandidat bersama-sama dengan himpunan solusi yang sudah terbentuk tidak melanggar kendala yang ada; e. fungsi objektif, fungsi yang memaksimumkan atau meminimumkan nilai solusi. 3. Metode Penelitian Metode penelitian yang digunakan untuk menyusun penelitian ini adalah sebagai berikut. 1. Studi Literatur Studi literatur yang dilakukan adalah mempelajari dokumentasi tata cara bermain congklak yang terdapat di beberapa website di internet, membaca dan memahami buku referensi berkaitan dengan pengembangan perangkat lunak, desain kecerdasan buatan, dan desain permainan. 2. Identifikasi Kebutuhan Tahap ini merupakan tahap awal analisis konsep dan tata cara permainan congklak, menginventarisasi data dan bahan yang dibutuhkan untuk mendesain aplikasi yang akan dibuat. 3. Desain Tahap ini membahas rancangan aplikasi melalui model-model perancangan yang telah ditentukan. Di dalamnya juga terdapat desain kecerdasan buatan dan penentuan nilai heuristik pada pemain komputer. Teknik Informatika / Universitas Surabaya Halaman 2

4. Implementasi Tahap ini meliputi implementasi hasil desain sistem melalui pengkodean. 5. Pengujian dan Evaluasi Tahap pengujian sistem dengan menjalankan permainan dan mengevaluasi apakah implementasi sistem sudah sesuai dengan tujuan yang ingin dicapai. 4. Hasil dan Diskusi Dalam bagian ini akan dibahas desain kecerdasan buatan, implementasi dan hasil pengujiannya. 4.1 Desain Kecerdasan Buatan Dalam sub-bab ini membahas teknis kecerdasan buatan, strategi pencarian heuristik greedy best first search, dan pola berfikir dinamis. 4.1.1. Teknis Kecerdasan Buatan Teknis kecerdasan buatan meliputi: searching, reasoning, planning, learning. Dalam hal ini, teknis kecerdasan yang digunakan adalah searching. State space search permainan congklak bisa dideskripsikan sebagai berikut. Setiap posisi atau lubang-lubang pada permainan congklak dapat direpresentasikan sebagai sebuah array 1 dimensi sejumlah 16 ruang atau indeks, dimana indeks 1 7 merupakan representasi lubang kecil pemain 1 dan indeks 8 sebagai lubang besarnya, sedangkan indeks 9 15 merupakan representasi lubang kecil pemain 2 dan indeks 16 sebagai lubang besarnya. Kondisi inisial (atau keadaan awal) permainan congklak adalah setiap lubang kecil berisi jumlah biji inisial yang telah ditentukan pengguna, misalnya 7, dan kedua lubang besar tidak diisi biji atau disimbolkan dengan angka 0. Keadaan tujuan adalah keadaan ketika semua lubang-lubang kecil dari kedua pemain sudah tidak ada bijinya atau berisi angka 0, sehingga permainan berhenti. Sedangkan tujuan permainan dari masing-masing pemain adalah memperoleh jumlah biji sebanyak-banyaknya pada lubang besarnya. Legal Moves (pemilihan lubang dan pengedaran biji yang memungkinkan). Di antaranya adalah: o o o pengambilan biji oleh pemain ketika permainan baru dimulai atau usai ganti pemain adalah hanya diperbolehkan pada areanya masing-masing, pengambilan biji ketika di tengah-tengah permainan adalah pada lubang dimana biji terakhir jatuh pada lubang tidak kosong, baik di area sendiri maupun area lawan, pengedaran biji dilakukan pada lubang-lubang kecil sebelah kanannya secara berurutan berlawanan dengan arah jarum jam, dimana pemain yang bersangkutan bisa menambahkan biji pada lubang besarnya tapi tidak pada besar lawan. 4.1.2. Strategi Pencarian Heuristik Greedy Best First Search Sebagaimana telah ditulis pada persamaan (2) bahwa algoritma greedy menggunakan fungsi evaluasi f(n) = h(n). Penggunaan algoritma greedy ini bertujuan memperoleh biji sebanyak-banyaknya pada lubang besar pemain yang bersangkutan tanpa perlu memperhatikan jumlah biji yang telah diperoleh. Namun dalam penerapannya, algoritma greedy ini tidak dibuat berdiri sendiri, melainkan dalam hal-hal tertentu mempertimbangkan jika estimasi jumlah biji yang akan diperoleh relatif sedikit (dimana parameter sedikit bisa disesuaikan) maka sistem akan menempuh solusi lain, misalnya bagaimana supaya biji yang terbanyak tidak di- tembak/pikul oleh pemain lawan, dan lain sebagainya. Cara atau proses berfikir sistem dengan menggunakan algoritma greedy adalah sebagai berikut. a. Bangkitkan semua hasil penelusuran dari setiap lubang-lubang kecil yang di area pemain yang bersangkutan. b. Di antara ketujuh lubang kecil yang dipilih tersebut, carilah lubang mana yang akan menghasilkan biji atau perolehan terbesar pada lubang besar. c. Indeks lubang yang diperoleh pada langkah 2 dipilih sebagai lubang dengan nilai evaluasi terbaik saat ini. Pemilihan lubang yang menghasilkan perolehan biji terbesar bisa melalui 2 cara, yaitu: a. pengedaran biji secara terus menerus sampai mati, b. atau, melakukan tembak/pikul yang langsung menghasilkan perolehan biji terbesar. 4.1.3. Pola Berfikir Dinamis Perolehan nilai terbesar hanya dengan mengandalkan algoritma greedy kadang kala tidak sesuai jika pada kondisi tertentu estimasi perolehan nilai relatif kecil. Misalkan jumlah biji perlubang diset 7, sehingga jika jumlah biji pada lubang adalah 15, maka akan jatuh pada lubang tersebut lagi sehingga memungkinkan melakukan tembak/pikul. Teknik Informatika / Universitas Surabaya Halaman 3

Contoh ilustrasi kondisi tersebut dapat dilihat pada Gambar 2. Gambar 2. Kondisi papan congklak yang bisa menghasilkan aksi tembak/pikul. Jika indeks 12 dipilih, maka hasil akhirnya adalah seperti tampak pada Gambar 3 berikut ini Gambar 3. Kondisi papan congklak saat terjadi aksi tembak/pikul Hal ini menunjukkan bahwa angka atau jumlah biji 15 bisa dikategorikan sebagai nilai penting atau nilai besar. Apalagi aktifitas ini juga bisa dilakukan oleh pihak lawan. Sehingga, dalam kondisi demikian bisa diprioritaskan untuk menyelamatkan lubang yang memiliki jumlah biji lebih besar atau sama dengan 15 terutama jika lubang lawan di seberangnya dalam keaadan kosong, daripada mengambil lubang yang estimasi perolehannya kecil. Parameter kecil di sini bisa diperoleh dengan cara jumlah biji perlubang dibagi 2 pada bilangan integer. Selanjutnya, apabila estimasi perolehan biji lebih besar atau sama dengan jumlah biji maksimal yang ada pada areanya ditambah jika lubang yang memiliki nilai evaluasi terbaik ada lebih dari satu, maka bisa diprioritaskan lubang yang biji terakhirnya jatuh pada lubang besar sendiri. Hal ini dilakukan untuk memperpanjang nafas permainan sehingga memungkinkan memperoleh biji sebanyak-banyaknya. Algoritma akhir hasil kombinasi algoritma greedy dan penyelesaian masalah secara dinamis pada satu putaran permainan adalah sebagai berikut. 4.2 Implementasi dan Hasil Pengujian Gambar 4. Algoritma proses berfikir pemilihan lubang terbaik Dalam sub-bab ini membahas implementasi congklak dan hasil pengujiannya. 4.2.1. Implementasi Bangkitkan semua nilai evaluasi f(n) dari semua lubang kecil di areanya Cari di antara lubang-lubang tersebut yang memiliki nilai f(n) tertinggi Jika nilai f(n) <= jumlah biji perlubang/2 maka Cari lubang yang mempunyai jumlah biji maksimum atau lubang(maks) Jika jumlah biji di seberang lubang(maks) = 0 Ambil lubang ini Jika tidak Ambil lubang(maks) yang terakhir ditemukan Jika nilai f(n) > jumlah biji perlubang / 2 maka Jika terdapat lebih dari 1 lubang yang memiliki nilai f(n) sama maka Cari lubang yang biji terakhirnya jatuh pada lubang besar sendiri Jika ditemukan maka Ambil lubang ini Jika tidak ditemukan maka Ambil lubang dengan nilai f(n) terbesar yang pertama kali ditemukan Implementasi aplikasi permainan dalam bentuk dua dimensi adalah seperti terlihat pada Gambar 5. Dimana dalam hal ini representasi papan berupa ilustrasi persegi panjang, representasi lubang berupa ilustrasi lingkaran, dan biji hanya berupa bilangan integer. Teknik Informatika / Universitas Surabaya Halaman 4

4.2.2. Hasil Pengujian Gambar 5. Antar muka awal aplikasi permainan congklak Tabel 1 berisi serangkaian pengujian yang telah dilakukan pada aplikasi menggunakan metode pengujian blackbox, dimana hasilnya secara umum telah memenuhi tata cara permainan congklak konvensional. Tabel 1. Rangkaian pengujian Kelas Uji Butir Uji Pemilihan lubang kecil saat permainan baru Memilih di area sendiri mulai Memilih di area lawan Memilih lubang pada biji terakhir Pemilihan lubang kecil saat permainan Memilih lubang lain di area sendiri sedang berjalan Memilih lubang lain di area lawan Biji terakhir jatuh di lubang kosong Lubang kosong di area sendiri Lubang kosong di area lawan Biji terakhir jatuh di lubang besar sendiri Biji terakhir jatuh di lubang besar sendiri Semua biji di lubang kecil salah satu pemain habis Semua biji di lubang kecil salah satu pemain habis Semua biji di kedua pemain habis Semua biji di kedua pemain habis Penerapan algoritma greedy untuk membantu pemain komputer memilih lubang yang optimal untuk satu langkah atau satu putaran ke depan sudah cukup baik, walaupun belum tentu optimal untuk keseluruhan putaran dalam permainan. 5. Kesimpulan Kesimpulan hasil penelitian adalah sebagai berikut. 1. Algoritma greedy dalam permainan congklak secara sederhana, praktis, dan cukup baik dapat digunakan untuk memilih lubang yang dimungkinkan memperoleh biji terbanyak. 2. Kombinasi dengan cara berfikir dinamis, pemain komputer dapat memutuskan kapan harus menyelamatkan biji lubangnya atau lebih memilih memperoleh biji sebanyak-banyaknya. 3. Algoritma yang digunakan dapat membantu mendapatkan solusi lokal yang optimal walaupun tidak selalu menghasilkan solusi terbaik secara keseluruhan. 4. Aplikasi permainan congklak secara fungsional berjalan sesuai dengan tata cara atau sistem bermain congklak tradisional, meliputi: memilih lubang, mengedarkan biji, menembak/pikul, kapan harus berganti pemain dan kapan pemain tetap dibolehkan bermain, hingga permainan usai. Perbaikan kecerdasan buatan perlu lebih diperbaiki untuk mendapatkan hasil yang lebih optimal. Begitu juga dengan antarmuka dan kemampuan permainan yang dapat dimainkan oleh banyak pengguna dalam sebuah jaringan lokal atau bahkan internet. Teknik Informatika / Universitas Surabaya Halaman 5

6. Daftar Pustaka [1] Conglak - Traditional Game of Indonesia, http://www.expat.or.id/info/congklak.html, diakses terakhir tanggal 2 Maret 2012. [2] Instructions for How to Play Congklak, http://www.expat.or.id/info/congklakinstructions.html, diakses terakhir tanggal 2 Maret 2012. [3] Jones, M.T. (2008), Artificial Intelligence : A Systems Approach, Hingham: Infinity Science Press. [4] Russel, S., dan Norvig, P. (2003). Artificial Intelligence A Modern Approach, 2nd edition, New Jersey: Prentice Hall. Teknik Informatika / Universitas Surabaya Halaman 6