एमएल मॉडल के प्रदर्शन में सुधार

एन्सेम्बल के साथ प्रदर्शन में सुधार

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

अनुक्रमिक कलाकारों की टुकड़ी तरीकों

जैसा कि नाम से पता चलता है, इस तरह के कलाकारों की टुकड़ी के तरीकों में, आधार सीखने वाले क्रमिक रूप से उत्पन्न होते हैं। इस तरह के तरीकों की प्रेरणा आधार शिक्षार्थियों के बीच निर्भरता का शोषण करना है।

समानांतर पहनावा तरीके

जैसा कि नाम से पता चलता है, इस तरह के पहनावा के तरीकों में, आधार सीखने वाले समानांतर में उत्पन्न होते हैं। इस तरह के तरीकों की प्रेरणा आधार शिक्षार्थियों के बीच स्वतंत्रता का शोषण करना है।

सीखने के तरीके को सुनिश्चित करें

निम्नलिखित सबसे लोकप्रिय पहनावा सीखने के तरीके हैं अर्थात विभिन्न मॉडलों से भविष्यवाणियों के संयोजन के तरीके -

ऊलजलूल का कपड़ा

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

बढ़ाने

बढ़ावा देने की विधि में, पहनावा मॉडल के निर्माण का मुख्य सिद्धांत क्रमिक रूप से प्रत्येक आधार मॉडल अनुमानक को प्रशिक्षित करके इसे बढ़ाना है। जैसा कि नाम से पता चलता है, यह मूल रूप से कई सप्ताह आधार शिक्षार्थियों को जोड़ती है, शक्तिशाली पहनावा बनाने के लिए, प्रशिक्षण डेटा के कई पुनरावृत्तियों पर क्रमिक रूप से प्रशिक्षित होता है। सप्ताह के आधार शिक्षार्थियों के प्रशिक्षण के दौरान, उच्च भार उन शिक्षार्थियों को सौंपा जाता है जो पहले मिसकैरेज किए गए थे। बूस्टिंग विधि का उदाहरण AdaBoost है।

मतदान

इस पहनावा सीखने के मॉडल में, विभिन्न प्रकार के कई मॉडल बनाए जाते हैं और कुछ सरल आँकड़े, जैसे कि माध्य या माध्यिका आदि की गणना की जाती है, भविष्यवाणियों को संयोजित करने के लिए उपयोग किया जाता है। यह भविष्यवाणी अंतिम भविष्यवाणी करने के लिए प्रशिक्षण के लिए अतिरिक्त इनपुट के रूप में काम करेगी।

बैजिंग एन्सेंबल एल्गोरिदम

निम्नलिखित तीन बैगिंग एनगेंबेल एल्गोरिदम हैं -

तय किया हुआ वृक्ष

जैसा कि हम जानते हैं कि बैगेज एंबेडेड तरीके उन एल्गोरिदम के साथ अच्छी तरह से काम करते हैं जिनमें उच्च विचरण होता है और, इस चिंता में, सबसे अच्छा एक ट्री एल्गोरिदम का निर्णय लिया जाता है। निम्नलिखित पायथन रेसिपी में, हम पाइमा इंडियन्स डायबिटीज डेटासेट पर DecisionTreeClasifier (एक वर्गीकरण और प्रतिगमन ट्री एल्गोरिथ्म) के साथ स्केलेर के बैगिंगक्लासीफायर फ़ंक्शन का उपयोग करके बैगेड डिसाइड ट्री एन्सेम्बल मॉडल बनाने जा रहे हैं।

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

from pandas import read_csv
from sklearn.model_selection import KFold
from sklearn.model_selection import cross_val_score
from sklearn.ensemble import BaggingClassifier
from sklearn.tree import DecisionTreeClassifier

अब, हमें पहले उदाहरणों में किए गए पेमा डायबिटीज डेटासेट को लोड करना होगा -

path = r"C:\pima-indians-diabetes.csv"
headernames = ['preg', 'plas', 'pres', 'skin', 'test', 'mass', 'pedi', 'age', 'class']
data = read_csv(path, names=headernames)
array = data.values
X = array[:,0:8]
Y = array[:,8]

