Zaman Serisi - Hızlı Kılavuz

Bir zaman serisi, belirli bir dönemdeki gözlemler dizisidir. Tek değişkenli bir zaman serisi, bir dönem boyunca periyodik zaman örneklerinde tek bir değişken tarafından alınan değerlerden ve çok değişkenli bir zaman serisi, bir dönem boyunca aynı periyodik zaman örneklerinde birden çok değişken tarafından alınan değerlerden oluşur. Günlük bazda hepimizin karşılaştığı bir zaman serisinin en basit örneği, gün veya hafta veya ay veya yıl boyunca sıcaklıktaki değişimdir.

Zamansal verilerin analizi, bir değişkenin zaman içinde nasıl değiştiği veya diğer değişken (ler) in değerlerindeki değişime nasıl bağlı olduğu konusunda bize yararlı bilgiler verebilir. Bir değişkenin önceki değerleri ve / veya diğer değişkenler üzerindeki bu ilişkisi, zaman serisi tahmini için analiz edilebilir ve yapay zeka konusunda çok sayıda uygulamaya sahiptir.

Herhangi bir programlama dilinin temel olarak anlaşılması, bir kullanıcının makine öğrenimi problemleriyle çalışması veya bunları geliştirmesi için gereklidir. Makine öğrenimi üzerinde çalışmak isteyen herkes için tercih edilen programlama dillerinin bir listesi aşağıda verilmiştir -

Python

Hızlı ve kodlaması kolay, yüksek düzeyde yorumlanmış bir programlama dilidir. Python, prosedürel veya nesne yönelimli programlama paradigmalarını takip edebilir. Çeşitli kütüphanelerin varlığı, karmaşık prosedürlerin uygulanmasını kolaylaştırır. Bu eğitici yazıda, Python'da kodlama yapacağız ve zaman serisi modellemesi için yararlı olan ilgili kütüphaneler ilerideki bölümlerde tartışılacaktır.

R

Python'a benzer şekilde, R, istatistiksel hesaplama ve grafikleri destekleyen, yorumlanmış çok paradigmalı bir dildir. Paketlerin çeşitliliği, R'de makine öğrenimi modellemesini uygulamayı kolaylaştırır.

Java

Çok çeşitli paket kullanılabilirliği ve sofistike veri görselleştirme teknikleriyle oldukça ünlü olan, yorumlanmış bir nesne yönelimli programlama dilidir.

C / C ++

Bunlar derlenmiş diller ve en eski iki programlama dilidir. Bu diller, makine öğrenimi algoritmalarının uygulamasını kolayca özelleştirmenize olanak sağladıkları için, halihazırda mevcut uygulamalarda makine öğrenimi yeteneklerini dahil etmek için sıklıkla tercih edilir.

MATLAB

MATrix LABoratory, matrislerle çalışmaya işlevsellik kazandıran çok paradigmalı bir dildir. Karmaşık problemler için matematiksel işlemlere izin verir. Öncelikle sayısal işlemler için kullanılır, ancak bazı paketler ayrıca grafiksel çoklu alan simülasyonuna ve model tabanlı tasarıma da izin verir.

Makine öğrenimi sorunları için tercih edilen diğer programlama dilleri arasında JavaScript, LISP, Prolog, SQL, Scala, Julia, SAS vb. Yer alır.

Python, yazması ve anlaşılması kolay kod yapısının yanı sıra çok çeşitli açık kaynak kitaplıkları nedeniyle makine öğrenimi gerçekleştiren kişiler arasında köklü bir popülerliğe sahiptir. İlerleyen bölümlerde kullanacağımız bu tür açık kaynak kitaplıklardan birkaçı aşağıda tanıtılmıştır.

Dizi

Sayısal Python, bilimsel hesaplama için kullanılan bir kütüphanedir. N boyutlu bir dizi nesnesi üzerinde çalışır ve boyut, şekil, ortalama, standart sapma, minimum, maksimum gibi temel matematiksel işlevlerin yanı sıra doğrusal cebirsel işlevler ve Fourier dönüşümü gibi bazı daha karmaşık işlevler sağlar. Bu eğitimde ilerledikçe bunlar hakkında daha fazla bilgi edineceksiniz.

Pandalar

Bu kütüphane, seriler, veri çerçeveleri ve paneller gibi oldukça verimli ve kullanımı kolay veri yapıları sağlar. Python'un işlevselliğini yalnızca veri toplama ve hazırlamadan veri analizine kadar geliştirmiştir. İki kütüphane, Pandas ve NumPy, küçük ve çok büyük veri kümeleri üzerinde herhangi bir işlemi çok basit hale getirir. Bu işlevler hakkında daha fazla bilgi edinmek için bu öğreticiyi izleyin.

SciPy

Science Python, bilimsel ve teknik hesaplama için kullanılan bir kütüphanedir. Optimizasyon, sinyal ve görüntü işleme, entegrasyon, enterpolasyon ve doğrusal cebir için işlevler sağlar. Bu kitaplık, makine öğrenimi gerçekleştirilirken kullanışlı olur. Bu eğitimde ilerledikçe bu işlevleri tartışacağız.

Scikit Learn

Bu kütüphane, çeşitli özelleştirilebilir regresyon, sınıflandırma ve kümeleme modelleri içerdiğinden, istatistiksel modelleme, makine öğrenimi ve derin öğrenme için yaygın olarak kullanılan bir SciPy Toolkit'tir. Numpy, Pandas ve diğer kütüphanelerle iyi çalışır ve bu da kullanımı kolaylaştırır.

İstatistik modelleri

Scikit Learn gibi, bu kütüphane de istatistiksel veri keşfi ve istatistiksel modelleme için kullanılır. Ayrıca diğer Python kitaplıklarıyla da iyi çalışır.

Matplotlib

Bu kütüphane, çizgi grafiği, çubuk grafik, ısı haritaları, dağılım grafikleri, histogram vb. Gibi çeşitli formatlarda veri görselleştirme için kullanılır. Çizimden etiketlemeye kadar gerekli tüm grafikle ilgili işlevleri içerir. Bu eğitimde ilerledikçe bu işlevleri tartışacağız.

Bu kitaplıklar, her türlü veriyle makine öğrenimine başlamak için çok önemlidir.

Yukarıda tartışılanların yanı sıra, zaman serileriyle ilgilenmek için özellikle önemli olan başka bir kütüphane -

Tarih saat

Tarih saat ve takvim olmak üzere iki modülüyle bu kütüphane, zamanı okumak, biçimlendirmek ve işlemek için gerekli tüm tarih saat işlevselliğini sağlar.

Bu kütüphaneleri ilerleyen bölümlerde kullanacağız.

Zaman Serileri, eşit aralıklı zaman aralıklarında indekslenmiş bir gözlemler dizisidir. Bu nedenle, herhangi bir zaman serisinde düzen ve süreklilik korunmalıdır.

Kullanacağımız veri seti, önemli ölçüde kirlenmiş bir İtalyan şehrinde hava kalitesi için yaklaşık bir yıllık saatlik verilere sahip çok değişkenli bir zaman serisidir. Veri seti aşağıda verilen bağlantıdan indirilebilir -https://archive.ics.uci.edu/ml/datasets/air+quality.

