AI dengan Python - Deep Learning

Artificial Neural Network (ANN) adalah sistem komputasi yang efisien, yang tema utamanya dipinjam dari analogi jaringan saraf biologis. Jaringan saraf adalah salah satu jenis model untuk pembelajaran mesin. Pada pertengahan 1980-an dan awal 1990-an, banyak kemajuan arsitektur yang penting dibuat dalam jaringan saraf. Di bab ini, Anda akan mempelajari lebih lanjut tentang Pembelajaran Mendalam, sebuah pendekatan AI.

Pembelajaran mendalam muncul dari pertumbuhan komputasi yang eksplosif selama satu dekade sebagai pesaing serius di lapangan. Dengan demikian, pembelajaran dalam adalah jenis pembelajaran mesin tertentu yang algoritmanya terinspirasi oleh struktur dan fungsi otak manusia.

Pembelajaran Mesin v / s Deep Learning

Pembelajaran mendalam adalah teknik pembelajaran mesin paling kuat saat ini. Ini sangat kuat karena mereka belajar cara terbaik untuk merepresentasikan masalah sambil belajar bagaimana memecahkan masalah. Perbandingan pembelajaran mendalam dan pembelajaran mesin diberikan di bawah ini -

Ketergantungan Data

Titik perbedaan pertama didasarkan pada performa DL dan ML saat skala data meningkat. Jika datanya besar, algoritme pembelajaran mendalam bekerja dengan sangat baik.

Ketergantungan Mesin

Algoritme pembelajaran mendalam membutuhkan mesin kelas atas untuk bekerja dengan sempurna. Di sisi lain, algoritme pembelajaran mesin juga dapat berfungsi pada mesin kelas bawah.

Ekstraksi Fitur

Algoritme pembelajaran mendalam dapat mengekstrak fitur tingkat tinggi dan mencoba belajar dari fitur yang sama juga. Di sisi lain, diperlukan seorang pakar untuk mengidentifikasi sebagian besar fitur yang diekstrak oleh pembelajaran mesin.

Waktu Eksekusi

Waktu eksekusi tergantung pada banyak parameter yang digunakan dalam suatu algoritma. Pembelajaran mendalam memiliki lebih banyak parameter daripada algoritma pembelajaran mesin. Oleh karena itu, waktu eksekusi algoritma DL, khususnya waktu pelatihan, jauh lebih banyak daripada algoritma ML. Tetapi waktu pengujian algoritma DL kurang dari algoritma ML.

Pendekatan Pemecahan Masalah

Pembelajaran mendalam memecahkan masalah secara menyeluruh, sedangkan pembelajaran mesin menggunakan cara tradisional untuk memecahkan masalah, yaitu dengan memecahnya menjadi beberapa bagian.

Jaringan Neural Konvolusional (CNN)

Jaringan saraf konvolusional sama dengan jaringan saraf biasa karena jaringan tersebut juga terdiri dari neuron yang memiliki bobot dan bias yang dapat dipelajari. Jaringan saraf biasa mengabaikan struktur data masukan dan semua data diubah menjadi larik 1-D sebelum memasukkannya ke dalam jaringan. Proses ini sesuai dengan data biasa, namun jika data tersebut berisi gambar, proses tersebut mungkin akan merepotkan.

CNN memecahkan masalah ini dengan mudah. Ini memperhitungkan struktur 2D gambar saat mereka memprosesnya, yang memungkinkan mereka mengekstrak properti khusus untuk gambar. Dengan cara ini, tujuan utama CNN adalah beralih dari data gambar mentah di lapisan masukan ke kelas yang benar di lapisan keluaran. Satu-satunya perbedaan antara NN biasa dan CNN adalah dalam perlakuan data masukan dan jenis lapisan.

Tinjauan Arsitektur CNN

Secara arsitektural, jaringan saraf biasa menerima masukan dan mengubahnya melalui serangkaian lapisan tersembunyi. Setiap lapisan terhubung ke lapisan lain dengan bantuan neuron. Kerugian utama dari jaringan neural biasa adalah jaringan tersebut tidak diskalakan dengan baik ke gambar penuh.

Arsitektur CNN memiliki neuron yang tersusun dalam 3 dimensi yang disebut lebar, tinggi dan kedalaman. Setiap neuron di lapisan saat ini terhubung ke patch kecil keluaran dari lapisan sebelumnya. Ini mirip dengan overlay a×filter pada gambar masukan. Itu menggunakanMfilter untuk memastikan mendapatkan semua detail. IniM Filter adalah ekstraktor fitur yang mengekstrak fitur seperti tepi, sudut, dll.

