अपाचे एमएक्सनेट - केवीस्टोर और विज़ुअलाइज़ेशन
यह अध्याय अजगर संकुल 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)