Stokastik programlama - Stochastic programming

Nın alanında matematiksel optimizasyon, stokastik programlama için bir çerçevedir modelleme optimizasyon içeren sorunlar belirsizlik. Bir stokastik program bazı veya tüm problem parametrelerinin belirsiz olduğu, ancak bilinenleri takip ettiği bir optimizasyon problemidir olasılık dağılımları[1][2]. Bu çerçeve, tüm problem parametrelerinin tam olarak bilindiğinin varsayıldığı deterministik optimizasyonla çelişir. Stokastik programlamanın amacı, hem karar verici tarafından seçilen bazı kriterleri optimize eden hem de problem parametrelerinin belirsizliğini uygun şekilde açıklayan bir karar bulmaktır. Pek çok gerçek dünya kararı belirsizlik içerdiğinden, stokastik programlama, finans -e ulaşım enerji optimizasyonuna.[3][4]

İki aşamalı sorunlar

İki aşamalı stokastik programlamanın temel fikri, (optimal) kararların, kararların alındığı anda mevcut olan verilere dayanması ve gelecekteki gözlemlere bağlı olmamasıdır. İki aşamalı formülasyon, stokastik programlamada yaygın olarak kullanılmaktadır. İki aşamalı bir stokastik programlama probleminin genel formülasyonu şu şekilde verilir:

nerede ikinci aşama probleminin optimal değeridir

Klasik iki aşamalı doğrusal stokastik programlama problemleri şu şekilde formüle edilebilir:

nerede ikinci aşama probleminin optimal değeridir

Böyle bir formülasyonda ilk aşama karar değişken vektörüdür, ikinci aşama karar değişken vektörüdür ve ikinci aşama probleminin verilerini içerir. Bu formülasyonda, ilk aşamada "şimdi ve burada" bir karar vermeliyiz belirsiz verilerin gerçekleşmesinden önce rastgele bir vektör olarak görüldüğü için bilinir. İkinci aşamada, kullanılabilir olduğunda, uygun bir optimizasyon problemini çözerek davranışımızı optimize ederiz.

İlk aşamada maliyeti optimize ediyoruz (yukarıdaki formülasyonda en aza indiriyoruz) birinci aşama kararın toplamı artı (optimal) ikinci aşama kararının beklenen maliyeti. İkinci aşama problemini basitçe, belirsiz veriler ortaya çıktığında sözde optimal davranışımızı tanımlayan bir optimizasyon problemi olarak görebiliriz veya çözümünü bir başvuru eylemi olarak düşünebiliriz sistemdeki olası bir tutarsızlığı telafi eder ve bu rücu eyleminin maliyetidir.

Dikkate alınan iki aşamalı sorun şudur: doğrusal çünkü amaç fonksiyonları ve kısıtlamalar doğrusaldır. Kavramsal olarak bu gerekli değildir ve daha genel iki aşamalı stokastik programlar düşünülebilir. Örneğin, birinci aşama problemi tamsayı ise, uygulanabilir küme ayrık olacak şekilde birinci aşama probleme integrallik kısıtlamaları eklenebilir. Doğrusal olmayan hedefler ve kısıtlamalar da gerekirse dahil edilebilir.[5]

Dağılım varsayımı

Yukarıdaki iki aşamalı problemin formülasyonu, ikinci aşama verilerinin rastgele bir vektör olarak modellenebilir. bilinen olasılık dağılımı (sadece belirsiz değil). Bu pek çok durumda haklı çıkar. Örneğin, Geçmiş verilerden elde edilen bilgiler olabilir ve dağılım, dikkate alınan süre boyunca önemli ölçüde değişmez. Bu tür durumlarda, gerekli olasılık dağılımı ve optimizasyon güvenilir bir şekilde tahmin edilebilir. ortalamada haklı olabilir büyük sayılar kanunu. Başka bir örnek de çıktıları stokastik olan bir simülasyon modelinin gerçekleşmeleri olabilir. Örneklemin ampirik dağılımı, doğru ancak bilinmeyen çıktı dağılımına bir yaklaşım olarak kullanılabilir.

