ggplot2 - त्वरित गाइड
ggplot2 एक R पैकेज है जो विशेष रूप से डेटा विज़ुअलाइज़ेशन और सर्वश्रेष्ठ खोज डेटा विश्लेषण प्रदान करने के लिए डिज़ाइन किया गया है। यह सुंदर, परेशानी मुक्त भूखंड प्रदान करता है जो किंवदंतियों को चित्रित करने और उनका प्रतिनिधित्व करने जैसे मिनट विवरणों का ध्यान रखता है। भूखंडों को पुनरावृति से बनाया जा सकता है और बाद में संपादित किया जा सकता है। यह पैकेज एक स्तरित फैशन में काम करने के लिए डिज़ाइन किया गया है, आर के साथ खोजपूर्ण डेटा विश्लेषण के दौरान एकत्र किए गए कच्चे डेटा को दिखाने वाली एक परत के साथ शुरू होता है, फिर एनोटेशन और सांख्यिकीय सारांश की परतों को जोड़ना।
यहां तक कि सबसे अनुभवी आर उपयोगकर्ताओं को सुरुचिपूर्ण ग्राफिक्स बनाने के लिए मदद की आवश्यकता है। यह पुस्तकालय आर में ग्राफिक्स बनाने के लिए एक अभूतपूर्व उपकरण है, लेकिन लगभग दैनिक उपयोग के कई वर्षों के बाद भी हमें अपनी चीट शीट को संदर्भित करने की आवश्यकता है।
यह पैकेज गहरे व्याकरण के तहत काम करता है जिसे "ग्राफिक्स का व्याकरण" कहा जाता है, जो स्वतंत्र घटकों के एक सेट से बना होता है जिसे कई तरीकों से बनाया जा सकता है। "ग्राफिक्स का व्याकरण" एकमात्र एकमात्र कारण है जो ggplot2 को बहुत शक्तिशाली बनाता है क्योंकि R डेवलपर पूर्व-निर्दिष्ट ग्राफिक्स के सेट तक सीमित नहीं है जो अन्य पैकेज में उपयोग किया जाता है। व्याकरण में मुख्य नियमों और सिद्धांतों का सरल सेट शामिल है।
वर्ष 2005 में, विल्किंसन ने गहन विशेषताओं का वर्णन करने के लिए ग्राफिक्स के व्याकरण की अवधारणा बनाई या बल्कि उत्पन्न की, जो सभी सांख्यिकीय ग्राफिक्स के बीच शामिल है। यह परतों के प्राथमिक पर केंद्रित है जिसमें आर के साथ एम्बेडेड विशेषताओं को शामिल करना शामिल है।
"ग्राफिक्स के व्याकरण" और आर के बीच संबंध
यह उपयोगकर्ता या डेवलपर को बताता है कि सांख्यिकीय विशेषताओं, जैसे रंग, आकृति, आकार के आकार, संबंधित ज्यामितीय वस्तुओं जैसे बिंदुओं, रेखाओं और बार के डेटा को मैप करने के लिए एक सांख्यिकीय ग्राफ़िक का उपयोग किया जाता है। प्लॉट में संबंधित डेटा के विभिन्न सांख्यिकीय रूपांतरण भी हो सकते हैं जो उल्लेखित समन्वय प्रणाली पर खींचा गया है। इसमें "सुविधा" नाम की एक सुविधा भी शामिल है, जिसका उपयोग आम तौर पर उल्लेखित डेटासेट के विभिन्न सबसेट के लिए एक ही प्लॉट बनाने के लिए किया जाता है। विभिन्न अंतर्निर्मित डेटासेट में R शामिल है। इन स्वतंत्र घटकों के संयोजन में पूरी तरह से एक विशेष ग्राफिक शामिल है।
अब हम विभिन्न प्रकार के भूखंडों पर ध्यान केंद्रित करते हैं जिन्हें व्याकरण के संदर्भ में बनाया जा सकता है -
डेटा
यदि उपयोगकर्ता सौंदर्य मैपिंग के दिए गए सेट की कल्पना करना चाहता है, जो बताता है कि मैप किए गए सौंदर्य विशेषताओं के निर्माण के लिए डेटा में आवश्यक चर एक साथ मैप किए गए हैं।
परतों
यह ज्यामितीय तत्वों और आवश्यक सांख्यिकीय परिवर्तन से बना है। लेयर्स में जियोमेट्रिक ऑब्जेक्ट्स, शॉर्ट डेटा के लिए जूम शामिल होते हैं जो वास्तव में बिंदुओं, रेखाओं, बहुभुजों और कई और अधिक की मदद से प्लॉट का प्रतिनिधित्व करते हैं। सबसे अच्छा प्रदर्शन एक विशिष्ट रैखिक मॉडल के 2 डी रिश्ते को सारांशित करने के लिए विशिष्ट हिस्टोग्राम बनाने के लिए टिप्पणियों को गिन और गिन रहा है।
तराजू
स्केल का उपयोग डेटा स्पेस में मूल्यों को मैप करने के लिए किया जाता है जो कि मूल्यों के निर्माण के लिए उपयोग किया जाता है चाहे वह रंग, आकार और आकार हो। यह एक किंवदंती या कुल्हाड़ियों को खींचने में मदद करता है, जो उल्लिखित भूखंड से मूल डेटा मूल्यों को पढ़ने के लिए एक उलटा मानचित्रण प्रदान करने के लिए आवश्यक है।
समन्वय प्रणाली
यह वर्णन करता है कि ग्राफिक के उल्लिखित विमान में डेटा निर्देशांक को एक साथ मैप कैसे किया जाता है। यह उन अक्षों और ग्रिडलाइन्स की जानकारी भी प्रदान करता है जिनकी आवश्यकता ग्राफ को पढ़ने के लिए होती है। आम तौर पर इसका उपयोग कार्टेशियन समन्वय प्रणाली के रूप में किया जाता है जिसमें ध्रुवीय निर्देशांक और मानचित्र अनुमान शामिल होते हैं।
faceting
इसमें यह आवश्यक है कि डेटा को आवश्यक सबसेट में कैसे विभाजित किया जाए और सबसेट को डेटा के गुणक के रूप में प्रदर्शित किया जाए। इसे कंडीशनिंग या लैटिसिंग प्रक्रिया भी कहा जाता है।
विषय
यह फ़ॉन्ट आकार और पृष्ठभूमि रंग गुणों की तरह प्रदर्शन के महीन बिंदुओं को नियंत्रित करता है। एक आकर्षक भूखंड बनाने के लिए, संदर्भों पर विचार करना हमेशा बेहतर होता है।
अब, उन सीमाओं या विशेषताओं पर चर्चा करना भी उतना ही महत्वपूर्ण है जो व्याकरण प्रदान नहीं करता है -
इसमें सुझाव का अभाव है कि किस ग्राफिक्स का उपयोग किया जाना चाहिए या एक उपयोगकर्ता को ऐसा करने में रुचि है।
यह अन्तरक्रियाशीलता का वर्णन नहीं करता है क्योंकि इसमें केवल स्थैतिक ग्राफिक्स का वर्णन शामिल है। गतिशील ग्राफिक्स के निर्माण के लिए अन्य वैकल्पिक समाधान लागू किया जाना चाहिए।
Ggplot2 के साथ बनाया गया सरल ग्राफ नीचे उल्लिखित है -
आर पैकेज विभिन्न क्षमताओं के साथ आते हैं जैसे कि सांख्यिकीय जानकारी का विश्लेषण करना या भू-स्थानिक डेटा की गहराई से अनुसंधान करना या सरल हम बुनियादी रिपोर्ट बना सकते हैं।
R के पैकेजों को एक अच्छी तरह से परिभाषित प्रारूप में R फ़ंक्शन, डेटा और संकलित कोड के रूप में परिभाषित किया जा सकता है। वह फ़ोल्डर या निर्देशिका जहाँ संकुल संग्रहीत किया जाता है उसे पुस्तकालय कहा जाता है।
जैसा कि उपरोक्त आकृति में दिखाई दे रहा है, libPaths () वह फ़ंक्शन है जो आपको लाइब्रेरी दिखाता है जो स्थित है, और फ़ंक्शन लाइब्रेरी उन पैकेजों को दिखाता है जो लाइब्रेरी में सहेजे गए हैं।
आर में कई फ़ंक्शन शामिल हैं जो पैकेजों में हेरफेर करते हैं। हम तीन प्रमुख कार्यों पर ध्यान केंद्रित करेंगे जो मुख्य रूप से उपयोग किए जाते हैं, वे हैं -
- पैकेज स्थापित कर रहा है
- पैकेज लोड हो रहा है
- पैकेज के बारे में सीखना
R में एक पैकेज स्थापित करने के लिए फ़ंक्शन के साथ सिंटैक्स है -
Install.packages(“<package-name>”)
पैकेज स्थापित करने का सरल प्रदर्शन नीचे दिखाई दे रहा है। विचार करें कि हमें पैकेज "ggplot2" स्थापित करने की आवश्यकता है जो डेटा विज़ुअलाइज़ेशन लाइब्रेरी है, निम्नलिखित सिंटैक्स का उपयोग किया जाता है -
Install.packages(“ggplot2”)
विशेष पैकेज को लोड करने के लिए, हमें नीचे दिए गए सिंटैक्स का पालन करना होगा -
Library(<package-name>)
नीचे बताए अनुसार ggplot2 के लिए भी यही लागू होता है -
library(“ggplot2”)
आउटपुट नीचे स्नैपशॉट में दर्शाया गया है -
आवश्यक पैकेज और बुनियादी कार्यक्षमता की आवश्यकता को समझने के लिए, आर मदद फ़ंक्शन प्रदान करता है जो पैकेज का पूरा विवरण देता है जो स्थापित है।
पूरा वाक्यविन्यास नीचे उल्लिखित है -
help(ggplot2)
इस अध्याय में, हम ggplot2 की मदद से एक सरल प्लॉट बनाने पर ध्यान केंद्रित करेंगे। R में डिफ़ॉल्ट प्लॉट बनाने के लिए हम निम्न चरणों का उपयोग करेंगे।
कार्यक्षेत्र में पुस्तकालय और डेटासेट का समावेश
लाइब्रेरी को R में शामिल करें। उस पैकेज को लोड करें जिसकी जरूरत है। अब हम ggplot2 पैकेज पर ध्यान केंद्रित करेंगे।
# Load ggplot2
library(ggplot2)
हम "आइरिस" नाम से डेटासेट लागू करेंगे। डेटासेट में प्रत्येक में 50 उदाहरणों की 3 कक्षाएं होती हैं, जहां प्रत्येक वर्ग एक प्रकार के आईरिस पौधे को संदर्भित करता है। एक वर्ग अन्य दो से रैखिक रूप से अलग है; उत्तरार्द्ध एक दूसरे से रैखिक रूप से अलग नहीं हैं।
# Read in dataset
data(iris)
डेटासेट में शामिल विशेषताओं की सूची नीचे दी गई है -
नमूना साजिश के लिए विशेषताओं का उपयोग करना
सरल तरीके से ggplot2 के साथ आईरिस डेटासेट प्लॉट को प्लॉट करना निम्नलिखित सिंटैक्स को शामिल करता है -
# Plot
IrisPlot <- ggplot(iris, aes(Sepal.Length, Petal.Length, colour=Species))
+ geom_point()
print(IrisPlot)
पहला पैरामीटर डेटासेट को इनपुट के रूप में लेता है, दूसरा पैरामीटर किंवदंती और विशेषताओं का उल्लेख करता है जिन्हें डेटाबेस में प्लॉट किए जाने की आवश्यकता होती है। इस उदाहरण में, हम किंवदंती प्रजाति का उपयोग कर रहे हैं। Geom_point () का अर्थ है बिखरे हुए भूखंड जो बाद के अध्याय में विस्तार से चर्चा करेंगे।
उत्पन्न उत्पादन नीचे उल्लिखित है -
यहां हम शीर्षक, x लेबल और y लेबल को संशोधित कर सकते हैं जिसका अर्थ है x अक्ष और y अक्ष लेबल व्यवस्थित स्वरूप में नीचे दिए गए अनुसार -
print(IrisPlot + labs(y="Petal length (cm)", x = "Sepal length (cm)")
+ ggtitle("Petal and sepal length of iris"))
जब हम रेखांकन में अक्षों के बारे में बोलते हैं, तो यह x और y अक्ष के बारे में होता है, जिसे दो आयामी तरीके से दर्शाया जाता है। इस अध्याय में, हम दो डेटासेट "प्लांटग्राउथ" और "आइरिस" डेटासेट पर ध्यान केंद्रित करेंगे, जो आमतौर पर डेटा वैज्ञानिकों द्वारा उपयोग किया जाता है।
आइरिस डाटासेट में कुल्हाड़ियों को लागू करना
हम R के ggplot2 पैकेज का उपयोग करके x और y अक्षों पर काम करने के लिए निम्नलिखित चरणों का उपयोग करेंगे।
पैकेज की कार्यात्मकता प्राप्त करने के लिए पुस्तकालय को लोड करना हमेशा महत्वपूर्ण होता है।
# Load ggplot
library(ggplot2)
# Read in dataset
data(iris)
कथानक बिंदु बनाना
पिछले अध्याय में चर्चा की तरह, हम इसमें बिंदुओं के साथ एक भूखंड बनाएंगे। दूसरे शब्दों में, इसे बिखरे हुए कथानक के रूप में परिभाषित किया गया है।
# Plot
p <- ggplot(iris, aes(Sepal.Length, Petal.Length, colour=Species)) + geom_point()
p
अब आइए हम एईएस की कार्यक्षमता को समझते हैं जिसमें "ggplot2" की मैपिंग संरचना का उल्लेख है। एस्थेटिक मैपिंग चर संरचना का वर्णन करती है जो कि प्लॉटिंग के लिए आवश्यक होती है और डेटा जिसे व्यक्तिगत परत प्रारूप में प्रबंधित किया जाना चाहिए।
उत्पादन नीचे दिया गया है -
हाइलाइट करें और टिक मार्क करें
नीचे दिए गए अनुसार एक्स और वाई कुल्हाड़ियों के उल्लेख किए गए निर्देशांक के साथ मार्करों को प्लॉट करें। इसमें पाठ जोड़ना, पाठ दोहराना, विशेष क्षेत्र को उजागर करना और खंड जोड़ना इस प्रकार है -
# add text
p + annotate("text", x = 6, y = 5, label = "text")
# add repeat
p + annotate("text", x = 4:6, y = 5:7, label = "text")
# highlight an area
p + annotate("rect", xmin = 5, xmax = 7, ymin = 4, ymax = 6, alpha = .5)
# segment
p + annotate("segment", x = 5, xend = 7, y = 4, yend = 5, colour = "black")
पाठ जोड़ने के लिए उत्पन्न आउटपुट नीचे दिया गया है -
उल्लेखित समन्वय के साथ विशेष पाठ को दोहराने से निम्न आउटपुट उत्पन्न होता है। पाठ 4 से 6 तक x सह-निर्देशांक और 5 से 7 तक y सह-निर्देशांक के साथ उत्पन्न होता है -
विशेष क्षेत्र उत्पादन का विभाजन और हाइलाइटिंग नीचे दिया गया है -
प्लांटग्रो डेटासैट
अब हम "प्लांटग्राउथ" नामक अन्य डेटासेट के साथ काम करने पर ध्यान केंद्रित करते हैं और जिस चरण की आवश्यकता होती है वह नीचे दिया गया है।
पुस्तकालय के लिए कॉल करें और "प्लांटग्राउथ" की विशेषताओं की जांच करें। इस डेटासेट में एक नियंत्रण और दो अलग-अलग उपचार स्थितियों के तहत प्राप्त पैदावार (पौधों के सूखे वजन द्वारा मापी गई) की तुलना करने के लिए प्रयोग शामिल हैं।
> PlantGrowth
weight group
1 4.17 ctrl
2 5.58 ctrl
3 5.18 ctrl
4 6.11 ctrl
5 4.50 ctrl
6 4.61 ctrl
7 5.17 ctrl
8 4.53 ctrl
9 5.33 ctrl
10 5.14 ctrl
11 4.81 trt1
12 4.17 trt1
13 4.41 trt1
14 3.59 trt1
15 5.87 trt1
16 3.83 trt1
17 6.03 trt1
कुल्हाड़ियों के साथ विशेषताएँ जोड़ना
नीचे बताए अनुसार ग्राफ के आवश्यक x और y अक्ष के साथ एक सरल भूखंड की कोशिश करें -
> bp <- ggplot(PlantGrowth, aes(x=group, y=weight)) +
+ geom_point()
> bp
उत्पन्न उत्पादन नीचे दिया गया है -
अंत में, हम नीचे बताए अनुसार बुनियादी कार्य के साथ अपनी आवश्यकता के अनुसार x और y कुल्हाड़ियों को स्वाइप कर सकते हैं -
> bp <- ggplot(PlantGrowth, aes(x=group, y=weight)) +
+ geom_point()
> bp
असल में, हम ggplot2 का उपयोग करके कुल्हाड़ियों के साथ काम करने के लिए सौंदर्य मैपिंग के साथ कई गुणों का उपयोग कर सकते हैं।
अक्ष और किंवदंतियों को सामूहिक रूप से मार्गदर्शक कहा जाता है। वे हमें कथानक से टिप्पणियों को पढ़ने और मूल मूल्यों के संबंध में उन्हें वापस करने की अनुमति देते हैं। लीजेंड कीज़ और टिक लेबल, स्केल ब्रेक द्वारा निर्धारित किए जाते हैं। किंवदंतियों और कुल्हाड़ियों का निर्माण स्वचालित रूप से संबंधित तराजू और ज्यामिति के आधार पर किया जाता है जो भूखंड के लिए आवश्यक हैं।
Ggplot2 में किंवदंतियों के काम को समझने के लिए निम्नलिखित चरणों को लागू किया जाएगा -
कार्यक्षेत्र में पैकेज और डेटासेट का समावेश
हमें ggplot2 के साथ उत्पन्न ग्राफ की कथा पर ध्यान केंद्रित करने के लिए एक ही प्लॉट बनाने दें -
> # Load ggplot
> library(ggplot2)
>
> # Read in dataset
> data(iris)
>
> # Plot
> p <- ggplot(iris, aes(Sepal.Length, Petal.Length, colour=Species)) + geom_point()
> p
यदि आप कथानक का निरीक्षण करते हैं, तो किंवदंतियों को नीचे बताए अनुसार बाएं कोने पर बनाया गया है -
यहां, किंवदंती में दिए गए डाटासेट की विभिन्न प्रकार की प्रजातियां शामिल हैं।
किंवदंतियों के लिए विशेषताएँ बदलना
हम "पौराणिक कथा" संपत्ति की मदद से किंवदंती को हटा सकते हैं और हमें उचित आउटपुट प्राप्त होता है -
> # Remove Legend
> p + theme(legend.position="none")
हम नीचे दिए गए अनुसार संपत्ति "element_blank ()" के साथ किंवदंती का शीर्षक भी छिपा सकते हैं -
> # Hide the legend title
> p + theme(legend.title=element_blank())
हम जरूरत पड़ने पर किंवदंती की स्थिति का भी उपयोग कर सकते हैं। यह संपत्ति सटीक प्लॉट प्रतिनिधित्व उत्पन्न करने के लिए उपयोग की जाती है।
> #Change the legend position
> p + theme(legend.position="top")
>
> p + theme(legend.position="bottom")
Top representation
Bottom representation
किंवदंतियों की फ़ॉन्ट शैली बदलना
हम नीचे दिए गए अनुसार फ़ॉन्ट शैली और फ़ॉन्ट प्रकार और शीर्षक की अन्य विशेषताओं को बदल सकते हैं -
> #Change the legend title and text font styles
> # legend title
> p + theme(legend.title = element_text(colour = "blue", size = 10, + face = "bold"))
> # legend labels
> p + theme(legend.text = element_text(colour = "red", size = 8, + face = "bold"))
उत्पन्न उत्पादन नीचे दिया गया है -
आगामी अध्याय विभिन्न पृष्ठभूमि गुणों जैसे रंग, विषय और डेटा विज्ञान के दृष्टिकोण से उनमें से प्रत्येक के महत्व के साथ विभिन्न प्रकार के भूखंडों पर ध्यान केंद्रित करेंगे।
स्कैटर प्लॉट लाइन ग्राफ के समान हैं जो आमतौर पर प्लॉटिंग के लिए उपयोग किए जाते हैं। तितर बितर भूखंड दिखाते हैं कि एक चर दूसरे से कितना संबंधित है। चर के बीच के संबंध को सहसंबंध कहा जाता है जो आमतौर पर सांख्यिकीय विधियों में उपयोग किया जाता है। हम "आईरिस" नामक समान डेटासेट का उपयोग करेंगे जिसमें प्रत्येक चर के बीच बहुत अधिक भिन्नता शामिल है। यह प्रसिद्ध डेटासेट है जो आइरिस की 3 प्रजातियों में से प्रत्येक से 50 फूलों के लिए पत्थरों की लंबाई और चौड़ाई के साथ चर लंबाई और चौड़ाई के सेंटीमीटर में माप देता है। प्रजातियों को आइरिस सेटोसा, वर्सीकोलर और वर्जिनिका कहा जाता है।
बेसिक स्कैटर प्लॉट बनाना
"Ggplot2" पैकेज के साथ तितर बितर भूखंड बनाने के लिए निम्नलिखित कदम शामिल हैं -
निम्नलिखित के लिए एक मूल स्कैटर प्लॉट बनाने के लिए कमांड निष्पादित की जाती है -
> # Basic Scatter Plot
> ggplot(iris, aes(Sepal.Length, Petal.Length)) +
+ geom_point()
विशेषताएँ जोड़ना
हम geom_point () फ़ंक्शन में आकृति नामक संपत्ति के साथ अंकों के आकार को बदल सकते हैं।
> # Change the shape of points
> ggplot(iris, aes(Sepal.Length, Petal.Length)) +
+ geom_point(shape=1)
हम उन बिंदुओं में रंग जोड़ सकते हैं जो आवश्यक तितर बितर भूखंडों में जोड़े जाते हैं।
> ggplot(iris, aes(Sepal.Length, Petal.Length, colour=Species)) +
+ geom_point(shape=1)
इस उदाहरण में, हमने उन प्रजातियों के अनुसार रंग बनाए हैं जिनका उल्लेख किंवदंतियों में किया गया है। उल्लिखित भूखंड में तीनों प्रजातियां विशिष्ट रूप से प्रतिष्ठित हैं।
अब हम चर के बीच संबंध स्थापित करने पर ध्यान केंद्रित करेंगे।
> ggplot(iris, aes(Sepal.Length, Petal.Length, colour=Species)) +
+ geom_point(shape=1) +
+ geom_smooth(method=lm)
geom_smooth कार्य अतिव्यापी और आवश्यक चर के पैटर्न बनाने के पैटर्न एड्स।
विशेषता विधि "lm" में प्रतिगमन रेखा का उल्लेख है जिसे विकसित करने की आवश्यकता है।
> # Add a regression line
> ggplot(iris, aes(Sepal.Length, Petal.Length, colour=Species)) +
+ geom_point(shape=1) +
+ geom_smooth(method=lm)
हम नीचे उल्लेख वाक्यविन्यास के साथ बिना छायांकित आत्मविश्वास वाले क्षेत्र के साथ एक प्रतिगमन रेखा भी जोड़ सकते हैं -
># Add a regression line but no shaded confidence region
> ggplot(iris, aes(Sepal.Length, Petal.Length, colour=Species)) +
+ geom_point(shape=1) +
+ geom_smooth(method=lm, se=FALSE)
छायांकित क्षेत्र विश्वास क्षेत्रों के अलावा अन्य चीजों का प्रतिनिधित्व करते हैं।
जटर प्लॉट
घबराने वाले भूखंडों में विशेष प्रभाव शामिल होते हैं जिनके साथ बिखरे हुए भूखंडों को चित्रित किया जा सकता है। घबराना कुछ भी नहीं है, लेकिन एक यादृच्छिक मूल्य है जो डॉट्स को सौंपा गया है उन्हें नीचे बताए अनुसार अलग किया जाए -
> ggplot(mpg, aes(cyl, hwy)) +
+ geom_point() +
+ geom_jitter(aes(colour = class))
बार भूखंड आयताकार तरीके से श्रेणीबद्ध डेटा का प्रतिनिधित्व करते हैं। सलाखों को लंबवत और क्षैतिज रूप से प्लॉट किया जा सकता है। हाइट्स या लंबाई ग्राफ में दर्शाए गए मानों के समानुपाती होते हैं। बार भूखंडों की एक्स और वाई कुल्हाड़ियों उस श्रेणी को निर्दिष्ट करते हैं जो विशिष्ट डेटा सेट में शामिल है।
हिस्टोग्राम एक बार ग्राफ है जो उल्लेखित डेटा सेट के वितरण की स्पष्ट तस्वीर के साथ कच्चे डेटा का प्रतिनिधित्व करता है।
इस अध्याय में, हम ggplot2 की मदद से बार प्लॉट और हिस्टोग्राम के निर्माण पर ध्यान केंद्रित करेंगे।
एमपीजी डेटासेट को समझना
आइए हम उन डेटासेट को समझें जिनका उपयोग किया जाएगा। Mpg डेटासेट में ईंधन अर्थव्यवस्था डेटा का एक सबसेट होता है जिसे EPA नीचे दिए गए लिंक में उपलब्ध कराता है -
http://fueleconomy.gov
इसमें ऐसे मॉडल शामिल हैं, जो 1999 और 2008 के बीच हर साल एक नई रिलीज़ करते थे। इसका इस्तेमाल कार की लोकप्रियता के लिए एक प्रॉक्सी के रूप में किया गया था।
निम्नलिखित आदेशों को उन विशेषताओं की सूची को समझने के लिए निष्पादित किया जाता है, जो डेटासेट के लिए आवश्यक हैं।
> library(ggplot2)
अटैचमेंट पैकेज ggplot2 है।
निम्नलिखित वस्तु नकाबपोश है _by_ .GlobalEnv -
mpg
चेतावनी संदेश
- पैकेज का संग्रह आर संस्करण 3.5.1 के तहत बनाया गया था
- पैकेज ट्यूनर R संस्करण 3.5.3 के तहत बनाया गया था
- पैकेज ggplot2 R संस्करण 3.5.3 के तहत बनाया गया था
बार काउंट प्लॉट बनाना
बार काउंट प्लॉट नीचे उल्लिखित प्लॉट के साथ बनाया जा सकता है -
> # A bar count plot
> p <- ggplot(mpg, aes(x=factor(cyl)))+
+ geom_bar(stat="count")
> p
geom_bar () फ़ंक्शन है जो बार प्लॉट बनाने के लिए उपयोग किया जाता है। यह सांख्यिकीय मूल्य की विशेषता लेता है जिसे गिनती कहा जाता है।
हिस्टोग्राम
हिस्टोग्राम काउंट प्लॉट नीचे उल्लिखित प्लॉट के साथ बनाया जा सकता है -
> # A historgram count plot
> ggplot(data=mpg, aes(x=hwy)) +
+ geom_histogram( col="red",
+ fill="green",
+ alpha = .2,
+ binwidth = 5)
geom_histogram () में हिस्टोग्राम बनाने के लिए सभी आवश्यक गुण शामिल हैं। यहाँ, यह संबंधित गिनती के साथ hwy का गुण लेता है। आवश्यकताओं के अनुसार रंग लिया जाता है।
स्टैक्ड बार चार्ट
बार ग्राफ और हिस्टोग्राम के सामान्य प्लॉट निम्नानुसार बनाए जा सकते हैं -
> p <- ggplot(mpg, aes(class))
> p + geom_bar()
> p + geom_bar()
इस प्लॉट में संबंधित वर्ग के साथ बार ग्राफ़ में परिभाषित सभी श्रेणियां शामिल हैं। इस प्लॉट को स्टैक्ड ग्राफ कहा जाता है।
एक पाई चार्ट को एक परिपत्र सांख्यिकीय ग्राफ माना जाता है, जो संख्यात्मक अनुपात को चित्रित करने के लिए स्लाइस में विभाजित है। उल्लिखित पाई चार्ट में, प्रत्येक स्लाइस की चाप लंबाई उस मात्रा का आनुपातिक है जो इसका प्रतिनिधित्व करती है। चाप की लंबाई पाई चार्ट के कोण का प्रतिनिधित्व करती है। पाई चार्ट की कुल डिग्री 360 डिग्री है। अर्धवृत्त या अर्ध पाई चार्ट में 180 डिग्री होते हैं।
पाई चार्ट बनाना
नीचे दिए गए अनुसार कार्यक्षेत्र में पैकेज लोड करें -
> # Load modules
> library(ggplot2)
>
> # Source: Frequency table
> df <- as.data.frame(table(mpg$class))
> colnames(df) <- c("class", "freq")
निम्न आदेश का उपयोग करके नमूना चार्ट बनाया जा सकता है -
> pie <- ggplot(df, aes(x = "", y=freq, fill = factor(class))) +
+ geom_bar(width = 1, stat = "identity") +
+ theme(axis.line = element_blank(),
+ plot.title = element_text(hjust=0.5)) +
+ labs(fill="class",
+ x=NULL,
+ y=NULL,
+ title="Pie Chart of class",
+ caption="Source: mpg")
> pie
यदि आप आउटपुट का निरीक्षण करते हैं, तो चित्र नीचे दिए गए अनुसार परिपत्र तरीके से नहीं बनाया गया है -
को-ऑर्डिनेट बनाना
आइए निम्न पाई चार्ट बनाने के लिए निम्न कमांड निष्पादित करें: -
> pie + coord_polar(theta = "y", start=0)
इस अध्याय में, हम सीमांत भूखंडों के बारे में चर्चा करेंगे।
सीमांत भूखंडों को समझना
सीमांत भूखंडों का उपयोग दो चर के बीच संबंध का आकलन करने और उनके वितरण की जांच करने के लिए किया जाता है। जब हम सीमांत भूखंड बनाने के बारे में बात करते हैं, तो वे कुछ भी नहीं होते हैं, लेकिन तितर बितर भूखंड होते हैं जिनमें संबंधित एक्स और वाई कुल्हाड़ियों के मार्जिन में हिस्टोग्राम, बॉक्स प्लॉट या डॉट प्लॉट होते हैं।
निम्नलिखित चरणों का उपयोग R "पैकेज" ggExtra के साथ सीमांत भूखंड बनाने के लिए किया जाएगा। यह पैकेज "ggplot2" पैकेज की सुविधाओं को बढ़ाने के लिए डिज़ाइन किया गया है और इसमें सफल सीमांत भूखंड बनाने के लिए विभिन्न कार्य शामिल हैं।
चरण 1
सफल निष्पादन के लिए निम्न आदेश का उपयोग करके "ggExtra" पैकेज स्थापित करें (यदि पैकेज आपके सिस्टम में स्थापित नहीं है)।
> install.packages("ggExtra")
चरण 2
सीमांत भूखंड बनाने के लिए कार्यक्षेत्र में आवश्यक पुस्तकालयों को शामिल करें।
> library(ggplot2)
> library(ggExtra)
चरण 3
आवश्यक डेटासेट "mpg" को पढ़ना जो हमने पिछले अध्यायों में उपयोग किया है।
> data(mpg)
> head(mpg)
# A tibble: 6 x 11
manufacturer model displ year cyl trans drv cty hwy fl class
<chr> <chr> <dbl> <int> <int> <chr> <chr> <int> <int> <chr> <chr>
1 audi a4 1.8 1999 4 auto(l5) f 18 29 p compa~
2 audi a4 1.8 1999 4 manual(m5) f 21 29 p compa~
3 audi a4 2 2008 4 manual(m6) f 20 31 p compa~
4 audi a4 2 2008 4 auto(av) f 21 30 p compa~
5 audi a4 2.8 1999 6 auto(l5) f 16 26 p compa~
6 audi a4 2.8 1999 6 manual(m5) f 18 26 p compa~
>
चरण 4
अब हम "ggplot2" का उपयोग करके एक सरल प्लॉट बनाते हैं जो हमें सीमांत भूखंडों की अवधारणा को समझने में मदद करेगा।
> #Plot
> g <- ggplot(mpg, aes(cty, hwy)) +
+ geom_count() +
+ geom_smooth(method="lm", se=F)
> g
चर के बीच संबंध
अब हम ggMarginal फ़ंक्शन का उपयोग करके सीमांत भूखंड बनाते हैं जो दो विशेषताओं "hwy" और "cty" के बीच संबंध बनाने में मदद करता है।
> ggMarginal(g, type = "histogram", fill="transparent")
> ggMarginal(g, type = "boxplot", fill="transparent")
हिस्टोग्राम सीमांत भूखंडों के लिए उत्पादन निम्नानुसार है -
बॉक्स सीमांत भूखंडों के लिए उत्पादन निम्नानुसार है -
बबल प्लॉट कुछ और नहीं बल्कि बबल चार्ट हैं जो मूल रूप से सर्कल आकार के लिए उपयोग किए जाने वाले तीसरे संख्यात्मक चर के साथ एक स्कैटर प्लॉट है। इस अध्याय में, हम बार काउंट प्लॉट और हिस्टोग्राम काउंट प्लॉट के निर्माण पर ध्यान केंद्रित करेंगे, जिसे बबल प्लॉट की प्रतिकृति माना जाता है।
उल्लिखित पैकेज के साथ बबल प्लॉट और काउंट चार्ट बनाने के लिए निम्नलिखित चरणों का उपयोग किया जाता है -
डेटासट को समझना
बबल प्लॉट और काउंट चार्ट बनाने के लिए संबंधित पैकेज और आवश्यक डेटासेट लोड करें।
> # Load ggplot
> library(ggplot2)
>
> # Read in dataset
> data(mpg)
> head(mpg)
# A tibble: 6 x 11
manufacturer model displ year cyl trans drv cty hwy fl class
<chr> <chr> <dbl> <int> <int> <chr> <chr> <int> <int> <chr> <chr>
1 audi a4 1.8 1999 4 auto(l5) f 18 29 p compa~
2 audi a4 1.8 1999 4 manual(m5) f 21 29 p compa~
3 audi a4 2 2008 4 manual(m6) f 20 31 p compa~
4 audi a4 2 2008 4 auto(av) f 21 30 p compa~
5 audi a4 2.8 1999 6 auto(l5) f 16 26 p compa~
6 audi a4 2.8 1999 6 manual(m5) f 18 26 p compa~
निम्नलिखित कमांड का उपयोग करके बार काउंट प्लॉट बनाया जा सकता है -
> # A bar count plot
> p <- ggplot(mpg, aes(x=factor(cyl)))+
+ geom_bar(stat="count")
> p
हिस्टोग्राम के साथ विश्लेषण
हिस्टोग्राम काउंट प्लॉट निम्नलिखित कमांड का उपयोग करके बनाया जा सकता है -
> # A historgram count plot
> ggplot(data=mpg, aes(x=hwy)) +
+ geom_histogram( col="red",
+ fill="green",
+ alpha = .2,
+ binwidth = 5)
बबल चार्ट
अब हम बिखरे हुए भूखंड में उल्लिखित बिंदुओं के आयाम को बढ़ाने के लिए आवश्यक विशेषताओं के साथ सबसे बुनियादी बुलबुला प्लाट बनाते हैं।
ggplot(mpg, aes(x=cty, y=hwy, size = pop)) +geom_point(alpha=0.7)
कथानक निर्माताओं की प्रकृति का वर्णन करता है जो किंवदंती प्रारूप में शामिल है। प्रतिनिधित्व मूल्यों में "hwy" विशेषता के विभिन्न आयाम शामिल हैं।
पिछले अध्यायों में, हमने विभिन्न प्रकार के चार्टों पर एक नज़र डाली, जिन्हें "ggplot2" पैकेज का उपयोग करके बनाया जा सकता है। अब हम बार चार्ट, लॉलीपॉप चार्ट और कई अन्य जैसे डायवर्जन की भिन्नता पर ध्यान केंद्रित करेंगे। शुरू करने के लिए, हम डायवर्जिंग बार चार्ट बनाने के साथ शुरू करेंगे और निम्नलिखित चरणों का उल्लेख नीचे किया जाएगा -
डेटासेट को समझना
आवश्यक पैकेज लोड करें और mpg डाटासेट के भीतर 'कार का नाम' नामक एक नया कॉलम बनाएं।
#Load ggplot
> library(ggplot2)
> # create new column for car names
> mtcars$`car name` <- rownames(mtcars)
> # compute normalized mpg
> mtcars$mpg_z <- round((mtcars$mpg - mean(mtcars$mpg))/sd(mtcars$mpg), 2)
> # above / below avg flag
> mtcars$mpg_type <- ifelse(mtcars$mpg_z < 0, "below", "above")
> # sort
> mtcars <- mtcars[order(mtcars$mpg_z), ]
उपरोक्त गणना में कार नामों के लिए एक नया कॉलम बनाना शामिल है, गोल फ़ंक्शन की सहायता से सामान्यीकृत डेटासेट की गणना करना। हम "प्रकार" कार्यक्षमता के मूल्यों को प्राप्त करने के लिए एवीजी ध्वज के ऊपर और नीचे का उपयोग कर सकते हैं। बाद में, हम आवश्यक डेटासेट बनाने के लिए मानों को क्रमबद्ध करते हैं।
प्राप्त उत्पादन इस प्रकार है -
नीचे दिए गए अनुसार एक विशेष भूखंड में क्रमबद्ध क्रम को बनाए रखने के लिए मूल्यों को कारक में बदलें -
> # convert to factor to retain sorted order in plot.
> mtcars$`car name` <- factor(mtcars$`car name`, levels = mtcars$`car name`)
प्राप्त उत्पादन नीचे उल्लिखित है -
गोताखोर बार चार्ट
अब उल्लिखित विशेषताओं के साथ एक डायवर्जिंग बार चार्ट बनाएं जो आवश्यक निर्देशांक के रूप में लिया गया है।
> # Diverging Barcharts
> ggplot(mtcars, aes(x=`car name`, y=mpg_z, label=mpg_z)) +
+ geom_bar(stat='identity', aes(fill=mpg_type), width=.5) +
+ scale_fill_manual(name="Mileage",
+ labels = c("Above Average", "Below Average"),
+ values = c("above"="#00ba38", "below"="#f8766d")) +
+ labs(subtitle="Normalised mileage from 'mtcars'",
+ title= "Diverging Bars") +
+ coord_flip()
Note - उल्लिखित मानों के संबंध में ऊपर या नीचे दिशा की ओर इशारा करते हुए कुछ आयाम सदस्यों के लिए एक बार बार चार्ट अंकन।
बार चार्ट को डायवर्ट करने के आउटपुट का उल्लेख नीचे किया गया है जहां हम बार चार्ट बनाने के लिए फ़ंक्शन geom_bar का उपयोग करते हैं -
लॉलीपॉप चार्ट को बदलना
एक ही विशेषताओं के साथ एक डायवर्जिंग लॉलीपॉप चार्ट बनाएं और उपयोग किए जाने वाले फ़ंक्शन के केवल परिवर्तन के साथ समन्वय करें, अर्थात जियोमसेसेशन () जो लॉलीपॉप चार्ट बनाने में मदद करता है।
> ggplot(mtcars, aes(x=`car name`, y=mpg_z, label=mpg_z)) +
+ geom_point(stat='identity', fill="black", size=6) +
+ geom_segment(aes(y = 0,
+ x = `car name`,
+ yend = mpg_z,
+ xend = `car name`),
+ color = "black") +
+ geom_text(color="white", size=2) +
+ labs(title="Diverging Lollipop Chart",
+ subtitle="Normalized mileage from 'mtcars': Lollipop") +
+ ylim(-2.5, 2.5) +
+ coord_flip()
गोताखोर डॉट प्लॉट
इसी तरह से एक विचलन डॉट प्लॉट बनाएं जहां डॉट्स बड़े आयाम में बिखरे हुए भूखंडों में बिंदुओं का प्रतिनिधित्व करते हैं।
> ggplot(mtcars, aes(x=`car name`, y=mpg_z, label=mpg_z)) +
+ geom_point(stat='identity', aes(col=mpg_type), size=6) +
+ scale_color_manual(name="Mileage",
+ labels = c("Above Average", "Below Average"),
+ values = c("above"="#00ba38", "below"="#f8766d")) +
+ geom_text(color="white", size=2) +
+ labs(title="Diverging Dot Plot",
+ subtitle="Normalized mileage from 'mtcars': Dotplot") +
+ ylim(-2.5, 2.5) +
+ coord_flip()
यहां, किंवदंतियां हरे और लाल रंग के विभिन्न रंगों के साथ "उपरोक्त औसत" और "औसत से नीचे" मूल्यों का प्रतिनिधित्व करती हैं। डॉट प्लॉट स्थैतिक जानकारी से अवगत कराता है। सिद्धांत डायवर्जिंग बार चार्ट में एक के समान हैं, सिवाय इसके कि केवल बिंदु का उपयोग किया जाता है।
इस अध्याय में, हम अनुकूलित विषय का उपयोग करने पर ध्यान केंद्रित करेंगे जिसका उपयोग कार्यक्षेत्र के रूप और स्वरूप को बदलने के लिए किया जाता है। हम आर के कार्यक्षेत्र में थीम प्रबंधन की अवधारणा को समझने के लिए "ggthemes" पैकेज का उपयोग करेंगे।
हमें बताए गए डेटासेट के भीतर आवश्यक विषय का उपयोग करने के लिए निम्नलिखित चरणों को लागू करना चाहिए।
GGTHEMES
R कार्यस्थान में आवश्यक पैकेज के साथ "ggthemes" पैकेज स्थापित करें।
> install.packages("ggthemes")
> Library(ggthemes)
उत्पादन और विस्थापन के वर्ष के साथ निर्माताओं के किंवदंतियों को उत्पन्न करने के लिए नई थीम को लागू करें।
> library(ggthemes)
> ggplot(mpg, aes(year, displ, color=factor(manufacturer)))+
+ geom_point()+ggtitle("This plot looks a lot different from the default")+
+ theme_economist()+scale_colour_economist()
यह देखा जा सकता है कि टिक टेक्स्ट, किंवदंतियों और अन्य तत्वों का डिफ़ॉल्ट आकार पिछले थीम प्रबंधन के साथ बहुत कम है। एक बार में सभी पाठ तत्वों के आकार को बदलना अविश्वसनीय रूप से आसान है। यह एक कस्टम विषय बनाने पर किया जा सकता है जिसे हम नीचे दिए गए चरण में देख सकते हैं कि सभी तत्व के आकार base_size के सापेक्ष (rel ()) हैं।
> theme_set(theme_gray(base_size = 30))
> ggplot(mpg, aes(x=year, y=class))+geom_point(color="red")
मल्टी पैनल प्लॉट्स का मतलब है एक ही प्लॉट में एक साथ कई ग्राफ्स का प्लॉट बनाना। हम ग्राफिकल पैरामीटर mfrow और mfcol पास करके एक ही भूखंड में कई रेखांकन डालने के लिए par () फ़ंक्शन का उपयोग करेंगे।
यहां हम मल्टी पैनल प्लॉट्स को लागू करने के लिए "एयरक्यूअलिटी" डेटासेट का उपयोग करेंगे। बहु पैनल भूखंडों के निर्माण पर एक नज़र रखने के लिए सबसे पहले डेटासेट को समझें। इस डेटासेट में एक इतालवी शहर में मैदान पर तैनात गैस मल्टी-सेंसर डिवाइस की प्रतिक्रियाएं शामिल हैं। एक प्रमाणित विश्लेषक से गैस की सांद्रता के संदर्भ में प्रति घंटा औसत प्रतिक्रियाएं दर्ज की जाती हैं।
इनसाइट ऑफ़ () फ़ंक्शन
आवश्यक बहु पैनल भूखंडों का एक आयाम बनाने के लिए सममूल्य () फ़ंक्शन को समझें।
> par(mfrow=c(1,2))
> # set the plotting area into a 1*2 array
यह 1 * 2 के आयाम के साथ एक खाली भूखंड बनाता है।
अब निम्नलिखित कमांड का उपयोग करके उल्लेखित डेटासेट का बार प्लॉट और पाई चार्ट बनाएं। इसी घटना को ग्राफिकल पैरामीटर mfcol के साथ प्राप्त किया जा सकता है।
मल्टी पैनल प्लॉट बनाना
दोनों के बीच एकमात्र अंतर यह है कि, mfrow सबप्लॉट रीजन वार में भरता है जबकि mfcol इसे कॉलम वार भरता है।
> Temperature <- airquality$Temp
> Ozone <- airquality$Ozone
> par(mfrow=c(2,2))
> hist(Temperature)
> boxplot(Temperature, horizontal=TRUE)
> hist(Ozone)
> boxplot(Ozone, horizontal=TRUE)
बॉक्सप्लाट्स और बारप्लेट्स सिंगल विंडो में बनाए जाते हैं जो मूल रूप से एक मल्टी पैनल प्लॉट बनाते हैं।
सम फ़ंक्शन में आयामों के परिवर्तन के साथ एक ही प्लॉट इस प्रकार दिखेगा -
par(mfcol = c(2, 2))
इस अध्याय में, हम कई भूखंडों के निर्माण पर ध्यान केंद्रित करेंगे जिनका उपयोग आगे 3 आयामी भूखंड बनाने के लिए किया जा सकता है। जिन भूखंडों की सूची शामिल की जाएगी उनमें शामिल हैं -
- घनत्व प्लॉट
- बॉक्स प्लॉट
- बिंदु साजिश
- वायलिन प्लॉट
हम पिछले अध्याय में उपयोग किए गए "mpg" डेटासेट का उपयोग करेंगे। यह डेटासेट 38 लोकप्रिय कारों के लिए 1999 और 2008 से ईंधन अर्थव्यवस्था डेटा प्रदान करता है। डेटासेट ggplot2 पैकेज के साथ भेज दिया गया है। विभिन्न प्रकार के भूखंडों को बनाने के लिए नीचे दिए गए कदम का पालन करना महत्वपूर्ण है।
> # Load Modules
> library(ggplot2)
>
> # Dataset
> head(mpg)
# A tibble: 6 x 11
manufacturer model displ year cyl trans drv cty hwy fl class
<chr> <chr> <dbl> <int> <int> <chr> <chr> <int> <int> <chr> <chr>
1 audi a4 1.8 1999 4 auto(l5) f 18 29 p compa~
2 audi a4 1.8 1999 4 manual(m5) f 21 29 p compa~
3 audi a4 2 2008 4 manual(m6) f 20 31 p compa~
4 audi a4 2 2008 4 auto(av) f 21 30 p compa~
5 audi a4 2.8 1999 6 auto(l5) f 16 26 p compa~
6 audi a4 2.8 1999 6 manual(m5) f 18 26 p compa~
घनत्व प्लॉट
एक घनत्व प्लॉट उल्लेखित डेटासेट में किसी भी संख्यात्मक चर के वितरण का एक ग्राफिक प्रतिनिधित्व है। यह चर की संभावना घनत्व फ़ंक्शन को दिखाने के लिए कर्नेल घनत्व अनुमान का उपयोग करता है।
"Ggplot2" पैकेज में घनत्व प्लॉट बनाने के लिए geom_density () नामक फ़ंक्शन शामिल है।
घनत्व प्लॉट बनाने के लिए हम निम्नलिखित कमांड निष्पादित करेंगे -
> p −- ggplot(mpg, aes(cty)) +
+ geom_density(aes(fill=factor(cyl)), alpha=0.8)
> p
हम नीचे निर्मित प्लॉट से विभिन्न घनत्वों का निरीक्षण कर सकते हैं -
हम x और y कुल्हाड़ियों का नाम बदलकर साजिश रच सकते हैं जो विभिन्न रंगों के संयोजन के साथ शीर्षक और किंवदंतियों को शामिल करने के साथ बेहतर स्पष्टता बनाए रखता है।
> p + labs(title="Density plot",
+ subtitle="City Mileage Grouped by Number of cylinders",
+ caption="Source: mpg",
+ x="City Mileage",
+ fill="# Cylinders")
बॉक्स प्लॉट
बॉक्स प्लॉट जिसे बॉक्स भी कहा जाता है और व्हिस्कर प्लॉट डेटा के पांच-नंबर सारांश का प्रतिनिधित्व करता है। पांच नंबर सारांश में न्यूनतम, प्रथम चतुर्थक, मध्य, तृतीय चतुर्थक और अधिकतम जैसे मान शामिल हैं। बॉक्स प्लॉट के मध्य भाग से होकर जाने वाली ऊर्ध्वाधर रेखा को "माध्यिका" माना जाता है।
हम निम्नलिखित कमांड का उपयोग करके बॉक्स प्लॉट बना सकते हैं -
> p <- ggplot(mpg, aes(class, cty)) +
+ geom_boxplot(varwidth=T, fill="blue")
> p + labs(title="A Box plot Example",
+ subtitle="Mileage by Class",
+ caption="MPG Dataset",
+ x="Class",
+ y="Mileage")
>p
यहां, हम वर्ग और cty की विशेषताओं के संबंध में बॉक्स प्लॉट बना रहे हैं।
बिंदु साजिश
डॉट प्लॉट बिखरे हुए प्लॉट के समान होते हैं जिनमें केवल आयाम के अंतर होते हैं। इस खंड में, हम मौजूदा बॉक्स प्लॉट में बेहतर चित्र और स्पष्टता के लिए डॉट प्लॉट जोड़ रहे हैं।
निम्नलिखित आदेश का उपयोग करके बॉक्स प्लॉट बनाया जा सकता है -
> p <- ggplot(mpg, aes(manufacturer, cty)) +
+ geom_boxplot() +
+ theme(axis.text.x = element_text(angle=65, vjust=0.6))
> p
डॉट प्लॉट का निर्माण निम्नानुसार किया गया है -
> p + geom_dotplot(binaxis='y',
+ stackdir='center',
+ dotsize = .5
+ )
वायलिन प्लॉट
वायलिन की साजिश भी इसी तरह से बनाई गई है जिसमें बॉक्स के बजाय केवल वायलिन के संरचना परिवर्तन हैं। उत्पादन नीचे स्पष्ट रूप से उल्लेख किया गया है -
> p <- ggplot(mpg, aes(class, cty))
>
> p + geom_violin()
नीचे दिए गए एक फ़ंक्शन के साथ अपने प्लॉट के पूरे रूप को बदलने के तरीके हैं। लेकिन अगर आप अपने द्वारा किए जा सकने वाले पैनल के बैकग्राउंड कलर को बदलना चाहते हैं, तो निम्न का उपयोग करें -
पैनल पृष्ठभूमि को लागू करना
हम निम्नलिखित कमांड का उपयोग करके पृष्ठभूमि का रंग बदल सकते हैं जो पैनल (पैनल.बैकग्राउंड) को बदलने में मदद करता है -
> ggplot(iris, aes(Sepal.Length, Species))+geom_point(color="firebrick")+
+ theme(panel.background = element_rect(fill = 'grey75'))
रंग में परिवर्तन को नीचे दी गई तस्वीर में स्पष्ट रूप से दर्शाया गया है -
पैनल को लागू करना
हम संपत्ति का उपयोग कर ग्रिड लाइनों को बदल सकते हैं "पैनल.ग्रिड.मेजर" जैसा कि नीचे कमांड में उल्लिखित है -
> ggplot(iris, aes(Sepal.Length, Species))+geom_point(color="firebrick")+
+ theme(panel.background = element_rect(fill = 'grey75'),
+ panel.grid.major = element_line(colour = "orange", size=2),
+ panel.grid.minor = element_line(colour = "blue"))
हम प्लॉट बैकग्राउंड को भी बदल सकते हैं, विशेष रूप से "प्लॉट.बैकग्राउंड" प्रॉपर्टी का उपयोग करके नीचे बताए गए पैनल को छोड़कर -
ggplot(iris, aes(Sepal.Length, Species))+geom_point(color="firebrick")+
+ theme(plot.background = element_rect(fill = 'pink'))
एक समय श्रृंखला एक आलेखीय कथानक है जो विशिष्ट समय क्रम में डेटा बिंदुओं की श्रृंखला का प्रतिनिधित्व करता है। एक समय श्रृंखला एक अनुक्रम है जो समय के क्रमिक समान दूरी पर अनुक्रम के साथ लिया जाता है। समय श्रृंखला को असतत-समय डेटा माना जा सकता है। इस अध्याय में हम जो डेटासेट उपयोग करेंगे, वह "अर्थशास्त्र" डेटासेट है जिसमें यूएस आर्थिक समय श्रृंखला के सभी विवरण शामिल हैं।
डेटाफ्रेम में निम्नलिखित विशेषताएं शामिल हैं जो नीचे उल्लिखित हैं -
दिनांक | डेटा संग्रह का महीना |
Psavert | व्यक्तिगत बचत दर |
PCE | व्यक्तिगत उपभोग व्यय |
Unemploy | हजारों की संख्या में बेरोजगार |
Unempmed | बेरोजगारी की औसत अवधि |
पॉप | हजारों में कुल जनसंख्या |
आवश्यक पैकेज लोड करें और समय श्रृंखला बनाने के लिए डिफ़ॉल्ट थीम सेट करें।
> library(ggplot2)
> theme_set(theme_minimal())
> # Demo dataset
> head(economics)
# A tibble: 6 x 6
date pce pop psavert uempmed unemploy
<date> <dbl> <dbl> <dbl> <dbl> <dbl>
1 1967-07-01 507. 198712 12.6 4.5 2944
2 1967-08-01 510. 198911 12.6 4.7 2945
3 1967-09-01 516. 199113 11.9 4.6 2958
4 1967-10-01 512. 199311 12.9 4.9 3143
5 1967-11-01 517. 199498 12.8 4.7 3066
6 1967-12-01 525. 199657 11.8 4.8 3018
एक मूल पंक्ति भूखंड बनाएं जो एक समय श्रृंखला संरचना बनाता है।
> # Basic line plot
> ggplot(data = economics, aes(x = date, y = pop))+
+ geom_line(color = "#00AFBB", size = 2)
हम निम्नलिखित कमांड का उपयोग करके डेटा के सबसेट को प्लॉट कर सकते हैं -
> # Plot a subset of the data
> ss <- subset(economics, date > as.Date("2006-1-1"))
> ggplot(data = ss, aes(x = date, y = pop)) +
+ geom_line(color = "#FC4E07", size = 2)
टाइम सीरीज़ बनाना
यहाँ हम तारीखों के आधार पर वेरिएबल्स psavert और uempmed प्लॉट करेंगे। यहां हमें डेटा का उपयोग tidyr पैकेज के जैसा होना चाहिए। यह एक ही कॉलम (नए कॉलम) में psavert और बेरोजगार मूल्यों को ढहने से प्राप्त किया जा सकता है। समारोह: इकट्ठा () [tidyr]। अगले चरण में एक समूहीकरण चर बनाना शामिल है जो स्तरों के साथ = psavert और uempmed है।
> library(tidyr)
> library(dplyr)
Attaching package: ‘dplyr’
The following object is masked from ‘package:ggplot2’: vars
The following objects are masked from ‘package:stats’: filter, lag
The following objects are masked from ‘package:base’: intersect, setdiff, setequal, union
> df <- economics %>%
+ select(date, psavert, uempmed) %>%
+ gather(key = "variable", value = "value", -date)
> head(df, 3)
# A tibble: 3 x 3
date variable value
<date> <chr> <dbl>
1 1967-07-01 psavert 12.6
2 1967-08-01 psavert 12.6
3 1967-09-01 psavert 11.9
"Psavert" और "बेरोजगार" के बीच संबंधों पर एक नज़र रखने के लिए निम्नलिखित कमांड का उपयोग करके कई लाइन भूखंड बनाएं -
> ggplot(df, aes(x = date, y = value)) +
+ geom_line(aes(color = variable), size = 1) +
+ scale_color_manual(values = c("#00AFBB", "#E7B800")) +
+ theme_minimal()