Algoritma Extended Kalman Filter

Algoritma Extended Kalman Filter adalah salah satu algoritma yang digunakan untuk memperkirakan hasil berikutnya berdasarkan data-data yang sudah ada sebelumnya. Contoh yang dibahas kali ini adalah mengenai memperkirakan penjualan pada periode berikutnya berdasarkan data penjualan pada periode sebelumnya.
Algoritma ini merupakan pengembangan dari Algoritma Kalman Filter yang sudah dijelaskan sebelumnya. Algoritma ini digunakan dalam permasalahan non-linier, dan yang akan dilakukan algoritma ini adalah melakukan linearisasi pada rata-rata dan kovarians non-linier dan kemudian melakukan proses filter menggunakan variabel tersebut.



Diasumsikan ada 4 data barang yang sudah diketahui hasil penjualannya
Masing-masing barang memiliki data penjualan pada 5 periode sebelumnya
Maka tentukan prediksi penjualan untuk 3 periode berikutnya
Diasumsikan data penjualan adalah sebagai berikut:

Nama Barang Periode1 Periode2 Periode3 Periode4 Periode5
Pensil 10 12 8 11 20
Penghapus 15 12 13 14 14
Pena 9 7 15 15 10
Penggaris 1 2 4 12 13

Langkah pertama adalah memasukkan data-data yang digunakan.
Contoh data awal adalah sebagai berikut:

data=[10 12 8 11 20; ...
      15 12 13 14 14; ...
      9 7 15 15 10; ...
      1 2 4 12 13];



Sebelum masuk kedalam langkah-langkah pembahasan algoritma, ada beberapa konstanta atau parameter yang harus diketahui, yaitu:
* Tentukan jumlah state yang digunakan
State ini merupakan banyak data yang dimasukkan ke dalam fungsi non linier
Diasumsikan dalam kasus ini, jumlah state ada 3 buah

jumlahState = 3;

Langkah-langkah penggunaan algoritma ini adalah

* Lakukan perhitungan pada masing-masing data (poin 1 – 4)

for i=1:size(data,1)
. . .

1. Hitung rata-rata dan standar deviasi dari data yang sedang dihitung
Rata-rata adalah jumlah semua data dibagi dengan jumlah datanya
Standar deviasi adalah akar dari ((kuadrat dari (jumlah dari (data – rata-rata))) / jumlah data)

rata2 = mean(data(i,:));
stdDev = sqrt(sum((data(i,:) - rata2) .^ 2) / jumlahData);

2. Beri nilai awal untuk setiap variabel yang dibutuhkan
Penjelasan lebih lanjut mengenai masing-masing variabel dapat dilihat pada skrip dibawah ini

2a. Kovarians Noise Proses

Q = stdDev^2 * eye(jumlahState); 

2b. Kovarians Noise Observasi

R = stdDev^2;                    

2c. Persamaan Non-linier State
Jumlah Persamaan Non-linier harus sama dengan parameter jumlah state

f = @(x)[x(2); x(3); sqrt(-0.5*x(1)*x(1) + 0.5*x(2)*x(2) + x(3)*x(3))];  

2d. Persamaan Observasi

h = @(x)x(3);

2e. State awal
Jumlah elemen state awal harus sama dengan parameter jumlah state

s = [-1; -1; -1];

2f. Estimasi Vektor State

x = s;

2g. Kovarians Estimasi Vektor State

P = eye(jumlahState);

3. Lakukan perulangan sebanyak jumlah data yang ada (poin 3a – 3c)

for j=1:jumlahData
. . .

3a. Tentukan data observasi yang akan dihitung

z = data(i,k);
%zV(k)  = z;

3b. Lakukan proses update nilai state yang digunakan

s = [s(2); s(3); z];
sV(:,k)= s;

3c. Lakukan proses perhitungan dengan menggunakan metode Extended Kalman Filter
Penjelasan tentang fungsi ini akan dijelaskan pada perhitungan dibawah ini (poin 3c1 – 3c7)

[x, P] = ekf(f,x,P,h,z,Q,R);
xV(:,k) = x;

Memasuki perhitungan pada fungsi ekf

3c1. Lakukan proses linierisasi pada persamaan non-linier pada Estimasi Vektor State sementara

[x1,A]=jacobian(f,x);

* Gunakan fungsi ini untuk melakukan linierisasi pada fungsi non-linier,
Teknik yang digunakan adalah diferensiasi kompleks dengan metode Jacobian

function [z,J]=jacobian(fungsi,x)
% z = f(x)
% J = f'(x)

z = fungsi(x);
n = numel(x);
m = numel(z);
J = zeros(m,n);
h = n*eps;
for k=1:n
    x1 = x;
    x1(k) = x1(k)+h*1i;
    J(:,k) = imag(fungsi(x1))/h;
end

3c2. Hitung nilai Kovarians Estimasi Vektor State sementara

P=A*P*A'+Q;

3c3. Lakukan proses linierisasi pada persamaan non-linier observasi menggunakan nilai state yang sudah dihitung sebelumnya

[z1,H]=jacobian(h,x1);

3c4. Hitung nilai Kovarians silang antara kedua persamaan tersebut

P12=P*H';

3c5. Lakukan faktorisasi menggunakan teknik Cholesky

R=chol(H*P12+R);

3c6. Hitung nilai U dengan cara membagi nilai Kovarians Silang dengan Kovarians Noise Observasi

U=P12/R;

3c7. Hitung nilai akhir dari Estimasi Vektor State dan Kovarians Estimasi Vektor State

x=x1+U*(R'\(z-z1));
P=P-U*U';

4. Nilai prediksi akhir diambil dari nilai Estimasi Transisi State yang sudah dihitung sebelumnya

kf(i) = round(xV(jumlahState, jumlahData),0);

Hasil akhir adalah:

Algoritma Extended Kalman Filter
Contoh: Memperkirakan penjualan pada periode berikutnya berdasarkan data penjualan pada periode sebelumnya
Diasumsikan ada 4 data barang yang sudah diketahui hasil penjualannya
Masing-masing barang memiliki data penjualan pada 5 periode sebelumnya
Maka tentukan prediksi penjualan untuk 3 periode berikutnya
Diasumsikan data penjualan adalah sebagai berikut: 
Nama Barang, Periode1, Periode2, Periode3, Periode4, Periode5
Pensil     , 10      , 12      , 8       , 11      , 20
Penghapus  , 15      , 12      , 13      , 14      , 14
Pena       , 9       , 7       , 15      , 15      , 10
Penggaris  , 1       , 2       , 4       , 12      , 13


Hasil Perhitungan dengan metode Extended Kalman Filter
Nama Barang, Periode1, Periode2, Periode3, Periode4, Periode5, Prediksi Periode berikutnya
Pensil     , 10      , 12      , 8       , 11      , 20      , 17
Penghapus  , 15      , 12      , 13      , 14      , 14      , 14
Pena       , 9       , 7       , 15      , 15      , 10      , 12
Penggaris  , 1       , 2       , 4       , 12      , 13      , 12

Contoh modul / source code menggunakan Matlab dapat didownload disini:

[sdm_download id=”2257″ fancy=”0″]



Jika membutuhkan jasa kami dalam pembuatan program, keterangan selanjutnya dapat dilihat di Fasilitas dan Harga
Jika ada yang kurang paham dengan langkah-langkah algoritma diatas, silahkan berikan komentar Anda.
Selamat mencoba.

Comments

Leave a Reply

Your email address will not be published. Required fields are marked *