पायथन के साथ एआई - डीप लर्निंग

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

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

मशीन लर्निंग v / s डीप लर्निंग

डीप लर्निंग इन दिनों सबसे शक्तिशाली मशीन लर्निंग तकनीक है। यह इतना शक्तिशाली है क्योंकि वे समस्या को हल करने का तरीका सीखने के दौरान समस्या का प्रतिनिधित्व करने का सबसे अच्छा तरीका सीखते हैं। डीप लर्निंग और मशीन लर्निंग की तुलना नीचे दी गई है -

डेटा निर्भरता

अंतर का पहला बिंदु डेटा के पैमाने बढ़ने पर डीएल और एमएल के प्रदर्शन पर आधारित है। जब डेटा बड़ा होता है, तो डीप लर्निंग एल्गोरिदम बहुत अच्छा प्रदर्शन करते हैं।

मशीन निर्भरता

डीप लर्निंग एल्गोरिदम को पूरी तरह से काम करने के लिए उच्च-अंत मशीनों की आवश्यकता होती है। दूसरी ओर, मशीन लर्निंग एल्गोरिदम कम-अंत मशीनों पर भी काम कर सकता है।

सुविधा निकासी

डीप लर्निंग एल्गोरिदम उच्च स्तरीय विशेषताओं को निकाल सकता है और उसी से सीखने की कोशिश भी कर सकता है। दूसरी ओर, मशीन लर्निंग द्वारा निकाली गई अधिकांश विशेषताओं की पहचान करने के लिए एक विशेषज्ञ की आवश्यकता होती है।

निष्पादन का समय

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

समस्या के समाधान के लिए दृष्टिकोण

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

संवादी तंत्रिका नेटवर्क (CNN)

संवेदी तंत्रिका नेटवर्क साधारण तंत्रिका नेटवर्क के समान हैं क्योंकि वे भी न्यूरॉन्स से बने होते हैं जिनमें सीखने योग्य भार और पूर्वाग्रह होते हैं। साधारण तंत्रिका नेटवर्क इनपुट डेटा की संरचना को अनदेखा करते हैं और सभी डेटा को नेटवर्क में फीड करने से पहले 1-डी सरणी में परिवर्तित कर दिया जाता है। यह प्रक्रिया नियमित डेटा के अनुकूल है, हालांकि यदि डेटा में चित्र शामिल हैं, तो प्रक्रिया बोझिल हो सकती है।

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

CNNs का आर्किटेक्चर अवलोकन

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

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

लेयर CNNs का निर्माण करते थे

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

  • Input Layer - यह कच्ची छवि डेटा लेता है जैसा कि यह है।

  • Convolutional Layer- यह परत CNNs का मुख्य निर्माण खंड है जो अधिकांश संगणना करता है। यह परत इनपुट में न्यूरॉन्स और विभिन्न पैच के बीच संकल्‍पों की गणना करती है।

  • Rectified Linear Unit Layer- यह पिछली परत के आउटपुट के लिए एक सक्रियण फ़ंक्शन लागू करता है। यह नेटवर्क में गैर-रैखिकता जोड़ता है ताकि यह किसी भी प्रकार के फ़ंक्शन को अच्छी तरह से सामान्य कर सके।

  • Pooling Layer- पूलिंग हमें केवल महत्वपूर्ण भागों को रखने में मदद करता है क्योंकि हम नेटवर्क में प्रगति करते हैं। पूलिंग परत इनपुट के हर गहराई के टुकड़े पर स्वतंत्र रूप से काम करती है और इसे स्थानिक रूप से आकार देती है। यह MAX फ़ंक्शन का उपयोग करता है।

  • Fully Connected layer/Output layer - यह परत अंतिम परत में आउटपुट स्कोर की गणना करती है। परिणामी आउटपुट आकार का है×× , जहां एल संख्या प्रशिक्षण डाटासेट कक्षाएं है।

उपयोगी पायथन पैकेज स्थापित करना

आप उपयोग कर सकते हैं Keras, जो एक उच्च स्तरीय तंत्रिका नेटवर्क एपीआई है, जिसे पायथन में लिखा गया है और TensorFlow, CNTK या थेओ के शीर्ष पर चलने में सक्षम है। यह पायथन 2.7-3.6 के साथ संगत है। आप इसके बारे में और जान सकते हैंhttps://keras.io/।

