अपाचे एमएक्सनेट - पायथन एपीआई सिंबल

इस अध्याय में, हम MXNet में एक इंटरफ़ेस के बारे में जानेंगे जिसे प्रतीक के रूप में जाना जाता है।

Mxnet.ndarray

अपाचे एमएक्सनेट का सिंबल एपीआई प्रतीकात्मक प्रोग्रामिंग के लिए एक इंटरफ़ेस है। प्रतीक एपीआई निम्नलिखित का उपयोग करता है -

  • कम्प्यूटेशनल रेखांकन

  • याददाश्त का कम होना

  • फ़ंक्शन ऑप्टिमाइज़ेशन का उपयोग करें

नीचे दिए गए उदाहरण से पता चलता है कि कैसे एमएक्सनेट के सिंबल एपीआई का उपयोग करके एक सरल अभिव्यक्ति बना सकते हैं -

एक नियमित पायथन सूची से 1-डी और 2-डी 'सरणी' का उपयोग करके एक एनडीएआरयर -

import mxnet as mx
# Two placeholders namely x and y will be created with mx.sym.variable
x = mx.sym.Variable('x')
y = mx.sym.Variable('y')
# The symbol here is constructed using the plus ‘+’ operator.
z = x + y

Output

आप निम्न आउटपुट देखेंगे -

<Symbol _plus0>

Example

(x, y, z)

Output

उत्पादन नीचे दिया गया है -

(<Symbol x>, <Symbol y>, <Symbol _plus0>)

अब आइए MXNet के ndarray API के वर्गों, कार्यों और मापदंडों के बारे में विस्तार से चर्चा करें।

कक्षाओं

निम्नलिखित तालिका में एमएक्सनेट के प्रतीक एपीआई की कक्षाएं शामिल हैं -

कक्षा परिभाषा
प्रतीक (संभाल) यह वर्ग अर्थात् प्रतीक अपाचे एमएक्सनेट का प्रतीकात्मक ग्राफ है।

कार्य और उनके पैरामीटर

निम्नलिखित कुछ महत्वपूर्ण कार्य और उनके पैरामीटर mxnet द्वारा कवर किए गए हैं। सिम्बॉल एपीआई -

