डी 3.जेएस - एरे एपीआई
डी 3 में मॉड्यूल का संग्रह होता है। आप प्रत्येक मॉड्यूल को स्वतंत्र रूप से या संचालन करने के लिए एक साथ मॉड्यूल के संग्रह का उपयोग कर सकते हैं। यह अध्याय एरे एपीआई के बारे में विस्तार से बताता है।
एक ऐरे क्या है?
एक सरणी में एक ही प्रकार के तत्वों का एक निश्चित आकार का अनुक्रमिक संग्रह होता है। एक सरणी का उपयोग डेटा के संग्रह को संग्रहीत करने के लिए किया जाता है, लेकिन एक सरणी के समान प्रकार के संग्रह के रूप में सरणी के बारे में सोचना अक्सर अधिक उपयोगी होता है।
API को कॉन्फ़िगर करना
आप नीचे दी गई स्क्रिप्ट का उपयोग करके आसानी से एपीआई को कॉन्फ़िगर कर सकते हैं।
<script src = "https://d3js.org/d3-array.v1.min.js"></script>
<body>
<script>
</script>
</body>
एरे स्टेटिस्टिक्स एपीआई तरीके
निम्नलिखित कुछ सबसे महत्वपूर्ण सरणी आँकड़े API विधियाँ हैं।
- d3.min(array)
- d3.max(array)
- d3.extent(array)
- d3.sum(array)
- d3.mean(array)
- d3.quantile(array)
- d3.variance(array)
- d3.deviation(array)
आइए हम इनमें से प्रत्येक पर विस्तार से चर्चा करें।
d3.min (सरणी)
यह दिए गए सरणी में प्राकृतिक क्रम का उपयोग करके न्यूनतम मान लौटाता है।
Example - निम्नलिखित स्क्रिप्ट पर विचार करें।
<script>
var data = [20,40,60,80,100];
console.log(d3.min(data));
</script>
Result - उपरोक्त स्क्रिप्ट आपके कंसोल में सरणी 20 में माइनम मान लौटाता है।
d3.max (सरणी)
यह किसी दिए गए सरणी में अधिकतम मान लौटाता है।
Example - निम्नलिखित स्क्रिप्ट पर विचार करें।
<script>
var data = [20,40,60,80,100];
console.log(d3.max(data));
</script>
Result - उपरोक्त स्क्रिप्ट आपके कंसोल में सरणी (100) में अधिकतम मान लौटाता है।
d3.extent (सरणी)
यह दिए गए एरे में न्यूनतम और अधिकतम मान देता है।
Example - निम्नलिखित स्क्रिप्ट पर विचार करें।
<script>
var data = [20,40,60,80,100];
console.log(d3.extent(data));
</script>
Result - उपर्युक्त स्क्रिप्ट में एक सीमा मान [20,100] है।
d3.sum (सरणी)
यह दी गई संख्याओं की संख्या का योग देता है। यदि सरणी खाली है, तो यह 0 देता है।
Example - नीचे दिए गए पर विचार करें।
<script>
var data = [20,40,60,80,100];
console.log(d3.sum(data));
</script>
Result - उपरोक्त लिपि का मान 300 है।
d3.mean (सरणी)
यह दी गई संख्याओं के माध्य को लौटाता है।
Example - नीचे दिए गए पर विचार करें।
<script>
var data = [20,40,60,80,100];
console.log(d3.mean(data));
</script>
Result - उपरोक्त स्क्रिप्ट 60 के रूप में माध्य मान लौटाता है। इसी तरह, आप माध्य मूल्य की जांच कर सकते हैं।
d3.quantile (सरणी)
यह संख्याओं के दिए गए क्रमबद्ध सरणी के p-quantile को लौटाता है, जहाँ p श्रेणी [0, 1] में एक संख्या है। उदाहरण के लिए, माध्यिका p = 0.5 का उपयोग करके गणना की जा सकती है, पहला चतुर्थक p = 0.25 पर और तीसरा चतुर्थक p = 0.75 पर। यह कार्यान्वयन R-7 विधि, डिफ़ॉल्ट R प्रोग्रामिंग भाषा और Excel का उपयोग करता है।
Example - निम्नलिखित उदाहरण पर विचार करें।
var data = [20, 40, 60, 80, 100];
d3.quantile(data, 0); // output is 20
d3.quantile(data, 0.5); // output is 60
d3.quantile(data, 1); // output is 100
इसी तरह, आप अन्य मूल्यों की जांच कर सकते हैं।
d3.variance (सरणी)
यह दी गई संख्याओं की भिन्नता को देता है।
Example - निम्नलिखित स्क्रिप्ट पर विचार करें।
<script>
var data = [20,40,60,80,100];
console.log(d3.variance(data));
</script>
Result - उपरोक्त स्क्रिप्ट 1000 के रूप में विचरण मान लौटाती है।
d3.deviation (सरणी)
यह दिए गए ऐरे का मानक विचलन लौटाता है। यदि सरणी में दो से कम मान हैं, तो यह अपरिभाषित के रूप में लौटता है।
Example - नीचे दिए गए पर विचार करें।
<script>
var data = [20,40,60,80,100];
console.log(d3.deviation(data));
</script>
Result - उपर्युक्त स्क्रिप्ट 31.622776601683793 के रूप में विचलन मान लौटाती है।
Example- निम्नलिखित स्क्रिप्ट का उपयोग करके ऊपर चर्चा की गई सभी ऐरे एपीआई विधियों का प्रदर्शन करते हैं। एक वेबपेज "array.html" बनाएं और उसमें निम्न परिवर्तन जोड़ें।
<html>
<head>
<script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
</head>
<body>
<h3>D3 array API</h3>
<script>
var data = [20,40,60,80,100];
console.log(d3.min(data));
console.log(d3.max(data));
console.log(d3.extent(data));
console.log(d3.sum(data));
console.log(d3.mean(data));
console.log(d3.quantile(data,0.5));
console.log(d3.variance(data));
console.log(d3.deviation(data));
</script>
</body>
</html>
अब, ब्राउज़र का अनुरोध करें और हम निम्नलिखित प्रतिक्रिया देखेंगे।
ऐरे खोज एपीआई तरीके
निम्नलिखित कुछ महत्वपूर्ण ऐरे खोज एपीआई तरीके हैं।
- d3.scan(array)
- d3.ascending (ए, बी)
आइये इन दोनों को विस्तार से समझते हैं।
d3.scan (सरणी)
इस पद्धति का उपयोग निर्दिष्ट सरणी के रैखिक स्कैन को करने के लिए किया जाता है। यह निर्दिष्ट तुलनित्र के लिए सबसे कम तत्व का सूचकांक देता है। एक सरल उदाहरण नीचे परिभाषित किया गया है।
Example -
var array = [{one: 1}, {one: 10}];
console.log(d3.scan(array, function(a, b) { return a.one - b.one; })); // output is 0
console.log(d3.scan(array, function(a, b) { return b.one - a.one; })); // output is 1
d3.ascending (ए, बी)
इस विधि का उपयोग तुलनित्र कार्य करने के लिए किया जाता है। इसे इस प्रकार लागू किया जा सकता है -
function ascending(a, b) {
return a < b ? -1 : a > b ? 1 : a > = b ? 0 : NaN;
}
यदि कोई तुलनित्र फ़ंक्शन अंतर्निहित सॉर्ट विधि के लिए निर्दिष्ट नहीं है, तो डिफ़ॉल्ट क्रम वर्णानुक्रम है। उपरोक्त फ़ंक्शन -1 देता है, यदि a, b से कम है या 1, यदि a, b से अधिक है, या 0 है।
इसी तरह, आप अवरोही (ए, बी) विधि कर सकते हैं। यह -1 लौटाता है, यदि a, b से अधिक है, या 1, यदि a, b से कम है, या 0. यह फ़ंक्शन रिवर्स प्राकृतिक क्रम करता है।
Example -
एक वेबपेज बनाएं array_search.html और इसमें निम्नलिखित परिवर्तन जोड़ें।
<html>
<head>
<script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
</head>
<body>
<h3>D3 array API</h3>
<script>
var array = [{one: 1}, {one: 10}];
console.log(d3.scan(array, function(a, b) { return a.one - b.one; })); // 0
console.log(d3.scan(array, function(a, b) { return b.one - a.one; })); // 1
</script>
</body>
</html>
अब, ब्राउज़र का अनुरोध करें और हम निम्नलिखित परिणाम देखेंगे।
एरे ट्रांसफॉर्मेशन एपीआई
निम्नलिखित कुछ सबसे प्रमुख सरणी रूपांतरण एपीआई तरीके हैं।
- d3.cross (a, b [, reducer])
- d3.merge(arrays)
- d3. जोड़े (सरणी [, reducer])
- d3.permute (सरणी, अनुक्रमणिका)
- d3.zip(arrays)
आइए हम इनमें से प्रत्येक को विस्तार से समझें।
d3.cross (a, b [, reducer])
इस पद्धति का उपयोग दिए गए दो सरणियों ए और बी के कार्टेशियन उत्पाद को वापस करने के लिए किया जाता है। एक सरल उदाहरण नीचे परिभाषित किया गया है।
d3.cross([10, 20], ["a", "b"]); // output is [[10, "a"], [10, "b"], [20, "a"], [20, "b"]]
d3.merge (सरणियों)
इस पद्धति का उपयोग सरणियों को मर्ज करने के लिए किया जाता है और इसे नीचे परिभाषित किया गया है।
d3.merge([[10], [20]]); // output is [10, 20]
d3. जोड़े (सरणी [, reducer])
इस पद्धति का उपयोग सरणी तत्वों को जोड़ने के लिए किया जाता है और नीचे परिभाषित किया गया है।
d3.pairs([10, 20, 30, 40]); // output is [[10, 20], [20, 30], [30, 40]]
d3.permute (सरणी, अनुक्रमणिका)
इस पद्धति का उपयोग निर्दिष्ट सरणी और अनुक्रमित से क्रमांकन करने के लिए किया जाता है। आप किसी ऑब्जेक्ट से किसी सरणी में मान भी कर सकते हैं। इसे नीचे समझाया गया है।
var object = {fruit:"mango", color: "yellow"},
fields = ["fruit", "color"];
d3.permute(object, fields); // output is "mango" "yellow"
d3.zip (सरणियों)
इस पद्धति का उपयोग सारणियों के एक सरणी को लौटाने के लिए किया जाता है। यदि सरणियों में केवल एक सरणी होती है, तो दिए गए सरणी में एक-तत्व सरणियाँ होती हैं। यदि कोई तर्क निर्दिष्ट नहीं है, तो लौटा हुआ सरणी खाली है। इसे नीचे परिभाषित किया गया है।
d3.zip([10, 20], [30, 40]); // output is [[10, 30], [20, 40]]
Example - एक वेबपेज बनाएं array_transform और इसमें निम्नलिखित परिवर्तन जोड़ें।
<html>
<head>
<script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
</head>
<body>
<h3>D3 array API</h3>
<script>
console.log(d3.cross([10, 20], ["a", "b"]));
console.log(d3.merge([[10], [30]]));
console.log(d3.pairs([10, 20, 30, 40]));
var object = {fruit:"mango", color: "yellow"},
fields = ["fruit", "color"];
console.log(d3.permute(object, fields));
console.log(d3.zip([10, 20], [30, 40]));
</script>
</body>
</html>
अब, ब्राउज़र का अनुरोध करें और हम निम्नलिखित प्रतिक्रिया देखेंगे।