Time Series - Model LSTM

Sekarang, kita sudah familiar dengan pemodelan statistik pada deret waktu, namun pembelajaran mesin sedang populer saat ini, jadi penting untuk juga memahami beberapa model pembelajaran mesin. Kita akan mulai dengan model yang paling populer dalam domain deret waktu - Model Memori Jangka Pendek.

LSTM adalah kelas jaringan saraf berulang. Jadi sebelum kita dapat beralih ke LSTM, penting untuk memahami jaringan saraf dan jaringan saraf berulang.

Jaringan Neural

Jaringan saraf tiruan adalah struktur berlapis dari neuron yang terhubung, yang terinspirasi oleh jaringan saraf biologis. Ini bukan hanya satu algoritma tetapi kombinasi dari berbagai algoritma yang memungkinkan kita untuk melakukan operasi kompleks pada data.

Jaringan Neural Berulang

Ini adalah kelas jaringan saraf yang disesuaikan untuk menangani data temporal. Neuron RNN memiliki keadaan sel / memori, dan input diproses sesuai dengan keadaan internal ini, yang dicapai dengan bantuan loop di dalam jaringan saraf. Ada modul berulang dari lapisan 'tanh' di RNN yang memungkinkan mereka untuk menyimpan informasi. Namun, tidak untuk waktu yang lama, itulah sebabnya kami membutuhkan model LSTM.

LSTM

Ini adalah jenis jaringan saraf berulang khusus yang mampu mempelajari ketergantungan jangka panjang dalam data. Ini dicapai karena modul berulang model memiliki kombinasi empat lapisan yang saling berinteraksi.

Gambar di atas menggambarkan empat lapisan jaringan saraf dalam kotak kuning, operator titik bijaksana dalam lingkaran hijau, masukan dalam lingkaran kuning dan keadaan sel dalam lingkaran biru. Modul LSTM memiliki status sel dan tiga gerbang yang memberi mereka kekuatan untuk secara selektif mempelajari, melepaskan atau menyimpan informasi dari masing-masing unit. Status sel di LSTM membantu informasi mengalir melalui unit tanpa diubah dengan hanya mengizinkan beberapa interaksi linier. Setiap unit memiliki input, output, dan gerbang lupa yang dapat menambah atau menghapus informasi ke status sel. Gerbang lupa memutuskan informasi mana dari keadaan sel sebelumnya yang harus dilupakan yang menggunakan fungsi sigmoid. Gerbang masukan mengontrol aliran informasi ke keadaan sel saat ini menggunakan operasi perkalian titik-bijaksana 'sigmoid' dan 'tanh' masing-masing. Akhirnya, gerbang keluaran memutuskan informasi mana yang harus diteruskan ke keadaan tersembunyi berikutnya

Sekarang setelah kita memahami cara kerja internal model LSTM, mari kita terapkan. Untuk memahami penerapan LSTM, kita akan mulai dengan contoh sederhana - garis lurus. Mari kita lihat, apakah LSTM dapat mempelajari hubungan garis lurus dan memprediksinya.

Pertama mari kita buat dataset yang menggambarkan garis lurus.

Dalam [402]:

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

Keluar [402]:

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

Dalam [403]:

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

Sekarang data telah dibuat dan dipecah menjadi train and test. Mari kita ubah data deret waktu ke dalam bentuk data pembelajaran terbimbing sesuai dengan nilai periode lihat-balik, yang pada dasarnya adalah jumlah kelambatan yang terlihat untuk memprediksi nilai pada waktu 't'.

Jadi deret waktu seperti ini -

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

Jika periode lihat-balik adalah 1, diubah menjadi -

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

Dalam [404]:

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)

Dalam [405]:

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

Sekarang kita akan melatih model kita.

Kumpulan kecil data pelatihan ditampilkan ke jaringan, satu proses saat seluruh data pelatihan ditampilkan ke model dalam batch dan kesalahan dihitung disebut epoch. Epochs harus dijalankan sampai saat error berkurang.

Di [ ]:

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

Dalam [407]:

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

Sekarang mari kita lihat seperti apa prediksi kita.

Dalam [408]:

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

Keluar [408]:

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

Sekarang, kita harus mencoba dan membuat model gelombang sinus atau cosinus dengan cara yang serupa. Anda dapat menjalankan kode yang diberikan di bawah ini dan bermain dengan parameter model untuk melihat bagaimana hasil berubah.

Dalam [409]:

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

Keluar [409]:

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

Dalam [410]:

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

Dalam [411]:

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

Di [ ]:

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

Dalam [413]:

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

Dalam [415]:

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

Keluar [415]:

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

Sekarang Anda siap untuk beralih ke kumpulan data apa pun.