實(shí)驗(yàn)最優(yōu)化方法建模及實(shí)現(xiàn)_第1頁
實(shí)驗(yàn)最優(yōu)化方法建模及實(shí)現(xiàn)_第2頁
實(shí)驗(yàn)最優(yōu)化方法建模及實(shí)現(xiàn)_第3頁
實(shí)驗(yàn)最優(yōu)化方法建模及實(shí)現(xiàn)_第4頁
實(shí)驗(yàn)最優(yōu)化方法建模及實(shí)現(xiàn)_第5頁
已閱讀5頁,還剩54頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

(優(yōu)選)實(shí)驗(yàn)最優(yōu)化方法建模及實(shí)現(xiàn)當(dāng)前1頁,總共59頁。最優(yōu)化問題優(yōu)化問題,一般是指用“最好”的方式,使用或分配有限的資源,即勞動(dòng)力、原材料、機(jī)器、資金等,使得費(fèi)用最小或利潤最大.建立優(yōu)化問題的數(shù)學(xué)模型

1)確定問題的決策變量

2)構(gòu)造模型的目標(biāo)函數(shù)和允許取值的范圍,常用一組不等式來表示.當(dāng)前2頁,總共59頁。(1)(2)由(1)、(2)組成的模型屬于約束優(yōu)化,若只有(1)式就是無約束優(yōu)化,f(x)稱為目標(biāo)函數(shù),gi(x)稱為約束條件若目標(biāo)函數(shù)f(x)和約束條件g(x)都是線性函數(shù),則稱該模型是線性規(guī)劃.當(dāng)前3頁,總共59頁。線性規(guī)劃模型例1、生產(chǎn)炊事用具需要兩種資源-勞動(dòng)力和原材料,某公司制定生產(chǎn)計(jì)劃,生產(chǎn)三種不同的產(chǎn)品,生產(chǎn)管理部門提供的數(shù)據(jù)如下ABC勞動(dòng)力(小時(shí)/件)736原材料(千克/件)445利潤(元/件)423當(dāng)前4頁,總共59頁。每天供應(yīng)原材料200kg,每天可使用的勞動(dòng)力為150h.建立線性規(guī)劃模型,使總收益最大,并求各種產(chǎn)品的日產(chǎn)量.

解第一步,確定決策變量.用分別表示A,B,C三種產(chǎn)品的日產(chǎn)量第二步,約束條件原材料:勞動(dòng)力:第三步,確定目標(biāo)函數(shù)當(dāng)前5頁,總共59頁。例2一家廣告公司想在電視、廣播上做廣告,其目的是盡可能多的招來顧客,下面是調(diào)查結(jié)果:

電視無線電廣播雜志白天最佳時(shí)間一次廣告費(fèi)用(千元)40753015受每次廣告影響的顧客數(shù)(千人)400900500200受每次廣告影響的女顧客數(shù)(千人)300400200100當(dāng)前6頁,總共59頁。這家公司希望廣告費(fèi)用不超過800(千元)還要求:1)至少要有200萬婦女收看廣告;2)電視廣告費(fèi)用不超過500(千元)3)電視廣告白天至少播出3次,最佳時(shí)間至少播出2次;4)通過廣播、雜志做的廣告要重復(fù)5到10次.令分別白天,最佳電視、廣播、雜志廣告次數(shù)當(dāng)前7頁,總共59頁。例3:任務(wù)分配問題:某車間有甲、乙兩臺(tái)機(jī)床,可用于加工三種工件。假定這兩臺(tái)車床的可用臺(tái)時(shí)數(shù)分別為800和900,三種工件的數(shù)量分別為400、600和500,且已知用三種不同車床加工單位數(shù)量不同工件所需的臺(tái)時(shí)數(shù)和加工費(fèi)用如下表。問怎樣分配車床的加工任務(wù),才能既滿足加工工件的要求,又使加工費(fèi)用最低?當(dāng)前8頁,總共59頁。解設(shè)在甲車床上加工工件1、2、3的數(shù)量分別為x1、x2、x3,在乙車床上加工工件1、2、3的數(shù)量分別為x4、x5、x6。可建立以下線性規(guī)劃模型:

解答當(dāng)前9頁,總共59頁。例4:某廠每日8小時(shí)的產(chǎn)量不低于1800件。為了進(jìn)行質(zhì)量控制,計(jì)劃聘請(qǐng)兩種不同水平的檢驗(yàn)員。一級(jí)檢驗(yàn)員的標(biāo)準(zhǔn)為:速度25件/小時(shí),正確率98%,計(jì)時(shí)工資4元/小時(shí);二級(jí)檢驗(yàn)員的標(biāo)準(zhǔn)為:速度15小時(shí)/件,正確率95%,計(jì)時(shí)工資3元/小時(shí)。檢驗(yàn)員每錯(cuò)檢一次,工廠要損失2元。為使總檢驗(yàn)費(fèi)用最省,該工廠應(yīng)聘一級(jí)、二級(jí)檢驗(yàn)員各幾名?解設(shè)需要一級(jí)和二級(jí)檢驗(yàn)員的人數(shù)分別為x1、x2人,則應(yīng)付檢驗(yàn)員的工資為:因檢驗(yàn)員錯(cuò)檢而造成的損失為:當(dāng)前10頁,總共59頁。故目標(biāo)函數(shù)為:約束條件為:當(dāng)前11頁,總共59頁。線性規(guī)劃模型:

解答返回當(dāng)前12頁,總共59頁。線性規(guī)劃模型的一般形式

目標(biāo)函數(shù)和所有的約束條件都是決策變量的線性函數(shù)。當(dāng)前13頁,總共59頁。實(shí)際問題中的優(yōu)化模型x~決策變量f(x)~目標(biāo)函數(shù)gi(x)0~約束條件數(shù)學(xué)規(guī)劃線性規(guī)劃(LP)二次規(guī)劃(QP)非線性規(guī)劃(NLP)純整數(shù)規(guī)劃(PIP)混合整數(shù)規(guī)劃(MIP)整數(shù)規(guī)劃(IP)0-1整數(shù)規(guī)劃一般整數(shù)規(guī)劃連續(xù)規(guī)劃

優(yōu)化模型的分類當(dāng)前14頁,總共59頁。線性規(guī)劃問題的求解在理論上有單純形法,在實(shí)際建模中常用以下解法:

1.圖解法

2.LINGO軟件包;

3.Excel中的規(guī)劃求解;

4.MATLAB軟件包.當(dāng)前15頁,總共59頁。minz=cX

1、模型:命令:x=linprog(c,A,b)

2、模型:minz=cX

命令:x=linprog(c,A,b,Aeq,beq)或

x=linprog(c,A,b,Aeq,beq,x0)或

[x,fval]=linprog(c,A,b,Aeq,beq)注意:若沒有不等式:存在,則令A(yù)=[],b=[].用MATLAB優(yōu)化工具箱解線性linear規(guī)劃當(dāng)前16頁,總共59頁。3、模型:minz=cX

VLB≤X≤VUB(low,up)

命令:[1]x=linprog(c,A,b,Aeq,beq,VLB,VUB)

[2]x=linprog(c,A,b,Aeq,beq,VLB,VUB,X0)

注意:[1]若沒有等式約束:,則令A(yù)eq=[],beq=[].[2]其中X0表示初始點(diǎn)

4、命令:[x,fval]=linprog(…)

返回最優(yōu)解x及x處的目標(biāo)函數(shù)值fval.當(dāng)前17頁,總共59頁。解:編寫M文件xxgh1.m如下:

c=[634];A=[1,2,-3;010];b=[80;50];Aeq=[111];beq=[120];vlb=[30,0,20];vub=[];[x,fval]=linprog(c,A,b,Aeq,beq,vlb,vub)ToMatlab(xxgh1)例5當(dāng)前18頁,總共59頁。解編寫M文件xxgh2.m如下:c=[-0.4-0.28-0.32-0.72-0.64-0.6];A=[0.010.010.010.030.030.03;0.02000.0500;00.02000.050;000.03000.08];b=[850;700;100;900];Aeq=[];beq=[];vlb=[0;0;0;0;0;0];vub=[];[x,fval]=linprog(c,A,b,Aeq,beq,vlb,vub)

