अपाचे एमएक्सनेट - टूलकिट्स और इकोसिस्टम

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

उपकरणकिटें

एमएक्सनेट द्वारा प्रदान किए गए कुछ सबसे महत्वपूर्ण और महत्वपूर्ण टूलकिट निम्नलिखित हैं -

GluonCV

जैसा कि नाम से स्पष्ट है कि GluonCV MXNet द्वारा संचालित कंप्यूटर विज़न के लिए एक Gluon टूलकिट है। यह कंप्यूटर दृष्टि (सीवी) में अत्याधुनिक डीएल (डीप लर्निंग) एल्गोरिदम का कार्यान्वयन प्रदान करता है। GluonCV टूलकिट इंजीनियरों की मदद से, शोधकर्ता और छात्र नए विचारों को मान्य कर सकते हैं और आसानी से सीवी सीख सकते हैं।

नीचे कुछ दिए गए हैं features of GluonCV -

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

  • 170+ से अधिक उच्च गुणवत्ता वाले ढाँचे वाले मॉडल।

  • लचीले विकास पैटर्न को अपनाएं।

  • GluonCV को अनुकूलित करना आसान है। हम इसे भारी वजन डीएल ढांचे को बनाए रखने के बिना तैनात कर सकते हैं।

  • यह ध्यान से डिज़ाइन किए गए एपीआई प्रदान करता है जो कार्यान्वयन की जटिलता को बहुत कम करते हैं।

  • सामुदायिक समर्थन।

  • कार्यान्वयन को समझने में आसान।

निम्नलिखित हैं supported applications GluonCV टूलकिट द्वारा:

  • छवि वर्गीकरण

  • ऑब्जेक्ट डिटेक्शन

  • शब्दार्थ विभाजन

  • उदाहरण खंड

  • अनुमान लगाएं

  • वीडियो एक्शन मान्यता

हम निम्नानुसार पाइप का उपयोग करके GluonCV स्थापित कर सकते हैं -

pip install --upgrade mxnet gluoncv

GluonNLP

जैसा कि नाम से स्पष्ट है कि GluonNLP MXNet द्वारा संचालित प्राकृतिक भाषा प्रसंस्करण (NLP) के लिए एक Gluon टूलकिट है। यह एनएलपी में अत्याधुनिक डीएल (डीप लर्निंग) मॉडल का कार्यान्वयन प्रदान करता है।

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

नीचे दी गई कुछ विशेषताएं ग्लूएनएनएलपी की हैं:

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

  • सामान्य एनएलपी कार्यों के लिए प्रिटेंडेड मॉडल का सेट।

  • यह ध्यान से डिज़ाइन किए गए एपीआई प्रदान करता है जो कार्यान्वयन की जटिलता को बहुत कम करते हैं।

  • सामुदायिक समर्थन।

  • यह आपको नए एनएलपी कार्यों को शुरू करने में मदद करने के लिए ट्यूटोरियल भी प्रदान करता है।

एनएलपी कार्य निम्नलिखित हैं जिन्हें हम ग्लूएनएनएलपी टूलकिट के साथ लागू कर सकते हैं -

  • शब्द एंबेडिंग

  • भाषा मॉडल

  • मशीन अनुवाद

  • पाठ वर्गीकरण

  • भावनाओं का विश्लेषण

  • प्राकृतिक भाषा का आविष्कार

  • टेक्स्ट जनरेशन

  • निर्भरता पार्सिंग

  • जिसका नाम एंटिटी रिकग्निशन रखा गया है

  • आशय वर्गीकरण और स्लॉट लेबलिंग

हम निम्नानुसार पाइप का उपयोग करके ग्लूएनएनएलपी स्थापित कर सकते हैं -

pip install --upgrade mxnet gluonnlp

GluonTS

जैसा कि नाम से स्पष्ट है कि GluonTS, MXNet द्वारा संचालित प्रोबेबिलिस्टिक टाइम सीरीज़ मॉडलिंग के लिए एक Gluon टूलकिट है।