Şunlardan emin olmak gerekir -

  • Zaman serileri eşit aralıklarla yerleştirilmiştir ve

  • İçinde fazlalık değer veya boşluk yoktur.

Zaman serisinin sürekli olmaması durumunda, onu yukarı veya aşağı örnekleyebiliriz.

Df.head () gösteriliyor

[122] 'de:

import pandas

[123] 'te:

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

[124] 'te:

len(df)

Çıkış [124]:

9471

[125] içinde:

df.head()

Çıkış [125]:

Zaman serilerini önişlemek için, veri setinde NaN (NULL) değerlerinin olmadığından emin oluruz; varsa, bunları 0 veya ortalama veya önceki veya sonraki değerlerle değiştirebiliriz. Değiştirme, zaman serisinin sürekliliğinin korunması için düşürmeye göre tercih edilen bir seçimdir. Ancak, veri setimizde son birkaç değer NULL görünüyor ve bu nedenle düşme sürekliliği etkilemeyecek.

NaN (Sayı Değil) Bırakılıyor

[126] 'da:

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

[127] 'de:

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

[128] 'de:

df.isna().sum()

Çıkış [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

Zaman Serileri genellikle zamana karşı çizgi grafikler olarak çizilir. Bunun için şimdi tarih ve saat sütununu birleştirip onu dizelerden bir datetime nesnesine dönüştüreceğiz. Bu, datetime kitaplığı kullanılarak gerçekleştirilebilir.

Datetime nesnesine dönüştürme

[129] 'da:

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

<class 'str'>

[130] 'da:

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'>

Sıcaklık gibi bazı değişkenlerin zamanla nasıl değiştiğini görelim.

Grafikler gösteriliyor

[131] 'de:

df.index = df.DateTime

[132] 'de:

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

Çıkış [132]:

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

[208] 'de:

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

Çıkış [208]:

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

Kutu grafikleri, bir veri kümesiyle ilgili birçok bilgiyi tek bir grafikte yoğunlaştırmanıza izin veren başka bir yararlı grafik türüdür. Ortalama,% 25 ve% 75 çeyreklik ve bir veya birden çok değişkenin aykırı değerlerini gösterir. Aykırı değerlerin sayısının az olduğu ve ortalamadan çok uzak olduğu durumda, aykırı değerleri ortalama değere veya% 75 çeyrek değerine ayarlayarak eleyebiliriz.

Boxplots gösteriliyor

[134] 'te:

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

Çıkış [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': []
}

Giriş

Bir zaman serisinin aşağıda verildiği gibi 4 bileşeni vardır -

  • Level - Serinin değiştiği ortalama değerdir.

  • Trend - Bir değişkenin zamanla artan veya azalan davranışıdır.

  • Seasonality - Zaman serilerinin döngüsel davranışıdır.

  • Noise - Çevresel faktörlerden dolayı eklenen gözlemlerdeki hatadır.

Zaman Serisi Modelleme Teknikleri

Bu bileşenleri yakalamak için, bir dizi popüler zaman serisi modelleme tekniği vardır. Bu bölüm, her tekniğin kısa bir girişini verir, ancak sonraki bölümlerde bunlar hakkında ayrıntılı olarak tartışacağız -

Naif Yöntemler

Bunlar, tahmin edilen değere zamana bağlı değişkenin önceki değerlerinin ortalamasına eşit değer verilmesi veya önceki gerçek değer gibi basit tahmin teknikleridir. Bunlar, gelişmiş modelleme teknikleriyle karşılaştırmak için kullanılır.

Otomatik Regresyon

Otomatik regresyon, önceki zaman dönemlerindeki değerlerin bir fonksiyonu olarak gelecekteki zaman dönemlerinin değerlerini tahmin eder. Otomatik regresyon tahminleri, verilere naif yöntemlerden daha iyi uyabilir, ancak mevsimselliği açıklayamayabilir.

ARIMA Modeli

Bir otomatik gerilimli entegre hareketli ortalama, bir değişkenin değerini, bir sabit zaman serisinin önceki zaman adımlarında önceki değerlerin ve artık hataların doğrusal bir fonksiyonu olarak modeller. Ancak, gerçek dünya verileri sabit olmayabilir ve mevsimsel olabilir, bu nedenle Mevsimsel-ARIMA ve Kesirli-ARIMA geliştirilmiştir. ARIMA, birden çok değişkeni işlemek için tek değişkenli zaman serileri üzerinde çalışır. VARIMA tanıtıldı.

Üstel Düzeltme

Bir değişkenin değerini, önceki değerlerin üstel ağırlıklı doğrusal işlevi olarak modeller. Bu istatistiksel model eğilimi ve mevsimselliği de ele alabilir.

LSTM

Uzun Kısa Süreli Bellek modeli (LSTM), uzun vadeli bağımlılıkları hesaba katmak için zaman serileri için kullanılan tekrarlayan bir sinir ağıdır. Çok değişkenli zaman serilerindeki eğilimleri yakalamak için büyük miktarda veriyle eğitilebilir.

Söz konusu modelleme teknikleri, zaman serisi regresyonu için kullanılmaktadır. İlerleyen bölümlerde şimdi tüm bunları tek tek inceleyelim.

Giriş

Herhangi bir istatistiksel veya makine öğrenimi modelinin, verilerin nasıl modelleneceğini büyük ölçüde etkileyen bazı parametreleri vardır. Örneğin, ARIMA'nın p, d, q değerleri vardır. Bu parametrelere, gerçek değerler ile modellenen değerler arasındaki hata minimum olacak şekilde karar verilmelidir. Parametre kalibrasyonunun, model yerleştirmenin en önemli ve zaman alıcı görevi olduğu söylenir. Bu nedenle, optimum parametreleri seçmemiz çok önemlidir.

Parametrelerin Kalibrasyon Yöntemleri

Parametreleri kalibre etmenin çeşitli yolları vardır. Bu bölümde bazıları hakkında ayrıntılı olarak bahsedilmektedir.

Vur ve dene

Modelleri kalibre etmenin yaygın bir yolu, zaman serilerini görselleştirerek ve sezgisel olarak bazı parametre değerlerini denediğiniz ve yeterince iyi bir uyum elde edene kadar bunları tekrar tekrar değiştirdiğiniz el kalibrasyonudur. Denediğimiz modelin iyi anlaşılmasını gerektirir. ARIMA modeli için, el kalibrasyonu, 'p' parametresi için oto-korelasyon grafiği, 'q' parametresi için kısmi oto-korelasyon grafiği ve zaman serilerinin durağanlığını teyit etmek için ADF testi ve 'd' parametresini ayarlamak için yapılır. . Tüm bunları ilerleyen bölümlerde detaylı olarak tartışacağız.

Izgara Araması

Modelleri kalibre etmenin başka bir yolu da, esasen tüm olası parametre kombinasyonları için bir model oluşturmaya çalıştığınız ve minimum hatayla olanı seçeceğiniz anlamına gelen ızgara aramasıdır. Bu, zaman alıcıdır ve dolayısıyla, kalibre edilecek parametrelerin sayısı ve aldıkları değerlerin aralığı daha az olduğunda kullanışlıdır, çünkü bu, çoklu iç içe döngüler içerir.

Genetik Algoritma

Genetik algoritma, iyi bir çözümün sonunda en 'optimal' çözüme dönüşeceği biyolojik prensibi üzerinde çalışır. Nihayet optimal bir çözüme ulaşmak için biyolojik mutasyon, çapraz geçiş ve seçim işlemlerini kullanır.

Daha fazla bilgi için Bayesian optimizasyonu ve Swarm optimizasyonu gibi diğer parametre optimizasyon tekniklerini okuyabilirsiniz.

Giriş

İstatistiksel modellerin ve makine öğrenimi modellerinin ne kadar iyi performans gösterebileceğini ölçmek için, 't' zamanında tahmin edilen değerin 't-1' zamanında değişkenin gerçek değeri olduğunu varsaymak veya serinin yuvarlanma ortalaması gibi Naif Yöntemler kullanılır. ve ihtiyaçlarını vurgulayın.

Bu bölümde, bu modelleri zaman serisi verilerimizin özelliklerinden biri üzerinde deneyelim.

Önce verilerimizin 'sıcaklık' özelliğinin ortalamasını ve etrafındaki sapmayı göreceğiz. Maksimum ve minimum sıcaklık değerlerini görmek de faydalıdır. Numpy kitaplığının işlevlerini burada kullanabiliriz.

İstatistikler gösteriliyor

[135] 'de:

import numpy
print (
   'Mean: ',numpy.mean(df['T']), '; 
   Standard Deviation: ',numpy.std(df['T']),'; 
   \nMaximum Temperature: ',max(df['T']),'; 
   Minimum Temperature: ',min(df['T'])
)

Verileri anlamamız için yararlı olan, eşit aralıklı zaman çizelgesindeki 9357 gözlemin tümü için istatistiklere sahibiz.

Şimdi ilk naif yöntemi deneyeceğiz, şimdiki zamanda tahmin edilen değeri önceki zamandaki gerçek değere eşit ayarlayacağız ve bu yöntemin performansını ölçmek için kök ortalama kare hatasını (RMSE) hesaplayacağız.

1 Gösterilen st naif yöntemi

[136] 'da:

df['T']
df['T_t-1'] = df['T'].shift(1)

[137] 'de:

df_naive = df[['T','T_t-1']][1:]

[138] 'de:

from sklearn import metrics
from math import sqrt

true = df_naive['T']
prediction = df_naive['T_t-1']
error = sqrt(metrics.mean_squared_error(true,prediction))
print ('RMSE for Naive Method 1: ', error)

Naif Yöntem 1 için RMSE: 12.901140576492974

Şimdiki zaman için öngörülen değerin kendisinden önceki zaman dilimlerinin ortalamasına eşit olduğu bir sonraki naif yöntemi görelim. Bu yöntem için de RMSE'yi hesaplayacağız.

2 Gösterilen nd naif yöntemi

[139] 'da:

df['T_rm'] = df['T'].rolling(3).mean().shift(1)
df_naive = df[['T','T_rm']].dropna()

[140] 'da:

true = df_naive['T']
prediction = df_naive['T_rm']
error = sqrt(metrics.mean_squared_error(true,prediction))
print ('RMSE for Naive Method 2: ', error)

RMSE for Naive Method 2: 14.957633272839242

Burada, burada 3 olarak tutulan, göz önünde bulundurmak istediğiniz 'gecikmeler' olarak da adlandırılan çeşitli sayıda önceki dönemleri deneyebilirsiniz. Bu verilerde, siz gecikme sayıları arttıkça ve hataların arttığı görülmektedir. Gecikme 1 tutulursa, daha önce kullanılan naif yöntemle aynı hale gelir.

Points to Note

  • Kök ortalama karesel hatayı hesaplamak için çok basit bir fonksiyon yazabilirsiniz. Burada, 'sklearn' paketinden ortalama kare hata fonksiyonunu kullandık ve sonra karekökünü aldık.

  • Pandas df'de ['sütun_adı'], df.column_name olarak da yazılabilir, ancak bu veri kümesi için df.T, df ['T'] ile aynı şekilde çalışmayacaktır çünkü df.T, bir veri çerçevesinin aktarılması işlevidir. Bu nedenle sadece df ['T'] kullanın veya diğer sözdizimini kullanmadan önce bu sütunu yeniden adlandırmayı düşünün.

Sabit bir zaman serisi için, bir otomatik regresyon modeli, bir değişkenin değerini 't' zamanında, kendisinden önceki 'p' değerlerinin doğrusal bir fonksiyonu olarak görür. Matematiksel olarak şu şekilde yazılabilir -

$$y_{t} = \:C+\:\phi_{1}y_{t-1}\:+\:\phi_{2}Y_{t-2}+...+\phi_{p}y_{t-p}+\epsilon_{t}$$

 

Nerede, 'p' otomatik gerileyen eğilim parametresidir

$\epsilon_{t}$ beyaz gürültü ve

$y_{t-1}, y_{t-2}\:\: ...y_{t-p}$ önceki zaman dönemlerindeki değişkenin değerini gösterir.

P'nin değeri çeşitli yöntemler kullanılarak kalibre edilebilir. 'P'nin apt değerini bulmanın bir yolu, otomatik korelasyon grafiğini çizmektir.

Note- Veriler üzerinde herhangi bir analiz yapmadan önce verileri eğitime ayırmalı ve mevcut toplam verilerin 8: 2 oranında test etmeliyiz çünkü test verileri yalnızca modelimizin doğruluğunu bulmak içindir ve varsayım, bizim için mevcut değildir. tahminler yapıldıktan sonrasına kadar. Zaman serileri söz konusu olduğunda, veri noktalarının sırası çok önemlidir, bu nedenle verilerin bölünmesi sırasında sırayı kaybetmemek akılda tutulmalıdır.

Bir oto-korelasyon grafiği veya bir korelogram, bir değişkenin önceki zaman adımlarında kendisiyle olan ilişkisini gösterir. Pearson korelasyonunu kullanır ve korelasyonları% 95 güven aralığında gösterir. Verilerimizin 'sıcaklık' değişkeni için nasıl göründüğüne bakalım.

ACP gösteriliyor

[141] 'de:

split = len(df) - int(0.2*len(df))
train, test = df['T'][0:split], df['T'][split:]

[142] 'de:

from statsmodels.graphics.tsaplots import plot_acf

plot_acf(train, lags = 100)
plt.show()

Gölgeli mavi bölgenin dışında kalan tüm gecikme değerlerinin bir karşılıklı ilişkiye sahip olduğu varsayılır.

Durağan bir zaman serisi için, hareketli bir ortalama modeli, bir değişkenin değerini 't' zamanında kendisinden önceki 'q' zaman adımlarından kalan hataların doğrusal bir fonksiyonu olarak görür. Kalan hata, 't' anındaki değer ile önceki değerlerin hareketli ortalamasını karşılaştırarak hesaplanır.

Matematiksel olarak şu şekilde yazılabilir -

$$y_{t} = c\:+\:\epsilon_{t}\:+\:\theta_{1}\:\epsilon_{t-1}\:+\:\theta_{2}\:\epsilon_{t-2}\:+\:...+:\theta_{q}\:\epsilon_{t-q}\:$$

Burada 'q' hareketli ortalama eğilim parametresidir

$\epsilon_{t}$ beyaz gürültü ve

$\epsilon_{t-1}, \epsilon_{t-2}...\epsilon_{t-q}$ önceki dönemlerdeki hata terimleridir.

'Q' değeri, çeşitli yöntemler kullanılarak kalibre edilebilir. 'Q'nun apt değerini bulmanın bir yolu, kısmi oto-korelasyon grafiğini çizmektir.

Kısmi bir oto-korelasyon grafiği, doğrudan ve dolaylı korelasyonları gösteren oto-korelasyon grafiğinin aksine, dolaylı korelasyonların kaldırıldığı önceki zaman adımlarında bir değişkenin kendisiyle ilişkisini gösterir, bakalım bizim 'sıcaklık' değişkenimizin nasıl göründüğünü veri.

PACP gösteriliyor

[143] içinde:

from statsmodels.graphics.tsaplots import plot_pacf

plot_pacf(train, lags = 100)
plt.show()

Kısmi bir oto-korelasyon, bir korelogram ile aynı şekilde okunur.

Durağan bir zaman serisi için 't' zamanındaki bir değişkenin, önceki gözlemlerin veya artık hataların doğrusal bir fonksiyonu olduğunu zaten anladık. Bu nedenle, ikisini birleştirme ve Otomatik gerilimli hareketli ortalama (ARMA) modeline sahip olma zamanı.

Bununla birlikte, zaman serileri durağan değildir, yani ortalama, varyans gibi bir serinin istatistiksel özellikleri zamanla değişir. Şimdiye kadar incelediğimiz istatistiksel modeller, zaman serilerinin durağan olduğunu varsaymaktadır, bu nedenle, onu durağan hale getirmek için zaman serilerini farklılaştıran bir ön işleme adımı ekleyebiliriz. Şimdi uğraştığımız zaman serilerinin durağan olup olmadığını öğrenmek bizim için önemli.

Bir zaman serisinin durağanlığını bulmanın çeşitli yöntemleri, zaman serilerinin planında mevsimsellik veya eğilim arar, çeşitli zaman dönemleri için ortalama ve varyans farkını kontrol eder, Augmented Dickey-Fuller (ADF) testi, KPSS testi, Hurst üssü vb. .

Veri setimizin 'sıcaklık' değişkeninin durağan bir zaman serisi olup olmadığını ADF testi kullanıp kullanmadığını görelim.

[74] 'te:

from statsmodels.tsa.stattools import adfuller

result = adfuller(train)
print('ADF Statistic: %f' % result[0])
print('p-value: %f' % result[1])
print('Critical Values:')
for key, value In result[4].items()
   print('\t%s: %.3f' % (key, value))

ADF İstatistiği: -10.406056

p-değeri: 0.000000

Kritik Değerler:

% 1: -3.431

% 5: -2.862

% 10: -2,567

Artık ADF testini çalıştırdığımıza göre, sonucu yorumlayalım. Önce ADF İstatistiğini kritik değerlerle karşılaştıracağız, daha düşük bir kritik değer bize serinin büyük olasılıkla durağan olmadığını söyler. Sonra, p değerini görüyoruz. 0.05'ten büyük bir p değeri ayrıca zaman serisinin durağan olmadığını gösterir.

Alternatif olarak, 0,05'ten küçük veya eşit p değeri veya kritik değerlerden daha düşük ADF İstatistiği, zaman serilerinin sabit olduğunu gösterir.

Dolayısıyla, uğraştığımız zaman serileri zaten durağan. Durağan zaman serileri durumunda, 'd' parametresini 0 olarak ayarlıyoruz.

Hurst üssünü kullanarak zaman serilerinin durağanlığını da doğrulayabiliriz.

[75] içinde:

import hurst

H, c,data = hurst.compute_Hc(train)
print("H = {:.4f}, c = {:.4f}".format(H,c))

H = 0.1660, c = 5.0740

H <0,5 değeri, kalıcı olmayan davranışı gösterir ve H> 0,5, kalıcı davranışı veya bir trend serisini gösterir. H = 0.5 rastgele yürüyüş / Brown hareketini gösterir. Serimizin durağan olduğunu doğrulayan H <0.5 değeri.

Durağan olmayan zaman serileri için, 'd' parametresini 1 olarak ayarladık. Ayrıca, otomatik gerilimli trend parametresi 'p' ve hareketli ortalama trend parametresi 'q', durağan zaman serileri üzerinde hesaplanır, örn. Zaman serilerini farklılaştırdıktan sonra ACP ve PACP.

3 parametre (p, d, q) ile karakterize edilen ARIMA Modeli artık bizim için anlaşılır, öyleyse zaman serimizi modelleyelim ve gelecekteki sıcaklık değerlerini tahmin edelim.

[156] 'da:

from statsmodels.tsa.arima_model import ARIMA

model = ARIMA(train.values, order=(5, 0, 2))
model_fit = model.fit(disp=False)

[157] 'de:

predictions = model_fit.predict(len(test))
test_ = pandas.DataFrame(test)
test_['predictions'] = predictions[0:1871]

[158] 'de:

plt.plot(df['T'])
plt.plot(test_.predictions)
plt.show()

[167] 'de:

error = sqrt(metrics.mean_squared_error(test.values,predictions[0:1871]))
print ('Test RMSE for ARIMA: ', error)

ARIMA için RMSE'yi test edin: 43.21252940234892

Bir önceki bölümde, ARIMA modelinin nasıl çalıştığını ve mevsimsel verileri veya çok değişkenli zaman serilerini işleyememesi konusundaki sınırlamalarını şimdi gördük ve bu nedenle, bu özellikleri içeren yeni modeller tanıtıldı.

Bu yeni modellere bir bakış burada verilmiştir -

Vektör Otomatik Regresyon (VAR)

Çok değişkenli durağan zaman serileri için otomatik regresyon modelinin genelleştirilmiş bir versiyonudur. 'P' parametresi ile karakterizedir.

Vektör Hareketli Ortalama (VMA)

Çok değişkenli durağan zaman serileri için hareketli ortalama modelinin genelleştirilmiş bir versiyonudur. 'Q' parametresi ile karakterizedir.

Vektör Otomatik Regresyon Hareketli Ortalama (VARMA)

VAR ve VMA'nın birleşimi ve çok değişkenli durağan zaman serileri için ARMA modelinin genelleştirilmiş bir versiyonudur. 'P' ve 'q' parametreleri ile karakterizedir. Benzer şekilde, ARMA, 'q' parametresini 0 olarak ayarlayarak bir AR modeli gibi davranabilir ve 'p' parametresini 0 olarak ayarlayarak bir MA modeli olarak hareket edebilir, VARMA da 'q' parametresini ayarlayarak bir VAR modeli gibi davranabilir. 0 olarak ve 'p' parametresini 0 olarak ayarlayarak bir VMA modeli olarak.

[209] 'da:

df_multi = df[['T', 'C6H6(GT)']]
split = len(df) - int(0.2*len(df))
train_multi, test_multi = df_multi[0:split], df_multi[split:]

[211] 'de:

from statsmodels.tsa.statespace.varmax import VARMAX

model = VARMAX(train_multi, order = (2,1))
model_fit = model.fit()
c:\users\naveksha\appdata\local\programs\python\python37\lib\site-packages\statsmodels\tsa\statespace\varmax.py:152: 
   EstimationWarning: Estimation of VARMA(p,q) models is not generically robust, 
   due especially to identification issues. 
   EstimationWarning)
