पायथन के साथ एआई - तंत्रिका नेटवर्क
तंत्रिका नेटवर्क समानांतर कंप्यूटिंग डिवाइस हैं जो मस्तिष्क का कंप्यूटर मॉडल बनाने का प्रयास है। पीछे मुख्य उद्देश्य पारंपरिक प्रणालियों की तुलना में तेजी से विभिन्न कम्प्यूटेशनल कार्य करने के लिए एक प्रणाली विकसित करना है। इन कार्यों में पैटर्न रिकॉग्निशन और वर्गीकरण, अनुमोदन, अनुकूलन और डेटा क्लस्टरिंग शामिल हैं।
कृत्रिम तंत्रिका नेटवर्क (ANN) क्या है
आर्टिफिशियल न्यूरल नेटवर्क (ANN) एक कुशल कंप्यूटिंग सिस्टम है जिसका केंद्रीय विषय जैविक तंत्रिका नेटवर्क के सादृश्य से उधार लिया गया है। ANN को आर्टिफिशियल न्यूरल सिस्टम, पैरेलल डिस्ट्रिब्यूटेड प्रोसेसिंग सिस्टम और कनैक्टिस्ट सिस्टम के नाम से भी जाना जाता है। एएनएन उन इकाइयों के बड़े संग्रह का अधिग्रहण करता है जो उनके बीच संचार की अनुमति देने के लिए कुछ पैटर्न में परस्पर जुड़े होते हैं। इन इकाइयों के रूप में भी जाना जाता हैnodes या neurons, सरल प्रोसेसर हैं जो समानांतर में काम करते हैं।
प्रत्येक न्यूरॉन एक के माध्यम से अन्य न्यूरॉन के साथ जुड़ा हुआ है connection link। प्रत्येक कनेक्शन लिंक एक वजन से जुड़ा होता है जिसमें इनपुट सिग्नल के बारे में जानकारी होती है। यह न्यूरॉन्स के लिए किसी विशेष समस्या को हल करने के लिए सबसे उपयोगी जानकारी है क्योंकिweightआम तौर पर उस सिग्नल को उत्तेजित या बाधित करता है जिसे संचार किया जा रहा है। प्रत्येक न्यूरॉन की अपनी आंतरिक स्थिति होती है जिसे कहा जाता हैactivation signal। आउटपुट सिग्नल, जो इनपुट सिग्नल और सक्रियण नियम के संयोजन के बाद उत्पन्न होते हैं, अन्य इकाइयों को भेजे जा सकते हैं।
यदि आप तंत्रिका नेटवर्क का विस्तार से अध्ययन करना चाहते हैं तो आप लिंक का अनुसरण कर सकते हैं - कृत्रिम तंत्रिका नेटवर्क ।
उपयोगी पैकेज स्थापित करना
पायथन में तंत्रिका नेटवर्क बनाने के लिए, हम तंत्रिका नेटवर्क नामक एक शक्तिशाली पैकेज का उपयोग कर सकते हैं NeuroLab। यह बुनियादी तंत्रिका नेटवर्क एल्गोरिदम का एक पुस्तकालय है जिसमें लचीले नेटवर्क विन्यास और पायथन के लिए लर्निंग एल्गोरिदम हैं। आप कमांड प्रॉम्प्ट पर निम्नलिखित कमांड की मदद से इस पैकेज को स्थापित कर सकते हैं -
pip install NeuroLab
यदि आप एनाकोंडा पर्यावरण का उपयोग कर रहे हैं, तो न्यूरोलैब स्थापित करने के लिए निम्न कमांड का उपयोग करें -
conda install -c labfabulous neurolab
भवन निर्माण तंत्रिका नेटवर्क
इस खंड में, हम न्यूरलैब पैकेज का उपयोग करके पायथन में कुछ तंत्रिका नेटवर्क का निर्माण करते हैं।
परसेप्ट्रॉन आधारित क्लासिफायर
Perceptrons ANN के बिल्डिंग ब्लॉक्स हैं। आप perceptron के बारे में अधिक जानना चाहते हैं, तो आप लिंक का पालन कर सकते हैं - artificial_neural_network
निम्नलिखित एक सरल तंत्रिका नेटवर्क perceptron आधारित क्लासिफायरियर के निर्माण के लिए पायथन कोड का एक चरणबद्ध निष्पादन है -
दिखाए गए अनुसार आवश्यक पैकेज आयात करें -
import matplotlib.pyplot as plt
import neurolab as nl
इनपुट मान दर्ज करें। ध्यान दें कि यह पर्यवेक्षित शिक्षण का एक उदाहरण है, इसलिए आपको लक्ष्य मान भी प्रदान करने होंगे।
input = [[0, 0], [0, 1], [1, 0], [1, 1]]
target = [[0], [0], [0], [1]]
2 इनपुट और 1 न्यूरॉन के साथ नेटवर्क बनाएं -
net = nl.net.newp([[0, 1],[0, 1]], 1)
अब, नेटवर्क को प्रशिक्षित करें। यहां, हम प्रशिक्षण के लिए डेल्टा नियम का उपयोग कर रहे हैं।
error_progress = net.train(input, target, epochs=100, show=10, lr=0.1)
अब, आउटपुट की कल्पना करें और ग्राफ को प्लॉट करें -
plt.figure()
plt.plot(error_progress)
plt.xlabel('Number of epochs')
plt.ylabel('Training error')
plt.grid()
plt.show()
आप त्रुटि मीट्रिक का उपयोग करके प्रशिक्षण प्रगति दिखाते हुए निम्नलिखित ग्राफ देख सकते हैं -
सिंगल - लेयर न्यूरल नेटवर्क
इस उदाहरण में, हम एक एकल परत तंत्रिका नेटवर्क बना रहे हैं जिसमें आउटपुट उत्पादन करने के लिए इनपुट डेटा पर अभिनय करने वाले स्वतंत्र न्यूरॉन्स होते हैं। ध्यान दें कि हम नाम की पाठ फ़ाइल का उपयोग कर रहे हैंneural_simple.txt हमारे इनपुट के रूप में।
दिखाए गए अनुसार उपयोगी पैकेज आयात करें -
import numpy as np
import matplotlib.pyplot as plt
import neurolab as nl
डेटासेट निम्नानुसार लोड करें -
input_data = np.loadtxt(“/Users/admin/neural_simple.txt')
निम्नलिखित डेटा है जिसका हम उपयोग करने जा रहे हैं। ध्यान दें कि इस डेटा में, पहले दो कॉलम फीचर्स हैं और अंतिम दो कॉलम लेबल हैं।
array([[2. , 4. , 0. , 0. ],
[1.5, 3.9, 0. , 0. ],
[2.2, 4.1, 0. , 0. ],
[1.9, 4.7, 0. , 0. ],
[5.4, 2.2, 0. , 1. ],
[4.3, 7.1, 0. , 1. ],
[5.8, 4.9, 0. , 1. ],
[6.5, 3.2, 0. , 1. ],
[3. , 2. , 1. , 0. ],
[2.5, 0.5, 1. , 0. ],
[3.5, 2.1, 1. , 0. ],
[2.9, 0.3, 1. , 0. ],
[6.5, 8.3, 1. , 1. ],
[3.2, 6.2, 1. , 1. ],
[4.9, 7.8, 1. , 1. ],
[2.1, 4.8, 1. , 1. ]])
अब, इन चार स्तंभों को 2 डेटा कॉलम और 2 लेबल में अलग करें -
data = input_data[:, 0:2]
labels = input_data[:, 2:]
निम्नलिखित आदेशों का उपयोग करके इनपुट डेटा प्लॉट करें -
plt.figure()
plt.scatter(data[:,0], data[:,1])
plt.xlabel('Dimension 1')
plt.ylabel('Dimension 2')
plt.title('Input data')
अब, प्रत्येक आयाम के लिए न्यूनतम और अधिकतम मान निर्धारित करें जैसा कि यहाँ दिखाया गया है -
dim1_min, dim1_max = data[:,0].min(), data[:,0].max()
dim2_min, dim2_max = data[:,1].min(), data[:,1].max()
अगला, उत्पादन परत में न्यूरॉन्स की संख्या को निम्नानुसार परिभाषित करें -
nn_output_layer = labels.shape[1]
अब, एकल-परत तंत्रिका नेटवर्क को परिभाषित करें -
dim1 = [dim1_min, dim1_max]
dim2 = [dim2_min, dim2_max]
neural_net = nl.net.newp([dim1, dim2], nn_output_layer)
दिखाए गए अनुसार युगों और सीखने की दर के साथ तंत्रिका नेटवर्क को प्रशिक्षित करें -
error = neural_net.train(data, labels, epochs = 200, show = 20, lr = 0.01)
अब, निम्नलिखित कमांड्स का उपयोग करके प्रशिक्षण प्रगति की कल्पना और साजिश करें -
plt.figure()
plt.plot(error)
plt.xlabel('Number of epochs')
plt.ylabel('Training error')
plt.title('Training error progress')
plt.grid()
plt.show()
अब, ऊपर दिए गए वर्गीकरण में परीक्षण डेटा-बिंदुओं का उपयोग करें -
print('\nTest Results:')
data_test = [[1.5, 3.2], [3.6, 1.7], [3.6, 5.7],[1.6, 3.9]] for item in data_test:
print(item, '-->', neural_net.sim([item])[0])
आप यहाँ दिखाए गए अनुसार परीक्षा परिणाम देख सकते हैं -
[1.5, 3.2] --> [1. 0.]
[3.6, 1.7] --> [1. 0.]
[3.6, 5.7] --> [1. 1.]
[1.6, 3.9] --> [1. 0.]
आप अब तक चर्चा किए गए कोड के आउटपुट के रूप में निम्नलिखित ग्राफ देख सकते हैं -
बहु परत तंत्रिका नेटवर्क
इस उदाहरण में, हम एक बहु-परत तंत्रिका नेटवर्क बना रहे हैं जिसमें प्रशिक्षण डेटा में अंतर्निहित पैटर्न को निकालने के लिए एक से अधिक परत शामिल हैं। यह बहुपरत तंत्रिका नेटवर्क एक प्रतिगामी की तरह काम करेगा। हम समीकरण के आधार पर कुछ डेटा बिंदु उत्पन्न करने जा रहे हैं: y = 2x 2 +8।
दिखाए गए अनुसार आवश्यक पैकेज आयात करें -
import numpy as np
import matplotlib.pyplot as plt
import neurolab as nl
उपर्युक्त समीकरण के आधार पर कुछ डेटा बिंदु उत्पन्न करें -
min_val = -30
max_val = 30
num_points = 160
x = np.linspace(min_val, max_val, num_points)
y = 2 * np.square(x) + 8
y /= np.linalg.norm(y)
अब, इस डेटा को इस प्रकार सेट करें -
data = x.reshape(num_points, 1)
labels = y.reshape(num_points, 1)
निम्न आदेशों का उपयोग करते हुए इनपुट डेटा सेट की कल्पना करें और प्लॉट करें -
plt.figure()
plt.scatter(data, labels)
plt.xlabel('Dimension 1')
plt.ylabel('Dimension 2')
plt.title('Data-points')
अब, दो छिपे हुए परतों वाले तंत्रिका नेटवर्क का निर्माण करें neurolab साथ में ten पहली छिपी परत में न्यूरॉन्स, six दूसरी छिपी हुई परत में और one आउटपुट लेयर में।
neural_net = nl.net.newff([[min_val, max_val]], [10, 6, 1])
अब ढाल प्रशिक्षण एल्गोरिथ्म का उपयोग करें -
neural_net.trainf = nl.train.train_gd
अब ऊपर दिए गए डेटा पर सीखने के लक्ष्य के साथ नेटवर्क को प्रशिक्षित करें -
error = neural_net.train(data, labels, epochs = 1000, show = 100, goal = 0.01)
अब, प्रशिक्षण डेटा बिंदुओं पर तंत्रिका नेटवर्क चलाएं -
output = neural_net.sim(data)
y_pred = output.reshape(num_points)
अब प्लॉट और विज़ुअलाइज़ेशन कार्य -
plt.figure()
plt.plot(error)
plt.xlabel('Number of epochs')
plt.ylabel('Error')
plt.title('Training error progress')
अब हम वास्तविक बनाम अनुमानित उत्पादन की साजिश रचेंगे -
x_dense = np.linspace(min_val, max_val, num_points * 2)
y_dense_pred = neural_net.sim(x_dense.reshape(x_dense.size,1)).reshape(x_dense.size)
plt.figure()
plt.plot(x_dense, y_dense_pred, '-', x, y, '.', x, y_pred, 'p')
plt.title('Actual vs predicted')
plt.show()
उपरोक्त आदेशों के परिणामस्वरूप, आप नीचे दिखाए गए रेखांकन देख सकते हैं -