Senin, 24 Juli 2017

Game Pong Berbasis Arduino (Implementasi)

BAB 3
Implementasi

1.  Pembuatan Game Pong Berbasis Arduino

Pong adalah videogame pertama yang sampai di pasar massal. Untuk pertama kalinya dalam sejarah, konsep "video game" dibawa ke rumah keluarga, berkat Atari 2600 - jadi kita dapat melestarikan game bersejarah ini. Sekarang, Anda bisa menghidupkan kembali gameplay (yang memang agak membosankan) menggunakan Arduino dan beberapa komponen umum.
Tidak mungkin anak perempuan Anda akan melepaskan Nintendo DS-nya, dan ini tidak hanya akan memberikan kesenangan bagi seluruh keluarga - tapi ini adalah perminan yang mengagumkan dan mudah untuk memperbaiki pengkodean Arduino Anda.
Kami akan membuat dua pengendali dasar, dan video akan menampilkan TV Anda melalui kabel video komposit standar.
Alat yang dibutuhkan:
·         470 ohm resistor x1
·         1k ohm resistor x1
·         10k ohm Potentiometer (twiddly variable resistor) x2
·         Arduino x1 (any version)
·         RCA plug x1 
·         Pushbutton switch x1
·         10k ohm resistor x1



Ambil steker RCA Anda dan lepaskan lapisan luarnya. Kumpulkan perisai, putar dan tempelkan ke satu sisi. Ini adalah medanmu. Di tengahnya harus ada kabel lain dengan pelindung plastik - sekali lagi, strip ini sehingga Anda memiliki garis sinyal Anda.



Solder resistor 470 ohm dan 1k ohm ke garis sinyal tengah steker RCA Anda - ini memberikan sinyal sinkronisasi dan sinyal video yang sebenarnya, digabungkan untuk menghasilkan input video analog. The 470 ohm resistor harus slot ke pin IO digital D07, sedangkan 1k ohm resistor pergi ke pin D09.
Pin ini diatur oleh perpustakaan yang kita impor, jadi Anda tidak bisa mengubahnya. Salah satu pin GND Arduino Anda harus masuk ke perisai (di luar) RCA.


Sekarang Anda bisa terus maju dan memasukkan contoh; Walaupun keduanya PAL dan NTSC disediakan, seharusnya tidak terlalu penting dengan TV digital modern - demo NTSC bekerja dengan baik. Tancapkan ke TV Anda, dan harus mendapatkan kubus 3D retro yang cocok



Test Analog Potentiometer Inputs
Setelah output TV bekerja, sekarang mari kita pergi dengan pengendali. Kabel dari "pot" tidak begitu penting - masing-masing harus memiliki 3 pin, dan yang sentral hampir selalu menghasilkan sinyal output. Kawat itu ke A0 dan A1 (satu untuk masing-masing pot). Pada salah satu sisi pin - tidak masalah yang - kawat atas 5 V. Pin lainnya di sisi lain harus di ground.
Di sini setelah menempatkan mereka berdua menghadap masing-masing di papan tempat pemotongan, karena hanya memiliki kabel pendek. Untuk produk yang dipoles, Anda pasti ingin menggunakan beberapa kabel jaringan lama untuk memberi jarak sedikit (sehingga Anda bisa benar-benar duduk di sofa untuk dimainkan).


Selanjutnya, muatkan salah satu sketsa contoh dasar yang menyertai Arduino - masukan analog satu. Demo ini akan menyalakan LED onboard lebih cepat atau lebih lambat, tergantung pada input pada A0.
Ini tidak menguji bagian A1 lainnya, tapi jika Anda memasang A0 dengan benar maka kami tidak dapat melihat bagaimana Anda akan membuat kesalahan pada A1, jadi anggap itu bagus dan terus berlanjut.

Menambahkan Start Switch
Akhirnya, kita akan menambahkan tombol start pada D02. Lihat diagram pengkabelan di sini untuk bagaimana melakukannya. Peralihan ini akan digunakan untuk memulai permainan saat berada di menu.


The Pong Code
Kami menggunakan beberapa kode yang aslinya ditulis oleh Lamonica, dimodifikasi oleh duboisvb untuk dua pemain, dan diperbarui sendiri untuk menggunakan versi terbaru perpustakaan TV out terbaru. Anda bisa melihat dan mendownload kode dari pastebin ini.
Ini cukup panjang tapi kode sederhana yang seharusnya tidak memerlukan penjelasan. Seperti kebanyakan game, game ini bergantung pada status permainan (menu, game dalam game, game over), dan membaca nilai masukan dari kedua pengendali dan setiap perulangan loop. Di luar itu adalah metode untuk menggambar layar, bola, dayung, dan logika permainan.


Perhatikan bahwa kode tersebut mencakup keluaran audio juga: Kami tidak dapat menemukan colokan RCA lagi untuk mengujinya, namun jika Anda memilikinya, maka pasang pin sinyal langsung ke D11, dan Anda harus mendapatkan nada retro yang cocok.


Arduino bahkan bisa melakukan TV tanpa pengkodean yang sangat rumit; TV out library membuatnya sangat mudah. Bahkan jika Anda tidak memasuki game retro, menggunakan TV dasar ini adalah cara yang bagus untuk memanfaatkan peralatan yang ada sebagai perangkat monitor murah. Tentu saja Anda bisa mengeluarkan warna output.
2.
2. Reinforcement Learning (RL)
Reinforcement Learning (RL) sering digunakan. Anda mungkin telah memperhatikan bahwa komputer sekarang dapat secara otomatis belajar bermain game ATARI (dari piksel permainan mentah!), Mereka mengalahkan juara dunia di Go, simulasi quadruped belajar berlari dan melompat, dan robot belajar bagaimana melakukan tugas manipulasi yang rumit. Ternyata semua kemajuan ini berada di bawah penelitian RL. Kami juga tertarik pada RL sendiri selama tahun terakhir: Kami bekerja melalui buku Richard Sutton, membaca kursus David Silver, menyaksikan ceramah John Schulmann, menulis sebuah perpustakaan RL di Javascript, selama musim panas yang diadakan di DeepMind yang bekerja di kelompok DeepRL, Dan yang paling baru bernada sedikit dengan desain / pengembangan OpenAI Gym, toolkit benchmarking RL baru. Jadi, sudah pasti mengasyikkan setidaknya selama satu tahun ini,

Contoh RL di alam bebas. Dari kiri ke kanan: Deep Q Belajar jaringan bermain ATARI, AlphaGo, Berkeley menumpuk robot Legos, simulasi melompati quadruped secara fisik di atas medan.
Menarik untuk memikirkan sifat kemajuan terkini dalam RL. Kami secara luas ingin memikirkan empat faktor terpisah yang menahan AI:
a.     Hitung (yang jelas: Hukum Moore, GPU, ASIC),
b.     Data (dalam bentuk yang bagus, tidak hanya di luar sana di suatu tempat di internet - misalnya ImageNet),
c.      Algoritma (penelitian dan gagasan, misalnya backprop, CNN, LSTM), dan
d.     Infrastruktur (perangkat lunak di bawah Anda - Linux, TCP / IP, Git, ROS, PR2, AWS, AMT, TensorFlow, dll.).
Mirip dengan apa yang terjadi di Computer Vision, kemajuan dalam RL tidak didorong sebanyak yang mungkin Anda anggap sebagai ide baru yang menakjubkan. Di Computer Vision, AlexNet 2012 sebagian besar merupakan varian Convnets tahun 1990 yang lebih kecil dan lebih luas. Demikian pula, makalah ATARI Deep Q Learning dari tahun 2013 adalah implementasi dari algoritma standar (Q Learning with function approximation, yang dapat Anda temukan di buku RL standar Sutton 1998), di mana perkiraan fungsi menjadi ConvNet. AlphaGo menggunakan gradien kebijakan dengan Monte Carlo Tree Search (MCT) - ini juga merupakan komponen standar. Tentu saja, dibutuhkan banyak keterampilan dan kesabaran untuk membuatnya bekerja, dan beberapa tweak cerdas di atas algoritma lama telah dikembangkan, namun sampai pada urutan pertama, pendorong utama kemajuan terakhir bukanlah algoritme tapi (serupa Untuk Computer Vision) menghitung / data / infrastruktur.

