PyBrain - त्वरित गाइड

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

पाइब्रेन की परिभाषा इसके आधिकारिक दस्तावेज़ीकरण के अनुसार इस प्रकार है -

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

PyBrain Python- आधारित सुदृढीकरण सीखना, कृत्रिम बुद्धिमत्ता और तंत्रिका नेटवर्क लाइब्रेरी के लिए छोटा है। वास्तव में, हम पहले नाम के साथ आए थे और बाद में इस काफी वर्णनात्मक "बैक्रोनिम" को रिवर्स-इंजीनियर किया।

Pybrain की विशेषताएं

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

नेटवर्क

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

feed-forward networkएक तंत्रिका नेटवर्क है, जहां नोड्स के बीच सूचना आगे की दिशा में चलती है और कभी भी पीछे की ओर नहीं जाएगी। फीड फॉरवर्ड नेटवर्क कृत्रिम तंत्रिका नेटवर्क में उपलब्ध नेटवर्क में पहला और सबसे सरल है।

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

Recurrent Networksफ़ीड फॉरवर्ड नेटवर्क के समान हैं; एकमात्र अंतर यह है कि प्रत्येक चरण पर डेटा को याद रखना है। प्रत्येक चरण के इतिहास को सहेजना होगा।

डेटासेट

डेटासेट नेटवर्क पर परीक्षण, सत्यापन और प्रशिक्षण के लिए दिया जाने वाला डेटा है। उपयोग किए जाने वाले डेटासेट का प्रकार उन कार्यों पर निर्भर करता है जो हम मशीन लर्निंग के साथ करने जा रहे हैं। सबसे अधिक इस्तेमाल किया जाने वाला डेटासेट जो Pybrain का समर्थन करता हैSupervisedDataSet तथा ClassificationDataSet

SupervisedDataSet - इसमें के क्षेत्र शामिल हैं input तथा target। यह एक डाटासेट का सबसे सरल रूप है और मुख्य रूप से पर्यवेक्षित शिक्षण कार्यों के लिए उपयोग किया जाता है।

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

ट्रेनर

जब हम एक नेटवर्क, यानी न्यूरल नेटवर्क बनाते हैं, तो उसे दिए गए प्रशिक्षण डेटा के आधार पर प्रशिक्षित किया जाएगा। अब नेटवर्क ठीक से प्रशिक्षित है या नहीं, यह उस नेटवर्क पर परीक्षण किए गए डेटा की भविष्यवाणी पर निर्भर करेगा। Pybrain Training में सबसे महत्वपूर्ण अवधारणा BackpropTrainer और TrainUntilConvergence का उपयोग है।

BackpropTrainer - यह एक ट्रेनर है जो एक पर्यवेक्षित या ClassificationDataSet डेटासेट (संभावित अनुक्रमिक) के अनुसार त्रुटियों के बैकप्रोपैगेटिंग (समय के माध्यम से) के अनुसार मॉड्यूल के मापदंडों को प्रशिक्षित करता है।

TrainUntilConvergence −यह डेटासेट पर मॉड्यूल को तब तक प्रयोग करने के लिए उपयोग किया जाता है जब तक कि यह परिवर्तित न हो जाए।

उपकरण

Pybrain उपकरण मॉड्यूल प्रदान करता है जो पैकेज आयात करके नेटवर्क बनाने में मदद कर सकता है: pybrain.tools.shortcuts.buildNetwork

VISUALIZATION

Pybrain का उपयोग करके परीक्षण डेटा की कल्पना नहीं की जा सकती है। लेकिन डेटा की कल्पना करने के लिए Pybrain अन्य चौखटे जैसे Mathplotlib, pyplot के साथ काम कर सकता है।

पाइब्रेन के फायदे

Pybrain के फायदे हैं -

  • मशीन लर्निंग सीखने के लिए पाइब्रेन एक ओपन-सोर्स फ्री लाइब्रेरी है। यह मशीन लर्निंग में रुचि रखने वाले किसी भी नवागंतुक के लिए एक अच्छी शुरुआत है।

  • पायब्रेन इसे लागू करने के लिए अजगर का उपयोग करता है और यह जावा / सी ++ जैसी भाषाओं की तुलना में विकास में तेज करता है।

  • Pybrain डेटा की कल्पना करने के लिए अजगर के अन्य पुस्तकालयों के साथ आसानी से काम करता है।

  • Pybrain लोकप्रिय नेटवर्क जैसे फ़ीड-फ़ॉर्वर्ड नेटवर्क, आवर्तक नेटवर्क, तंत्रिका नेटवर्क आदि के लिए समर्थन प्रदान करता है।

  • डेटासेट्स को लोड करने के लिए .csv के साथ काम करना Pybrain में बहुत आसान है। यह किसी अन्य लाइब्रेरी से डेटासेट का उपयोग करने की भी अनुमति देता है।

  • Pybrain प्रशिक्षकों का उपयोग करके डेटा का प्रशिक्षण और परीक्षण आसान है।

Pybrain की सीमाएँ

Pybrain किसी भी मुद्दे का सामना करने के लिए कम मदद प्रदान करता है। कुछ प्रश्न अनुत्तरित हैंstackoverflow और इसपर Google Group

Pybrain का वर्कफ़्लो

Pybrain प्रलेखन के अनुसार मशीन लर्निंग का प्रवाह निम्न आकृति में दिखाया गया है -

शुरुआत में, हमारे पास कच्चा डेटा होता है जो प्रीप्रोसेसिंग के बाद Pybrain के साथ उपयोग किया जा सकता है।

Pybrain का प्रवाह डेटासेट्स से शुरू होता है जो प्रशिक्षित और परीक्षण डेटा में विभाजित होते हैं।

  • नेटवर्क बनाया जाता है, और डेटासेट और नेटवर्क ट्रेनर को दिया जाता है।

  • ट्रेनर नेटवर्क पर डेटा को प्रशिक्षित करता है और आउटपुट को प्रशिक्षित त्रुटि और सत्यापन त्रुटि के रूप में वर्गीकृत करता है जिसे विज़ुअलाइज़ किया जा सकता है।

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

शब्दावली

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

Total Error- यह नेटवर्क प्रशिक्षित होने के बाद दिखाई गई त्रुटि को संदर्भित करता है। यदि त्रुटि प्रत्येक पुनरावृत्ति पर बदलती रहती है, तो इसका मतलब है कि इसे अभी भी व्यवस्थित करने के लिए समय चाहिए, जब तक कि यह पुनरावृत्ति के बीच निरंतर त्रुटि दिखाना शुरू नहीं करता है। एक बार जब यह निरंतर त्रुटि संख्या दिखाना शुरू कर देता है, तो इसका मतलब है कि नेटवर्क परिवर्तित हो गया है और किसी भी अतिरिक्त प्रशिक्षण के बावजूद वही लागू रहेगा।

Trained data - यह Pybrain नेटवर्क को प्रशिक्षित करने के लिए उपयोग किया जाने वाला डेटा है।

Testing data - यह प्रशिक्षित Pybrain नेटवर्क का परीक्षण करने के लिए उपयोग किया जाने वाला डेटा है।

Trainer- जब हम एक नेटवर्क बनाते हैं, अर्थात, न्यूरल नेटवर्क, तो उसे दिए गए प्रशिक्षण डेटा के आधार पर प्रशिक्षित किया जाएगा। अब नेटवर्क ठीक से प्रशिक्षित है या नहीं, यह उस नेटवर्क पर परीक्षण किए गए डेटा की भविष्यवाणी पर निर्भर करेगा। Pybrain Training में सबसे महत्वपूर्ण अवधारणा BackpropTrainer और TrainUntilConvergence का उपयोग है।

BackpropTrainer - यह एक ट्रेनर है जो एक पर्यवेक्षित या ClassificationDataSet डेटासेट (संभावित अनुक्रमिक) के अनुसार त्रुटियों के बैकप्रोपैगेटिंग (समय के माध्यम से) के अनुसार मॉड्यूल के मापदंडों को प्रशिक्षित करता है।

TrainUntilConvergence - इसका उपयोग डेटासेट पर मॉड्यूल को तब तक करने के लिए किया जाता है जब तक कि यह परिवर्तित न हो जाए।

Layers - परतें मूल रूप से फ़ंक्शंस का एक सेट होती हैं जो किसी नेटवर्क की छिपी हुई परतों पर उपयोग की जाती हैं।

Connections- एक कनेक्शन एक परत के समान काम करता है; केवल एक अंतर यह है कि यह एक नेटवर्क में एक नोड से दूसरे डेटा को शिफ्ट करता है।

Modules - मॉड्यूल ऐसे नेटवर्क हैं जिनमें इनपुट और आउटपुट बफर होते हैं।

Supervised Learning- इस मामले में, हमारे पास एक इनपुट और आउटपुट है, और हम आउटपुट के साथ इनपुट को मैप करने के लिए एक एल्गोरिथ्म का उपयोग कर सकते हैं। एल्गोरिथ्म दिए गए प्रशिक्षण डेटा पर सीखने के लिए बनाया गया है और उस पर पुनरावृत्ति हुई है और जब एल्गोरिथ्म सही डेटा की भविष्यवाणी करता है तो पुनरावृत्ति की प्रक्रिया बंद हो जाती है।

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

इस अध्याय में, हम PyBrain की स्थापना पर काम करेंगे। PyBrain के साथ काम करना शुरू करने के लिए, हमें पहले Python को स्थापित करना होगा। इसलिए हम निम्नलिखित पर काम करने जा रहे हैं -

  • अजगर स्थापित करें
  • PyBrain स्थापित करें

पायथन स्थापित करना

पायथन को स्थापित करने के लिए, पायथन आधिकारिक साइट पर जाएँ: www.python.org/downloads जैसा कि नीचे दिखाया गया है और विंडोज़, लिनक्स / यूनिक्स और मैकओएस के लिए उपलब्ध नवीनतम संस्करण पर क्लिक करें। अपने साथ उपलब्ध 64- या 32-बिट OS के अनुसार अजगर डाउनलोड करें।

डाउनलोड हो जाने के बाद, पर क्लिक करें .exe अपने सिस्टम पर अजगर को स्थापित करने के लिए चरणों का पालन करें।

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

पेट में जोड़ें

PATH में जोड़ने के लिए, नीचे दिए गए चरणों का पालन करें -

  • अपने कंप्यूटर आइकन पर राइट-क्लिक करें और गुण -> उन्नत सिस्टम सेटिंग्स पर क्लिक करें।

  • यह नीचे दिखाए गए अनुसार स्क्रीन को प्रदर्शित करेगा

  • ऊपर दिखाए गए अनुसार पर्यावरण चर पर क्लिक करें। यह नीचे दिखाए गए अनुसार स्क्रीन को प्रदर्शित करेगा

पथ का चयन करें और संपादन बटन पर क्लिक करें, अंत में अपने अजगर का स्थान पथ जोड़ें। अब हम अजगर संस्करण की जांच करते हैं।

पायथन संस्करण के लिए जाँच की जा रही है

नीचे दिया गया कोड हमें पायथन के संस्करण की जाँच करने में मदद करता है -

E:\pybrain>python --version
Python 3.7.3

PyBrain स्थापित करना

अब जब हमने Python स्थापित कर लिया है, हम Pybrain स्थापित करने जा रहे हैं। नीचे दिखाए अनुसार पाइब्रेन रिपॉजिटरी को क्लोन करें -

