केरस - मॉड्यूल

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

उपलब्ध मॉड्यूल

आइए सबसे पहले 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 मॉडल के प्रदर्शन को समझने के लिए एक छवि उत्पन्न करेगा।