Sekarang kembali ke RL. Kapan pun ada keterputusan antara bagaimana sesuatu yang ajaib terlihat dan betapa sederhananya berada di bawah tenda, kami mendapatkan semua gelisah dan sangat ingin menulis posting blog. Dalam hal ini kami telah melihat banyak orang yang tidak percaya bahwa kita dapat secara otomatis belajar bermain game ATARI paling banyak di tingkat manusia, dengan satu algoritma, dari piksel, dan dari awal - dan ini menakjubkan, dan kami pernah ke sana. diri! Tapi pada intinya pendekatan yang kami gunakan juga benar-benar sangat sangat bodoh (walaupun kami mengerti mudah membuat klaim semacam itu dalam retrospeksi). Lagi pula, kami ingin memandu Anda melalui Gradien Kebijakan (PG), pilihan default favorit kami untuk menyerang masalah RL saat ini. Jika Anda berasal dari luar RL, Anda mungkin penasaran mengapa kami tidak menghadirkan DQN sebagai gantinya, yang merupakan algoritma RL alternatif dan lebih dikenal, dipopulerkan secara luas oleh permainan ATARI yang bermain. Ternyata Q-Learning bukanlah algoritma yang hebat (bisa dibilang DQN jadi 2013 (oke kami 50% bercanda)). Sebenarnya kebanyakan orang lebih suka menggunakan Gradien Kebijakan, termasuk penulis naskah DQN asli yang telah menunjukkan Gradien Kebijakan agar bekerja lebih baik daripada Q Learning saat menyetel dengan baik. PG lebih disukai karena bersifat end-to-end: ada kebijakan eksplisit dan pendekatan berprinsip yang secara langsung mengoptimalkan penghargaan yang diharapkan. Bagaimanapun, sebagai contoh yang berjalan, kita akan belajar memainkan game ATARI (Pong!) Dengan PG, dari nol, dari piksel, dengan jaringan syaraf yang dalam, dan semuanya 130 baris Python hanya menggunakan numpy sebagai ketergantungan.

Pong dari piksel

Kiri: Pertandingan Pong. Kanan: Pong adalah kasus khusus dari Markov Decision Process (MDP): Grafik di mana setiap simpul adalah negara permainan tertentu dan setiap tepi adalah transisi kemungkinan (pada umumnya probabilistik). Setiap sisi juga memberi poin, dan tujuannya adalah untuk menghitung cara bertindak yang optimal dalam keadaan apapun untuk memaksimalkan penghargaan.
Permainan Pong adalah contoh bagus dari tugas RL sederhana. Dalam versi ATARI 2600 kami akan mengajak Anda bermain sebagai salah satu dayung (yang lainnya dikendalikan oleh AI yang layak) dan Anda harus memantul bola melewati pemain lain. Pada tingkat rendah permainan bekerja sebagai berikut: kita menerima bingkai gambar (array 210x160x3 byte (bilangan bulat dari 0 sampai 255 memberikan nilai piksel)) dan kita dapat memutuskan apakah kita ingin memindahkan dayung ke atas atau ke bawah (misalnya biner pilihan). Setelah setiap pilihan simulator permainan menjalankan tindakan dan memberi kami poin: Entah imbalan +1 jika bola melewati lawan, poin -1 jika kami melewatkan bola, atau 0 sebaliknya. Dan tentu saja, tujuannya adalah menggerakkan dayung sehingga mendapatkan banyak poin.

Ketika kita melalui solusi ini, ingatlah bahwa kita akan mencoba membuat asumsi yang sangat sedikit tentang Pong karena kita diam-diam tidak terlalu peduli dengan Pong; Kami peduli dengan masalah kompleks dan berdimensi tinggi seperti manipulasi robot, perakitan dan navigasi. Pong hanyalah sebuah mainan yang menyenangkan, sesuatu yang kita mainkan sementara kita mencari tahu bagaimana menulis sistem AI yang sangat umum yang suatu hari bisa melakukan tugas-tugas bermanfaat yang sewenang-wenang.

Jaringan kebijakan Pertama, kita akan menentukan jaringan kebijakan yang mengimplementasikan pemain kita (atau "agen"). Jaringan ini akan mengambil keadaan permainan dan memutuskan apa yang harus kita lakukan (bergerak ke atas atau bawah). Sebagai blok sederhana favorit kami, kami akan menggunakan jaringan syaraf 2 lapisan yang mengambil piksel gambar mentah (100.800 nomor total (210 * 160 * 3)), dan menghasilkan satu angka yang menunjukkan probabilitas untuk naik UP. Perhatikan bahwa itu adalah standar untuk menggunakan kebijakan stokastik, yang berarti bahwa kita hanya menghasilkan probabilitas untuk bergerak ke atas. Setiap iterasi kita akan sampel dari distribusi ini (yaitu melempar koin yang bias) untuk mendapatkan pergerakan sebenarnya. Alasan untuk ini akan menjadi lebih jelas begitu kita berbicara tentang pelatihan.


Dan untuk membuat hal-hal yang konkret di sini adalah bagaimana Anda bisa menerapkan jaringan kebijakan ini dengan Python / numpy. Misalkan kita diberi vektor x yang menyimpan informasi pixel (preprocessed). Kami akan menghitung:H = np.dot (W1, x) # menghitung aktivasi neuron lapisan tersembunyi
H [h <0] = 0 # ReLU nonlinier: ambang di nol
Logp = np.dot (W2, h) # menghitung probabilitas log naik
P = 1.0 / (1.0 + np.exp (-logp)) # fungsi sigmoid (memberi kemungkinan naik)
Di mana dalam potongan ini W1 dan W2 adalah dua matriks yang kita inisialisasi secara acak. Perhatikan bahwa kita menggunakan sigmoid non-linearity di akhir, yang squashes probabilitas output ke kisaran [0,1]. Secara intuitif, neuron di lapisan tersembunyi (yang memiliki bobot yang diatur di sepanjang barisan W1) dapat mendeteksi berbagai skenario permainan (misalnya bola ada di atas, dan dayung kita ada di tengah), dan bobot di W2 kemudian dapat Putuskan jika dalam setiap kasus kita harus pergi UP atau DOWN. Sekarang, W1 dan W2 acak awal tentu saja menyebabkan pemain tersebut tersadar. Jadi satu-satunya masalah sekarang adalah menemukan W1 dan W2 yang mengarah pada permainan ahli Pong!

Cetak halus: preprocessing. Idealnya Anda ingin memberi makan minimal 2 frame ke jaringan kebijakan sehingga bisa mendeteksi gerakan. Untuk membuat hal-hal sedikit lebih sederhana kami akan melakukan sedikit persiapan ulang. Kami benar-benar akan memberi umpan pada frame perbedaan ke jaringan (yaitu pengurangan bingkai saat ini dan yang terakhir).

Kedengarannya tidak mungkin. Pada titik ini kami ingin Anda menghargai betapa sulitnya masalah RL. Kami mendapatkan 100.800 nomor (210 * 160 * 3) dan meneruskan jaringan kebijakan kami (yang dengan mudah melibatkan pesanan satu juta parameter di W1 dan W2). Misalkan kita memutuskan untuk pergi ke UP. Permainan mungkin merespons bahwa kita mendapatkan 0 poin saat ini dan memberi kami 100.800 nomor lagi untuk frame berikutnya. Kita bisa mengulangi proses ini selama seratus timesteps sebelum kita mendapatkan poin tanpa nol! Misalnya. Misalkan kita akhirnya mendapatkan +1. Itu bagus, tapi bagaimana kita bisa tahu apa yang terjadi? Apakah itu sesuatu yang kita lakukan sekarang? Atau mungkin 76 frame lalu? Atau mungkin ada kaitannya dengan frame 10 dan kemudian frame 90? Dan bagaimana kita mengetahui mana dari jutaan tombol yang harus diubah dan bagaimana, agar bisa lebih baik di masa depan? Kami menyebutnya masalah penugasan kredit. Dalam kasus spesifik Pong kita tahu bahwa kita mendapatkan +1 jika bola berhasil melewati lawan. Penyebab sebenarnya adalah bahwa kita kebetulan memantulkan bola pada lintasan yang bagus, namun sebenarnya kita sudah melakukan banyak bingkai lalu - mis. Mungkin sekitar 20 dalam kasus Pong, dan setiap tindakan yang kami lakukan kemudian tidak berpengaruh pada apakah kami akan mendapatkan pahala atau tidak. Dengan kata lain kita dihadapkan pada masalah yang sangat sulit dan hal-hal yang terlihat sangat suram.