c:\users\naveksha\appdata\local\programs\python\python37\lib\site-packages\statsmodels\tsa\base\tsa_model.py:171: 
   ValueWarning: No frequency information was provided, so inferred frequency H will be used. 
  % freq, ValueWarning)
c:\users\naveksha\appdata\local\programs\python\python37\lib\site-packages\statsmodels\base\model.py:508: 
   ConvergenceWarning: Maximum Likelihood optimization failed to converge. Check mle_retvals 
  "Check mle_retvals", ConvergenceWarning)

[213] içinde:

predictions_multi = model_fit.forecast( steps=len(test_multi))
c:\users\naveksha\appdata\local\programs\python\python37\lib\site-packages\statsmodels\tsa\base\tsa_model.py:320: 
   FutureWarning: Creating a DatetimeIndex by passing range endpoints is deprecated.  Use `pandas.date_range` instead.
   freq = base_index.freq)
c:\users\naveksha\appdata\local\programs\python\python37\lib\site-packages\statsmodels\tsa\statespace\varmax.py:152: 
   EstimationWarning: Estimation of VARMA(p,q) models is not generically robust, due especially to identification issues.
   EstimationWarning)

[231] içinde:

plt.plot(train_multi['T'])
plt.plot(test_multi['T'])
plt.plot(predictions_multi.iloc[:,0:1], '--')
plt.show()

