KNN एल्गोरिथम - निकटतम पड़ोसियों का पता लगाना

परिचय

K- निकटतम पड़ोसी (KNN) एल्गोरिथ्म एक प्रकार का पर्यवेक्षित ML एल्गोरिथम है, जिसका उपयोग वर्गीकरण के साथ-साथ प्रतिगमन पूर्वानुमान संबंधी समस्याओं दोनों के लिए किया जा सकता है। हालांकि, यह मुख्य रूप से उद्योग में वर्गीकरण की भविष्य कहनेवाला समस्याओं के लिए उपयोग किया जाता है। निम्नलिखित दो गुण KNN को अच्छी तरह से परिभाषित करेंगे -

  • Lazy learning algorithm - KNN एक आलसी शिक्षण एल्गोरिथ्म है क्योंकि इसमें एक विशेष प्रशिक्षण चरण नहीं है और वर्गीकरण के दौरान प्रशिक्षण के लिए सभी डेटा का उपयोग करता है।

  • Non-parametric learning algorithm - KNN एक गैर-पैरामीट्रिक लर्निंग एल्गोरिथम भी है क्योंकि यह अंतर्निहित डेटा के बारे में कुछ भी नहीं मानता है।

KNN एल्गोरिथम का कार्य करना

K- निकटतम पड़ोसियों (KNN) एल्गोरिथ्म ने नए डेटापॉइंट्स के मूल्यों की भविष्यवाणी करने के लिए 'फ़ीचर समानता' का उपयोग किया है, जिसका अर्थ है कि नए डेटा बिंदु को प्रशिक्षण सेट में बिंदुओं के साथ कितनी निकटता के आधार पर एक मान असाइन किया जाएगा। हम निम्नलिखित चरणों की सहायता से इसके कार्य को समझ सकते हैं -

  • Step 1- किसी भी एल्गोरिथ्म को लागू करने के लिए, हमें डाटासेट की आवश्यकता होती है। इसलिए KNN के पहले चरण के दौरान, हमें प्रशिक्षण के साथ-साथ परीक्षण डेटा भी लोड करना होगा।

  • Step 2- इसके बाद, हमें K यानी निकटतम डेटा बिंदुओं का मान चुनने की आवश्यकता है। K कोई भी पूर्णांक हो सकता है।

  • Step 3 - परीक्षण डेटा में प्रत्येक बिंदु के लिए निम्न कार्य करें -

    3.1- किसी भी विधि की मदद से परीक्षण डेटा और प्रशिक्षण डेटा की प्रत्येक पंक्ति के बीच की दूरी की गणना करें: यूक्लिडियन, मैनहट्टन या हैमिंग दूरी। दूरी की गणना करने के लिए सबसे अधिक इस्तेमाल की जाने वाली विधि यूक्लिडियन है।

    3.2 - अब, दूरी मूल्य के आधार पर, उन्हें आरोही क्रम में क्रमबद्ध करें।

    3.3 - इसके बाद, यह क्रमबद्ध सरणी से शीर्ष K पंक्तियों का चयन करेगा।

    3.4 - अब, यह इन पंक्तियों के सबसे अक्सर वर्ग के आधार पर एक कक्षा को परीक्षण बिंदु पर असाइन करेगा।

  • Step 4 - अंत

उदाहरण

निम्नलिखित केएन और एल्गोरिथ्म के काम की अवधारणा को समझने के लिए एक उदाहरण है -

मान लीजिए हमारे पास एक डेटासेट है, जिसे निम्नानुसार प्लॉट किया जा सकता है -

अब, हमें ब्लैक डॉट (बिंदु 60,60 पर) के साथ नए डेटा बिंदु को नीले या लाल वर्ग में वर्गीकृत करना होगा। हम K = 3 मान रहे हैं, अर्थात इसमें तीन निकटतम डेटा पॉइंट मिलेंगे। इसे अगले चित्र में दिखाया गया है -