Pembelajaran yang perlu diperhatikan. Sebelum kita terjun ke solusi Gradien Kebijakan, kami ingin mengingatkan Anda secara singkat tentang pembelajaran yang diawasi karena, seperti yang akan kita lihat, RL sangat mirip. Lihat diagram di bawah ini. Dalam pembelajaran yang diawasi biasa, kami akan memberi umpan pada jaringan dan mendapatkan beberapa kemungkinan, mis. Untuk dua kelas UP dan DOWN. Kami menunjukkan probabilitas log (-1,2, -0,36) untuk UP dan DOWN daripada probabilitas mentah (30% dan 70% dalam kasus ini) karena kami selalu mengoptimalkan probabilitas log dari label yang benar (ini membuat matematika menjadi lebih baik, dan Adalah setara dengan mengoptimalkan probabilitas mentah karena log monotonik). Sekarang, dalam pembelajaran yang diawasi kita akan memiliki akses ke label. Misalnya, kita mungkin diberitahu bahwa hal yang benar untuk dilakukan saat ini adalah pergi ke UP (label 0). Dalam sebuah implementasi kita akan memasukkan gradien 1.0 pada probabilitas log UP dan menjalankan backprop untuk menghitung vektor gradien Wlogp(y=UPx). Gradien ini akan memberi tahu kita bagaimana kita mengubah setiap parameter dari juta kita untuk membuat jaringan sedikit lebih cenderung memprediksi UP. Misalnya, salah satu dari jutaan parameter dalam jaringan mungkin memiliki gradien -2,1, yang berarti bahwa jika kita ingin meningkatkan parameter tersebut dengan jumlah positif kecil (misalnya 0,001), probabilitas log UP akan turun sebesar 2,1 * 0,001 (Penurunan karena tanda negatif). Jika kemudian kami melakukan update parameter, yay, jaringan kami sekarang akan sedikit lebih cenderung memprediksi UP ketika melihat gambar yang sangat mirip di masa depan.


Gradien Kebijakan Oke, tapi apa yang kita lakukan jika kita tidak memiliki label yang benar dalam pengaturan Belajar Penguatan? Inilah solusi Gradien Kebijakan (sekali lagi lihat diagram di bawah ini). Jaringan kebijakan kami menghitung probabilitas naik UP sebesar 30% (logprob -1.2) dan DOWN 70% (logprob -0.36). Sekarang kita akan mengambil contoh tindakan dari distribusi ini; Misalnya. Misalkan kita sampel DOWN, dan kita akan menjalankannya dalam game. Pada titik ini perhatikan satu fakta menarik: Kita dapat segera mengisi gradien 1,0 untuk DOWN seperti yang kita lakukan dalam pembelajaran di bawah pengawasan, dan menemukan vektor gradien yang akan mendorong jaringan untuk sedikit lebih mungkin melakukan aksi DOWN di masa depan. Jadi kita bisa langsung mengevaluasi gradien ini dan itu bagus, tapi masalahnya adalah setidaknya untuk saat ini kita belum tahu apakah akan DOWN itu bagus. Tapi yang penting adalah tidak apa-apa, karena kita bisa menunggu sebentar dan melihat! Misalnya di Pong kita bisa menunggu sampai akhir permainan, lalu ambil reward yang kita dapatkan (baik +1 jika kita menang atau -1 jika kita kalah), dan masukkan skalar itu sebagai gradien untuk tindakan yang telah kita ambil (DOWN pada kasus ini). Pada contoh di bawah ini, DOWN akan berakhir sampai kalah game (-1 reward). Jadi jika kita mengisi -1 untuk probabilitas log DOWN dan melakukan backprop kita akan menemukan gradien yang menghambat jaringan untuk mengambil aksi DOWN untuk masukan itu di masa depan (dan memang begitu, karena mengambil tindakan tersebut menyebabkan kita kehilangan permainan ).


Dan begitulah: kami memiliki kebijakan stokastik yang melakukan tindakan sampel dan kemudian tindakan yang pada akhirnya menghasilkan hasil yang baik didorong di masa depan, dan tindakan yang dilakukan yang mengarah pada hasil yang buruk berkecil hati. Juga, pahala bahkan tidak perlu menjadi +1 atau -1 jika kita memenangkan permainan pada akhirnya. Ini bisa menjadi ukuran yang sewenang-wenang dari beberapa jenis kualitas akhirnya. Misalnya jika semuanya berjalan dengan baik, itu bisa jadi 10.0, yang kemudian akan kita masukkan sebagai gradien dan bukan -1 untuk memulai backprop. Itulah keindahan jaring saraf; Menggunakannya bisa terasa seperti kecurangan: Anda diperbolehkan memiliki 1 juta parameter yang disatukan dalam 1 teraflop perhitungan dan Anda dapat membuatnya melakukan hal-hal yang sewenang-wenang dengan SGD. Seharusnya tidak bekerja, tapi menggelikan kita hidup di alam semesta dimana hal itu terjadi.

Protokol pelatihan di sini adalah bagaimana pelatihan akan bekerja secara rinci. Kami akan menginisialisasi jaringan kebijakan dengan beberapa W1, W2 dan memainkan 100 game Pong (kami menyebut "rollouts" kebijakan ini). Mari kita asumsikan bahwa setiap permainan terdiri dari 200 frame jadi totalnya kita telah membuat 20.000 keputusan untuk naik ke atas atau ke bawah dan untuk masing-masing kita mengetahui parameter gradien, yang memberitahu kita bagaimana kita harus mengubah parameter jika kita ingin Dorong keputusan itu di negara bagian itu di masa depan. Yang tersisa sekarang adalah memberi label pada setiap keputusan yang telah kita buat sebagai baik atau buruk. Misalnya anggaplah kita memenangkan 12 pertandingan dan kalah pada tahun 88. Kami akan mengambil semua 200 * 12 = 2400 keputusan yang kami buat di dalam permainan yang menang dan melakukan pembaruan positif (mengisi +1,0 dalam gradien untuk tindakan sampel, melakukan backprop, Dan update parameter mendorong tindakan yang kami ambil di semua negara bagian tersebut). Dan kita akan mengambil 200 lain lagi: 17600 keputusan yang kita buat dalam permainan kalah dan melakukan pembaruan negatif (mengecilkan hati apa pun yang kita lakukan). Dan ... itu dia. Jaringan sekarang akan menjadi sedikit lebih mungkin untuk mengulang tindakan yang berhasil, dan sedikit lebih kecil kemungkinannya untuk mengulangi tindakan yang tidak berhasil. Sekarang kami memainkan 100 game lagi dengan kebijakan baru kami yang sedikit membaik dan berkumur dan diulang.

Gradien Kebijakan: Jalankan sebuah kebijakan untuk sementara waktu. Lihatlah tindakan apa yang menghasilkan penghargaan tinggi. Tingkatkan probabilitasnya.


