모델 성능 평가

모델 성능을 평가하기 위해 evaluate 다음과 같이 방법-

loss_and_metrics = model.evaluate(X_test, Y_test, verbose=2)

모델 성능을 평가하기 위해 evaluate 다음과 같이 방법-

loss_and_metrics = model.evaluate(X_test, Y_test, verbose=2)

다음 두 가지 진술을 사용하여 손실과 정확성을 인쇄합니다.

print("Test Loss", loss_and_metrics[0])
print("Test Accuracy", loss_and_metrics[1])

위의 명령문을 실행하면 다음 출력이 표시됩니다.

Test Loss 0.08041584826191042
Test Accuracy 0.9837

이것은 98 %의 테스트 정확도를 보여 주며 이는 우리가 받아 들일 수있을 것입니다. 2 %의 경우 손으로 쓴 숫자가 올바르게 분류되지 않는다는 것이 의미하는 바입니다. 또한 테스트 데이터에서 모델의 성능을 확인하기 위해 정확도 및 손실 메트릭을 플로팅합니다.

정확도 메트릭 플로팅

우리는 기록 된 history훈련 중에 정확도 메트릭 플롯을 얻습니다. 다음 코드는 각 시대의 정확도를 표시합니다. 플로팅을 위해 훈련 데이터 정확도 ( "acc")와 검증 데이터 정확도 ( "val_acc")를 선택합니다.

plot.subplot(2,1,1)
plot.plot(history.history['acc'])
plot.plot(history.history['val_acc'])
plot.title('model accuracy')
plot.ylabel('accuracy')
plot.xlabel('epoch')
plot.legend(['train', 'test'], loc='lower right')

출력 플롯은 다음과 같습니다.

다이어그램에서 볼 수 있듯이 처음 두 epoch에서 정확도가 빠르게 증가하여 네트워크가 빠르게 학습하고 있음을 나타냅니다. 그 후 곡선이 평평 해져 모델을 더 훈련하는 데 너무 많은 에포크가 필요하지 않음을 나타냅니다. 일반적으로 학습 데이터 정확도 ( "acc")가 계속 개선되고 유효성 검사 데이터 정확도 ( "val_acc")가 더 나빠지면 과적 합이 발생한 것입니다. 모델이 데이터를 기억하기 시작했음을 나타냅니다.

또한 모델의 성능을 확인하기 위해 손실 메트릭을 플로팅합니다.

손실 메트릭 플로팅

다시 한 번, 학습 ( "손실") 및 테스트 ( "val_loss") 데이터 모두에 대한 손실을 플로팅합니다. 이것은 다음 코드를 사용하여 수행됩니다-

plot.subplot(2,1,2)
plot.plot(history.history['loss'])
plot.plot(history.history['val_loss'])
plot.title('model loss')
plot.ylabel('loss')
plot.xlabel('epoch')
plot.legend(['train', 'test'], loc='upper right')

이 코드의 출력은 다음과 같습니다.

다이어그램에서 볼 수 있듯이 훈련 세트의 손실은 처음 두 Epoch 동안 빠르게 감소합니다. 테스트 세트의 경우 손실은 학습 세트와 동일한 비율로 감소하지 않지만 여러 세대에 대해 거의 균일하게 유지됩니다. 이것은 우리 모델이 보이지 않는 데이터에 대해 잘 일반화되고 있음을 의미합니다.

이제 훈련 된 모델을 사용하여 테스트 데이터의 숫자를 예측합니다.