यह निम्नलिखित सुविधाएँ प्रदान करता है -

  • अत्याधुनिक (एसओटीए) प्रशिक्षण प्राप्त करने के लिए तैयार गहन शिक्षण मॉडल।

  • लोडिंग के लिए उपयोगिताओं के साथ-साथ समय-श्रृंखला डेटासेट पर चलना।

  • अपने खुद के मॉडल को परिभाषित करने के लिए बिल्डिंग ब्लॉक।

GluonTS टूलकिट इंजीनियरों, शोधकर्ताओं और छात्रों की मदद से अपने स्वयं के डेटा पर किसी भी अंतर्निहित मॉडल का प्रशिक्षण और मूल्यांकन कर सकते हैं, जल्दी से विभिन्न समाधानों के साथ प्रयोग कर सकते हैं, और अपने समय श्रृंखला कार्यों के समाधान के साथ आ सकते हैं।

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

हम निम्नानुसार पाइप का उपयोग करके GluonTS स्थापित कर सकते हैं -

pip install gluonts

GluonFR

जैसा कि नाम से ही स्पष्ट है, यह एफआर (फेस रिकॉग्निशन) के लिए अपाचे एमएक्सनेट ग्लोन टूलकिट है। यह निम्नलिखित सुविधाएँ प्रदान करता है -

  • चेहरे की पहचान में अत्याधुनिक शिक्षण मॉडल (SOTA)।

  • SoftmaxCrossEntropyLoss, ArcLoss, TripletLoss, RingLoss, CosLoss / AMsoftmax, L2-Softmax, A-Softmax, CenterLoss, ContemiveLoss, और LGM Loss, आदि का कार्यान्वयन।

Gluon Face को स्थापित करने के लिए, हमें Python 3.5 या बाद की आवश्यकता है। हमें भी सबसे पहले GluonCV और MXNet स्थापित करने की आवश्यकता है -

pip install gluoncv --pre
pip install mxnet-mkl --pre --upgrade
pip install mxnet-cuXXmkl --pre –upgrade # if cuda XX is installed

एक बार जब आप निर्भरता स्थापित करते हैं, तो आप GluonFR को स्थापित करने के लिए निम्न कमांड का उपयोग कर सकते हैं -

From Source

pip install git+https://github.com/THUFutureLab/gluon-face.git@master

Pip

pip install gluonfr

पारिस्थितिकी तंत्र

अब हमें MXNet के समृद्ध पुस्तकालयों, पैकेजों और रूपरेखाओं का पता लगाने दें -

कोच आर.एल.

कोच, AI AI लैब द्वारा बनाया गया पायथन रीइनफोर्समेंट लर्निंग (RL) ढांचा। यह अत्याधुनिक आरएल एल्गोरिदम के साथ आसान प्रयोग को सक्षम बनाता है। कोच आरएल बैक के अंत के रूप में अपाचे एमएक्सनेट का समर्थन करता है और नए वातावरण के सरल एकीकरण को हल करने की अनुमति देता है।

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

कोच आरएल ढांचे के लिए एजेंट और समर्थित एल्गोरिदम निम्नलिखित हैं -

मूल्य अनुकूलन एजेंट

  • डीप क्यू नेटवर्क (DQN)

  • डबल डीप क्यू नेटवर्क (DDQN)

  • द्वंद्व क्यू नेटवर्क

  • मिश्रित मोंटे कार्लो (MMC)

  • निरंतर लाभ सीखना (पाल)

  • श्रेणीबद्ध डीप क्यू नेटवर्क (C51)

  • मात्रात्मक प्रतिगमन डीप क्यू नेटवर्क (QR-DQN)

  • एन-स्टेप क्यू लर्निंग

  • तंत्रिका संबंधी नियंत्रण (एनईसी)

  • सामान्यीकृत लाभ कार्य (एनएएफ)

  • Rainbow