Ini adalah diagram dari 4 game. Setiap lingkaran hitam adalah beberapa status permainan (tiga contoh keadaan divisualisasikan di bagian bawah), dan setiap panah adalah transisi, yang diberi catatan dengan tindakan yang dijadikan sampel. Dalam hal ini kita memenangkan 2 game dan kalah 2 game. Dengan Gradien Kebijakan, kami akan mengambil dua pertandingan yang kami menangi dan sedikit mendorong setiap tindakan yang kami lakukan di episode itu. Sebaliknya, kita juga akan mengambil dua pertandingan yang kita hilang dan sedikit mengecilkan hati setiap tindakan yang kita buat di episode itu.
Jika Anda memikirkan proses ini, Anda akan mulai menemukan beberapa sifat lucu. Misalnya bagaimana jika kita melakukan aksi yang baik di frame 50 (memantulkan bola kembali dengan benar), tapi kemudian merindukan bola di frame 150? Jika setiap tindakan sekarang dicantumkan sebagai buruk (karena kita kalah), bukankah itu akan mengecilkan mental yang benar pada frame 50? Anda benar - itu akan terjadi. Namun, bila Anda mempertimbangkan proses lebih dari ribuan juta game, kemudian melakukan bouncing pertama benar membuat Anda sedikit lebih mungkin untuk menang di jalan, jadi rata-rata Anda akan melihat lebih positif daripada pembaruan negatif untuk mental yang benar dan kebijakan Anda. Akan berakhir melakukan hal yang benar.

Dalam penjelasan kami di atas, kami menggunakan istilah seperti "mengisi gradien dan backprop", yang kami sadari adalah tipe pemikiran khusus jika Anda terbiasa menulis kode backprop Anda sendiri, atau menggunakan Torch di mana gradiennya eksplisit dan terbuka. Untuk bermain-main. Namun, jika Anda terbiasa dengan Theano atau TensorFlow Anda mungkin sedikit bingung karena kode tersebut disatukan di sekitar menentukan fungsi kehilangan dan backprop sepenuhnya otomatis dan sulit dipecahkan. Dalam kasus ini, pandangan alternatif berikut mungkin lebih intuitif. Dalam pembelajaran vanili yang diawasi, tujuannya adalah untuk memaksimalkan Σilogp (yi|xi)
ilogp(yi
xi)∑ilogp(yixi) dimana xi,yixi,yiadalah contoh pelatihan (seperti gambar dan labelnya). Gradien kebijakan sama persis dengan pembelajaran yang diawasi dengan dua perbedaan kecil: 1) Kami tidak memiliki label yiyi yang benar sehingga sebagai "label palsu" kami mengganti tindakan yang kami lakukan untuk mengambil contoh dari kebijakan saat melihat xixi, dan 2 ) Kami memodulasi kerugian untuk setiap contoh secara multiplisatif berdasarkan hasil akhirnya, karena kami ingin meningkatkan probabilitas log untuk tindakan yang berhasil dan menurunkannya bagi yang tidak melakukannya. Jadi, dalam ringkasan kerugian kita sekarang terlihat seperti iAilogp(yixi)∑iAilogp(yixi),di mana yiyi adalah tindakan yang kita lakukan untuk sampel dan AiAi adalah angka yang kita sebut keuntungan. Dalam kasus Pong, misalnya, AiAi bisa menjadi 1,0 jika kita akhirnya menang dalam episode yang mengandung xixi dan -1,0 jika kita kalah. Ini akan memastikan bahwa kita memaksimalkan probabilitas log tindakan yang menghasilkan hasil yang baik dan meminimalkan probabilitas log dari yang tidak. Jadi, pembelajaran penguatan sama persis dengan pembelajaran yang diawasi, namun pada kumpulan data yang terus berubah (episode), diperkecil oleh keuntungan, dan kami hanya ingin melakukan satu (atau sangat sedikit) pembaruan berdasarkan masing-masing kumpulan data sampel.

Kami juga sedikit lebih banyak membahas pengembalian. Sejauh ini kita telah menilai kebaikan setiap tindakan individu berdasarkan pada apakah kita memenangkan pertandingan atau tidak. Dalam setting RL yang lebih umum kita akan menerima beberapa reward rtrt setiap saat. Salah satu pilihan yang umum adalah menggunakan poin diskon, jadi "poin akhir" pada diagram di atas akan menjadi Rt=∑∞k=0γkrt+kRt=∑k=0∞γkrt+k,di mana γγ adalah angka antara 0 dan 1 Disebut faktor diskon (misalnya 0,99). Ungkapan tersebut menyatakan bahwa kekuatan yang digunakan untuk mendorong tindakan sampel adalah jumlah tertimbang dari semua penghargaan setelahnya, namun penghargaan selanjutnya secara eksponensial kurang penting. Dalam prakteknya, penting juga untuk menormalkan hal ini. Sebagai contoh, anggaplah kita menghitung RtRt untuk semua 20.000 tindakan dalam batch 100 rollthrough game Pong di atas. Salah satu ide bagus adalah "membakukan" pengembalian ini (misal: kurangi mean, bagi dengan standar deviasi) sebelum kita menghubungkannya ke backprop. Dengan cara ini kami selalu memberi semangat dan mengurangi kira-kira setengah dari tindakan yang dilakukan. Secara matematis Anda juga bisa menafsirkan trik ini sebagai cara untuk mengendalikan varians estimator gradien kebijakan. Eksplorasi yang lebih mendalam dapat ditemukan di sini.
Kami juga ingin memberikan sketsa dari mana Gradien Kebijakan berasal secara matematis. Gradien Kebijakan adalah kasus khusus dari estimator gradien fungsi skor yang lebih umum. Kasus umum adalah bahwa ketika kita memiliki ekspresi dari bentuk Exp(xθ)[f(x)]Exp(xθ)[f(x)] - i.e. yaitu harapan beberapa skor bernilai skalar Fungsi f (x) f (x) di bawah beberapa distribusi probabilitas p (x; θ) p (x; θ) yang ditentukan oleh beberapa θθ. Petunjuk singkat, f (x) f (x) akan menjadi fungsi reward kita (atau fungsi keuntungan lebih umum) dan p (x) p (x) akan menjadi jaringan kebijakan kita, yang benar-benar merupakan model untuk p (a|I) P (a|I), memberikan distribusi atas tindakan untuk setiap gambar II. Kemudian kami tertarik untuk menemukan bagaimana kita harus mengalihkan distribusi (melalui parameternya θθ) untuk meningkatkan nilai sampelnya, seperti yang dinilai oleh ff (yaitu bagaimana kita mengubah parameter jaringan sehingga sampel tindakan mendapat imbalan lebih tinggi).
Kami memilikinya:
θEx[f(x)]       =θxp(x)f(x)                        Definisi harapan
=∑xθp(x)f(x)                        Jumlah wap dan gradien
=∑xp(x)θp(x)p(x)f(x)          Keduanya mengalikan dan membagi dengan p (x)
=∑xp(x)θlogp(x)f(x)                        Gunakan fakta bahwa θlog (z) = 1zθz
Definisi harapan

Untuk memasukkan ini ke dalam bahasa Inggris, kita memiliki beberapa distribusi p (x; θ) p (x; θ) (kami menggunakan steno p (x) p (x) untuk mengurangi kekacauan) yang dapat kita contoh (misalnya ini bisa menjadi gaussian ). Untuk setiap sampel, kami juga dapat mengevaluasi fungsi skor yang mengambil sampel dan memberi kami beberapa nilai skalar. Persamaan ini memberi tahu kita bagaimana kita harus mengalihkan distribusi (melalui parameternya θθ) jika kita ingin sampelnya mencapai nilai yang lebih tinggi, seperti yang dinilai oleh ff. Secara khusus, ia mengatakan bahwa tampilan: menggambar beberapa sampel xx, mengevaluasi nilai f (x) f (x), dan untuk setiap xx juga mengevaluasi istilah kedua
θlogp(x;θ)θlogp(x;θ).Apa istilah kedua ini? Ini adalah vektor - gradien yang memberi kita arah di ruang parameter yang akan menyebabkan peningkatan probabilitas yang ditetapkan ke xx. Dengan kata lain, jika kita ingin menyenggol θθ ke arah ∇θlogp(x;θ)∇θlog⁡p(x;θ)kita akan melihat probabilitas baru yang diberikan pada beberapa xx sedikit meningkat. Jika Anda melihat kembali rumusnya, ini memberi tahu kita bahwa kita harus mengambil arah ini dan mengalikannya dengan nilai skor skalar f (x) f (x). Hal ini akan membuatnya sehingga sampel yang memiliki skor lebih tinggi akan "menarik" pada kerapatan probabilitas lebih kuat daripada sampel yang memiliki skor lebih rendah, jadi jika kita melakukan update berdasarkan beberapa sampel dari pp maka kerapatan probabilitas akan bergeser sekitar Arah skor yang lebih tinggi, membuat sampel dengan skor tinggi lebih mungkin terjadi.



