थीनो - त्वरित गाइड

क्या आपने पायथन में मशीन लर्निंग मॉडल विकसित किया है? फिर, जाहिर है कि आप इन मॉडलों को विकसित करने में पेचीदगियों को जानते हैं। विकास आमतौर पर कम्प्यूटेशनल शक्ति के घंटे और दिन लेने की एक धीमी प्रक्रिया है।

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

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

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

इस ट्यूटोरियल में, आप थीनो लाइब्रेरी का उपयोग करना सीखेंगे।

थीनो को विंडोज, मैकओएस और लिनक्स पर स्थापित किया जा सकता है। सभी मामलों में स्थापना तुच्छ है। Theano को स्थापित करने से पहले, आपको इसकी निर्भरता स्थापित करनी होगी। निम्नलिखित निर्भरताओं की सूची है -

  • Python
  • न्यूम्पी - आवश्यक
  • SciPy - केवल विरल मैट्रिक्स और विशेष कार्यों के लिए आवश्यक है
  • BLAS - बेसिक वेक्टर और मैट्रिक्स ऑपरेशन करने के लिए मानक बिल्डिंग ब्लॉक प्रदान करता है

वैकल्पिक पैकेज जो आप अपनी आवश्यकताओं के आधार पर स्थापित करने के लिए चुन सकते हैं -

  • नाक: थीनो के टेस्ट-सूट को चलाने के लिए
  • स्फिंक्स - दस्तावेज़ के निर्माण के लिए
  • ग्रिपिज़ और पाइडोट - ग्राफिक्स और छवियों को संभालने के लिए
  • NVIDIA CUDA ड्राइवर - GPU कोड पीढ़ी / निष्पादन के लिए आवश्यक है
  • libgpuarray - CUDA और OpenCL उपकरणों पर GPU / CPU कोड जेनरेशन के लिए आवश्यक है

हम MacOS में थीनो को स्थापित करने के चरणों पर चर्चा करेंगे।

MacOS स्थापना

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

$ pip install Theano
$ pip install numpy
$ pip install scipy
$ pip install pydot

आपको निम्न कमांड का उपयोग करके OSx कमांड लाइन डेवलपर टूल स्थापित करना होगा -

$ xcode-select --install

आपको निम्न स्क्रीन दिखाई देगी। पर क्लिक करेंInstall उपकरण स्थापित करने के लिए बटन।

सफल स्थापना पर, आप कंसोल पर सफलता संदेश देखेंगे।

स्थापना का परीक्षण

स्थापना सफलतापूर्वक पूर्ण होने के बाद, एनाकोंडा जुपिटर में एक नई नोटबुक खोलें। कोड सेल में, निम्नलिखित पायथन स्क्रिप्ट दर्ज करें -

उदाहरण

import theano
from theano import tensor
a = tensor.dscalar()
b = tensor.dscalar()
c = a + b
f = theano.function([a,b], c)
d = f(1.5, 2.5)
print (d)

उत्पादन

स्क्रिप्ट निष्पादित करें और आपको निम्न आउटपुट देखना चाहिए -

4.0

निष्पादन का स्क्रीनशॉट आपके त्वरित संदर्भ के लिए नीचे दिखाया गया है -

यदि आपको उपरोक्त आउटपुट मिलता है, तो आपका थीनो इंस्टॉलेशन सफल है। यदि नहीं, तो समस्याओं को ठीक करने के लिए Theano डाउनलोड पृष्ठ पर डीबग निर्देशों का पालन करें।

क्या है थीनो?

अब जब आपने थीनो को सफलतापूर्वक स्थापित कर लिया है, तो पहले हमें यह समझने की कोशिश करें कि थीनो क्या है? थीनो एक पायथन लाइब्रेरी है। यह आपको गणितीय अभिव्यक्तियों को परिभाषित, अनुकूलन और मूल्यांकन करने देता है, विशेष रूप से जो मशीन लर्निंग मॉडल विकास में उपयोग किया जाता है। थीनो में ही कोई पूर्व-परिभाषित एमएल मॉडल नहीं हैं; यह सिर्फ इसके विकास की सुविधा देता है। बहु-आयामी सरणियों से निपटने के दौरान यह विशेष रूप से उपयोगी है। यह मूल रूप से NumPy के साथ एकीकृत होता है, जो कि पायथन में वैज्ञानिक गणना के लिए एक मौलिक और व्यापक रूप से उपयोग किया जाने वाला पैकेज है।

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

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

