PyBrain - परतें

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

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

  • समझ की परत
  • 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