नीति अनुकूलन एजेंट

  • नीति स्नातक (PG)

  • अतुल्यकालिक लाभ अभिनेता-आलोचक (A3C)

  • दीप निर्धारक नीति स्नातक (DDPG)

  • समीपस्थ नीति अनुकूलन (पीपीओ)

  • प्रोक्सिमल पॉलिसी ऑप्टिमाइज़ेशन (CPPO)

  • सामान्यीकृत लाभ अनुमान (GAE)

  • एक्सपीरिएंस रीप्ले (ACER) के साथ सैंपल एफिशिएंट एक्टर-क्रिटिक

  • सॉफ्ट एक्टर-क्रिटिक (SAC)

  • जुड़वां विलंबित गहरी निर्धारक नीति स्नातक (TD3)

सामान्य एजेंट

  • प्रत्यक्ष भविष्य की भविष्यवाणी (DFP)

इमीटेशन लर्निंग एजेंट्स

  • व्यवहार प्रतिरूपण (BC)

  • सशर्त नकल सीखना

पदानुक्रमित सुदृढीकरण सीखना एजेंट

  • पदानुक्रमित अभिनेता आलोचक (HAC)

डीप ग्राफ लाइब्रेरी

एनवाईयू और एडब्ल्यूएस टीमों, शंघाई द्वारा विकसित डीप ग्राफ लाइब्रेरी (डीजीएल), एक पायथन पैकेज है जो एमएक्सनेट के शीर्ष पर ग्राफ न्यूरल नेटवर्क्स (जीएनएन) का आसान कार्यान्वयन प्रदान करता है। यह PyTorch, Gluon, इत्यादि जैसे अन्य प्रमुख गहरे शिक्षण पुस्तकालयों के शीर्ष पर GNN का आसान कार्यान्वयन प्रदान करता है।

डीप ग्राफ लाइब्रेरी एक मुफ्त सॉफ्टवेयर है। यह Ubuntu 16.04, macOS X, और विंडोज 7 या बाद के सभी लिनक्स वितरण पर उपलब्ध है। इसे पायथन 3.5 संस्करण या बाद के संस्करण की भी आवश्यकता है।

डीजीएल की विशेषताएं निम्नलिखित हैं -

No Migration cost - डीजीएल का उपयोग करने के लिए कोई माइग्रेशन लागत नहीं है क्योंकि यह लोकप्रिय एक्साइटिंग डीएल फ्रेमवर्क के शीर्ष पर बनाया गया है।

Message Passing- DGL संदेश पासिंग प्रदान करता है और इस पर बहुमुखी नियंत्रण है। यह संदेश निम्न-स्तरीय परिचालनों से होता है जैसे चयनित किनारों को उच्च-स्तरीय नियंत्रण में भेजना जैसे कि ग्राफ़-वाइड फ़ीचर अपडेट।

Smooth Learning Curve - DGL सीखना और उपयोग करना काफी आसान है क्योंकि शक्तिशाली उपयोगकर्ता-परिभाषित फ़ंक्शन लचीले होने के साथ-साथ उपयोग करने में आसान हैं।

Transparent Speed Optimization - DGL कम्प्यूटेशंस और स्पार्स मैट्रिक्स गुणन की स्वचालित बैचिंग करके पारदर्शी गति अनुकूलन प्रदान करता है।

High performance - अधिकतम दक्षता प्राप्त करने के लिए, DGL स्वचालित रूप से एक या कई ग्राफ़ पर एक साथ DNN (डीप न्यूरल नेटवर्क) ट्रेनिंग को बैच देता है।

Easy & friendly interface - DGL हमें एज फीचर एक्सेस के साथ-साथ ग्राफ संरचना में हेरफेर के लिए आसान और अनुकूल इंटरफेस प्रदान करता है।

InsightFace

