CNTK - Sinir Ağının Eğitimi

Burada Sinir Ağının CNTK'da eğitimini anlayacağız.

CNTK'da model yetiştirme

Önceki bölümde, derin öğrenme modeli için tüm bileşenleri tanımladık. Şimdi onu eğitme zamanı. Daha önce tartıştığımız gibi, CNTK'da bir NN modelini aşağıdakilerin kombinasyonunu kullanarak eğitebiliriz:learner ve trainer.

Bir öğrenci seçme ve eğitim kurma

Bu bölümde, tanımlayacağız learner. CNTK birkaç sağlarlearnersndan şeçmek. Önceki bölümlerde tanımladığımız modelimiz için kullanacağızStochastic Gradient Descent (SGD) learner.

Sinir ağını eğitmek için, learner ve trainer aşağıdaki adımların yardımıyla -

Step 1 - Öncelikle ithalat yapmamız gerekiyor sgd işlevi cntk.lerners paketi.

from cntk.learners import sgd

Step 2 - Sonra, içe aktarmamız gerekiyor Trainer işlevi cntk.train.trainer paketi.

from cntk.train.trainer import Trainer

Step 3 - Şimdi, bir learner. Çağrılarak oluşturulabilirsgd modelin parametreleri ve öğrenme oranı için bir değer sağlamakla birlikte işlev görür.

learner = sgd(z.parametrs, 0.01)

Step 4 - Sonunda, trainer. Ağın,loss ve metric ile birlikte learner.

trainer = Trainer(z, (loss, error_rate), [learner])

Optimizasyon hızını kontrol eden öğrenme oranı 0.1 ile 0.001 arasında küçük bir sayı olmalıdır.

Bir öğrenci seçme ve eğitimi ayarlama - Tam örnek

from cntk.learners import sgd
from cntk.train.trainer import Trainer
learner = sgd(z.parametrs, 0.01)
trainer = Trainer(z, (loss, error_rate), [learner])

Verileri eğitmene besleme

Eğiticiyi seçip yapılandırdıktan sonra, veri kümesini yükleme zamanı gelmiştir. Kurtardıkiris veri kümesi olarak.CSV dosya ve adlı veri düzenleme paketini kullanacağız. pandas Veri kümesini yüklemek için.

Veri kümesini .CSV dosyasından yükleme adımları

Step 1 - Öncelikle, pandas paketi.

from import pandas as pd

Step 2 - Şimdi, isimli işlevi çağırmamız gerekiyor read_csv .csv dosyasını diskten yükleme işlevi.