अब हम थीनो के विकास की प्रक्रिया को समझेंगे। आइए शुरुआत करते हैं कि थीनो में गणितीय अभिव्यक्ति को कैसे परिभाषित किया जाए।

हमें थीनो में एक तुच्छ अभिव्यक्ति को परिभाषित और मूल्यांकन करके थीनो की अपनी यात्रा शुरू करनी चाहिए। दो खंभों को जोड़ने वाली निम्नलिखित तुच्छ अभिव्यक्ति पर विचार करें -

c = a + b

कहाँ पे a, b चर हैं और cअभिव्यक्ति आउटपुट है। थीनो में, परिभाषित करना और मूल्यांकन करना यहां तक ​​कि यह तुच्छ अभिव्यक्ति मुश्किल है।

आइए हम उपरोक्त अभिव्यक्ति के मूल्यांकन के चरणों को समझें।

आयात थीनो

सबसे पहले, हमें अपने कार्यक्रम में थीनो लाइब्रेरी को आयात करने की आवश्यकता है, जिसे हम निम्नलिखित कथन का उपयोग करते हैं -

from theano import *

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

भिन्नता की घोषणा

आगे हम एक वैरिएबल घोषित करेंगे a निम्नलिखित कथन का उपयोग करते हुए -

a = tensor.dscalar()

dscalarविधि एक दशमलव अदिश चर घोषित करती है। उपर्युक्त कथन का निष्पादन नामक एक चर बनाता हैaअपने प्रोग्राम कोड में। इसी तरह, हम परिवर्तनशील बनाएंगेb निम्नलिखित कथन का उपयोग करते हुए -

b = tensor.dscalar()

अभिव्यक्ति को परिभाषित करना

अगला, हम अपनी अभिव्यक्ति को परिभाषित करेंगे जो इन दो चर पर संचालित होती है a तथा b

c = a + b

थीनो में, उपरोक्त कथन का निष्पादन दो चर का स्केलर जोड़ नहीं करता है a तथा b

थीनो फ़ंक्शन को परिभाषित करना

उपरोक्त अभिव्यक्ति का मूल्यांकन करने के लिए, हमें थीनो में एक फ़ंक्शन को निम्नानुसार परिभाषित करना होगा -

f = theano.function([a,b], c)

कार्यक्रम functionदो तर्क लेता है, पहला तर्क फ़ंक्शन का एक इनपुट है और दूसरा इसका आउटपुट है। उपरोक्त घोषणा में कहा गया है कि पहला तर्क दो तत्वों से मिलकर टाइप एरे का हैa तथा b। आउटपुट एक अदिश इकाई है जिसे कहा जाता हैc। इस फ़ंक्शन को चर नाम के साथ संदर्भित किया जाएगाf हमारे आगे कोड में।

थीनो फंक्शन को लागू करना

फ़ंक्शन f का कॉल निम्न कथन का उपयोग करके किया जाता है -

d = f(3.5, 5.5)

समारोह में इनपुट दो स्केल से मिलकर एक सरणी है: 3.5 तथा 5.5। निष्पादन का आउटपुट स्केलर चर को सौंपा गया हैd। की सामग्री मुद्रित करने के लिएd, हम उपयोग करेंगे print कथन -

print (d)

निष्पादन मूल्य का कारण होगा d कंसोल पर मुद्रित किया जाना है, जो इस मामले में 9.0 है।

पूर्ण कार्यक्रम लिस्टिंग

पूरा कार्यक्रम सूची आपके त्वरित संदर्भ के लिए यहां दी गई है -

from theano import *
a = tensor.dscalar()
b = tensor.dscalar()
c = a + b
f = theano.function([a,b], c)
d = f(3.5, 5.5)
print (d)

