केर के साथ गहन सीखना - डेटा तैयार करना
इससे पहले कि हम अपने नेटवर्क को डेटा फ़ीड करें, इसे नेटवर्क द्वारा आवश्यक प्रारूप में परिवर्तित किया जाना चाहिए। इसे नेटवर्क के लिए डेटा तैयार करना कहा जाता है। इसमें बहु-आयामी इनपुट को एकल-आयाम वेक्टर में परिवर्तित करना और डेटा बिंदुओं को सामान्य बनाना शामिल है।
रिचार्जिंग इनपुट वेक्टर
हमारे डेटासेट में चित्र 28 x 28 पिक्सेल के हैं। इसे हमारे नेटवर्क में फीड करने के लिए 28 * 28 = 784 आकार के एकल आयामी वेक्टर में परिवर्तित किया जाना चाहिए। हम कॉल करके ऐसा करते हैंreshape वेक्टर पर विधि।
X_train = X_train.reshape(60000, 784)
X_test = X_test.reshape(10000, 784)
अब, हमारे प्रशिक्षण वेक्टर में 60000 डेटा बिंदु शामिल होंगे, प्रत्येक में 784 आकार के एकल आयाम वेक्टर शामिल होंगे। इसी प्रकार, हमारे परीक्षण वेक्टर में 784 आकार के एकल-आयाम वेक्टर के 10000 डेटा बिंदु शामिल होंगे।
डेटा को सामान्य कर रहा है
इनपुट वेक्टर में मौजूद डेटा में वर्तमान में 0 और 255 के बीच असतत मान है - ग्रे स्केल स्तर। 0 और 1 के बीच इन पिक्सेल मूल्यों को सामान्य करने से प्रशिक्षण को गति देने में मदद मिलती है। जैसा कि हम स्टोकेस्टिक ग्रेडिएंट वंश का उपयोग करने जा रहे हैं, डेटा को सामान्य करने से स्थानीय ऑप्टिमा में फंसने की संभावना को कम करने में भी मदद मिलेगी।
डेटा को सामान्य करने के लिए, हम इसे फ्लोट प्रकार के रूप में दर्शाते हैं और इसे 255 से विभाजित करते हैं जैसा कि निम्नलिखित कोड स्निपेट में दिखाया गया है -
X_train = X_train.astype('float32')
X_test = X_test.astype('float32')
X_train /= 255
X_test /= 255
आइए अब देखते हैं कि सामान्यीकृत डेटा कैसा दिखता है।
सामान्यीकृत डेटा की जांच करना
सामान्यीकृत डेटा को देखने के लिए, हम हिस्टोग्राम फ़ंक्शन को यहां दिखाए गए अनुसार कहेंगे -
plot.hist(X_train[0])
plot.title("Digit: {}".format(y_train[0]))
यहां, हम पहले तत्व के हिस्टोग्राम की साजिश रचते हैं X_trainवेक्टर। हम इस डेटा बिंदु द्वारा दर्शाए गए अंकों को भी प्रिंट करते हैं। उपरोक्त कोड चलाने का आउटपुट यहाँ दिखाया गया है -
आपको शून्य के करीब मान वाले बिंदुओं का एक मोटा घनत्व दिखाई देगा। ये छवि में काले बिंदु बिंदु हैं, जो स्पष्ट रूप से छवि का प्रमुख हिस्सा है। ग्रे स्केल के बाकी बिंदु, जो सफेद रंग के करीब हैं, अंक का प्रतिनिधित्व करते हैं। आप किसी अन्य अंक के लिए पिक्सेल के वितरण की जांच कर सकते हैं। नीचे दिया गया कोड प्रशिक्षण डेटासेट में 2 के सूचकांक में एक अंक के हिस्टोग्राम को प्रिंट करता है।
plot.hist(X_train[2])
plot.title("Digit: {}".format(y_train[2])
उपरोक्त कोड चलाने का आउटपुट नीचे दिखाया गया है -
उपरोक्त दो आंकड़ों की तुलना करने पर, आप देखेंगे कि दो चित्रों में सफेद पिक्सेल का वितरण उपरोक्त दो चित्रों में एक अलग अंक - "5" और "4" का प्रतिनिधित्व दर्शाता है।
अगला, हम अपने पूर्ण प्रशिक्षण डेटासेट में डेटा के वितरण की जांच करेंगे।
डेटा वितरण की जांच करना
अपने मशीन लर्निंग मॉडल को हमारे डेटासेट पर प्रशिक्षित करने से पहले, हमें अपने डेटासेट में अद्वितीय अंकों के वितरण को जानना चाहिए। हमारी छवियां 0 से 9. तक 10 अलग-अलग अंकों का प्रतिनिधित्व करती हैं। हम अपने डेटासेट में अंकों की संख्या 0, 1, आदि जानना चाहते हैं। हम इस जानकारी का उपयोग करके प्राप्त कर सकते हैंunique Numpy की विधि।
अद्वितीय मानों की संख्या और प्रत्येक की घटनाओं की संख्या को मुद्रित करने के लिए निम्न आदेश का उपयोग करें
print(np.unique(y_train, return_counts=True))
जब आप उपरोक्त कमांड चलाते हैं, तो आपको निम्न आउटपुट दिखाई देंगे -
(array([0, 1, 2, 3, 4, 5, 6, 7, 8, 9], dtype=uint8), array([5923, 6742, 5958, 6131, 5842, 5421, 5918, 6265, 5851, 5949]))
यह दर्शाता है कि १० अलग-अलग मूल्य हैं - ० ९ के माध्यम से। ५ ९ २३ अंक हैं ० अंक के ०, ६ there४२ होने वाले अंक १ हैं, और इसी तरह। आउटपुट का स्क्रीनशॉट यहाँ दिखाया गया है -
डेटा तैयार करने के अंतिम चरण के रूप में, हमें अपने डेटा को एनकोड करना होगा।
डेटा एन्कोडिंग
हमारे डेटासेट में हमारी दस श्रेणियां हैं। इस प्रकार हम इन दस श्रेणियों में एक-गर्म एन्कोडिंग का उपयोग करके अपने उत्पादन को कूटबद्ध करेंगे। हम एन्कोडिंग प्रदर्शन करने के लिए Numpy उपयोगिताओं की to_categorial विधि का उपयोग करते हैं। आउटपुट डेटा एन्कोडेड होने के बाद, प्रत्येक डेटा पॉइंट को 10. के एकल आयामी वेक्टर में परिवर्तित किया जाएगा। उदाहरण के लिए, अंक 5 को अब [0,0,0,0,0,1,0,0,0 के रूप में दर्शाया जाएगा। , 0]।
निम्नलिखित कोड का उपयोग करके डेटा को एनकोड करें -
n_classes = 10
Y_train = np_utils.to_categorical(y_train, n_classes)
आप श्रेणीबद्ध Y_train वेक्टर के पहले 5 तत्वों को प्रिंट करके एन्कोडिंग के परिणाम की जांच कर सकते हैं।
पहले 5 वैक्टर प्रिंट करने के लिए निम्नलिखित कोड का उपयोग करें -
for i in range(5):
print (Y_train[i])
आप निम्न आउटपुट देखेंगे -
[0. 0. 0. 0. 0. 1. 0. 0. 0. 0.]
[1. 0. 0. 0. 0. 0. 0. 0. 0. 0.]
[0. 0. 0. 0. 1. 0. 0. 0. 0. 0.]
[0. 1. 0. 0. 0. 0. 0. 0. 0. 0.]
[0. 0. 0. 0. 0. 0. 0. 0. 0. 1.]
पहला तत्व अंक 5 का प्रतिनिधित्व करता है, दूसरा अंक 0 का प्रतिनिधित्व करता है, और इसी तरह।
अंत में, आपको परीक्षण डेटा को भी वर्गीकृत करना होगा, जो निम्नलिखित कथन का उपयोग करके किया गया है -
Y_test = np_utils.to_categorical(y_test, n_classes)
इस स्तर पर, आपका डेटा नेटवर्क में फीड करने के लिए पूरी तरह से तैयार है।
अगला, सबसे महत्वपूर्ण हिस्सा है और यह हमारे नेटवर्क मॉडल को प्रशिक्षित कर रहा है।