समय श्रृंखला - डाटा प्रोसेसिंग और विज़ुअलाइज़ेशन

टाइम सीरीज़ समान-अंतराल समय अंतराल में अनुक्रमित टिप्पणियों का एक क्रम है। इसलिए, किसी भी समय श्रृंखला में क्रम और निरंतरता को बनाए रखा जाना चाहिए।

जिस डेटासेट का हम उपयोग कर रहे हैं, वह एक बहु-चर समय श्रृंखला है जिसमें लगभग एक वर्ष तक प्रति घंटा डेटा होता है, जो काफी प्रदूषित इतालवी शहर में हवा की गुणवत्ता के लिए है। डाटासेट नीचे दिए गए लिंक से डाउनलोड किया जा सकता है -https://archive.ics.uci.edu/ml/datasets/air+quality।

यह सुनिश्चित करना आवश्यक है कि -

  • समय श्रृंखला समान रूप से दूरी पर है, और

  • इसमें कोई निरर्थक मूल्य या अंतराल नहीं हैं।

यदि समय श्रृंखला निरंतर नहीं है, तो हम इसे बढ़ा या घटा सकते हैं।

दिखा रहा है df.head ()

[१२२] में:

import pandas

[123] में:

df = pandas.read_csv("AirQualityUCI.csv", sep = ";", decimal = ",")
df = df.iloc[ : , 0:14]

[१२४] में:

len(df)

आउट [124]:

9471

[125] में:

df.head()

आउट [125]:

समय श्रृंखला के प्रीप्रोसेसिंग के लिए, हम सुनिश्चित करते हैं कि डेटासेट में कोई NaN (NULL) मान नहीं हैं; यदि हैं, तो हम उन्हें 0 या औसत या पूर्ववर्ती या सफल मान के साथ बदल सकते हैं। रिप्लेसिंग ड्रॉपिंग पर एक पसंदीदा विकल्प है ताकि टाइम सीरीज़ की निरंतरता बनी रहे। हालाँकि, हमारे डेटासेट में पिछले कुछ मान NULL लगते हैं और इसलिए छोड़ने से निरंतरता प्रभावित नहीं होगी।

ड्रॉपिंग एनएन (संख्या नहीं)

[१२६] में:

df.isna().sum()
Out[126]:
Date             114
Time             114
CO(GT)           114
PT08.S1(CO)      114
NMHC(GT)         114
C6H6(GT)         114
PT08.S2(NMHC)    114
NOx(GT)          114
PT08.S3(NOx)     114
NO2(GT)          114
PT08.S4(NO2)     114
PT08.S5(O3)      114
T                114
RH               114
dtype: int64

[१२ In] में:

df = df[df['Date'].notnull()]

[१२ In] में:

df.isna().sum()

आउट [128]:

Date             0
Time             0
CO(GT)           0
PT08.S1(CO)      0
NMHC(GT)         0
C6H6(GT)         0
PT08.S2(NMHC)    0
NOx(GT)          0
PT08.S3(NOx)     0
NO2(GT)          0
PT08.S4(NO2)     0
PT08.S5(O3)      0
T                0
RH               0
dtype: int64

टाइम सीरीज़ को आमतौर पर समय के विपरीत लाइन ग्राफ़ के रूप में प्लॉट किया जाता है। उसके लिए अब हम तारीख और समय कॉलम को जोड़ेंगे और इसे स्ट्रिंग से डेटाइम ऑब्जेक्ट में बदल देंगे। यह डेटाइम लाइब्रेरी का उपयोग करके पूरा किया जा सकता है।

डेटाटाइम ऑब्जेक्ट में परिवर्तित हो रहा है

[१२ ९] में:

df['DateTime'] = (df.Date) + ' ' + (df.Time)
print (type(df.DateTime[0]))

<class 'str'>

[१३०] में:

import datetime

df.DateTime = df.DateTime.apply(lambda x: datetime.datetime.strptime(x, '%d/%m/%Y %H.%M.%S'))
print (type(df.DateTime[0]))

<class 'pandas._libs.tslibs.timestamps.Timestamp'>

आइए देखते हैं कि समय में परिवर्तन के साथ तापमान में परिवर्तन कैसे होता है।

प्लॉट दिखा रहे हैं

[131] में:

df.index = df.DateTime

[१३२] में:

import matplotlib.pyplot as plt
plt.plot(df['T'])

आउट [132]:

[<matplotlib.lines.Line2D at 0x1eaad67f780>]

[208] में:

plt.plot(df['C6H6(GT)'])

आउट [208]:

[<matplotlib.lines.Line2D at 0x1eaaeedff28>]

बॉक्स-प्लॉट एक अन्य उपयोगी प्रकार के ग्राफ़ हैं, जो आपको एक सिंगल ग्राफ़ में डेटासेट के बारे में बहुत सारी जानकारी प्राप्त करने की अनुमति देते हैं। यह 25% और 75% चतुर्थक और एक या कई चरों के आउटलेयर का मतलब दिखाता है। उस स्थिति में जब आउटलेयर की संख्या कम है और इस बीच से बहुत दूर है, हम आउटलेर्स को औसत मूल्य या 75% चतुर्थक मान पर सेट करके समाप्त कर सकते हैं।

Boxplots दिखा रहा है

[१३४] में:

plt.boxplot(df[['T','C6H6(GT)']].values)

आउट [134]:

{'whiskers': [<matplotlib.lines.Line2D at 0x1eaac16de80>,
   <matplotlib.lines.Line2D at 0x1eaac16d908>,
   <matplotlib.lines.Line2D at 0x1eaac177a58>,
   <matplotlib.lines.Line2D at 0x1eaac177cf8>],
   'caps': [<matplotlib.lines.Line2D at 0x1eaac16d2b0>,
   <matplotlib.lines.Line2D at 0x1eaac16d588>,
   <matplotlib.lines.Line2D at 0x1eaac1a69e8>,
   <matplotlib.lines.Line2D at 0x1eaac1a64a8>],
   'boxes': [<matplotlib.lines.Line2D at 0x1eaac16dc50>,
   <matplotlib.lines.Line2D at 0x1eaac1779b0>],
   'medians': [<matplotlib.lines.Line2D at 0x1eaac16d4a8>,
   <matplotlib.lines.Line2D at 0x1eaac1a6c50>],
   'fliers': [<matplotlib.lines.Line2D at 0x1eaac177dd8>,
   <matplotlib.lines.Line2D at 0x1eaac1a6c18>],'means': []
}