उपरोक्त कोड निष्पादित करें और आप आउटपुट को 9.0 के रूप में देखेंगे। स्क्रीन शॉट यहाँ दिखाया गया है -

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

हम दो मैट्रिक्स के एक डॉट उत्पाद की गणना करेंगे। पहला मैट्रिक्स आयाम 2 x 3 का है और दूसरा आयाम 3 x 2 का है। जिन मैट्रेस का हमने इनपुट के रूप में उपयोग किया है और उनके उत्पाद यहां व्यक्त किए गए हैं -

$$ \ start {bmatrix} 0 & -1 & 2 \\ 4 & 11 & 2 \ end {bmatrix} \: \ start {bmatrix} 3 & -1 \\ 1 & 2 \\ 35 & 20 \ अंत {bmatrix} = \ start {bmatrix} 11 & 0 \\ 35 & 20 \ end {bmatrix} $$

भिन्नता की घोषणा

उपरोक्त के लिए एक थीनो अभिव्यक्ति लिखने के लिए, हम पहले अपने वैरिएंट्स का प्रतिनिधित्व करने के लिए दो चर घोषित करते हैं -

a = tensor.dmatrix()
b = tensor.dmatrix()

डमेट्रिक्स डबल्स के लिए मैट्रिसेस का प्रकार है। ध्यान दें कि हम कहीं भी मैट्रिक्स का आकार निर्दिष्ट नहीं करते हैं। इस प्रकार, ये चर किसी भी आयाम के मैट्रिक्स का प्रतिनिधित्व कर सकते हैं।

अभिव्यक्ति को परिभाषित करना

डॉट उत्पाद की गणना करने के लिए, हमने बिल्ट-इन फ़ंक्शन का उपयोग किया है dot निम्नानुसार है -

c = tensor.dot(a,b)

गुणन का आउटपुट एक मैट्रिक्स चर को सौंपा जाता है जिसे कहा जाता है c

थीनो फ़ंक्शन को परिभाषित करना

अगला, हम अभिव्यक्ति के मूल्यांकन के लिए एक फ़ंक्शन को पहले के उदाहरण के रूप में परिभाषित करते हैं।

f = theano.function([a,b], c)

ध्यान दें कि फ़ंक्शन के इनपुट दो चर a और b हैं जो मैट्रिक्स प्रकार के हैं। फ़ंक्शन आउटपुट को चर को सौंपा गया हैc जो स्वचालित रूप से मैट्रिक्स प्रकार का होगा।

थीनो फंक्शन को लागू करना

अब हम निम्नलिखित कथन का उपयोग करते हुए फंक्शन शुरू करते हैं -

d = f([[0, -1, 2], [4, 11, 2]], [[3, -1],[1,2], [6,1]])

उपर्युक्त कथन के दो चर हैं- NumPy सरणियाँ। आप यहाँ दिखाए गए अनुसार स्पष्ट रूप से NumPy सरणियों को परिभाषित कर सकते हैं -

f(numpy.array([[0, -1, 2], [4, 11, 2]]),
numpy.array([[3, -1],[1,2], [6,1]]))

उपरांत d गणना की जाती है कि हम इसका मूल्य छापते हैं -

print (d)

आप आउटपुट पर निम्न आउटपुट देखेंगे -

[[11. 0.]
[25. 20.]]

पूर्ण कार्यक्रम लिस्टिंग

The complete program listing is given here:
from theano import *
a = tensor.dmatrix()
b = tensor.dmatrix()
c = tensor.dot(a,b)
f = theano.function([a,b], c)
d = f([[0, -1, 2],[4, 11, 2]], [[3, -1],[1,2],[6,1]])
print (d)

कार्यक्रम के निष्पादन का स्क्रीनशॉट यहाँ दिखाया गया है -

उपरोक्त दो उदाहरणों से, आपने देखा होगा कि थीनो में हम एक अभिव्यक्ति बनाते हैं जिसका अंत में थीनो का उपयोग करके मूल्यांकन किया जाता है function। थीनो एक अभिव्यक्ति के निष्पादन का अनुकूलन करने के लिए उन्नत अनुकूलन तकनीकों का उपयोग करता है। गणना ग्राफ की कल्पना करने के लिए, थीनो एक प्रदान करता हैprinting इसके पुस्तकालय में पैकेज।