Ayrıştırma

İki aşamalı stokastik problemi sayısal olarak çözmek için genellikle rasgele vektörün varsayılması gerekir. sınırlı sayıda olası gerçekleşmesi vardır. senaryolar, söyle , ilgili olasılık kütleleri ile . O zaman birinci aşama problemin amaç işlevindeki beklenti, özet olarak yazılabilir:

ve dahası, iki aşamalı problem tek bir büyük doğrusal programlama problemi olarak formüle edilebilir (buna, orijinal problemin deterministik eşdeğeri denir, bkz. § Stokastik bir problemin deterministik eşdeğeri ).

Ne zaman sonsuz (veya çok büyük) sayıda olası gerçekleşmeye sahipse, standart yaklaşım bu dağılımı senaryolarla temsil etmektir. Bu yaklaşım üç soruyu gündeme getiriyor:

  1. Senaryolar nasıl oluşturulur, bkz. § Senaryo yapımı;
  2. Deterministik eşdeğer nasıl çözülür. Gibi optimize ediciler CPLEX, GLPK ve Gurobi büyük doğrusal / doğrusal olmayan problemleri çözebilir. NEOS Sunucusu,[6] barındırılan Wisconsin-Madison Üniversitesi, birçok modern çözücüye ücretsiz erişim sağlar. Belirleyici bir eşdeğerin yapısı, özellikle ayrıştırma yöntemlerini uygulamak için uygundur,[7] gibi Bükücülerin ayrışması veya senaryo ayrıştırması;
  3. "Gerçek" optimum ile ilgili olarak elde edilen çözümün kalitesi nasıl ölçülür.

Bu sorular bağımsız değil. Örneğin, oluşturulan senaryoların sayısı hem deterministik eşdeğerin izlenebilirliğini hem de elde edilen çözümlerin kalitesini etkileyecektir.

Stokastik doğrusal programlama