ToMatlab(xxgh2)例6當(dāng)前19頁,總共59頁。S.t.改寫為:

問題例3的解答當(dāng)前20頁,總共59頁。編寫M文件xxgh3.m如下:f=[1391011128];A=[0.41.110000000.51.21.3];b=[800;900];Aeq=[100100010010001001];beq=[400600500];vlb=zeros(6,1);vub=[];[x,fval]=linprog(f,A,b,Aeq,beq,vlb,vub)ToMatlab(xxgh3)當(dāng)前21頁,總共59頁。x=0.0000600.00000.0000400.00000.0000500.0000fval=1.3800e+004計(jì)算結(jié)果:

即在甲機(jī)床上加工600個(gè)工件2,在乙機(jī)床上加工400個(gè)工件1、500個(gè)工件3,可在滿足條件的情況下使總加工費(fèi)最小為13800。當(dāng)前22頁,總共59頁。

問題改寫為:例4的解答當(dāng)前23頁,總共59頁。編寫M文件xxgh4.m如下:c=[40;36];A=[-5-3];b=[-45];Aeq=[];beq=[];vlb=zeros(2,1);vub=[9;15];%調(diào)用linprog函數(shù):[x,fval]=linprog(c,A,b,Aeq,beq,vlb,vub)ToMatlab(xxgh4)當(dāng)前24頁,總共59頁。結(jié)果為:

x=9.00000.0000fval=360即只需聘用9個(gè)一級(jí)檢驗(yàn)員。

注:本問題應(yīng)還有一個(gè)約束條件:x1、x2取整數(shù)。故它是一個(gè)整數(shù)線性規(guī)劃問題。這里把它當(dāng)成一個(gè)線性規(guī)劃來解,求得其最優(yōu)解剛好是整數(shù):x1=9,x2=0,故它就是該整數(shù)規(guī)劃的最優(yōu)解。若用線性規(guī)劃解法求得的最優(yōu)解不是整數(shù),將其取整后不一定是相應(yīng)整數(shù)規(guī)劃的最優(yōu)解,這樣的整數(shù)規(guī)劃應(yīng)用專門的方法求解。返回當(dāng)前25頁,總共59頁。當(dāng)前26頁,總共59頁。1)首先建立M文件fun.m,定義目標(biāo)函數(shù)F(X):functionf=fun(X)f=F(X);

其中X為n維變?cè)蛄浚珿(X)與Ceq(X)均為非線性函數(shù)組成的向量,其它變量的含義與線性規(guī)劃、二次規(guī)劃中相同.用Matlab求解上述問題,基本步驟分三步:二、非線性規(guī)劃問題及其Matlab當(dāng)前27頁,總共59頁。3)建立主程序.非線性規(guī)劃求解的函數(shù)是fmincon,命令的基本格式如下:

(1)x=fmincon(‘fun’,X0,A,b)

(2)x=fmincon(‘fun’,X0,A,b,Aeq,beq)

(3)x=fmincon(‘fun’,X0,A,b,Aeq,beq,VLB,VUB)

(4)x=fmincon(‘fun’,X0,A,b,Aeq,beq,VLB,VUB,’nonlcon’)(5)x=fmincon(‘fun’,X0,A,b,Aeq,beq,VLB,VUB,’nonlcon’,options)

(6)[x,fval]=fmincon(...)

(7)[x,fval,exitflag]=fmincon(...)

