最優計算量分配(OCBA) 是最早由陳俊宏教授於90年代中期提出的一個概念。這一方法試圖在找到一個最優決策的前提下最大化仿真效率。[1]
簡言之,OCBA是一種仿真方法,它能夠在給定一組仿真參數的情況下,幫助確定所需的仿真次數及(或)所需的仿真時間,以達到可接受的(或最好的)結果。[2] 其具體做法是通過使用一個漸進框架對最優分配的結構進行分析。[3]
OCBA的目標是為大量仿真提供一種系統方法,最終從一些候選解中選取最優解(其中只有部分解是重要解)。換言之,它主要關注於最重要的那些解,從而最小化計算時間並降低重要解的估計值的方差。OCBA的預期效果是事半功倍,即到達所需的精度要求的同時使用更少的仿真量[4]。比如我們可以進行一個包含5個解的簡單仿真,目標是選擇平均時延最小的解。下圖給出了初步仿真結果 (即只對每個節進行了部分數量的仿真)。顯然解2和解3的時延要遠遠低於其它解 (由紅色方框圈出)。為節省計算量花費 (也即運行仿真所花費的時間,資源和金錢),OCBA建議應該把更多的計算量分配給解2和解3,並可以提前終止對解1,4和5的仿真,同時不影響最終結果。
OCBA的主要目標是最大化正確選擇最優解的概率(PCS)。PCS服從給定採樣階段時的採樣數量τ的約束。
此時,代表總計算量花費。[5]
OCBA的主要理論結果基於對一個漸進的情況的考慮。該情況中,τ趨近於 ∞,同時採樣數量β趨向於∞,而且τi 也增大到ni。使用「OCBA解決的問題」一節中的式(1)可以得到,當滿足以下兩個方程時,PCS可以被最大化。
有趣的是,式(2)表明每個解的仿真次數正比於信噪比的平方。這裏的噪聲指的是樣本標準差,而信號指的是的樣本均值和最優解樣本均值之差。
這裏用圖1中的簡單例子對OCBA進行數值測試。我們試圖把31個並行伺服器分配給一個兩階段的排隊系統。本例中的一個約束條件是,每個隊列中的伺服器數量(p1, p2)都不少於11台。用數學語言描述,即為:p1 + p2 = 31, p1 > 11 and p2 > 11.
給定以上信息,可知總共有10種關於(p1, p2)的分配方法。我們的目標是最小化前100個到達的顧客的平均等待時間。為了描述不同排隊過程的性能,我們引入關於計算量(即使用的資源,如時間,能源等)的函數β,該函數的取值在200到8000之間的範圍。PCS的估計值是β的函數。PCS是通過計算正確選擇的事件數與獨立實驗數的比值進行估計的。不同的β對應的PCS值如圖2所示。
表2給出了圖2一例的數值結果。結果中對使用OCBA和平均分配方法達到0.95和0.99的PCS值所需的採樣數量進行了比較。
PCS |
OCBA |
Equal allocation
|
0.95 |
470 |
1450
|
0.99 |
850 |
2890
|
接下來進行另一個實驗,實驗中解的數量有k個。例如,可以假設伺服器的數量大於31。則我們可以觀察使用不同分配方法達到所需PCS值時的加速因子。在本例中,我們想達到的PCS值為0.99。表3給出了使用OCBA和平均分配方法時的加速因子。加速因子通過計算β_EA/ β_OCBA得到。可以看到,加速因子隨着解的數量增大而增大。這正是對大量解進行仿真時可以節省仿真時間的原因。
Number of alternatives (k) |
4 |
10 |
20 |
50 |
75 |
100
|
Speedup factor |
1.75 |
3.42 |
6.45 |
12.8 |
16.3 |
19.8
|
[6]
該領域中的專家指出,有些問題中僅僅知道一個最優解是不夠的,而知道排名前5,前10前50的解更加重要,因為可能存在決策者關心的其它因素,這些因素將影響決策,而這些決策沒有被包含在模型中。根據Szechtman和Yücesan (2008),[7] OCBA對於可行性確定問題也有幫助。在這一問題中,決策者只對區分可行解和不可行解感興趣。此外,對於其他一些決策者,更重要的是如何選擇性能相似但結構簡更單的解。這種情況下, 最好的選擇是排名前r,結構最簡單,且性能排名高於所需水平的解。[8] 另外,Trailovic[9]和Pao[10] (2004)提出了一種OCBA方法,這種選取的是方差而非均值最小的解。這裏,我們假設方差未知,捨棄了OCBA的規則(即假設方差已知)。2010的對基於t分佈的OCBA方法的研究表明,使用t分佈和正態分佈並沒有顯著的差別。以上所提及的OCBA的推廣研究並不完整,還需要進一步的探索和編輯。[6]
多目標最優計算量分配(MOCBA)將OCBA應用於多目標問題。在典型的MOCBA中,PCS被定義為
其中
- 為觀測的帕累托集合,
- 為非帕累托集合,即,
- 為一個事件,它定義為解被任何其它解支配,
- 為一個事件,它定義為解至少被一個解支配。
注意到,識別一個正確的帕累托解集的一類錯誤率和二類錯誤率 分別為
and .
另外,可以證明
以及
其中為目標的個數,服從的後驗分佈。
注意到和是對於目標下的解的觀測性能測度的均值和標準差,而為觀測次數。
因此,不同於最大化,我們可以最大化它的下界,即假設,可以利用拉格朗日方法得到以下結論:
其中
- 對於解, ,
- 對於解, ,
且
與之前幾節提到的類似,許多情況下性能指標是多重的。如果這些性能指標同樣重要,決策者可以使用MOCBA。在其它的一些情形中,決策者需要對一個主要性能進行優化,同時必須滿足關於次要性能的某些約束條件。主要性能指標被稱為主目標,而次要性能測度被稱為約束指標。這一問題屬於帶約束優化的範疇。當解的數目固定,該問題被稱為帶約束的排名和選擇,其目的在主目標和約束指標需要通過隨機仿真進行估計的情況下,選擇最優的可行解。針對帶約束優化問題的OCBA方法(稱為OCBA-CO)可參見Pujowidianto等人(2009)[11] 和Lee等人(2012)[12]。
關鍵的區別在於PCS的定義。帶約束的優化問題中有兩個主要部分,即最優性和可行性。因此,可以基於最優性或可行性把仿真計算量分配給非最優的解。換言之,如果一個非最優的解一直保持不可行或比真實最優可行解的性能更差的狀態,它就不會被錯誤地選為最優可行解。因此基本思想是,如果一個解明顯比最優解差,則不需要用大量的計算量去驗證它的可行性。類似地,如果一個解的性能(主目標函數值)明顯好於其它解,我們可以基於可行性進行分配,從而節省計算量。
該問題的目標是高效檢測一個有限集合內所有解的可行性。如果所有可行解都能被正確選出,決策者可以以此為依據,結合其它確定性的限制條件,做出最優的決策。儘管可行性檢測問題也涉及隨機約束,但是該問題和之前的有約束的優化問題有本質的區別。可行性檢測問題的目標是找出所有可行解,而非單一的最優可行解。
定義
- : 解的數量;
- : 約束條件的數量;
- : 第個約束條件的控制參數, ;
- : 可行解的集合;
- : 非可行解的集合;
- : 第個約束條件以及第個解的仿真樣本的均值;
- : 第個約束條件以及第個解的仿真樣本的方差;
- : 分配給第個解的仿真預算的比例;
- : 第個約束條件以及第個解的仿真樣本的樣本均值.
假設所有的約束條件都是的形式, . 正確選擇所有可行解的概率是
可行性檢測的計算量分配問題可以寫成 (Gao and Chen (2017)[13])
定義以及,該問題的漸進最優的計算量分配方案是
最初的最優計算量分配問題的目標是最大化正確選擇最優解的概率(PCS),而實際當中另一個常用的目標計量是機會成本的期望(EOC)。EOC衡量選到的解的表現和最優解的表現的差異,其意義體現在,如果最優解最終並沒有被選到,EOC計量下選到的解的表現也不會太差。
機會成本的期望的表達式如下:
其中,
- 是解的數量;
- 代表最優解;
- 是觀測到的最優解;
- 是第個解的仿真樣本的均值, ;
- .
基於EOC計量的計算量分配問題可以寫成如下形式 (Gao et al. (2017)[14])
其中 是分配給第個解的仿真預算的比例。如果我們假設對所有的非最優解, ,那麼該問題的漸進最優分配方案如下
其中是第個解的仿真樣本的方差。該分配方案和問題(1)的漸進最優解一致,也就是說,漸進意義下,最大化PCS和最小化EOC其實是一樣的。
OCBA方法的一個潛在的假設是,輸入仿真模型的分佈和參數的真實值是已知的,而實際當中它們是未知的,需要用歷史數據來估計。這個估計會導致分佈和參數輸入的不確定性,繼而可能(嚴重)影響選到的解的質量。在Gao et al. (2017)[15]文章當中,作者考慮了該問題,為每個解建立了一個關於不確定性的集合,包含有限多個可能輸入的分佈和參數。每個解的不確定性集合中最差的分佈和參數輸入對應的系統表現被視作該解的表現,基於此,這篇文章找到了存在輸入不確定性的漸進最優的計算量分配方案。
以下連結提供了一個OCBA演示的簡單例子。在演示中,你將看到與傳統的平均分配方法相比,OCBA如何以不同的方式分配計算量。
- ^ Fu, M, C. H. Chen, and L. Shi, 「Some Topics for Simulation Optimization,」 Proceedings of 2008 Winter Simulation Conference, pp. 27–38, Miami, FL, December 2008.
- ^ Chen, and Loo H. Lee. Stochastic simulation optimization an optimal computing budget allocation. Singapore Hackensack, NJ: World Scientific, 2011. Print..
- ^ Chen, C. H. "An Effective Approach to Smartly Allocate Computing Budget for Discrete Event Simulation," Proceedings of the 34th IEEE Conference on Decision and Control, pp. 2598–2605, December 1995.
- ^ Chen, Chun-Hung. Optimal Computing Budget Allocation (OCBA) for Simulation-based Decision Making Under Uncertainty. [9 July 2013]. (原始內容存檔於2013年10月1日).
- ^ Chen, and Loo H. Lee. Stochastic simulation optimization an optimal computing budget allocation. Singapore Hackensack, NJ: World Scientific, 2011. Print.
- ^ 6.0 6.1 Chen, C. H., M. Fu, L. Shi, and L. H. Lee, 「Stochastic Systems Simulation Optimization,」 Frontiers of Electrical and Electronic Engineering in China, 6(3), 468–480, 2011
- ^ Szechtman R, Yücesan E (2008) A new perspective on feasibility determination. Proc of the 2008 Winter Simul Conf 273–280
- ^ Jia QS, Zhou E, Chen CH (2012). efficient computing budget allocation for finding simplest good designs. IIE Trans, To Appear.
- ^ Trailovic Tekin E, Sabuncuoglu I (2004) Simulation optimization: A comprehensive review on theory and applications. IIE Trans 36:1067–1081
- ^ Trailovic L, Pao LY (2004) Computing budget allocation for efficient ranking and selection of variances with application to target tracking algorithms, IEEE Trans Autom Control 49:58–67.
- ^ Pujowidianto NA, Lee LH, Chen CH, Yap CM (2009) Optimal computing budget allocation for constrained optimization. Proc of the 2009 Winter Simul Conf 584–589.
- ^ Lee LH, Pujowidianto NA, Li LW, Chen CH, Yap CM (2012) Approximation simulation budget allocation for selecting the best design in the presence of stochastic constraints, IEEE Trans Autom Control 57:2940–2945.
- ^ Gao, S. and W. Chen, "Efficient feasibility determination with multiple performance measure constraints," IEEE Transactions on Automatic Control, 62, 113–122, 2017.
- ^ Gao, S., W. Chen and L. Shi, "A New Budget Allocation Framework for the Expected Opportunity Cost," Operations Research, 63, 787–803, 2017.
- ^ Gao, S., H. Xiao, E. Zhou and W. Chen, "Robust Ranking and Selection with Optimal Computing Budget Allocation," Automatica, 81, 30–36, 2017.