Apache MXNet - पायथन एपीआई ndarray

यह अध्याय ndarray पुस्तकालय को बताता है जो Apache MXNet में उपलब्ध है।

Mxnet.ndarray

Apache MXNet की NDArray लाइब्रेरी सभी गणितीय संगणनाओं के लिए मुख्य DS (डेटा संरचनाओं) को परिभाषित करती है। NDArray की दो मूलभूत नौकरियां इस प्रकार हैं -

  • यह हार्डवेयर कॉन्फ़िगरेशन की एक विस्तृत श्रृंखला पर तेजी से निष्पादन का समर्थन करता है।

  • यह स्वचालित रूप से उपलब्ध हार्डवेयर में कई ऑपरेशनों को समानांतर करता है।

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

import mxnet as mx
from mxnet import nd

x = nd.array([1,2,3,4,5,6,7,8,9,10])
print(x)

Output

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

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

Example

y = nd.array([[1,2,3,4,5,6,7,8,9,10], [1,2,3,4,5,6,7,8,9,10], [1,2,3,4,5,6,7,8,9,10]])
print(y)

Output

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

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

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

कक्षाएं

निम्न तालिका में MXNet के ndarray API की कक्षाएं शामिल हैं -

कक्षा परिभाषा
कैश्ड ऑप (सिम्फनी [, झंडे]) इसका उपयोग कैश्ड ऑपरेटर हैंडल के लिए किया जाता है।
NDArray (संभाल [, लिखने योग्य]) इसका उपयोग एक सरणी ऑब्जेक्ट के रूप में किया जाता है जो निश्चित-आकार की वस्तुओं के एक बहु-आयामी, सजातीय सरणी का प्रतिनिधित्व करता है।

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

निम्नलिखित कुछ महत्वपूर्ण कार्य और उनके पैरामीटर mxnet.ndarray API द्वारा कवर किए गए हैं -

समारोह और इसके पैरामीटर परिभाषा
Activation((डेटा, act_type, out, name]) यह एक सक्रियण फ़ंक्शन तत्व-वार को इनपुट पर लागू करता है। यह relu, sigmoid, tanh, softrelu, softsign सक्रियण कार्यों का समर्थन करता है।
BatchNorm((डेटा, गामा, बीटा, मूविंग_मन,…]) इसका उपयोग बैच के सामान्यीकरण के लिए किया जाता है। यह फ़ंक्शन माध्य और विचरण द्वारा डेटा बैच को सामान्य करता है। यह एक स्केल गामा और ऑफ़सेट बीटा लागू करता है।
BilinearSampler((डेटा, ग्रिड, cudnn_off,…])

यह फ़ंक्शन इनपुट फीचर मैप पर बिलिनियर सैंपलिंग लागू करता है। वास्तव में यह "स्थानिक ट्रांसफार्मर नेटवर्क" की कुंजी है।

यदि आप OpenCV में रीमैप फ़ंक्शन से परिचित हैं, तो इस फ़ंक्शन का उपयोग काफी हद तक समान है। फर्क सिर्फ इतना है कि इसमें बैकवर्ड पास है।

ब्लॉकग्राद ([डेटा, आउट, नाम]) जैसा कि नाम निर्दिष्ट करता है, यह फ़ंक्शन ढाल संगणना को रोकता है। यह मूल रूप से पिछड़े दिशा में इस ऑपरेटर के माध्यम से बहने से इनपुट के संचित ढाल को रोकता है।
कास्ट ([डेटा, dtype, आउट, नाम]) यह फ़ंक्शन इनपुट के सभी तत्वों को एक नए प्रकार में डालेगा।

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

नीचे दिए गए उदाहरण में, हम दो बार डेटा को ज़ूम आउट करने और क्षैतिज रूप से -1 पिक्सेल द्वारा डेटा को स्थानांतरित करने के लिए फ़ंक्शन बिलिनियरसमलर () का उपयोग करेंगे।

import mxnet as mx
from mxnet import nd
data = nd.array([[[[2, 5, 3, 6],
   [1, 8, 7, 9],
   [0, 4, 1, 8],
   [2, 0, 3, 4]]]])
affine_matrix = nd.array([[2, 0, 0],
   [0, 2, 0]])

affine_matrix = nd.reshape(affine_matrix, shape=(1, 6))