plt.plot(train_multi['C6H6(GT)'])
plt.plot(test_multi['C6H6(GT)'])
plt.plot(predictions_multi.iloc[:,1:2], '--')
plt.show()

Yukarıdaki kod, VARMA modelinin çok değişkenli zaman serilerini modellemek için nasıl kullanılabileceğini gösterir, ancak bu model verilerimiz için en uygun olmayabilir.

Dışsal Değişkenlerle VARMA (VARMAX)

Bu, ilgilendiğimiz birincil değişkeni modellemek için ortak değişken adı verilen ekstra değişkenlerin kullanıldığı VARMA modelinin bir uzantısıdır.

Mevsimsel Otomatik Regresif Entegre Hareketli Ortalama (SARIMA)

Bu, ARIMA modelinin mevsimsel verilerle ilgilenen uzantısıdır. Verileri mevsimsel ve mevsimsel olmayan bileşenlere ayırır ve benzer bir şekilde modeller. Mevsimsel olmayan kısım (p, d, q) parametreleri için ARIMA modeli ile aynı ve mevsimsel kısım (P, D, Q, m) parametreleri için 7 parametre ile karakterize edilir, burada 'm' mevsimsel dönemlerin sayısıdır ve P, D, Q, ARIMA modelinin parametrelerine benzer. Bu parametreler, ızgara araması veya genetik algoritma kullanılarak kalibre edilebilir.