Sebuah visualisasi dari skor fungsi gradient estimator. Kiri: Distribusi gaussian dan beberapa contoh darinya (titik biru). Pada setiap titik biru kita juga memplot gradien probabilitas log berkenaan dengan parameter mean gaussian. Panah menunjukkan arah di mana rata-rata distribusi harus didorong untuk meningkatkan probabilitas sampel tersebut. Tengah: Overlay beberapa fungsi skor memberi -1 di mana-mana kecuali +1 di beberapa wilayah kecil (perhatikan ini bisa menjadi fungsi skalar bernilai sewenang-wenang dan tidak harus terdiferensialkan). Anak panah sekarang diberi kode warna karena karena perbanyakan di update kita akan rata-rata menaiki semua panah hijau, dan tanda panah merah negatif. Kanan: setelah update parameter, panah hijau dan panah merah terbalik mendorong kita ke kiri dan ke arah bawah. Sampel dari distribusi ini sekarang akan memiliki nilai harapan yang lebih tinggi, sesuai keinginan.
Kami harap koneksi ke RL jelas. Jaringan kebijakan kami memberi kita contoh tindakan, dan beberapa di antaranya bekerja lebih baik daripada yang lain (seperti yang dinilai oleh fungsi keuntungan). Bagian kecil matematika ini memberi tahu kami bahwa cara untuk mengubah parameter kebijakan adalah melakukan beberapa peluncuran, mengambil gradien dari tindakan sampel, memperbanyaknya dengan skor dan menambahkan semuanya, itulah yang telah kami lakukan di atas. Untuk derivasi dan diskusi yang lebih menyeluruh, kami merekomendasikan ceramah John Schulman.

Baiklah, kami telah mengembangkan intuisi untuk gradien kebijakan dan melihat sketsa derivasi mereka. Kami menerapkan keseluruhan pendekatan dalam skrip Python 130 baris, yang menggunakan ATARI 2600 PANDA OpenAI Gym. Kami melatih jaringan kebijakan 2 layer dengan 200 unit lapisan tersembunyi menggunakan RMSProp pada batch 10 episode (setiap episode adalah beberapa lusin game, karena permainannya menghasilkan skor 21 untuk kedua pemain). Kami tidak menyetel hiperparameter terlalu banyak dan menjalankan eksperimen di Macbook kami yang lamban, namun setelah berlatih selama 3 malam, kami berakhir dengan sebuah kebijakan yang sedikit lebih baik daripada pemain AI. Jumlah total episode kira-kira 8.000 sehingga algoritma tersebut memainkan kira-kira 200.000 game Pong (cukup banyak bukan!) Dan menghasilkan total 800 update. Kami diberitahu oleh teman bahwa jika Anda melatih GPU dengan ConvNets selama beberapa hari, Anda dapat mengalahkan pemain AI lebih sering, dan jika Anda juga mengoptimalkan hyperparameters dengan hati-hati, Anda juga dapat secara konsisten mendominasi pemain AI (yaitu memenangkan setiap pertandingan tunggal). Namun, kami tidak menghabiskan terlalu banyak waktu untuk melakukan komputasi atau tweaking, jadi kita akan berakhir dengan AI Pong yang menggambarkan gagasan utama dan bekerja dengan baik:



Bobot yang dipelajari. Kita juga bisa melihat bobot yang dipelajari. Karena preprocessing setiap masukan kita adalah gambar perbedaan 80x80 (frame saat ini dikurangi frame terakhir). Kita sekarang bisa mengambil setiap baris W1, merentangnya hingga 80x80 dan memvisualisasikannya. Berikut adalah koleksi 40 (dari 200) neuron dalam kotak. Pixel putih adalah bobot positif dan piksel hitam adalah bobot negatif. Perhatikan bahwa beberapa neuron disetel ke jejak bola bouncing tertentu, dikodekan dengan bolak hitam dan putih sepanjang garis. Bola hanya bisa berada di satu titik, jadi neuron ini multitasking dan akan "memecat" beberapa lokasi bola sepanjang garis itu. Bolak hitam dan putih menarik karena saat bola bergerak sepanjang jejak, aktivitas neuron akan berfluktuasi sebagai gelombang sinus dan karena ReLU itu akan "menyala" pada posisi terpisah dan terpisah di sepanjang jejak. Ada sedikit kebisingan dalam gambar, yang kami asumsikan telah dikurangi jika kami menggunakan regularisasi L2.


Kami belajar memainkan Pong dari piksel mentah dengan Gradien Kebijakan dan hasilnya cukup baik. Pendekatannya adalah bentuk tebakan dan cek yang bagus, di mana "tebakan" mengacu pada penggolongan sampling dari kebijakan kami saat ini, dan "cek" tersebut mengacu pada tindakan yang mendorong hasil yang baik. Modulo beberapa rincian, ini merupakan keadaan seni dalam bagaimana kita saat ini mendekati masalah belajar penguatan. Yang mengesankan bahwa kita dapat mempelajari perilaku ini, namun jika Anda memahami algoritme secara intuitif dan Anda tahu cara kerjanya, Anda setidaknya harus sedikit kecewa. Secara khusus, bagaimana cara kerjanya?

Bandingkan dengan bagaimana manusia bisa belajar bermain Pong. Anda menunjukkan permainan mereka dan mengatakan sesuatu di sepanjang baris "Anda memegang kendali dayung dan Anda dapat memindahkannya ke atas dan ke bawah, dan tugas Anda adalah memantul bola melewati pemain lain yang dikendalikan oleh AI", dan Anda ' Kembali siap dan siap untuk pergi Perhatikan beberapa perbedaannya:

Dalam pengaturan praktis, biasanya kami mengkomunikasikan tugas dengan cara tertentu (misalnya bahasa Inggris di atas), namun dalam masalah RL standar, Anda menganggap fungsi penghargaan sewenang-wenang yang harus Anda temukan melalui interaksi lingkungan. Dapat dikatakan bahwa jika seorang manusia masuk dalam permainan Pong tapi tanpa mengetahui apapun tentang fungsi penghargaan (memang, terutama jika fungsi penghargaan bersifat statis tapi acak), manusia akan memiliki banyak kesulitan untuk belajar apa yang harus dilakukan kecuali Gradien Kebijakan akan acuh tak acuh, dan kemungkinan bekerja lebih baik. Demikian pula, jika kita mengambil frame dan mengubah piksel secara acak maka manusia kemungkinan besar akan gagal, namun solusi Gradient Policy kita bahkan tidak bisa membedakannya (jika menggunakan jaringan yang terhubung sepenuhnya seperti yang dilakukan di sini).
Seseorang membawa sejumlah besar pengetahuan sebelumnya, seperti fisika intuitif (bola memantul, tidak mungkin melakukan teleport, tidak mungkin tiba-tiba berhenti, ia mempertahankan kecepatan konstan, dll.), Dan psikologi intuitif (lawan AI) menginginkan "Untuk menang, kemungkinan mengikuti strategi yang jelas untuk bergerak menuju bola, dll.). Anda juga memahami konsep "mengendalikan" dayung, dan itu merespons perintah tombol UP / DOWN Anda. Sebaliknya, algoritma kita mulai dari nol yang secara bersamaan mengesankan (karena berhasil) dan menekan (karena kita kekurangan ide konkret untuk bagaimana tidak).
Gradien Kebijakan adalah solusi brute force, di mana tindakan yang benar akhirnya ditemukan dan diinternalisasi menjadi sebuah kebijakan. Manusia membangun model, kaya abstrak dan rencana di dalamnya. Di Pong, kami bisa beralasan lawan cukup lamban sehingga bisa jadi strategi bagus untuk memantulkan bola dengan kecepatan vertikal tinggi, yang akan menyebabkan lawan tidak menangkapnya tepat pada waktunya. Namun, rasanya juga kita juga akhirnya "menginternalisasi" solusi yang baik menjadi apa yang terasa lebih mirip dengan kebijakan memori otot reaktif. Misalnya jika Anda mempelajari tugas motor baru (misalnya mengendarai mobil dengan tongkat bergeser?) Anda sering merasa diri Anda banyak berpikir di awal tapi pada akhirnya tugas menjadi otomatis dan tidak berperasaan.
Gradien Kebijakan harus benar-benar mengalami penghargaan positif, dan mengalaminya dengan sangat sering agar akhirnya dan secara perlahan mengubah parameter kebijakan menjadi pengulangan pergerakan yang memberi penghargaan tinggi. Dengan model abstrak kita, manusia dapat mengetahui apa yang mungkin memberi penghargaan tanpa pernah benar-benar mengalami transisi yang menguntungkan atau tidak menguntungkan. Kami menabrak mobil ke dinding beberapa ratus kali sebelum kami perlahan-lahan mulai menghindari untuk melakukannya.