(8)[x,fval,exitflag,output]=fmincon(...)輸出極值點(diǎn)M文件迭代的初值參數(shù)說明變量上下限當(dāng)前28頁,總共59頁。注意:[1]fmincon函數(shù)提供了大型優(yōu)化算法和中型優(yōu)化算法。默認(rèn)時(shí),若在fun函數(shù)中提供了梯度(options參數(shù)的GradObj設(shè)置為’on’),并且只有上下界存在或只有等式約束,fmincon函數(shù)將選擇大型算法。當(dāng)既有等式約束又有梯度約束時(shí),使用中型算法。[2]fmincon函數(shù)的中型算法使用的是序列二次規(guī)劃法。在每一步迭代中求解二次規(guī)劃子問題,并用BFGS法更新拉格朗日Hessian矩陣。[3]fmincon函數(shù)可能會(huì)給出局部最優(yōu)解,這與初值X0的選取有關(guān)。當(dāng)前29頁,總共59頁。1.先建立M文件fun2.m,定義目標(biāo)函數(shù):

functionf=fun2(x)f=exp(x(1))*(4*x(1)^2+2*x(2)^2+4*x(1)*x(2)+2*x(2)+1);x1+x2=0s.t.1.5+x1x2-x1-x20-x1x2–10

02.再建立M文件mycon2.m定義非線性約束:

function[g,ceq]=mycon2(x)g=[1.5+x(1)*x(2)-x(1)-x(2);-x(1)*x(2)-10];ceq=[];例2當(dāng)前30頁,總共59頁。3.主程序youh2.m為:x0=[-1;1];A=[];b=[];Aeq=[11];beq=[0];vlb=[];vub=[];[x,fval]=fmincon('fun2',x0,A,b,Aeq,beq,vlb,vub,'mycon2')MATLAB(youh2)4.運(yùn)算結(jié)果為:

x=-1.22471.2247fval=1.8951當(dāng)前31頁,總共59頁。1.先建立M-文件fun3.m定義目標(biāo)函數(shù):

functionf=fun3(x)f=-2*x(1)-x(2);2.再建立M文件mycon3.m定義非線性約束:

function[g,ceq]=mycon3(x)g=[x(1)^2+x(2)^2-25;x(1)^2-x(2)^2-7];ceq=[];

例3當(dāng)前32頁,總共59頁。3.主程序youh3.m為:

x0=[3;2.5];VLB=[00];VUB=[510];[x,fval,exitflag,output]=fmincon('fun3',x0,[],[],[],[],VLB,VUB,'mycon3')MATLAB(youh3(fun3))當(dāng)前33頁,總共59頁。4.運(yùn)算結(jié)果為:

x=4.00003.0000fval=-11.0000exitflag=1output=iterations:4funcCount:17stepsize:1algorithm:[1x44char]firstorderopt:[]cgiterations:[]

返回當(dāng)前34頁,總共59頁。當(dāng)前35頁,總共59頁。建模案例:投資的收益和風(fēng)險(xiǎn)(1998A)當(dāng)前36頁,總共59頁。二、基本假設(shè)和符號(hào)規(guī)定當(dāng)前37頁,總共59頁。1.總體風(fēng)險(xiǎn)用所投資的Si中最大的一個(gè)風(fēng)險(xiǎn)來衡量,即:三、模型的建立與分析當(dāng)前38頁,總共59頁。3.建立模型雙目標(biāo)模型為:當(dāng)前39頁,總共59頁。4.模型簡化即模型為:當(dāng)前40頁,總共59頁。當(dāng)前41頁,總共59頁。四、模型1的求解siri

(%)qi

(%)pi

(%)ui

(元)S0(銀行)5000S1282.51103S2211.52198S3235.54.552S4252.66.540將n=4,M=1,及平均收益率ri,

風(fēng)險(xiǎn)損失率qi,費(fèi)率

pi代入模型1得:當(dāng)前42頁,總共59頁。

