क्लस्टरिंग एल्गोरिदम - मीनिंग शिफ्ट एल्गोरिथम

मीन-शिफ्ट एल्गोरिथ्म का परिचय

जैसा कि पहले चर्चा की गई थी, यह एक और शक्तिशाली क्लस्टरिंग एल्गोरिथ्म है जिसका उपयोग अप्रशिक्षित शिक्षा में किया जाता है। K- साधन क्लस्टरिंग के विपरीत, यह कोई धारणा नहीं बनाता है; इसलिए यह एक गैर पैरामीट्रिक एल्गोरिथ्म है।

मीन-शिफ्ट एल्गोरिथ्म मूल रूप से डेटापॉइंट्स के उच्चतम घनत्व की ओर बिंदुओं को शिफ्ट करके क्लस्टर समूहों के डेटापेट को निर्दिष्ट करता है।

के-मीन्स एल्गोरिथ्म और मीन-शिफ्ट के बीच अंतर यह है कि बाद में किसी को पहले से क्लस्टर की संख्या निर्दिष्ट करने की आवश्यकता नहीं है, क्योंकि क्लस्टर की संख्या एल्गोरिदम पीटी डेटा द्वारा निर्धारित की जाएगी।

मीन-शिफ्ट एलगोरिदम का कार्य

हम निम्नलिखित चरणों की मदद से मीन-शिफ्ट क्लस्टरिंग एल्गोरिदम के कार्य को समझ सकते हैं -

  • Step 1 - सबसे पहले, अपने स्वयं के क्लस्टर में निर्दिष्ट डेटा बिंदुओं के साथ शुरू करें।

  • Step 2 - अगला, यह एल्गोरिथ्म केन्द्रक की गणना करेगा।

  • Step 3 - इस चरण में, नए केंद्रों का स्थान अपडेट किया जाएगा।

  • Step 4 - अब, प्रक्रिया को पुनरावृत्त किया जाएगा और उच्च घनत्व क्षेत्र में ले जाया जाएगा।

  • Step 5 - अंत में, सेंट्रोइड्स उस स्थिति में पहुंच जाएंगे, जहां से यह आगे नहीं बढ़ सकता है।

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

यह समझने के लिए एक सरल उदाहरण है कि मीन-शिफ्ट एल्गोरिथ्म कैसे काम करता है। इस उदाहरण में, हम सबसे पहले 2D डेटा जनरेट करने वाले हैं जिसमें 4 अलग-अलग ब्लब्स हैं और इसके बाद परिणाम देखने के लिए मीन-शिफ्ट एल्गोरिथ्म लागू होगा।

%matplotlib inline
import numpy as np
from sklearn.cluster import MeanShift
import matplotlib.pyplot as plt
from matplotlib import style
style.use("ggplot")
from sklearn.datasets.samples_generator import make_blobs
centers = [[3,3,3],[4,5,5],[3,10,10]]
X, _ = make_blobs(n_samples = 700, centers = centers, cluster_std = 0.5)
plt.scatter(X[:,0],X[:,1])
plt.show()
ms = MeanShift()
ms.fit(X)
labels = ms.labels_
cluster_centers = ms.cluster_centers_
print(cluster_centers)
n_clusters_ = len(np.unique(labels))
print("Estimated clusters:", n_clusters_)
colors = 10*['r.','g.','b.','c.','k.','y.','m.']
for i in range(len(X)):
    plt.plot(X[i][0], X[i][1], colors[labels[i]], markersize = 3)
plt.scatter(cluster_centers[:,0],cluster_centers[:,1],
    marker=".",color='k', s=20, linewidths = 5, zorder=10)
plt.show()

उत्पादन

[[ 2.98462798 9.9733794 10.02629344]
[ 3.94758484 4.99122771 4.99349433]
[ 3.00788996 3.03851268 2.99183033]]
Estimated clusters: 3

फायदे और नुकसान

लाभ

मीन-शिफ्ट क्लस्टरिंग एल्गोरिथ्म के कुछ फायदे निम्नलिखित हैं -

  • इसे K- माध्य या गौसियन मिश्रण की तरह किसी भी मॉडल को बनाने की आवश्यकता नहीं है।

  • यह उन जटिल समूहों को भी मॉडल कर सकता है जिनके पास गैर-आकार है।

  • इसे केवल बैंडविड्थ नाम के एक पैरामीटर की आवश्यकता होती है जो स्वचालित रूप से क्लस्टर की संख्या निर्धारित करता है।

  • K- साधनों की तरह स्थानीय मिनीमाता का कोई मुद्दा नहीं है।

  • आउटलेयर से कोई समस्या उत्पन्न नहीं हुई।

नुकसान

मीन-शिफ्ट क्लस्टरिंग एल्गोरिदम के कुछ नुकसान निम्नलिखित हैं -

मीन-शिफ्ट एल्गोरिथ्म उच्च आयाम के मामले में अच्छी तरह से काम नहीं करता है, जहां क्लस्टर की संख्या अचानक बदल जाती है।

  • क्लस्टर की संख्या पर हमारा कोई सीधा नियंत्रण नहीं है लेकिन कुछ अनुप्रयोगों में, हमें एक विशिष्ट संख्या में क्लस्टर की आवश्यकता होती है।

  • यह सार्थक और अर्थहीन मोड के बीच अंतर नहीं कर सकता है।