Kiri: Montezuma's Revenge: permainan yang sulit untuk algoritma RL kami. Pemain harus melompat turun, memanjat, mendapatkan kunci, dan membuka pintu. Seorang manusia mengerti bahwa memperoleh sebuah kunci berguna. Contoh komputer miliaran gerakan acak dan 99% waktunya jatuh ke kematiannya atau terbunuh oleh monster tersebut. Dengan kata lain sulit untuk "tersandung ke dalam" situasi yang menguntungkan. Benar: Game lain yang sulit disebut Frostbite, di mana manusia mengerti bahwa segala sesuatunya bergerak, ada beberapa hal yang bagus untuk disentuh, beberapa hal buruk untuk disentuh, dan tujuannya adalah membangun bata igloo dari batu bata. Analisis yang bagus tentang permainan ini dan diskusi tentang perbedaan antara pendekatan manusia dan komputer dapat ditemukan di Mesin Bangunan yang Mempelajari dan Berpikir Seperti Orang.
Kami juga ingin menekankan maksudnya, sebaliknya, ada banyak permainan di mana Gradien Kebijakan akan dengan mudah mengalahkan manusia. Secara khusus, apapun dengan sinyal poin yang sering dibutuhkan, refleks yang cepat, dan perencanaan jangka panjang yang tidak terlalu banyak akan ideal, karena korelasi jangka pendek antara penghargaan dan tindakan dapat dengan mudah "diperhatikan" oleh pendekatan, dan Eksekusi dengan cermat disempurnakan oleh polis. Anda dapat melihat petunjuk tentang hal ini yang sudah terjadi pada agen Pong kami: ia mengembangkan strategi di mana ia menunggu bola dan kemudian dengan cepat berlari untuk menangkapnya tepat di tepi, yang meluncurkannya dengan cepat dan dengan kecepatan vertikal tinggi. Agen tersebut mencatat beberapa poin berturut-turut untuk mengulangi strategi ini. Ada banyak game ATARI dimana Deep Q Learning menghancurkan kinerja dasar manusia dengan cara ini - mis. Pinball, Breakout, dll.

Sebagai kesimpulan, setelah Anda memahami "trik" yang digunakan algoritma ini, Anda dapat memberi alasan melalui kekuatan dan kelemahan mereka. Secara khusus, kita tidak berada di dekat manusia dalam membangun representasi permainan yang abstrak dan kaya yang dapat kita rencanakan di dalam dan digunakan untuk pembelajaran cepat. Suatu hari komputer akan melihat array piksel dan melihat sebuah kunci, sebuah pintu, dan berpikir untuk dirinya sendiri bahwa mungkin ide yang bagus untuk mengambil kunci dan mencapai pintu. Untuk saat ini tidak ada yang dekat dengan ini, dan mencoba untuk sampai ke sana adalah area penelitian yang aktif.

Perhitungan yang tidak dapat dibedakan dalam Neural Networks

Kami ingin menyebutkan satu aplikasi menarik dari Gradien Kebijakan yang tidak terkait dengan permainan: Ini memungkinkan kita merancang dan melatih jaringan syaraf tiruan dengan komponen yang melakukan (atau berinteraksi dengan) perhitungan yang tidak dapat dibedakan. Idenya pertama kali diperkenalkan di Williams 1992 dan baru-baru ini dipopulerkan oleh Recurrent Models of Visual Attention dengan nama "perhatian keras", dalam konteks model yang mengolah gambar dengan urutan sekilas jarak pandang rendah (terinspirasi oleh kita sendiri Mata manusia). Secara khusus, pada setiap iterasi, RNN akan menerima sepotong kecil gambar dan sampel lokasi untuk melihat berikutnya. Misalnya RNN mungkin melihat posisi (5,30), menerima sepotong kecil gambar, lalu memutuskan untuk melihat (24, 50), dan lain-lain. Masalahnya dengan gagasan ini adalah ada sepotong jaringan yang menghasilkan Distribusi kemana harus mencari selanjutnya dan kemudian sampel darinya. Kamingnya, operasi ini tidak dapat dibedakan karena, secara intuitif, kita tidak tahu apa yang akan terjadi jika kita mencicipi lokasi yang berbeda. Secara umum, perhatikan jaringan saraf dari beberapa input ke output:





Perhatikan bahwa sebagian besar panah (berwarna biru) dapat didiferensiasi seperti biasa, namun beberapa transformasi representasi secara opsional juga mencakup operasi sampling yang tidak dapat didiferensiasi (berwarna merah). Kita bisa membalikkan melalui panah biru dengan baik, tapi panah merah mewakili ketergantungan yang tidak dapat kita perbaiki.

Kita akan memikirkan bagian jaringan yang melakukan sampling sebagai kebijakan stokastik kecil yang tertanam di jaringan yang lebih luas. Oleh karena itu, selama pelatihan kami akan menghasilkan beberapa sampel (ditunjukkan oleh cabang di bawah), dan kemudian kami akan mendorong sampel yang akhirnya menghasilkan hasil yang baik (dalam hal ini misalnya diukur dengan kerugian pada akhirnya). Dengan kata lain, kita akan melatih parameter yang terkait dengan panah biru dengan backprop seperti biasa, namun parameter yang terkait dengan panah merah sekarang akan diperbarui secara independen dari arus balik dengan menggunakan gradien kebijakan, mendorong sampel yang menyebabkan kerugian rendah. Ide ini juga baru saja diformalkan dengan baik dalam Estimasi Gradien Menggunakan Grafik Perhitungan Stokastik.


Memori Pelatih I / O.
Anda juga akan menemukan ide ini di banyak makalah lainnya. Sebagai contoh, Neural Turing Machine memiliki pita memori yang mereka baca dan tulis. Untuk melakukan operasi tulis seseorang ingin melakukan sesuatu seperti m [i] = x, di mana i dan x diprediksi oleh jaringan pengendali RNN. Namun, operasi ini tidak dapat dibedakan karena tidak ada sinyal yang memberitahu kita apa yang akan terjadi pada kerugian jika kita menulis ke lokasi yang berbeda j! = I. Oleh karena itu, NTM harus melakukan operasi baca dan tulis yang lunak. Ini memprediksikan distribusi perhatian (dengan elemen antara 0 dan 1 dan menjumlahkan ke 1, dan memuncak di sekitar indeks yang ingin kita tulis), dan kemudian melakukan semua i: m [i] = a [i] * x . Ini sekarang bisa dibedakan, tapi kita harus membayar harga komputasi yang berat karena kita harus menyentuh setiap sel memori hanya untuk menulis ke satu posisi. Bayangkan jika setiap tugas di komputer kita harus menyentuh keseluruhan RAM!