स्केलर एडिशन के लिए प्रतीकात्मक ग्राफ

हमारे स्केलर जोड़ कार्यक्रम के लिए अभिकलन ग्राफ देखने के लिए, मुद्रण पुस्तकालय का उपयोग निम्नानुसार करें -

theano.printing.pydotprint(f, outfile="scalar_addition.png", var_with_name_simple=True)

जब आप इस कथन को निष्पादित करते हैं, तो एक फ़ाइल जिसे बुलाया जाता है scalar_addition.pngआपकी मशीन पर बनाया जाएगा। सहेजे गए संगणना ग्राफ को आपके त्वरित संदर्भ के लिए यहां प्रदर्शित किया गया है -

उपरोक्त छवि बनाने के लिए पूरा कार्यक्रम सूची नीचे दी गई है -

from theano import *
a = tensor.dscalar()
b = tensor.dscalar()
c = a + b
f = theano.function([a,b], c)
theano.printing.pydotprint(f, outfile="scalar_addition.png", var_with_name_simple=True)

मैट्रिक्स गुणक के लिए प्रतीकात्मक ग्राफ

अब, हमारे मैट्रिक्स गुणक के लिए अभिकलन ग्राफ बनाने का प्रयास करें। इस ग्राफ को बनाने के लिए पूरी सूची नीचे दी गई है -

from theano import *
a = tensor.dmatrix()
b = tensor.dmatrix()
c = tensor.dot(a,b)
f = theano.function([a,b], c)
theano.printing.pydotprint(f, outfile="matrix_dot_product.png", var_with_name_simple=True)

उत्पन्न ग्राफ यहाँ दिखाया गया है -

जटिल रेखांकन

बड़ी अभिव्यक्तियों में, कम्प्यूटेशनल रेखांकन बहुत जटिल हो सकते हैं। थीनो प्रलेखन से लिया गया ऐसा ही एक ग्राफ यहाँ दिखाया गया है -

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

क्यों थीनो?

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

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

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

डाटा प्रकार थीनो टाइप
बाइट

bscalar, bvector, bmatrix, brow, bcol, btensor3, btensor4, btensor5, btensor6, btensor7

16-बिट पूर्णांक

wscalar, wvector, wmatrix, wrow, wcol, wtensor3, wtensor4, wtensor5, wtensor6, wtensor7

32-बिट पूर्णांक

इस्कलर, ivector, इमेट्रिक्स, आईरो, आइकोल, itensor3, itensor4, itensor5, itensor6, itensor7

64-बिट पूर्णांक

lscalar, lvector, lmatrix, lrow, lcol, ltensor3, ltensor4, ltensor5, ltensor6, ltensor7

नाव

fscalar, fvector, fmatrix, frow, fcol, ftensor3, ftensor4, ftensor5, ftensor6, ftensor7

दोहरा

dscalar, dvector, dmatrix, drow, dcol, dtensor3, dtensor4, dtensor5, dtensor6, dtensor7

जटिल

cscalar, cvector, cmatrix, Crow, ccol, ctensor3, ctensor4, ctensor5, ctensor6, ctensor7

उपरोक्त सूची संपूर्ण नहीं है और पूरी सूची के लिए पाठक को टेनसर निर्माण दस्तावेज में संदर्भित किया जाता है।

अब मैं आपको थीनो में विभिन्न प्रकार के डेटा के चर बनाने का कुछ उदाहरण दूंगा।

अदिश

स्केलर वैरिएबल के निर्माण के लिए आप सिंटैक्स का उपयोग करेंगे -

वाक्य - विन्यास

x = theano.tensor.scalar ('x')
x = 5.0
print (x)

उत्पादन

5.0

एक आयामी सरणी

एक आयामी सरणी बनाने के लिए, निम्नलिखित घोषणा का उपयोग करें -

उदाहरण

f = theano.tensor.vector
f = (2.0, 5.0, 3.0)
print (f)f = theano.tensor.vector
f = (2.0, 5.0, 3.0)
print (f)
print (f[0])
print (f[2])

