पायथन के साथ मशीन सीखना - डेटा तैयार करना
परिचय
मशीन लर्निंग एल्गोरिदम पूरी तरह से डेटा पर निर्भर हैं क्योंकि यह सबसे महत्वपूर्ण पहलू है जो मॉडल प्रशिक्षण को संभव बनाता है। दूसरी ओर, यदि हम उस डेटा से बाहर होने में सक्षम नहीं होंगे, तो उसे एमएल एल्गोरिदम में फीड करने से पहले, एक मशीन बेकार हो जाएगी। सरल शब्दों में, हमें हमेशा सही डेटा यानी सही स्केल, फॉर्मेट और सार्थक विशेषताओं वाले डेटा को फीड करना होगा, जिस समस्या के लिए हम मशीन को हल करना चाहते हैं।
यह एमएल प्रक्रिया में डेटा की तैयारी को सबसे महत्वपूर्ण कदम बनाता है। डेटा तैयारी को उस प्रक्रिया के रूप में परिभाषित किया जा सकता है जो हमारे डेटासेट को एमएल प्रक्रिया के लिए अधिक उपयुक्त बनाती है।
डेटा पूर्व प्रसंस्करण क्यों?
एमएल प्रशिक्षण के लिए कच्चे डेटा का चयन करने के बाद, सबसे महत्वपूर्ण कार्य डेटा पूर्व प्रसंस्करण है। व्यापक अर्थ में, डेटा प्रीप्रोसेसिंग चयनित डेटा को एक ऐसे रूप में परिवर्तित कर देगा जिसे हम एमएल एल्गोरिदम के साथ काम कर सकते हैं या खिला सकते हैं। हमें हमेशा अपने डेटा को प्रीप्रोसेस करने की आवश्यकता है ताकि यह मशीन लर्निंग एल्गोरिदम की अपेक्षा के अनुसार हो सके।
डेटा पूर्व प्रसंस्करण तकनीक
हमारे पास निम्नलिखित डेटा प्रीप्रोसेसिंग तकनीकें हैं जिन्हें एमएल एल्गोरिदम के लिए डेटा का उत्पादन करने के लिए डेटा सेट पर लागू किया जा सकता है -
स्केलिंग
ज्यादातर शायद हमारे डेटासेट में अलग-अलग पैमाने के गुण होते हैं, लेकिन हम एमएल एल्गोरिथम को ऐसा डेटा प्रदान नहीं कर सकते हैं, इसलिए इसे पुनर्विक्रय की आवश्यकता होती है। डेटा rescaling सुनिश्चित करता है कि विशेषताएँ समान पैमाने पर हैं। आम तौर पर, विशेषताओं को 0 और 1. की श्रेणी में बदल दिया जाता है। एमएल एल्गोरिदम जैसे ढाल वंश और के-नेस्टेस्ट नेबर्स को स्केल किए गए डेटा की आवश्यकता होती है। हम साइकिट-लर्न पाइथन लाइब्रेरी के मिनमैक्सस्लेकर वर्ग की मदद से डेटा को पुनः प्राप्त कर सकते हैं।
उदाहरण
इस उदाहरण में हम पिमा इंडियन्स डायबिटीज डेटासेट के डेटा को फिर से देखेंगे जो हमने पहले इस्तेमाल किया था। सबसे पहले, CSV डेटा लोड किया जाएगा (जैसा कि पिछले अध्यायों में किया गया है) और फिर MinMaxScaler वर्ग की मदद से इसे 0 और 1 की श्रेणी में फिर से सेट किया जाएगा।
निम्नलिखित स्क्रिप्ट की पहली कुछ पंक्तियाँ वैसी ही हैं जैसी हमने पिछले चैप्टर में CSV डेटा लोड करते समय लिखी हैं।
from pandas import read_csv
from numpy import set_printoptions
from sklearn import preprocessing
path = r'C:\pima-indians-diabetes.csv'
names = ['preg', 'plas', 'pres', 'skin', 'test', 'mass', 'pedi', 'age', 'class']
dataframe = read_csv(path, names=names)
array = dataframe.values
अब, हम 0 और 1 की श्रेणी में डेटा को फिर से भरने के लिए मिनमैक्सस्लेकर वर्ग का उपयोग कर सकते हैं।
data_scaler = preprocessing.MinMaxScaler(feature_range=(0,1))
data_rescaled = data_scaler.fit_transform(array)
हम अपनी पसंद के अनुसार आउटपुट के लिए डेटा को सारांशित भी कर सकते हैं। यहां, हम 1 पर सटीक सेट कर रहे हैं और आउटपुट में पहली 10 पंक्तियों को दिखा रहे हैं।
set_printoptions(precision=1)
print ("\nScaled data:\n", data_rescaled[0:10])
उत्पादन
Scaled data:
[
[0.4 0.7 0.6 0.4 0. 0.5 0.2 0.5 1. ]
[0.1 0.4 0.5 0.3 0. 0.4 0.1 0.2 0. ]
[0.5 0.9 0.5 0. 0. 0.3 0.3 0.2 1. ]
[0.1 0.4 0.5 0.2 0.1 0.4 0. 0. 0. ]
[0. 0.7 0.3 0.4 0.2 0.6 0.9 0.2 1. ]
[0.3 0.6 0.6 0. 0. 0.4 0.1 0.2 0. ]
[0.2 0.4 0.4 0.3 0.1 0.5 0.1 0.1 1. ]
[0.6 0.6 0. 0. 0. 0.5 0. 0.1 0. ]
[0.1 1. 0.6 0.5 0.6 0.5 0. 0.5 1. ]
[0.5 0.6 0.8 0. 0. 0. 0.1 0.6 1. ]
]
उपरोक्त आउटपुट से, सभी डेटा 0 और 1 की सीमा में बदल गए।
मानकीकरण
एक अन्य उपयोगी डेटा प्रीप्रोसेसिंग तकनीक सामान्यीकरण है। इसका उपयोग डेटा की प्रत्येक पंक्ति को 1 की लंबाई के लिए पुनर्विक्रय करने के लिए किया जाता है। यह स्पार्स डेटासेट में मुख्य रूप से उपयोगी है जहां हमारे पास बहुत सारे शून्य हैं। हम स्किकिट-लर्निंग पाइथन लाइब्रेरी के नॉर्मलाइज़र वर्ग की मदद से डेटा को फिर से जोड़ सकते हैं।
सामान्यीकरण के प्रकार
मशीन लर्निंग में, सामान्यीकरण प्रीप्रोसेसिंग तकनीकों के दो प्रकार हैं: -
एल 1 सामान्यीकरण
इसे सामान्यीकरण तकनीक के रूप में परिभाषित किया जा सकता है जो डेटासेट मानों को इस तरह से संशोधित करता है कि प्रत्येक पंक्ति में पूर्ण मानों का योग हमेशा 1 तक होगा। इसे कम से कम निरपेक्ष विचलन भी कहा जाता है।
Example
इस उदाहरण में, हम पी 1 इंडियन्स डायबिटीज डेटासेट का सामान्यीकरण करने के लिए एल 1 नॉर्मलाइज़ तकनीक का उपयोग करते हैं, जिसे हमने पहले इस्तेमाल किया था। सबसे पहले, CSV डेटा लोड किया जाएगा और फिर नॉर्मलाइज़र क्लास की मदद से इसे सामान्य किया जाएगा।
निम्न स्क्रिप्ट की पहली कुछ पंक्तियाँ वैसी ही हैं जैसी हमने CSV डेटा लोड करते समय पिछले अध्यायों में लिखी हैं।
from pandas import read_csv
from numpy import set_printoptions
from sklearn.preprocessing import Normalizer
path = r'C:\pima-indians-diabetes.csv'
names = ['preg', 'plas', 'pres', 'skin', 'test', 'mass', 'pedi', 'age', 'class']
dataframe = read_csv (path, names=names)
array = dataframe.values
अब, हम डेटा को सामान्य करने के लिए एल 1 के साथ नॉर्मलाइज़र वर्ग का उपयोग कर सकते हैं।
Data_normalizer = Normalizer(norm='l1').fit(array)
Data_normalized = Data_normalizer.transform(array)
हम अपनी पसंद के अनुसार आउटपुट के लिए डेटा को सारांशित भी कर सकते हैं। यहां, हम परिशुद्धता को 2 पर सेट कर रहे हैं और आउटपुट में पहली 3 पंक्तियों को दिखा रहे हैं।
set_printoptions(precision=2)
print ("\nNormalized data:\n", Data_normalized [0:3])
Output
Normalized data:
[
[0.02 0.43 0.21 0.1 0. 0.1 0. 0.14 0. ]
[0. 0.36 0.28 0.12 0. 0.11 0. 0.13 0. ]
[0.03 0.59 0.21 0. 0. 0.07 0. 0.1 0. ]
]
L2 सामान्यीकरण
इसे सामान्यीकरण तकनीक के रूप में परिभाषित किया जा सकता है जो डेटासेट मानों को इस तरह से संशोधित करता है कि प्रत्येक पंक्ति में वर्गों का योग हमेशा 1 तक होगा। इसे कम से कम वर्ग भी कहा जाता है।
Example
इस उदाहरण में, हम पी 2 इंडियन्स डायबिटीज डेटासेट के डेटा को सामान्य करने के लिए एल 2 नॉर्मलाइज़ेशन तकनीक का उपयोग करते हैं, जिसे हमने पहले इस्तेमाल किया था। सबसे पहले, CSV डेटा लोड किया जाएगा (जैसा कि पिछले अध्यायों में किया गया है) और फिर नॉर्मलाइज़र क्लास की मदद से इसे सामान्यीकृत किया जाएगा।
निम्न स्क्रिप्ट की पहली कुछ पंक्तियाँ वैसी ही हैं जैसी हमने CSV डेटा लोड करते समय पिछले अध्यायों में लिखी हैं।
from pandas import read_csv
from numpy import set_printoptions
from sklearn.preprocessing import Normalizer
path = r'C:\pima-indians-diabetes.csv'
names = ['preg', 'plas', 'pres', 'skin', 'test', 'mass', 'pedi', 'age', 'class']
dataframe = read_csv (path, names=names)
array = dataframe.values
अब, हम डेटा को सामान्य करने के लिए एल 1 के साथ नॉर्मलाइज़र वर्ग का उपयोग कर सकते हैं।
Data_normalizer = Normalizer(norm='l2').fit(array)
Data_normalized = Data_normalizer.transform(array)
हम अपनी पसंद के अनुसार आउटपुट के लिए डेटा को सारांशित भी कर सकते हैं। यहां, हम परिशुद्धता को 2 पर सेट कर रहे हैं और आउटपुट में पहली 3 पंक्तियों को दिखा रहे हैं।
set_printoptions(precision=2)
print ("\nNormalized data:\n", Data_normalized [0:3])
Output
Normalized data:
[
[0.03 0.83 0.4 0.2 0. 0.19 0. 0.28 0.01]
[0.01 0.72 0.56 0.24 0. 0.22 0. 0.26 0. ]
[0.04 0.92 0.32 0. 0. 0.12 0. 0.16 0.01]
]
binarization
जैसा कि नाम से पता चलता है, यह तकनीक है जिसकी मदद से हम अपने डेटा को बाइनरी बना सकते हैं। हम अपने डेटा को बाइनरी बनाने के लिए एक बाइनरी सीमा का उपयोग कर सकते हैं। उस सीमा मान से ऊपर के मान 1 में बदल जाएंगे और उस सीमा से नीचे 0. में परिवर्तित हो जाएंगे। उदाहरण के लिए, यदि हम थ्रेशोल्ड मान = 0.5 चुनते हैं, तो इसके ऊपर का डेटासेट मान 1 हो जाएगा और इसके नीचे 0. हो जाएगा। हम इसे क्यों कह सकते हैंbinarizing डेटा या thresholdingआँकड़े। यह तकनीक तब उपयोगी होती है जब हम अपने डेटासेट में संभावनाएं रखते हैं और उन्हें कुरकुरा मूल्यों में बदलना चाहते हैं।
हम स्कोररिट-लर्निंग पाइथन लाइब्रेरी के बिनराइज़र क्लास की मदद से डेटा का बिनाराइज कर सकते हैं।
उदाहरण
इस उदाहरण में, हम पिमा इंडियन्स डायबिटीज डेटासेट के डेटा को फिर से देखेंगे जो हमने पहले इस्तेमाल किया था। सबसे पहले, CSV डेटा लोड किया जाएगा और फिर Binarizer वर्ग की मदद से इसे बाइनरी वैल्यूज़ यानी 0 और 1 में थ्रेशोल्ड वैल्यू के आधार पर परिवर्तित किया जाएगा। हम 0.5 को थ्रेशोल्ड मान के रूप में ले रहे हैं।
निम्न स्क्रिप्ट की पहली कुछ पंक्तियाँ वैसी ही हैं जैसी हमने CSV डेटा लोड करते समय पिछले अध्यायों में लिखी हैं।
from pandas import read_csv
from sklearn.preprocessing import Binarizer
path = r'C:\pima-indians-diabetes.csv'
names = ['preg', 'plas', 'pres', 'skin', 'test', 'mass', 'pedi', 'age', 'class']
dataframe = read_csv(path, names=names)
array = dataframe.values
अब, हम डेटा को बाइनरी मान में परिवर्तित करने के लिए बिनाराइज़ क्लास का उपयोग कर सकते हैं।
binarizer = Binarizer(threshold=0.5).fit(array)
Data_binarized = binarizer.transform(array)
यहां, हम आउटपुट में पहली 5 पंक्तियाँ दिखा रहे हैं।
print ("\nBinary data:\n", Data_binarized [0:5])
उत्पादन
Binary data:
[
[1. 1. 1. 1. 0. 1. 1. 1. 1.]
[1. 1. 1. 1. 0. 1. 0. 1. 0.]
[1. 1. 1. 0. 0. 1. 1. 1. 1.]
[1. 1. 1. 1. 1. 1. 0. 1. 0.]
[0. 1. 1. 1. 1. 1. 1. 1. 1.]
]
मानकीकरण
एक अन्य उपयोगी डेटा प्रीप्रोसेसिंग तकनीक है जो मूल रूप से गौसियन वितरण के साथ डेटा विशेषताओं को बदलने के लिए उपयोग की जाती है। यह माध्य और एसडी (मानक विचलन) को एक मानक गाऊसी वितरण में 0 और 1 के माध्य के साथ भिन्न करता है। यह तकनीक एमएल एल्गोरिदम जैसे रैखिक प्रतिगमन, लॉजिस्टिक प्रतिगमन में उपयोगी है जो इनपुट डेटासेट में एक गौसियन वितरण को मानता है और बेहतर उत्पादन करता है। परिणामी डेटा के साथ परिणाम। हम डेटा के मानकीकरण कर सकते हैं (मतलब = 0 और एसडी = 1), स्किटिट-लर्निंग पायथन लाइब्रेरी के स्टैंडर्डसक्लेर वर्ग की मदद से।
उदाहरण
इस उदाहरण में, हम पिमा इंडियन्स डायबिटीज डेटासेट के डेटा को फिर से देखेंगे जो हमने पहले इस्तेमाल किया था। सबसे पहले, CSV डेटा लोड किया जाएगा और फिर StandardScaler वर्ग की मदद से इसे गौसियन डिस्ट्रीब्यूशन में माध्य = 0 और SD = 1 के साथ परिवर्तित किया जाएगा।
निम्न स्क्रिप्ट की पहली कुछ पंक्तियाँ वैसी ही हैं जैसी हमने CSV डेटा लोड करते समय पिछले अध्यायों में लिखी हैं।
from sklearn.preprocessing import StandardScaler
from pandas import read_csv
from numpy import set_printoptions
path = r'C:\pima-indians-diabetes.csv'
names = ['preg', 'plas', 'pres', 'skin', 'test', 'mass', 'pedi', 'age', 'class']
dataframe = read_csv(path, names=names)
array = dataframe.values
अब, हम डेटा पुनर्विक्रय करने के लिए StandardScaler वर्ग का उपयोग कर सकते हैं।
data_scaler = StandardScaler().fit(array)
data_rescaled = data_scaler.transform(array)
हम अपनी पसंद के अनुसार आउटपुट के लिए डेटा को सारांशित भी कर सकते हैं। यहां, हम परिशुद्धता को 2 पर सेट कर रहे हैं और आउटपुट में पहली 5 पंक्तियों को दिखा रहे हैं।
set_printoptions(precision=2)
print ("\nRescaled data:\n", data_rescaled [0:5])
उत्पादन
Rescaled data:
[
[ 0.64 0.85 0.15 0.91 -0.69 0.2 0.47 1.43 1.37]
[-0.84 -1.12 -0.16 0.53 -0.69 -0.68 -0.37 -0.19 -0.73]
[ 1.23 1.94 -0.26 -1.29 -0.69 -1.1 0.6 -0.11 1.37]
[-0.84 -1. -0.16 0.15 0.12 -0.49 -0.92 -1.04 -0.73]
[-1.14 0.5 -1.5 0.91 0.77 1.41 5.48 -0.02 1.37]
]
डेटा लेबलिंग
हमने एमएल एल्गोरिदम के लिए अच्छे फाटा के महत्व के साथ-साथ कुछ तकनीकों को एमएल एल्गोरिदम पर भेजने से पहले डेटा को पूर्व-संसाधित करने के लिए चर्चा की। इस संबंध में एक और पहलू डेटा लेबलिंग है। एमएल एल्गोरिदम को उचित लेबलिंग के लिए डेटा भेजना भी बहुत महत्वपूर्ण है। उदाहरण के लिए, वर्गीकरण की समस्याओं के मामले में, शब्द, संख्या आदि के रूप में बहुत सारे लेबल डेटा पर हैं।
लेबल एनकोडिंग क्या है?
अधिकांश स्केलेर फ़ंक्शन यह अपेक्षा करते हैं कि शब्द लेबल के बजाय संख्या लेबल वाला डेटा। इसलिए, हमें ऐसे लेबलों को नंबर लेबल में बदलने की आवश्यकता है। इस प्रक्रिया को लेबल एन्कोडिंग कहा जाता है। हम Scikit-Py Pyon Library की लेबलईनकोडर () फ़ंक्शन की मदद से डेटा की लेबल एन्कोडिंग कर सकते हैं।
उदाहरण
निम्नलिखित उदाहरण में, पायथन स्क्रिप्ट लेबल एन्कोडिंग का प्रदर्शन करेगी।
सबसे पहले, आवश्यक अजगर पुस्तकालयों को निम्नानुसार आयात करें -
import numpy as np
from sklearn import preprocessing
अब, हमें निम्नानुसार इनपुट लेबल प्रदान करने की आवश्यकता है -
input_labels = ['red','black','red','green','black','yellow','white']
कोड की अगली पंक्ति लेबल एनकोडर बनाएगी और उसे प्रशिक्षित करेगी।
encoder = preprocessing.LabelEncoder()
encoder.fit(input_labels)
स्क्रिप्ट की अगली पंक्तियाँ यादृच्छिक क्रमबद्ध सूची को कूटबद्ध करके प्रदर्शन की जाँच करेंगी -
test_labels = ['green','red','black']
encoded_values = encoder.transform(test_labels)
print("\nLabels =", test_labels)
print("Encoded values =", list(encoded_values))
encoded_values = [3,0,4,1]
decoded_list = encoder.inverse_transform(encoded_values)
हम निम्न लिपि की मदद से एन्कोडेड मूल्यों की सूची प्राप्त कर सकते हैं -
print("\nEncoded values =", encoded_values)
print("\nDecoded labels =", list(decoded_list))
उत्पादन
Labels = ['green', 'red', 'black']
Encoded values = [1, 2, 0]
Encoded values = [3, 0, 4, 1]
Decoded labels = ['white', 'black', 'yellow', 'green']