स्किट सीखो - मॉडलिंग प्रक्रिया

यह अध्याय स्केलेरन में शामिल मॉडलिंग प्रक्रिया से संबंधित है। आइए हम उसी के बारे में विस्तार से समझते हैं और डाटासेट लोडिंग के साथ शुरू करते हैं।

डेटासेट लोड हो रहा है

डेटा के संग्रह को डेटासेट कहा जाता है। इसके निम्नलिखित दो घटक हैं -

Features- डेटा के चर को इसकी विशेषताएं कहा जाता है। उन्हें भविष्यवक्ता, इनपुट या विशेषताओं के रूप में भी जाना जाता है।

  • Feature matrix - यह सुविधाओं का संग्रह है, मामले में एक से अधिक हैं।

  • Feature Names - यह सुविधाओं के सभी नामों की सूची है।

Response- यह आउटपुट चर है जो मूल रूप से सुविधा चर पर निर्भर करता है। उन्हें लक्ष्य, लेबल या आउटपुट के रूप में भी जाना जाता है।

  • Response Vector- इसका उपयोग प्रतिक्रिया कॉलम का प्रतिनिधित्व करने के लिए किया जाता है। आम तौर पर, हमारे पास केवल एक प्रतिक्रिया स्तंभ होता है।

  • Target Names - यह एक प्रतिक्रिया वेक्टर द्वारा उठाए गए संभावित मूल्यों का प्रतिनिधित्व करता है।

स्किकिट-लर्न में कुछ उदाहरण डेटासेट जैसे हैं iris तथा digits वर्गीकरण के लिए और Boston house prices प्रतिगमन के लिए।

उदाहरण

निम्नलिखित लोड करने के लिए एक उदाहरण है iris डेटासेट -

from sklearn.datasets import load_iris
iris = load_iris()
X = iris.data
y = iris.target
feature_names = iris.feature_names
target_names = iris.target_names
print("Feature names:", feature_names)
print("Target names:", target_names)
print("\nFirst 10 rows of X:\n", X[:10])

उत्पादन

Feature names: ['sepal length (cm)', 'sepal width (cm)', 'petal length (cm)', 'petal width (cm)']
Target names: ['setosa' 'versicolor' 'virginica']
First 10 rows of X:
[
   [5.1 3.5 1.4 0.2]
   [4.9 3. 1.4 0.2]
   [4.7 3.2 1.3 0.2]
   [4.6 3.1 1.5 0.2]
   [5. 3.6 1.4 0.2]
   [5.4 3.9 1.7 0.4]
   [4.6 3.4 1.4 0.3]
   [5. 3.4 1.5 0.2]
   [4.4 2.9 1.4 0.2]
   [4.9 3.1 1.5 0.1]
]

डेटासेट विभाजित करना

हमारे मॉडल की सटीकता की जांच करने के लिए, हम डेटासेट को दो टुकड़ों में विभाजित कर सकते हैं-a training set तथा a testing set। मॉडल का परीक्षण करने के लिए प्रशिक्षण सेट का उपयोग करें और मॉडल का परीक्षण करने के लिए परीक्षण सेट करें। उसके बाद, हम मूल्यांकन कर सकते हैं कि हमारे मॉडल ने कितना अच्छा किया।

उदाहरण

निम्न उदाहरण डेटा को 70:30 अनुपात में विभाजित करेगा, अर्थात 70% डेटा का उपयोग प्रशिक्षण डेटा के रूप में किया जाएगा और 30% का उपयोग परीक्षण डेटा के रूप में किया जाएगा। उपर्युक्त उदाहरण में डेटासेट iris डाटासेट है।

from sklearn.datasets import load_iris
iris = load_iris()

X = iris.data
y = iris.target

from sklearn.model_selection import train_test_split

X_train, X_test, y_train, y_test = train_test_split(
   X, y, test_size = 0.3, random_state = 1
)

print(X_train.shape)
print(X_test.shape)

print(y_train.shape)
print(y_test.shape)

उत्पादन

(105, 4)
(45, 4)
(105,)
(45,)

जैसा कि ऊपर दिए गए उदाहरण में देखा गया है, यह उपयोग करता है train_test_split()स्किकिट का कार्य- डेटासेट विभाजित करना सीखें। इस फ़ंक्शन के निम्नलिखित तर्क हैं -

  • X, y - यहाँ X है feature matrix और वाई है response vector, जिसे विभाजित करने की आवश्यकता है।

  • test_size- यह कुल दिए गए डेटा के परीक्षण डेटा के अनुपात का प्रतिनिधित्व करता है। जैसा कि उपरोक्त उदाहरण में, हम सेट कर रहे हैंtest_data = 0.3 X की 150 पंक्तियों के लिए। यह 150 * 0.3 = 45 पंक्तियों के परीक्षण डेटा का उत्पादन करेगा।

  • random_size- यह गारंटी देने के लिए उपयोग किया जाता है कि विभाजन हमेशा समान होगा। यह उन स्थितियों में उपयोगी है जहां आप प्रजनन योग्य परिणाम चाहते हैं।