अगला, 10 गुना क्रॉस सत्यापन के लिए इनपुट इस प्रकार दें -

seed = 7
kfold = KFold(n_splits=10, random_state=seed)
cart = DecisionTreeClassifier()

हमें उन पेड़ों की संख्या प्रदान करने की आवश्यकता है जिन्हें हम बनाने जा रहे हैं। यहाँ हम 150 पेड़ बना रहे हैं -

num_trees = 150

अगला, निम्नलिखित स्क्रिप्ट की मदद से मॉडल बनाएं -

model = BaggingClassifier(base_estimator=cart, n_estimators=num_trees, random_state=seed)

परिणाम की गणना और प्रिंट निम्न प्रकार है -

results = cross_val_score(model, X, Y, cv=kfold)
print(results.mean())

उत्पादन

0.7733766233766234

ऊपर दिए गए आउटपुट से पता चलता है कि हमें अपने बैगेड डिसीजन ट्री क्लासिफायर मॉडल की 77% सटीकता प्राप्त हुई।

बेतरतीब जंगल

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

निम्नलिखित पायथन रेसिपी में, हम पिमा इंडियन्स डायबिटीज डेटासेट पर स्केलेर के रैंडमफोरेस्ट क्लैसिफायर वर्ग का उपयोग करके बैगेड रैंडम फॉरेस्ट एसेम्बल मॉडल बनाने जा रहे हैं।

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

from pandas import read_csv
from sklearn.model_selection import KFold
from sklearn.model_selection import cross_val_score
from sklearn.ensemble import RandomForestClassifier

अब, हमें पहले उदाहरणों के अनुसार पीमा डायबिटीज डेटासेट लोड करने की आवश्यकता है -

path = r"C:\pima-indians-diabetes.csv"
headernames = ['preg', 'plas', 'pres', 'skin', 'test', 'mass', 'pedi', 'age', 'class']
data = read_csv(path, names=headernames)
array = data.values
X = array[:,0:8]
Y = array[:,8]

अगला, 10 गुना क्रॉस सत्यापन के लिए इनपुट इस प्रकार दें -

seed = 7
kfold = KFold(n_splits=10, random_state=seed)

हमें उन पेड़ों की संख्या प्रदान करने की आवश्यकता है जिन्हें हम बनाने जा रहे हैं। यहां हम 5 सुविधाओं से चुने गए विभाजन बिंदुओं के साथ 150 पेड़ बना रहे हैं -

num_trees = 150
max_features = 5

अगला, निम्नलिखित स्क्रिप्ट की मदद से मॉडल बनाएं -

model = RandomForestClassifier(n_estimators=num_trees, max_features=max_features)

परिणाम की गणना और प्रिंट निम्न प्रकार है -

results = cross_val_score(model, X, Y, cv=kfold)
print(results.mean())

उत्पादन

0.7629357484620642

ऊपर दिए गए आउटपुट से पता चलता है कि हमें अपने बैगर्ड रैंडम फॉरेस्ट क्लासिफायर मॉडल की 76% सटीकता प्राप्त हुई।

अतिरिक्त पेड़

यह बैगेड डिसीजन ट्री एन्सेम्बल विधि का एक और विस्तार है। इस पद्धति में यादृच्छिक वृक्षों का निर्माण प्रशिक्षण डेटासेट के नमूनों से किया जाता है।

निम्नलिखित पायथन रेसिपी में, हम पेमा इंडियन्स डायबिटीज डेटासेट पर स्केलेरेंट के एक्स्ट्राट्रीक्लासफाइटर क्लास का उपयोग करके अतिरिक्त ट्री एनसेम्बल मॉडल बनाने जा रहे हैं।

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

from pandas import read_csv
from sklearn.model_selection import KFold
from sklearn.model_selection import cross_val_score
from sklearn.ensemble import ExtraTreesClassifier