Dışsal Değişkenlerle SARIMA (SARIMAX)

Bu, SARIMA modelinin, ilgilendiğimiz değişkeni modellememize yardımcı olan dışsal değişkenleri içerecek bir uzantısıdır.

Değişkenleri dışsal değişkenler olarak koymadan önce, değişkenler üzerinde bir eş-ilişki analizi yapmak faydalı olabilir.

[251] içinde:

from scipy.stats.stats import pearsonr
x = train_multi['T'].values
y = train_multi['C6H6(GT)'].values

corr , p = pearsonr(x,y)
print ('Corelation Coefficient =', corr,'\nP-Value =',p)
Corelation Coefficient = 0.9701173437269858
P-Value = 0.0

Pearson Korelasyonu 2 değişken arasında doğrusal bir ilişki gösterir, sonuçları yorumlamak için önce p değerine bakarız, 0,05'ten düşükse katsayı değeri anlamlıdır, aksi takdirde katsayı değeri anlamlı değildir. Anlamlı p-değeri için, pozitif bir korelasyon katsayısı değeri pozitif korelasyonu gösterir ve negatif bir değer negatif bir korelasyonu gösterir.

Dolayısıyla, verilerimiz için 'sıcaklık' ve 'C6H6' oldukça pozitif bir korelasyona sahip gibi görünüyor. Bu nedenle yapacağız

[297] 'de:

from statsmodels.tsa.statespace.sarimax import SARIMAX

model = SARIMAX(x, exog = y, order = (2, 0, 2), seasonal_order = (2, 0, 1, 1), enforce_stationarity=False, enforce_invertibility = False)
model_fit = model.fit(disp = False)
c:\users\naveksha\appdata\local\programs\python\python37\lib\site-packages\statsmodels\base\model.py:508: 
   ConvergenceWarning: Maximum Likelihood optimization failed to converge. Check mle_retvals
   "Check mle_retvals", ConvergenceWarning)

[298] 'de:

y_ = test_multi['C6H6(GT)'].values
predicted = model_fit.predict(exog=y_)
test_multi_ = pandas.DataFrame(test)
test_multi_['predictions'] = predicted[0:1871]

[299] 'da:

plt.plot(train_multi['T'])
plt.plot(test_multi_['T'])
plt.plot(test_multi_.predictions, '--')

Çıkış [299]:

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

Tek değişkenli ARIMA modellemesinin aksine, buradaki tahminler şimdi daha büyük varyasyonlar alıyor gibi görünüyor.

Söylemeye gerek yok, SARIMAX, yalnızca karşılık gelen parametreleri sıfır olmayan değerlere ayarlayarak bir ARX, MAX, ARMAX veya ARIMAX modeli olarak kullanılabilir.

Kesirli Otomatik Regresif Entegre Hareketli Ortalama (FARIMA)

Zaman zaman serimiz sabit olmayabilir, ancak 1 değerini alan 'd' parametresiyle farklılaşmak onu fazla farklılaştırabilir. Bu nedenle, zaman serilerini kesirli bir değer kullanarak fark etmemiz gerekiyor.

