CNTK - Sınıflandırma Modeli

Bu bölüm, CNTK'da sınıflandırma modelinin performansının nasıl ölçüleceğini anlamanıza yardımcı olacaktır. Karışıklık matrisi ile başlayalım.

Karışıklık matrisi

Karışıklık matrisi - tahmin edilen çıktıya karşılık beklenen çıktıya sahip bir tablo, çıktının iki veya daha fazla sınıf türünden olabileceği bir sınıflandırma probleminin performansını ölçmenin en kolay yoludur.

Nasıl çalıştığını anlamak için, bir kredi kartı işleminin normal mi yoksa sahtekarlık mı olduğunu tahmin eden ikili sınıflandırma modeli için bir kafa karışıklığı matrisi oluşturacağız. Aşağıdaki gibi gösterilmiştir -

Gerçek dolandırıcılık Gerçek normal

Predicted fraud

Gerçek pozitif

Yanlış pozitif

Predicted normal

Yanlış negatif

Gerçek negatif

Gördüğümüz gibi, yukarıdaki örnek karışıklık matrisi, biri sınıf dolandırıcılığı ve diğeri normal sınıf için olmak üzere 2 sütun içerir. Aynı şekilde 2 satırımız var, biri sınıf dolandırıcılığı için, diğeri sınıf normal için ekleniyor. Karışıklık matrisi ile ilgili terimlerin açıklaması aşağıdadır -

  • True Positives - Hem gerçek sınıf hem de tahmin edilen veri noktası sınıfı 1 olduğunda.

  • True Negatives - Hem gerçek sınıf hem de tahmin edilen veri noktası sınıfı 0 olduğunda.

  • False Positives - Gerçek veri noktası sınıfı 0 olduğunda ve tahmin edilen veri noktası sınıfı 1 olduğunda.

  • False Negatives - Gerçek veri noktası sınıfı 1 olduğunda ve tahmin edilen veri noktası sınıfı 0 olduğunda.

Bakalım, karışıklık matrisinden farklı şeylerin sayısını nasıl hesaplayabiliriz -

  • Accuracy- Makine öğrenimi sınıflandırma modelimiz tarafından yapılan doğru tahminlerin sayısıdır. Aşağıdaki formül yardımıyla hesaplanabilir -

  • Precision− Tahmin ettiğimiz tüm örneklerden kaç tane örneğin doğru tahmin edildiğini bize söyler. Aşağıdaki formül yardımı ile hesaplanabilir -

  • Recall or Sensitivity- Geri çağırma, makine öğrenimi sınıflandırma modelimiz tarafından döndürülen pozitiflerin sayısıdır. Diğer bir deyişle, model tarafından veri setindeki dolandırıcılık vakalarının kaç tanesinin gerçekte tespit edildiğini söyler. Aşağıdaki formül yardımıyla hesaplanabilir -

  • Specificity- Geri çağırmanın aksine, ML sınıflandırma modelimiz tarafından döndürülen negatiflerin sayısını verir. Aşağıdaki formül yardımıyla hesaplanabilir -

F ölçüsü

F-ölçüsünü Confusion matrix'e alternatif olarak kullanabiliriz. Bunun arkasındaki ana sebep, Geri Çağırma ve Hassasiyeti aynı anda maksimize edemeyiz. Bu ölçümler arasında çok güçlü bir ilişki vardır ve bu, aşağıdaki örnek yardımıyla anlaşılabilir -

Hücre örneklerini kanserli veya normal olarak sınıflandırmak için bir DL modeli kullanmak istediğimizi varsayalım. Burada, maksimum kesinliğe ulaşmak için tahmin sayısını 1'e düşürmemiz gerekiyor. Yine de, bu bize yaklaşık yüzde 100 kesinlik sağlayabilir, ancak geri çağırma gerçekten düşük olacaktır.

Öte yandan, maksimum hatırlamaya ulaşmak istiyorsak, mümkün olduğunca çok tahmin yapmamız gerekir. Bununla birlikte, bu bize yaklaşık yüzde 100 geri çağırma ulaşmamızı sağlayabilir, ancak hassasiyet gerçekten çok düşük olacaktır.