grid = nd.GridGenerator(data=affine_matrix, transform_type='affine', target_shape=(4, 4))

output = nd.BilinearSampler(data, grid)

Output

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

[[[[0. 0. 0. 0. ]
   [0. 4.0000005 6.25 0. ]
   [0. 1.5 4. 0. ]
   [0. 0. 0. 0. ]]]]
<NDArray 1x1x4x4 @cpu(0)>

उपरोक्त आउटपुट दो बार डेटा को ज़ूम आउट करने को दर्शाता है।

1 पिक्सेल द्वारा डाटा को शिफ्ट करने का उदाहरण इस प्रकार है -

import mxnet as mx
from mxnet import nd
data = nd.array([[[[2, 5, 3, 6],
   [1, 8, 7, 9],
   [0, 4, 1, 8],
   [2, 0, 3, 4]]]])
warp_matrix = nd.array([[[[1, 1, 1, 1],
   [1, 1, 1, 1],
   [1, 1, 1, 1],
   [1, 1, 1, 1]],
   [[0, 0, 0, 0],
   [0, 0, 0, 0],
   [0, 0, 0, 0],
   [0, 0, 0, 0]]]])
grid = nd.GridGenerator(data=warp_matrix, transform_type='warp')
output = nd.BilinearSampler(data, grid)

Output

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

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

इसी तरह, निम्नलिखित उदाहरण कलाकारों () फ़ंक्शन का उपयोग दिखाता है -

nd.cast(nd.array([300, 10.1, 15.4, -1, -2]), dtype='uint8')

Output

निष्पादन के बाद, आपको निम्न आउटपुट प्राप्त होंगे -

[ 44 10 15 255 254]
<NDArray 5 @cpu(0)>

ndarray.contrib

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

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

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