Veri bilimi dünyasında tek bir üstün model yoktur, verileriniz üzerinde çalışan model büyük ölçüde veri kümenize bağlıdır. Çeşitli modellerin bilgisi, verilerimiz üzerinde çalışan birini seçmemize ve en iyi sonuçları elde etmek için bu modeli denememize olanak tanır. Ve sonuçlar, hata ölçütlerinin yanı sıra olay örgüsü olarak görülmelidir, bazen küçük bir hata da kötü olabilir, bu nedenle sonuçların grafiğini çizmek ve görselleştirmek önemlidir.

Bir sonraki bölümde, başka bir istatistiksel modele, üstel yumuşatmaya bakacağız.

Bu bölümde, zaman serilerinin üstel yumuşatılmasında yer alan tekniklerden bahsedeceğiz.

Basit Üstel Düzeltme

Üstel Yumuşatma, bir zaman periyodu boyunca verilere katlanarak azalan ağırlıklar atayarak tek değişkenli zaman serilerini yumuşatmak için kullanılan bir tekniktir.

Matematiksel olarak, 't + 1' anındaki değişkenin değeri t zamanında değer verildiğinde, y_ (t + 1 | t) - olarak tanımlanır

$$y_{t+1|t}\:=\:\alpha y_{t}\:+\:\alpha\lgroup1 -\alpha\rgroup y_{t-1}\:+\alpha\lgroup1-\alpha\rgroup^{2}\:y_{t-2}\:+\:...+y_{1}$$

nerede,$0\leq\alpha \leq1$ yumuşatma parametresidir ve

$y_{1},....,y_{t}$ 1, 2, 3,…, t zamanlarında ağ trafiğinin önceki değerleridir.

Bu, net bir eğilim veya mevsimsellik olmadan bir zaman serisini modellemek için basit bir yöntemdir. Ancak üstel yumuşatma, trend ve mevsimsellik içeren zaman serileri için de kullanılabilir.

Üçlü Üstel Yumuşatma

Üçlü Üstel Yumuşatma (TES) veya Holt'un Kış yöntemi, üstel yumuşatma işlemini üç kez uygular - seviyeli yumuşatma $l_{t}$, trend yumuşatma $b_{t}$ve mevsimsel yumuşatma $S_{t}$, ile $\alpha$, $\beta^{*}$ ve $\gamma$ mevsimsellik sıklığı olarak 'm' ile parametreleri yumuşatma olarak, yani bir yıldaki mevsim sayısı.

Mevsimsel bileşenin niteliğine göre, TES'in iki kategorisi vardır -

  • Holt-Winter's Additive Method - Mevsimsellik doğada katkı maddesi olduğunda.

  • Holt-Winter’s Multiplicative Method - Mevsimsellik doğası gereği çoğaldığında.

Mevsimsel olmayan zaman serileri için, Holt'un Doğrusal Trend Yöntemi olarak adlandırılan, yalnızca trend yumuşatma ve seviye yumuşatma sahibiyiz.

Verilerimize üçlü üstel yumuşatma uygulamayı deneyelim.

[316] 'da:

from statsmodels.tsa.holtwinters import ExponentialSmoothing

model = ExponentialSmoothing(train.values, trend= )
model_fit = model.fit()

[322] 'de:

predictions_ = model_fit.predict(len(test))

[325] içinde:

plt.plot(test.values)
plt.plot(predictions_[1:1871])

Çıkış [325]:

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

Burada bir kez eğitim seti ile modeli eğittik ve ardından tahminler yapmaya devam ediyoruz. Daha gerçekçi bir yaklaşım, modeli bir veya daha fazla zaman adımından sonra yeniden eğitmektir. Eğitim verilerinden 't + 1' zaman tahminini 't'ye kadar' zamana kadar aldığımızda, 't + 2' için bir sonraki tahmin, 't + 1' zamanına kadar gerçek olarak eğitim verisi kullanılarak yapılabilir. 't + 1'deki değer o zaman bilinecektir. Gelecekteki bir veya daha fazla adım için tahminler yapmak ve ardından modeli yeniden eğitmek için kullanılan bu metodolojiye sıralı tahmin veya ileriye dönük doğrulama adı verilir.

Zaman serisi modellemede, zamanla tahminler gittikçe daha az doğru hale gelir ve bu nedenle, daha fazla tahmin için kullanılabilir hale geldikçe modeli gerçek verilerle yeniden eğitmek daha gerçekçi bir yaklaşımdır. İstatistiksel modellerin eğitimi zaman alıcı olmadığından, ileriye dönük doğrulama, en doğru sonuçları elde etmek için en çok tercih edilen çözümdür.

Verilerimize bir adım ileriye dönük doğrulama uygulayalım ve daha önce aldığımız sonuçlarla karşılaştıralım.

[333] içinde:

prediction = []
data = train.values
for t In test.values:
   model = (ExponentialSmoothing(data).fit())
   y = model.predict()
   prediction.append(y[0])
   data = numpy.append(data, t)

[335] içinde:

test_ = pandas.DataFrame(test)
test_['predictionswf'] = prediction

[341] 'de:

plt.plot(test_['T'])
plt.plot(test_.predictionswf, '--')
plt.show()

[340] 'da:

error = sqrt(metrics.mean_squared_error(test.values,prediction))
print ('Test RMSE for Triple Exponential Smoothing with Walk-Forward Validation: ', error)
Test RMSE for Triple Exponential Smoothing with Walk-Forward Validation:  11.787532205759442

Modelimizin şimdi önemli ölçüde daha iyi performans gösterdiğini görebiliyoruz. Aslında, eğilim o kadar yakından takip ediliyor ki, arsa üzerinde tahminler gerçek değerlerle örtüşüyor. ARIMA modellerinde de önden onaylı doğrulama uygulamayı deneyebilirsiniz.

2017'de Facebook açık kaynaklı peygamber modelini gün düzeyinde, hafta düzeyinde, yıl düzeyinde vb.Güçlü çoklu mevsimliklere ve trendlere sahip zaman serilerini modelleyebildi. Uzman olmayan bir veri bilimcisinin daha iyi tahminler için ayarlayabileceği sezgisel parametrelere sahiptir. Özünde, zaman serilerini modellemek için değişim noktalarını tespit edebilen ek bir gerileme modelidir.

Peygamber, zaman serilerini trendin bileşenlerine ayırır $g_{t}$, mevsimsellik $S_{t}$ ve tatiller $h_{t}$.

$$y_{t}=g_{t}+s_{t}+h_{t}+\epsilon_{t}$$

Nerede, $\epsilon_{t}$ hata terimidir.

Nedensel etki ve anormallik tespiti gibi zaman serisi tahmini için benzer paketler, sırasıyla google ve twitter tarafından R'de tanıtıldı.

Şimdi, zaman serilerinde istatistiksel modellemeye aşinayız, ancak makine öğrenimi şu anda çok popüler, bu nedenle bazı makine öğrenimi modellerine aşina olmak da çok önemli. Zaman serisi alanındaki en popüler model olan Uzun Kısa Süreli Bellek modeli ile başlayacağız.

LSTM, tekrarlayan bir sinir ağı sınıfıdır. Bu yüzden, LSTM'ye geçmeden önce, sinir ağlarını ve tekrarlayan sinir ağlarını anlamak çok önemlidir.