Namun, kita bisa menggunakan gradien kebijakan untuk menghindari masalah ini (secara teori), seperti yang dilakukan di RL-NTM. Kami masih meramalkan distribusi perhatian, tapi alih-alih menulis dengan lembut, kami sampel lokasi untuk ditulis ke: i = sampel (a); M [i] = x. Selama pelatihan, kami akan melakukan ini untuk sekelompok kecil kami, dan pada akhirnya membuat cabang apa pun yang bekerja paling baik. Keuntungan komputasi yang besar adalah kita sekarang hanya perlu membaca / menulis di satu lokasi pada saat uji. Namun, seperti yang ditunjukkan dalam makalah ini strategi ini sangat sulit untuk bisa bekerja karena seseorang harus secara tidak sengaja tersandung oleh algoritma kerja melalui sampling. Konsensus saat ini adalah bahwa PG bekerja dengan baik hanya dalam pengaturan di mana ada beberapa pilihan diskrit sehingga tidak ada pengambilan keputusan dengan cepat melalui ruang pencarian yang sangat besar.

Namun, dengan Gradien Kebijakan dan dalam kasus di mana banyak data / perhitungan tersedia, kita pada prinsipnya dapat bersikap besar - misalnya kita dapat merancang jaringan syaraf tiruan yang belajar berinteraksi dengan modul besar dan tidak terdiferensiasi seperti kompiler Lateks (misalnya jika Anda Seperti char-rnn untuk menghasilkan lateks yang dikompilasi), atau sistem SLAM, atau pemecah LQR, atau sejenisnya. Atau, misalnya, sebuah superintelligence mungkin ingin belajar berinteraksi dengan internet melalui TCP / IP (yang kamingnya tidak dapat dibedakan) untuk mengakses informasi penting yang dibutuhkan untuk menguasai dunia. Itu contoh bagus.

Kami melihat bahwa Gradien Kebijakan adalah algoritma umum yang kuat dan sebagai contoh, kami melatih agen ATARI Pong dari piksel mentah, dari awal, dalam 130 baris Python. Secara umum algoritma yang sama dapat digunakan untuk melatih agen untuk permainan sewenang-wenang dan suatu hari mudah-mudahan pada banyak masalah pengendalian dunia nyata yang berharga. Kami ingin menambahkan beberapa catatan lagi sebagai penutup:

Saat memajukan AI. Kami melihat bahwa algoritma tersebut bekerja melalui pencarian brute force dimana Anda berkelana secara acak pada awalnya dan tanpa sengaja harus tersandung pada situasi yang menguntungkan setidaknya sekali, dan idealnya sering dan berulang kali sebelum distribusi kebijakan menggeser parameternya untuk mengulangi tindakan yang bertanggung jawab. Kita juga melihat bahwa manusia mendekati masalah ini dengan sangat berbeda, dalam apa yang terasa lebih mirip bangunan model abstrak yang cepat - sesuatu yang hampir saja kita gores permukaan penelitian (walaupun banyak orang mencoba). Karena model abstrak ini sangat sulit (jika tidak mungkin) untuk secara eksplisit memberi anotasi, inilah mengapa ada begitu banyak minat baru-baru ini dalam model generatif dan induksi program yang tidak diawasi.
Di gunakan di setting robotika yang kompleks. Algoritma ini tidak berskala naif dengan setting dimana eksplorasi dalam jumlah besar sulit didapat. Misalnya, dalam pengaturan robot, seseorang mungkin memiliki robot tunggal (atau sedikit), berinteraksi dengan dunia secara real time. Ini melarang aplikasi algoritma naif karena kami mempresentasikannya di posting ini. Salah satu bidang pekerjaan yang dimaksudkan untuk mengurangi masalah ini adalah gradien kebijakan deterministik - alih-alih mensyaratkan sampel dari kebijakan stokastik dan mendorong yang mendapatkan nilai lebih tinggi, pendekatan menggunakan kebijakan deterministik dan mendapatkan informasi gradien langsung dari jaringan kedua (disebut Seorang kritikus) yang memodelkan fungsi skor. Pendekatan ini pada prinsipnya dapat lebih efisien dalam pengaturan dengan tindakan berdimensi sangat tinggi di mana tindakan pengambilan sampel memberikan cakupan yang buruk, namun sejauh ini tampaknya agak sulit untuk bekerja dengan giat. Pendekatan lain yang terkait adalah meningkatkan robotika, karena kita mulai melihat dengan ladang robot robot milik Google, atau mungkin juga model Tes S + Autopilot Tesla.

Ada juga sederet pekerjaan yang mencoba membuat proses pencarian kurang putus asa dengan menambah pengawasan tambahan. Dalam banyak kasus praktis, misalnya, seseorang dapat memperoleh lintasan ahli dari manusia. Misalnya AlphaGo pertama menggunakan pembelajaran yang diawasi untuk memprediksi pergerakan manusia dari permainan Go yang ahli dan kebijakan menirukan manusia yang dihasilkan kemudian disempurnakan dengan gradien kebijakan pada tujuan "nyata" untuk memenangkan permainan. Dalam beberapa kasus, seseorang mungkin memiliki lebih sedikit lintasan pakar (misalnya dari teleoperasi robot) dan ada teknik untuk memanfaatkan data ini di bawah payung pembelajaran magang. Akhirnya, jika tidak ada data yang diawasi disediakan oleh manusia, hal itu juga dapat dalam beberapa kasus dihitung dengan teknik pengoptimalan yang mahal, mis. Dengan optimasi lintasan dalam model dinamika yang diketahui (seperti F = maF = ma dalam simulator fisik), atau dalam kasus di mana seseorang mempelajari model dinamika lokal perkiraan (seperti yang terlihat pada kerangka Pencarian Kebijakan Terpandu yang sangat menjanjikan).

Saat menggunakan PG dalam praktek. Sebagai catatan terakhir, kami ingin melakukan sesuatu yang kami harap telah kami lakukan di pos blog RNN kami. Kami rasa kami mungkin telah memberi kesan bahwa RNN adalah sihir dan secara otomatis melakukan masalah berurutan yang sewenang-wenang. Yang benar adalah bahwa membuat model ini bekerja dapat menjadi rumit, membutuhkan perawatan dan keahlian, dan dalam banyak kasus juga bisa menjadi berlebihan, di mana metode sederhana bisa membuat Anda 90% + jalan ke sana. Hal yang sama berlaku untuk Gradien Kebijakan. Mereka tidak otomatis: Anda memerlukan banyak sampel, itu akan melatih selamanya, sulit untuk melakukan debug saat tidak bekerja. Kita harus selalu mencoba pistol BB sebelum meraih Bazooka. Dalam kasus Reinforcement Learning misalnya, satu dasar kuat yang harus selalu dicoba terlebih dahulu adalah metode cross-entropy (CEM), pendekatan "tebak dan cek tebakan stokastik yang sederhana yang terinspirasi secara longgar oleh evolusi. Dan jika Anda bersikeras mencoba Gradien Kebijakan untuk masalah Anda, pastikan Anda memperhatikan bagian trik di kertas, mulailah yang sederhana dulu, dan gunakan variasi PG yang disebut TRPO, yang hampir selalu bekerja lebih baik dan lebih konsisten daripada vanilla PG di praktek. Gagasan utamanya adalah untuk menghindari perubahan parameter yang mengubah kebijakan Anda terlalu banyak, karena ditegakkan oleh kendala pada perbedaan KL antara distribusi yang diprediksi oleh kebijakan lama dan baru pada sekumpulan data (bukan gradien konjugasi Instansiasi sederhana dari ini Ide bisa diimplementasikan dengan melakukan pencarian garis dan pengecekan KL di sepanjang jalan).
Karakter/objek pada game pong berbasis arduino.
Spesifikasi sistem yang akan dibuat adalah sebagai berikut:





·         Menggunakan development board Arduino Uno
·         Menggunakan FreeRTOS sebagai operating system pada konsol
·         Menggunakan joystick sebagai input, dimana player menggerakkan joystick ke atas atau ke bawah
·         Menggunakan layar OLED untuk menampilkan game Pong yang dijalankan
·         Permainan terdiri dari dua buah paddle, dimainkan oleh dua orang player, yang saling memantulkan bola, dengan objektif menggolkan bola ke arah lawan sebanyak-banyaknya, ke daerah lawan yang tidak ber-paddle
·         Skor bertambah setiap bola berhasil mencapai daerah lawan
·         Permainan selesai ketika skor salah satu pemain mencapai 10

Mengimplementasikan Mekanisme Karakter Game Pong
Setelah objek muncul, maka kita perlu mengimplementasikan mekanisme dasar game yang kira-kira sebagai berikut:
1.    Objek bola bergerak di koordinat x dan y
2.    Objek player bergerak mengikuti perintah dari joystick
3.    Jika bola menyentuh player, maka ia akan memantul
4.    Jika bola berjalan melewati player, maka bola dikembalikan ke posisi awal dan permainan dimulai lagi
Semua mekanisme ini akan berjalan berulang-ulang selama game dimainkan. Oleh karena itu, ini semua akan dilakukan di dalam fungsi yang belum kita sentuh sebelumnya.

Menampilkan Aset Grafik
Permainan Pong setidaknya membutuhkan 3 aset grafik:
1.    Grafik untuk player 1
2.    Grafik untuk player 2
3.    Grafik untuk bola
Menggunakan aset persegi panjang untuk kedua player, serta sebuah aset titik sebagai grafik untuk bola.



2.    Pemodelan Sistem

Pemodelan sistem dilakukan untuk mempermudah proses desain game sehingga memudahkan pengertian desain yang dirancang. Pemodelan terdiri dari flowchartstate chartcontext diagram, dan data flow diagram.




Gambar 2.1 Context diagram dari game Pong


Terdapat satu buah proses dan tiga buah terminator pada context diagram game Pong dengan masing-masing flow yang menghubungkan terminator dan flow. Terminatornya adalah input dari kedua player dan output di layar OLED, sedangkan prosesornya adalah sistem game Pong tersebut dengan flow antar komponen seperti Gambar 2.1 di atas.

Gambar 2.2 Data flow diagram dari game Pong


Sistem game Pong yang kami rancang memiliki dua buah input dari joystick masing masing playerPlayer mengarahkan joystick ke atas atau ke bawah sesuai keinginan dengan tujuan untuk mengontrol paddle menghindari bola masuk ke daerahnya. Ketika bola mengenai paddle, bola akan memantul, akan tetapi, ketika bola memasuki daerah lawan, skor akan bertambah. Pembacaan dari joystick menghasilkan range angka 0 – 1024, dengan 0 berarti sangat ke bawah, 1024 sangat ke atas, dan 511 dibiarkan di tengah. Prosesor mengambil angka ini dan menerjemahkan range 0 – 510 menjadi player mengarahkan paddle  ke bawah, 512 – 1024 ke atas, dan 511 berarti paddle diam saja.
Output dari proses penggambaran adalah keluaran keseluruhan permainan yang mencakup pergerakan paddle, bola, dan skor.



Gambar 2.3 Flowchart task readJoystick pada game Pong

Task readJoystick berfungsi untuk membaca gerakan yang diberikan player pada penggerak joystickJoystick sendiri adalah resistor pembatas yang dapat memberikan nilai 0 – 1024 pada dua sumbu. Sebelum task dapat diimplementasikan, task ini diinisiasi dengan meng-assign pin dari joystick di Arduino. Jangka nilai dari joysticktersebut, pada mikrokontroler, akan diterjemahkan menjadi perintah ke mikrokontroler.



Gambar 2.4 Flowchart task draw pada game Pong

Pada task ini, layar OLED diinisiasi dengan library U8GLIB yang terdapat di website referensi Arduino. Setelah menginisiasi layar dengan resolusi yang tepat, keluaran dari mikrokontroler akan tampil di layar OLED.
Task draw pada FreeRTOS Arduino diimplementasikan dalam loop do – while. Pertama, base statis dari game digambar pada layar OLED, yaitu garis tengah pembatas area dua player. Selanjutnya, bola berupa piksel juga digambar pada layar OLED, bersama dengan dua paddle player.



Gambar 2.5 Flowchart task drawPlayer pada game Pong

Task drawPlayer1 dan drawPlayer2 berfungsi untuk menggambar paddle kedua player yang dapat digerakkan ke atas dan ke bawah sesuai arahan joystickTask drawPlayer akan diimplementasikan oleh task draw ke layar OLED.

Gambar 2.6 Flowchart task drawBall pada game Pong

Task drawBall berfungsi untuk menggambar bola berupa piksel yang akan memantul jika terkena paddle player dan menambah skor jika memasuki area lawan.

Gambar 2.7 Flowchart task drawCentralLine pada game Pong

Task drawCentralLine berfungsi untuk menggambar garis putus-putus di tengah layar yang membatasi dua area player.
Gambar 2.8 Flowchart game Pong

Ketika sistem mulai dijalankan, dilakukan pendefinisian library, konstanta, dan variabel yang digunakan. Setelah itu, dilakukan pendefinisian variabel dan task yang digunakan untuk membuat task, mengatur task, dan semaphore. Dilakukan inisiasi penggunaan joystick, layar OLED, dan variabel-variabel yang berhubungan dengan game lainnya.
Setelah inisiasi keseluruhan selesai, pada layar OLED digambar dasar permainan, yaitu paddle masing-masing pemain, bola, dan garis pembatas. Masing-masing gambar memiliki task secara independen, yaitu drawPlayer1, drawPlayer2, drawBall, dan drawCentralLine. Fungsi setiap task akan dijelaskan melalui masing-masing flowchart-nya. Untuk menghindari deadlock semua task, dibuat semaphoresebagai tanda pergantian keberjalanan task.

Implementasi Sistem






Algoritma diimplementasikan dengan arsitektur FreeRTOS, sehingga task­task dieksekusi bergantian.
1.    Task draw (ke layar OLED)
Task yang dijalankan secara iteratif ini berfungsi untuk memanggil ketiga task draw lainnya setelah delay-delay yang ditentukan. Sebelum task ini dapat dijalankan, diperlukan inisiasi dengan library U8GLIB yang disesuaikan dengan layar OLED.
2.    Task readJoystick
Task ini akan membaca pergerakan player oleh joystick, menghasilkan angka sebagai masukan, dan mengirim angka tersebut ke mikrokontroler. Oleh mikrokontroler, perintah berupa angka tersebut diterjemahkan sebagai ‘paddle ke atas’ atau ‘paddle ke bawah’.
3.    Task drawCentralLine
Task ini adalah rangkaian piksel yang ditampilkan persis di tengah layar sebagai pembatas area player 1 dengan player 2.
4.    Task drawBall
Task ini akan menggambar sebuah piksel yang berlaku sebagai bola. Bola akan bergerak ke arah paddle player acak pada permulaan permainan. Bola akan memantul jika mengenai paddle player dan akan menambah skor player lawan jika tidak mengenai paddle di areanya.
5.    Task drawPlayer
Task ini akan menggambar dua buah garis, berlaku sebagai paddle untuk memantulkan bola, yang masing-masing dapat dikontrol secara independen oleh dua player melalui dua buah joystick.

4.    Analisis Sistem
Pada proyek ini, shared resources-nya adalah variabel-variabel global untuk masukan dan keluaran. Variabel-variabel tersebut utamanya adalah integer yang akan diisi dengan nilai dari joystick dan akan diteruskan ke layar OLED, integer yang merupakan posisi bola di layar, dan integer posisi paddle di layar.

Karena oleh sistem, masukan dan keluaran dibutuhkan untuk bekerja secara simultan, variabel yang digunakan yang ditempatkan lokal di dalam task akan membutuhkan parameter global untuk kontinuitas perubahan nilainya. Untuk meng-handle shared resources agar tidak terjadi deadlock pada keberjalanan task-task, digunakan semaphore yang diimplementasikan di tiap task.

Tidak ada komentar:

Posting Komentar