अपाचे एमएक्सनेट - केवीस्टोर और विज़ुअलाइज़ेशन

यह अध्याय अजगर संकुल KVStore और विज़ुअलाइज़ेशन से संबंधित है।

KVStore पैकेज

KV स्टोर की-वैल्यू स्टोर के लिए है। यह मल्टी-डिवाइस प्रशिक्षण के लिए उपयोग किया जाने वाला महत्वपूर्ण घटक है। यह महत्वपूर्ण है क्योंकि, मापदंडों के लिए केवीस्टोर के साथ एक या एक से अधिक सर्वरों के माध्यम से एकल और साथ ही कई मशीनों के पार उपकरणों के मापदंडों का संचार होता है।

आइए हम निम्नलिखित बिंदुओं की सहायता से KVStore के कार्य को समझते हैं:

  • KVStore में प्रत्येक मान a द्वारा दर्शाया गया है key और एक value

  • नेटवर्क में प्रत्येक पैरामीटर सरणी को असाइन किया गया है a key और उस पैरामीटर सरणी का वजन द्वारा संदर्भित किया जाता है value

  • उसके बाद, कार्यकर्ता नोड करता है pushएक बैच के प्रसंस्करण के बाद ढाल। वे भीpull नए बैच को संसाधित करने से पहले अद्यतन किए गए वज़न।

सरल शब्दों में, हम कह सकते हैं कि KVStore डेटा शेयरिंग के लिए एक जगह है, जहाँ प्रत्येक डिवाइस डेटा को पुश कर सकता है और डेटा को बाहर निकाल सकता है।

डेटा पुश-इन और पुल-आउट

KVStore को विभिन्न उपकरणों जैसे जीपीयू और कंप्यूटर पर साझा की गई एकल वस्तु के रूप में सोचा जा सकता है, जहां प्रत्येक डिवाइस डेटा को पुश करने और डेटा को बाहर निकालने में सक्षम है।

निम्नलिखित कार्यान्वयन कदम हैं जिन्हें डेटा को पुश करने और डेटा को बाहर निकालने के लिए उपकरणों द्वारा अनुसरण किया जाना चाहिए:

कार्यान्वयन के कदम

Initialisation- मूल्यों को इनिशियलाइज़ करने के लिए पहला कदम है। हमारे उदाहरण के लिए, हम KVStrore में एक जोड़ी (int, NDArray) जोड़ी की शुरुआत करेंगे और उसके बाद मानों को बाहर निकालेंगे -

import mxnet as mx
kv = mx.kv.create('local') # create a local KVStore.
shape = (3,3)
kv.init(3, mx.nd.ones(shape)*2)
a = mx.nd.zeros(shape)
kv.pull(3, out = a)
print(a.asnumpy())

Output

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

[[2. 2. 2.]
[2. 2. 2.]
[2. 2. 2.]]

Push, Aggregate, and Update - एक बार शुरू होने के बाद, हम कुंजी के समान आकार के साथ KVStore में एक नया मान बढ़ा सकते हैं -

kv.push(3, mx.nd.ones(shape)*8)
kv.pull(3, out = a)
print(a.asnumpy())

Output

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

[[8. 8. 8.]
 [8. 8. 8.]
 [8. 8. 8.]]

पुश करने के लिए उपयोग किए जाने वाले डेटा को किसी भी उपकरण जैसे GPU या कंप्यूटर पर संग्रहीत किया जा सकता है। हम एक ही कुंजी में कई मानों को आगे बढ़ा सकते हैं। इस स्थिति में, KVStore पहले इन सभी मानों को जोड़ देगा और फिर निम्न मान को निम्नानुसार धकेल देगा -

contexts = [mx.cpu(i) for i in range(4)]
b = [mx.nd.ones(shape, ctx) for ctx in contexts]
kv.push(3, b)
kv.pull(3, out = a)
print(a.asnumpy())

Output

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

[[4. 4. 4.]
 [4. 4. 4.]
 [4. 4. 4.]]

आपके द्वारा लागू किए गए प्रत्येक पुश के लिए, KVStore पहले से संग्रहीत मूल्य के साथ धक्का दिए गए मूल्य को संयोजित करेगा। इसे अपडेटर की मदद से किया जाएगा। यहां, डिफ़ॉल्ट अपडेटर ASSIGN है।

def update(key, input, stored):
   print("update on key: %d" % key)
   
   stored += input * 2
kv.set_updater(update)
kv.pull(3, out=a)
print(a.asnumpy())

Output

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

[[4. 4. 4.]
 [4. 4. 4.]
 [4. 4. 4.]]

Example

kv.push(3, mx.nd.ones(shape))
kv.pull(3, out=a)
print(a.asnumpy())

Output

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