करैस को स्थापित करने के लिए निम्नलिखित कमांड का उपयोग करें

pip install keras

पर conda पर्यावरण, आप निम्न आदेश का उपयोग कर सकते हैं -

conda install –c conda-forge keras

एएनएन का उपयोग करके रैखिक रजिस्ट्रार का निर्माण

इस खंड में, आप सीखेंगे कि कृत्रिम तंत्रिका नेटवर्क का उपयोग करके रैखिक रेजिस्टर कैसे बनाया जाए। आप उपयोग कर सकते हैंKerasRegressorइसे पाने के लिये। इस उदाहरण में, हम बोस्टन में गुणों के लिए 13 संख्यात्मक के साथ बोस्टन हाउस प्राइस डेटासेट का उपयोग कर रहे हैं। उसी के लिए पायथन कोड यहाँ दिखाया गया है -

दिखाए गए अनुसार सभी आवश्यक पैकेज आयात करें -

import numpy
import pandas
from keras.models import Sequential
from keras.layers import Dense
from keras.wrappers.scikit_learn import KerasRegressor
from sklearn.model_selection import cross_val_score
from sklearn.model_selection import KFold

अब, हमारे डेटासेट को लोड करें जो स्थानीय निर्देशिका में सहेजा गया है।

dataframe = pandas.read_csv("/Usrrs/admin/data.csv", delim_whitespace = True, header = None)
dataset = dataframe.values

अब, डेटा को इनपुट और आउटपुट वेरिएबल्स में विभाजित करें अर्थात X और Y -

X = dataset[:,0:13]
Y = dataset[:,13]

चूंकि हम आधारभूत तंत्रिका नेटवर्क का उपयोग करते हैं, इसलिए मॉडल को परिभाषित करें -

def baseline_model():

अब, इस प्रकार मॉडल बनाएं -

model_regressor = Sequential()
model_regressor.add(Dense(13, input_dim = 13, kernel_initializer = 'normal', 
   activation = 'relu'))
model_regressor.add(Dense(1, kernel_initializer = 'normal'))

अगला, मॉडल संकलित करें -

model_regressor.compile(loss='mean_squared_error', optimizer='adam')
return model_regressor

अब, निम्नानुसार प्रजनन योग्य प्रजनन के लिए यादृच्छिक बीज को ठीक करें -

seed = 7
numpy.random.seed(seed)

में उपयोग के लिए केरस रैपर ऑब्जेक्ट scikit-learn प्रतिगमन अनुमानक के रूप में कहा जाता है KerasRegressor। इस अनुभाग में, हम इस मॉडल का मूल्यांकन मानकीकृत डेटा सेट के साथ करेंगे।

estimator = KerasRegressor(build_fn = baseline_model, nb_epoch = 100, batch_size = 5, verbose = 0)
kfold = KFold(n_splits = 10, random_state = seed)
baseline_result = cross_val_score(estimator, X, Y, cv = kfold)
print("Baseline: %.2f (%.2f) MSE" % (Baseline_result.mean(),Baseline_result.std()))

ऊपर दिखाए गए कोड का आउटपुट अनदेखी डेटा के लिए समस्या पर मॉडल के प्रदर्शन का अनुमान होगा। यह क्रॉस स्क्वेरेशन मूल्यांकन की सभी 10 परतों में औसत और मानक विचलन सहित औसत चुकता त्रुटि होगी।

छवि क्लासिफायरियर: डीप लर्निंग का एक अनुप्रयोग

संवादात्मक तंत्रिका नेटवर्क (CNNs) एक छवि वर्गीकरण समस्या को हल करता है, वह यह है कि इनपुट छवि किस वर्ग की है। आप केरस डीप लर्निंग लाइब्रेरी का उपयोग कर सकते हैं। ध्यान दें कि हम निम्नलिखित लिंक से बिल्लियों और कुत्तों की छवियों के प्रशिक्षण और परीक्षण डेटा सेट का उपयोग कर रहे हैंhttps://www.kaggle.com/c/dogs-vs-cats/data।

दिखाए गए अनुसार महत्वपूर्ण करेर्स लाइब्रेरी और पैकेज आयात करें -