उत्पादन

(2.0, 5.0, 3.0)
2.0
3.0

यदि तुम करो f[3] जैसा कि यहाँ दिखाया गया है, यह सीमा त्रुटि से बाहर एक सूचकांक उत्पन्न करेगा -

print f([3])

उत्पादन

IndexError                          Traceback (most recent call last)
<ipython-input-13-2a9c2a643c3a> in <module>
   4 print (f[0])
   5 print (f[2])
----> 6 print (f[3])
IndexError: tuple index out of range

दोयम दर्जे का ऐरे

दो-आयामी सरणी घोषित करने के लिए आप निम्नलिखित कोड स्निपेट का उपयोग करेंगे -

उदाहरण

m = theano.tensor.matrix
m = ([2,3], [4,5], [2,4])
print (m[0])
print (m[1][0])

उत्पादन

[2, 3]
4

5-आयामी सरणी

5-आयामी सरणी घोषित करने के लिए, निम्नलिखित सिंटैक्स का उपयोग करें -

उदाहरण

m5 = theano.tensor.tensor5
m5 = ([0,1,2,3,4], [5,6,7,8,9], [10,11,12,13,14])
print (m5[1])
print (m5[2][3])

उत्पादन

[5, 6, 7, 8, 9]
13

आप डेटा प्रकार का उपयोग करके 3-आयामी सरणी घोषित कर सकते हैं tensor3 की जगह में tensor5, डेटा प्रकार का उपयोग करके एक 4-आयामी सरणी tensor4, और इतने पर tensor7

बहुवचन निर्माता

कभी-कभी, आप एक ही घोषणा में एक ही प्रकार के चर बनाना चाह सकते हैं। आप निम्न सिंटैक्स का उपयोग करके ऐसा कर सकते हैं -

वाक्य - विन्यास

from theano.tensor import * x, y, z = dmatrices('x', 'y', 'z') 
x = ([1,2],[3,4],[5,6]) 
y = ([7,8],[9,10],[11,12]) 
z = ([13,14],[15,16],[17,18]) 
print (x[2]) 
print (y[1]) 
print (z[0])

उत्पादन

[5, 6] 
[9, 10] 
[13, 14]

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

x = theano.tensor.fvector('x')

इस कथन में, हमने एक चर बनाया है x32-बिट फ़्लोट वाले प्रकार के वेक्टर। हम इसका नामकरण भी कर रहे हैंx। नाम आम तौर पर डिबगिंग के लिए उपयोगी होते हैं।

32-बिट पूर्णांक के वेक्टर को घोषित करने के लिए, आप निम्नलिखित सिंटैक्स का उपयोग करेंगे -

i32 = theano.tensor.ivector

यहां, हम चर के लिए एक नाम निर्दिष्ट नहीं करते हैं।

64-बिट फ़्लोट वाले तीन-आयामी वेक्टर घोषित करने के लिए, आप निम्नलिखित घोषणा का उपयोग करेंगे -

f64 = theano.tensor.dtensor3

उनके डेटा प्रकारों के साथ विभिन्न प्रकार के निर्माणकर्ता नीचे दी गई तालिका में सूचीबद्ध हैं -

निर्माता डाटा प्रकार आयाम
fvector float32 1
ivector int32 1
fscalar float32 0
fmatrix float32 2
ftensor3 float32 3
dtensor3 float64 3

आप एक सामान्य वेक्टर कंस्ट्रक्टर का उपयोग कर सकते हैं और डेटा प्रकार स्पष्ट रूप से निर्दिष्ट कर सकते हैं -

x = theano.tensor.vector ('x', dtype=int32)

अगले अध्याय में, हम सीखेंगे कि साझा चर कैसे बनाएँ।

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

वाक्य - विन्यास

आप एक साझा चर बनाते हैं जो आप निम्नलिखित सिंटैक्स का उपयोग करते हैं -

import numpy
W = theano.shared(numpy.asarray([0.1, 0.25, 0.15, 0.3]), 'W')

उदाहरण