हम उपरोक्त आरेख में डेटा बिंदु के तीन निकटतम पड़ोसियों को काले बिंदु के साथ देख सकते हैं। उन तीनों में, उनमें से दो रेड क्लास में हैं, इसलिए ब्लैक डॉट को भी रेड क्लास में सौंपा जाएगा।

पायथन में कार्यान्वयन

जैसा कि हम जानते हैं कि K- निकटतम पड़ोसी (KNN) एल्गोरिथ्म का उपयोग वर्गीकरण के साथ-साथ प्रतिगमन दोनों के लिए किया जा सकता है। केएनएन को क्लासिफायर के साथ-साथ रेग्रेसर के रूप में उपयोग करने के लिए पायथन में निम्नलिखित रेसिपी हैं -

क्लासिफायर के रूप में KNN

सबसे पहले, आवश्यक अजगर पैकेज आयात करने के साथ शुरू करें -

import numpy as np
import matplotlib.pyplot as plt
import pandas as pd

इसके बाद आईरिस डेटासेट को इसके वेबलिंक से डाउनलोड करें -

path = "https://archive.ics.uci.edu/ml/machine-learning-databases/iris/iris.data"

आगे, हमें कॉलम नामों को डेटासेट में निर्दिष्ट करना होगा -

headernames = ['sepal-length', 'sepal-width', 'petal-length', 'petal-width', 'Class']

अब, हमें डेटासेट को पंडों के डेटासेट को पढ़ने की जरूरत है -

dataset = pd.read_csv(path, names=headernames)
dataset.head()
slno। बाह्यदल-लंबाई बाह्यदल-चौड़ाई पत्ती-लंबाई पत्ती-चौड़ाई कक्षा
0 5.1 3.5 1.4 0.2 आइरिस-setosa
1 4.9 3.0 1.4 0.2 आइरिस-setosa
2 4.7 3.2 1.3 0.2 आइरिस-setosa
3 4.6 3.1 1.5 0.2 आइरिस-setosa
4 5.0 3.6 1.4 0.2 आइरिस-setosa

निम्नलिखित स्क्रिप्ट लाइनों की मदद से डेटा प्रीप्रोसेसिंग किया जाएगा -

X = dataset.iloc[:, :-1].values
y = dataset.iloc[:, 4].values

अगला, हम डेटा को ट्रेन और परीक्षण विभाजन में विभाजित करेंगे। निम्नलिखित कोड डेटासेट को 60% प्रशिक्षण डेटा और 40% परीक्षण डेटा में विभाजित करेगा -

from sklearn.model_selection import train_test_split
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.40)

अगला, डेटा स्केलिंग निम्नानुसार किया जाएगा -

from sklearn.preprocessing import StandardScaler
scaler = StandardScaler()
scaler.fit(X_train)
X_train = scaler.transform(X_train)
X_test = scaler.transform(X_test)

इसके बाद, इस प्रकार के रूप में स्केनियर के केनेबर्सक्लासिफायर वर्ग की मदद से मॉडल को प्रशिक्षित करें -

from sklearn.neighbors import KNeighborsClassifier
classifier = KNeighborsClassifier(n_neighbors=8)
classifier.fit(X_train, y_train)

अंत में हमें भविष्यवाणी करने की आवश्यकता है। यह निम्नलिखित स्क्रिप्ट की मदद से किया जा सकता है -

y_pred = classifier.predict(X_test)

अगला, परिणाम निम्नानुसार मुद्रित करें -

from sklearn.metrics import classification_report, confusion_matrix, accuracy_score
result = confusion_matrix(y_test, y_pred)
print("Confusion Matrix:")
print(result)
result1 = classification_report(y_test, y_pred)
print("Classification Report:",)
print (result1)
result2 = accuracy_score(y_test,y_pred)
print("Accuracy:",result2)

उत्पादन

Confusion Matrix:
[[21 0 0]
[ 0 16 0]
[ 0 7 16]]
Classification Report:
            precision      recall       f1-score       support
Iris-setosa       1.00        1.00         1.00          21
Iris-versicolor   0.70        1.00         0.82          16
Iris-virginica    1.00        0.70         0.82          23
micro avg         0.88        0.88         0.88          60
macro avg         0.90        0.90         0.88          60
weighted avg      0.92        0.88         0.88          60


