मॉडल प्रदर्शन का मूल्यांकन
मॉडल के प्रदर्शन का मूल्यांकन करने के लिए, हम कॉल करते हैं 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सटीकता मैट्रिक्स के एक भूखंड को प्राप्त करने के लिए हमारे प्रशिक्षण के दौरान। निम्नलिखित कोड प्रत्येक युग पर सटीकता की साजिश करेगा। हम प्रशिक्षण डेटा सटीकता ("एसीसी") और प्लॉटिंग के लिए सत्यापन डेटा सटीकता ("वैल_एसीसी") उठाते हैं।
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')
आउटपुट प्लॉट नीचे दिखाया गया है -
जैसा कि आप आरेख में देख सकते हैं, पहले दो युगों में सटीकता तेजी से बढ़ जाती है, यह दर्शाता है कि नेटवर्क तेजी से सीख रहा है। बाद में, वक्र यह दर्शाता है कि मॉडल को आगे प्रशिक्षित करने के लिए बहुत अधिक युगों की आवश्यकता नहीं है। आमतौर पर, यदि प्रशिक्षण डेटा सटीकता ("एसीसी") में सुधार होता रहता है, जबकि सत्यापन डेटा सटीकता ("वैल_एसीसी") खराब हो जाती है, तो आप ओवरफिटिंग का सामना कर रहे हैं। यह इंगित करता है कि मॉडल डेटा को याद रखना शुरू कर रहा है।
हम अपने मॉडल के प्रदर्शन की जांच करने के लिए लॉस मेट्रिक्स की साजिश भी करेंगे।
प्लॉटिंग लॉस मेट्रिक्स
फिर, हम दोनों प्रशिक्षण ("नुकसान") और परीक्षण ("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')
इस कोड का आउटपुट नीचे दिखाया गया है -
जैसा कि आप आरेख में देख सकते हैं, पहले दो युगों के लिए प्रशिक्षण सेट पर नुकसान तेजी से घटता है। परीक्षण सेट के लिए, नुकसान उसी दर से कम नहीं होता है जितना कि प्रशिक्षण सेट, लेकिन कई युगों के लिए लगभग सपाट रहता है। इसका मतलब है कि हमारा मॉडल डेटा को अनदेखा करने के लिए अच्छी तरह से सामान्यीकरण कर रहा है।
अब, हम अपने परीक्षण मॉडल के अंको का अनुमान लगाने के लिए अपने प्रशिक्षित मॉडल का उपयोग करेंगे।