अनुक्रमिक नामक निम्नलिखित पैकेज तंत्रिका नेटवर्क को अनुक्रमिक नेटवर्क के रूप में आरंभ करेगा।

from keras.models import Sequential

निम्नलिखित पैकेज कहा जाता है Conv2D सीएनएन के पहले चरण के कनवल्शन ऑपरेशन को करने के लिए उपयोग किया जाता है।

from keras.layers import Conv2D

निम्नलिखित पैकेज कहा जाता है MaxPoling2D पूलिंग ऑपरेशन करने के लिए प्रयोग किया जाता है, CNN का दूसरा चरण।

from keras.layers import MaxPooling2D

निम्नलिखित पैकेज कहा जाता है Flatten सभी परिणामी 2D सरणियों को एक एकल लंबे निरंतर रैखिक वेक्टर में परिवर्तित करने की प्रक्रिया है।

from keras.layers import Flatten

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

from keras.layers import Dense

अब, अनुक्रमिक वर्ग की एक वस्तु बनाएं।

S_classifier = Sequential()

अब, अगला चरण कन्वेक्शन पार्ट को कोड कर रहा है।

S_classifier.add(Conv2D(32, (3, 3), input_shape = (64, 64, 3), activation = 'relu'))

यहाँ relu रेक्टिफायर फंक्शन है।

अब, सीएनएन का अगला चरण परिणय भाग के बाद परिणामी फीचर मानचित्रों पर पूलिंग ऑपरेशन है।

S-classifier.add(MaxPooling2D(pool_size = (2, 2)))

अब, सभी पूल की गई छवियों को चापलूसी द्वारा निरंतर वेक्टर में परिवर्तित करें -

S_classifier.add(Flatten())

इसके बाद, पूरी तरह से कनेक्टेड लेयर बनाएं।

S_classifier.add(Dense(units = 128, activation = 'relu'))

यहां 128 छिपी हुई इकाइयों की संख्या है। 2 की शक्ति के रूप में छिपी हुई इकाइयों की संख्या को परिभाषित करना एक आम बात है।

अब, आउटपुट लेयर को इनिशियलाइज़ करें:

S_classifier.add(Dense(units = 1, activation = 'sigmoid'))

अब, सीएनएन संकलित करें, हमने बनाया है -

S_classifier.compile(optimizer = 'adam', loss = 'binary_crossentropy', metrics = ['accuracy'])

यहां ऑप्टिमाइज़र पैरामीटर स्टोचस्टिक ग्रेडिएंट डीसेंट अल्गोरिथम को चुनने के लिए है, लॉस पैरामीटर को लॉस फंक्शन को चुनने के लिए है और मेट्रिक्स पैरामीटर को प्रदर्शन मीट्रिक चुनने के लिए है।

अब, छवि संवर्द्धन निष्पादित करें और फिर छवियों को तंत्रिका नेटवर्क में फिट करें -

train_datagen = ImageDataGenerator(rescale = 1./255,shear_range = 0.2,
zoom_range = 0.2,
horizontal_flip = True)
test_datagen = ImageDataGenerator(rescale = 1./255)

training_set = 
   train_datagen.flow_from_directory(”/Users/admin/training_set”,target_size = 
      (64, 64),batch_size = 32,class_mode = 'binary')

test_set = 
   test_datagen.flow_from_directory('test_set',target_size = 
      (64, 64),batch_size = 32,class_mode = 'binary')

अब, हमारे द्वारा बनाए गए मॉडल के डेटा को फिट करें -

classifier.fit_generator(training_set,steps_per_epoch = 8000,epochs = 
25,validation_data = test_set,validation_steps = 2000)

यहाँ steps_per_epoch में प्रशिक्षण छवियों की संख्या है।

अब जैसा कि मॉडल को प्रशिक्षित किया गया है, हम इसे निम्नानुसार भविष्यवाणी के लिए उपयोग कर सकते हैं -

from keras.preprocessing import image

test_image = image.load_img('dataset/single_prediction/cat_or_dog_1.jpg', 
target_size = (64, 64))

test_image = image.img_to_array(test_image)

test_image = np.expand_dims(test_image, axis = 0)

result = classifier.predict(test_image)

training_set.class_indices

if result[0][0] == 1:
prediction = 'dog'

else:
   prediction = 'cat'