इनसाइटफेस, फेस एनालिसिस के लिए एक डीप लर्निंग टूलकिट जो एमएक्सनेट द्वारा संचालित कंप्यूटर विजन में एसओटीए (अत्याधुनिक) फेस एनालिसिस एल्गोरिदम को लागू करता है। यह प्रदान करता है -

  • पूर्व-प्रशिक्षित मॉडल के उच्च-गुणवत्ता वाले बड़े सेट।

  • अत्याधुनिक स्क्रिप्ट (एसओटीए) प्रशिक्षण स्क्रिप्ट।

  • InsightFace को ऑप्टिमाइज़ करना आसान है। हम इसे भारी वजन डीएल ढांचे को बनाए रखने के बिना तैनात कर सकते हैं।

  • यह ध्यान से डिज़ाइन किए गए एपीआई प्रदान करता है जो कार्यान्वयन की जटिलता को बहुत कम करते हैं।

  • अपने खुद के मॉडल को परिभाषित करने के लिए बिल्डिंग ब्लॉक।

हम पाइप का उपयोग करके इनसाइटफेस को निम्नानुसार स्थापित कर सकते हैं -

pip install --upgrade insightface

कृपया ध्यान दें कि InsightFace स्थापित करने से पहले, कृपया अपने सिस्टम कॉन्फ़िगरेशन के अनुसार सही MXNet पैकेज स्थापित करें।

Keras-MXNet

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

Keras-MXNet की विशेषताएं नीचे उल्लिखित हैं -

  • उपयोगकर्ताओं को आसान, सहज और तेज़ प्रोटोटाइप के लिए अनुमति देता है। यह सब उपयोगकर्ता मित्रता, प्रतिरूपकता, और विस्तारशीलता के माध्यम से होता है।

  • दोनों CNN (कन्वीनियनल न्यूरल नेटवर्क्स) और RNN (रीक्रिएट न्यूरल नेटवर्क्स) और साथ ही दोनों के संयोजन का भी समर्थन करता है।

  • सेंट्रल प्रोसेसिंग यूनिट (सीपीयू) और ग्राफिकल प्रोसेसिंग यूनिट (जीपीयू) दोनों पर दोषपूर्ण तरीके से चलता है।

  • एक या मल्टी जीपीयू पर चल सकता है।

इस बैकएंड के साथ काम करने के लिए, आपको सबसे पहले keras-mxnet स्थापित करने की आवश्यकता है -

pip install keras-mxnet

अब, यदि आप GPU का उपयोग कर रहे हैं, तो CUDA 9 समर्थन के साथ MXNet स्थापित करें -

pip install mxnet-cu90

लेकिन अगर आप सीपीयू का उपयोग कर रहे हैं, तो मूल एमएक्सनेट को निम्नानुसार स्थापित करें -

pip install mxnet

MXBoard

MXBoard एक लॉगिंग टूल है, जिसे Python में लिखा गया है, जिसका उपयोग MXNet डेटा फ़्रेम को रिकॉर्ड करने और TensorBardard में प्रदर्शित करने के लिए किया जाता है। दूसरे शब्दों में, MXBoard का अर्थ टेंसोरबोर्ड-पाइटरॉच एपीआई का पालन करना है। यह TensorBoard में अधिकांश डेटा प्रकारों का समर्थन करता है।

उनमें से कुछ नीचे वर्णित हैं -

  • Graph

  • Scalar

  • Histogram

  • Embedding

  • Image

  • Text

  • Audio

  • प्रेसिजन-रिकॉल कर्व

MXFusion

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

MXFusion को Python संस्करण 3.4 और MacOS और Linux OS पर अधिक सत्यापित किया गया है। एमएक्सफ़्यूज़न स्थापित करने के लिए, हमें पहले निम्न निर्भरताएँ स्थापित करनी होंगी -

  • एमएक्सनेट> = 1.3

  • Networkx> = 2.1