मॉडल को प्रशिक्षित करें

अगला, हम कुछ डेटा-मॉडल को प्रशिक्षित करने के लिए अपने डेटासेट का उपयोग कर सकते हैं। जैसा कि चर्चा की गई है, स्किकिट-लर्न की विस्तृत श्रृंखला हैMachine Learning (ML) algorithms जिसमें फिटिंग के लिए एक सुसंगत इंटरफ़ेस है, सटीकता की भविष्यवाणी करना, याद रखना आदि।

उदाहरण

नीचे दिए गए उदाहरण में, हम KNN (K निकटतम पड़ोसियों) क्लासिफायर का उपयोग करने जा रहे हैं। KNN एल्गोरिदम के विवरण में मत जाओ, क्योंकि इसके लिए एक अलग अध्याय होगा। इस उदाहरण का उपयोग केवल कार्यान्वयन भाग को समझने के लिए किया जाता है।

from sklearn.datasets import load_iris
iris = load_iris()
X = iris.data
y = iris.target
from sklearn.model_selection import train_test_split
X_train, X_test, y_train, y_test = train_test_split(
   X, y, test_size = 0.4, random_state=1
)
from sklearn.neighbors import KNeighborsClassifier
from sklearn import metrics
classifier_knn = KNeighborsClassifier(n_neighbors = 3)
classifier_knn.fit(X_train, y_train)
y_pred = classifier_knn.predict(X_test)
# Finding accuracy by comparing actual response values(y_test)with predicted response value(y_pred)
print("Accuracy:", metrics.accuracy_score(y_test, y_pred))
# Providing sample data and the model will make prediction out of that data

sample = [[5, 5, 3, 2], [2, 4, 3, 5]]
preds = classifier_knn.predict(sample)
pred_species = [iris.target_names[p] for p in preds] print("Predictions:", pred_species)

उत्पादन

Accuracy: 0.9833333333333333
Predictions: ['versicolor', 'virginica']

मॉडल की दृढ़ता

एक बार जब आप मॉडल को प्रशिक्षित करते हैं, तो यह वांछनीय है कि मॉडल भविष्य के उपयोग के लिए बने रहना चाहिए ताकि हमें बार-बार इसे वापस लेने की आवश्यकता न हो। की सहायता से किया जा सकता हैdump तथा load की सुविधाएं joblib पैकेज।

नीचे दिए गए उदाहरण पर विचार करें जिसमें हम भविष्य के उपयोग के लिए उपरोक्त प्रशिक्षित मॉडल (क्लासिफायर_कन) की बचत करेंगे -

from sklearn.externals import joblib
joblib.dump(classifier_knn, 'iris_classifier_knn.joblib')

उपरोक्त कोड iris_classifier_knn.joblib नामक फ़ाइल में मॉडल को बचाएगा। अब, वस्तु को निम्नलिखित कोड की मदद से फाइल से पुनः लोड किया जा सकता है -

joblib.load('iris_classifier_knn.joblib')

डेटा को रोकना

जैसा कि हम बहुत सारे डेटा के साथ काम कर रहे हैं और यह डेटा कच्चे रूप में है, उस डेटा को मशीन लर्निंग एल्गोरिदम में इनपुट करने से पहले, हमें इसे सार्थक डेटा में बदलने की आवश्यकता है। इस प्रक्रिया को डेटा को प्रीप्रोसेस करना कहा जाता है। स्किकिट-लर्न का पैकेज नाम दिया गया हैpreprocessingइस काम के लिए। preprocessing पैकेज में निम्नलिखित तकनीकें हैं -

Binarisation

इस प्रीप्रोसेसिंग तकनीक का उपयोग तब किया जाता है जब हमें अपने संख्यात्मक मूल्यों को बूलियन मूल्यों में बदलने की आवश्यकता होती है।

उदाहरण

import numpy as np
from sklearn import preprocessing
Input_data = np.array(
   [2.1, -1.9, 5.5],
   [-1.5, 2.4, 3.5],
   [0.5, -7.9, 5.6],
   [5.9, 2.3, -5.8]]
)
data_binarized = preprocessing.Binarizer(threshold=0.5).transform(input_data)
print("\nBinarized data:\n", data_binarized)

उपरोक्त उदाहरण में, हमने उपयोग किया threshold value = 0.5 और इसीलिए, 0.5 से ऊपर के सभी मानों को 1 में बदल दिया जाएगा, और 0.5 से नीचे के सभी मूल्यों को 0 में बदल दिया जाएगा।

उत्पादन

Binarized data:
[
   [ 1. 0. 1.]
   [ 0. 1. 1.]
   [ 0. 0. 1.]
   [ 1. 1. 0.]
]

