Algoritma Unscented Kalman Filter

Algoritma Unscented 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 dan memiliki kedekatan dengan Algoritma Extended Kalman Filter yang sudah dijelaskan sebelumnya. Algoritma ini bekerja dengan menggunakan data sample yang disebut dengan sigma yang kemudian akan dilakukan proses transformasi Unscented untuk mendapatkan estimasi rata-rata dan kovarians non-linier. Langkah perhitungan berikutnya adalah melakukan 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 Unscented Kalman Filter
Penjelasan tentang fungsi ini akan dijelaskan pada perhitungan dibawah ini (poin 3c1 – 3c10)

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

Memasuki perhitungan pada fungsi ukf

3c1. Hitung jumlah elemen dari nilai state dan nilai observasi

L = numel(x);
m = numel(z);

3c2. Tentukan nilai konstanta alpha, beta, dan k1

alpha = 1e-3;
beta = 2;
ki = 0;

3c3. Hitung nilai lambda dan c untuk digunakan sebagai faktor skala

lambda = alpha^2*(L+ki)-L;
c = L+lambda;

3c4. Hitung bobot rata-rata dan bobot kovarians

Wm = [lambda/c 0.5/c+zeros(1,2*L)];
Wc = Wm;
Wc(1) = Wc(1)+(1-alpha^2+beta);

3c5. Lakukan proses perhitungan sigma poin disekitar nilai state
Penjelasan tentang fungsi ini akan dijelaskan pada perhitungan dibawah ini

c=sqrt(c);
X=sigmaPoin(x,P,c);

* Gunakan fungsi ini untuk mendapatkan sigma poin disekitar nilai state yang sedang dihitung

function X=sigmaPoin(x,P,c)
Inputs:
  x: nilai state yang akan dicari sigmanya
  P: kovarians estimasi vektor state
  c: faktor skala
Output:
  X: Sigma poin

A = c*chol(P)';
Y = x(:,ones(1,numel(x)));
X = [x Y+A Y-A]; 

3c6. Lakukan proses transformasi Unscented pada state
Penjelasan tentang fungsi ini akan dijelaskan pada perhitungan dibawah ini

[x1,X1,P1,X2]=Unscented(fstate,X,Wm,Wc,L,Q);

* Gunakan fungsi ini untuk melakukan transformasi Unscented

function [y,Y,P,Y1]=Unscented(fungsi,X,Wm,Wc,n,R)
Input:
  f: fungsi non-linear
  X: sigma poin
 Wm: bobot rata-rata
 Wc: bobot kovarians
  n: jumlah elemen dalam fungsi
  R: kovarians noise
Output:
  y: transformasi rata-rata
  Y: transformasi poin sampling
  P: transformasi kovarians
 Y1: transformasi deviasi

L=size(X,2);
y=zeros(n,1);
Y=zeros(n,L);
for k=1:L                   
    Y(:,k)=fungsi(X(:,k));       
    y=y+Wm(k)*Y(:,k);       
end
Y1=Y-y(:,ones(1,L));
P=Y1*diag(Wc)*Y1'+R;  

3c7. Lakukan proses transformasi Unscented pada data observasi
Penjelasan tentang fungsi Unscented sudah dijelaskan pada perhitungan sebelumnya

[z1,Z1,P2,Z2]=Unscented(hmeas,X1,Wm,Wc,m,R);

3c8. Hitung nilai Kovarians Silang menggunakan data hasil transformasi pada perhitungan sebelumnya

P12=X2*diag(Wc)*Z2';

3c9. Hitung faktor gain Kalman

K=P12*inv(P2);

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

x=x1+K*(z-z1);
P=P1-K*P12';

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 Unscented 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 Unscented 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      , 11
Penggaris  , 1       , 2       , 4       , 12      , 13      , 12

Contoh modul / source code menggunakan Matlab dapat didownload disini:

[sdm_download id=”2262″ 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 *