अब, हमें पहले उदाहरणों के अनुसार पीमा डायबिटीज डेटासेट लोड करने की आवश्यकता है -

path = r"C:\pima-indians-diabetes.csv"
headernames = ['preg', 'plas', 'pres', 'skin', 'test', 'mass', 'pedi', 'age', 'class']
data = read_csv(path, names=headernames)
array = data.values
X = array[:,0:8]
Y = array[:,8]

अगला, 10 गुना क्रॉस सत्यापन के लिए इनपुट इस प्रकार दें -

seed = 7
kfold = KFold(n_splits=10, random_state=seed)

हमें उन पेड़ों की संख्या प्रदान करने की आवश्यकता है जिन्हें हम बनाने जा रहे हैं। यहां हम 5 सुविधाओं से चुने गए विभाजन बिंदुओं के साथ 150 पेड़ बना रहे हैं -

num_trees = 150
max_features = 5

अगला, निम्नलिखित स्क्रिप्ट की मदद से मॉडल बनाएं -

model = ExtraTreesClassifier(n_estimators=num_trees, max_features=max_features)

परिणाम की गणना और प्रिंट निम्न प्रकार है -

results = cross_val_score(model, X, Y, cv=kfold)
print(results.mean())

उत्पादन

0.7551435406698566

ऊपर दिए गए आउटपुट से पता चलता है कि हमें अपने बैगेज एक्स्ट्रा ट्री क्लासिफायर मॉडल की लगभग 75.5% सटीकता प्राप्त हुई।

बूस्टिंग एंब्रॉयडरी एल्गोरिदम

अनुवर्ती दो सबसे आम बूस्टिंग एल्गोरिदम हैं -

AdaBoost

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

निम्नलिखित पायथन रेसिपी में, हम पेमा इंडियन्स डायबिटीज डेटासेट पर स्केलेरन के AdaBoostClassifier वर्ग का उपयोग करके वर्गीकरण के लिए Ada Boost कलाकारों की टुकड़ी मॉडल बनाने जा रहे हैं।

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

from pandas import read_csv
from sklearn.model_selection import KFold
from sklearn.model_selection import cross_val_score
from sklearn.ensemble import AdaBoostClassifier

अब, हमें पहले उदाहरणों के अनुसार पीमा डायबिटीज डेटासेट लोड करने की आवश्यकता है -

path = r"C:\pima-indians-diabetes.csv"
headernames = ['preg', 'plas', 'pres', 'skin', 'test', 'mass', 'pedi', 'age', 'class']
data = read_csv(path, names=headernames)
array = data.values
X = array[:,0:8]
Y = array[:,8]

अगला, 10 गुना क्रॉस सत्यापन के लिए इनपुट इस प्रकार दें -

seed = 5
kfold = KFold(n_splits=10, random_state=seed)

हमें उन पेड़ों की संख्या प्रदान करने की आवश्यकता है जिन्हें हम बनाने जा रहे हैं। यहां हम 5 सुविधाओं से चुने गए विभाजन बिंदुओं के साथ 150 पेड़ बना रहे हैं -

num_trees = 50

अगला, निम्नलिखित स्क्रिप्ट की मदद से मॉडल बनाएं -

model = AdaBoostClassifier(n_estimators=num_trees, random_state=seed)

परिणाम की गणना और प्रिंट निम्न प्रकार है -

results = cross_val_score(model, X, Y, cv=kfold)
print(results.mean())

उत्पादन

0.7539473684210527

ऊपर दिए गए आउटपुट से पता चलता है कि हमें अपने AdaBoost क्लासिफायर पहनावा मॉडल के लगभग 75% सटीकता मिली।

स्टोचैस्टिक ग्रेडिंग बूस्टिंग

इसे ग्रेडिएंट बूस्टिंग मशीनें भी कहा जाता है। निम्नलिखित पायथॉन रेसिपी में, हम पिमा इंडियन्स डायबिटीज डेटासेट पर Sklearn के GradientBoostingClassifier वर्ग का उपयोग करके वर्गीकरण के लिए Stochastic Gradient Boostingensemble मॉडल बनाने जा रहे हैं।

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