Lapisan yang digunakan untuk membuat CNN

Lapisan berikut digunakan untuk membuat CNN -

  • Input Layer - Dibutuhkan data gambar mentah sebagaimana adanya.

  • Convolutional Layer- Lapisan ini adalah blok pembangun inti CNN yang melakukan sebagian besar komputasi. Lapisan ini menghitung konvolusi antara neuron dan berbagai tambalan di masukan.

  • Rectified Linear Unit Layer- Ini menerapkan fungsi aktivasi ke output dari lapisan sebelumnya. Ini menambahkan non-linearitas ke jaringan sehingga dapat menggeneralisasi dengan baik ke semua jenis fungsi.

  • Pooling Layer- Pooling membantu kita mempertahankan hanya bagian-bagian penting saat kita maju dalam jaringan. Lapisan penggabungan beroperasi secara independen pada setiap potongan kedalaman masukan dan mengubah ukurannya secara spasial. Ini menggunakan fungsi MAX.

  • Fully Connected layer/Output layer - Lapisan ini menghitung skor keluaran di lapisan terakhir. Output yang dihasilkan adalah ukurannya×× , dengan L adalah kelas set data pelatihan angka.

Menginstal Paket Python yang Berguna

Kamu dapat memakai Keras, yang merupakan API jaringan neural level tinggi, ditulis dengan Python dan mampu berjalan di atas TensorFlow, CNTK, atau Theno. Ini kompatibel dengan Python 2.7-3.6. Anda dapat mempelajarinya lebih lanjut darihttps://keras.io/.

Gunakan perintah berikut untuk menginstal keras -

pip install keras

Di conda lingkungan, Anda dapat menggunakan perintah berikut -

conda install –c conda-forge keras

Membangun Regresor Linier menggunakan ANN

Di bagian ini, Anda akan mempelajari cara membuat regressor linier menggunakan jaringan saraf tiruan. Kamu dapat memakaiKerasRegressoruntuk mencapai ini. Dalam contoh ini, kami menggunakan kumpulan data harga rumah Boston dengan 13 numerik untuk properti di Boston. Kode Python untuk hal yang sama ditampilkan di sini -

Impor semua paket yang diperlukan seperti yang ditunjukkan -

import numpy
import pandas
from keras.models import Sequential
from keras.layers import Dense
from keras.wrappers.scikit_learn import KerasRegressor
from sklearn.model_selection import cross_val_score
from sklearn.model_selection import KFold

Sekarang, muat dataset kami yang disimpan di direktori lokal.

dataframe = pandas.read_csv("/Usrrs/admin/data.csv", delim_whitespace = True, header = None)
dataset = dataframe.values

Sekarang, bagi data menjadi variabel input dan output yaitu X dan Y -

X = dataset[:,0:13]
Y = dataset[:,13]

Karena kami menggunakan jaringan saraf dasar, tentukan modelnya -

def baseline_model():

Sekarang, buat model sebagai berikut -

model_regressor = Sequential()
model_regressor.add(Dense(13, input_dim = 13, kernel_initializer = 'normal', 
   activation = 'relu'))
model_regressor.add(Dense(1, kernel_initializer = 'normal'))

Selanjutnya, kompilasi model -

model_regressor.compile(loss='mean_squared_error', optimizer='adam')
return model_regressor

Sekarang, perbaiki benih acak untuk reproduktifitas sebagai berikut -

seed = 7
numpy.random.seed(seed)

Objek Keras wrapper untuk digunakan di scikit-learn sebagai penaksir regresi disebut KerasRegressor. Pada bagian ini, kita akan mengevaluasi model ini dengan kumpulan data standar.

estimator = KerasRegressor(build_fn = baseline_model, nb_epoch = 100, batch_size = 5, verbose = 0)
kfold = KFold(n_splits = 10, random_state = seed)
baseline_result = cross_val_score(estimator, X, Y, cv = kfold)
print("Baseline: %.2f (%.2f) MSE" % (Baseline_result.mean(),Baseline_result.std()))

Output dari kode yang ditunjukkan di atas akan menjadi perkiraan kinerja model pada masalah data yang tidak terlihat. Ini akan menjadi kesalahan kuadrat rata-rata, termasuk rata-rata dan deviasi standar di semua 10 lipatan evaluasi validasi silang.

