एच 2 ओ - ऑटोएमएल

AutoML का उपयोग करने के लिए, एक नया Jupyter नोटबुक शुरू करें और नीचे दिखाए गए चरणों का पालन करें।

AutoML आयात कर रहा है

निम्नलिखित दो कथनों का उपयोग करके परियोजना में पहले H2O और AutoML पैकेज का आयात करें -

import h2o
from h2o.automl import H2OAutoML

H2O को प्रारंभ करें

निम्नलिखित कथन का उपयोग करके h2o को प्रारंभ करें -

h2o.init()

आपको स्क्रीन पर क्लस्टर जानकारी देखनी चाहिए जैसा कि नीचे स्क्रीनशॉट में दिखाया गया है -

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

हम उसी iris.csv डेटासेट का उपयोग करेंगे जिसका उपयोग आपने पहले इस ट्यूटोरियल में किया था। निम्नलिखित कथन का उपयोग कर डेटा लोड करें -

data = h2o.import_file('iris.csv')

डेटासेट तैयार करना

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

features = ['sepal_length', 'sepal_width', 'petal_length', 'petal_width']
output = 'class'

प्रशिक्षण और परीक्षण के लिए 80:20 अनुपात में डेटा विभाजित करें -

train, test = data.split_frame(ratios=[0.8])

ऑटोएमएल लागू करना

अब, हम अपने डेटासेट पर AutoML लागू करने के लिए पूरी तरह तैयार हैं। ऑटोएमएल हमारे द्वारा निर्धारित समय के लिए चलेगा और हमें अनुकूलित मॉडल देगा। हमने निम्नलिखित कथन का उपयोग करते हुए AutoML की स्थापना की -

aml = H2OAutoML(max_models = 30, max_runtime_secs=300, seed = 1)

पहला पैरामीटर उन मॉडलों की संख्या निर्दिष्ट करता है जिन्हें हम मूल्यांकन और तुलना करना चाहते हैं।

दूसरा पैरामीटर उस समय को निर्दिष्ट करता है जिसके लिए एल्गोरिथ्म चलता है।

अब हम यहां दिखाए गए अनुसार AutoML ऑब्जेक्ट पर ट्रेन विधि कहते हैं -

aml.train(x = features, y = output, training_frame = train)

हम एक्स को उन विशेषताओं सरणी के रूप में निर्दिष्ट करते हैं जो हमने पहले बनाई थी, y अनुमानित मान और डेटाफ़्रेम को इंगित करने के लिए आउटपुट चर के रूप में वाई train डाटासेट।

कोड चलाएं, आपको 5 मिनट तक इंतजार करना होगा (जब तक आप निम्नलिखित आउटपुट प्राप्त नहीं करते हैं, हम अधिकतम_रंटटाइम_सैक 300 तक सेट करते हैं) -

लीडरबोर्ड छपाई

जब ऑटोएमएल प्रसंस्करण पूरा हो जाता है, तो यह उन सभी 30 एल्गोरिदम को रैंकिंग करने वाला लीडरबोर्ड बनाता है जिसका उसने मूल्यांकन किया है। लीडरबोर्ड के पहले 10 रिकॉर्ड देखने के लिए, निम्नलिखित कोड का उपयोग करें -

lb = aml.leaderboard
lb.head()

निष्पादन पर, उपरोक्त कोड निम्नलिखित आउटपुट उत्पन्न करेगा -

स्पष्ट रूप से, DeepLearning एल्गोरिथ्म को अधिकतम अंक मिला है।

टेस्ट डेटा पर निर्भर

अब, आपके पास रैंक वाले मॉडल हैं, आप अपने परीक्षण डेटा पर टॉप-रेटेड मॉडल का प्रदर्शन देख सकते हैं। ऐसा करने के लिए, निम्नलिखित कोड स्टेटमेंट चलाएं -

preds = aml.predict(test)

प्रसंस्करण थोड़ी देर तक जारी रहता है और पूरा होने पर आपको निम्न आउटपुट दिखाई देगा।

मुद्रण परिणाम

निम्नलिखित कथन का उपयोग करके अनुमानित परिणाम प्रिंट करें -

print (preds)

उपरोक्त कथन के निष्पादन पर, आप निम्नलिखित परिणाम देखेंगे -

सभी के लिए रैंकिंग मुद्रण

यदि आप सभी परीक्षण किए गए एल्गोरिदम की रैंक देखना चाहते हैं, तो निम्न कोड स्टेटमेंट चलाएं -

lb.head(rows = lb.nrows)

उपरोक्त कथन के निष्पादन पर, निम्नलिखित आउटपुट उत्पन्न होंगे (आंशिक रूप से दिखाए गए) -

निष्कर्ष

एच 2 ओ किसी दिए गए डेटासेट पर विभिन्न एमएल एल्गोरिदम को लागू करने के लिए एक आसान-से-खुला उपयोग स्रोत मंच प्रदान करता है। यह गहरी शिक्षा सहित कई सांख्यिकीय और एमएल एल्गोरिदम प्रदान करता है। परीक्षण के दौरान, आप इन एल्गोरिदम के मापदंडों को ठीक कर सकते हैं। आप कमांड-लाइन या फ़्लो नामक वेब-आधारित इंटरफ़ेस का उपयोग करके ऐसा कर सकते हैं। H2O भी AutoML का समर्थन करता है जो उनके प्रदर्शन के आधार पर कई एल्गोरिदम के बीच रैंकिंग प्रदान करता है। H2O बिग डाटा पर भी अच्छा प्रदर्शन करता है। यह निश्चित रूप से डेटा साइंटिस्ट के लिए अपने डेटासेट पर विभिन्न मशीन लर्निंग मॉडल लागू करने और उनकी जरूरतों को पूरा करने के लिए सबसे अच्छा लेने के लिए एक वरदान है।