समारोह और इसके पैरामीटर परिभाषा
सक्रियण ([डेटा, act_type, आउट, नाम]) यह एक सक्रियण फ़ंक्शन तत्व-वार को इनपुट पर लागू करता है। यह समर्थन करता हैrelu, sigmoid, tanh, softrelu, softsign सक्रियण कार्य।
बैचनॉर्म ([डेटा, गामा, बीटा, मूविंग_मन,…]) इसका उपयोग बैच के सामान्यीकरण के लिए किया जाता है। यह फ़ंक्शन माध्य और विचरण द्वारा डेटा बैच को सामान्य करता है। यह एक पैमाने पर लागू होता हैgamma और ऑफसेट beta
BilinearSampler ([डेटा, ग्रिड, cudnn_off,…]) यह फ़ंक्शन इनपुट फीचर मैप पर बिलिनियर सैंपलिंग लागू करता है। वास्तव में यह "स्थानिक ट्रांसफार्मर नेटवर्क" की कुंजी है। यदि आप OpenCV में रीमैप फ़ंक्शन से परिचित हैं, तो इस फ़ंक्शन का उपयोग काफी हद तक समान है। फर्क सिर्फ इतना है कि इसमें बैकवर्ड पास है।
ब्लॉकग्राद ([डेटा, आउट, नाम]) जैसा कि नाम निर्दिष्ट करता है, यह फ़ंक्शन ढाल संगणना को रोकता है। यह मूल रूप से पिछड़े दिशा में इस ऑपरेटर के माध्यम से बहने से इनपुट के संचित ढाल को रोकता है।
कास्ट ([डेटा, dtype, आउट, नाम]) यह फ़ंक्शन इनपुट के सभी तत्वों को एक नए प्रकार में डालेगा।
यह फ़ंक्शन इनपुट के सभी तत्वों को एक नए प्रकार में डालेगा। यह फ़ंक्शन, जैसा कि निर्दिष्ट नाम है, शून्य और दिए गए आकार और प्रकार का एक नया प्रतीक देता है।
वाले (आकार [, dtype]) यह फ़ंक्शन, जैसा कि नाम निर्दिष्ट है, दिए गए आकार और प्रकार का एक नया प्रतीक लौटाता है, जो कि भरा हुआ है।
पूर्ण (आकार, वैल [, dtype]) यह फ़ंक्शन, जैसा कि नाम निर्दिष्ट है, दिए गए आकार और प्रकार का एक नया सरणी देता है, दिए गए मान से भरा हुआ है val
अरेंज (स्टार्ट [, स्टॉप, स्टेप, रिपीट,…]) यह दिए गए अंतराल के भीतर समान रूप से अंतरित मान लौटाएगा। मान आधे खुले अंतराल [प्रारंभ, रोक) के भीतर उत्पन्न होते हैं, जिसका अर्थ है कि अंतराल शामिल हैstart लेकिन बाहर रखा गया है stop
Linspace (प्रारंभ, स्टॉप, संख्या [, समापन बिंदु, नाम,…]) यह एक निर्दिष्ट अंतराल के भीतर समान रूप से अंतरित संख्या लौटाएगा। फ़ंक्शन अरेंज () के समान, मान आधे खुले अंतराल [स्टार्ट, स्टॉप) के भीतर उत्पन्न होते हैं, जिसका अर्थ है कि अंतराल शामिल हैstart लेकिन बाहर रखा गया है stop
हिस्टोग्राम ([[, डिब्बे, रेंज]) जैसा कि नाम से ही स्पष्ट है, यह फ़ंक्शन इनपुट डेटा के हिस्टोग्राम की गणना करेगा।
शक्ति (आधार, ऍक्स्प) जैसा कि नाम से ही स्पष्ट है, यह फ़ंक्शन तत्व-वार परिणाम लौटाएगा base तत्वों से शक्तियों को उठाया expतत्व। दोनों इनपुट यानी बेस और ऍक्स्प, या तो सिंबल या स्केलर हो सकते हैं। यहां ध्यान दें कि प्रसारण की अनुमति नहीं है। आप उपयोग कर सकते हैंbroadcast_pow यदि आप प्रसारण की सुविधा का उपयोग करना चाहते हैं।
सॉफ्टमैक्सएक्टिवेशन ([डेटा, मोड, नाम, एटर, आउट]) यह फ़ंक्शन इनपुट पर सॉफ्टमैक्स सक्रियण लागू करता है। यह आंतरिक परतों के लिए अभिप्रेत है। यह वास्तव में पदावनत है, हम उपयोग कर सकते हैंsoftmax() बजाय।

कार्यान्वयन के उदाहरण

नीचे दिए गए उदाहरण में हम फ़ंक्शन का उपयोग करेंगे power() आधार तत्व के तत्व-वार परिणाम, जो एक्सपेक्ट एलिमेंट से शक्तियों के लिए उठाया जाएगा:

import mxnet as mx
mx.sym.power(3, 5)

Output

आप निम्न आउटपुट देखेंगे -

243

Example

x = mx.sym.Variable('x')
y = mx.sym.Variable('y')
z = mx.sym.power(x, 3)
z.eval(x=mx.nd.array([1,2]))[0].asnumpy()

Output

यह निम्नलिखित उत्पादन का उत्पादन करता है -

array([1., 8.], dtype=float32)

Example

z = mx.sym.power(4, y)
z.eval(y=mx.nd.array([2,3]))[0].asnumpy()

Output

जब आप उपरोक्त कोड निष्पादित करते हैं, तो आपको निम्नलिखित आउटपुट देखना चाहिए -

array([16., 64.], dtype=float32)

Example

z = mx.sym.power(x, y)
z.eval(x=mx.nd.array([4,5]), y=mx.nd.array([2,3]))[0].asnumpy()

Output

उत्पादन का उल्लेख नीचे दिया गया है -

array([ 16., 125.], dtype=float32)

नीचे दिए गए उदाहरण में, हम फ़ंक्शन का उपयोग करेंगे SoftmaxActivation() (or softmax()) जो इनपुट पर लागू किया जाएगा और आंतरिक परतों के लिए अभिप्रेत है।

input_data = mx.nd.array([[2., 0.9, -0.5, 4., 8.], [4., -.7, 9., 2., 0.9]])
soft_max_act = mx.nd.softmax(input_data)
print (soft_max_act.asnumpy())

Output

आप निम्न आउटपुट देखेंगे -

[[2.4258138e-03 8.0748333e-04 1.9912292e-04 1.7924475e-02 9.7864312e-01]
[6.6843745e-03 6.0796250e-05 9.9204916e-01 9.0463174e-04 3.0112563e-04]]

symbol.contrib

कॉन्ट्रिब NDArray API को सिंबल.कंट्री पैकेज में परिभाषित किया गया है। यह आम तौर पर नई सुविधाओं के लिए कई उपयोगी प्रयोगात्मक एपीआई प्रदान करता है। यह एपीआई उस समुदाय के लिए एक जगह के रूप में काम करता है जहां वे नई सुविधाओं की कोशिश कर सकते हैं। फीचर योगदानकर्ता को प्रतिक्रिया भी मिलेगी।

कार्य और उनके पैरामीटर

निम्नलिखित कुछ महत्वपूर्ण कार्य और उनके मापदंडों को कवर किया गया है mxnet.symbol.contrib API -

समारोह और इसके पैरामीटर परिभाषा
rand_zipfian (true_classes, num_sampled,…) यह फ़ंक्शन लगभग ज़िपफ़ियन वितरण से यादृच्छिक नमूने खींचता है। इस फ़ंक्शन का आधार वितरण ज़िपफ़ियन वितरण है। यह फ़ंक्शन यादृच्छिक रूप से num_sampled उम्मीदवारों का नमूना देता है और samped_candidates के तत्व ऊपर दिए गए आधार वितरण से तैयार किए जाते हैं।
foreach (शरीर, डेटा, init_states) जैसा कि नाम से पता चलता है, यह फ़ंक्शन आयाम 0. पर NDArrays पर उपयोगकर्ता द्वारा परिभाषित संगणना के साथ एक लूप चलाता है। यह फ़ंक्शन लूप के लिए अनुकरण करता है और बॉडी में लूप के पुनरावृत्ति के लिए अभिकलन होता है।
जबकि_लूप (कॉन्ड, फंक, लूप_वर्ज़ [,…]) जैसा कि नाम से ही स्पष्ट है, यह फ़ंक्शन उपयोगकर्ता द्वारा परिभाषित संगणना और लूप स्थिति के साथ थोड़ी देर चलता है। यह फ़ंक्शन थोड़ी देर के लूप को अनुकरण करता है जो कि अगर शर्त संतुष्ट हो तो साहित्यिक रूप से अनुकूलित गणना करता है।
कंडोम (पूर्व, तत्कालीन_फून, और_फंक) जैसा कि नाम से ही स्पष्ट है, यह फ़ंक्शन उपयोगकर्ता द्वारा परिभाषित स्थिति और अभिकलन का उपयोग करके एक if-if-अन्यथा चलाता है। यह फ़ंक्शन एक अगर-जैसी शाखा का अनुकरण करता है, जो निर्दिष्ट स्थिति के अनुसार दो अनुकूलित संगणनाओं में से एक करने का विकल्प चुनता है।
getnnz ([डेटा, अक्ष, आउट, नाम]) यह फ़ंक्शन हमें एक विरल टेंसर के लिए संग्रहीत मूल्यों की संख्या देता है। इसमें स्पष्ट शून्य भी शामिल है। यह केवल सीपीयू पर सीएसआर मैट्रिक्स का समर्थन करता है।
अपेक्षित ([डेटा, min_range, max_range,…]) इस फ़ंक्शन को दिए गए डेटा की आवश्यकता होती है जिसे int32 और संबंधित थ्रेसहोल्ड में परिमाणित किया जाता है, मिनट और अधिकतम थ्रेसहोल्ड का उपयोग करके int8 में रनटाइम या कैलिब्रेशन से गणना की जाती है।
index_copy ([old_tensor, index_vector,…]) यह फ़ंक्शन a के तत्वों को कॉपी करता है new_tensor into the old_tensor by selecting the indices in the order given in index. The output of this operator will be a new tensor that contains the rest elements of old tensor and the copied elements of new tensor
interleaved_matmul_encdec_qk ([प्रश्न,…]) यह ऑपरेटर एनकोडर-डिकोडर के रूप में मल्टी-हेड ध्यान उपयोग में प्रश्नों और कुंजियों के अनुमानों के बीच मैट्रिक्स गुणन की गणना करता है। शर्त यह है कि इनपुट लेआउट के बाद आने वाले प्रश्नों के अनुमानों का दशांश होना चाहिए: (seq_length, batch_size, num_heads *, head_dim)।

कार्यान्वयन के उदाहरण

नीचे दिए गए उदाहरण में हम लगभग ज़िपफियन वितरण से यादृच्छिक नमूने खींचने के लिए फ़ंक्शन rand_zipfian का उपयोग करेंगे।

import mxnet as mx
true_cls = mx.sym.Variable('true_cls')
samples, exp_count_true, exp_count_sample = mx.sym.contrib.rand_zipfian(true_cls, 5, 6)
samples.eval(true_cls=mx.nd.array([3]))[0].asnumpy()

Output

आप निम्न आउटपुट देखेंगे -

array([4, 0, 2, 1, 5], dtype=int64)

Example

exp_count_true.eval(true_cls=mx.nd.array([3]))[0].asnumpy()

Output

उत्पादन का उल्लेख नीचे दिया गया है -

array([0.57336551])

Example

exp_count_sample.eval(true_cls=mx.nd.array([3]))[0].asnumpy()

Output

आप निम्न आउटपुट देखेंगे -

array([1.78103594, 0.46847373, 1.04183923, 0.57336551, 1.04183923])

नीचे दिए गए उदाहरण में हम फ़ंक्शन का उपयोग करेंगे while_loop उपयोगकर्ता द्वारा परिभाषित संगणना और लूप स्थिति के लिए कुछ समय के लिए लूप चलाने के लिए -

cond = lambda i, s: i <= 7
func = lambda i, s: ([i + s], [i + 1, s + i])
loop_vars = (mx.sym.var('i'), mx.sym.var('s'))
outputs, states = mx.sym.contrib.while_loop(cond, func, loop_vars, max_iterations=10)
print(outputs)

Output

आउटपुट नीचे दिया गया है:

[<Symbol _while_loop0>]

Example

Print(States)

Output

यह निम्नलिखित उत्पादन का उत्पादन करता है -

[<Symbol _while_loop0>, <Symbol _while_loop0>]

नीचे दिए गए उदाहरण में हम फ़ंक्शन का उपयोग करेंगे index_copy जो new_tensor के तत्वों को पुराने_tensor में कॉपी करता है।

import mxnet as mx
a = mx.nd.zeros((6,3))
b = mx.nd.array([[1,2,3],[4,5,6],[7,8,9]])
index = mx.nd.array([0,4,2])
mx.nd.contrib.index_copy(a, index, b)

Output

जब आप उपरोक्त कोड निष्पादित करते हैं, तो आपको निम्नलिखित आउटपुट देखना चाहिए -

[[1. 2. 3.]
[0. 0. 0.]
[7. 8. 9.]
[0. 0. 0.]
[4. 5. 6.]
[0. 0. 0.]]
<NDArray 6x3 @cpu(0)>

symbol.image

छवि प्रतीक एपीआई को सिंबल पैकेज में परिभाषित किया गया है। जैसा कि नाम का तात्पर्य है, यह आमतौर पर छवियों और उनकी विशेषताओं के लिए उपयोग किया जाता है।

कार्य और उनके पैरामीटर

निम्नलिखित कुछ महत्वपूर्ण कार्य और उनके मापदंडों को कवर किया गया है mxnet.symbol.image API -

समारोह और इसके पैरामीटर परिभाषा
समायोजन_ प्रकाश ([डेटा, अल्फा, आउट, नाम]) जैसा कि नाम से ही स्पष्ट है, यह फ़ंक्शन इनपुट के प्रकाश स्तर को समायोजित करता है। यह एलेक्सनेट शैली का अनुसरण करता है।
फसल ([डेटा, x, y, चौड़ाई, ऊंचाई, बाहर, नाम]) इस फ़ंक्शन की सहायता से हम उपयोगकर्ता द्वारा दिए गए आकार को NDArray ऑफ़ शेप (H x W x C) या (N x H x W x C) क्रॉप कर सकते हैं।
सामान्यीकृत करें ([डेटा, माध्य, एसटीडी, आउट, नाम]) यह आकार के दसियों (C x H x W) या (N x C x H x W) को सामान्य करेगा mean तथा standard deviation(SD)
random_crop ([डेटा, xrange, yrange, चौड़ाई, ...]) फसल के समान (), यह बेतरतीब ढंग से उपयोगकर्ता द्वारा दिए गए आकार को आकार (एच एक्स डब्ल्यू एक्स सी) या (एन एक्स एच एक्स डब्ल्यू एक्स सी) की एक छवि NDArray फसल देता है। यदि यह परिणाम को प्रभावित करेगाsrc से छोटा है size
random_lighting((डेटा, अल्फ़ा_स्टीडी, आउट, नाम]) जैसा कि नाम से पता चलता है, यह फ़ंक्शन पीसीए शोर को यादृच्छिक रूप से जोड़ता है। यह एलेक्सनेट शैली का अनुसरण भी करता है।
random_resized_crop ([डेटा, xrange, yrange,…]) यह दी गई आकृति में बेतरतीब ढंग से NDArray की आकृति (H x W x C) या (N x H x W x C) को भी काटता है। यदि परिणाम src आकार से छोटा है, तो यह परिणाम को बेहतर बनाएगा। यह क्षेत्र और पहलू राशन को भी यादृच्छिक करेगा।
आकार ([डेटा, आकार, Keep_ratio, इंटरप,…]) जैसा कि नाम से पता चलता है, यह फ़ंक्शन उपयोगकर्ता द्वारा दिए गए आकार के आकार (H x W x C) या (N x H x W x C) की एक छवि NDArray का आकार देगा।
to_tensor ([डेटा, आउट, नाम]) यह आकार के एक NDArray (H x W x x C) या (N x H x W x C) को आकार के मान [0, 255] के आकार के प्रति दसवें NDArray (C x H x W) या में परिवर्तित करता है। N x C x H x W) की सीमा में मानों के साथ [0, 1]।