मतलब निकालना

इस तकनीक का उपयोग फीचर वेक्टर से माध्य को खत्म करने के लिए किया जाता है ताकि हर सुविधा शून्य पर केंद्रित हो।

उदाहरण

import numpy as np
from sklearn import preprocessing
Input_data = np.array(
   [2.1, -1.9, 5.5],
   [-1.5, 2.4, 3.5],
   [0.5, -7.9, 5.6],
   [5.9, 2.3, -5.8]]
)

#displaying the mean and the standard deviation of the input data
print("Mean =", input_data.mean(axis=0))
print("Stddeviation = ", input_data.std(axis=0))
#Removing the mean and the standard deviation of the input data

data_scaled = preprocessing.scale(input_data)
print("Mean_removed =", data_scaled.mean(axis=0))
print("Stddeviation_removed =", data_scaled.std(axis=0))

उत्पादन

Mean = [ 1.75 -1.275 2.2 ]
Stddeviation = [ 2.71431391 4.20022321 4.69414529]
Mean_removed = [ 1.11022302e-16 0.00000000e+00 0.00000000e+00]
Stddeviation_removed = [ 1. 1. 1.]

स्केलिंग

फीचर वैक्टर को स्केल करने के लिए हम इस प्रीप्रोसेसिंग तकनीक का उपयोग करते हैं। फ़ीचर वैक्टर की स्केलिंग महत्वपूर्ण है, क्योंकि सुविधाओं को कृत्रिम रूप से बड़ा या छोटा नहीं होना चाहिए।

उदाहरण

import numpy as np
from sklearn import preprocessing
Input_data = np.array(
   [
      [2.1, -1.9, 5.5],
      [-1.5, 2.4, 3.5],
      [0.5, -7.9, 5.6],
      [5.9, 2.3, -5.8]
   ]
)
data_scaler_minmax = preprocessing.MinMaxScaler(feature_range=(0,1))
data_scaled_minmax = data_scaler_minmax.fit_transform(input_data)
print ("\nMin max scaled data:\n", data_scaled_minmax)

उत्पादन

Min max scaled data:
[
   [ 0.48648649 0.58252427 0.99122807]
   [ 0. 1. 0.81578947]
   [ 0.27027027 0. 1. ]
   [ 1. 0.99029126 0. ]
]

मानकीकरण

हम फीचर वैक्टर को संशोधित करने के लिए इस प्रीप्रोसेसिंग तकनीक का उपयोग करते हैं। फीचर वैक्टर का सामान्यीकरण आवश्यक है, ताकि फीचर वैक्टर को सामान्य पैमाने पर मापा जा सके। सामान्यीकरण दो प्रकार के होते हैं -

एल 1 सामान्यीकरण

इसे Least Absolute Deviations भी कहा जाता है। यह इस तरह से मूल्य को संशोधित करता है कि प्रत्येक पंक्ति में पूर्ण मानों का योग हमेशा 1 तक रहता है। निम्नलिखित उदाहरण इनपुट डेटा पर एल 1 सामान्यीकरण के कार्यान्वयन को दर्शाता है।

उदाहरण

import numpy as np
from sklearn import preprocessing
Input_data = np.array(
   [
      [2.1, -1.9, 5.5],
      [-1.5, 2.4, 3.5],
      [0.5, -7.9, 5.6],
      [5.9, 2.3, -5.8]
   ]
)
data_normalized_l1 = preprocessing.normalize(input_data, norm='l1')
print("\nL1 normalized data:\n", data_normalized_l1)

उत्पादन

L1 normalized data:
[
   [ 0.22105263 -0.2 0.57894737]
   [-0.2027027 0.32432432 0.47297297]
   [ 0.03571429 -0.56428571 0.4 ]
   [ 0.42142857 0.16428571 -0.41428571]
]

L2 सामान्यीकरण

जिसे Least Squares भी कहा जाता है। यह मूल्य को इस तरह से संशोधित करता है कि वर्गों का योग प्रत्येक पंक्ति में हमेशा 1 तक रहता है। निम्नलिखित उदाहरण इनपुट डेटा पर एल 2 के सामान्यीकरण के कार्यान्वयन को दर्शाता है।

उदाहरण

import numpy as np
from sklearn import preprocessing
Input_data = np.array(
   [
      [2.1, -1.9, 5.5],
      [-1.5, 2.4, 3.5],
      [0.5, -7.9, 5.6],
      [5.9, 2.3, -5.8]
   ]
)
data_normalized_l2 = preprocessing.normalize(input_data, norm='l2')
print("\nL1 normalized data:\n", data_normalized_l2)

उत्पादन

L2 normalized data:
[
   [ 0.33946114 -0.30713151 0.88906489]
   [-0.33325106 0.53320169 0.7775858 ]
   [ 0.05156558 -0.81473612 0.57753446]
   [ 0.68706914 0.26784051 -0.6754239 ]
]