from pandas import read_csv
from sklearn.model_selection import KFold
from sklearn.model_selection import cross_val_score
from sklearn.ensemble import GradientBoostingClassifier

अब, हमें पहले उदाहरणों के अनुसार पीमा डायबिटीज डेटासेट लोड करने की आवश्यकता है -

path = r"C:\pima-indians-diabetes.csv"
headernames = ['preg', 'plas', 'pres', 'skin', 'test', 'mass', 'pedi', 'age', 'class']
data = read_csv(path, names=headernames)
array = data.values
X = array[:,0:8]
Y = array[:,8]

अगला, 10 गुना क्रॉस सत्यापन के लिए इनपुट इस प्रकार दें -

seed = 5
kfold = KFold(n_splits=10, random_state=seed)

हमें उन पेड़ों की संख्या प्रदान करने की आवश्यकता है जिन्हें हम बनाने जा रहे हैं। यहां हम 5 सुविधाओं से चुने गए विभाजन बिंदुओं के साथ 150 पेड़ बना रहे हैं -

num_trees = 50

अगला, निम्नलिखित स्क्रिप्ट की मदद से मॉडल बनाएं -

model = GradientBoostingClassifier(n_estimators=num_trees, random_state=seed)

परिणाम की गणना और प्रिंट निम्न प्रकार है -

results = cross_val_score(model, X, Y, cv=kfold)
print(results.mean())

उत्पादन

0.7746582365003418

ऊपर दिए गए आउटपुट से पता चलता है कि हमें अपने ग्रेडिएंट बूस्टिंग क्लासिफायर पहनावा मॉडल की 77.5% सटीकता प्राप्त हुई।

वोटिंग एन्सेम्बल एल्गोरिदम

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

निम्नलिखित पायथन रेसिपी में, हम पिमा इंडियन्स डायबिटीज डेटासेट पर स्केलेरन के वोटिंगक्लासीफायर वर्ग का उपयोग करके वर्गीकरण के लिए वोटिंग एनसेंबल मॉडल बनाने जा रहे हैं। हम लॉजिस्टिक रिग्रेशन, डिसीजन ट्री क्लासिफायर और एसवीएम की भविष्यवाणियों को एक वर्गीकरण समस्या के लिए एक साथ जोड़ रहे हैं -

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

from pandas import read_csv
from sklearn.model_selection import KFold
from sklearn.model_selection import cross_val_score
from sklearn.linear_model import LogisticRegression
from sklearn.tree import DecisionTreeClassifier
from sklearn.svm import SVC
from sklearn.ensemble import VotingClassifier

अब, हमें पहले उदाहरणों के अनुसार पीमा डायबिटीज डेटासेट लोड करने की आवश्यकता है -

path = r"C:\pima-indians-diabetes.csv"
headernames = ['preg', 'plas', 'pres', 'skin', 'test', 'mass', 'pedi', 'age', 'class']
data = read_csv(path, names=headernames)
array = data.values
X = array[:,0:8]
Y = array[:,8]

अगला, 10 गुना क्रॉस सत्यापन के लिए इनपुट इस प्रकार दें -

kfold = KFold(n_splits=10, random_state=7)

इसके बाद, हमें उप-मॉडल बनाने की आवश्यकता है -

estimators = []
model1 = LogisticRegression()
estimators.append(('logistic', model1))
model2 = DecisionTreeClassifier()
estimators.append(('cart', model2))
model3 = SVC()
estimators.append(('svm', model3))

अब, उप-निर्मित उप-मॉडल के पूर्वानुमानों को जोड़कर मतदान पहनावा मॉडल बनाएं।

ensemble = VotingClassifier(estimators)
results = cross_val_score(ensemble, X, Y, cv=kfold)
print(results.mean())

उत्पादन

0.7382262474367738

ऊपर दिए गए आउटपुट से पता चलता है कि हमें अपने वोटिंग क्लासिफ़ायर पहनावा मॉडल की लगभग 74% सटीकता प्राप्त हुई।