कार्यान्वयन के उदाहरण

नीचे दिए गए उदाहरण में, हम फ़ंक्शन to_tensor का उपयोग करके आकृति के NDArray (H x W x C) या (N x H x W x C) के मान को रेंज में मानों के साथ उपयोग करेंगे [0, 255] एक दसवें NDArray के लिए आकार (C x H x W) या (N x C x H x W) की श्रेणी में मानों के साथ [0, 1]।

import numpy as np

img = mx.sym.random.uniform(0, 255, (4, 2, 3)).astype(dtype=np.uint8)

mx.sym.image.to_tensor(img)

Output

उत्पादन नीचे बताया गया है -

<Symbol to_tensor4>

Example

img = mx.sym.random.uniform(0, 255, (2, 4, 2, 3)).astype(dtype=np.uint8)

mx.sym.image.to_tensor(img)

Output

उत्पादन नीचे उल्लिखित है:

<Symbol to_tensor5>

नीचे दिए गए उदाहरण में, हम आकार के एक टेंसर (C x H x W) या (N x C x H x W) को सामान्य करने के लिए फ़ंक्शन को सामान्यीकृत () का उपयोग करेंगे। mean तथा standard deviation(SD)

img = mx.sym.random.uniform(0, 1, (3, 4, 2))

mx.sym.image.normalize(img, mean=(0, 1, 2), std=(3, 2, 1))