Accuracy: 0.8833333333333333

Regnor के रूप में KNN

सबसे पहले, आवश्यक पायथन पैकेजों को आयात करना शुरू करें -

import numpy as np
import pandas as pd

इसके बाद आईरिस डेटासेट को इसके वेबलिंक से डाउनलोड करें -

path = "https://archive.ics.uci.edu/ml/machine-learning-databases/iris/iris.data"

आगे, हमें कॉलम नामों को डेटासेट में निर्दिष्ट करना होगा -

headernames = ['sepal-length', 'sepal-width', 'petal-length', 'petal-width', 'Class']

अब, हमें डेटासेट को पंडों के डेटासेट को पढ़ने की जरूरत है -

data = pd.read_csv(url, names=headernames)
array = data.values
X = array[:,:2]
Y = array[:,2]
data.shape

output:(150, 5)

अगला, मॉडल को फिट करने के लिए स्केनर से KNeighborsRegressor आयात करें -

from sklearn.neighbors import KNeighborsRegressor
knnr = KNeighborsRegressor(n_neighbors=10)
knnr.fit(X, y)

अंत में, हम एमएसई को निम्नानुसार पा सकते हैं -

print ("The MSE is:",format(np.power(y-knnr.predict(X),2).mean()))

उत्पादन

The MSE is: 0.12226666666666669

केएनएन के पेशेवरों और विपक्ष

पेशेवरों

  • यह समझने और व्याख्या करने के लिए बहुत सरल एल्गोरिथ्म है।

  • यह nonlinear डेटा के लिए बहुत उपयोगी है क्योंकि इस एल्गोरिथ्म में डेटा के बारे में कोई धारणा नहीं है।

  • यह एक बहुमुखी एल्गोरिथ्म है क्योंकि हम इसे वर्गीकरण के साथ-साथ प्रतिगमन के लिए भी उपयोग कर सकते हैं।

  • इसमें अपेक्षाकृत उच्च सटीकता है लेकिन KNN की तुलना में बहुत बेहतर पर्यवेक्षण मॉडल हैं।

विपक्ष

  • यह कम्प्यूटेशनल रूप से थोड़ा महंगा एल्गोरिथ्म है क्योंकि यह सभी प्रशिक्षण डेटा संग्रहीत करता है।

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

  • बड़े एन के मामले में भविष्यवाणी धीमी है।

  • यह डेटा के पैमाने के साथ-साथ अप्रासंगिक विशेषताओं के प्रति बहुत संवेदनशील है।

केएनएन के अनुप्रयोग

निम्नलिखित कुछ ऐसे क्षेत्र हैं जिनमें KNN को सफलतापूर्वक लागू किया जा सकता है -

बैंकिंग सिस्टम

KNN का उपयोग बैंकिंग प्रणाली में किया जा सकता है ताकि मौसम का अनुमान लगाया जा सके कि कोई व्यक्ति ऋण स्वीकृति के लिए उपयुक्त है? क्या उस व्यक्ति के पास बकाएदारों के समान विशेषताएँ हैं?

क्रेडिट रेटिंग की गणना

KNN एल्गोरिदम का उपयोग किसी व्यक्ति के क्रेडिट रेटिंग को खोजने के लिए किया जा सकता है, जिसमें समान लक्षण वाले व्यक्तियों के साथ तुलना की जाती है।

राजनीति

KNN एल्गोरिदम की मदद से, हम संभावित मतदाता को "विल वोट", "वोट नहीं देंगे", "विल वोट टू पार्टी 'कांग्रेस'," विल वोट टू पार्टी 'बीजेपी' जैसे विभिन्न वर्गों में वर्गीकृत कर सकते हैं।

अन्य क्षेत्र जिनमें KNN एल्गोरिथ्म का उपयोग किया जा सकता है, वे हैं स्पीच रिकॉग्निशन, हैंडराइटिंग डिटेक्शन, इमेज रिकॉग्निशन और वीडियो रिकॉग्निशन।