df_source = pd.read_csv(‘iris.csv’, names = [‘sepal_length’, ‘sepal_width’, 
‘petal_length’, ‘petal_width’, index_col=False)

Veri kümesini yükledikten sonra, onu bir dizi özelliğe ve bir etikete bölmemiz gerekir.

Veri kümesini özelliklere ve etikete bölme adımları

Step 1- Öncelikle, veri kümesinden tüm satırları ve ilk dört sütunu seçmemiz gerekir. Kullanılarak yapılabiliriloc işlevi.

x = df_source.iloc[:, :4].values

Step 2- Daha sonra iris veri kümesinden tür sütununu seçmemiz gerekiyor. Temel değerlere erişmek için values ​​özelliğini kullanacağız.numpy dizi.

x = df_source[‘species’].values

Türler sütununu sayısal vektör gösterimine kodlama adımları

Daha önce tartıştığımız gibi, modelimiz sınıflandırmaya dayalıdır, sayısal girdi değerleri gerektirir. Bu nedenle, burada tür sütununu sayısal bir vektör gösterimine kodlamamız gerekir. Bunu yapmak için gereken adımları görelim -

Step 1- İlk olarak, dizideki tüm öğeleri yinelemek için bir liste ifadesi oluşturmamız gerekir. Ardından, her değer için label_mapping sözlüğünde bir arama yapın.

label_mapping = {‘Iris-Setosa’ : 0, ‘Iris-Versicolor’ : 1, ‘Iris-Virginica’ : 2}

Step 2- Daha sonra, dönüştürülen bu sayısal değeri tek etkin kodlanmış vektöre dönüştürün. Kullanacağızone_hot aşağıdaki gibi işlev -

def one_hot(index, length):
result = np.zeros(length)
result[index] = 1
return result

Step 3 - Sonunda, bu dönüştürülmüş listeyi bir numpy dizi.

y = np.array([one_hot(label_mapping[v], 3) for v in y])

Aşırı oturmayı tespit etmek için adımlar

Modeliniz örnekleri hatırladığında, ancak eğitim örneklerinden kuralları çıkaramadığında durum fazlasıyla uyumludur. Aşağıdaki adımların yardımıyla, modelimizdeki aşırı uyumu tespit edebiliriz -

Step 1 - İlk olarak sklearn paketi içe aktar train_test_split işlevinden model_selection modül.

from sklearn.model_selection import train_test_split

Step 2 - Sonra, x özellikleri ve y etiketleri ile train_test_split işlevini aşağıdaki gibi çağırmamız gerekir -

x_train, x_test, y_train, y_test = train_test_split(X, y, test_size=0-2, 
stratify=y)

Toplam verilerin% 20'sini bir kenara koymak için test_size olarak 0,2 belirledik.

label_mapping = {‘Iris-Setosa’ : 0, ‘Iris-Versicolor’ : 1, ‘Iris-Virginica’ : 2}

Modelimize eğitim seti ve doğrulama seti besleme adımları

Step 1 - Modelimizi eğitmek için önce, train_minibatchyöntem. Ardından, giriş verilerini NN'yi ve onun ilişkili kayıp işlevini tanımlamak için kullandığımız giriş değişkeniyle eşleştiren bir sözlük verin.

trainer.train_minibatch({ features: X_train, label: y_train})

Step 2 - Sonra, ara train_minibatch aşağıdaki for döngüsünü kullanarak -

for _epoch in range(10):
trainer.train_minbatch ({ feature: X_train, label: y_train})
print(‘Loss: {}, Acc: {}’.format(
trainer.previous_minibatch_loss_average,
trainer.previous_minibatch_evaluation_average))

Verileri eğitmene besleme - Tam örnek

from import pandas as pd
df_source = pd.read_csv(‘iris.csv’, names = [‘sepal_length’, ‘sepal_width’, ‘petal_length’, ‘petal_width’, index_col=False)
x = df_source.iloc[:, :4].values
x = df_source[‘species’].values
label_mapping = {‘Iris-Setosa’ : 0, ‘Iris-Versicolor’ : 1, ‘Iris-Virginica’ : 2}
def one_hot(index, length):
result = np.zeros(length)
result[index] = 1
return result
y = np.array([one_hot(label_mapping[v], 3) for v in y])
from sklearn.model_selection import train_test_split
x_train, x_test, y_train, y_test = train_test_split(X, y, test_size=0-2, stratify=y)
label_mapping = {‘Iris-Setosa’ : 0, ‘Iris-Versicolor’ : 1, ‘Iris-Virginica’ : 2}
trainer.train_minibatch({ features: X_train, label: y_train})
for _epoch in range(10):
trainer.train_minbatch ({ feature: X_train, label: y_train})
print(‘Loss: {}, Acc: {}’.format(
trainer.previous_minibatch_loss_average,
trainer.previous_minibatch_evaluation_average))

NN'nin performansını ölçme

NN modelimizi optimize etmek için, eğiticiden her veri ilettiğimizde, modelin performansını eğitmen için yapılandırdığımız metrik üzerinden ölçer. Eğitim sırasında NN modelinin bu tür performans ölçümü eğitim verilerindedir. Öte yandan, model performansının tam bir analizi için test verilerini de kullanmamız gerekir.

Bu nedenle, test verilerini kullanarak modelin performansını ölçmek için, test_minibatch yöntemi trainer aşağıdaki gibi -

trainer.test_minibatch({ features: X_test, label: y_test})

NN ile tahmin yapmak

Bir derin öğrenme modeli eğittikten sonra, en önemli şey, onu kullanarak tahminler yapmaktır. Yukarıdaki eğitimli NN'den tahmin yapmak için verilen adımları takip edebiliriz−

Step 1 - Öncelikle, aşağıdaki işlevi kullanarak test setinden rastgele bir öğe seçmemiz gerekir -

np.random.choice

Step 2 - Daha sonra, test setinden örnek verileri kullanarak seçmemiz gerekir. sample_index.

Step 3 - Şimdi, sayısal çıktıyı NN'ye gerçek bir etikete dönüştürmek için tersine çevrilmiş bir eşleme oluşturun.

Step 4 - Şimdi seçili olanı kullanın sampleveri. NN z'yi bir işlev olarak çağırarak bir tahmin yapın.

Step 5- Şimdi, tahmin edilen çıktıyı aldığınızda, tahmin edilen değer olarak en yüksek değere sahip nöronun indeksini alın. Kullanılarak yapılabilirnp.argmax işlevinden numpy paketi.

Step 6 - Sonunda, dizin değerini kullanarak gerçek etikete dönüştürün. inverted_mapping.

NN ile tahmin yapmak - Tam örnek

sample_index = np.random.choice(X_test.shape[0])
sample = X_test[sample_index]
inverted_mapping = {
   1:’Iris-setosa’,
   2:’Iris-versicolor’,
   3:’Iris-virginica’
}
prediction = z(sample)
predicted_label = inverted_mapping[np.argmax(prediction)]
print(predicted_label)

Çıktı

Yukarıdaki derin öğrenme modelini eğitip çalıştırdıktan sonra, aşağıdaki çıktıyı alacaksınız -

Iris-versicolor