Stokastik doğrusal program klasik iki aşamalı stokastik programın belirli bir örneğidir. Stokastik bir DP, her biri aynı yapıya ancak biraz farklı verilere sahip olan çok dönemli doğrusal programların (LP'ler) bir koleksiyonundan oluşturulur. iki dönem LP, temsil eden senaryo, aşağıdaki biçime sahip olarak kabul edilebilir:

Vektörler ve değerleri hemen seçilmesi gereken ilk dönem değişkenlerini içerir. Vektör sonraki dönemler için tüm değişkenleri içerir. Kısıtlamalar sadece birinci dönem değişkenlerini içerir ve her senaryoda aynıdır. Diğer kısıtlamalar sonraki dönemlerin değişkenlerini içerir ve bazı açılardan senaryodan senaryoya farklılık göstererek geleceğe ilişkin belirsizliği yansıtır.

Unutmayın ki iki dönem DP varsayımına eşdeğerdir belirsizliğin olmadığı ikinci dönemdeki senaryo. İkinci aşamada belirsizlikleri dahil etmek için, olasılıkları farklı senaryolara atamak ve karşılık gelen deterministik eşdeğerini çözmek gerekir.

Stokastik bir problemin deterministik eşdeğeri

Sonlu sayıda senaryo ile, iki aşamalı stokastik doğrusal programlar, büyük doğrusal programlama problemleri olarak modellenebilir. Bu formülasyon genellikle deterministik eşdeğer doğrusal program olarak adlandırılır veya deterministik eşdeğer olarak kısaltılır. (Kesin olarak, deterministik bir eşdeğer, optimum birinci aşama kararını hesaplamak için kullanılabilecek herhangi bir matematiksel programdır, bu nedenle bunlar, ikinci aşama maliyeti kapalı bir biçimde temsil edilebildiğinde, sürekli olasılık dağılımları için de mevcut olacaktır.) Örneğin, yukarıdaki stokastik doğrusal programın deterministik eşdeğerini oluşturmak için bir olasılık atarız her senaryoya . Ardından, tüm senaryoların kısıtlamalarına tabi olarak hedefin beklenen değerini en aza indirebiliriz:

Farklı bir vektörümüz var her senaryo için sonraki dönem değişkenlerinin . İlk dönem değişkenleri ve ancak her senaryoda aynıdır, çünkü hangi senaryonun gerçekleşeceğini bilmeden önce ilk dönem için bir karar vermemiz gerekir. Sonuç olarak, yalnızca içeren kısıtlamalar ve sadece bir kez belirtilmelidir, kalan kısıtlamalar her senaryo için ayrı ayrı verilmelidir.

Senaryo yapımı

Uygulamada, uzmanların geleceğe yönelik görüşlerini alarak senaryolar oluşturmak mümkün olabilir. Oluşturulan senaryoların sayısı, elde edilen deterministik eşdeğerin makul hesaplama çabası ile çözülebilmesi için nispeten az olmalıdır. Yalnızca birkaç senaryoyu kullanan optimal bir çözümün, yalnızca tek bir senaryoyu varsayandan daha uyarlanabilir planlar sağladığı sıklıkla iddia edilir. Bazı durumlarda böyle bir iddia bir simülasyonla doğrulanabilir. Teoride, elde edilen bir çözümün orijinal sorunu makul bir doğrulukla çözdüğüne dair bazı garanti önlemleri. Genellikle uygulamalarda yalnızca ilk aşama en uygun çözüm Pratik bir değere sahiptir çünkü hemen hemen her zaman rastgele verilerin "gerçek" bir gerçekleştirilmesi, oluşturulmuş (oluşturulan) senaryolar kümesinden farklı olacaktır.

Varsayalım içerir Her biri üç olası gerçekleştirme içeren bağımsız rastgele bileşenler (örneğin, her bir rastgele parametrenin gelecekteki gerçekleşmeleri düşük, orta ve yüksek olarak sınıflandırılır), ardından toplam senaryo sayısı . Böyle üstel büyüme çok sayıda senaryo, uzman görüşünü kullanarak model geliştirmeyi makul boyutta bile çok zorlaştırıyor . Durum, bazı rastgele bileşenler halinde daha da kötüleşir. sürekli dağılımlara sahiptir.

Monte Carlo örnekleme ve Örnek Ortalama Yaklaşım (SAA) Yöntemi

Senaryo setini yönetilebilir bir boyuta indirmek için yaygın bir yaklaşım, Monte Carlo simülasyonu kullanmaktır. Toplam senaryo sayısının çok büyük ve hatta sonsuz olduğunu varsayalım. Ayrıca bir örnek oluşturabileceğimizi varsayalım nın-nin rastgele vektörün kopyaları . Genellikle örnek olduğu varsayılır. bağımsız ve aynı şekilde dağıtılmış (i.i.d örneği). Bir örnek verildiğinde, beklenti işlevi örnek ortalamaya göre yaklaşıktır

ve sonuç olarak ilk aşama problemi şu şekilde verilir:

Bu formülasyon, Örnek Ortalama Yaklaşıklık yöntem. SAA problemi, dikkate alınan örneğin bir fonksiyonudur ve bu anlamda rastgeledir. Belirli bir örnek için SAA problemi, senaryolarla iki aşamalı stokastik doğrusal programlama problemi ile aynı formdadır. ., her biri aynı olasılıkla alınır .

İstatiksel sonuç

Aşağıdaki stokastik programlama problemini düşünün

Buraya boş olmayan kapalı bir alt kümesidir , olasılık dağılımı olan rastgele bir vektördür bir sette destekleniyor , ve . İki aşamalı stokastik programlama çerçevesinde, karşılık gelen ikinci aşama probleminin optimal değeri ile verilir.

Varsayalım ki iyi tanımlanmış ve sonlu değerli hepsi için . Bu, her biri için değer neredeyse kesin olarak sonludur.

Bir örneğimiz olduğunu varsayalım nın-nin rastgele vektörün gerçekleşmeleri . Bu rastgele örnek, geçmişe ait veriler olarak görülebilir. gözlemleri veya Monte Carlo örnekleme teknikleriyle oluşturulabilir. O zaman karşılık gelen bir formüle edebiliriz örnek ortalama yaklaşımı

Tarafından Büyük Sayılar Kanunu bazı düzenlilik koşulları altında buna sahibiz 1 olasılıkla noktasal olarak yakınsar gibi . Ayrıca, hafif ek koşullar altında yakınsama tek tiptir. Ayrıca buna sahibiz yani bir tarafsız tahmincisi . Bu nedenle, SAA probleminin optimal değerinin ve optimal çözümlerinin, gerçek problemin muadillerine yakınsamasını beklemek doğaldır. .

SAA tahmin edicilerinin tutarlılığı

Olası seti varsayalım SAA sorununun giderilmesi, yani numuneden bağımsızdır. İzin Vermek ve sırasıyla, gerçek sorunun optimal değeri ve optimal çözümler kümesi olsun ve ve SAA probleminin sırasıyla optimal değeri ve optimal çözümler kümesi olabilir.

  1. İzin Vermek ve (deterministik) gerçek değerli fonksiyonların bir dizisi olabilir. Aşağıdaki iki özellik eşdeğerdir:
    • herhangi ve herhangi bir sıra yakınsak onu takip eder yakınsamak
    • işlev sürekli ve yakınsamak üniform olarak herhangi bir kompakt alt kümesinde
  2. SAA sorununun amacı gerçek sorunun amacına yaklaşır olasılıkla 1 uygun sette eşit olarak . Sonra yakınsamak 1 olasılıkla .
  3. Kompakt bir küme olduğunu varsayalım öyle ki
    • set gerçek problemin optimal çözümlerinin boş olmamasıdır ve
    • işlev sonlu değerlidir ve sürekli
    • fonksiyonların sırası yakınsamak olasılıkla 1 tekdüze olarak
    • için yeterince büyük set boş değil ve olasılıkla 1
sonra ve 1 olasılıkla . Bunu not et gösterir setin sapması setten , olarak tanımlandı

Bazı durumlarda uygulanabilir set SAA problemi tahmin edilir, ardından ilgili SAA problemi şu şekilde olur:

nerede alt kümesidir örneğe bağlı ve bu nedenle rastgele. Bununla birlikte, SAA tahmin edicileri için tutarlılık sonuçları bazı ek varsayımlar altında hala türetilebilir:

  1. Kompakt bir küme olduğunu varsayalım öyle ki
    • set gerçek problemin optimal çözümlerinin boş olmamasıdır ve
    • işlev sonlu değerlidir ve sürekli
    • fonksiyonların sırası yakınsamak olasılıkla 1 tekdüze olarak
    • için yeterince büyük set boş değil ve olasılıkla 1
    • Eğer ve 1 olasılıkla bir noktaya yakınsar , sonra
    • bir noktaya kadar bir dizi var öyle ki olasılıkla 1.
sonra ve 1 olasılıkla .

SAA optimal değerinin asimptotikleri

Örnek varsayalım i.i.d. ve bir noktayı düzelt . Daha sonra örnek ortalama tahminci , nın-nin tarafsızdır ve farklılıkları vardır , nerede sonlu olması gerekiyor. Üstelik Merkezi Limit Teoremi bizde var

nerede yakınsamayı gösterir dağıtım ve ortalama ile normal bir dağılıma sahiptir ve varyans , olarak yazılmıştır .

Diğer bir deyişle, vardır asimptotik olarak normal dağıtım, yani büyük , ortalama ile yaklaşık olarak normal dağılıma sahiptir ve varyans . Bu, aşağıdakilere yol açar (yaklaşık) % güven aralığı :

nerede (İşte standart normal dağılımın cdf'sini gösterir) ve

örnek varyans tahmini . Yani, tahmin hatası düzen (stokastik olarak) .

Uygulamalar ve Örnekler

Biyolojik uygulamalar

Stokastik dinamik programlama modellemek için sıklıkla kullanılır hayvan davranışı gibi alanlarda davranışsal ekoloji.[8][9] Modellerinin ampirik testleri optimal yiyecek arama, hayat hikayesi gibi geçişler kuşlarda acemi ve yumurtlama parazitoid eşek arıları davranışsal karar vermenin evrimini açıklamada bu modelleme tekniğinin değerini göstermiştir. Bu modeller tipik olarak iki aşamalı yerine çok aşamalıdır.

Ekonomik uygulamalar

Stokastik dinamik programlama belirsizlik altında karar vermeyi anlamada yararlı bir araçtır. Belirsizlik altında sermaye stoku birikimi buna bir örnektir; genellikle kaynak ekonomistleri tarafından analiz etmek için kullanılır biyoekonomik sorunlar[10] belirsizliğin girdiği hava durumu vb.

Örnek: çok aşamalı portföy optimizasyonu

Aşağıda, çok aşamalı stokastik programlamanın finansından bir örnek olduğunu varsayalım. ilk sermayemiz var yatırım yapmak varlıklar. Ayrıca portföyümüzü zaman zaman yeniden dengelememize izin verildiğini varsayalım ama içine ek para enjekte etmeden. Her dönemde mevcut servetin yeniden dağıtılmasına karar veriyoruz arasında varlıklar. İzin Vermek n varlığa yatırılan ilk tutarlar. Her birini istiyoruz negatif değildir ve denge denklemi tutmalı.

Toplam getiriyi düşünün her dönem için . Bu, vektör değerli rastgele bir süreç oluşturur . Zaman aralığında , portföyü tutarları belirleyerek yeniden dengeleyebiliriz ilgili varlıklara yatırım yaptı. O zaman, ilk dönemdeki getiriler gerçekleştiğinden, bu bilgilerin yeniden dengeleme kararında kullanılması mantıklıdır. Böylece, ikinci aşamadaki kararlar, , aslında rastgele vektörün gerçekleştirilmesinin işlevleridir yani . Benzer şekilde, zamanında karar bir işlev tarafından verilen mevcut bilgilerin rasgele sürecin zamana kadarki geçmişi . Bir dizi işlev , , ile sabit olmak, bir uygulanabilir politika karar sürecinin. Böyle bir politika olduğu söyleniyor mümkün Olasılık 1 olan model kısıtlamalarını, yani nonngativite kısıtlamalarını karşılarsa , , ve refah dengesi kısıtlamaları,

dönemin neresinde zenginlik tarafından verilir

bu rastgele sürecin gerçekleşmesine ve zamana kadarki kararlara bağlıdır .

Hedefin, son dönemde bu servetin beklenen faydasını maksimize etmek, yani sorunu ele almak olduğunu varsayalım.

Bu, aşamaların numaralandırıldığı çok aşamalı bir stokastik programlama problemidir. -e . Optimizasyon, uygulanabilir ve uygulanabilir tüm politikalar üzerinden gerçekleştirilir. Problem tanımını tamamlamak için rastgele sürecin olasılık dağılımının da tanımlanması gerekir. . Bu, çeşitli şekillerde yapılabilir. Örneğin, sürecin zaman evrimini tanımlayan belirli bir senaryo ağacı oluşturulabilir. Her aşamada, her bir varlığın rastgele getirisinin diğer varlıklardan bağımsız olarak iki devamı olmasına izin verilirse, o zaman toplam senaryo sayısı

Yazmak için dinamik program denklemler, yukarıdaki çok aşamalı problemi zamanda geriye doğru düşünün. Son aşamada , bir farkındalık rastgele sürecin bilinmesi ve seçilmiş. Bu nedenle, aşağıdaki problemin çözülmesi gerekiyor

nerede şartlı beklentisini gösterir verilen . Yukarıdaki problemin optimal değeri şuna bağlıdır: ve ve gösterilir .

Benzer şekilde, aşamalarda sorunu çözmeli

optimal değeri ile gösterilen . Nihayet sahnede sorun çözülür

Aşamalı bağımsız rastgele süreç

İşlemin genel dağılımı için bu dinamik programlama denklemlerini çözmek zor olabilir. Durum, süreç önemli ölçüde basitleşir. kademeli olarak bağımsızdır, yani (stokastik olarak) bağımsızdır için . Bu durumda, karşılık gelen koşullu beklentiler, koşulsuz beklentiler haline gelir ve işlev , bağlı değil . Yani, problemin optimal değeridir

ve optimal değeridir

için .

Yazılım araçları

Modelleme dilleri

Tüm ayrık stokastik programlama problemleri herhangi bir cebirsel modelleme dili, ortaya çıkan modelin her aşamada sağlanan bilginin yapısına saygı duyduğundan emin olmak için açık veya örtük öngörülemezliği manüel olarak uygulamak. Genel bir modelleme dili tarafından oluşturulan bir SP probleminin bir örneği, oldukça büyük büyüme eğilimindedir (senaryoların sayısında doğrusal olarak) ve matrisi, aksi takdirde çözüm zamanında kötüye kullanılabilecek olan bu problem sınıfına özgü yapıyı kaybeder. SP için özel olarak tasarlanmış modelleme dillerinin uzantıları görünmeye başlıyor, bakınız:

  • AMAÇLAR - SP problemlerinin tanımını destekler
  • EMP SP (Stokastik Programlama için Genişletilmiş Matematiksel Programlama) - bir modül OYUNLAR Stokastik programlamayı kolaylaştırmak için oluşturulmuştur (parametrik dağılımlar için anahtar kelimeler, şans kısıtlamaları ve Riskteki değer ve Beklenen eksiklik ).
  • SAMPL - bir dizi uzantı AMPL Stokastik programları ifade etmek için özel olarak tasarlanmış (şans kısıtlamaları için sözdizimi, entegre şans kısıtlamaları ve Sağlam Optimizasyon sorunlar)

Her ikisi de problemin yapısını çözücüye gereksiz olmayan bir biçimde ileten SMPS örnek seviyesi formatı oluşturabilir.

Ayrıca bakınız

Referanslar

  1. ^ Shapiro, Alexander; Dentcheva, Darinka; Ruszczyński, Andrzej (2009). Stokastik programlama üzerine dersler: Modelleme ve teori (PDF). Optimizasyon Üzerine MPS / SIAM Serisi. 9. Philadelphia, PA: Endüstriyel ve Uygulamalı Matematik Derneği (SIAM). Matematiksel Programlama Topluluğu (MPS). s. xvi + 436. ISBN  978-0-89871-687-0. BAY  2562798.
  2. ^ Birge, John R .; Louveaux, François (2011). "Stokastik Programlamaya Giriş". Yöneylem Araştırması ve Finans Mühendisliğinde Springer Serisi. doi:10.1007/978-1-4614-0237-4. ISSN  1431-8598.
  3. ^ Stein W. Wallace ve William T. Ziemba (editörler). Stokastik Programlama Uygulamaları. Optimizasyon 5 MPS-SIAM Kitap Serisi, 2005.
  4. ^ Stokastik programlama uygulamaları aşağıdaki web sitesinde açıklanmıştır, Stokastik Programlama Topluluğu.
  5. ^ Shapiro, Alexander; Philpott, Andy. Stokastik Programlama üzerine bir eğitim (PDF).
  6. ^ http://www.neos-server.org/neos/
  7. ^ Ruszczyński, Andrzej; Shapiro, Alexander (2003). Stokastik Programlama. Yöneylem Araştırması ve Yönetim Bilimi El Kitapları. 10. Philadelphia: Elsevier. s. 700. ISBN  978-0444508546.
  8. ^ Mangel, M. ve Clark, C.W. 1988. Davranışsal ekolojide dinamik modelleme. Princeton University Press ISBN  0-691-08506-4
  9. ^ Houston, A. I ve McNamara, J.M. 1999. Uyarlanabilir davranış modelleri: duruma dayalı bir yaklaşım. Cambridge University Press ISBN  0-521-65539-0
  10. ^ Howitt, R., Msangi, S., Reynaud, A ve K. Knapp. 2002. "Stokastik Dinamik Programlama Sorunlarını Çözmek için Polinom Yaklaşımlarını Kullanma: veya SDP'ye" Betty Crocker "Yaklaşımı." University of California, Davis, Department of Agriculture and Resource Economics Working Paper.

daha fazla okuma

Dış bağlantılar