You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

218 lines
24 KiB

<!--
CO_OP_TRANSLATOR_METADATA:
{
"original_hash": "a49d78e32e280c410f04e5f2a2068e77",
"translation_date": "2025-09-06T07:31:51+00:00",
"source_file": "3-Data-Visualization/09-visualization-quantities/README.md",
"language_code": "mr"
}
-->
# प्रमाणांचे दृश्यांकन
|![ Sketchnote by [(@sketchthedocs)](https://sketchthedocs.dev) ](../../sketchnotes/09-Visualizing-Quantities.png)|
|:---:|
| प्रमाणांचे दृश्यांकन - _Sketchnote by [@nitya](https://twitter.com/nitya)_ |
या धड्यात तुम्ही प्रमाणाच्या संकल्पनेभोवती आकर्षक दृश्यांकन तयार करण्यासाठी उपलब्ध असलेल्या अनेक Python लायब्ररींपैकी एकाचा वापर कसा करायचा हे शिकाल. मिनेसोटामधील पक्ष्यांबद्दलच्या स्वच्छ केलेल्या डेटासेटचा वापर करून तुम्ही स्थानिक वन्यजीवांबद्दल अनेक मनोरंजक तथ्ये शिकू शकता.
## [पूर्व-व्याख्यान प्रश्नमंजूषा](https://ff-quizzes.netlify.app/en/ds/quiz/16)
## Matplotlib सह पंखांचा विस्तार निरीक्षण करा
सोप्या आणि प्रगत प्रकारच्या प्लॉट्स आणि चार्ट्स तयार करण्यासाठी एक उत्कृष्ट लायब्ररी म्हणजे [Matplotlib](https://matplotlib.org/stable/index.html). सामान्यतः, या लायब्ररींचा वापर करून डेटा प्लॉट करण्याची प्रक्रिया तुमच्या डेटाफ्रेममधील लक्ष्यित भाग ओळखणे, आवश्यक असल्यास त्या डेटावर कोणतेही रूपांतरण करणे, त्याचे x आणि y अक्ष मूल्ये नियुक्त करणे, कोणत्या प्रकारचा प्लॉट दाखवायचा ते ठरवणे आणि नंतर प्लॉट दाखवणे यांचा समावेश असतो. Matplotlib विविध प्रकारचे दृश्यांकन ऑफर करते, परंतु या धड्यासाठी, प्रमाणाचे दृश्यांकन करण्यासाठी सर्वात योग्य असलेल्या प्रकारांवर लक्ष केंद्रित करूया: लाइन चार्ट्स, स्कॅटरप्लॉट्स आणि बार प्लॉट्स.
> ✅ तुमच्या डेटाच्या संरचनेसाठी आणि तुम्हाला सांगायची असलेल्या गोष्टीसाठी सर्वोत्तम चार्ट वापरा.
> - वेळेनुसार ट्रेंड्स विश्लेषण करण्यासाठी: लाइन
> - मूल्यांची तुलना करण्यासाठी: बार, कॉलम, पाई, स्कॅटरप्लॉट
> - भाग कसे संपूर्णाशी संबंधित आहेत हे दाखवण्यासाठी: पाई
> - डेटाचा वितरण दाखवण्यासाठी: स्कॅटरप्लॉट, बार
> - ट्रेंड्स दाखवण्यासाठी: लाइन, कॉलम
> - मूल्यांमधील संबंध दाखवण्यासाठी: लाइन, स्कॅटरप्लॉट, बबल
तुमच्याकडे डेटासेट असल्यास आणि दिलेल्या आयटमचे किती प्रमाण आहे हे शोधायचे असल्यास, तुमच्याकडे असलेले पहिले कार्य त्याच्या मूल्यांची तपासणी करणे असेल.
✅ Matplotlib साठी उत्कृष्ट 'चीट शीट्स' [इथे](https://matplotlib.org/cheatsheets/cheatsheets.pdf) उपलब्ध आहेत.
## पक्ष्यांच्या पंखांच्या विस्तारावर आधारित लाइन प्लॉट तयार करा
या धड्याच्या फोल्डरच्या मूळ भागातील `notebook.ipynb` फाइल उघडा आणि एक सेल जोडा.
> लक्षात ठेवा: डेटा या रिपॉजिटरीच्या मूळ भागातील `/data` फोल्डरमध्ये संग्रहित आहे.
```python
import pandas as pd
import matplotlib.pyplot as plt
birds = pd.read_csv('../../data/birds.csv')
birds.head()
```
मजक आणि ां िरण आह:
| | | ि | वर | ऑरडर | ुं | | वरधन ि | ि ां | कम ां | ि शर वजन | कम शर वजन | ि ि | कम ि |
| ---: | :--------------------------- | :--------------------- | :-------------------- | :----------- | :------- | :---------- | :----------------- | --------: | --------: | ----------: | ----------: | ----------: | ----------: |
| 0 | -ि िसलिं-डक | Dendrocygna autumnalis | बदक//णपक | Anseriformes | Anatidae | Dendrocygna | LC | 47 | 56 | 652 | 1020 | 76 | 94 |
| 1 | हस िसलिं-डक | Dendrocygna bicolor | बदक//णपक | Anseriformes | Anatidae | Dendrocygna | LC | 45 | 53 | 712 | 1050 | 85 | 93 |
| 2 | | Anser caerulescens | बदक//णपक | Anseriformes | Anatidae | Anser | LC | 64 | 79 | 2050 | 4050 | 135 | 165 |
| 3 | सच | Anser rossii | बदक//णपक | Anseriformes | Anatidae | Anser | LC | 57.3 | 64 | 1066 | 1567 | 113 | 116 |
| 4 | टर इट- | Anser albifrons | बदक//णपक | Anseriformes | Anatidae | Anser | LC | 64 | 81 | 1930 | 3310 | 130 | 165 |
आत आकरषक पकां कम ि तय करण मक पर एक लभ इन तय कर.
```python
wingspan = birds['MaxWingspan']
wingspan.plot()
```
![कम ि](../../../../3-Data-Visualization/09-visualization-quantities/images/max-wingspan-02.png)
लग लक े? ि एक अपव िसत - ि पच आहे! 2300 ेंटर ि हणज 23 टर - िमध टरइल िरत आह ा? चल तप कर.
Excel मध जलद रमव अपव शकत, कदि यप असत, पर टमधनच ांकन रकि .
x-अकवर बल णत रकरच पक आह खव:
```
plt.title('Max Wingspan in Centimeters')
plt.ylabel('Wingspan (CM)')
plt.xlabel('Birds')
plt.xticks(rotation=45)
x = birds['Name']
y = birds['MaxWingspan']
plt.plot(x, y)
plt.show()
```
![लेबल्ससह पंख विस्तार](../../../../3-Data-Visualization/09-visualization-quantities/images/max-wingspan-labels-02.png)
लेबल्स 45 अंशांवर फिरवले असले तरी वाचण्यासाठी खूप जास्त आहेत. वेगळ्या रणनीतीचा प्रयत्न करूया: फक्त अपवादांना लेबल करा आणि चार्टमध्येच लेबल्स सेट करा. लेबलिंगसाठी अधिक जागा तयार करण्यासाठी तुम्ही स्कॅटर चार्ट वापरू शकता:
```python
plt.title('Max Wingspan in Centimeters')
plt.ylabel('Wingspan (CM)')
plt.tick_params(axis='both',which='both',labelbottom=False,bottom=False)
for i in range(len(birds)):
x = birds['Name'][i]
y = birds['MaxWingspan'][i]
plt.plot(x, y, 'bo')
if birds['MaxWingspan'][i] > 500:
plt.text(x, y * (1 - 0.05), birds['Name'][i], fontsize=12)
plt.show()
```
इथे काय चालले आहे? तुम्ही `tick_params` वापरून तळाशी असलेली लेबल्स लपवली आणि नंतर तुमच्या पक्ष्यांच्या डेटासेटवर लूप तयार केला. `bo` वापरून लहान गोल निळ्या ठिपक्यांसह चार्ट प्लॉट करताना, तुम्ही 500 पेक्षा जास्त कमाल पंख विस्तार असलेल्या कोणत्याही पक्ष्याची तपासणी केली आणि जर तसे असेल तर ठिपक्याजवळ त्यांचे लेबल दाखवले. तुम्ही y अक्षावर लेबल्स थोडेसे ऑफसेट केले (`y * (1 - 0.05)`) आणि पक्ष्याचे नाव लेबल म्हणून वापरले.
तुम्हाला काय सापडले?
![अपवाद](../../../../3-Data-Visualization/09-visualization-quantities/images/labeled-wingspan-02.png)
## तुमचा डेटा फिल्टर करा
बॉल्ड ईगल आणि प्रेरी फाल्कन, कदाचित खूप मोठे पक्षी असले तरी, चुकीचे लेबल केलेले दिसतात, त्यांच्या कमाल पंख विस्तारामध्ये अतिरिक्त `0` जोडले गेले आहे. 25 मीटर पंख विस्तार असलेल्या बॉल्ड ईगलला भेटण्याची शक्यता कमी आहे, परंतु जर तसे असेल तर कृपया आम्हाला कळवा! चला या दोन अपवादांशिवाय नवीन डेटाफ्रेम तयार करूया:
```python
plt.title('Max Wingspan in Centimeters')
plt.ylabel('Wingspan (CM)')
plt.xlabel('Birds')
plt.tick_params(axis='both',which='both',labelbottom=False,bottom=False)
for i in range(len(birds)):
x = birds['Name'][i]
y = birds['MaxWingspan'][i]
if birds['Name'][i] not in ['Bald eagle', 'Prairie falcon']:
plt.plot(x, y, 'bo')
plt.show()
```
अपवाद फिल्टर करून, तुमचा डेटा आता अधिक सुसंगत आणि समजण्यास सोपा आहे.
![पंख विस्ताराचा स्कॅटरप्लॉट](../../../../3-Data-Visualization/09-visualization-quantities/images/scatterplot-wingspan-02.png)
आता आपल्याकडे पंख विस्ताराच्या बाबतीत स्वच्छ डेटासेट आहे, चला या पक्ष्यांबद्दल अधिक शोधूया.
लाइन आणि स्कॅटर प्लॉट्स डेटा मूल्ये आणि त्यांचे वितरण दर्शवू शकतात, परंतु आपण या डेटासेटमध्ये अंतर्भूत असलेल्या मूल्यांबद्दल विचार करू इच्छितो. तुम्ही प्रमाणाबद्दल खालील प्रश्नांची उत्तरे देण्यासाठी दृश्यांकन तयार करू शकता:
> पक्ष्यांचे किती वर्ग आहेत आणि त्यांची संख्या किती आहे?
> पक्षी किती नामशेष, संकटग्रस्त, दुर्मिळ किंवा सामान्य आहेत?
> लिनियसच्या संज्ञेत विविध वंश आणि ऑर्डर किती आहेत?
## बार चार्ट्स एक्सप्लोर करा
डेटाचे गट दाखवायचे असल्यास बार चार्ट्स व्यावहारिक असतात. या डेटासेटमध्ये असलेल्या पक्ष्यांच्या वर्गांचे अन्वेषण करूया आणि पाहूया की संख्या किती आहे.
नोटबुक फाइलमध्ये एक मूलभूत बार चार्ट तयार करा.
✅ लक्षात ठेवा, तुम्ही मागील विभागात ओळखलेल्या दोन अपवाद पक्ष्यांना फिल्टर करू शकता, त्यांच्या पंख विस्तारातील टायपो संपादित करू शकता किंवा पंख विस्ताराच्या मूल्यांवर अवलंबून नसलेल्या या व्यायामांसाठी त्यांना तसेच ठेवू शकता.
जर तुम्हाला बार चार्ट तयार करायचा असेल, तर तुम्ही लक्ष केंद्रित करायचा डेटा निवडू शकता. बार चार्ट्स कच्च्या डेटावरून तयार केले जाऊ शकतात:
```python
birds.plot(x='Category',
kind='bar',
stacked=True,
title='Birds of Minnesota')
```
![पूर्ण डेटा बार चार्ट म्हणून](../../../../3-Data-Visualization/09-visualization-quantities/images/full-data-bar-02.png)
तथापि, हा बार चार्ट वाचण्यायोग्य नाही कारण खूप जास्त न गटबद्ध डेटा आहे. तुम्हाला प्लॉट करायचा डेटा निवडावा लागेल, म्हणून पक्ष्यांच्या वर्गाच्या आधारावर लांबी पाहूया.
तुमचा डेटा फक्त पक्ष्यांच्या वर्गाचा समावेश करण्यासाठी फिल्टर करा.
✅ लक्षात ठेवा की तुम्ही Pandas वापरून डेटा व्यवस्थापित करता आणि नंतर Matplotlib चार्टिंग करते.
कारण अनेक वर्ग आहेत, तुम्ही हा चार्ट उभा दाखवू शकता आणि सर्व डेटासाठी त्याची उंची समायोजित करू शकता:
```python
category_count = birds.value_counts(birds['Category'].values, sort=True)
plt.rcParams['figure.figsize'] = [6, 12]
category_count.plot.barh()
```
![वर्ग आणि लांबी](../../../../3-Data-Visualization/09-visualization-quantities/images/category-counts-02.png)
हा बार चार्ट प्रत्येक वर्गातील पक्ष्यांची संख्या चांगल्या प्रकारे दाखवतो. एका झटक्यात तुम्हाला दिसते की या प्रदेशातील सर्वात जास्त पक्षी बदके/हंस/पाणपक्षी वर्गात आहेत. मिनेसोटा '10,000 तलावांचे प्रदेश' आहे त्यामुळे हे आश्चर्यकारक नाही!
✅ या डेटासेटवर काही इतर गणना करून पहा. तुम्हाला काही आश्चर्य वाटते का?
## डेटा तुलना
तुम्ही नवीन अक्ष तयार करून गटबद्ध डेटाची वेगवेगळी तुलना करू शकता. पक्ष्याच्या वर्गाच्या आधारावर पक्ष्याच्या कमाल लांबीची तुलना करून पहा:
```python
maxlength = birds['MaxLength']
plt.barh(y=birds['Category'], width=maxlength)
plt.rcParams['figure.figsize'] = [6, 12]
plt.show()
```
![डेटाची तुलना](../../../../3-Data-Visualization/09-visualization-quantities/images/category-length-02.png)
इथे काहीही आश्चर्यकारक नाही: हंबिंगबर्ड्सची कमाल लांबी पेलिकन्स किंवा हंसांच्या तुलनेत सर्वात कमी आहे. जेव्हा डेटा तार्किक अर्थ प्राप्त करतो ते चांगले आहे!
तुम्ही बार चार्ट्सचे अधिक मनोरंजक दृश्य तयार करू शकता डेटा सुपरइम्पोज करून. चला दिलेल्या पक्ष्याच्या वर्गावर किमान आणि कमाल लांबी सुपरइम्पोज करूया:
```python
minLength = birds['MinLength']
maxLength = birds['MaxLength']
category = birds['Category']
plt.barh(category, maxLength)
plt.barh(category, minLength)
plt.show()
```
या प्लॉटमध्ये, तुम्ही किमान लांबी आणि कमाल लांबीच्या श्रेणी प्रति पक्षी वर्ग पाहू शकता. तुम्ही सुरक्षितपणे म्हणू शकता की, या डेटानुसार, पक्षी जितका मोठा तितकी त्याची लांबी श्रेणी मोठी. आकर्षक!
![सुपरइम्पोज केलेली मूल्ये](../../../../3-Data-Visualization/09-visualization-quantities/images/superimposed-02.png)
## 🚀 आव्हान
हा पक्ष्यांचा डेटासेट विशिष्ट परिसंस्थेतील विविध प्रकारच्या पक्ष्यांबद्दल माहिती देतो. इंटरनेटवर शोधा आणि पक्ष्यांशी संबंधित इतर डेटासेट शोधा. या पक्ष्यांभोवती चार्ट्स आणि ग्राफ्स तयार करण्याचा सराव करा आणि तुम्हाला माहित नसलेल्या तथ्यांचा शोध घ्या.
## [व्याख्यानानंतरची प्रश्नमंजूषा](https://ff-quizzes.netlify.app/en/ds/quiz/17)
## पुनरावलोकन आणि स्व-अभ्यास
या पहिल्या धड्याने तुम्हाला प्रमाणांचे दृश्यांकन करण्यासाठी Matplotlib कसे वापरायचे याबद्दल काही माहिती दिली आहे. दृश्यांकनासाठी डेटासेटसह कार्य करण्याच्या इतर मार्गांबद्दल संशोधन करा. [Plotly](https://github.com/plotly/plotly.py) एक आहे ज्याचा आपण या धड्यांमध्ये कव्हर करणार नाही, त्यामुळे ते काय ऑफर करू शकते ते पहा.
## असाइनमेंट
[लाइन, स्कॅटर्स आणि बार्स](assignment.md)
---
**अस्वीकरण**:
हा दस्तऐवज AI भाषांतर सेवा [Co-op Translator](https://github.com/Azure/co-op-translator) चा वापर करून भाषांतरित करण्यात आला आहे. आम्ही अचूकतेसाठी प्रयत्नशील असलो तरी कृपया लक्षात ठेवा की स्वयंचलित भाषांतरे त्रुटी किंवा अचूकतेच्या अभावाने युक्त असू शकतात. मूळ भाषेतील दस्तऐवज हा अधिकृत स्रोत मानला जावा. महत्त्वाच्या माहितीसाठी व्यावसायिक मानवी भाषांतराची शिफारस केली जाते. या भाषांतराचा वापर करून उद्भवलेल्या कोणत्याही गैरसमज किंवा चुकीच्या अर्थासाठी आम्ही जबाबदार राहणार नाही.