Nöral ağlar

Yapay sinir ağı, biyolojik sinir ağlarından esinlenen, birbirine bağlı nöronların katmanlı bir yapısıdır. Tek bir algoritma değil, veriler üzerinde karmaşık işlemler yapmamızı sağlayan çeşitli algoritmaların kombinasyonlarıdır.

Tekrarlayan Sinir Ağları

Zamansal verilerle başa çıkmak için uyarlanmış bir sinir ağları sınıfıdır. RNN'nin nöronları bir hücre durumuna / belleğine sahiptir ve girdi, sinir ağındaki döngülerin yardımıyla elde edilen bu iç duruma göre işlenir. RNN'lerde, bilgileri tutmalarına izin veren yinelenen 'tanh' katmanı modülleri vardır. Ancak uzun süredir değil, bu yüzden LSTM modellerine ihtiyacımız var.

LSTM

Verilerdeki uzun vadeli bağımlılıkları öğrenebilen özel bir tür tekrarlayan sinir ağıdır. Bu, modelin tekrar eden modülünün birbiriyle etkileşime giren dört katmanın bir kombinasyonuna sahip olması nedeniyle elde edilir.

Yukarıdaki resim sarı kutulardaki dört sinir ağı katmanını, yeşil çemberler içindeki noktasal operatörleri, sarı çemberlerle girdileri ve mavi çemberlerdeki hücre durumunu gösteriyor. Bir LSTM modülünün bir hücre durumu ve ünitelerin her birinden gelen bilgileri seçmeli olarak öğrenme, öğrenmeyi geri alma veya saklama gücü sağlayan üç kapısı vardır. LSTM'deki hücre durumu, yalnızca birkaç doğrusal etkileşime izin vererek bilgilerin değişmeden birimlerden geçmesine yardımcı olur. Her birim, bilgiyi hücre durumuna ekleyebilen veya çıkarabilen bir giriş, çıkış ve bir unutma geçidine sahiptir. Unutma geçidi, önceki hücre durumundan hangi bilgilerin bir sigmoid işlevi kullandığı unutulacağına karar verir. Giriş kapısı, sırasıyla 'sigmoid' ve 'tanh' noktasal çarpma işlemini kullanarak mevcut hücre durumuna bilgi akışını kontrol eder. Son olarak, çıkış kapısı hangi bilgilerin bir sonraki gizli duruma aktarılması gerektiğine karar verir.

Artık LSTM modelinin iç işleyişini anladığımıza göre, onu uygulayalım. LSTM'nin uygulanmasını anlamak için basit bir örnekle başlayacağız - düz bir çizgi. Bakalım, LSTM düz bir çizginin ilişkisini öğrenip tahmin edebiliyor mu?

Önce düz bir çizgiyi gösteren veri setini oluşturalım.

[402] 'de:

x = numpy.arange (1,500,1)
y = 0.4 * x + 30
plt.plot(x,y)

Çıkış [402]:

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

[403] içinde:

trainx, testx = x[0:int(0.8*(len(x)))], x[int(0.8*(len(x))):]
trainy, testy = y[0:int(0.8*(len(y)))], y[int(0.8*(len(y))):]
train = numpy.array(list(zip(trainx,trainy)))
test = numpy.array(list(zip(trainx,trainy)))

Artık veriler oluşturulmuş ve eğitim ve test olarak ayrılmıştır. Zaman serisi verilerini, geriye dönüp bakma süresinin değerine göre denetimli öğrenme verileri biçimine çevirelim; bu, esasen 't' anındaki değeri tahmin ettiği görülen gecikme sayısıdır.

Yani bunun gibi bir zaman serisi -

time variable_x
t1  x1
t2  x2
 :   :
 :   :
T   xT

Yeniden inceleme süresi 1 olduğunda, şu değere dönüştürülür -

x1   x2
x2   x3
 :    :
 :    :
xT-1 xT

[404] içinde:

def create_dataset(n_X, look_back):
   dataX, dataY = [], []
   for i in range(len(n_X)-look_back):
      a = n_X[i:(i+look_back), ]
      dataX.append(a)
      dataY.append(n_X[i + look_back, ])
   return numpy.array(dataX), numpy.array(dataY)

[405] içinde:

look_back = 1
trainx,trainy = create_dataset(train, look_back)
testx,testy = create_dataset(test, look_back)

trainx = numpy.reshape(trainx, (trainx.shape[0], 1, 2))
testx = numpy.reshape(testx, (testx.shape[0], 1, 2))

Şimdi modelimizi eğiteceğiz.

Küçük grup eğitim verileri ağa gösterilir; eğitim verilerinin tamamı modele gruplar halinde gösterildiğinde ve hata hesaplandığında bir çalıştırma dönem olarak adlandırılır. Devirler, hatanın azaldığı zamana kadar çalıştırılacaktır.

İçinde [ ]:

from keras.models import Sequential
from keras.layers import LSTM, Dense

model = Sequential()
model.add(LSTM(256, return_sequences = True, input_shape = (trainx.shape[1], 2)))
model.add(LSTM(128,input_shape = (trainx.shape[1], 2)))
model.add(Dense(2))
model.compile(loss = 'mean_squared_error', optimizer = 'adam')
model.fit(trainx, trainy, epochs = 2000, batch_size = 10, verbose = 2, shuffle = False)
model.save_weights('LSTMBasic1.h5')

[407] 'de:

model.load_weights('LSTMBasic1.h5')
predict = model.predict(testx)

Şimdi tahminlerimizin neye benzediğini görelim.

[408] 'de:

plt.plot(testx.reshape(398,2)[:,0:1], testx.reshape(398,2)[:,1:2])
plt.plot(predict[:,0:1], predict[:,1:2])

Çıkış [408]:

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

Şimdi, benzer bir şekilde bir sinüs veya kosinüs dalgasını modellemeye çalışmalıyız. Sonuçların nasıl değiştiğini görmek için aşağıda verilen kodu çalıştırabilir ve model parametreleriyle oynayabilirsiniz.

[409] 'da:

x = numpy.arange (1,500,1)
y = numpy.sin(x)
plt.plot(x,y)

Çıkış [409]:

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

[410] içinde:

trainx, testx = x[0:int(0.8*(len(x)))], x[int(0.8*(len(x))):]
trainy, testy = y[0:int(0.8*(len(y)))], y[int(0.8*(len(y))):]
train = numpy.array(list(zip(trainx,trainy)))
test = numpy.array(list(zip(trainx,trainy)))

[411] içinde:

look_back = 1
trainx,trainy = create_dataset(train, look_back)
testx,testy = create_dataset(test, look_back)
trainx = numpy.reshape(trainx, (trainx.shape[0], 1, 2))
testx = numpy.reshape(testx, (testx.shape[0], 1, 2))

İçinde [ ]:

model = Sequential()
model.add(LSTM(512, return_sequences = True, input_shape = (trainx.shape[1], 2)))
model.add(LSTM(256,input_shape = (trainx.shape[1], 2)))
model.add(Dense(2))
model.compile(loss = 'mean_squared_error', optimizer = 'adam')
model.fit(trainx, trainy, epochs = 2000, batch_size = 10, verbose = 2, shuffle = False)
model.save_weights('LSTMBasic2.h5')