यहाँ चार फ्लोटिंग पॉइंट नंबरों से युक्त NumPy सरणी बनाई गई है। सेट / प्राप्त करने के लिएW मान आप निम्न कोड स्निपेट का उपयोग करेंगे -

import numpy
W = theano.shared(numpy.asarray([0.1, 0.25, 0.15, 0.3]), 'W')
print ("Original: ", W.get_value())
print ("Setting new values (0.5, 0.2, 0.4, 0.2)")
W.set_value([0.5, 0.2, 0.4, 0.2])
print ("After modifications:", W.get_value())

उत्पादन

Original: [0.1 0.25 0.15 0.3 ]
Setting new values (0.5, 0.2, 0.4, 0.2)
After modifications: [0.5 0.2 0.4 0.2]

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

कुशल संकलित कोड अब थीनो के इनपुट के रूप में दिया गया है function। जब आप थीनो को निष्पादित करते हैंfunction, यह हमारे द्वारा निर्दिष्ट चर के लिए गणना का परिणाम प्रदान करता है। अनुकूलन का प्रकार FAST_COMPILE या FAST_RUN के रूप में निर्दिष्ट किया जा सकता है। यह पर्यावरण चर THEANO_FLAGS में निर्दिष्ट है।

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

f = theano.function ([x], y)

पहला पैरामीटर [x] इनपुट चर और दूसरे पैरामीटर की सूची है y आउटपुट चर की सूची है।

अब आपको थीनो की मूल बातें समझ में आ गई हैं, आइए हम तुएनो कोडिंग को एक तुच्छ उदाहरण के साथ शुरू करते हैं।

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

समस्या का विवरण

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

प्रशिक्षण का लक्ष्य प्रत्येक सुविधा को सौंपे गए भार को संशोधित करना है ताकि योग 100 के लक्ष्य मूल्य तक पहुंच जाए।

sum = f1 * w1 + f2 * w2 + f3 * w3 + f4 * w4

कहाँ पे f1, f2, ... सुविधा मूल्य हैं और w1, w2, ... वज़न है।

मुझे समस्या कथन की बेहतर समझ के लिए उदाहरण देना है। हम प्रत्येक सुविधा के लिए 1.0 का प्रारंभिक मान लेंगे और हम w1 के बराबर राशि लेंगे0.1, w2 बराबरी 0.25, w3 बराबरी 0.15, तथा w4 बराबरी 0.3। वजन मूल्यों को निर्धारित करने में कोई निश्चित तर्क नहीं है, यह सिर्फ हमारा अंतर्ज्ञान है। इस प्रकार, प्रारंभिक राशि इस प्रकार है -

sum = 1.0 * 0.1 + 1.0 * 0.25 + 1.0 * 0.15 + 1.0 * 0.3

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

आइए देखते हैं कि थीनो में इस पूरे तर्क को कैसे लागू किया गया है।

भिन्नता की घोषणा

हम अपने इनपुट वेक्टर x को पहले घोषित करते हैं -

x = tensor.fvector('x')

कहाँ पे x फ्लोट मानों का एकल आयामी सरणी है।

हम एक स्केलर को परिभाषित करते हैं target नीचे दिया गया चर

target = tensor.fscalar('target')

अगला, हम एक वज़न टेंसर बनाते हैं W ऊपर चर्चा के रूप में प्रारंभिक मूल्यों के साथ -

W = theano.shared(numpy.asarray([0.1, 0.25, 0.15, 0.3]), 'W')

थीनो अभिव्यक्ति को परिभाषित करना

अब हम निम्नलिखित अभिव्यक्ति का उपयोग कर आउटपुट की गणना करते हैं -

y = (x * W).sum()

ध्यान दें कि उपरोक्त कथन में x तथा Wवैक्टर हैं और साधारण स्केलर वैरिएबल नहीं हैं। अब हम निम्नलिखित अभिव्यक्ति के साथ त्रुटि (लागत) की गणना करते हैं -

cost = tensor.sqr(target - y)

लागत लक्ष्य मूल्य और वर्तमान आउटपुट के बीच अंतर है, चुकता है।