Pengklasifikasi Gambar: Aplikasi Pembelajaran Mendalam

Convolutional Neural Networks (CNNs) memecahkan masalah klasifikasi citra, yaitu milik kelas mana citra masukan tersebut. Anda dapat menggunakan pustaka deep learning Keras. Perhatikan bahwa kami menggunakan kumpulan data pelatihan dan pengujian gambar kucing dan anjing dari tautan berikuthttps://www.kaggle.com/c/dogs-vs-cats/data.

Impor pustaka dan paket keras yang penting seperti yang ditunjukkan -

Paket berikut yang disebut sekuensial akan menginisialisasi jaringan saraf sebagai jaringan sekuensial.

from keras.models import Sequential

Paket berikut disebut Conv2D digunakan untuk melakukan operasi konvolusi, langkah pertama CNN.

from keras.layers import Conv2D

Paket berikut disebut MaxPoling2D digunakan untuk melakukan operasi penggabungan, langkah kedua dari CNN.

from keras.layers import MaxPooling2D

Paket berikut disebut Flatten adalah proses mengubah semua larik 2D yang dihasilkan menjadi satu vektor linier kontinu panjang tunggal.

from keras.layers import Flatten

Paket berikut disebut Dense digunakan untuk melakukan koneksi penuh dari jaringan saraf, langkah keempat CNN.

from keras.layers import Dense

Sekarang, buat objek dari kelas sekuensial.

S_classifier = Sequential()

Sekarang, langkah selanjutnya adalah mengkodekan bagian konvolusi.

S_classifier.add(Conv2D(32, (3, 3), input_shape = (64, 64, 3), activation = 'relu'))

Sini relu adalah fungsi penyearah.

Sekarang, langkah CNN selanjutnya adalah operasi penggabungan pada peta fitur yang dihasilkan setelah bagian konvolusi.

S-classifier.add(MaxPooling2D(pool_size = (2, 2)))

Sekarang, ubah semua gambar yang dikumpulkan menjadi vektor kontinu dengan menggunakan penyanjung -

S_classifier.add(Flatten())

Selanjutnya, buat lapisan yang sepenuhnya terhubung.

S_classifier.add(Dense(units = 128, activation = 'relu'))

Di sini, 128 adalah jumlah unit tersembunyi. Ini adalah praktik umum untuk menentukan jumlah unit tersembunyi sebagai pangkat 2.

Sekarang, inisialisasi lapisan keluaran sebagai berikut -

S_classifier.add(Dense(units = 1, activation = 'sigmoid'))

Sekarang, kompilasi CNN, kami telah membangun -

S_classifier.compile(optimizer = 'adam', loss = 'binary_crossentropy', metrics = ['accuracy'])

Di sini parameter pengoptimal adalah memilih algoritme penurunan gradien stokastik, parameter kerugian untuk memilih fungsi kerugian dan parameter metrik untuk memilih metrik kinerja.

Sekarang, lakukan penambahan gambar lalu paskan gambar ke jaringan saraf -

train_datagen = ImageDataGenerator(rescale = 1./255,shear_range = 0.2,
zoom_range = 0.2,
horizontal_flip = True)
test_datagen = ImageDataGenerator(rescale = 1./255)

training_set = 
   train_datagen.flow_from_directory(”/Users/admin/training_set”,target_size = 
      (64, 64),batch_size = 32,class_mode = 'binary')

test_set = 
   test_datagen.flow_from_directory('test_set',target_size = 
      (64, 64),batch_size = 32,class_mode = 'binary')

Sekarang, paskan datanya dengan model yang telah kita buat -

classifier.fit_generator(training_set,steps_per_epoch = 8000,epochs = 
25,validation_data = test_set,validation_steps = 2000)

Di sini steps_per_epoch memiliki jumlah gambar pelatihan.

Sekarang setelah model dilatih, kita dapat menggunakannya untuk prediksi sebagai berikut -

from keras.preprocessing import image

test_image = image.load_img('dataset/single_prediction/cat_or_dog_1.jpg', 
target_size = (64, 64))

test_image = image.img_to_array(test_image)

test_image = np.expand_dims(test_image, axis = 0)

result = classifier.predict(test_image)

training_set.class_indices

if result[0][0] == 1:
prediction = 'dog'

else:
   prediction = 'cat'