Output

नीचे दिए गए कोड का उत्पादन है -

<Symbol normalize0>

Example

img = mx.sym.random.uniform(0, 1, (2, 3, 4, 2))

mx.sym.image.normalize(img, mean=(0, 1, 2), std=(3, 2, 1))

Output

उत्पादन नीचे दिखाया गया है -

<Symbol normalize1>

symbol.random

रैंडम सिंबल एपीआई को सिंबल.ड्रैगन पैकेज में परिभाषित किया गया है। जैसा कि नाम से ही स्पष्ट है, यह MXNet का यादृच्छिक वितरण जनरेटर प्रतीक API है।

कार्य और उनके पैरामीटर

निम्नलिखित कुछ महत्वपूर्ण कार्य और उनके मापदंडों को कवर किया गया है mxnet.symbol.random API -

समारोह और इसके पैरामीटर परिभाषा
वर्दी ([कम, उच्च, आकार, dtype, ctx, आउट]) यह एक समान वितरण से यादृच्छिक नमूने उत्पन्न करता है।
सामान्य ([स्थान, पैमाना, आकार, dtype, ctx, out]) यह एक सामान्य (गाऊसी) वितरण से यादृच्छिक नमूने उत्पन्न करता है।
रंडन (* आकार, ** कंवर) यह एक सामान्य (गाऊसी) वितरण से यादृच्छिक नमूने उत्पन्न करता है।
पॉइसन ([लाम, आकार, dtype, ctx, आउट]) यह एक Poisson वितरण से यादृच्छिक नमूने उत्पन्न करता है।
घातीय ([पैमाने, आकार, dtype, ctx, आउट]) यह एक घातांक वितरण से नमूने उत्पन्न करता है।
गामा ([अल्फा, बीटा, आकृति, dtype, ctx, out]) यह एक गामा वितरण से यादृच्छिक नमूने उत्पन्न करता है।
बहुराष्ट्रीय (डेटा [, आकृति, get_prob, आउट, dtype]) यह कई बहुराष्ट्रीय वितरण से समवर्ती नमूना उत्पन्न करता है।
negative_binomial ([k, p, आकृति, dtype, ctx, out]) यह एक नकारात्मक द्विपद वितरण से यादृच्छिक नमूने उत्पन्न करता है।
generalized_negative_binomial ([म्यू, अल्फा,…]) यह सामान्यीकृत नकारात्मक द्विपद वितरण से यादृच्छिक नमूने उत्पन्न करता है।
फेरबदल (डेटा, ** kwargs) यह तत्वों को यादृच्छिक रूप से फेरबदल करता है।
रैंडिन्ट (कम, उच्च [, आकार, dtype, ctx, out]) यह असतत वर्दी वितरण से यादृच्छिक नमूने उत्पन्न करता है।
exponential_like ([डेटा, लाम, आउट, नाम]) यह इनपुट सरणी आकार के अनुसार एक घातांक वितरण से यादृच्छिक नमूने उत्पन्न करता है।
gamma_like ([डेटा, अल्फ़ा, बीटा, आउट, नाम]) यह इनपुट सरणी आकार के अनुसार एक गामा वितरण से यादृच्छिक नमूने उत्पन्न करता है।
generalized_negative_binomial_like ([डेटा,…]) यह इनपुट सरणी आकार के अनुसार एक सामान्यीकृत नकारात्मक द्विपद वितरण से यादृच्छिक नमूने उत्पन्न करता है।
negative_binomial_like ([डेटा, के, पी, आउट, नाम]) यह इनपुट सरणी आकार के अनुसार एक नकारात्मक द्विपद वितरण से यादृच्छिक नमूने उत्पन्न करता है।
normal_like ([डेटा, लोकेशन, स्केल, आउट, नाम]) यह इनपुट सरणी आकार के अनुसार एक सामान्य (गाऊसी) वितरण से यादृच्छिक नमूने उत्पन्न करता है।
poisson_like ([डेटा, लाम, आउट, नाम]) यह इनपुट सरणी आकार के अनुसार एक पॉइसन वितरण से यादृच्छिक नमूने उत्पन्न करता है।
समरूप_रूप ([डेटा, निम्न, उच्च, बाहर, नाम]) यह इनपुट सरणी आकार के अनुसार एक समान वितरण से यादृच्छिक नमूने उत्पन्न करता है।

