TensorFlow - केरेस

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

  • अनुक्रमिक एपीआई
  • कार्यात्मक एपीआई

केरस में गहन शिक्षण मॉडल बनाने के लिए निम्नलिखित आठ चरणों पर विचार करें -

  • डेटा लोड हो रहा है
  • लोड किए गए डेटा को रोकें
  • मॉडल की परिभाषा
  • मॉडल का संकलन
  • निर्दिष्ट मॉडल को फिट करें
  • इसका मूल्यांकन करें
  • आवश्यक भविष्यवाणी करें
  • मॉडल को सहेजें

हम नीचे दिखाए गए अनुसार आउटपुट के निष्पादन और प्रदर्शन के लिए Jupyter नोटबुक का उपयोग करेंगे -

Step 1 - डेटा लोड करना और लोड किए गए डेटा को प्रीप्रोसेस करना सबसे पहले डीप लर्निंग मॉडल को निष्पादित करने के लिए कार्यान्वित किया जाता है।

import warnings
warnings.filterwarnings('ignore')

import numpy as np
np.random.seed(123) # for reproducibility

from keras.models import Sequential
from keras.layers import Flatten, MaxPool2D, Conv2D, Dense, Reshape, Dropout
from keras.utils import np_utils
Using TensorFlow backend.
from keras.datasets import mnist

# Load pre-shuffled MNIST data into train and test sets
(X_train, y_train), (X_test, y_test) = mnist.load_data()
X_train = X_train.reshape(X_train.shape[0], 28, 28, 1)
X_test = X_test.reshape(X_test.shape[0], 28, 28, 1)
X_train = X_train.astype('float32')
X_test = X_test.astype('float32')
X_train /= 255
X_test /= 255
Y_train = np_utils.to_categorical(y_train, 10)
Y_test = np_utils.to_categorical(y_test, 10)

इस चरण को "आयात पुस्तकालयों और मॉड्यूल" के रूप में परिभाषित किया जा सकता है, जिसका अर्थ है कि सभी पुस्तकालय और मॉड्यूल एक प्रारंभिक चरण के रूप में आयात किए जाते हैं।

Step 2 - इस चरण में, हम मॉडल वास्तुकला को परिभाषित करेंगे -

model = Sequential()
model.add(Conv2D(32, 3, 3, activation = 'relu', input_shape = (28,28,1)))
model.add(Conv2D(32, 3, 3, activation = 'relu'))
model.add(MaxPool2D(pool_size = (2,2)))
model.add(Dropout(0.25))
model.add(Flatten())
model.add(Dense(128, activation = 'relu'))
model.add(Dropout(0.5))
model.add(Dense(10, activation = 'softmax'))

Step 3 - अब हम निर्दिष्ट मॉडल संकलित करते हैं -

model.compile(loss = 'categorical_crossentropy', optimizer = 'adam', metrics = ['accuracy'])

Step 4 - अब हम प्रशिक्षण डेटा का उपयोग करके मॉडल फिट करेंगे -

model.fit(X_train, Y_train, batch_size = 32, epochs = 10, verbose = 1)

निर्मित पुनरावृत्तियों का उत्पादन निम्नानुसार है -

Epoch 1/10 60000/60000 [==============================] - 65s - 
loss: 0.2124 - 
acc: 0.9345 
Epoch 2/10 60000/60000 [==============================] - 62s - 
loss: 0.0893 - 
acc: 0.9740 
Epoch 3/10 60000/60000 [==============================] - 58s - 
loss: 0.0665 - 
acc: 0.9802 
Epoch 4/10 60000/60000 [==============================] - 62s - 
loss: 0.0571 - 
acc: 0.9830 
Epoch 5/10 60000/60000 [==============================] - 62s - 
loss: 0.0474 - 
acc: 0.9855 
Epoch 6/10 60000/60000 [==============================] - 59s -
loss: 0.0416 - 
acc: 0.9871 
Epoch 7/10 60000/60000 [==============================] - 61s - 
loss: 0.0380 - 
acc: 0.9877 
Epoch 8/10 60000/60000 [==============================] - 63s - 
loss: 0.0333 - 
acc: 0.9895 
Epoch 9/10 60000/60000 [==============================] - 64s - 
loss: 0.0325 - 
acc: 0.9898 
Epoch 10/10 60000/60000 [==============================] - 60s - 
loss: 0.0284 - 
acc: 0.9910