केरस - मॉड्यूल
जैसा कि हमने पहले सीखा था, केरस मॉड्यूल में पूर्व-परिभाषित कक्षाएं, फ़ंक्शंस और चर शामिल होते हैं जो गहन शिक्षण एल्गोरिथ्म के लिए उपयोगी होते हैं। आइए हम इस अध्याय में केरस द्वारा प्रदान किए गए मॉड्यूल को जानें।
उपलब्ध मॉड्यूल
आइए सबसे पहले Keras में उपलब्ध मॉड्यूल की सूची देखें।
Initializers- इनिशियलाइजर्स फंक्शन की एक सूची प्रदान करता है। हम इसे केरस लेयर चैप्टर में विस्तार से जान सकते हैं । मशीन सीखने के मॉडल निर्माण के चरण के दौरान।
Regularizers- नियमितिकरण समारोह की एक सूची प्रदान करता है। हम इसे केरस लेयर्स चैप्टर में विस्तार से जान सकते हैं ।
Constraints- बाधा कार्य की एक सूची प्रदान करता है। हम इसे केरस लेयर्स चैप्टर में विस्तार से जान सकते हैं ।
Activations- एक्टिवेटर फ़ंक्शन की एक सूची प्रदान करता है। हम इसे केरस लेयर्स चैप्टर में विस्तार से जान सकते हैं ।
Losses- नुकसान समारोह की एक सूची प्रदान करता है। हम इसे मॉडल ट्रेनिंग चैप्टर में विस्तार से जान सकते हैं ।
Metrics- मैट्रिक्स फ़ंक्शन की एक सूची प्रदान करता है। हम इसे मॉडल ट्रेनिंग चैप्टर में विस्तार से जान सकते हैं ।
Optimizers- ऑप्टिमाइज़र फ़ंक्शन की एक सूची प्रदान करता है। हम इसे मॉडल ट्रेनिंग चैप्टर में विस्तार से जान सकते हैं ।
Callback- कॉलबैक फ़ंक्शन की एक सूची प्रदान करता है। हम प्रशिक्षण प्रक्रिया के दौरान इसका उपयोग इंटरमीडिएट डेटा प्रिंट करने के साथ-साथ स्वयं प्रशिक्षण को रोकने के लिए कर सकते हैं (EarlyStopping विधि) कुछ शर्त पर आधारित है।
Text processing- मशीन लर्निंग के लिए उपयुक्त NumPy सरणी में पाठ परिवर्तित करने के लिए कार्य प्रदान करता है। हम इसे मशीन लर्निंग के डेटा तैयारी चरण में उपयोग कर सकते हैं।
Image processing- मशीन लर्निंग के लिए उपयुक्त NumPy सरणी में छवियों को परिवर्तित करने के लिए कार्य प्रदान करता है। हम इसे मशीन लर्निंग के डेटा तैयारी चरण में उपयोग कर सकते हैं।
Sequence processing- दिए गए इनपुट डेटा से समय आधारित डेटा उत्पन्न करने के लिए फ़ंक्शन प्रदान करता है। हम इसे मशीन लर्निंग के डेटा तैयारी चरण में उपयोग कर सकते हैं।
Backend- TensorFlow और Theano जैसे बैकएंड लाइब्रेरी का कार्य प्रदान करता है ।
Utilities - गहरी शिक्षा में उपयोगी बहुत सारे उपयोगिता समारोह प्रदान करता है।
देखते हैं backend मॉड्यूल और utils इस अध्याय में मॉडल।
बैकएंड मॉड्यूल
backend moduleकायर बैकएंड ऑपरेशन के लिए उपयोग किया जाता है। डिफ़ॉल्ट रूप से, केरस TensorFlow बैकएंड के शीर्ष पर चलता है। आप चाहें तो थीनो या सीएनटीके जैसे अन्य बैकएंड पर स्विच कर सकते हैं। Defualt बैकएंड कॉन्फ़िगरेशन आपके रूट निर्देशिका के अंदर .keras / keras.json फ़ाइल में परिभाषित किया गया है।
कोड्स बैकएंड मॉड्यूल को नीचे दिए गए कोड का उपयोग करके आयात किया जा सकता है
>>> from keras import backend as k
यदि हम डिफ़ॉल्ट बैकेंड TensorFlow का उपयोग कर रहे हैं , तो नीचे दिया गया फ़ंक्शन TensorFlow आधारित जानकारी नीचे बताए अनुसार देता है -
>>> k.backend()
'tensorflow'
>>> k.epsilon()
1e-07
>>> k.image_data_format()
'channels_last'
>>> k.floatx()
'float32'
आइए संक्षिप्त में डेटा विश्लेषण के लिए उपयोग किए जाने वाले कुछ महत्वपूर्ण बैकेंड कार्यों को समझते हैं -
get_uid ()
यह डिफ़ॉल्ट ग्राफ़ के लिए पहचानकर्ता है। यह नीचे परिभाषित किया गया है -
>>> k.get_uid(prefix='')
1
>>> k.get_uid(prefix='') 2
reset_uids
इसका उपयोग uid मान रीसेट करता है।
>>> k.reset_uids()
अब, फिर से get_uid () निष्पादित करें । यह रीसेट हो जाएगा और फिर से 1 में बदल जाएगा।
>>> k.get_uid(prefix='')
1
प्लेसहोल्डर
यह एक प्लेसहोल्डर टेंसर को तुरंत इस्तेमाल करता है। 3-डी आकार रखने के लिए सरल प्लेसहोल्डर नीचे दिखाया गया है -
>>> data = k.placeholder(shape = (1,3,3))
>>> data
<tf.Tensor 'Placeholder_9:0' shape = (1, 3, 3) dtype = float32>
If you use int_shape(), it will show the shape.
>>> k.int_shape(data) (1, 3, 3)
दूरसंचार विभाग
इसका उपयोग दो टेनर्स को गुणा करने के लिए किया जाता है। गौर कीजिए कि a और b दो टेनर्स हैं और c, ab के गुणा का परिणाम होगा। मान लें कि कोई आकृति (4,2) है और b आकार (2,3) है। यह नीचे परिभाषित किया गया है,
>>> a = k.placeholder(shape = (4,2))
>>> b = k.placeholder(shape = (2,3))
>>> c = k.dot(a,b)
>>> c
<tf.Tensor 'MatMul_3:0' shape = (4, 3) dtype = float32>
>>>
लोगों
इसका उपयोग सभी को शुरू करने के लिए किया जाता है one मूल्य।
>>> res = k.ones(shape = (2,2))
#print the value
>>> k.eval(res)
array([[1., 1.], [1., 1.]], dtype = float32)
batch_dot
इसका उपयोग बैचों में दो डेटा के उत्पाद को करने के लिए किया जाता है। इनपुट आयाम 2 या अधिक होना चाहिए। इसे नीचे दिखाया गया है -
>>> a_batch = k.ones(shape = (2,3))
>>> b_batch = k.ones(shape = (3,2))
>>> c_batch = k.batch_dot(a_batch,b_batch)
>>> c_batch
<tf.Tensor 'ExpandDims:0' shape = (2, 1) dtype = float32>
परिवर्तनशील
इसका उपयोग किसी वैरिएबल को इनिशियलाइज़ करने के लिए किया जाता है। आइए हम इस चर में सरल पारगमन ऑपरेशन करते हैं।
>>> data = k.variable([[10,20,30,40],[50,60,70,80]])
#variable initialized here
>>> result = k.transpose(data)
>>> print(result)
Tensor("transpose_6:0", shape = (4, 2), dtype = float32)
>>> print(k.eval(result))
[[10. 50.]
[20. 60.]
[30. 70.]
[40. 80.]]
यदि आप numpy से एक्सेस करना चाहते हैं -
>>> data = np.array([[10,20,30,40],[50,60,70,80]])
>>> print(np.transpose(data))
[[10 50]
[20 60]
[30 70]
[40 80]]
>>> res = k.variable(value = data)
>>> print(res)
<tf.Variable 'Variable_7:0' shape = (2, 4) dtype = float32_ref>
is_sparse (टेन्सर)
इसका उपयोग यह जांचने के लिए किया जाता है कि टेंसर विरल है या नहीं।
>>> a = k.placeholder((2, 2), sparse=True)
>>> print(a) SparseTensor(indices =
Tensor("Placeholder_8:0",
shape = (?, 2), dtype = int64),
values = Tensor("Placeholder_7:0", shape = (?,),
dtype = float32), dense_shape = Tensor("Const:0", shape = (2,), dtype = int64))
>>> print(k.is_sparse(a)) True
to_dense ()
इसका उपयोग विरल को घने में परिवर्तित करने के लिए किया जाता है।
>>> b = k.to_dense(a)
>>> print(b) Tensor("SparseToDense:0", shape = (2, 2), dtype = float32)
>>> print(k.is_sparse(b)) False
random_uniform_variable
इसका उपयोग शुरू करने के लिए किया जाता है uniform distribution अवधारणा।
k.random_uniform_variable(shape, mean, scale)
यहाँ,
shape - टुपल्स के प्रारूप में पंक्तियों और स्तंभों को दर्शाता है।
mean - समान वितरण का मतलब।
scale - समान वितरण का मानक विचलन।
आइए नीचे दिए गए उदाहरण के उपयोग पर एक नजर डालें -
>>> a = k.random_uniform_variable(shape = (2, 3), low=0, high = 1)
>>> b = k. random_uniform_variable(shape = (3,2), low = 0, high = 1)
>>> c = k.dot(a, b)
>>> k.int_shape(c)
(2, 2)
बर्तन मॉड्यूल
utilsगहरी सीखने के लिए उपयोगी उपयोगिताओं प्रदान करता है। द्वारा प्रदान की गई विधियों में से कुछutils मॉड्यूल इस प्रकार है -
HDF5Matrix
इसका उपयोग एचडीएफ 5 प्रारूप में इनपुट डेटा का प्रतिनिधित्व करने के लिए किया जाता है।
from keras.utils import HDF5Matrix data = HDF5Matrix('data.hdf5', 'data')
to_categorical
इसका उपयोग क्लास वेक्टर को बाइनरी क्लास मैट्रिक्स में बदलने के लिए किया जाता है।
>>> from keras.utils import to_categorical
>>> labels = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
>>> to_categorical(labels)
array([[1., 0., 0., 0., 0., 0., 0., 0., 0., 0.],
[0., 1., 0., 0., 0., 0., 0., 0., 0., 0.],
[0., 0., 1., 0., 0., 0., 0., 0., 0., 0.],
[0., 0., 0., 1., 0., 0., 0., 0., 0., 0.],
[0., 0., 0., 0., 1., 0., 0., 0., 0., 0.],
[0., 0., 0., 0., 0., 1., 0., 0., 0., 0.],
[0., 0., 0., 0., 0., 0., 1., 0., 0., 0.],
[0., 0., 0., 0., 0., 0., 0., 1., 0., 0.],
[0., 0., 0., 0., 0., 0., 0., 0., 1., 0.],
[0., 0., 0., 0., 0., 0., 0., 0., 0., 1.]], dtype = float32)
>>> from keras.utils import normalize
>>> normalize([1, 2, 3, 4, 5])
array([[0.13483997, 0.26967994, 0.40451992, 0.53935989, 0.67419986]])
print_summary
इसका उपयोग मॉडल के सारांश को प्रिंट करने के लिए किया जाता है।
from keras.utils import print_summary print_summary(model)
plot_model
इसका उपयोग डॉट प्रारूप में मॉडल प्रतिनिधित्व बनाने और इसे फ़ाइल में सहेजने के लिए किया जाता है।
from keras.utils import plot_model
plot_model(model,to_file = 'image.png')
यह plot_model मॉडल के प्रदर्शन को समझने के लिए एक छवि उत्पन्न करेगा।