समारोह और इसके पैरामीटर परिभाषा
rand_zipfian(true_classes, num_sampled,…) यह फ़ंक्शन लगभग ज़िपफ़ियन वितरण से यादृच्छिक नमूने खींचता है। इस फ़ंक्शन का आधार वितरण ज़िपफ़ियन वितरण है। यह फ़ंक्शन यादृच्छिक रूप से num_sampled उम्मीदवारों का नमूना देता है और samped_candidates के तत्व ऊपर दिए गए आधार वितरण से तैयार किए जाते हैं।
foreach(शरीर, डेटा, init_states) जैसा कि नाम से पता चलता है, यह फ़ंक्शन आयाम 0. पर NDArrays पर उपयोगकर्ता द्वारा परिभाषित संगणना के साथ लूप के लिए चलता है। यह फ़ंक्शन लूप के लिए अनुकरण करता है और लूप के लिए पुनरावृत्ति के लिए शरीर की गणना होती है।
जबकि_लूप (कॉन्ड, फंक, लूप_वर्ज़ [,…]) जैसा कि नाम से ही स्पष्ट है, यह फ़ंक्शन उपयोगकर्ता द्वारा परिभाषित संगणना और लूप स्थिति के साथ थोड़ी देर चलता है। यह फ़ंक्शन थोड़ी देर के लूप को अनुकरण करता है जो कि अगर शर्त संतुष्ट हो तो साहित्यिक रूप से अनुकूलित गणना करता है।
cond(पूर्व, तत्पश्चात जैसा कि नाम से ही स्पष्ट है, यह फ़ंक्शन उपयोगकर्ता द्वारा परिभाषित स्थिति और अभिकलन का उपयोग करके एक if-if-अन्यथा चलाता है। यह फ़ंक्शन एक अगर-जैसी शाखा का अनुकरण करता है, जो निर्दिष्ट स्थिति के अनुसार दो अनुकूलित संगणनाओं में से एक करने का विकल्प चुनता है।
isinf(डेटा) यह फ़ंक्शन यह निर्धारित करने के लिए एक तत्व-वार जाँच करता है कि NDArray में एक अनंत तत्व है या नहीं।
getnnz((डेटा, अक्ष, बाहर, नाम]) यह फ़ंक्शन हमें एक विरल टेंसर के लिए संग्रहीत मूल्यों की संख्या देता है। इसमें स्पष्ट शून्य भी शामिल है। यह केवल सीपीयू पर सीएसआर मैट्रिक्स का समर्थन करता है।
अपेक्षित ([डेटा, min_range, max_range,…]) यह फ़ंक्शन दिए गए डेटा को int32 और संबंधित थ्रेसहोल्ड में परिमाणित करता है, जो min8 और अधिकतम थ्रेसहोल्ड का उपयोग करके int8 में रनटाइम पर या कैलिब्रेशन से गणना करता है।

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

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

import mxnet as mx
from mxnet import nd
trueclass = mx.nd.array([2])
samples, exp_count_true, exp_count_sample = mx.nd.contrib.rand_zipfian(trueclass, 3, 4)
samples

Output

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

[0 0 1]
<NDArray 3 @cpu(0)>

Example

exp_count_true

Output

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

[0.53624076]
<NDArray 1 @cpu(0)>

Example

exp_count_sample

Output

यह निम्न आउटपुट का उत्पादन करता है:

[1.29202967 1.29202967 0.75578891]
<NDArray 3 @cpu(0)>

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

cond = lambda i, s: i <= 7
func = lambda i, s: ([i + s], [i + 1, s + i])
loop_var = (mx.nd.array([0], dtype="int64"), mx.nd.array([1], dtype="int64"))
outputs, states = mx.nd.contrib.while_loop(cond, func, loop_vars, max_iterations=10)
outputs

Output

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

[
[[       1]
 [      2]
 [      4]
 [      7]
 [     11]
 [     16]
 [     22]
 [     29]
 [3152434450384]
 [     257]]
<NDArray 10x1 @cpu(0)>]

Example

States

Output

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

[
[8]
<NDArray 1 @cpu(0)>,
[29]
<NDArray 1 @cpu(0)>]

ndarray.image

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

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

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

समारोह और इसके पैरामीटर परिभाषा
adjust_lighting((डेटा, अल्फा, आउट, नाम]) जैसा कि नाम से ही स्पष्ट है, यह फ़ंक्शन इनपुट के प्रकाश स्तर को समायोजित करता है। यह एलेक्सनेट शैली का अनुसरण करता है।
crop((डेटा, एक्स, वाई, चौड़ाई, ऊंचाई, बाहर, नाम]) इस फ़ंक्शन की सहायता से, हम उपयोगकर्ता द्वारा दिए गए आकार के लिए NDArray की आकृति (H x W x C) या (N x H x W x C) काट सकते हैं।
normalize((डेटा, माध्य, एसटीडी, आउट, नाम]) यह आकार के दसियों (C x H x W) या (N x C x H x W) को सामान्य करेगा mean तथा standard deviation(SD)
random_crop ([डेटा, xrange, yrange, चौड़ाई, ...]) फसल के समान (), यह बेतरतीब ढंग से उपयोगकर्ता द्वारा दिए गए आकार को NDArray की आकृति (H x W x C) या (N x H x W x C) का आकार देता है। यदि परिणाम src आकार से छोटा है, तो यह परिणाम को बेहतर बनाएगा।
random_lighting((डेटा, अल्फ़ा_स्टीडी, आउट, नाम]) जैसा कि नाम से पता चलता है, यह फ़ंक्शन पीसीए शोर को यादृच्छिक रूप से जोड़ता है। यह एलेक्सनेट शैली का अनुसरण भी करता है।
random_resized_crop((डेटा, xrange, yrange,…]) यह दी गई आकृति में बेतरतीब ढंग से NDArray की आकृति (H x W x C) या (N x H x W x C) को भी काटता है। यह परिणाम को खराब कर देगा, अगर src आकार से छोटा है। यह क्षेत्र और पहलू राशन को भी यादृच्छिक करेगा।
resize((डेटा, आकार, Keep_ratio, interp,…]) जैसा कि नाम से पता चलता है, यह फ़ंक्शन उपयोगकर्ता द्वारा दिए गए आकार के आकार (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 x) या (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.nd.random.uniform(0, 255, (4, 2, 3)).astype(dtype=np.uint8)
mx.nd.image.to_tensor(img)

Output

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

[[[0.972549 0.5058824 ]
   [0.6039216 0.01960784]
   [0.28235295 0.35686275]
   [0.11764706 0.8784314 ]]

[[0.8745098 0.9764706 ]
   [0.4509804 0.03529412]
   [0.9764706 0.29411766]
   [0.6862745 0.4117647 ]]

[[0.46666667 0.05490196]
   [0.7372549 0.4392157 ]
   [0.11764706 0.47843137]
   [0.31764707 0.91764706]]]
<NDArray 3x4x2 @cpu(0)>

Example

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

mx.nd.image.to_tensor(img)

Output

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

[[[[0.0627451 0.5647059 ]
[0.2627451 0.9137255 ]
[0.57254905 0.27450982]
[0.6666667 0.64705884]]
[[0.21568628 0.5647059 ]
[0.5058824 0.09019608]
[0.08235294 0.31764707]
[0.8392157 0.7137255 ]]
[[0.6901961 0.8627451 ]
[0.52156866 0.91764706]
[0.9254902 0.00784314]
[0.12941177 0.8392157 ]]]
[[[0.28627452 0.39607844]
[0.01960784 0.36862746]
[0.6745098 0.7019608 ]
[0.9607843 0.7529412 ]]
[[0.2627451 0.58431375]
[0.16470589 0.00392157]
[0.5686275 0.73333335]
[0.43137255 0.57254905]]
[[0.18039216 0.54901963]
[0.827451 0.14509805]
[0.26666668 0.28627452]
[0.24705882 0.39607844]]]]
<NDArgt;ray 2x3x4x2 @cpu(0)>

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

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

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

Output

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

[[[ 0.29391178 0.3218054 ]
[ 0.23084386 0.19615503]
[ 0.24175143 0.21988946]
[ 0.16710812 0.1777354 ]]
[[-0.02195817 -0.3847335 ]
[-0.17800489 -0.30256534]
[-0.28807247 -0.19059572]
[-0.19680339 -0.26256624]]
[[-1.9808068 -1.5298678 ]
[-1.6984252 -1.2839255 ]
[-1.3398265 -1.712009 ]
[-1.7099224 -1.6165378 ]]]
<NDArray 3x4x2 @cpu(0)>

Example

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

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

Output

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

[[[[ 2.0600514e-01 2.4972327e-01]
[ 1.4292289e-01 2.9281738e-01]
[ 4.5158025e-02 3.4287784e-02]
[ 9.9427439e-02 3.0791296e-02]]
[[-2.1501756e-01 -3.2297665e-01]
[-2.0456362e-01 -2.2409186e-01]
[-2.1283737e-01 -4.8318747e-01]
[-1.7339960e-01 -1.5519112e-02]]
[[-1.3478968e+00 -1.6790028e+00]
[-1.5685816e+00 -1.7787373e+00]
[-1.1034534e+00 -1.8587360e+00]
[-1.6324382e+00 -1.9027401e+00]]]
[[[ 1.4528830e-01 3.2801408e-01]
[ 2.9730779e-01 8.6780310e-02]
[ 2.6873133e-01 1.7900752e-01]
[ 2.3462953e-01 1.4930873e-01]]
[[-4.4988656e-01 -4.5021546e-01]
[-4.0258706e-02 -3.2384416e-01]
[-1.4287934e-01 -2.6537544e-01]
[-5.7649612e-04 -7.9429924e-02]]
[[-1.8505517e+00 -1.0953522e+00]
[-1.1318740e+00 -1.9624406e+00]
[-1.8375070e+00 -1.4916846e+00]
[-1.3844404e+00 -1.8331525e+00]]]]
<NDArray 2x3x4x2 @cpu(0)>

ndarray.random

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

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

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

समारोह और इसके पैरामीटर परिभाषा
वर्दी ([कम, उच्च, आकार, dtype, ctx, आउट]) यह एक समान वितरण से यादृच्छिक नमूने उत्पन्न करता है।
सामान्य ([स्थान, पैमाना, आकार, dtype, ctx, out]) यह एक सामान्य (गाऊसी) वितरण से यादृच्छिक नमूने उत्पन्न करता है।
रैंडन (* आकार, ** कंवर) यह एक सामान्य (गाऊसी) वितरण से यादृच्छिक नमूने उत्पन्न करता है।
घातीय ([पैमाने, आकार, 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 ([डेटा, लाम, आउट, नाम]) यह इनपुट सरणी आकार के अनुसार, पॉइसन वितरण से यादृच्छिक नमूने उत्पन्न करता है।
समरूप_रूप ([डेटा, निम्न, उच्च, बाहर, नाम]) यह इनपुट सरणी आकार के अनुसार एक समान वितरण से यादृच्छिक नमूने उत्पन्न करता है।

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

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

mx.nd.random.uniform(0, 1)

Output

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

[0.12381998]
<NDArray 1 @cpu(0)>

Example

mx.nd.random.uniform(-1, 1, shape=(2,))

Output

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

[0.558102 0.69601643]
<NDArray 2 @cpu(0)>

Example

low = mx.nd.array([1,2,3])
high = mx.nd.array([2,3,4])
mx.nd.random.uniform(low, high, shape=2)

Output

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

[[1.8649333 1.8073189]
 [2.4113967 2.5691009]
 [3.1399727 3.4071832]]
<NDArray 3x2 @cpu(0)>

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

mx.nd.random.generalized_negative_binomial(10, 0.5)

Output

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

[1.]
<NDArray 1 @cpu(0)>

Example

mx.nd.random.generalized_negative_binomial(10, 0.5, shape=(2,))

Output

उत्पादन के साथ दी गई है -

[16. 23.]
<NDArray 2 @cpu(0)>

Example

mu = mx.nd.array([1,2,3])
alpha = mx.nd.array([0.2,0.4,0.6])
mx.nd.random.generalized_negative_binomial(mu, alpha, shape=2)

Output

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

[[0. 0.]
 [4. 1.]
 [9. 3.]]
<NDArray 3x2 @cpu(0)>

ndarray.utils

उपयोगिता NDArray API को ndarray.utils पैकेज में परिभाषित किया गया है। जैसा कि नाम से ही स्पष्ट है, यह NDArray और BaseSparseNDArray के लिए उपयोगिता कार्य प्रदान करता है।

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

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

समारोह और इसके पैरामीटर परिभाषा
शून्य (आकृति [, ctx, dtype, stype]) यह फ़ंक्शन शून्य से भरे आकार और प्रकार की एक नई सरणी लौटाएगा।
खाली (आकार [, ctx, dtype, stype]) यह दिए गए आकार और प्रकार का एक नया सरणी लौटाएगा, प्रविष्टियों को शुरू किए बिना।
सरणी (source_array [, ctx, dtype]) जैसा कि नाम से ही स्पष्ट है, यह फ़ंक्शन सरणी इंटरफ़ेस को उजागर करने वाली किसी भी वस्तु से एक सरणी बनाएगा।
लोड (fname) यह फ़ाइल से एक सरणी लोड करेगा।
load_frombuffer (buf) जैसा कि नाम से ही स्पष्ट है, यह फ़ंक्शन किसी बफर से एक सरणी शब्दकोश या सूची लोड करेगा
सहेजें (fname, डेटा) यह फ़ंक्शन एरे की सूची या फाइल करने के लिए str-> सरणी के एक कमांड को बचाएगा।

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

नीचे दिए गए उदाहरण में, हम दिए गए आकार और प्रकार की एक नई सरणी वापस करने जा रहे हैं, जो शून्य से भरा है। इसके लिए, हम फ़ंक्शन का उपयोग करेंगेzeros()

mx.nd.zeros((1,2), mx.cpu(), stype='csr')

Output

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

<CSRNDArray 1x2 @cpu(0)>

Example

mx.nd.zeros((1,2), mx.cpu(), 'float16', stype='row_sparse').asnumpy()

Output

आपको निम्न आउटपुट प्राप्त होंगे -

array([[0., 0.]], dtype=float16)

नीचे दिए गए उदाहरण में, हम सरणियों की एक सूची और तार के एक शब्दकोश को बचाने जा रहे हैं। इसके लिए, हम फ़ंक्शन का उपयोग करेंगेsave()

Example

x = mx.nd.zeros((2,3))
y = mx.nd.ones((1,4))
mx.nd.save('list', [x,y])
mx.nd.save('dict', {'x':x, 'y':y})
mx.nd.load('list')

Output

निष्पादन के बाद, आपको निम्न आउटपुट प्राप्त होंगे -

[
[[0. 0. 0.]
[0. 0. 0.]]
<NDArray 2x3 @cpu(0)>,
[[1. 1. 1. 1.]]
<NDArray 1x4 @cpu(0)>]

Example

mx.nd.load('my_dict')

Output

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

{'x':
[[0. 0. 0.]
[0. 0. 0.]]
<NDArray 2x3 @cpu(0)>, 'y':
[[1. 1. 1. 1.]]
<NDArray 1x4 @cpu(0)>}