Deep Learning dengan Keras - Deep Learning
Seperti yang dikatakan dalam pendahuluan, pembelajaran dalam adalah proses melatih jaringan saraf tiruan dengan sejumlah besar data. Setelah dilatih, jaringan akan dapat memberi kami prediksi pada data yang tidak terlihat. Sebelum saya menjelaskan lebih jauh tentang apa itu pembelajaran dalam, mari kita bahas beberapa istilah yang digunakan dalam melatih jaringan saraf.
Jaringan Neural
Ide jaringan saraf tiruan berasal dari jaringan saraf di otak kita. Jaringan saraf tipikal terdiri dari tiga lapisan - input, output, dan lapisan tersembunyi seperti yang ditunjukkan pada gambar di bawah ini.
Ini juga disebut a shallowjaringan saraf, karena hanya berisi satu lapisan tersembunyi. Anda menambahkan lebih banyak lapisan tersembunyi pada arsitektur di atas untuk membuat arsitektur yang lebih kompleks.
Jaringan Dalam
Diagram berikut menunjukkan jaringan dalam yang terdiri dari empat lapisan tersembunyi, lapisan masukan, dan lapisan keluaran.
Karena jumlah lapisan tersembunyi ditambahkan ke jaringan, pelatihannya menjadi lebih kompleks dalam hal sumber daya yang diperlukan dan waktu yang diperlukan untuk melatih jaringan sepenuhnya.
Pelatihan Jaringan
Setelah Anda menentukan arsitektur jaringan, Anda melatihnya untuk melakukan jenis prediksi tertentu. Melatih jaringan adalah proses menemukan bobot yang tepat untuk setiap tautan di jaringan. Selama pelatihan, data mengalir dari lapisan Input ke Output melalui berbagai lapisan tersembunyi. Karena data selalu bergerak dalam satu arah dari input ke output, kami menyebut jaringan ini sebagai Jaringan Umpan-maju dan kami menyebut propagasi data sebagai Propagasi Teruskan.
Fungsi Aktivasi
Di setiap lapisan, kami menghitung jumlah masukan yang dibobot dan memasukkannya ke fungsi Aktivasi. Fungsi aktivasi membawa nonlinier ke jaringan. Ini hanyalah beberapa fungsi matematika yang membedakan keluaran. Beberapa fungsi aktivasi yang paling umum digunakan adalah sigmoid, hiperbolik, tangen (tanh), ReLU dan Softmax.
Propagasi mundur
Propagasi mundur adalah algoritme untuk pembelajaran yang diawasi. Dalam Backpropagation, kesalahan menyebar ke belakang dari output ke lapisan input. Diberikan fungsi kesalahan, kami menghitung gradien fungsi kesalahan sehubungan dengan bobot yang ditetapkan pada setiap koneksi. Perhitungan hasil gradien mundur melalui jaringan. Gradien dari lapisan bobot terakhir dihitung pertama dan gradien dari bobot lapisan pertama dihitung terakhir.
Pada setiap lapisan, penghitungan sebagian dari gradien digunakan kembali dalam penghitungan gradien untuk lapisan sebelumnya. Ini disebut Gradient Descent.
Dalam tutorial berbasis proyek ini Anda akan menentukan jaringan neural dalam umpan-maju dan melatihnya dengan teknik propagasi mundur dan penurunan gradien. Untungnya, Keras memberi kita semua API tingkat tinggi untuk menentukan arsitektur jaringan dan melatihnya menggunakan penurunan gradien. Selanjutnya, Anda akan mempelajari cara melakukan ini di Keras.
Sistem Pengenalan Digit Tulisan Tangan
Dalam proyek mini ini, Anda akan menerapkan teknik yang dijelaskan sebelumnya. Anda akan membuat jaringan saraf pembelajaran mendalam yang akan dilatih untuk mengenali angka tulisan tangan. Dalam proyek pembelajaran mesin apa pun, tantangan pertama adalah mengumpulkan data. Terutama, untuk jaringan pembelajaran yang dalam, Anda membutuhkan data yang sangat banyak. Untungnya, untuk masalah yang kami coba selesaikan, seseorang telah membuat kumpulan data untuk pelatihan. Ini disebut mnist, yang tersedia sebagai bagian dari pustaka Keras. Dataset terdiri dari beberapa gambar 28x28 piksel dengan digit tulisan tangan. Anda akan melatih model Anda pada bagian utama dari kumpulan data ini dan data lainnya akan digunakan untuk memvalidasi model terlatih Anda.
Deskripsi Proyek
Itu mnistdataset terdiri dari 70000 gambar digit tulisan tangan. Beberapa gambar contoh direproduksi di sini untuk referensi Anda
Setiap gambar berukuran 28 x 28 piksel sehingga menjadi total 768 piksel dengan berbagai tingkat skala abu-abu. Sebagian besar piksel cenderung ke arah bayangan hitam sementara hanya sedikit yang berwarna putih. Kami akan menempatkan distribusi piksel ini dalam sebuah array atau vektor. Misalnya, distribusi piksel untuk gambar tipikal dari angka 4 dan 5 ditunjukkan pada gambar di bawah ini.
Setiap gambar berukuran 28 x 28 piksel sehingga menjadi total 768 piksel dengan berbagai tingkat skala abu-abu. Sebagian besar piksel cenderung ke arah bayangan hitam sementara hanya sedikit yang berwarna putih. Kami akan menempatkan distribusi piksel ini dalam sebuah array atau vektor. Misalnya, distribusi piksel untuk gambar tipikal dari angka 4 dan 5 ditunjukkan pada gambar di bawah ini.
Jelas, Anda dapat melihat bahwa distribusi piksel (terutama yang cenderung ke arah warna putih) berbeda, ini membedakan digit yang diwakilinya. Kami akan memasukkan distribusi 784 piksel ini ke jaringan kami sebagai inputnya. Output jaringan akan terdiri dari 10 kategori yang mewakili digit antara 0 dan 9.
Jaringan kita akan terdiri dari 4 lapisan - satu lapisan masukan, satu lapisan keluaran, dan dua lapisan tersembunyi. Setiap lapisan tersembunyi akan berisi 512 node. Setiap lapisan terhubung sepenuhnya ke lapisan berikutnya. Saat kami melatih jaringan, kami akan menghitung bobot untuk setiap koneksi. Kami melatih jaringan dengan menerapkan backpropagation dan gradient descent yang telah kita bahas sebelumnya.