कार्यान्वयन के उदाहरण

नीचे दिए गए उदाहरण में, हम फेरबदल () फ़ंक्शन का उपयोग करते हुए तत्वों को बेतरतीब ढंग से फेरबदल करने जा रहे हैं। यह पहली धुरी के साथ सरणी को फेरबदल करेगा।

data = mx.nd.array([[0, 1, 2], [3, 4, 5], [6, 7, 8],[9,10,11]])
x = mx.sym.Variable('x')
y = mx.sym.random.shuffle(x)
y.eval(x=data)

Output

आप निम्न आउटपुट देखेंगे:

[
[[ 9. 10. 11.]
[ 0. 1. 2.]
[ 6. 7. 8.]
[ 3. 4. 5.]]
<NDArray 4x3 @cpu(0)>]

Example

y.eval(x=data)

Output

जब आप उपरोक्त कोड निष्पादित करते हैं, तो आपको निम्नलिखित आउटपुट देखना चाहिए -

[
[[ 6. 7. 8.]
[ 0. 1. 2.]
[ 3. 4. 5.]
[ 9. 10. 11.]]
<NDArray 4x3 @cpu(0)>]

नीचे दिए गए उदाहरण में, हम सामान्यकृत द्विपद वितरण से यादृच्छिक नमूने आकर्षित करने जा रहे हैं। इसके लिए फ़ंक्शन का उपयोग किया जाएगाgeneralized_negative_binomial()