git clone git://github.com/pybrain/pybrain.git

C:\pybrain>git clone git://github.com/pybrain/pybrain.git
Cloning into 'pybrain'...
remote: Enumerating objects: 2, done.
remote: Counting objects: 100% (2/2), done.
remote: Compressing objects: 100% (2/2), done.
remote: Total 12177 (delta 0), reused 0 (delta 0), pack-reused 12175
Receiving objects: 100% (12177/12177), 13.29 MiB | 510.00 KiB/s, done.
Resolving deltas: 100% (8506/8506), done.

अब प्रदर्शन करते हैं cd pybrain और निम्नलिखित कमांड चलाएं -

python setup.py install

यह कमांड आपके सिस्टम पर pybrain स्थापित करेगा।

एक बार हो जाने के बाद, यह जांचने के लिए कि पाइब्रेन स्थापित है या नहीं, कमांड लाइन प्रॉम्प्ट खोलें और नीचे दिखाए गए अजगर इंटरप्रेटर को शुरू करें -

C:\pybrain\pybrain>python
Python 3.7.3 (v3.7.3:ef4ec6ed12, Mar 25 2019, 22:22:05) [MSC v.1916 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
>>>

हम नीचे दिए गए कोड का उपयोग करके आयात pybrain जोड़ सकते हैं -

>>> import pybrain
>>>

यदि आयात pybrain बिना किसी त्रुटि के काम करता है, तो इसका मतलब सफलतापूर्वक स्थापित pybrain है। अब आप pybrain के साथ काम करना शुरू करने के लिए अपना कोड लिख सकते हैं।

PyBrain Python के साथ मशीन लर्निंग के लिए विकसित एक पुस्तकालय है। मशीन लर्निंग में कुछ महत्वपूर्ण अवधारणाएँ हैं और उनमें से एक नेटवर्क है। एक नेटवर्क मॉड्यूल से बना है और वे कनेक्शन का उपयोग करके जुड़े हुए हैं।

एक सरल तंत्रिका नेटवर्क का एक लेआउट इस प्रकार है -

Pybrain तंत्रिका नेटवर्क जैसे फ़ीड-फ़ॉर्वर्ड नेटवर्क, आवर्तक नेटवर्क, आदि का समर्थन करता है।

feed-forward networkएक तंत्रिका नेटवर्क है, जहां नोड्स के बीच सूचना आगे की दिशा में चलती है और कभी भी पीछे की ओर नहीं जाएगी। फीड फॉरवर्ड नेटवर्क कृत्रिम तंत्रिका नेटवर्क में उपलब्ध नेटवर्क में पहला और सबसे सरल है। जानकारी को इनपुट नोड्स से, छिपे हुए नोड्स के बगल में और बाद में आउटपुट नोड में भेज दिया जाता है।

यहाँ एक सरल फीड फॉरवर्ड नेटवर्क लेआउट है।

सर्कल को मॉड्यूल कहा जाता है और तीर के साथ लाइनें मॉड्यूल से कनेक्शन हैं।

नोड्स A, B, C तथा D इनपुट नोड्स हैं

H1, H2, H3, H4 छिपे हुए नोड्स हैं और O आउटपुट है।

उपरोक्त नेटवर्क में, हमारे पास 4 इनपुट नोड्स, 4 छिपी हुई परतें और 1 आउटपुट हैं। आरेख में दिखाए गए लाइनों की संख्या मॉडल में वजन मापदंडों को दर्शाती है जो प्रशिक्षण के दौरान समायोजित की जाती हैं।

Recurrent Networksफीड फ़ॉरवर्ड नेटवर्क के समान ही अंतर है कि इसे प्रत्येक चरण पर डेटा को याद रखना है। प्रत्येक चरण के इतिहास को सहेजना होगा।

यहाँ एक सरल लेआउट आवर्तक नेटवर्क है -

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

  • नेटवर्क बनाएँ
  • नेटवर्क का विश्लेषण करें

नेटवर्क बनाना

हम अपने कोड को निष्पादित करने के लिए अजगर इंटरप्रेटर का उपयोग करने जा रहे हैं। Pybrain में नेटवर्क बनाने के लिए, हमें उपयोग करना होगाbuildNetwork आपी को नीचे दिखाया गया है -

C:\pybrain\pybrain>python
Python 3.7.3 (v3.7.3:ef4ec6ed12, Mar 25 2019, 22:22:05) [MSC v.1916 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
>>>
>>>
>>> from pybrain.tools.shortcuts import buildNetwork
>>> network = buildNetwork(2, 3, 1)
>>>

हमने buildNetwork () का उपयोग करके एक नेटवर्क बनाया है और परम 2, 3, 1 हैं जिसका अर्थ है कि नेटवर्क 2 इनपुट, 3 छिपे हुए और एक एकल आउटपुट से बना है।

नीचे नेटवर्क, अर्थात मॉड्यूल और कनेक्शन का विवरण दिया गया है -

C:\pybrain\pybrain>python
Python 3.7.3 (v3.7.3:ef4ec6ed12, Mar 25 2019, 22:22:05) [MSC v.1916 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
>>> from pybrain.tools.shortcuts import buildNetwork
>>> network = buildNetwork(2,3,1)
>>> print(network)
FeedForwardNetwork-8
   Modules:
   [<BiasUnit 'bias'>, <LinearLayer 'in'>, <SigmoidLayer 'hidden0'>,
<LinearLay er 'out'>]
   Connections:
   [<FullConnection 'FullConnection-4': 'hidden0' -> 'out'>, <FullConnection 'F
ullConnection-5': 'in' -> 'hidden0'>, <FullConnection 'FullConnection-6': 'bias'
-< 'out'>, <FullConnection 'FullConnection-7': 'bias' -> 'hidden0'>]
>>>

मॉड्यूल में परतें होती हैं, और कनेक्शन FullConnection ऑब्जेक्ट से बनाए जाते हैं। इसलिए प्रत्येक मॉड्यूल और कनेक्शन को ऊपर दिखाए गए अनुसार नाम दिया गया है।

विश्लेषण नेटवर्क

आप मॉड्यूल परतों और कनेक्शन को उनके नाम के अनुसार व्यक्तिगत रूप से एक्सेस कर सकते हैं -

>>> network['bias']
<BiasUnit 'bias'>
>>> network['in']
<LinearLayer 'in'>

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

  • डेटासेट बनाना
  • डेटासेट में जोड़ना

हम पहले सीखेंगे कि डेटासेट कैसे बनाएं और दिए गए इनपुट से डेटासेट का परीक्षण करें।

डेटासेट बनाना

डेटासेट बनाने के लिए हमें pybrain डेटासेट पैकेज का उपयोग करना होगा: pybrain.datasets

Pybrain डेटासेट क्लासेस का समर्थन करता है SupervisedDataset, अनुक्रमिकदात्से, वर्गीकरणडासैटसेट। हम उपयोग करने जा रहे हैंSupervisedDataset , हमारे डाटासेट बनाने के लिए। उपयोग किए जाने वाले डेटासेट मशीन सीखने के कार्य पर निर्भर करता है जिसे उपयोगकर्ता कार्यान्वित करने की कोशिश कर रहा है। SupervisedDataset सबसे सरल है और हम यहां पर उसी का उपयोग करने जा रहे हैं।

SupervisedDataset datasetपरमेस इनपुट और लक्ष्य की जरूरत है। एक XOR सत्य तालिका पर विचार करें, जैसा कि नीचे दिखाया गया है -

A XOR B
0 0 0
0 1 1
1 0 1
1 1 0

जो इनपुट दिए गए हैं, वे 2-आयामी सरणी की तरह हैं और हमें 1 आउटपुट मिलता है। तो यहाँ इनपुट आकार बन जाता है और इसे लक्ष्य बनाता है जो आउटपुट है। 1. तो हमारे डेटासेट के लिए जाने वाले इनपुट 2,1 होंगे।

createdataset.py

from pybrain.datasets import SupervisedDataSet
sds = SupervisedDataSet(2, 1)
print(sds)

यह तब होता है जब हम कोड पायथन से निर्मित कोडैटोमेतो के ऊपर निष्पादित करते हैं -

C:\pybrain\pybrain\src>python createdataset.py
input: dim(0, 2)
[]
target: dim(0, 1)
[]

यह आकार 2 के इनपुट और आकार 1 के लक्ष्य को ऊपर दिखाए गए अनुसार प्रदर्शित करता है।

डेटासेट में जोड़ना

अब हम डेटासेट में डेटा को जोड़ते हैं।

createdataset.py

from pybrain.datasets import SupervisedDataSet
sds = SupervisedDataSet(2, 1)
xorModel = [
   [(0,0), (0,)],
   [(0,1), (1,)],
   [(1,0), (1,)],
   [(1,1), (0,)],
]
for input, target in xorModel:
sds.addSample(input, target)
print("Input is:")
print(sds['input'])
print("\nTarget is:")
print(sds['target'])

हमने नीचे दिखाए अनुसार एक XORModel सरणी बनाई है -

xorModel = [
   [(0,0), (0,)],
   [(0,1), (1,)],
   [(1,0), (1,)],
   [(1,1), (0,)],
]

डेटासेट में जोड़ने के लिए, हम addSample () पद्धति का उपयोग कर रहे हैं जो इनपुट और लक्ष्य में लेता है।

AddSample में डेटा जोड़ने के लिए, हम नीचे दिखाए अनुसार xorModel ऐरे के माध्यम से लूप करेंगे -

for input, target in xorModel:
   sds.addSample(input, target)

निष्पादित करने के बाद, निम्नलिखित आउटपुट हमें मिलता है -

python createataset.py

C:\pybrain\pybrain\src>python createdataset.py
Input is:
[[0. 0.]
[0. 1.]
[1. 0.]
[1. 1.]]
Target is:
[[0.]
[1.]
[1.]
[0.]]

आप नीचे दिखाए गए इनपुट और लक्ष्य सूचकांक का उपयोग करके बनाए गए डेटासेट से इनपुट और लक्ष्य विवरण प्राप्त कर सकते हैं -

print(sds['input'])
print(sds[‘target’])

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

हम निम्नलिखित पैकेज को जोड़कर डेटासेट के साथ काम कर सकते हैं -

pybrain.dataset

SupervisedDataSet

SupervisedDataSet के क्षेत्र शामिल हैं input तथा target। यह एक डाटासेट का सबसे सरल रूप है और मुख्य रूप से पर्यवेक्षित शिक्षण कार्यों के लिए उपयोग किया जाता है।

नीचे आप इसे कोड में कैसे उपयोग कर सकते हैं -

from pybrain.datasets import SupervisedDataSet

सुपरवाइडडैटसेट पर उपलब्ध तरीके निम्नानुसार हैं -

addSample (inp, लक्ष्य)

यह विधि इनपुट और लक्ष्य का एक नया नमूना जोड़ेगी।

splitWithProportion (अनुपात = 0.10)

यह डेटासेट को दो भागों में विभाजित करेगा। पहले भाग में इनपुट के रूप में दिए गए डेटासेट का% होगा, अर्थात, यदि इनपुट .10 है, तो यह डेटासेट का 10% और 90% डेटा है। आप अपनी पसंद के अनुसार अनुपात तय कर सकते हैं। विभाजित डेटासेट का उपयोग आपके नेटवर्क के परीक्षण और प्रशिक्षण के लिए किया जा सकता है।

copy() - डेटासेट की गहरी प्रति लौटाता है।

clear() - डाटासेट को साफ करें।

saveToFile (फ़ाइल नाम, प्रारूप = कोई नहीं, ** kwargs)

फ़ाइल नाम द्वारा दी गई फ़ाइल को ऑब्जेक्ट सहेजें।

उदाहरण

यहाँ एक सुपरवाइडडैटसेट का उपयोग कर काम करने का उदाहरण दिया गया है -

testnetwork.py

from pybrain.tools.shortcuts import buildNetwork
from pybrain.structure import TanhLayer
from pybrain.datasets import SupervisedDataSet
from pybrain.supervised.trainers import BackpropTrainer

# Create a network with two inputs, three hidden, and one output
nn = buildNetwork(2, 3, 1, bias=True, hiddenclass=TanhLayer)

# Create a dataset that matches network input and output sizes:
norgate = SupervisedDataSet(2, 1)

# Create a dataset to be used for testing.
nortrain = SupervisedDataSet(2, 1)

# Add input and target values to dataset
# Values for NOR truth table
norgate.addSample((0, 0), (1,))
norgate.addSample((0, 1), (0,))
norgate.addSample((1, 0), (0,))
norgate.addSample((1, 1), (0,))

# Add input and target values to dataset
# Values for NOR truth table
nortrain.addSample((0, 0), (1,))
nortrain.addSample((0, 1), (0,))
nortrain.addSample((1, 0), (0,))
nortrain.addSample((1, 1), (0,))

#Training the network with dataset norgate.
trainer = BackpropTrainer(nn, norgate)

# will run the loop 1000 times to train it.
for epoch in range(1000):
   trainer.train()
trainer.testOnData(dataset=nortrain, verbose = True)

उत्पादन

उपरोक्त कार्यक्रम के लिए आउटपुट निम्नानुसार है -

python testnetwork.py

C:\pybrain\pybrain\src>python testnetwork.py
Testing on data:
('out: ', '[0.887 ]')
('correct:', '[1 ]')
error: 0.00637334
('out: ', '[0.149 ]')
('correct:', '[0 ]')
error: 0.01110338
('out: ', '[0.102 ]')
('correct:', '[0 ]')
error: 0.00522736
('out: ', '[-0.163]')
('correct:', '[0 ]')
error: 0.01328650
('All errors:', [0.006373344564625953, 0.01110338071737218, 0.005227359234093431
, 0.01328649974219942])
('Average error:', 0.008997646064572746)
('Max error:', 0.01328649974219942, 'Median error:', 0.01110338071737218)

ClassificationDataSet

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

यहाँ आप इसे कोड में कैसे उपयोग कर सकते हैं -

from pybrain.datasets import ClassificationDataSet
Syntax
// ClassificationDataSet(inp, target=1, nb_classes=0, class_labels=None)

ClassificationDataSet पर उपलब्ध तरीके निम्नानुसार हैं -

addSample(inp, target) - यह विधि इनपुट और लक्ष्य का एक नया नमूना जोड़ेगी।

splitByClass() - यह विधि दो नए डेटासेट देगी, पहले डेटासेट में कक्षा का चयन (0..nClasses-1) होगा, दूसरे में शेष नमूने होंगे।

_convertToOneOfMany() - यह विधि लक्ष्य वर्गों को 1-k-k प्रतिनिधित्व में बदल देगी, पुराने लक्ष्यों को क्षेत्र वर्ग के रूप में बनाए रखेगा

यहाँ एक कार्यशील उदाहरण है ClassificationDataSet

उदाहरण

from sklearn import datasets
import matplotlib.pyplot as plt
from pybrain.datasets import ClassificationDataSet
from pybrain.utilities import percentError
from pybrain.tools.shortcuts import buildNetwork
from pybrain.supervised.trainers import BackpropTrainer
from pybrain.structure.modules import SoftmaxLayer
from numpy import ravel
digits = datasets.load_digits()
X, y = digits.data, digits.target
ds = ClassificationDataSet(64, 1, nb_classes=10)

for i in range(len(X)):
ds.addSample(ravel(X[i]), y[i])
test_data_temp, training_data_temp = ds.splitWithProportion(0.25)
test_data = ClassificationDataSet(64, 1, nb_classes=10)

for n in range(0, test_data_temp.getLength()):
test_data.addSample( test_data_temp.getSample(n)[0], test_data_temp.getSample(n)[1] )
training_data = ClassificationDataSet(64, 1, nb_classes=10)

for n in range(0, training_data_temp.getLength()):
training_data.addSample( training_data_temp.getSample(n)[0], training_data_temp.getSample(n)[1] )
test_data._convertToOneOfMany()
training_data._convertToOneOfMany()
net = buildNetwork(training_data.indim, 64, training_data.outdim, outclass=SoftmaxLayer)
trainer = BackpropTrainer(
   net, dataset=training_data, momentum=0.1,learningrate=0.01,verbose=True,weightdecay=0.01
)
trnerr,valerr = trainer.trainUntilConvergence(dataset=training_data,maxEpochs=10)
plt.plot(trnerr,'b',valerr,'r')
plt.show()
trainer.trainEpochs(10)
print('Percent Error on testData:',percentError(trainer.testOnClassData(dataset=test_data), test_data['class']))

उपरोक्त उदाहरण में उपयोग किया गया डेटासेट एक डिजिट डाटासेट है और कक्षाएं 0-9 से हैं, इसलिए 10 कक्षाएं हैं। इनपुट 64 है, लक्ष्य 1 और कक्षाएं, 10 हैं।

कोड डाटासेट के साथ नेटवर्क को प्रशिक्षित करता है और प्रशिक्षण त्रुटि और सत्यापन त्रुटि के लिए ग्राफ को आउटपुट करता है। यह testdata पर प्रतिशत त्रुटि भी देता है जो इस प्रकार है -

उत्पादन

Total error: 0.0432857814358
Total error: 0.0222276374185
Total error: 0.0149012052174
Total error: 0.011876985318
Total error: 0.00939854792853
Total error: 0.00782202445183
Total error: 0.00714707652044
Total error: 0.00606068893793
Total error: 0.00544257958975
Total error: 0.00463929281336
Total error: 0.00441275665294
('train-errors:', '[0.043286 , 0.022228 , 0.014901 , 0.011877 , 0.009399 , 0.007
   822 , 0.007147 , 0.006061 , 0.005443 , 0.004639 , 0.004413 ]')
('valid-errors:', '[0.074296 , 0.027332 , 0.016461 , 0.014298 , 0.012129 , 0.009
   248 , 0.008922 , 0.007917 , 0.006547 , 0.005883 , 0.006572 , 0.005811 ]')
Percent Error on testData: 3.34075723830735

इस अध्याय में, हम सीखेंगे कि Pybrain डेटासेट के साथ काम करने के लिए डेटा कैसे प्राप्त करें।

सबसे अधिक इस्तेमाल किया जाने वाला डेटासेट हैं -

  • स्केलेन का उपयोग करना
  • CSV फ़ाइल से

स्केलेन का उपयोग करना

स्केलेन का उपयोग करना

यहाँ लिंक है कि sklearn से डेटासेट का विवरण है:https://scikit-learn.org/stable/datasets/index.html

यहाँ sklearn से डेटासेट का उपयोग करने के कुछ उदाहरण दिए गए हैं -

उदाहरण 1: load_digits ()

from sklearn import datasets
from pybrain.datasets import ClassificationDataSet
digits = datasets.load_digits()
X, y = digits.data, digits.target
ds = ClassificationDataSet(64, 1, nb_classes=10)
for i in range(len(X)):
ds.addSample(ravel(X[i]), y[i])

उदाहरण 2: load_iris ()

from sklearn import datasets
from pybrain.datasets import ClassificationDataSet
digits = datasets.load_iris()
X, y = digits.data, digits.target
ds = ClassificationDataSet(4, 1, nb_classes=3)
for i in range(len(X)):
ds.addSample(X[i], y[i])

CSV फ़ाइल से

हम csv फ़ाइल के डेटा का उपयोग इस प्रकार कर सकते हैं -

यहाँ xor सत्य तालिका के लिए नमूना डेटा है: डाटासेट

डेटासेट के लिए .csv फ़ाइल से डेटा पढ़ने के लिए यहां काम करने का उदाहरण दिया गया है।

उदाहरण

from pybrain.tools.shortcuts import buildNetwork
from pybrain.structure import TanhLayer
from pybrain.datasets import SupervisedDataSet
from pybrain.supervised.trainers import BackpropTrainer
import pandas as pd

print('Read data...')
df = pd.read_csv('data/datasettest.csv',header=0).head(1000)
data = df.values

train_output = data[:,0]
train_data = data[:,1:]

print(train_output)
print(train_data)

# Create a network with two inputs, three hidden, and one output
nn = buildNetwork(2, 3, 1, bias=True, hiddenclass=TanhLayer)

# Create a dataset that matches network input and output sizes:
_gate = SupervisedDataSet(2, 1)

# Create a dataset to be used for testing.
nortrain = SupervisedDataSet(2, 1)

# Add input and target values to dataset
# Values for NOR truth table
for i in range(0, len(train_output)) :
   _gate.addSample(train_data[i], train_output[i])

#Training the network with dataset norgate.
trainer = BackpropTrainer(nn, _gate)

# will run the loop 1000 times to train it.
for epoch in range(1000):
   trainer.train()
trainer.testOnData(dataset=_gate, verbose = True)

उदाहरण के रूप में दिखाए गए CSV फ़ाइल के डेटा को पढ़ने के लिए पांडा का उपयोग किया जाता है।

उत्पादन

C:\pybrain\pybrain\src>python testcsv.py
Read data...
[0 1 1 0]
[
   [0 0]
   [0 1]
   [1 0]
   [1 1]
]
Testing on data:
('out: ', '[0.004 ]')
('correct:', '[0 ]')
error: 0.00000795
('out: ', '[0.997 ]')
('correct:', '[1 ]')
error: 0.00000380
('out: ', '[0.996 ]')
('correct:', '[1 ]')
error: 0.00000826
('out: ', '[0.004 ]')
('correct:', '[0 ]')
error: 0.00000829
('All errors:', [7.94733477723902e-06, 3.798267582566822e-06, 8.260969076585322e
-06, 8.286246525558165e-06])
('Average error:', 7.073204490487332e-06)
('Max error:', 8.286246525558165e-06, 'Median error:', 8.260969076585322e-06)

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

नीचे एक कामकाजी उदाहरण है कि बनाए गए नेटवर्क में डेटासेट कैसे जोड़ा जाए, और बाद में प्रशिक्षकों का उपयोग करके प्रशिक्षित और परीक्षण किया जाए।

testnetwork.py

from pybrain.tools.shortcuts import buildNetwork
from pybrain.structure import TanhLayer
from pybrain.datasets import SupervisedDataSet
from pybrain.supervised.trainers import BackpropTrainer

# Create a network with two inputs, three hidden, and one output
nn = buildNetwork(2, 3, 1, bias=True, hiddenclass=TanhLayer)

# Create a dataset that matches network input and output sizes:
norgate = SupervisedDataSet(2, 1)

# Create a dataset to be used for testing.
nortrain = SupervisedDataSet(2, 1)

# Add input and target values to dataset
# Values for NOR truth table
norgate.addSample((0, 0), (1,))
norgate.addSample((0, 1), (0,))
norgate.addSample((1, 0), (0,))
norgate.addSample((1, 1), (0,))

# Add input and target values to dataset
# Values for NOR truth table
nortrain.addSample((0, 0), (1,))
nortrain.addSample((0, 1), (0,))
nortrain.addSample((1, 0), (0,))
nortrain.addSample((1, 1), (0,))

#Training the network with dataset norgate.
trainer = BackpropTrainer(nn, norgate)

# will run the loop 1000 times to train it.
for epoch in range(1000):
trainer.train()
trainer.testOnData(dataset=nortrain, verbose = True)

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

हमने क्लास के 2 डेटासेट बनाए हैं - SupervisedDataSet। हम NOR डेटा मॉडल का उपयोग कर रहे हैं जो इस प्रकार है -

A NOR B
0 0 1
0 1 0
1 0 0
1 1 0

नेटवर्क को प्रशिक्षित करने के लिए उपरोक्त डेटा मॉडल का उपयोग किया जाता है।

norgate = SupervisedDataSet(2, 1)
# Add input and target values to dataset
# Values for NOR truth table
norgate.addSample((0, 0), (1,))
norgate.addSample((0, 1), (0,))
norgate.addSample((1, 0), (0,))
norgate.addSample((1, 1), (0,))

निम्नलिखित परीक्षण करने के लिए उपयोग किया जाने वाला डेटासेट निम्नलिखित है -

# Create a dataset to be used for testing.
nortrain = SupervisedDataSet(2, 1)

# Add input and target values to dataset
# Values for NOR truth table
norgate.addSample((0, 0), (1,))
norgate.addSample((0, 1), (0,))
norgate.addSample((1, 0), (0,))
norgate.addSample((1, 1), (0,))

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

#Training the network with dataset norgate.
trainer = BackpropTrainer(nn, norgate)

# will run the loop 1000 times to train it.
for epoch in range(1000):
   trainer.train()

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

trainer.testOnData(dataset=nortrain, verbose = True)

उत्पादन

python testnetwork.py

C:\pybrain\pybrain\src>python testnetwork.py
Testing on data:
('out: ', '[0.887 ]')
('correct:', '[1 ]')
error: 0.00637334
('out: ', '[0.149 ]')
('correct:', '[0 ]')
error: 0.01110338
('out: ', '[0.102 ]')
('correct:', '[0 ]')
error: 0.00522736
('out: ', '[-0.163]')
('correct:', '[0 ]')
error: 0.01328650
('All errors:', [0.006373344564625953, 0.01110338071737218, 0.005227359234093431
, 0.01328649974219942])
('Average error:', 0.008997646064572746)
('Max error:', 0.01328649974219942, 'Median error:', 0.01110338071737218)

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

आइए अब हम परीक्षण डेटा को बदलते हैं और एक औसत त्रुटि देखते हैं। हमने नीचे दिखाए अनुसार आउटपुट को बदल दिया है -

निम्नलिखित परीक्षण करने के लिए उपयोग किया जाने वाला डेटासेट निम्नलिखित है -

# Create a dataset to be used for testing.
nortrain = SupervisedDataSet(2, 1)

# Add input and target values to dataset
# Values for NOR truth table
norgate.addSample((0, 0), (0,))
norgate.addSample((0, 1), (1,))
norgate.addSample((1, 0), (1,))
norgate.addSample((1, 1), (0,))

आइये अब हम इसका परीक्षण करते हैं।

उत्पादन

अजगर टेस्टवर्कवर्क

C:\pybrain\pybrain\src>python testnetwork.py
Testing on data:
('out: ', '[0.988 ]')
('correct:', '[0 ]')
error: 0.48842978
('out: ', '[0.027 ]')
('correct:', '[1 ]')
error: 0.47382097
('out: ', '[0.021 ]')
('correct:', '[1 ]')
error: 0.47876379
('out: ', '[-0.04 ]')
('correct:', '[0 ]')
error: 0.00079160
('All errors:', [0.4884297811030845, 0.47382096780393873, 0.47876378995939756, 0
.0007915982149002194])
('Average error:', 0.3604515342703303)
('Max error:', 0.4884297811030845, 'Median error:', 0.47876378995939756)

हमें 0.36 के रूप में त्रुटि मिल रही है, जिससे पता चलता है कि हमारा परीक्षण डेटा पूरी तरह से प्रशिक्षित नेटवर्क के साथ मेल नहीं खा रहा है।

इस अध्याय में, हम कुछ उदाहरण देखने जा रहे हैं जहां हम डेटा को प्रशिक्षित करने और प्रशिक्षित डेटा पर त्रुटियों का परीक्षण करने जा रहे हैं।

हम प्रशिक्षकों का उपयोग करने जा रहे हैं -

BackpropTrainer

BackpropTrainer एक ट्रेनर है जो एक पर्यवेक्षित या ClassificationDataSet डेटासेट (संभावित अनुक्रमिक) के अनुसार त्रुटियों के बैकप्रॉपैगेटिंग (समय के माध्यम से) मॉड्यूल के मापदंडों को प्रशिक्षित करता है।

TrainUntilConvergence

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

जब हम एक तंत्रिका नेटवर्क बनाते हैं, तो यह दिए गए प्रशिक्षण डेटा के आधार पर प्रशिक्षित हो जाएगा। अब क्या नेटवर्क ठीक से प्रशिक्षित है या नहीं, यह उस नेटवर्क पर परीक्षण किए गए परीक्षण डेटा की भविष्यवाणी पर निर्भर करेगा।

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

हमारे नेटवर्क का परीक्षण

अपने नेटवर्क के परीक्षण के लिए हम निम्नलिखित चरणों का पालन करेंगे -

  • आवश्यक PyBrain और अन्य संकुल आयात करना
  • ClassDDataSet बनाएँ
  • डेटासेट को टेस्टडेटा के रूप में 25% और प्रशिक्षित डेटा के रूप में 75% विभाजित करना
  • Testdata और प्रशिक्षित डेटा को ClassificationDataSet के रूप में परिवर्तित करना
  • एक तंत्रिका नेटवर्क बनाना
  • नेटवर्क का प्रशिक्षण
  • त्रुटि और सत्यापन डेटा की कल्पना करना
  • परीक्षण डेटा त्रुटि के लिए प्रतिशत

Step 1

आवश्यक PyBrain और अन्य संकुल आयात करना।

पैकेज जो हमें चाहिए वे नीचे दिखाए गए अनुसार आयात किए गए हैं -

from sklearn import datasets
import matplotlib.pyplot as plt
from pybrain.datasets import ClassificationDataSet
from pybrain.utilities import percentError
from pybrain.tools.shortcuts import buildNetwork
from pybrain.supervised.trainers import BackpropTrainer
from pybrain.structure.modules import SoftmaxLayer
from numpy import ravel

Step 2

अगला चरण ClassificationDataSet बनाना है।

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

नीचे दिए गए लिंक में sklearn से load_digits डेटासेट देखें -

https://scikit-learn.org/stable/modules/generated/sklearn.datasets.load_digits.html#sklearn.datasets.load_digits

digits = datasets.load_digits()
X, y = digits.data, digits.target

ds = ClassificationDataSet(64, 1, nb_classes=10) 
# we are having inputs are 64 dim array and since the digits are from 0-9 the 
classes considered is 10.

for i in range(len(X)):
   ds.addSample(ravel(X[i]), y[i]) # adding sample to datasets

Step 3

डेटासेट को टेस्टडेटा के रूप में 25% और प्रशिक्षित डेटा के रूप में 75% विभाजित करना -

test_data_temp, training_data_temp = ds.splitWithProportion(0.25)

इसलिए, हमने डेटासेट पर एक विधि का उपयोग किया है जिसे स्प्लिटविथप्रोटेक्शन () कहा जाता है जिसका मूल्य 0.25 है, यह डेटासेट को परीक्षण डेटा के रूप में 25% और प्रशिक्षण डेटा के रूप में 75% विभाजित करेगा।

Step 4

Testdata और प्रशिक्षित डेटा को ClassificationDataSet के रूप में परिवर्तित करना।

test_data = ClassificationDataSet(64, 1, nb_classes=10)
for n in range(0, test_data_temp.getLength()):
   test_data.addSample( test_data_temp.getSample(n)[0], test_data_temp.getSample(n)[1] )
training_data = ClassificationDataSet(64, 1, nb_classes=10)

for n in range(0, training_data_temp.getLength()):

training_data.addSample( 
   training_data_temp.getSample(n)[0], training_data_temp.getSample(n)[1] 
)
test_data._convertToOneOfMany()
training_data._convertToOneOfMany()

डेटासेट पर स्प्लिटविप्रोप्रोएशन () पद्धति का उपयोग करके डेटासेट को सुपरवाइडसेटैट में परिवर्तित किया जाता है, इसलिए हम डेटासेट को वापस वर्गीकरणडैटसेट में बदल देंगे जैसा कि ऊपर चरण में दिखाया गया है।

Step 5

अगला कदम एक न्यूरल नेटवर्क बना रहा है।

net = buildNetwork(training_data.indim, 64, training_data.outdim, outclass=SoftmaxLayer)

हम एक नेटवर्क बना रहे हैं जिसमें इनपुट और आउटपुट का उपयोग प्रशिक्षण डेटा से किया जाता है।

Step 6

नेटवर्क का प्रशिक्षण

अब महत्वपूर्ण भाग डेटासेट पर नेटवर्क को प्रशिक्षित कर रहा है जैसा कि नीचे दिखाया गया है -

trainer = BackpropTrainer(net, dataset=training_data, 
momentum=0.1,learningrate=0.01,verbose=True,weightdecay=0.01)

हम BackpropTrainer () पद्धति का उपयोग कर रहे हैं और बनाए गए नेटवर्क पर डेटासेट का उपयोग कर रहे हैं।

Step 7

अगला चरण डेटा की त्रुटि और सत्यापन की कल्पना कर रहा है।

trnerr,valerr = trainer.trainUntilConvergence(dataset=training_data,maxEpochs=10)
plt.plot(trnerr,'b',valerr,'r')
plt.show()

हम प्रशिक्षण डेटा पर trainUntilConvergence नामक एक विधि का उपयोग करेंगे जो 10. के युगों के लिए अभिसरण करेगा। यह प्रशिक्षण त्रुटि और सत्यापन त्रुटि लौटाएगा जिसे हमने नीचे दिखाया गया है। नीली रेखा प्रशिक्षण त्रुटियों को दिखाती है और लाल रेखा सत्यापन त्रुटि को दर्शाती है।

उपरोक्त कोड के निष्पादन के दौरान प्राप्त कुल त्रुटि को नीचे दिखाया गया है -

Total error: 0.0432857814358
Total error: 0.0222276374185
Total error: 0.0149012052174
Total error: 0.011876985318
Total error: 0.00939854792853
Total error: 0.00782202445183
Total error: 0.00714707652044
Total error: 0.00606068893793
Total error: 0.00544257958975
Total error: 0.00463929281336
Total error: 0.00441275665294
('train-errors:', '[0.043286 , 0.022228 , 0.014901 , 0.011877 , 0.009399 , 0.007
822 , 0.007147 , 0.006061 , 0.005443 , 0.004639 , 0.004413 ]')
('valid-errors:', '[0.074296 , 0.027332 , 0.016461 , 0.014298 , 0.012129 , 0.009
248 , 0.008922 , 0.007917 , 0.006547 , 0.005883 , 0.006572 , 0.005811 ]')

त्रुटि 0.04 से शुरू होती है और बाद में प्रत्येक युग के लिए नीचे जाती है, जिसका अर्थ है कि नेटवर्क प्रशिक्षित हो रहा है और प्रत्येक युग के लिए बेहतर है।

Step 8

परीक्षण डेटा त्रुटि के लिए प्रतिशत

हम नीचे दिखाए गए अनुसार प्रतिशत पद्धति का उपयोग करके प्रतिशत त्रुटि की जाँच कर सकते हैं -

print('Percent Error on 
   testData:',percentError(trainer.testOnClassData(dataset=test_data), 
   test_data['class']))

Percent Error on testData - 3.34075723830735

हमें त्रुटि प्रतिशत, यानी 3.34% मिल रहा है, जिसका अर्थ है कि तंत्रिका नेटवर्क 97% सटीक है।

नीचे पूरा कोड है -

from sklearn import datasets
import matplotlib.pyplot as plt
from pybrain.datasets import ClassificationDataSet
from pybrain.utilities import percentError
from pybrain.tools.shortcuts import buildNetwork
from pybrain.supervised.trainers import BackpropTrainer
from pybrain.structure.modules import SoftmaxLayer
from numpy import ravel
digits = datasets.load_digits()
X, y = digits.data, digits.target

ds = ClassificationDataSet(64, 1, nb_classes=10)

for i in range(len(X)):
   ds.addSample(ravel(X[i]), y[i])

test_data_temp, training_data_temp = ds.splitWithProportion(0.25)
test_data = ClassificationDataSet(64, 1, nb_classes=10)
for n in range(0, test_data_temp.getLength()):
   test_data.addSample( test_data_temp.getSample(n)[0], test_data_temp.getSample(n)[1] )
training_data = ClassificationDataSet(64, 1, nb_classes=10)

for n in range(0, training_data_temp.getLength()):
   training_data.addSample( 
      training_data_temp.getSample(n)[0], training_data_temp.getSample(n)[1] 
   )
test_data._convertToOneOfMany()
training_data._convertToOneOfMany()

net = buildNetwork(training_data.indim, 64, training_data.outdim, outclass=SoftmaxLayer)
trainer = BackpropTrainer(
   net, dataset=training_data, momentum=0.1,
   learningrate=0.01,verbose=True,weightdecay=0.01
)
trnerr,valerr = trainer.trainUntilConvergence(dataset=training_data,maxEpochs=10)
plt.plot(trnerr,'b',valerr,'r')
plt.show()

trainer.trainEpochs(10)
print('Percent Error on testData:',percentError(
   trainer.testOnClassData(dataset=test_data), test_data['class']
))

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

इस अध्याय में हम चर्चा करने जा रहे हैं कि कैसे -

  • फ़ीड-फ़ॉर्वर्ड नेटवर्क बनाएँ
  • FFN में कनेक्शन और मॉड्यूल जोड़ें

फ़ीड फ़ॉरवर्ड नेटवर्क बनाना

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

एक फीडफ़ॉर्म नेटवर्क बनाने के लिए, हमें इसे आयात करना होगा pybrain.structure जैसा कि नीचे दिखाया गया है -

ffn.py

from pybrain.structure import FeedForwardNetwork
network = FeedForwardNetwork()
print(network)

नीचे दिखाए अनुसार ffn.py निष्पादित करें -

C:\pybrain\pybrain\src>python ffn.py
FeedForwardNetwork-0
Modules:
[]
Connections:
[]

हमने फीडफोर्वर्ड नेटवर्क में कोई मॉड्यूल और कनेक्शन नहीं जोड़ा है। इसलिए नेटवर्क मॉड्यूल और कनेक्शंस के लिए खाली एरेज़ दिखाता है।

मॉड्यूल और कनेक्शन जोड़ना

पहले हम इनपुट, हिडन, आउटपुट लेयर्स बनाएंगे और नीचे दिखाए गए मॉड्यूल के समान जोड़ेंगे -

ffy.py

from pybrain.structure import FeedForwardNetwork
from pybrain.structure import LinearLayer, SigmoidLayer
network = FeedForwardNetwork()

#creating layer for input => 2 , hidden=> 3 and output=>1
inputLayer = LinearLayer(2)
hiddenLayer = SigmoidLayer(3)
outputLayer = LinearLayer(1)

#adding the layer to feedforward network
network.addInputModule(inputLayer)
network.addModule(hiddenLayer)
network.addOutputModule(outputLayer)

print(network)

उत्पादन

C:\pybrain\pybrain\src>python ffn.py
FeedForwardNetwork-3
Modules:
[]
Connections:
[]

हम अभी भी खाली के रूप में मॉड्यूल और कनेक्शन प्राप्त कर रहे हैं। हमें नीचे दिखाए गए अनुसार बनाए गए मॉड्यूल से एक कनेक्शन प्रदान करना होगा -

यहां वह कोड है जहां हमने इनपुट, हिडन और आउटपुट लेयर्स के बीच एक कनेक्शन बनाया है और नेटवर्क से कनेक्शन जोड़ा है।

ffy.py

from pybrain.structure import FeedForwardNetwork
from pybrain.structure import LinearLayer, SigmoidLayer
from pybrain.structure import FullConnection
network = FeedForwardNetwork()

#creating layer for input => 2 , hidden=> 3 and output=>1
inputLayer = LinearLayer(2)
hiddenLayer = SigmoidLayer(3)
outputLayer = LinearLayer(1)

#adding the layer to feedforward network
network.addInputModule(inputLayer)
network.addModule(hiddenLayer)
network.addOutputModule(outputLayer)

#Create connection between input ,hidden and output
input_to_hidden = FullConnection(inputLayer, hiddenLayer)
hidden_to_output = FullConnection(hiddenLayer, outputLayer)

#add connection to the network
network.addConnection(input_to_hidden)
network.addConnection(hidden_to_output)

print(network)

उत्पादन

C:\pybrain\pybrain\src>python ffn.py
FeedForwardNetwork-3
Modules:
[]
Connections:
[]

हम अभी भी मॉड्यूल और कनेक्शन प्राप्त करने में सक्षम नहीं हैं। अब हम अंतिम चरण को जोड़ते हैं, अर्थात, हमें नीचे दिखाए अनुसार SortModules () विधि जोड़ने की आवश्यकता है -

ffy.py

from pybrain.structure import FeedForwardNetwork
from pybrain.structure import LinearLayer, SigmoidLayer
from pybrain.structure import FullConnection
network = FeedForwardNetwork()

#creating layer for input => 2 , hidden=> 3 and output=>1
inputLayer = LinearLayer(2)
hiddenLayer = SigmoidLayer(3)
outputLayer = LinearLayer(1)

#adding the layer to feedforward network
network.addInputModule(inputLayer)
network.addModule(hiddenLayer)
network.addOutputModule(outputLayer)

#Create connection between input ,hidden and output
input_to_hidden = FullConnection(inputLayer, hiddenLayer)
hidden_to_output = FullConnection(hiddenLayer, outputLayer)

#add connection to the network
network.addConnection(input_to_hidden)
network.addConnection(hidden_to_output)
network.sortModules()

print(network)

उत्पादन

C:\pybrain\pybrain\src>python ffn.py
FeedForwardNetwork-6
Modules:
[<LinearLayer 'LinearLayer-3'gt;, <SigmoidLayer 'SigmoidLayer-7'>, 
   <LinearLayer 'LinearLayer-8'>]
Connections:
[<FullConnection 'FullConnection-4': 'SigmoidLayer-7' -> 'LinearLayer-8'>, 
   <FullConnection 'FullConnection-5': 'LinearLayer-3' -> 'SigmoidLayer-7'>]

अब हम feedforwardnetwork के लिए मॉड्यूल और कनेक्शन विवरण देख पा रहे हैं।

आवर्तक नेटवर्क फ़ीड-फ़ॉरवर्ड नेटवर्क के समान है जिसमें केवल अंतर है जिसे आपको प्रत्येक चरण में डेटा को याद रखने की आवश्यकता है। प्रत्येक चरण के इतिहास को सहेजना होगा।

हम सीखेंगे कि कैसे -

  • एक आवर्तक नेटवर्क बनाएँ
  • मॉड्यूल और कनेक्शन जोड़ना

एक आवर्तक नेटवर्क बनाना

आवर्तक नेटवर्क बनाने के लिए, हम नीचे दिए गए अनुसार RecurrentNetwork वर्ग का उपयोग करेंगे -

rn.py

from pybrain.structure import RecurrentNetwork
recurrentn = RecurrentNetwork()
print(recurrentn)

अजगर rn.py

C:\pybrain\pybrain\src>python rn.py
RecurrentNetwork-0
Modules:
[]
Connections:
[]
Recurrent Connections:
[]

हम एक नए कनेक्शन को आवर्तक नेटवर्क के लिए आवर्तक कनेक्शन कह सकते हैं। अभी कोई डेटा उपलब्ध नहीं है।

आइए अब हम परतें बनाते हैं और मॉड्यूल में जोड़ते हैं और कनेक्शन बनाते हैं।

मॉड्यूल और कनेक्शन जोड़ना

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

यहाँ मॉड्यूल और कनेक्शन के साथ आवर्तक नेटवर्क के लिए कोड है।

rn.py

from pybrain.structure import RecurrentNetwork
from pybrain.structure import LinearLayer, SigmoidLayer
from pybrain.structure import FullConnection
recurrentn = RecurrentNetwork()

#creating layer for input => 2 , hidden=> 3 and output=>1
inputLayer = LinearLayer(2, 'rn_in')
hiddenLayer = SigmoidLayer(3, 'rn_hidden')
outputLayer = LinearLayer(1, 'rn_output')

#adding the layer to feedforward network
recurrentn.addInputModule(inputLayer)
recurrentn.addModule(hiddenLayer)
recurrentn.addOutputModule(outputLayer)

#Create connection between input ,hidden and output
input_to_hidden = FullConnection(inputLayer, hiddenLayer)
hidden_to_output = FullConnection(hiddenLayer, outputLayer)
hidden_to_hidden = FullConnection(hiddenLayer, hiddenLayer)

#add connection to the network
recurrentn.addConnection(input_to_hidden)
recurrentn.addConnection(hidden_to_output)
recurrentn.addRecurrentConnection(hidden_to_hidden)
recurrentn.sortModules()

print(recurrentn)

अजगर rn.py

C:\pybrain\pybrain\src>python rn.py
RecurrentNetwork-6
Modules:
[<LinearLayer 'rn_in'>, <SigmoidLayer 'rn_hidden'>, 
   <LinearLayer 'rn_output'>]
Connections:
[<FullConnection 'FullConnection-4': 'rn_hidden' -> 'rn_output'>, 
   <FullConnection 'FullConnection-5': 'rn_in' -> 'rn_hidden'>]
Recurrent Connections:
[<FullConnection 'FullConnection-3': 'rn_hidden' -> 'rn_hidden'>]

ऊपर ouput में हम मॉड्यूल, कनेक्शंस और रिक्रूट कनेक्शंस देख सकते हैं।

अब नीचे दिखाए गए तरीके से सक्रिय विधि का उपयोग कर नेटवर्क को सक्रिय करते हैं -

rn.py

पहले बनाए गए कोड में नीचे कोड जोड़ें -

#activate network using activate() method
act1 = recurrentn.activate((2, 2))
print(act1)

act2 = recurrentn.activate((2, 2))
print(act2)

अजगर rn.py

C:\pybrain\pybrain\src>python rn.py
[-1.24317586]
[-0.54117783]

हमने देखा है कि कैसे pybrain में प्रशिक्षकों का उपयोग करके एक नेटवर्क को प्रशिक्षित करना है। इस अध्याय में, एक नेटवर्क को प्रशिक्षित करने के लिए Pybrain के साथ उपलब्ध अनुकूलन एल्गोरिदम का उपयोग करेगा।

उदाहरण में, हम GA ऑप्टिमाइज़ेशन एल्गोरिदम का उपयोग करेंगे जिसे नीचे दिखाए अनुसार आयात करने की आवश्यकता है -

from pybrain.optimization.populationbased.ga import GA

उदाहरण

नीचे जीए ऑप्टिमाइज़ेशन एल्गोरिथ्म का उपयोग करते हुए एक प्रशिक्षण नेटवर्क का एक कार्यशील उदाहरण है -

from pybrain.datasets.classification import ClassificationDataSet
from pybrain.optimization.populationbased.ga import GA
from pybrain.tools.shortcuts import buildNetwork

# create XOR dataset
ds = ClassificationDataSet(2)
ds.addSample([0., 0.], [0.])
ds.addSample([0., 1.], [1.])
ds.addSample([1., 0.], [1.])
ds.addSample([1., 1.], [0.])
ds.setField('class', [ [0.],[1.],[1.],[0.]])

net = buildNetwork(2, 3, 1)
ga = GA(ds.evaluateModuleMSE, net, minimize=True)

for i in range(100):
net = ga.learn(0)[0]

print(net.activate([0,0]))
print(net.activate([1,0]))
print(net.activate([0,1]))
print(net.activate([1,1]))

उत्पादन

इनपुट के लिए नेटवर्क पर सक्रिय विधि नीचे दिखाए गए आउटपुट के साथ लगभग मेल खाती है -

C:\pybrain\pybrain\src>python example15.py
[0.03055398]
[0.92094839]
[1.12246157]
[0.02071285]

परतें मूल रूप से फ़ंक्शंस का एक सेट होती हैं जिनका उपयोग नेटवर्क की छिपी हुई परतों पर किया जाता है।

हम इस अध्याय में परतों के बारे में निम्नलिखित विवरण से गुजरेंगे -

  • समझ की परत
  • Pybrain का उपयोग करके परत बनाना

परतों को समझना

हमने पहले के उदाहरण देखे हैं जहां हमने परतों का उपयोग इस प्रकार किया है -

  • TanhLayer
  • SoftmaxLayer

उदाहरण Tanhayer का उपयोग कर

नीचे एक उदाहरण है जहाँ हमने नेटवर्क बनाने के लिए तन्हेलर का उपयोग किया है -

testnetwork.py

from pybrain.tools.shortcuts import buildNetwork
from pybrain.structure import TanhLayer
from pybrain.datasets import SupervisedDataSet
from pybrain.supervised.trainers import BackpropTrainer

# Create a network with two inputs, three hidden, and one output
nn = buildNetwork(2, 3, 1, bias=True, hiddenclass=TanhLayer)

# Create a dataset that matches network input and output sizes:
norgate = SupervisedDataSet(2, 1)

# Create a dataset to be used for testing.
nortrain = SupervisedDataSet(2, 1)

# Add input and target values to dataset
# Values for NOR truth table
norgate.addSample((0, 0), (1,))
norgate.addSample((0, 1), (0,))
norgate.addSample((1, 0), (0,))
norgate.addSample((1, 1), (0,))

# Add input and target values to dataset
# Values for NOR truth table
nortrain.addSample((0, 0), (1,))
nortrain.addSample((0, 1), (0,))
nortrain.addSample((1, 0), (0,))
nortrain.addSample((1, 1), (0,))

#Training the network with dataset norgate.
trainer = BackpropTrainer(nn, norgate)

# will run the loop 1000 times to train it.
for epoch in range(1000):
   trainer.train()
trainer.testOnData(dataset=nortrain, verbose = True)

उत्पादन

उपरोक्त कोड के लिए आउटपुट निम्नानुसार है -

python testnetwork.py

C:\pybrain\pybrain\src>python testnetwork.py
Testing on data:
('out: ', '[0.887 ]')
('correct:', '[1 ]')
error: 0.00637334
('out: ', '[0.149 ]')
('correct:', '[0 ]')
error: 0.01110338
('out: ', '[0.102 ]')
('correct:', '[0 ]')
error: 0.00522736
('out: ', '[-0.163]')
('correct:', '[0 ]')
error: 0.01328650
('All errors:', [0.006373344564625953, 0.01110338071737218, 
   0.005227359234093431, 0.01328649974219942])
('Average error:', 0.008997646064572746)
('Max error:', 0.01328649974219942, 'Median error:', 0.01110338071737218)

सॉफ्टमैक्सलेयर का उपयोग करके उदाहरण

नीचे एक उदाहरण है जहाँ हमने नेटवर्क बनाने के लिए सॉफ्टमैक्सलेयर का उपयोग किया है -

from pybrain.tools.shortcuts import buildNetwork
from pybrain.structure.modules import SoftmaxLayer
from pybrain.datasets import SupervisedDataSet
from pybrain.supervised.trainers import BackpropTrainer

# Create a network with two inputs, three hidden, and one output
nn = buildNetwork(2, 3, 1, bias=True, hiddenclass=SoftmaxLayer)

# Create a dataset that matches network input and output sizes:
norgate = SupervisedDataSet(2, 1)

# Create a dataset to be used for testing.
nortrain = SupervisedDataSet(2, 1)

# Add input and target values to dataset
# Values for NOR truth table
norgate.addSample((0, 0), (1,))
norgate.addSample((0, 1), (0,))
norgate.addSample((1, 0), (0,))
norgate.addSample((1, 1), (0,))

# Add input and target values to dataset
# Values for NOR truth table
nortrain.addSample((0, 0), (1,))
nortrain.addSample((0, 1), (0,))
nortrain.addSample((1, 0), (0,))
nortrain.addSample((1, 1), (0,))

#Training the network with dataset norgate.
trainer = BackpropTrainer(nn, norgate)

# will run the loop 1000 times to train it.
for epoch in range(1000):
trainer.train()
trainer.testOnData(dataset=nortrain, verbose = True)

उत्पादन

आउटपुट इस प्रकार है -

C:\pybrain\pybrain\src>python example16.py
Testing on data:
('out: ', '[0.918 ]')
('correct:', '[1 ]')
error: 0.00333524
('out: ', '[0.082 ]')
('correct:', '[0 ]')
error: 0.00333484
('out: ', '[0.078 ]')
('correct:', '[0 ]')
error: 0.00303433
('out: ', '[-0.082]')
('correct:', '[0 ]')
error: 0.00340005
('All errors:', [0.0033352368788838365, 0.003334842961037291, 
   0.003034328685718761, 0.0034000458892589056])
('Average error:', 0.0032761136037246985)
('Max error:', 0.0034000458892589056, 'Median error:', 0.0033352368788838365)

Pybrain में परत बनाना

Pybrain में, आप निम्नानुसार अपनी परत बना सकते हैं -

एक परत बनाने के लिए, आपको उपयोग करने की आवश्यकता है NeuronLayer class सभी प्रकार की परतें बनाने के लिए बेस क्लास के रूप में।

उदाहरण

from pybrain.structure.modules.neuronlayer import NeuronLayer
class LinearLayer(NeuronLayer):
   def _forwardImplementation(self, inbuf, outbuf):
      outbuf[:] = inbuf
   def _backwardImplementation(self, outerr, inerr, outbuf, inbuf):
      inerr[:] = outer

एक परत बनाने के लिए, हमें दो तरीकों को लागू करने की आवश्यकता है: _forwardImplementation () और _backwardImplementation ()

The _forwardImplementation() takes in 2 arguments inbufऔर प्रकोप, जो स्कैपी सरणियां हैं। इसका आकार परतों के इनपुट और आउटपुट आयामों पर निर्भर है।

_BackwardImplementation () दिए गए इनपुट के संबंध में उत्पादन के व्युत्पन्न गणना करने के लिए प्रयोग किया जाता है।

तो Pybrain में एक परत को लागू करने के लिए, यह परत वर्ग का कंकाल है -

from pybrain.structure.modules.neuronlayer import NeuronLayer
class NewLayer(NeuronLayer):
   def _forwardImplementation(self, inbuf, outbuf):
      pass
   def _backwardImplementation(self, outerr, inerr, outbuf, inbuf):
      pass

यदि आप एक परत के रूप में एक द्विघात बहुपद समारोह को लागू करना चाहते हैं, तो हम निम्नानुसार कर सकते हैं -

विचार करें कि हमारे पास एक बहुपद समारोह है -

f(x) = 3x2

उपरोक्त बहुपद समारोह का व्युत्पन्न निम्नानुसार होगा -

f(x) = 6 x

उपरोक्त बहुपद समारोह के लिए अंतिम परत वर्ग निम्नानुसार होगा -

testlayer.py

from pybrain.structure.modules.neuronlayer import NeuronLayer
class PolynomialLayer(NeuronLayer):
   def _forwardImplementation(self, inbuf, outbuf):
      outbuf[:] = 3*inbuf**2
   def _backwardImplementation(self, outerr, inerr, outbuf, inbuf):
      inerr[:] = 6*inbuf*outerr

अब नीचे दी गई परत के रूप में बनाई गई परत का उपयोग करते हैं -

testlayer1.py

from testlayer import PolynomialLayer
from pybrain.tools.shortcuts import buildNetwork
from pybrain.tests.helpers import gradientCheck

n = buildNetwork(2, 3, 1, hiddenclass=PolynomialLayer)
n.randomize()

gradientCheck(n)

GradientCheck () यह परीक्षण करेगा कि परत ठीक काम कर रही है या नहीं। हमें उस नेटवर्क को पास करने की आवश्यकता है जहां परत gradientCheck (n) के लिए उपयोग की जाती है। यदि परत ठीक काम कर रही है तो यह "परफेक्ट ग्रेडिएंट" के रूप में आउटपुट देगा।

उत्पादन

C:\pybrain\pybrain\src>python testlayer1.py
Perfect gradient

एक कनेक्शन एक परत के समान काम करता है; केवल एक अंतर यह है कि यह एक नेटवर्क में एक नोड से दूसरे डेटा को शिफ्ट करता है।

इस अध्याय में, हम इसके बारे में जानने जा रहे हैं -

  • कनेक्शंस को समझना
  • संबंध बनाना

कनेक्शंस को समझना

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

उदाहरण

ffy.py

from pybrain.structure import FeedForwardNetwork
from pybrain.structure import LinearLayer, SigmoidLayer
from pybrain.structure import FullConnection

network = FeedForwardNetwork()

#creating layer for input => 2 , hidden=> 3 and output=>1
inputLayer = LinearLayer(2)
hiddenLayer = SigmoidLayer(3)
outputLayer = LinearLayer(1)

#adding the layer to feedforward network
network.addInputModule(inputLayer)
network.addModule(hiddenLayer)
network.addOutputModule(outputLayer)

#Create connection between input ,hidden and output
input_to_hidden = FullConnection(inputLayer, hiddenLayer)
hidden_to_output = FullConnection(hiddenLayer, outputLayer)

#add connection to the network
network.addConnection(input_to_hidden)
network.addConnection(hidden_to_output)
network.sortModules()

print(network)

उत्पादन

C:\pybrain\pybrain\src>python ffn.py
FeedForwardNetwork-6
Modules:
[<LinearLayer 'LinearLayer-3'>, <SigmoidLayer 'SigmoidLayer-7'>, 
   <LinearLayer 'LinearLayer-8'>]
Connections:
[<FullConnection 'FullConnection-4': 'SigmoidLayer-7' -> 'LinearLayer-8'>, 
   <FullConnection 'FullConnection-5': 'LinearLayer-3' -> 'SigmoidLayer-7'>]

संबंध बनाना

Pybrain में, हम कनेक्शन मॉड्यूल का उपयोग करके कनेक्शन बना सकते हैं जैसा कि नीचे दिखाया गया है -

उदाहरण

connect.py

from pybrain.structure.connections.connection import Connection
class YourConnection(Connection):
   def __init__(self, *args, **kwargs):
      Connection.__init__(self, *args, **kwargs)
   def _forwardImplementation(self, inbuf, outbuf):
      outbuf += inbuf
   def _backwardImplementation(self, outerr, inerr, inbuf):
      inerr += outer

कनेक्शन बनाने के लिए, 2 विधियाँ हैं - _forwardIm कार्यान्वयन () और _backwardImplementation ()

_ForwardImplementation () भेजे मॉड्यूल जो है के उत्पादन में बफर के साथ कहा जाता है inbuf , और कहा जाता है बाहर जाने वाले मॉड्यूल के इनपुट बफर outbufInbuf बाहर जाने वाले मॉड्यूल में जोड़ा जाता है outbuf

_BackwardImplementation () के साथ कहा जाता है outerr , inerr , और inbuf । आउटगोइंग मॉड्यूल त्रुटि _backwardIm कार्यान्वयन () में आने वाले मॉड्यूल त्रुटि में जोड़ा जाता है ।

आइये अब उपयोग करते हैं YourConnection एक नेटवर्क में

testconnection.py

from pybrain.structure import FeedForwardNetwork
from pybrain.structure import LinearLayer, SigmoidLayer
from connect import YourConnection

network = FeedForwardNetwork()

#creating layer for input => 2 , hidden=> 3 and output=>1
inputLayer = LinearLayer(2)
hiddenLayer = SigmoidLayer(3)
outputLayer = LinearLayer(1)

#adding the layer to feedforward network
network.addInputModule(inputLayer)
network.addModule(hiddenLayer)
network.addOutputModule(outputLayer)

#Create connection between input ,hidden and output
input_to_hidden = YourConnection(inputLayer, hiddenLayer)
hidden_to_output = YourConnection(hiddenLayer, outputLayer)

#add connection to the network
network.addConnection(input_to_hidden)
network.addConnection(hidden_to_output)
network.sortModules()

print(network)

उत्पादन

C:\pybrain\pybrain\src>python testconnection.py
FeedForwardNetwork-6
Modules:
[<LinearLayer 'LinearLayer-3'>, <SigmoidLayer 'SigmoidLayer-7'>, 
   <LinearLayer 'LinearLayer-8'>]
Connections:
[<YourConnection 'YourConnection-4': 'LinearLayer-3' -> 'SigmoidLayer-7'>, 
   <YourConnection 'YourConnection-5': 'SigmoidLayer-7' -> 'LinearLayer-8'>]

मशीन लर्निंग में सुदृढीकरण सीखना (RL) एक महत्वपूर्ण हिस्सा है। सुदृढीकरण सीखने से वातावरण के इनपुट के आधार पर एजेंट अपने व्यवहार को सीखता है।

सुदृढीकरण के दौरान एक दूसरे के साथ बातचीत करने वाले घटक इस प्रकार हैं -

  • Environment
  • Agent
  • Task
  • Experiment

सुदृढीकरण सीखने का लेआउट नीचे दिया गया है -

आरएल में, एजेंट पर्यावरण के साथ पुनरावृत्ति में बात करता है। प्रत्येक पुनरावृत्ति पर, एजेंट को एक अवलोकन प्राप्त होता है जिसमें इनाम होता है। यह तब कार्रवाई को चुनता है और पर्यावरण को भेजता है। प्रत्येक पुनरावृत्ति पर वातावरण एक नई स्थिति में चला जाता है और प्रत्येक बार प्राप्त इनाम बच जाता है।

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

आइए हम Pybrain में आरएल के साथ काम करने के तरीके पर एक नज़र डालें।

हम भूलभुलैया पर काम करने जा रहे हैं environmentजिसका प्रतिनिधित्व 2 आयामी संख्या में किया जाएगा, जहाँ 1 एक दीवार है और 0 एक मुक्त क्षेत्र है। एजेंट की जिम्मेदारी है कि वह मुक्त क्षेत्र में आगे बढ़े और लक्ष्य बिंदु खोजे।

यहाँ भूलभुलैया के वातावरण के साथ काम करने का एक चरण है।

चरण 1

नीचे दिए गए कोड के साथ हमारे द्वारा आवश्यक पैकेज आयात करें -

from scipy import *
import sys, time
import matplotlib.pyplot as pylab # for visualization we are using mathplotlib

from pybrain.rl.environments.mazes import Maze, MDPMazeTask
from pybrain.rl.learners.valuebased import ActionValueTable
from pybrain.rl.agents import LearningAgent
from pybrain.rl.learners import Q, QLambda, SARSA #@UnusedImport
from pybrain.rl.explorers import BoltzmannExplorer #@UnusedImport
from pybrain.rl.experiments import Experiment
from pybrain.rl.environments import Task

चरण 2

नीचे दिए गए कोड का उपयोग करके भूलभुलैया का वातावरण बनाएं -

# create the maze with walls as 1 and 0 is a free field
mazearray = array(
   [[1, 1, 1, 1, 1, 1, 1, 1, 1],
   [1, 0, 0, 1, 0, 0, 0, 0, 1],
   [1, 0, 0, 1, 0, 0, 1, 0, 1],
   [1, 0, 0, 1, 0, 0, 1, 0, 1],
   [1, 0, 0, 1, 0, 1, 1, 0, 1],
   [1, 0, 0, 0, 0, 0, 1, 0, 1],
   [1, 1, 1, 1, 1, 1, 1, 0, 1],
   [1, 0, 0, 0, 0, 0, 0, 0, 1],
   [1, 1, 1, 1, 1, 1, 1, 1, 1]]
)
env = Maze(mazearray, (7, 7)) # create the environment, the first parameter is the 
maze array and second one is the goal field tuple

चरण 3

एजेंट बनाने के लिए अगला कदम है।

एजेंट आरएल में एक महत्वपूर्ण भूमिका निभाता है। यह गेटअवेशन () और इंटीग्रोऑब्जर्वेशन () विधियों का उपयोग करके भूलभुलैया के वातावरण के साथ बातचीत करेगा।

एजेंट के पास एक नियंत्रक है (जो क्रियाओं के लिए राज्यों को मैप करेगा) और एक शिक्षार्थी।

PyBrain में नियंत्रक एक मॉड्यूल की तरह है, जिसके लिए इनपुट राज्यों है और उन्हें क्रियाओं में परिवर्तित करते हैं।

controller = ActionValueTable(81, 4)
controller.initialize(1.)

ActionValueTable2 आदानों की जरूरत है, यानी, राज्यों और कार्यों की संख्या। मानक भूलभुलैया के वातावरण में 4 क्रियाएं हैं: उत्तर, दक्षिण, पूर्व, पश्चिम।

अब हम एक शिक्षार्थी बनाएंगे। हम एजेंट के साथ उपयोग किए जाने वाले सीखने के लिए SARSA () लर्निंग एल्गोरिदम का उपयोग करने जा रहे हैं।

learner = SARSA()
agent = LearningAgent(controller, learner)

चरण 4

यह कदम एजेंट को पर्यावरण से जोड़ रहा है।

एजेंट को पर्यावरण से जोड़ने के लिए, हमें कार्य नामक एक विशेष घटक की आवश्यकता होती है। की भूमिका एtask पर्यावरण में लक्ष्य की तलाश करना है और एजेंट को कार्यों के लिए पुरस्कार कैसे मिलते हैं।

पर्यावरण का अपना कार्य है। जिस भूलभुलैया वातावरण का हमने उपयोग किया है, उसमें MDPMazeTask कार्य है। एमडीपी के लिए खड़ा है“markov decision process”जिसका अर्थ है, एजेंट भूलभुलैया में अपनी स्थिति जानता है। पर्यावरण कार्य के लिए एक पैरामीटर होगा।

task = MDPMazeTask(env)

चरण 5

वातावरण में एजेंट जोड़ने के बाद अगला कदम एक प्रयोग करना है।

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

experiment = Experiment(task, agent)

अब हम नीचे दिखाए अनुसार प्रयोग को 1000 बार चलाने जा रहे हैं -

for i in range(1000):
   experiment.doInteractions(100)
   agent.learn()
   agent.reset()

निम्न कोड निष्पादित होने पर एजेंट और कार्य के बीच वातावरण 100 बार चलेगा -

experiment.doInteractions(100)

प्रत्येक पुनरावृत्ति के बाद, यह कार्य को एक नया राज्य देता है जो यह तय करता है कि एजेंट को कौन सी जानकारी और इनाम पारित किया जाना चाहिए। हम लूप के लिए एजेंट के अंदर सीखने और रीसेट करने के बाद एक नई तालिका तैयार करने जा रहे हैं।

for i in range(1000):
   experiment.doInteractions(100)
   agent.learn()
   agent.reset()
   pylab.pcolor(table.params.reshape(81,4).max(1).reshape(9,9))
   pylab.savefig("test.png")

यहाँ पूर्ण कोड है -

उदाहरण

maze.py

from scipy import *
import sys, time
import matplotlib.pyplot as pylab

from pybrain.rl.environments.mazes import Maze, MDPMazeTask
from pybrain.rl.learners.valuebased import ActionValueTable
from pybrain.rl.agents import LearningAgent
from pybrain.rl.learners import Q, QLambda, SARSA #@UnusedImport
from pybrain.rl.explorers import BoltzmannExplorer #@UnusedImport
from pybrain.rl.experiments import Experiment
from pybrain.rl.environments import Task

# create maze array
mazearray = array(
   [[1, 1, 1, 1, 1, 1, 1, 1, 1],
   [1, 0, 0, 1, 0, 0, 0, 0, 1],
   [1, 0, 0, 1, 0, 0, 1, 0, 1],
   [1, 0, 0, 1, 0, 0, 1, 0, 1],
   [1, 0, 0, 1, 0, 1, 1, 0, 1],
   [1, 0, 0, 0, 0, 0, 1, 0, 1],
   [1, 1, 1, 1, 1, 1, 1, 0, 1],
   [1, 0, 0, 0, 0, 0, 0, 0, 1],
   [1, 1, 1, 1, 1, 1, 1, 1, 1]]
)
env = Maze(mazearray, (7, 7))

# create task
task = MDPMazeTask(env)

#controller in PyBrain is like a module, for which the input is states and 
convert them into actions.
controller = ActionValueTable(81, 4)
controller.initialize(1.)

# create agent with controller and learner - using SARSA()
learner = SARSA()

# create agent
agent = LearningAgent(controller, learner)

# create experiment
experiment = Experiment(task, agent)

# prepare plotting
pylab.gray()
pylab.ion()

for i in range(1000):
experiment.doInteractions(100)

agent.learn()
agent.reset()

pylab.pcolor(controller.params.reshape(81,4).max(1).reshape(9,9))
pylab.savefig("test.png")

उत्पादन

python maze.py

प्रत्येक पुनरावृत्ति पर मुक्त क्षेत्र में रंग बदला जाएगा।

अब हम जानते हैं कि नेटवर्क कैसे बनाया जाए और इसे कैसे प्रशिक्षित किया जाए। इस अध्याय में, हम समझेंगे कि नेटवर्क कैसे बनाया और बचाया जाए, और जब भी आवश्यकता हो नेटवर्क का उपयोग करें।

सहेजें और पुनर्प्राप्त नेटवर्क

हम Pybrain टूल यानी pybrain.tools.customxml से NetworkWriter और NetworkReader का उपयोग करने जा रहे हैं।

यहाँ एक काम कर रहा है उदाहरण -

from pybrain.tools.shortcuts import buildNetwork
from pybrain.tools.customxml import NetworkWriter
from pybrain.tools.customxml import NetworkReader

net = buildNetwork(2,1,1)
NetworkWriter.writeToFile(net, 'network.xml')
net = NetworkReader.readFrom('network.xml')

नेटवर्क network.xml के अंदर सहेजा जाता है।

NetworkWriter.writeToFile(net, 'network.xml')

जब आवश्यक हो तो xml पढ़ने के लिए हम कोड का उपयोग कर सकते हैं -

net = NetworkReader.readFrom('network.xml')

यहाँ network.xml फ़ाइल बनाई गई है -

<?xml version="1.0" ?>
<PyBrain>
   <Network class="pybrain.structure.networks.feedforward.FeedForwardNetwork" name="FeedForwardNetwork-8">
      <name val="'FeedForwardNetwork-8'"/>
      <Modules>
         <LinearLayer class="pybrain.structure.modules.linearlayer.LinearLayer" inmodule="True" name="in">
            <name val="'in'"/>
            <dim val="2"/>
         </LinearLayer>
         
         <LinearLayer class="pybrain.structure.modules.linearlayer.LinearLayer" name="out" outmodule="True">
            <name val="'out'"/>
            <dim val="1"/>
         </LinearLayer>
         
         <BiasUnit class="pybrain.structure.modules.biasunit.BiasUnit" name="bias">
            <name val="'bias'"/>
         </BiasUnit>
         
         <SigmoidLayer class="pybrain.structure.modules.sigmoidlayer.SigmoidLayer" name="hidden0">
            <name val="'hidden0'"/>
            <dim val="1"/>
         </SigmoidLayer>
      </Modules>
      
      <Connections>
         <FullConnection class="pybrain.structure.connections.full.FullConnection" name="FullConnection-6">
            <inmod val="bias"/>
            <outmod val="out"/>
            <Parameters>[1.2441093186965146]</Parameters>
         </FullConnection>
         
         <FullConnection class="pybrain.structure.connections.full.FullConnection" name="FullConnection-7">
            <inmod val="bias"/>
            <outmod val="hidden0"/>
            <Parameters>[-1.5743530012126412]</Parameters>
         </FullConnection>
         
         <FullConnection class="pybrain.structure.connections.full.FullConnection" name="FullConnection-4">
            <inmod val="in"/>
            <outmod val="hidden0"/>
            <Parameters>[-0.9429546042034236, -0.09858196752687162]</Parameters>
         </FullConnection>
         
         <FullConnection class="pybrain.structure.connections.full.FullConnection" name="FullConnection-5">
            <inmod val="hidden0"/>
            <outmod val="out"/>
            <Parameters>[-0.29205472354634304]</Parameters>
         </FullConnection>
      </Connections>
      
   </Network>
</PyBrain>

एपीआई

नीचे एपीआई की एक सूची है जो हमने इस ट्यूटोरियल में उपयोग की है।

नेटवर्क के लिए

  • activate(input)- यह पैरामीटर, अर्थात, परीक्षण किया जाने वाला मान लेता है। यह दिए गए इनपुट के आधार पर परिणाम वापस कर देगा।

  • activateOnDataset(dataset) - यह दिए गए डेटासेट पर पुनरावृति करेगा और आउटपुट लौटाएगा।

  • addConnection(c) - नेटवर्क से कनेक्शन जोड़ता है।

  • addInputModule(m) - नेटवर्क को दिए गए मॉड्यूल को जोड़ता है और इसे इनपुट मॉड्यूल के रूप में चिह्नित करता है।

  • addModule(m) - दिए गए मॉड्यूल को नेटवर्क में जोड़ता है।

  • addOutputModule(m) - मॉड्यूल को नेटवर्क में जोड़ता है और इसे आउटपुट मॉड्यूल के रूप में चिह्नित करता है।

  • reset() - मॉड्यूल और नेटवर्क को रीसेट करता है।

  • sortModules()- यह आंतरिक रूप से सॉर्ट करके सक्रियण के लिए नेटवर्क तैयार करता है। इसे सक्रियण से पहले बुलाया जाना है।

पर्यवेक्षित डेटासेट के लिए

  • addSample(inp, target) - इनपुट और लक्ष्य का एक नया नमूना जोड़ता है।

  • splitWithProportion(proportion=0.5) - डेटासेट को दो भागों में विभाजित करता है, पहला भाग जिसमें आनुपातिक भाग डेटा होता है और अगला सेट जिसमें शेष भाग होता है।

प्रशिक्षकों के लिए

trainUntilConvergence(dataset=None, maxEpochs=None, verbose=None, continueEpochs=10, validationProportion=0.25)- इसका उपयोग डेटासेट पर मॉड्यूल को तब तक करने के लिए किया जाता है जब तक कि यह परिवर्तित न हो जाए। यदि डाटासेट नहीं दिया गया है, तो यह शुरुआत में उपयोग किए गए प्रशिक्षित डेटासेट पर प्रशिक्षित करने का प्रयास करेगा।

इस अध्याय में, PyBrain का उपयोग करके निष्पादित होने वाले सभी संभावित उदाहरण सूचीबद्ध हैं।

उदाहरण 1

NOR ट्रुथ टेबल के साथ काम करना और शुद्धता के लिए परीक्षण करना।

from pybrain.tools.shortcuts import buildNetwork
from pybrain.structure import TanhLayer
from pybrain.datasets import SupervisedDataSet
from pybrain.supervised.trainers import BackpropTrainer

# Create a network with two inputs, three hidden, and one output
nn = buildNetwork(2, 3, 1, bias=True, hiddenclass=TanhLayer)

# Create a dataset that matches network input and output sizes:
norgate = SupervisedDataSet(2, 1)

# Create a dataset to be used for testing.
nortrain = SupervisedDataSet(2, 1)

# Add input and target values to dataset
# Values for NOR truth table
norgate.addSample((0, 0), (1,))
norgate.addSample((0, 1), (0,))
norgate.addSample((1, 0), (0,))
norgate.addSample((1, 1), (0,))

# Add input and target values to dataset
# Values for NOR truth table
nortrain.addSample((0, 0), (1,))
nortrain.addSample((0, 1), (0,))
nortrain.addSample((1, 0), (0,))
nortrain.addSample((1, 1), (0,))

#Training the network with dataset norgate.
trainer = BackpropTrainer(nn, norgate)

# will run the loop 1000 times to train it.
for epoch in range(1000):
   trainer.train()
trainer.testOnData(dataset=nortrain, verbose = True)

उत्पादन

C:\pybrain\pybrain\src>python testnetwork.py
Testing on data:
('out: ', '[0.887 ]')
('correct:', '[1 ]')
error: 0.00637334
('out: ', '[0.149 ]')
('correct:', '[0 ]')
error: 0.01110338
('out: ', '[0.102 ]')
('correct:', '[0 ]')
error: 0.00522736
('out: ', '[-0.163]')
('correct:', '[0 ]')
error: 0.01328650
('All errors:', [0.006373344564625953, 0.01110338071737218, 
   0.005227359234093431, 0.01328649974219942])
('Average error:', 0.008997646064572746)
('Max error:', 0.01328649974219942, 'Median error:', 0.01110338071737218)

उदाहरण 2

डेटासेट के लिए, हम नीचे दिखाए गए अनुसार स्केलेर डेटासेट से डेटासेट का उपयोग करने जा रहे हैं: sklearn से load_digits डेटासेट देखें: scikit-learn.org

इसमें १० वर्ग हैं, यानी ०- ९ से अनुमानित अंक।

X में कुल इनपुट डेटा 64 है।

from sklearn import datasets
import matplotlib.pyplot as plt

from pybrain.datasets import ClassificationDataSet
from pybrain.utilities import percentError
from pybrain.tools.shortcuts import buildNetwork
from pybrain.supervised.trainers import BackpropTrainer
from pybrain.structure.modules import SoftmaxLayer
from numpy import ravel

digits = datasets.load_digits()
X, y = digits.data, digits.target
ds = ClassificationDataSet(64, 1, nb_classes=10) ) 

# we are having inputs are 64 dim array and since the digits are from 0-9 
the classes considered is 10.

for i in range(len(X)):
ds.addSample(ravel(X[i]), y[i]) # adding sample to datasets
test_data_temp, training_data_temp = ds.splitWithProportion(0.25) 

#Splitting the datasets 25% as testdata and 75% as trained data
# Using splitWithProportion() method on dataset converts the dataset to 
#superviseddataset, so we will convert the dataset back to classificationdataset 
#as shown in above step.
test_data = ClassificationDataSet(64, 1, nb_classes=10)

for n in range(0, test_data_temp.getLength()):
test_data.addSample( test_data_temp.getSample(n)[0], test_data_temp.getSample(n)[1] )
training_data = ClassificationDataSet(64, 1, nb_classes=10)

for n in range(0, training_data_temp.getLength()):
training_data.addSample( 
   training_data_temp.getSample(n)[0], training_data_temp.getSample(n)[1] 
)
test_data._convertToOneOfMany()
training_data._convertToOneOfMany()
net = buildNetwork(
   training_data.indim, 64, training_data.outdim, outclass=SoftmaxLayer
)
#creating a network wherein the input and output are used from the training data.
trainer = BackpropTrainer(
   net, dataset=training_data, momentum=0.1,learningrate=0.01,verbose=True,weightdecay=0.01
)
#Training the Network
trnerr,valerr = trainer.trainUntilConvergence(dataset=training_data,maxEpochs=10)

#Visualizing the error and validation data
plt.plot(trnerr,'b',valerr,'r')
plt.show()
trainer.trainEpochs(10)
print('Percent Error on testData:',percentError(
   trainer.testOnClassData(dataset=test_data), test_data['class']
))

उत्पादन

Total error: 0.0432857814358
Total error: 0.0222276374185
Total error: 0.0149012052174
Total error: 0.011876985318
Total error: 0.00939854792853
Total error: 0.00782202445183
Total error: 0.00714707652044
Total error: 0.00606068893793
Total error: 0.00544257958975
Total error: 0.00463929281336
Total error: 0.00441275665294
('train-errors:', '[0.043286 , 0.022228 , 0.014901 , 0.011877 , 0.009399 , 0.007
   822 , 0.007147 , 0.006061 , 0.005443 , 0.004639 , 0.004413 ]')
('valid-errors:', '[0.074296 , 0.027332 , 0.016461 , 0.014298 , 0.012129 , 0.009
   248 , 0.008922 , 0.007917 , 0.006547 , 0.005883 , 0.006572 , 0.005811 ]')
Percent Error on testData: 3.34075723830735