CNTK - Konsep Neural Network (NN)
Bab ini membahas konsep Neural Network yang berkaitan dengan CNTK.
Seperti yang kita ketahui, beberapa lapisan neuron digunakan untuk membuat jaringan saraf. Tetapi, muncul pertanyaan bahwa di CNTK bagaimana kita dapat memodelkan lapisan NN? Ini dapat dilakukan dengan bantuan fungsi lapisan yang ditentukan dalam modul lapisan.
Fungsi lapisan
Sebenarnya, di CNTK, bekerja dengan lapisan memiliki nuansa pemrograman fungsional yang berbeda. Fungsi lapisan terlihat seperti fungsi biasa dan menghasilkan fungsi matematika dengan serangkaian parameter yang telah ditentukan. Mari kita lihat bagaimana kita dapat membuat jenis lapisan paling dasar, Dense, dengan bantuan fungsi lapisan.
Contoh
Dengan bantuan langkah-langkah dasar berikut, kita dapat membuat jenis lapisan paling dasar -
Step 1 - Pertama, kita perlu mengimpor fungsi Dense layer dari paket layer CNTK.
from cntk.layers import Dense
Step 2 - Selanjutnya dari paket root CNTK, kita perlu mengimpor fungsi input_variable.
from cntk import input_variable
Step 3- Sekarang, kita perlu membuat variabel input baru menggunakan fungsi input_variable. Kami juga perlu memberikan ukurannya.
feature = input_variable(100)
Step 4 - Terakhir, kita akan membuat layer baru menggunakan fungsi Dense bersamaan dengan memberikan jumlah neuron yang kita inginkan.
layer = Dense(40)(feature)
Sekarang, kita dapat menjalankan fungsi Dense layer yang telah dikonfigurasi untuk menghubungkan layer Dense ke input.
Contoh implementasi lengkap
from cntk.layers import Dense
from cntk import input_variable
feature= input_variable(100)
layer = Dense(40)(feature)
Menyesuaikan lapisan
Seperti yang telah kita lihat, CNTK memberi kita satu set default yang cukup bagus untuk membangun NN. Berdasarkanactivationfungsi dan pengaturan lain yang kami pilih, perilaku serta kinerja NN berbeda. Ini adalah algoritma stemming yang sangat berguna. Itulah alasannya, ada baiknya untuk memahami apa yang dapat kita konfigurasi.
Langkah-langkah untuk mengkonfigurasi lapisan padat
Setiap lapisan di NN memiliki opsi konfigurasi yang unik dan ketika kita berbicara tentang lapisan Dense, kita harus mengikuti pengaturan penting berikut ini -
shape - Sesuai namanya, ini mendefinisikan bentuk keluaran dari lapisan yang selanjutnya menentukan jumlah neuron di lapisan itu.
activation - Ini mendefinisikan fungsi aktivasi lapisan itu, sehingga dapat mengubah data masukan.
init- Ini mendefinisikan fungsi inisialisasi lapisan itu. Ini akan menginisialisasi parameter lapisan saat kita mulai melatih NN.
Mari kita lihat langkah-langkah dengan bantuan yang dapat kita konfigurasikan Dense lapisan -
Step1 - Pertama, kita perlu mengimpor file Dense fungsi lapisan dari paket lapisan CNTK.
from cntk.layers import Dense
Step2 - Selanjutnya dari paket operasi CNTK, kita perlu mengimpor file sigmoid operator. Ini akan digunakan untuk mengkonfigurasi sebagai fungsi aktivasi.
from cntk.ops import sigmoid
Step3 - Sekarang, dari paket penginisialisasi, kita perlu mengimpor file glorot_uniform penginisialisasi.
from cntk.initializer import glorot_uniform
Step4 - Terakhir, kita akan membuat layer baru menggunakan fungsi Dense beserta jumlah neuron sebagai argumen pertama. Juga, sediakansigmoid operator sebagai activation fungsi dan glorot_uniform sebagai init berfungsi untuk lapisan.
layer = Dense(50, activation = sigmoid, init = glorot_uniform)
Contoh implementasi lengkap -
from cntk.layers import Dense
from cntk.ops import sigmoid
from cntk.initializer import glorot_uniform
layer = Dense(50, activation = sigmoid, init = glorot_uniform)
Mengoptimalkan parameter
Hingga saat ini, kita telah melihat bagaimana membuat struktur NN dan bagaimana mengkonfigurasi berbagai pengaturan. Di sini, kita akan melihat, bagaimana kita dapat mengoptimalkan parameter NN. Dengan bantuan kombinasi dua komponen yaitulearners dan trainers, kita dapat mengoptimalkan parameter NN.
komponen pelatih
Komponen pertama yang digunakan untuk mengoptimalkan parameter NN adalah trainerkomponen. Ini pada dasarnya mengimplementasikan proses propagasi mundur. Jika kita berbicara tentang kerjanya, ia melewatkan data melalui NN untuk mendapatkan prediksi.
Setelah itu, ia menggunakan komponen lain yang disebut pelajar untuk mendapatkan nilai baru untuk parameter di NN. Setelah memperoleh nilai baru, ia menerapkan nilai baru ini dan mengulangi proses sampai kriteria keluar terpenuhi.
komponen pelajar
Komponen kedua yang digunakan untuk mengoptimalkan parameter NN adalah learner komponen, yang pada dasarnya bertanggung jawab untuk melakukan algoritma penurunan gradien.
Peserta didik termasuk dalam perpustakaan CNTK
Berikut adalah daftar dari beberapa pembelajar menarik yang termasuk dalam perpustakaan CNTK -
Stochastic Gradient Descent (SGD) - Peserta ini mewakili penurunan gradien stokastik dasar, tanpa tambahan apa pun.
Momentum Stochastic Gradient Descent (MomentumSGD) - Dengan SGD, pembelajar ini memanfaatkan momentum untuk mengatasi masalah maxima lokal.
RMSProp - Pelajar ini, untuk mengontrol laju penurunan, menggunakan laju pembelajaran yang menurun.
Adam - Pelajar ini, untuk mengurangi laju penurunan dari waktu ke waktu, menggunakan momentum yang membusuk.
Adagrad - Pelajar ini, untuk fitur yang sering dan jarang muncul, menggunakan kecepatan pembelajaran yang berbeda.