Pratikte, hassasiyet ve geri çağırma arasında denge kurmanın bir yolunu bulmalıyız. F-ölçüsü metriği, kesinlik ve geri çağırma arasında harmonik bir ortalamayı ifade ettiğinden bunu yapmamızı sağlar.

Bu formül F1 ölçümü olarak adlandırılır ve burada eşit bir hassasiyet ve geri çağırma oranı elde etmek için B olarak adlandırılan ekstra terim 1 olarak ayarlanır. Hatırlamayı vurgulamak için B faktörünü 2'ye ayarlayabiliriz. Öte yandan kesinliği vurgulamak için B faktörünü 0,5 olarak ayarlayabiliriz.

Sınıflandırma performansını ölçmek için CNTK kullanma

Önceki bölümde Iris çiçek veri setini kullanarak bir sınıflandırma modeli oluşturduk. Burada, kafa karışıklığı matrisi ve F-ölçüsü metriği kullanarak performansını ölçeceğiz.

Karışıklık matrisi oluşturma

Modeli zaten oluşturduk, böylece aşağıdakileri içeren doğrulama sürecine başlayabiliriz: confusion matrix, aynısında. İlk olarak, şunun yardımıyla karışıklık matrisi oluşturacağız.confusion_matrix işlevi scikit-learn. Bunun için test numunelerimiz için gerçek etiketlere ve aynı test numuneleri için öngörülen etiketlere ihtiyacımız var.

Aşağıdaki python kodunu kullanarak karışıklık matrisini hesaplayalım -

from sklearn.metrics import confusion_matrix
y_true = np.argmax(y_test, axis=1)
y_pred = np.argmax(z(X_test), axis=1)
matrix = confusion_matrix(y_true=y_true, y_pred=y_pred)
print(matrix)

Çıktı

[[10 0 0]
[ 0 1 9]
[ 0 0 10]]

Aşağıdaki gibi bir karışıklık matrisini görselleştirmek için ısı haritası işlevini de kullanabiliriz -

import seaborn as sns
import matplotlib.pyplot as plt
g = sns.heatmap(matrix,
     annot=True,
     xticklabels=label_encoder.classes_.tolist(),
     yticklabels=label_encoder.classes_.tolist(),
     cmap='Blues')
g.set_yticklabels(g.get_yticklabels(), rotation=0)
plt.show()

Modeli karşılaştırmak için kullanabileceğimiz tek bir performans numarasına da sahip olmalıyız. Bunun için sınıflandırma hatasını kullanarak hesaplamamız gerekir.classification_error sınıflandırma modeli oluştururken olduğu gibi CNTK'daki metrik paketinden.

Şimdi sınıflandırma hatasını hesaplamak için, bir veri kümesiyle kayıp işlevinde test yöntemini yürütün. Bundan sonra CNTK, bu fonksiyon için girdi olarak sağladığımız örnekleri alacak ve girdi özelliklerine dayalı bir tahmin yapacak X_test.

loss.test([X_test, y_test])

Çıktı

{'metric': 0.36666666666, 'samples': 30}

F Önlemlerinin Uygulanması

CNTK, F Ölçülerini uygulamak için ayrıca f önlemleri adı verilen işlevi de içerir. Hücreyi değiştirerek NN'yi eğitirken bu işlevi kullanabiliriz.cntk.metrics.classification_errorbir çağrı ile cntk.losses.fmeasure kriter fabrika işlevini tanımlarken aşağıdaki gibi -

import cntk
@cntk.Function
def criterion_factory(output, target):
   loss = cntk.losses.cross_entropy_with_softmax(output, target)
metric = cntk.losses.fmeasure(output, target)
   return loss, metric

Cntk.losses.fmeasure fonksiyonunu kullandıktan sonra, farklı çıktılar elde edeceğiz. loss.test aşağıdaki gibi verilen yöntem çağrısı -

loss.test([X_test, y_test])

Çıktı

{'metric': 0.83101488749, 'samples': 30}