ग्रेडिएंट की गणना करने के लिए जो हमें बताता है कि हम लक्ष्य से कितनी दूर हैं, हम बिल्ट-इन का उपयोग करते हैं grad विधि इस प्रकार है -

gradients = tensor.grad(cost, [W])

अब हम अपडेट करते हैं weights की सीखने की दर को ले कर वेक्टर 0.1 निम्नानुसार है -

W_updated = W - (0.1 * gradients[0])

अगला, हमें उपरोक्त मूल्यों का उपयोग करके अपने वेट वेक्टर को अपडेट करना होगा। हम निम्नलिखित कथन में यह करते हैं -

updates = [(W, W_updated)]

थीनो फंक्शन को परिभाषित / आमंत्रित करना

अंत में, हम एक परिभाषित करते हैं function राशि की गणना करने के लिए Theano में।

f = function([x, target], y, updates=updates)

उपरोक्त फ़ंक्शन को एक निश्चित संख्या में लागू करने के लिए, हम एक बनाते हैं for पाश इस प्रकार है -

for i in range(10):
output = f([1.0, 1.0, 1.0, 1.0], 100.0)

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

print ("iteration: ", i)
print ("Modified Weights: ", W.get_value())
print ("Output: ", output)

पूर्ण कार्यक्रम लिस्टिंग

पूरा कार्यक्रम सूची आपके त्वरित संदर्भ के लिए यहां प्रस्तुत की गई है -

from theano import *
import numpy

x = tensor.fvector('x')
target = tensor.fscalar('target')

W = theano.shared(numpy.asarray([0.1, 0.25, 0.15, 0.3]), 'W')
print ("Weights: ", W.get_value())

y = (x * W).sum()
cost = tensor.sqr(target - y)
gradients = tensor.grad(cost, [W])
W_updated = W - (0.1 * gradients[0])
updates = [(W, W_updated)]

f = function([x, target], y, updates=updates)
for i in range(10):
   output = f([1.0, 1.0, 1.0, 1.0], 100.0)
   print ("iteration: ", i)
   print ("Modified Weights: ", W.get_value())
   print ("Output: ", output)

जब आप प्रोग्राम चलाते हैं तो आपको निम्न आउटपुट दिखाई देंगे -

Weights: [0.1 0.25 0.15 0.3 ]
iteration: 0
Modified Weights: [19.94 20.09 19.99 20.14]
Output: 0.8
iteration: 1
Modified Weights: [23.908 24.058 23.958 24.108]
Output: 80.16000000000001
iteration: 2
Modified Weights: [24.7016 24.8516 24.7516 24.9016]
Output: 96.03200000000001
iteration: 3
Modified Weights: [24.86032 25.01032 24.91032 25.06032]
Output: 99.2064
iteration: 4
Modified Weights: [24.892064 25.042064 24.942064 25.092064]
Output: 99.84128
iteration: 5
Modified Weights: [24.8984128 25.0484128 24.9484128 25.0984128]
Output: 99.968256
iteration: 6
Modified Weights: [24.89968256 25.04968256 24.94968256 25.09968256]
Output: 99.9936512
iteration: 7
Modified Weights: [24.89993651 25.04993651 24.94993651 25.09993651]
Output: 99.99873024
iteration: 8
Modified Weights: [24.8999873 25.0499873 24.9499873 25.0999873]
Output: 99.99974604799999
iteration: 9
Modified Weights: [24.89999746 25.04999746 24.94999746 25.09999746]
Output: 99.99994920960002

निरीक्षण करें कि चार पुनरावृत्तियों के बाद, आउटपुट है 99.96 और पांच पुनरावृत्तियों के बाद, यह है 99.99, जो हमारे वांछित लक्ष्य के करीब है 100.0

वांछित सटीकता के आधार पर, आप सुरक्षित रूप से निष्कर्ष निकाल सकते हैं कि नेटवर्क 4 से 5 पुनरावृत्तियों में प्रशिक्षित है। प्रशिक्षण पूरा होने के बाद, वेट वेक्टर देखें, जो 5 पुनरावृत्तियों के बाद निम्न मान लेता है -

iteration: 5
Modified Weights: [24.8984128 25.0484128 24.9484128 25.0984128]

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

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

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