由于a是任意給定的風(fēng)險(xiǎn)度,到底怎樣給定沒有一個(gè)準(zhǔn)則,不同的投資者有不同的風(fēng)險(xiǎn)度。我們從a=0開始,以步長△a=0.001進(jìn)行循環(huán)搜索,編制程序如下:當(dāng)前43頁,總共59頁。a=0;while(1.1-a)>1c=[-0.05-0.27-0.19-0.185-0.185];Aeq=[11.011.021.0451.065];beq=[1];A=[00.025000;000.01500;0000.0550;00000.026];b=[a;a;a;a];vlb=[0,0,0,0,0];vub=[];[x,val]=linprog(c,A,b,Aeq,beq,vlb,vub);ax=x'Q=-valplot(a,Q,'.');axis([00.100.5]);holdona=a+0.001;endxlabel('a'),ylabel('Q')ToMatlab(xxgh5)模型1的MATLAB程序:當(dāng)前44頁,總共59頁。a=0.006計(jì)算結(jié)果:當(dāng)前45頁,總共59頁。4.在a=0.006附近有一個(gè)轉(zhuǎn)折點(diǎn),在這一點(diǎn)左邊,風(fēng)險(xiǎn)增加很少時(shí),利潤增長很快。在這一點(diǎn)右邊,風(fēng)險(xiǎn)增加很大時(shí),利潤增長很緩慢,所以對(duì)于風(fēng)險(xiǎn)和收益沒有特殊偏好的投資者來說,應(yīng)該選擇曲線的拐點(diǎn)作為最優(yōu)投資組合,大約是a*=0.6%,Q*=20%,所對(duì)應(yīng)投資方案為:

風(fēng)險(xiǎn)度

收益

x0

x1

x2x3

x40.00600.201900.24000.40000.10910.22123.曲線上的任一點(diǎn)都表示該風(fēng)險(xiǎn)水平的最大可能收益和該收益要求的最小風(fēng)險(xiǎn)。對(duì)于不同風(fēng)險(xiǎn)的承受能力,選擇該風(fēng)險(xiǎn)水平下的最優(yōu)投資組合。當(dāng)投資越分散時(shí),投資者承擔(dān)的風(fēng)險(xiǎn)越小,這與題意一致。即:冒險(xiǎn)的投資者會(huì)出現(xiàn)集中投資的情況,保守的投資者則盡量分散投資。1.風(fēng)險(xiǎn)大,收益也大。模型1的結(jié)果分析當(dāng)前46頁,總共59頁。此模型又可改寫為模型2的求解:當(dāng)前47頁,總共59頁。由于k是任意給定的盈利,到底怎樣給定沒有一個(gè)準(zhǔn)則,不同的投資者有不同的盈利.我們從k=0.05開始,以步長△k=0.01進(jìn)行循環(huán)搜索,編制程序如下:模型2的求解:當(dāng)前48頁,總共59頁。k=0.05whilek<0.26/1.01;C=[000001];A=[00.025000-1;000.01500-1;0000.0550-1;00000.026-1];B=[0;0;0;0];Aeq=[0.050.270.190.1850.185,0;11.011.021.0451.065,0];Beq=[k;1];Vlb=[0;0;0;0;0;0];%orVlb=zeros(6,1);Vub=[];[x,fval]=linprog(C,A,B,Aeq,Beq,Vlb,Vub);模型2的MATLAB求解:當(dāng)前49頁,總共59頁。kQ=fvalx=x'plot(k,Q,'m.')axis([00.500.05])xlabel('收益k')ylabel('最小風(fēng)險(xiǎn)度Q')title('最小風(fēng)險(xiǎn)度Q隨收益R的變化趨勢圖')holdonk=k+0.01;gridonend模型2的MATLAB求解:當(dāng)前50頁,總共59頁。模型2的結(jié)果分析:當(dāng)前51頁,總共59頁。此模型又可改寫為模型3的求解:當(dāng)前52頁,總共59頁。模型3的求解:當(dāng)前53頁,總共59頁。s=0whiles<1;C=[-0.05*(1-s),-0.27*(1-s),-0.19*(1-s),-0.185*(1-s),-0.185*(1-s),s];A=[00.025000-1;000.01500-1;0000.0550-1;00000.026-1];B=[0;0;0;0];Aeq=[11.011.021.0451.065,0];Beq=[1];Vlb=[0;0;0;0;0;0];%orVlb=zeros

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論