CNTK - Модель классификации

Эта глава поможет вам понять, как измерить производительность модели классификации в CNTK. Начнем с матрицы путаницы.

Матрица путаницы

Матрица неточностей - таблица с прогнозируемым выходом в сравнении с ожидаемым выходом - это самый простой способ измерить производительность задачи классификации, где выходные данные могут относиться к двум или более типам классов.

Чтобы понять, как это работает, мы собираемся создать матрицу путаницы для модели двоичной классификации, которая предсказывает, была ли транзакция по кредитной карте нормальной или мошеннической. Это показано следующим образом -

Фактическое мошенничество Фактический нормальный

Predicted fraud

Истинно положительный

Ложный положительный результат

Predicted normal

Ложноотрицательный

Правда отрицательный

Как мы видим, приведенная выше матрица путаницы содержит 2 столбца: один для мошенничества класса, а другой - для обычного класса. Таким же образом у нас есть 2 строки, одна добавляется для мошенничества класса, а другая добавляется для обычного класса. Ниже приводится объяснение терминов, связанных с матрицей путаницы.

  • True Positives - Когда и фактический класс, и прогнозируемый класс точки данных равны 1.

  • True Negatives - Когда и фактический класс, и прогнозируемый класс точки данных равны 0.

  • False Positives - Когда фактический класс точки данных равен 0, а прогнозируемый класс точки данных равен 1.

  • False Negatives - Когда фактический класс точки данных равен 1, а прогнозируемый класс точки данных равен 0.

Давайте посмотрим, как мы можем вычислить количество разных вещей из матрицы путаницы -

  • Accuracy- Это количество правильных прогнозов, сделанных нашей классификационной моделью ML. Его можно рассчитать с помощью следующей формулы -

  • Precision- Он сообщает нам, сколько выборок было правильно предсказано из всех предсказанных нами выборок. Его можно рассчитать с помощью следующей формулы -

  • Recall or Sensitivity- Напомним, количество положительных результатов, возвращаемых нашей моделью классификации ML. Другими словами, он сообщает нам, сколько случаев мошенничества в наборе данных было фактически обнаружено моделью. Его можно рассчитать с помощью следующей формулы -

  • Specificity- Напротив, он дает количество негативов, возвращаемых нашей моделью классификации ML. Его можно рассчитать с помощью следующей формулы -

F-мера

Мы можем использовать F-меру как альтернативу матрице путаницы. Основная причина этого в том, что мы не можем одновременно максимизировать отзыв и точность. Между этими показателями существует очень сильная взаимосвязь, и это можно понять с помощью следующего примера:

Предположим, мы хотим использовать модель DL для классификации образцов клеток как злокачественных или нормальных. Здесь, чтобы достичь максимальной точности, нам нужно уменьшить количество прогнозов до 1. Хотя это может дать нам примерно 100-процентную точность, но отзывчивость станет очень низкой.

С другой стороны, если мы хотим добиться максимального отзыва, нам нужно сделать как можно больше прогнозов. Хотя это может дать нам около 100% отзыва, но точность станет действительно низкой.

На практике нам нужно найти способ балансировать между точностью и отзывом. Метрика F-мера позволяет нам это сделать, поскольку она выражает гармоническое среднее между точностью и отзывом.

Эта формула называется F1-мерой, где дополнительный член B устанавливается на 1, чтобы получить равное соотношение точности и полноты. Чтобы подчеркнуть отзыв, мы можем установить коэффициент B равным 2. С другой стороны, чтобы подчеркнуть точность, мы можем установить коэффициент B равным 0,5.

Использование CNTK для измерения эффективности классификации

В предыдущем разделе мы создали модель классификации, используя набор данных цветка ириса. Здесь мы будем измерять его производительность с помощью матрицы ошибок и метрики F-меры.

Создание матрицы путаницы

Мы уже создали модель, поэтому можем начать процесс проверки, который включает confusion matrix, на том же. Во-первых, мы собираемся создать матрицу путаницы с помощьюconfusion_matrix функция от scikit-learn. Для этого нам нужны настоящие метки для наших тестовых образцов и предсказанные метки для тех же тестовых образцов.

Давайте рассчитаем матрицу путаницы, используя следующий код Python -

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)

Вывод

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

Мы также можем использовать функцию тепловой карты для визуализации матрицы путаницы следующим образом:

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()

У нас также должен быть единый показатель производительности, который мы можем использовать для сравнения модели. Для этого нам нужно вычислить ошибку классификации, используяclassification_error из пакета метрик в CNTK, как это было сделано при создании модели классификации.

Теперь, чтобы вычислить ошибку классификации, выполните метод проверки функции потерь с набором данных. После этого CNTK возьмет образцы, которые мы предоставили в качестве входных данных для этой функции, и сделает прогноз на основе входных функций X_test.

loss.test([X_test, y_test])

Вывод

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

Внедрение F-мер

Для реализации F-мер CNTK также включает функцию, называемую fmeasures. Мы можем использовать эту функцию, обучая NN, заменяя ячейкуcntk.metrics.classification_error, с призывом к cntk.losses.fmeasure при определении функции фабрики критериев следующим образом:

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 мы получим другой вывод для loss.test вызов метода следующий:

loss.test([X_test, y_test])

Вывод

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