[413] içinde:

model.load_weights('LSTMBasic2.h5')
predict = model.predict(testx)

[415] içinde:

plt.plot(trainx.reshape(398,2)[:,0:1], trainx.reshape(398,2)[:,1:2])
plt.plot(predict[:,0:1], predict[:,1:2])

Çıkış [415]:

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

Artık herhangi bir veri kümesine geçmeye hazırsınız.

Geri bildirim ve karşılaştırma olarak kullanmak için bir modelin performansını ölçmek bizim için önemlidir. Bu eğiticide, en popüler hata metrik kökü ortalama karesel hatalardan birini kullandık. Çeşitli başka hata ölçümleri mevcuttur. Bu bölüm bunları kısaca tartışmaktadır.

Ortalama Kare Hatası

Tahmin edilen değerler ile gerçek değerler arasındaki farkın karesinin ortalamasıdır. Sklearn bunu bir işlev olarak sağlar. Doğru ve tahmin edilen değerlerin karesi ile aynı birimlere sahiptir ve her zaman pozitiftir.

$$MSE = \frac{1}{n} \displaystyle\sum\limits_{t=1}^n \lgroup y'_{t}\:-y_{t}\rgroup^{2}$$

Nerede $y'_{t}$ tahmin edilen değerdir

$y_{t}$ gerçek değerdir ve

n, test setindeki toplam değer sayısıdır.

Denklemden, MSE'nin daha büyük hatalar veya aykırı değerler için daha fazla cezalandırıcı olduğu açıktır.

Kök Ortalama Kare Hatası

Ortalama kare hatasının kareköküdür. Aynı zamanda her zaman pozitiftir ve veri aralığındadır.

$$RMSE = \sqrt{\frac{1}{n} \displaystyle\sum\limits_{t=1}^n \lgroup y'_{t}-y_{t}\rgroup ^2}$$

Nerede, $y'_{t}$ tahmin edilen değer

$y_{t}$ gerçek değerdir ve

n, test setindeki toplam değer sayısıdır.

Birliğin gücündedir ve bu nedenle MSE'ye kıyasla daha yorumlanabilir. RMSE ayrıca daha büyük hatalar için daha fazla cezalandırıcıdır. Eğitimimizde RMSE metriğini kullandık.

Ortalama Mutlak Hata

Tahmin edilen değerler ile gerçek değerler arasındaki mutlak farkın ortalamasıdır. Tahmin edilen ve gerçek değer ile aynı birimlere sahiptir ve her zaman pozitiftir.

$$MAE = \frac{1}{n}\displaystyle\sum\limits_{t=1}^{t=n} | y'{t}-y_{t}\lvert$$

Nerede, $y'_{t}$ tahmin edilen değerdir,

$y_{t}$ gerçek değerdir ve

n, test setindeki toplam değer sayısıdır.

Ortalama Yüzde Hatası

Tahmin edilen değerler ile gerçek değerler arasındaki ortalama mutlak farkın yüzdesinin gerçek değere bölünmesidir.

$$MAPE = \frac{1}{n}\displaystyle\sum\limits_{t=1}^n\frac{y'_{t}-y_{t}}{y_{t}}*100\: \%$$

Nerede, $y'_{t}$ tahmin edilen değerdir,

$y_{t}$ gerçek değerdir ve n, test setindeki toplam değer sayısıdır.

Bununla birlikte, bu hatayı kullanmanın dezavantajı, pozitif hata ve negatif hataların birbirini dengeleyebilmesidir. Bu nedenle ortalama mutlak yüzde hatası kullanılır.

Ortalama Mutlak Yüzde Hatası

Tahmin edilen değerler ile gerçek değerler arasındaki ortalama mutlak farkın yüzdesinin gerçek değere bölünmesidir.

$$MAPE = \frac{1}{n}\displaystyle\sum\limits_{t=1}^n\frac{|y'_{t}-y_{t}\lvert}{y_{t}}*100\: \%$$

Nerede $y'_{t}$ tahmin edilen değer

$y_{t}$ gerçek değerdir ve

n, test setindeki toplam değer sayısıdır.

Zaman serisi modellerinin önce mevcut gözlemlerden eğilimi ve mevsimselliği tanıdığı ve ardından bu eğilime ve mevsimselliğe dayalı bir değer tahmin ettiği anlayışını bize veren bu eğiticide zaman serisi analizini tartıştık. Bu tür bir analiz, aşağıdakiler gibi çeşitli alanlarda yararlıdır:

  • Financial Analysis - Satış tahmini, envanter analizi, borsa analizi, fiyat tahmini içerir.

  • Weather Analysis - Sıcaklık tahmini, iklim değişikliği, mevsimsel değişim tanıma, hava tahmini içerir.

  • Network Data Analysis - Ağ kullanım tahmini, anormallik veya izinsiz giriş tespiti, kestirimci bakımı içerir.

  • Healthcare Analysis - Nüfus tahmini, sigorta yardımları tahmini, hasta izlemeyi içerir.

Makine öğrenimi, çeşitli problem türleriyle ilgilenir. Aslında, hemen hemen tüm alanların makine öğrenimi yardımıyla otomatikleştirilmesi veya iyileştirilmesi gereken bir kapsamı vardır. Üzerinde çok fazla çalışmanın yapıldığı bu tür sorunlardan birkaçı aşağıda verilmiştir.

Zaman serisi verileri

Bu, zamana göre değişen verilerdir ve bu nedenle, bu eğitimde büyük ölçüde tartıştığımız zaman, bunda önemli bir rol oynar.

Zaman Serisi Dışı Veriler

Zamandan bağımsız verilerdir ve makine öğrenimi sorunlarının büyük bir yüzdesi zaman dışı seri verilerdedir. Basit olması için, bunu şu şekilde daha fazla kategorize edeceğiz:

  • Numerical Data - Bilgisayarlar, insanlardan farklı olarak yalnızca sayıları anlar, bu nedenle her tür veri sonuçta makine öğrenimi için sayısal verilere dönüştürülür, örneğin, görüntü verileri (r, b, g) değerlerine dönüştürülür, karakterler ASCII kodlarına veya kelimelere dönüştürülür sayılara endekslenir, konuşma verileri sayısal veriler içeren mfcc dosyalarına dönüştürülür.

  • Image Data - Bilgisayar görüşü bilgisayar dünyasında devrim yarattı, tıp, uydu görüntüleme vb. Alanlarda çeşitli uygulamalara sahip.

  • Text Data- Doğal Dil İşleme (NLP), metin sınıflandırması, başka sözcüklerle ifade algılama ve dil özetlemesi için kullanılır. Google ve Facebook'u akıllı yapan şey budur.

  • Speech Data- Konuşma İşleme, konuşma tanımayı ve duyguları anlamayı içerir. Bilgisayarlara insan benzeri nitelikler kazandırmada çok önemli bir rol oynar.