update on key: 3
[[6. 6. 6.]
 [6. 6. 6.]
 [6. 6. 6.]]

Pull - पुश की तरह, हम भी एक कॉल के साथ कई उपकरणों पर मूल्य खींच सकते हैं -

b = [mx.nd.ones(shape, ctx) for ctx in contexts]
kv.pull(3, out = b)
print(b[1].asnumpy())

Output

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

[[6. 6. 6.]
 [6. 6. 6.]
 [6. 6. 6.]]

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

नीचे दिया गया पूरा कार्यान्वयन उदाहरण है -

import mxnet as mx
kv = mx.kv.create('local')
shape = (3,3)
kv.init(3, mx.nd.ones(shape)*2)
a = mx.nd.zeros(shape)
kv.pull(3, out = a)
print(a.asnumpy())
kv.push(3, mx.nd.ones(shape)*8)
kv.pull(3, out = a) # pull out the value
print(a.asnumpy())
contexts = [mx.cpu(i) for i in range(4)]
b = [mx.nd.ones(shape, ctx) for ctx in contexts]
kv.push(3, b)
kv.pull(3, out = a)
print(a.asnumpy())
def update(key, input, stored):
   print("update on key: %d" % key)
   stored += input * 2
kv._set_updater(update)
kv.pull(3, out=a)
print(a.asnumpy())
kv.push(3, mx.nd.ones(shape))
kv.pull(3, out=a)
print(a.asnumpy())
b = [mx.nd.ones(shape, ctx) for ctx in contexts]
kv.pull(3, out = b)
print(b[1].asnumpy())

कुंजी-मूल्य जोड़े को संभालना

हमारे द्वारा ऊपर लागू किए गए सभी कार्यों में एक एकल कुंजी शामिल है, लेकिन KVStore इसके लिए एक इंटरफ़ेस भी प्रदान करता है a list of key-value pairs -

एक उपकरण के लिए

एक उपकरण के लिए कुंजी-मूल्य जोड़े की सूची के लिए KVStore इंटरफ़ेस दिखाने के लिए निम्नलिखित उदाहरण है -

keys = [5, 7, 9]
kv.init(keys, [mx.nd.ones(shape)]*len(keys))
kv.push(keys, [mx.nd.ones(shape)]*len(keys))
b = [mx.nd.zeros(shape)]*len(keys)
kv.pull(keys, out = b)
print(b[1].asnumpy())

Output

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

update on key: 5
update on key: 7
update on key: 9
[[3. 3. 3.]
 [3. 3. 3.]
 [3. 3. 3.]]

कई डिवाइस के लिए

कई डिवाइस के लिए की-वैल्यू पेयर की सूची के लिए KVStore इंटरफ़ेस दिखाने के लिए निम्नलिखित उदाहरण है -

b = [[mx.nd.ones(shape, ctx) for ctx in contexts]] * len(keys)
kv.push(keys, b)
kv.pull(keys, out = b)
print(b[1][1].asnumpy())

Output

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

update on key: 5
update on key: 7
update on key: 9
[[11. 11. 11.]
 [11. 11. 11.]
 [11. 11. 11.]]

दृश्य पैकेज

विज़ुअलाइज़ेशन पैकेज अपाचे एमएक्सनेट पैकेज है जिसका उपयोग तंत्रिका नेटवर्क (एनएन) को एक कम्प्यूटेशन ग्राफ के रूप में दर्शाया जाता है जिसमें नोड्स और किनारों होते हैं।

तंत्रिका नेटवर्क कल्पना

नीचे दिए गए उदाहरण में हम उपयोग करेंगे mx.viz.plot_networkतंत्रिका नेटवर्क की कल्पना करना। इसके लिए अनुवर्ती शर्तें हैं -

Prerequisites

  • ज्यूपिटर नोटबुक

  • ग्राफविज़ लाइब्रेरी

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

नीचे दिए गए उदाहरण में हम रेखीय मैट्रिक्स कारक के लिए एक नमूना NN की कल्पना करेंगे -

import mxnet as mx
user = mx.symbol.Variable('user')
item = mx.symbol.Variable('item')
score = mx.symbol.Variable('score')

# Set the dummy dimensions
k = 64
max_user = 100
max_item = 50

# The user feature lookup
user = mx.symbol.Embedding(data = user, input_dim = max_user, output_dim = k)

# The item feature lookup
item = mx.symbol.Embedding(data = item, input_dim = max_item, output_dim = k)

# predict by the inner product and then do sum
N_net = user * item
N_net = mx.symbol.sum_axis(data = N_net, axis = 1)
N_net = mx.symbol.Flatten(data = N_net)

# Defining the loss layer
N_net = mx.symbol.LinearRegressionOutput(data = N_net, label = score)

# Visualize the network
mx.viz.plot_network(N_net)