Milşteyn yöntemi

testwiki sitesinden
Gezinti kısmına atla Arama kısmına atla
Dosya:MilsteinYontemi.png

Matematiğin bir alt dalı olan stokastik analizde Milşteyn yöntemi (ya da Milstein yöntemi) stokastik diferansiyel denklemlere yaklaşık sayısal çözümler üretmek için geliştirilmiş yöntemlerden biridir. Yöntem adını, bu yaklaşıklığı 1974'te yayınlayan Grigori Milşteyn'den (Мильштейн, Г. Н.) almaktadır.[1][2]

Yöntemin açıklaması

Wt, Wiener süreci olsun. Başlangıç koşulu X0 = x0 olan ve

dXt=a(Xt,t)dt+b(Xt,t)dWt,

hâlindeki stokastik bir diferansiyel denklemi [0, T] aralığında sayısal olarak çözmek istediğimizi varsayalım. Stokastik diferansiyel denklemin teorik çözümü X ile gösterilsin. X'in Milstein yaklaşıklığı aşağıdaki gibi kurulup tanımlanan ve bir Markov zinciri olan Ydir.

  • [0, T] aralığını N tane eşit altaralığa bölelim. Her altaralığın uzunluğu Δt>0 ile gösterilsin. O zaman,
0=τ0<τ1<<τN=T ve Δt=T/N
olacaktır.
  • Y0 = x0 tanımlansın.
  • 0 ≤ n ≤ N-1 için ΔWn=Wτn+1Wτn olmak üzere, Yn terimleri yinelemeli olarak
Yn+1=Yn+a(Yn)Δt+b(Yn)ΔWn+12b(Yn)b(Yn)((ΔWn)2Δt)
olarak tanımlansın. Burada, b ile türev, yani, b(x) fonksiyonunun x'e göre türevi, kastedilmiştir. Bahsi geçen ΔWn rasgele değişkenleri bağımsız ve özdeş dağılmış normal rastgele değişkenlerdir. Her birinin beklenen değeri sıfırdır ve her biri Δt varyansına sahiptir.

Yöntemin arkasındaki fikir

Yöntemin arkasındaki esas fikir b(Xt) terimine Ito formülünü uygulayıp daha Euler yaklaşımlığını iyileştirmektir. Elbette, burada, bu terimdeki b fonksiyonun Ito formülünün koşullarına uyması beklenmektedir. Ito formülü ile db(Xt)=b(Xt)dXt+12b(Xt)b2(Xt)dt=[b(Xt)a(Xt)+12b(Xt)b2(Xt)]dt+b(Xt)b(Xt)dWt=μb(Xt)dt+σb(Xt)dWt elde edilir.[3] tut+Δt şartını sağlayan bir u sayısı için, Euler-Maruyama yöntemi kullanılarak, yukarıda elde edilen db(Xt) ifadesine yaklaşım sağlanır. Diğer deyişle, b(Xu)b(Xt)μb(Xt)[ut]+σb(Xt)[WuWt]=b(Xt)[b(Xt)a(Xt)+12b(Xt)b2(Xt)][ut]+b(Xt)b(Xt)[WuWt] yazılabilir. WuWt terimi olasılıkta O(ut) olduğundan ve bu yaklaşıklıktaki sürüklenme O(ut) olduğundan, O(ut) büyümesine sahip terimler düşürülüp b(Xu)b(Xt)+b(Xt)b(Xt)[WuWt],u[t,t+Δt] yazılır. Bu yüzden, tt+Δtb(Xu)dWutt+Δtb(Xt)+b(Xt)b(Xt)[WuWt]dW(u)=b(Xt)[Wt+ΔtWt]+b(Xt)b(Xt)tt+Δt[WuWt]dW(u)=b(Xt)[Wt+ΔtWt]+12b(Xt)b(Xt)[(Wt+ΔtWt)2Δt]. elde edilir. O zaman, Euler yaklaşımlığını biraz daha düzelterek Xt+ΔtXt+a(Xt)Δt+b(Xt)[Wt+ΔtWt]+12b(Xt)b(Xt)[(Wt+ΔtWt)2Δt] yazılır.

Programlama uygulaması

{dYt=μYdt+σYdWtY0=Yilk biçiminde verilmiş olan bir geometrik Brown hareketini sayısal olarak çözmek için Milşteyn yöntemi kullanılabilir.

Rastgele sayıların NumPy tarafından verildiği bir Python programlama kodu aşağıdaki gibi verilebilir:

# -*- coding: utf-8 -*-
import numpy as np
import matplotlib.pyplot as plt
from textwrap import wrap

class Model:
    """Stokastik modelin  sabitleri."""
    MU = 0.05
    SIGMA = 0.2

def dW(dt):
    """Normal rastgele değişken çekilişi"""
    return np.random.normal(loc=0.0, scale=np.sqrt(dt))

def simulasyon(t_i:int, t_s:int, adim_sayisi:int):
    """bir simülasyon yolağı"""
    T_ILK = t_i
    T_SON = t_s
    N = adim_sayisi 
    DT = float(T_SON - T_ILK) / N
    Tler = np.arange(T_ILK, T_SON + DT, DT)
    assert Tler.size == N + 1

    Y_ILK = 1

    yler = np.zeros(Tler.size)
    yler[0] = Y_ILK
    for i in range(1, Tler.size):
        t = (i - 1) * DT
        y = yler[i - 1]
        dw = dW(DT)

        #Milstein yontemindeki gibi terimleri topla
        yler[i] = y + \
            Model.MU * y * DT + \
            Model.SIGMA * y * dw + \
            (Model.SIGMA**2 / 2) * y * (dw**2 - DT)

    return Tler, yler

#Birkaç simülasyonun aynı grafikte çizimi
sim_sayisi=100
# [0, 1] aralığında 5000 zaman adımında hesaplıyoruz
t_i=0#
t_s=1
adim_sayisi=5000
for _ in range(sim_sayisi):
    plt.plot(*simulasyon(t_i, t_s, adim_sayisi))

plt.xlabel("zaman (s)")
plt.ylabel("y")
plt.title("\n".join(wrap(
r"$\mu=$ {} ve $\sigma=$ {} parametreleri verilen bir geometrik Brown hareketinin [{},{}] aralığında {} zaman adımlı Milşteyn yöntemiyle yapılan yaklaşıklamalarının {} yolaklı simülasyonu".format(Model.MU, Model.SIGMA, t_i, t_s, adim_sayisi, sim_sayisi))), fontsize='small')
plt.savefig('Milstein.png', format="png")
plt.show()

Ayrıca bakınız

Kaynakça

Şablon:Kaynakça