DC.js - स्कैटर प्लॉट
स्कैटर प्लॉट एक प्रकार का गणितीय आरेख है। यह डेटा के सेट के लिए आमतौर पर दो चर के लिए मूल्यों को प्रदर्शित करने के लिए कार्टेशियन निर्देशांक का उपयोग करके प्रतिनिधित्व किया जाता है। डेटा को बिंदुओं के संग्रह के रूप में प्रदर्शित किया जाता है और संभवतः रंगीन अंक। यह अध्याय विस्तार से बिखराव की साजिश के बारे में बताता है।
स्कैटर प्लॉट मेथड्स
बिखराव की साजिश को आगे बढ़ाने से पहले हमें समझना चाहिए dc.scatterPlotक्लास और उसके तरीके। Dc.scatterPlot किसी चार्ट को आरेखित करने की बुनियादी कार्यक्षमता प्राप्त करने के लिए मिश्रण का उपयोग करता है। Dc.scatterPlot द्वारा उपयोग किए गए मिश्रण को नीचे दिया गया है -
- dc.coordinateGridMixin
Dc.scatterPlot का पूरा वर्ग चित्र इस प्रकार है -
Dc.scatterPlot को उपरोक्त निर्दिष्ट मिश्रणों के सभी तरीके मिलते हैं। तितर बितर भूखंड को खींचने के लिए इसकी अपनी विधियां हैं, जिन्हें निम्नानुसार समझाया गया है।
रिवाज का प्रतीक ([प्रतीक])
इस पद्धति का उपयोग प्रतीक जनरेटर को प्राप्त करने या सेट करने के लिए किया जाता है।
खाली करें ([आकार])
समूह खाली होने पर प्रतीकों के लिए त्रिज्या सेट करने या प्राप्त करने के लिए इस पद्धति का उपयोग किया जाता है।
बहिष्कृत रंग ([रंग])
इस पद्धति का उपयोग चार्ट के फिल्टर से बाहर किए गए प्रतीकों के लिए रंग प्राप्त करने या सेट करने के लिए किया जाता है।
अपवर्जितता ([अस्पष्टता))
इस पद्धति का उपयोग चार्ट के फ़िल्टर से बाहर किए गए प्रतीकों के लिए अस्पष्टता प्राप्त करने या सेट करने के लिए किया जाता है।
बहिष्कृत (आकार)
इसका उपयोग चार्ट के फ़िल्टर से बाहर किए गए प्रतीकों के लिए सेट या आकार प्राप्त करने के लिए किया जाता है।
हाइलाइट किए गए आकार ([आकार])
इसका उपयोग हाइलाइट किए गए प्रतीकों के लिए त्रिज्या सेट या प्राप्त करने के लिए किया जाता है।
प्रतीक ([प्रकार])
इसका उपयोग प्रत्येक बिंदु के लिए उपयोग किए जाने वाले प्रतीक प्रकार को प्राप्त करने या सेट करने के लिए किया जाता है।
स्कैटर प्लॉट ड्रा करें
हमें डीसी में एक तितर बितर साजिश आकर्षित करते हैं। इस उदाहरण में, हम एक डाटासेट नाम लेते हैंhowell1.csvफ़ाइल। नमूना डेटा फ़ाइल निम्नानुसार है -
"height","weight","age","male"
151.765,47.8256065,63,1
139.7,36.4858065,63,0
136.525,31.864838,65,0
156.845,53.0419145,41,1
145.415,41.276872,51,0
163.83,62.992589,35,1
149.225,38.2434755,32,0
168.91,55.4799715,27,1
147.955,34.869885,19,0
165.1,54.487739,54,1
154.305,49.89512,47,0
...............
...............
उपरोक्त नमूना फ़ाइल में कई रिकॉर्ड हैं। हम निम्न लिंक पर क्लिक करके और इसे अपने डीसी स्थान पर सहेजकर फ़ाइल डाउनलोड कर सकते हैं।
howell1.csv
अब, डीसी में एक स्कैटर चार्ट बनाने के लिए बाद के चरणों का पालन करें।
चरण 1: एक चर को परिभाषित करें
नीचे दिखाए गए अनुसार एक चर को परिभाषित करते हैं -
var chart = dc.scatterPlot('#scatter');
यहाँ, स्कैडप्लॉट () फ़ंक्शन को आईडी स्कैटर के साथ मैप किया जाता है।
चरण 2: डेटा पढ़ें
नीचे दिखाए अनुसार Howell1.csv फ़ाइल से डेटा पढ़ें -
d3.csv("data/howell1.csv", function(errors, people) {
var mycrossfilter = crossfilter(people);
}
यदि डेटा मौजूद नहीं है, तो यह एक त्रुटि देता है। बाद में, डेटा को क्रॉसफ़िल्टर को असाइन करें।
चरण 3: रिकॉर्ड प्राप्त करें
आइए नीचे दिए गए कोडिंग का उपयोग करके रिकॉर्ड प्राप्त करें -
people.forEach(function(x) {
if(x.male == 1) {
x.gender = "Male";
} else {
x.gender = "Female";
}
});
यहां, हमने लिंग की जांच की है।
चरण 4: आयाम सेट करें
आप नीचे दिए गए कोडिंग का उपयोग करके आयाम सेट कर सकते हैं -
var hwDimension = mycrossfilter.dimension(function(data) {
return [Math.floor(data.height), Math.floor(data.weight)];
});
आयाम दिए जाने के बाद, नीचे दिए गए कोडिंग का उपयोग करके लिंग को समूहित करें -
var hwGroup = hwDimension.group().reduceCount();
चरण 5: एक चार्ट बनाएं
अब, नीचे दिए गए कोडिंग का उपयोग करके एक हीटमैप उत्पन्न करें -
chart
.width(800)
.height(600)
.x(d3.scale.linear().domain([0,180]))
.y(d3.scale.linear().domain([0,100]))
.brushOn(false)
.xAxisLabel("Height")
.yAxisLabel("Weight")
.symbolSize(8)
.clipPadding(10)
.dimension(hwDimension)
.group(hwGroup);
यहाँ,
- हमने चार्ट की चौड़ाई 800 और ऊंचाई 600 के रूप में दी है।
- एक्स और वाई अक्ष दोनों के लिए d3.scale.linear () फ़ंक्शन को लागू किया।
- झूठे के रूप में सक्षम ब्रशऑन मान।
- फिर, वजन के रूप में ऊंचाई और y- अक्ष लेबल के रूप में एक्स-अक्ष लेबल सौंपा।
- प्रतीक का आकार आठ और पैडिंग मान 10 के रूप में सेट करें।
- अंत में, डेटा समूह और चार्ट प्रस्तुत करना।
चरण 6: काम करने का उदाहरण
पूरी कोड सूची इस प्रकार है। एक वेब पेज बनाएँscatter.html और इसमें निम्नलिखित परिवर्तन जोड़ें।
<html>
<head>
<title>Scatter plot Sample</title>
<link rel = "stylesheet" type = "text/css" href = "css/bootstrap.css">
<link rel = "stylesheet" type = "text/css" href = "css/dc.css"/>
<script src = "js/d3.js"></script>
<script src = "js/crossfilter.js"></script>
<script src = "js/dc.js"></script>
</head>
<body>
<div>
<div id = "scatter"></div>
</div>
<script language = "javascript">
var chart = dc.scatterPlot('#scatter');
d3.csv("data/howell1.csv", function(errors, people) {
var mycrossfilter = crossfilter(people);
people.forEach(function(x) {
if(x.male == 1) {
x.gender = "Male";
} else {
x.gender = "Female";
}
});
var hwDimension = mycrossfilter.dimension(function(data) {
return [Math.floor(data.height), Math.floor(data.weight)];
});
var hwGroup = hwDimension.group().reduceCount();
chart
.width(800)
.height(600)
.x(d3.scale.linear().domain([0,180]))
.y(d3.scale.linear().domain([0,100]))
.brushOn(false)
.xAxisLabel("Height")
.yAxisLabel("Weight")
.symbolSize(8)
.clipPadding(10)
.dimension(hwDimension)
.group(hwGroup);
chart.render();
});
</script>
</body>
</html>
अब, ब्राउज़र का अनुरोध करें और हम निम्नलिखित प्रतिक्रिया देखेंगे।