mx.sym.random.generalized_negative_binomial(10, 0.1)

Output

उत्पादन नीचे दिया गया है -

<Symbol _random_generalized_negative_binomial0>

symbol.sparse

Sparse Symbol API को mxnet.symbol.sparse पैकेज में परिभाषित किया गया है। जैसा कि नाम से पता चलता है, यह सीपीयू पर विरल तंत्रिका नेटवर्क ग्राफ और ऑटो-भेदभाव प्रदान करता है।

कार्य और उनके पैरामीटर

निम्नलिखित कुछ महत्वपूर्ण कार्य हैं (जिनमें सिंबल क्रिएशन रूटीन, सिंबल मैनिपुलेशन रूटीन, गणितीय फ़ंक्शंस, त्रिकोणमितीय फ़ंक्शन, हाइबरबोलिक फ़ंक्शन, रिड्यूस फ़ंक्शन, राउंडिंग, पॉवर्स, न्यूरल नेटवर्क) और उनके पैरामीटर शामिल हैं mxnet.symbol.sparse API -

समारोह और इसके पैरामीटर परिभाषा
एलीमेंट वाइजसुम (* आर्ग्स, ** क्वार्ग्स) यह फ़ंक्शन सभी इनपुट तर्कों को तत्व वार जोड़ देगा। उदाहरण के लिए, _ (1,2,… = 1 + 2 + 1, +)। यहां, हम देख सकते हैं कि add_n n बार कॉल ऐड की तुलना में अधिक कुशल है।
एंबेडिंग ([डेटा, वजन, input_dim,…]) यह सदिश अभ्यावेदन यानी एम्बेडिंग के पूर्णांक सूचकांकों को मैप करेगा। यह वास्तव में शब्दों को उच्च-आयामी अंतरिक्ष में वास्तविक-मूल्यवान वैक्टरों के लिए मैप करता है जिसे शब्द एम्बेडिंग कहा जाता है।
LinearRegressionOutput ([डेटा, लेबल,…]) यह आगे के प्रसार के दौरान सिर्फ आउटपुट डेटा देने के लिए पिछड़े प्रसार के दौरान चुकता नुकसान के लिए गणना और अनुकूलन करता है।
LogisticRegressionOutput ([डेटा, लेबल,…]) एक लॉजिस्टिक फ़ंक्शन को लागू करता है जिसे इनपुट को सिग्मॉइड फ़ंक्शन भी कहा जाता है। फ़ंक्शन की गणना 1/1 + ऍक्स्प (.x) के रूप में की जाती है।
MAERegressionOutput ([डेटा, लेबल,…]) यह ऑपरेटर गणना करता है कि इनपुट की पूर्ण त्रुटि है। एमएई वास्तव में एक जोखिम मीट्रिक है जो पूर्ण त्रुटि के अपेक्षित मूल्य के अनुरूप है।
पेट ([डेटा, नाम, attr, बाहर]) जैसा कि नाम से स्पष्ट है, यह फ़ंक्शन इनपुट के तत्व-वार निरपेक्ष मान लौटाएगा।
adagrad_update ([वजन, ग्रेड, इतिहास, lr,…]) यह एक अद्यतन कार्य है AdaGrad optimizer
adam_update ([वजन, क्रम, माध्य, var, lr,…]) यह एक अद्यतन कार्य है Adam optimizer
add_n (* args, ** kwargs) जैसा कि नाम का तात्पर्य है यह सभी इनपुट तर्कों को तत्व-वार जोड़ देगा।
arccos ([डेटा, नाम, attr, आउट]) यह फ़ंक्शन इनपुट एरे के तत्व-वार उलटा कोसिन लौटाएगा।
डॉट ([lhs, rhs, transpose_a, transpose_b,…]) जैसा कि नाम से ही स्पष्ट है, यह दो सरणियों का डॉट उत्पाद देगा। यह इनपुट सरणी आयाम पर निर्भर करेगा: 1-डी: वैक्टर 2-डी का आंतरिक उत्पाद: मैट्रिक्स गुणन एनडी: पहले इनपुट के अंतिम अक्ष पर एक योग उत्पाद और दूसरे इनपुट का पहला अक्ष।
elemwise_add ([lhs, rhs, name, attr, out]) जैसा कि नाम से ही जाहिर है add तर्क तत्व वार।
elemwise_div ([lhs, rhs, name, attr, out]) जैसा कि नाम से ही जाहिर है divide तर्क तत्व वार।
एलएमवाइज_मूल ([lhs, rhs, name, attr, out]) जैसा कि नाम से ही जाहिर है Multiply तर्क तत्व वार।
elemwise_sub ([lhs, rhs, name, attr, out]) जैसा कि नाम का तात्पर्य है, यह तत्व तर्क को घटा देगा।
ऍक्स्प ([डेटा, नाम, Attr, आउट]) यह फ़ंक्शन दिए गए इनपुट का तत्व वार घातीय मान लौटाएगा।
sgd_update ([वजन, क्रम, lr, wd,…]) यह स्टोचस्टिक ग्रेडिएंट डिसेंट ऑप्टिमाइज़र के अपडेट फ़ंक्शन के रूप में कार्य करता है।
सिग्मॉइड ([डेटा, नाम, एटर, आउट]) जैसा कि नाम से ही स्पष्ट है कि यह गणना करेगा sigmoid एक्स तत्व के अनुसार।
हस्ताक्षर ([डेटा, नाम, Attr, आउट]) यह दिए गए इनपुट के तत्व वार संकेत को लौटा देगा।
पाप ([डेटा, नाम, attr, बाहर]) जैसा कि नाम से स्पष्ट है, यह फ़ंक्शन दिए गए इनपुट ऐरे के तत्व वार साइन की गणना करेगा।

कार्यान्वयन उदाहरण

नीचे दिए गए उदाहरण में, हम बेतरतीब ढंग से उपयोग किए जाने वाले तत्वों को फेरबदल करने जा रहे हैं ElementWiseSum()समारोह। यह वेक्टर अभ्यावेदन यानी शब्द एम्बेडिंग के पूर्णांक सूचकांकों को मैप करेगा।

input_dim = 4
output_dim = 5

Example

/* Here every row in weight matrix y represents a word. So, y = (w0,w1,w2,w3)
y = [[ 0., 1., 2., 3., 4.],
[ 5., 6., 7., 8., 9.],
[ 10., 11., 12., 13., 14.],
[ 15., 16., 17., 18., 19.]]
/* Here input array x represents n-grams(2-gram). So, x = [(w1,w3), (w0,w2)]
x = [[ 1., 3.],
[ 0., 2.]]
/* Now, Mapped input x to its vector representation y.
Embedding(x, y, 4, 5) = [[[ 5., 6., 7., 8., 9.],
[ 15., 16., 17., 18., 19.]],
[[ 0., 1., 2., 3., 4.],
[ 10., 11., 12., 13., 14.]]]