निम्नलिखित पाइप कमांड की सहायता से, आप एमएक्सफ़्यूज़न स्थापित कर सकते हैं -

pip install mxfusion

TVM

अपाचे टीवीएम, सीपीयू, जीपीयू और विशेष त्वरक जैसे हार्डवेयर-बैकएंड के लिए एक ओपन-सोर्स एंड-टू-एंड डीप लर्निंग कंपाइलर स्टैक है, जिसका उद्देश्य उत्पादकता-केंद्रित गहरी-सीखने की रूपरेखा और प्रदर्शन उन्मुख उन्मुख बैकेंड के बीच की खाई को भरना है। । नवीनतम रिलीज़ एमएक्सनेट 1.6.0 के साथ, उपयोगकर्ता पायथन प्रोग्रामिंग भाषा में उच्च-प्रदर्शन ऑपरेटर कर्नेल को लागू करने के लिए अपाचे (इनक्यूबेटिंग) टीवीएम का लाभ उठा सकते हैं।

अपाचे TVM वास्तव में वाशिंगटन विश्वविद्यालय के पॉल जी। एलन स्कूल ऑफ कंप्यूटर साइंस एंड इंजीनियरिंग के SAMPL समूह में एक शोध परियोजना के रूप में शुरू किया गया था और अब यह Apache Software Foundation (ASF) में ऊष्मायन के दौर से गुजर रहा है जो एक OSC द्वारा संचालित है। ओपन सोर्स कम्युनिटी) जिसमें अपाचे रास्ते के तहत कई उद्योग के साथ-साथ शैक्षणिक संस्थान शामिल हैं।

Apache (ऊष्मायन) TVM की मुख्य विशेषताएं निम्नलिखित हैं -

  • पूर्व C ++ आधारित विकास प्रक्रिया को सरल करता है।

  • कई हार्डवेयर बैकेंड जैसे CPU, GPU, आदि में समान कार्यान्वयन साझा करने में सक्षम करता है।

  • TVM विभिन्न हार्डवेयर बैक पर न्यूनतम तैनाती योग्य मॉड्यूल में Kears, MXNet, PyTorch, Tensorflow, CoreML, DarkNet जैसे डीएल मॉडल का संकलन प्रदान करता है।

  • यह हमें बेहतर प्रदर्शन के साथ दसियों ऑपरेटरों को स्वचालित रूप से उत्पन्न करने और अनुकूलित करने के लिए बुनियादी ढाँचा भी प्रदान करता है।

xfer

Xfer, एक स्थानांतरण सीखने की रूपरेखा, पायथन में लिखी गई है। यह मूल रूप से एमएक्सनेट मॉडल लेता है और मेटा-मॉडल को प्रशिक्षित करता है या मॉडल को नए लक्ष्य डेटासेट के लिए भी संशोधित करता है।

सरल शब्दों में, Xfer एक पायथन लाइब्रेरी है जो उपयोगकर्ताओं को DNN (गहरे तंत्रिका नेटवर्क) में संग्रहीत ज्ञान के त्वरित और आसान हस्तांतरण की अनुमति देता है।

Xfer का उपयोग किया जा सकता है -

  • मनमाना संख्यात्मक प्रारूप के डेटा के वर्गीकरण के लिए।

  • छवियों या पाठ डेटा के सामान्य मामलों के लिए।

  • एक पाइपलाइन के रूप में, जो एक पुनर्खरीदकर्ता को प्रशिक्षित करने के लिए विशेषताओं को निकालती है (एक वस्तु जो लक्ष्य कार्य में वर्गीकरण करती है)।

Xfer की विशेषताएं निम्नलिखित हैं:

  • संसाधन क्षमता

  • डेटा दक्षता

  • तंत्रिका नेटवर्क तक आसान पहुंच

  • अनिश्चितता मॉडलिंग

  • तिव्र प्रतिकृति

  • NN से सुविधा निष्कर्षण के लिए उपयोगिताएँ