版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)
文檔簡介
1、L/O/G/O培訓(xùn)教案LINGOLINGO實用簡易教程實用簡易教程培訓(xùn)教案LINGO培訓(xùn)內(nèi)容培訓(xùn)內(nèi)容上午(上午(8:3011:30)下午(下午(13:3016:30)LINGO基本功能介紹利用LINGO求解整數(shù)規(guī)劃問題LINGO的常用函數(shù)定義及其分類利用LINGO求解非線性規(guī)劃問題利用LINGO求解線性規(guī)劃問題在編程中對LINGO的調(diào)用利用LINGO進行敏感度分析培訓(xùn)教案LINGOLINGOLINGO簡介簡介 LINGO是一種專門用于求解數(shù)學(xué)規(guī)劃問題的軟件包。由于LINGO執(zhí)行速度快,易于方便地輸入、求解和分析數(shù)學(xué)規(guī)劃問題,因此在教學(xué)、科研和工業(yè)界得到廣泛應(yīng)用。 LINGO主要用于求解線性規(guī)劃
2、、非線性規(guī)劃、二次規(guī)劃和整數(shù)規(guī)劃等問題,也可以用于求解一些線性和非線性方程組及代數(shù)方程求根等。培訓(xùn)教案LINGO使用入門使用入門界面界面培訓(xùn)教案LINGO使用入門使用入門菜單命令菜單命令“File”“Edit”:match parenthesis:括號匹配,選定某括號的一邊,然后點擊此選項,程序會自動尋找與之相匹配的括號,如果未找到,會有彈窗提示。paste function:用來進行函數(shù)的插入。“l(fā)ingo”:solution:主要是考察結(jié)果,可以指定某一行或者某一個項目來考察結(jié)果,有文字形式也有圖表形式。range:主要是用于靈敏度分析,在這里要先更改默認(rèn)設(shè)置,將price改為price
3、and range,然后才能運行range。generate:可以產(chǎn)生相對應(yīng)的程序。debug:用于調(diào)試程序,只能在程序出錯時才能用。示例:model:sets: number/1.6/:x;endsetsdata: x = 5 1 3 4 6 10;enddata endwindows:command window:生成命令窗口,用于在非windows系統(tǒng)下以命令的方式編寫和運行程序。tile:排列窗口的方式/橫排或豎排cascade:以瀑布的方式排列窗口arrange icons:當(dāng)窗口最小化之后用來排列圖標(biāo)。培訓(xùn)教案LINGO程序結(jié)構(gòu)程序結(jié)構(gòu)集集 LINGO的程序一般是一“MODEL:”
4、開頭,以“end”結(jié)束,內(nèi)容包括四部分:集部分,數(shù)據(jù)部分,初始部分,目標(biāo)函數(shù)、約束函數(shù)部分。 集部分集部分是LINGO模型的一個可選部分。在LINGO模型中使用集之前,必須在集部分事先定義。集部分以關(guān)鍵字“sets:”開始,以“endsets”結(jié)束。一個模型可以沒有集部分,或有一個簡單的集部分,或有多個集部分。一個集部分可以放置于模型的任何地方,但是一個集及其屬性在模型約束中被引用之前必須被定義。 培訓(xùn)教案LINGO程序結(jié)構(gòu)程序結(jié)構(gòu)原始集原始集 集包括原始集和派生集兩集包括原始集和派生集兩種。種。 定義原始集定義原始集為了定義一個原始集,必須詳細(xì)聲明:集的名字可選,集的成員可選,集成員的屬性
5、定義一個原始集,用下面的語法: setname/member_list/:attribute_list;注意:用“ ”表示該部分內(nèi)容可選。示例1:model:sets:students/John,Linda,Tom/:age,gender;endsetsEnd示例2:Model:Sets:Month/Jan.Dec/:temperature;Endsetsend培訓(xùn)教案LINGO程序結(jié)構(gòu)程序結(jié)構(gòu)原始集原始集集成員列表的羅列可以有顯式羅列和隱式羅列兩種,顯示羅列如上頁所示,即將集成員全部羅列出來。隱式羅列不必羅列出每個集成員??刹捎萌缦抡Z法:setname/member1.memberN/: a
6、ttribute_list;這里的member1是集的第一個成員名,memberN是集的最末一個成員名。LINGO將自動產(chǎn)生中間的所有成員名。LINGO也接受一些特定的首成員名和末成員名,用于創(chuàng)建一些特殊的集。列表如下:隱式成員列表格式示例所產(chǎn)生集成員隱式成員列表格式示例所產(chǎn)生的集成員1.n1.51,2,3,4,5StringM.stringNCard2.Card10Card2,Card3,Card4Card10DayM.DayNMon.FriMon,Tue,Wen,Thu,FriMonthM.MonthNOct.JanOct,Nov,Dec,JanMonthYearM.MonthYearNO
7、ct2001.Jan2002Oct2001,Nov2001,Dec2001,Jan2002 培訓(xùn)教案LINGO程序結(jié)構(gòu)程序結(jié)構(gòu)原始集原始集也可以講集成員在數(shù)據(jù)部分定義。示例:!集部分;sets: students:sex,age;endsets!數(shù)據(jù)部分;data: students,sex,age= John 1 16 Jill 0 14 Rose 0 17 Mike 1 13;Enddata注意:開頭用感嘆號(!),末尾用分號(;)表示注釋,可跨多行。請注意:數(shù)據(jù)部分的數(shù)據(jù)之間可以用空格隔開,也可以用逗號隔開。程序默認(rèn)的數(shù)據(jù)是從索引1開始分配,即將“students,sex,age”的第一
8、個數(shù)據(jù)分配完了之后再分配其第二個數(shù)據(jù)。再如下例:model:sets:students/John,Linda,Tom/:age,gender;EndsetsData:Age,gender=10,1,11,0,12,1;enddataEnd運行之后便可看出數(shù)據(jù)分配的結(jié)果。培訓(xùn)教案LINGO程序結(jié)構(gòu)程序結(jié)構(gòu)派生集派生集定義派生集定義派生集為了定義一個派生集,必須詳細(xì)聲明:集的名字父集父集的名字可選,集成員可選,集成員的屬性可用下面的語法定義一個派生集:setname(parent_set_list)/member_list/:attribute_list;setname是集的名字。parent_s
9、et_list是已定義的集的列表,多個時必須用逗號隔開。如果沒有指定成員列表,那么LINGO會自動創(chuàng)建父集成員的所有組合作為派生集的成員。派生集的父集既可以是原始集,也可以是其它的派生集。 friendsStudentsHarryGreenJohn84Linda96Tom68示例:model:sets:students/John,Linda,Tom/:age,gender;friends/Harry,Green/;Links(students,friends):relationship;EndsetsData:Relationship=8,4,9,6,6,8;enddataEnd運行結(jié)果如下圖
10、:培訓(xùn)教案LINGO程序結(jié)構(gòu)程序結(jié)構(gòu)派生集派生集稀疏集可以用顯式表示也可以用成員資格過濾器表示。顯式表示可如下示例:Links(students,friends)/John,Harry,Linda,Green/:relationship;(1)成員資格過濾器表示可如下示例:Links(students,friends)|&1 #eq# 1 #and# &2 #eq# 2:relationship;(2)將分別插入程序中,并修改數(shù)據(jù),可得到如下結(jié)果:(1)RELATIONSHIP( JOHN, HARRY) 8.000000 RELATIONSHIP( LINDA, GREEN)
11、 6.000000(2)RELATIONSHIP( JOHN, GREEN) 8.000000培訓(xùn)教案LINGO程序結(jié)構(gòu)程序結(jié)構(gòu)數(shù)據(jù)數(shù)據(jù)數(shù)據(jù)部分以關(guān)鍵字“data:”開始,以關(guān)鍵字“enddata”結(jié)束。在這里,可以指定集成員、集的屬性。其語法如下:object_list = value_list;對象列對象列(object_list)包含要指定值的屬性名、要設(shè)置集成員的集名,用逗號或空格隔開。一個對象列中至多有一個集名,一個對象列中至多有一個集名,而屬性名可以有任意多。而屬性名可以有任意多。如果對象列中有多個屬性名,那么它們的類型必須一致。如果對象列中有一個集名,那么對象列中所有的屬性的類型
12、就是這個集。數(shù)值列數(shù)值列(value_list)包含要分配給對象列中的對象的值,用逗號或空格隔開。注意屬性值的個數(shù)必須等于集成員的個數(shù)??聪旅娴睦?。示例:sets: set1/A,B,C/: X,Y;endsetsdata: X=1,2,3; Y=4,5,6;Enddata數(shù)據(jù)部分也可以如此表示,其本質(zhì)是一樣的:data: X,Y=1 4 2 5 3 6;enddata培訓(xùn)教案LINGO程序結(jié)構(gòu)程序結(jié)構(gòu)數(shù)據(jù)數(shù)據(jù)Data部分也可以用來定義標(biāo)量變量,如下所示:data: interest_rate = .085;enddata也可以同時指定多個參數(shù)。data: interest_rate,inf
13、lation_rate = .085 .03;enddata 在某些情況,對于模型中的某些數(shù)據(jù)并不是定值。譬如模型中有一個通貨膨脹率的參數(shù),我們想在2%至6%范圍內(nèi),對不同的值求解模型,來觀察模型的結(jié)果對通貨膨脹的依賴有多么敏感。我們把這種情況稱為實時數(shù)據(jù)處理實時數(shù)據(jù)處理(what if analysis)。LINGO有一個特征可方便地做到這件事:在本該放數(shù)的地方輸入一個問號(?)。如下所示:data: interest_rate,inflation_rate = .085 ?;enddata每一次求解模型時,LINGO都會提示為參數(shù)inflation_rate輸入一個值。在WINDOWS操作
14、系統(tǒng)下,將會接收到一個類似右上角所示的對話框: 直接輸入一個值再點擊OK按鈕,LINGO就會把輸入的值指定給inflation_rate,然后繼續(xù)求解模型。培訓(xùn)教案LINGO程序結(jié)構(gòu)程序結(jié)構(gòu)數(shù)據(jù)數(shù)據(jù)指定屬性為一個值指定屬性為一個值可以在數(shù)據(jù)聲明的右邊輸入一個值來把所有的成員的該屬性指定為一個值。看下面的例子。數(shù)據(jù)部分的未知數(shù)值數(shù)據(jù)部分的未知數(shù)值有時只想為一個集的部分成員的某個屬性指定值,而讓其余成員的該屬性保持未知,以便讓LINGO去求出它們的最優(yōu)值。在數(shù)據(jù)聲明中輸入兩個相連的逗號表示該位置對應(yīng)的集成員的屬性值未知。兩個逗號間可以有空格。屬性capacity的第2個和第3個值分別為34和20,
15、其余的未知。 示例示例1:sets: days /MO,TU,WE,TH,FR,SA,SU/:needs,cost;endsetsdata: needs cost = 20 100;Enddata示例示例2:sets: years/1.5/: capacity;endsetsdata: capacity = ,34,20,;Enddata屬性capacity的第2個和第3個值分別為34和20,其余的未知。培訓(xùn)教案LINGO程序結(jié)構(gòu)程序結(jié)構(gòu)初始部分初始部分初始部分是LINGO提供的另一個可選部分。在初始部分中,可以輸入初始聲初始聲明明(initialization statement),和數(shù)據(jù)部
16、分中的數(shù)據(jù)聲明相同。對實際問題的建模時,初始部分并不起到描述模型的作用,在初始部分輸入的值僅被LINGO求解器當(dāng)作初始點來用,并且僅僅對非線性模型有用。僅僅對非線性模型有用。和數(shù)據(jù)部分指定變量的值不同,LINGO求解器可以自由改變初始部分初始化的變量的值。一個初始部分以“init:”開始,以“endinit”結(jié)束。初始部分的初始聲明規(guī)則和數(shù)據(jù)部分的數(shù)據(jù)聲明規(guī)則相同。也就是說,我們可以在聲明的左邊同時初始化多個集屬性,可以把集屬性初始化為一個值,可以用問號實現(xiàn)實時數(shù)據(jù)處理,還可以用逗號指定未知數(shù)值。示例:示例:init: X, Y = 0, .001;endinit Y=log(X); X+Y=
17、1;注意:好的初始點會減少模型的求解時間。如左例中,若將x的初始值改為0.9,則可以明顯減少迭代次數(shù)。培訓(xùn)教案LINGO程序結(jié)構(gòu)程序結(jié)構(gòu)基本運算符基本運算符一、基本運算符一、基本運算符1、算術(shù)運算符算術(shù)運算符是針對數(shù)值進行操作的。LINGO提供了5種二元運算符:乘方乘除加減LINGO唯一的一元算術(shù)運算符是取反函數(shù)“”。這些運算符的優(yōu)先級由高到底為:高(取反) 低運算符的運算次序為從左到右按優(yōu)先級高低來執(zhí)行。運算的次序可以用圓括號“()”來改變。培訓(xùn)教案LINGO程序結(jié)構(gòu)程序結(jié)構(gòu)邏輯運算符邏輯運算符2、邏輯運算符在LINGO中,邏輯運算符主要用于集循環(huán)函數(shù)的條件表達式中,來控制在函數(shù)中哪些集成員
18、被包含,哪些被排斥。在創(chuàng)建稀疏集時用在成員資格過濾器中。LINGO具有種邏輯運算符:#not# 否定該操作數(shù)的邏輯值,not是一個一元運算符#eq#若兩個運算數(shù)相等,則為true;否則為flase#ne# 若兩個運算符不相等,則為true;否則為flase#gt# 若左邊的運算符嚴(yán)格大于右邊的運算符,則為true;否則為flase#ge# 若左邊的運算符大于或等于右邊的運算符,則為true;否則為flase#lt# 若左邊的運算符嚴(yán)格小于右邊的運算符,則為true;否則為flase#le# 若左邊的運算符小于或等于右邊的運算符,則為true;否則為flase#and# 僅當(dāng)兩個參數(shù)都為true
19、時,結(jié)果為true;否則為flase#or# 僅當(dāng)兩個參數(shù)都為false時,結(jié)果為false;否則為true這些運算符的優(yōu)先級由高到低為:高 #not# #eq# #ne# #gt# #ge# #lt# #le#低 #and# #or#培訓(xùn)教案LINGO程序結(jié)構(gòu)程序結(jié)構(gòu)數(shù)學(xué)算符數(shù)學(xué)算符二、數(shù)學(xué)函數(shù)二、數(shù)學(xué)函數(shù)LINGO提供了大量的標(biāo)準(zhǔn)數(shù)學(xué)函數(shù):abs(x) 返回x的絕對值sin(x) 返回x的正弦值,x采用弧度制cos(x) 返回x的余弦值tan(x) 返回x的正切值exp(x) 返回常數(shù)e的x次方log(x) 返回x的自然對數(shù)lgm(x) 返回x的gamma函數(shù)的自然對數(shù)sign(x) 如果
20、x=0時,返回不超過x的最大整數(shù);當(dāng)x0時,返回不低于x的最小整數(shù)。smax(x1,x2,xn) 返回x1,x2,xn中的最大值smin(x1,x2,xn) 返回x1,x2,xn中的最小值培訓(xùn)教案LINGO程序結(jié)構(gòu)程序結(jié)構(gòu)應(yīng)用實例應(yīng)用實例應(yīng)用示例:給定一個直角三角形,求包含該三角形的最小正方形。 解:如圖所示。求最小的正方形就相當(dāng)于求如下的最優(yōu)化問題:LINGO代碼如下:model:sets: object/1.3/: f;endsetsdata: a, b = 3, 4; !兩個直角邊長,修改很方便;enddata f(1) = a * sin(x); f(2) = b * cos(x);
21、f(3) = a * cos(x) + b * sin(x); min = smax(f(1),f(2),f(3); bnd(0,x,1.57);endABCDEabx,sincos,cos,sinxbxaDExbADxaCE培訓(xùn)教案LINGO程序結(jié)構(gòu)程序結(jié)構(gòu)概率函數(shù)概率函數(shù)三、概率函數(shù)三、概率函數(shù)1pbn(p,n,x):二項分布的累積分布函數(shù)。當(dāng)n和(或)x不是整數(shù)時,用線性插值法進行計算。2pcx(n,x) :自由度為n的2分布的累積分布函數(shù)。3peb(a,x) :當(dāng)?shù)竭_負(fù)荷為a,服務(wù)系統(tǒng)有x個服務(wù)器且允許無窮排隊時的Erlang繁忙概率。4pel(a,x) :當(dāng)?shù)竭_負(fù)荷為a,服務(wù)系統(tǒng)有x
22、個服務(wù)器且不允許排隊時的Erlang繁忙概率。5pfd(n,d,x) :自由度為n和d的F分布的累積分布函數(shù)。6pfs(a,x,c) :當(dāng)負(fù)荷上限為a,顧客數(shù)為c,平行服務(wù)器數(shù)量為x時,有限源的Poisson服務(wù)系統(tǒng)的等待或返修顧客數(shù)的期望值。a是顧客數(shù)乘以平均服務(wù)時間,再除以平均返修時間。當(dāng)c和(或)x不是整數(shù)時,采用線性插值進行計算。7phg(pop,g,n,x) :超幾何(Hypergeometric)分布的累積分布函數(shù)。pop表示產(chǎn)品總數(shù),g是正品數(shù)。從所有產(chǎn)品中任意取出n(npop)件。pop,g,n和x都可以是非整數(shù),這時采用線性插值進行計算。8ppl(a,x)Poisson :分
23、布的線性損失函數(shù),即返回max(0,z-x)的期望值,其中隨機變量z服從均值為a的Poisson分布。9pps(a,x) :均值為a的Poisson分布的累積分布函數(shù)。當(dāng)x不是整數(shù)時,采用線性插值進行計算。10psl(x) :單位正態(tài)線性損失函數(shù),即返回max(0,z-x)的期望值,其中隨機變量z服從標(biāo)準(zhǔn)正態(tài)分布。11psn(x) :標(biāo)準(zhǔn)正態(tài)分布的累積分布函數(shù)12ptd(n,x) :自由度為n的t分布的累積分布函數(shù)。培訓(xùn)教案LINGO程序結(jié)構(gòu)程序結(jié)構(gòu)qrandqrand13qrand(seed):產(chǎn)生服從(0,1)區(qū)間的擬隨機數(shù)。qrand只允許在模型的數(shù)據(jù)部分使用,它將用擬隨機數(shù)填滿集屬性。
24、通常,聲明一個mn的二維表,m表示運行實驗的次數(shù),n表示每次實驗所需的隨機數(shù)的個數(shù)。在行內(nèi),隨機數(shù)是獨立分布的;在行間,隨機數(shù)是非常均勻的。這些隨機數(shù)是用“分層取樣”的方法產(chǎn)生的。model:data: M=4; N=2; seed=1234567;enddatasets: rows/1.M/; cols/1.N/; table(rows,cols): x;endsetsdata: X=qrand(seed);enddataend如果沒有為函數(shù)指定種子,那么LINGO將用系統(tǒng)時間構(gòu)造種子。培訓(xùn)教案LINGO程序結(jié)構(gòu)程序結(jié)構(gòu)randrand14rand(seed)返回0和1間的偽隨機數(shù),依賴于指
25、定的種子。典型用法是U(I+1)=rand(U(I)。注意如果seed不變,那么產(chǎn)生的隨機數(shù)也不變。示例:利用rand產(chǎn)生15個標(biāo)準(zhǔn)正態(tài)分布的隨機數(shù)和自由度為2的t分布的隨機數(shù)。model:!產(chǎn)生一列正態(tài)分布和t分布的隨機數(shù);sets: series/1.15/: u, znorm, zt;endsets !第一個均勻分布隨機數(shù)是任意的; u( 1) = rand( .1234); !產(chǎn)生其余的均勻分布的隨機數(shù); for(series( I)| I #GT# 1:u( I) = rand( u( I - 1) ); for( series( I): !正態(tài)分布隨機數(shù); psn( znorm(
26、I) = u( I); !和自由度為2的t分布隨機數(shù); ptd( 2, zt( I) = u( I); !ZNORM 和 ZT 可以是負(fù)數(shù); free( znorm( I); free( zt( I); );end培訓(xùn)教案LINGO程序結(jié)構(gòu)程序結(jié)構(gòu)變量界定函數(shù)變量界定函數(shù)四、變量界定函數(shù)四、變量界定函數(shù)變量界定函數(shù)實現(xiàn)對變量取值范圍的附加限制,共4種:bin(x):限制x為0或1bnd(L,x,U):限制LxUfree(x) :取消對變量x的默認(rèn)下界為0的限制,即x可以取任意實數(shù)gin(x):限制x為整數(shù)在默認(rèn)情況下,LINGO規(guī)定變量是非負(fù)的,也就是說下界為0,上界為+。free取消了默認(rèn)的
27、下界為0的限制,使變量也可以取負(fù)值。bnd用于設(shè)定一個變量的上下界,它也可以取消默認(rèn)下界為0的約束。應(yīng)用示例:(1)min=x1+x2;x1-x2=2;x1+2*x20。(4)若將程序修改為:max=x1+x2;x1-x2=2;x1+2*x2= required(J);end培訓(xùn)教案LINGO程序結(jié)構(gòu)程序結(jié)構(gòu)應(yīng)用實例應(yīng)用實例計算的部分結(jié)果為Global optimal solution found at iteration: 0 Objective value: 22.00000 Variable Value Reduced Cost REQUIRED( MON) 20.00000 0.000
28、000 REQUIRED( TUE) 16.00000 0.000000 REQUIRED( WED) 13.00000 0.000000 REQUIRED( THU) 16.00000 0.000000 REQUIRED( FRI) 19.00000 0.000000 REQUIRED( SAT) 14.00000 0.000000 REQUIRED( SUN) 12.00000 0.000000 START( MON) 8.000000 0.000000 START( TUE) 2.000000 0.000000 START( WED) 0.000000 0.3333333 START(
29、THU) 6.000000 0.000000 START( FRI) 3.000000 0.000000 START( SAT) 3.000000 0.000000 START( SUN) 0.000000 0.000000從而解決方案是:每周最少需要22個職員,周一安排8人,周二安排2人,周三無需安排人,周四安排6人,周五和周六都安排3人,周日無需安排人。培訓(xùn)教案LINGO程序結(jié)構(gòu)程序結(jié)構(gòu)集循環(huán)函數(shù)集循環(huán)函數(shù)3. prod函數(shù):用于獲取集中所有元素的乘積。示例:MODEL:SETS:COMPONENTS: P;ENDSETSDATA:P = .95 .99 .98;ENDDATAP_FAIL
30、 = 1 - PROD( COMPONENTS( I): P( I);END本例中P_FAIL表示的是一個串聯(lián)系統(tǒng)失效的概率。培訓(xùn)教案LINGO程序結(jié)構(gòu)程序結(jié)構(gòu)輔助函數(shù)輔助函數(shù)七、輔助函數(shù)七、輔助函數(shù)1if(logical_condition,true_result,false_result)if函數(shù)將評價一個邏輯表達式logical_condition,如果為真,返回true_ result,否則返回false_result。示例1:求解最優(yōu)化問題其LINGO代碼如下:model: min=fx+fy; fx=if(x #gt# 0, 100,0)+2*x; fy=if(y #gt# 0,6
31、0,0)+3*y; x+y=30;end 2warn(text,logical_condition)如果邏輯條件logical_condition為真,則產(chǎn)生一個內(nèi)容為text的信息框。示例2:model: x=1; warn(x是正數(shù),x #gt# 0); end培訓(xùn)教案LINGO簡單的命令行命令及應(yīng)用簡單的命令行命令及應(yīng)用命令行命令一般用于非windows系統(tǒng)的計算機中,我們可以通過菜單行中找到“command window”或者按組合鍵“CTRL+1” 來啟動命令窗口。在這里僅僅對簡單的命令作一下介紹。cat顯示所有命令類型;com按類型顯示所有命令;model開始以命令行方式輸入一個模
32、型;go求解當(dāng)前模型;solu顯示當(dāng)前模型的求解結(jié)果;quit退出lingo系統(tǒng)。培訓(xùn)教案LINGOLINGOLINGO實戰(zhàn)實戰(zhàn)線性規(guī)劃線性規(guī)劃某家具公司制造書桌、餐桌和椅子,所用的資源有三種:木料、木工和漆工。生產(chǎn)數(shù)據(jù)如下表所示:若要求桌子的生產(chǎn)量不超過5件,如何安排三種產(chǎn)品的生產(chǎn)可使利潤最大?每個書桌每個餐桌每個椅子現(xiàn)有資源總數(shù)木料8單位6單位1單位48單位漆工4單位2單位1.5單位20單位木工2單位1.5單位0.5單位8單位成本單價60單位30單位20單位培訓(xùn)教案LINGOLINGOLINGO實戰(zhàn)實戰(zhàn)線性規(guī)劃線性規(guī)劃分析:這是一個典型的線性規(guī)劃問題。我們用DESKS、TABLES和CHA
33、IRS分別表示三種產(chǎn)品的生產(chǎn)量,建立LP模型。程序如下所示:max=60*desks+30*tables+20*chairs; 8*desks+6*tables+chairs=48;4*desks+2*tables+1.5*chairs=20;2*desks+1.5*tables+.5*chairs=8;tables=5;在變量較少的情況下,用這種格式是比較方便的,但是當(dāng)變量增多時,這樣的寫法就會耗時耗力了。因此,我們提倡用lingo提供的函數(shù)來簡化模型的結(jié)構(gòu),使之更加易寫與易讀。首先,我們要定義集合:sets:products/desks,tables,chairs/:interest,vo
34、lume;materials/a.c/:capacity;links(products,materials):x;endsets培訓(xùn)教案LINGOLINGOLINGO實戰(zhàn)實戰(zhàn)線性規(guī)劃線性規(guī)劃現(xiàn)在我們來定義數(shù)據(jù)部分:data:interest=60,30,20;capacity=48,20,8;x=8,4,26,2,1.51,1.5,0.5;enddata然后我們寫出目標(biāo)函數(shù)與約束條件:max=sum(products(i):interest(i)*volume(i);for(materials(j):sum(products(i):x(i,j)*volume(i)=capacity(j);vo
35、lume(2)=5;最后,我們只需要將這幾部分組合起來即可。培訓(xùn)教案LINGOLINGOLINGO實戰(zhàn)實戰(zhàn)線性規(guī)劃線性規(guī)劃model:sets:products/desks,tables,chairs/:interest,volume;materials/a.c/:capacity;links(products,materials):x;endsetsdata:interest=60,30,20;capacity=48,20,8;x=8,4,26,2,1.51,1.5,0.5;enddatamax=sum(products(i):interest(i)*volume(i);for(materi
36、als(j):sum(products(i):x(i,j)*volume(i)=capacity(j);volume(2)=5;end培訓(xùn)教案LINGOLINGOLINGO實戰(zhàn)實戰(zhàn)線性規(guī)劃線性規(guī)劃Objective value: 280.0000Total solver iterations: 2Variable Value Reduced CostVOLUME( DESKS) 2.000000 0.000000 VOLUME( TABLES) 0.000000 5.000000 VOLUME( CHAIRS) 8.000000 0.000000 Row Slack or Surplus Du
37、al Price 1 280.0000 1.000000 2 24.00000 0.000000 3 0.000000 10.00000 4 0.000000 10.00000 5 5.000000 0.000000“Global optimal solution found at iteration: 2”表示2次迭代后得到全局最優(yōu)解。 “Objective value:280.0000”表示最優(yōu)目標(biāo)值為280。 培訓(xùn)教案LINGOLINGOLINGO實戰(zhàn)實戰(zhàn)線性規(guī)劃線性規(guī)劃“Reduced Cost”列出最優(yōu)單純形表中判別數(shù)所在行的變量的系數(shù),表示當(dāng)變量有微小變動時, 目標(biāo)函數(shù)的變化率。其
38、中基變量的reduced cost值應(yīng)為0, 對于非基變量 Xj, 相應(yīng)的 reduced cost值表示當(dāng)某個變量Xj 增加一個單位時目標(biāo)函數(shù)減少的量( max型問題)。本例中:變量tables對應(yīng)的reduced cost值為5,表示當(dāng)非基變量tables的值從0變?yōu)?1時(此時假定其他非基變量保持不變,但為了滿足約束條件,基變量顯然會發(fā)生變化),最優(yōu)的目標(biāo)函數(shù)值 = 280 - 5 = 275?!癉UAL PRICE”(對偶價格)表示當(dāng)對應(yīng)約束有微小變動時, 目標(biāo)函數(shù)的變化率。輸出結(jié)果中對應(yīng)于每一個約束有一個對偶價格。 若其數(shù)值為p, 表示對應(yīng)約束中不等式右端項若增加1 個單位,目標(biāo)函數(shù)
39、將增加p個單位(max型問題)。顯然,如果在最優(yōu)解處約束正好取等號(也就是“緊約束”,也稱為有效約束或起作用約束),對偶價格值才可能不是0。本例中:第3、4行是緊約束,對應(yīng)的對偶價格值為10,表示當(dāng)緊約束 3) 4 DESKS + 2 TABLES + 1.5 CHAIRS = 20 變?yōu)?3) 4 DESKS + 2 TABLES + 1.5 CHAIRS = 21 時,目標(biāo)函數(shù)值 = 280 +10 = 290。對第4行也類似。 對于非緊約束(如本例中第2、5行是非緊約束),DUAL PRICE 的值為0, 表示對應(yīng)約束中不等式右端項的微小擾動不影響目標(biāo)函數(shù)。有時, 通過分析DUAL PR
40、ICE, 也可對產(chǎn)生不可行問題的原因有所了解。培訓(xùn)教案LINGOLINGOLINGO實戰(zhàn)實戰(zhàn)靈敏度分析靈敏度分析下面我們來做靈敏度分析:首先,我們要啟動靈敏度分析,即將“General Solver”選項卡中的“Dual Computation”下拉項修改為“Prices & Ranges”。然后,我們點“Solve”運行程序,運行完之后,回到模型界面,點擊“l(fā)ingo”菜單下的“range”選項即可得到結(jié)果。結(jié)果顯示如下: Ranges in which the basis is unchanged: Objective Coefficient Ranges Current Allo
41、wable Allowable Variable Coefficient Increase Decrease VOLUME( DESKS) 60.00000 20.00000 4.000000 VOLUME( TABLES) 30.00000 5.000000 INFINITY VOLUME( CHAIRS) 20.00000 2.500000 5.000000培訓(xùn)教案LINGOLINGOLINGO實戰(zhàn)實戰(zhàn)靈敏度分析靈敏度分析 Righthand Side Ranges Row Current Allowable Allowable RHS Increase Decrease 2 48.000
42、00 INFINITY 24.00000 3 20.00000 4.000000 4.000000 4 8.000000 2.000000 1.333333 5 5.000000 INFINITY 5.000000培訓(xùn)教案LINGOLINGOLINGO實戰(zhàn)實戰(zhàn)靈敏度分析靈敏度分析目標(biāo)函數(shù)中DESKS變量原來的費用系數(shù)為60,允許增加(Allowable Increase)=4、允許減少(Allowable Decrease)=2,說明當(dāng)它在60-4,60+20 = 56,80范圍變化時,最優(yōu)基保持不變。對TABLES、CHAIRS變量,可以類似解釋。由于此時約束沒有變化(只是目標(biāo)函數(shù)中某個費用
43、系數(shù)發(fā)生變化),所以最優(yōu)基保持不變的意思也就是最優(yōu)解不變(當(dāng)然,由于目標(biāo)函數(shù)中費用系數(shù)發(fā)生了變化,所以最優(yōu)值會變化)。 第2行約束中右端項(Right Hand Side,簡寫為RHS)原來為48,當(dāng)它在48-24,48+ = 24,范圍變化時,最優(yōu)基保持不變。第3、4、5行可以類似解釋。不過由于此時約束發(fā)生變化,最優(yōu)基即使不變,最優(yōu)解、最優(yōu)值也會發(fā)生變化。靈敏性分析結(jié)果表示的是最優(yōu)基保持不變的系數(shù)范圍。由此,也可以進一步確定當(dāng)目標(biāo)函數(shù)的費用系數(shù)和約束右端項發(fā)生小的變化時,最優(yōu)基和最優(yōu)解、最優(yōu)值如何變化。下面我們通過求解一個實際問題來進行說明。培訓(xùn)教案LINGOLINGOLINGO實戰(zhàn)實戰(zhàn)靈敏
44、度分析靈敏度分析一奶制品加工廠用牛奶生產(chǎn)A1,A2兩種奶制品,1桶牛奶可以在甲車間用12小時加工成3公斤A1,或者在乙車間用8小時加工成4公斤A2。根據(jù)市場需求,生產(chǎn)的A1,A2全部能售出,且每公斤A1獲利24元,每公斤A2獲利16元?,F(xiàn)在加工廠每天能得到50桶牛奶的供應(yīng),每天正式工人總的勞動時間480小時,并且甲車間每天至多能加工100公斤A1,乙車間的加工能力沒有限制。試為該廠制訂一個生產(chǎn)計劃,使每天獲利最大,并進一步討論以下3個附加問題: 1) 若用35元可以買到1桶牛奶,應(yīng)否作這項投資?若投資,每天最多購買多少桶牛奶? 2) 若可以聘用臨時工人以增加勞動時間,付給臨時工人的工資最多是每
45、小時幾元? 3) 由于市場需求變化,每公斤A1的獲利增加到30元,應(yīng)否改變生產(chǎn)計劃?模型很簡單,設(shè)生產(chǎn)A1的數(shù)量為x1,生產(chǎn)A2的數(shù)量為x2,代碼如下:max=72*x1+64*x2;x1+x2=50;12*x1+8*x2=480;3*x1=100;培訓(xùn)教案LINGOLINGOLINGO實戰(zhàn)實戰(zhàn)靈敏度分析靈敏度分析求解這個模型并做靈敏性分析,結(jié)果如下。 Global optimal solution found at iteration: 0 Objective value: 3360.000 Variable Value Reduced Cost X1 20.00000 0.000000 X
46、2 30.00000 0.000000 Row Slack or Surplus Dual Price 1 3360.000 1.000000 2 0.000000 48.00000 3 0.000000 2.000000 4 40.00000 0.000000培訓(xùn)教案LINGOLINGOLINGO實戰(zhàn)實戰(zhàn)靈敏度分析靈敏度分析Ranges in which the basis is unchanged: Objective Coefficient Ranges Current Allowable AllowableVariable Coefficient Increase Decrease X
47、1 72.00000 24.00000 8.000000 X2 64.00000 8.000000 16.00000 Righthand Side Ranges Row Current Allowable Allowable RHS Increase Decrease 2 50.00000 10.00000 6.666667 3 480.0000 53.33333 80.00000 4 100.0000 INFINITY 40.00000培訓(xùn)教案LINGOLINGOLINGO實戰(zhàn)實戰(zhàn)靈敏度分析靈敏度分析目標(biāo)函數(shù)可以看作“效益”,成為緊約束的“資源”一旦增加,“效益”必然跟著增長。輸出中DUAL
48、 PRICES 給出這3種資源在最優(yōu)解下“資源”增加1個單位時“效益”的增量:原料增加1個單位(1桶牛奶)時利潤增長48(元),勞動時間增加1個單位(1小時)時利潤增長2(元),而增加非緊約束車間甲的能力顯然不會使利潤增長。這里,“效益”的增量可以看作“資源”的潛在價值,經(jīng)濟學(xué)上稱為影子價格,即1桶牛奶的影子價格為48元,1小時勞動的影子價格為2元,車間甲的影子價格為零。讀者可以用直接求解的辦法驗證上面的結(jié)論,即將輸入文件中原料約束milk)右端的50改為51,看看得到的最優(yōu)值(利潤)是否恰好增長48(元)。用影子價格的概念很容易回答附加問題1):用35元可以買到1桶牛奶,低于1桶牛奶的影子價
49、格48,當(dāng)然應(yīng)該作這項投資?;卮鸶郊訂栴}2):聘用臨時工人以增加勞動時間,付給的工資低于勞動時間的影子價格才可以增加利潤,所以工資最多是每小時2元。 目標(biāo)函數(shù)的系數(shù)發(fā)生變化時(假定約束條件不變),最優(yōu)解和最優(yōu)值會改變嗎?這個問題不能簡單地回答。上面輸出給出了最優(yōu)基不變條件下目標(biāo)函數(shù)系數(shù)的允許變化范圍:x1的系數(shù)為(72-8,72+24)=(64,96);x2的系數(shù)為(64-16,64+8)=(48,72)。注意:x1系數(shù)的允許范圍需要x2系數(shù)64不變,反之亦然。由于目標(biāo)函數(shù)的費用系數(shù)變化并不影響約束條件,因此此時最優(yōu)基不變可以保證最優(yōu)解也不變,但最優(yōu)值變化。用這個結(jié)果很容易回答附加問題3):若
50、每公斤A1的獲利增加到30元,則x1系數(shù)變?yōu)?03=90,在允許范圍內(nèi),所以不應(yīng)改變生產(chǎn)計劃,但最優(yōu)值變?yōu)?020+6430=3720。 培訓(xùn)教案LINGOLINGOLINGO實戰(zhàn)實戰(zhàn)靈敏度分析靈敏度分析下面對“資源”的影子價格作進一步的分析。影子價格的作用(即在最優(yōu)解下“資源”增加1個單位時“效益”的增量)是有限制的。每增加1桶牛奶利潤增長48元(影子價格),但是,上 面輸出的CURRENT RHS 的ALLOWABLE INCREASE 和 ALLOWABLE DECREASE 給出了影子價格有意義條件下約束右端的限制范圍: milk)原料最多增加10(桶牛奶),time)勞動時間最多增加
51、53(小時)?,F(xiàn)在可以回答附加問題1)的第2問:雖然應(yīng)該批準(zhǔn)用35元買1桶牛奶的投資,但每天最多購買10桶牛奶。順便地說,可以用低于每小時2元的工資聘用臨時工人以增加勞動時間,但最多增加53.3333小時。 需要注意的是:靈敏性分析給出的只是最優(yōu)基保持不變的充分條件,而不一定是必要條件。比如對于上面的問題,“原料最多增加10(桶牛奶)”的含義只能是“原料增加10(桶牛奶)”時最優(yōu)基保持不變,所以影子價格有意義,即利潤的增加大于牛奶的投資。反過來,原料增加超過10(桶牛奶),影子價格是否一定沒有意義?最優(yōu)基是否一定改變?一般來說,這是不能從靈敏性分析報告中直接得到的。此時,應(yīng)該重新用新數(shù)據(jù)求解規(guī)
52、劃模型,才能做出判斷。所以,從正常理解的角度來看,我們上面回答“原料最多增加10(桶牛奶)”并不是完全科學(xué)的。培訓(xùn)教案LINGOLINGOLINGO實戰(zhàn)實戰(zhàn)整數(shù)規(guī)劃整數(shù)規(guī)劃有四種資源被用于生產(chǎn)三種產(chǎn)品,資源量、產(chǎn)品單件可變費用、單件售價、資源單耗量及組織三種商品生產(chǎn)的固定費用見下表?,F(xiàn)要求制定一個生產(chǎn)計劃,使總收益最大。產(chǎn)品IIIIII資源量A248500B234300C123100D357700單件可變費用4612固定費用100150200單件售價71020單耗量資源培訓(xùn)教案LINGOLINGOLINGO實戰(zhàn)實戰(zhàn)整數(shù)規(guī)劃整數(shù)規(guī)劃培訓(xùn)教案LINGOLINGOLINGO實戰(zhàn)實戰(zhàn)整數(shù)規(guī)劃整數(shù)規(guī)劃培
53、訓(xùn)教案LINGOLINGOLINGO實戰(zhàn)實戰(zhàn)整數(shù)規(guī)劃整數(shù)規(guī)劃培訓(xùn)教案LINGOLINGOLINGO實戰(zhàn)實戰(zhàn)整數(shù)規(guī)劃整數(shù)規(guī)劃下面是LINGO程序。MODEL:DATA:M=150;ENDDATAmax=3*x1+4*x2+8*x3-100*y1-150*y2-200*y3;!目標(biāo)函數(shù);2*x1+4*x2+8*x3=500;2*x1+3*x2+4*x3=300;x1+2*x2+3*x3=100;3*x1+5*x2+7*x3=700;x1=M*y1;x2=M*y2;x3=M*y3;GIN(x1);GIN(x2);GIN(x3); !指定產(chǎn)品件數(shù)為整數(shù);BIN(y1);BIN(y2);BIN(y3);
54、 !指定0-1變量;end得到的解為x1=100,x2=0,x3=0,y1=1,y2=0,y3=0。最大值為Z=200元。培訓(xùn)教案LINGOLINGOLINGO整數(shù)規(guī)劃整數(shù)規(guī)劃公司在各地有4項業(yè)務(wù),選定了4位業(yè)務(wù)員去處理。由于業(yè)務(wù)能力、經(jīng)驗和其它情況不同,4業(yè)務(wù)員去處理4項業(yè)務(wù)的費用(單位:元)各不相同,見下表:業(yè)務(wù)業(yè)務(wù)業(yè)務(wù)員業(yè)務(wù)員1234111008001000700260050030080034008001000900411001000500700應(yīng)當(dāng)怎樣分派任務(wù),才能使總的費用最?。颗嘤?xùn)教案LINGOLINGOLINGO實戰(zhàn)實戰(zhàn)整數(shù)規(guī)劃整數(shù)規(guī)劃培訓(xùn)教案LINGOLINGOLINGO實戰(zhàn)實
55、戰(zhàn)整數(shù)規(guī)劃整數(shù)規(guī)劃LINGO程序如下:MODEL:SETS:person/1.4/;task/1.4/;assign(person,task):a,x;ENDSETSDATA:a=1100,800,1000,700, 600,500,300,800,400,800,1000,900,1100,1000,500,700;ENDDATAmin=sum(assign:a*x);for(person(i):sum(task(j):x(i,j)=1);for(task(j):sum(person(i):x(i,j)=1);for(assign(i,j):bin(x(i,j);END培訓(xùn)教案LINGOLI
56、NGOLINGO實戰(zhàn)實戰(zhàn)整數(shù)規(guī)劃整數(shù)規(guī)劃得到的結(jié)果如下:x(1,1)=0,x(1,2)=0,x(1,3)=0,x(1,4)=1;x(2,1)=0,x(2,2)=1,x(2,3)=0,x(2,4)=0;x(3,1)=1,x(3,2)=0,x(3,3)=0,x(3,4)=0;x(4,1)=0,x(4,2)=0,x(4,3)=1,x(4,4)=0;最小費用為2100元。即第1個業(yè)余員做第4項業(yè)務(wù),第2個業(yè)余員做第2項業(yè)務(wù),即第3個業(yè)余員做第1項業(yè)務(wù),第4業(yè)余員做第3項業(yè)務(wù)。總費用達到最小,為2100元。培訓(xùn)教案LINGOLINGOLINGO實戰(zhàn)實戰(zhàn)TSPTSP問題問題設(shè)有一個售貨員從10個城市中的某
57、一個城市出發(fā),去其它9個城市推銷產(chǎn)品。10個城市相互距離如下表。要求每個城市到達一次僅一次后,回到原出發(fā)城市。問他應(yīng)如何選擇旅行路線,使總路程最短。城市城市1234567891010745861213111827031091451417173430591021827124510501491092316589914078720196614109701352513712521108130232118813148975230181291117272320252118016101817121619131812160培訓(xùn)教案LINGOLINGOLINGO實戰(zhàn)實戰(zhàn)TSPTSP問題問題培訓(xùn)教案LINGOLI
58、NGOLINGO實戰(zhàn)實戰(zhàn)TSPTSP問題問題LINGO程序如下:!TSP quesion;MODEL:SETS:city/1.10/;link(city,city)|&1#GT#&2:d,s;ENDSETSDATA:d= 7 4 3 5 10 5 8 9 9 14 6 14 10 9 7 12 5 21 10 8 13 13 14 8 9 7 5 23 11 17 27 23 20 25 21 18 18 17 12 16 19 13 18 12 16; 培訓(xùn)教案LINGOLINGOLINGO實戰(zhàn)實戰(zhàn)TSPTSP問題問題ENDDATA MIN=SUM(link:d*s); SU
59、M(city(j)|j#GT#1:S(j,1)=2; !與第1個城市相連的有兩個城市; !與第i個城市相連有兩個城市; FOR(city(i)|i#GT#1:SUM(city(j)|j#GT#i:s(j,i)+ SUM(city(k)|k#LT#i:s(i,k)=2);FOR(link:BIN(s);得到的結(jié)果如下: S(3,2)=1,S(4,1)=1,S(4,3)=1,S(6,5)=1,S(7,2)=1,S(7,5)=1,S(8,6)=1,S(9,1)=1,S(10,8)=1,S(10,9)=1。其它全為0。 其最短路線為143275681091,最短距離為77公里。培訓(xùn)教案LINGOLIN
60、GOLINGO實戰(zhàn)實戰(zhàn)非線性規(guī)劃非線性規(guī)劃 使用LINGO軟件計算6個發(fā)點8個收點的最小費用運輸問題。產(chǎn)銷單位運價如下表。 單單 銷地銷地位運位運價價產(chǎn)產(chǎn)地地B B1 1B B2 2B B3 3B B4 4B B5 5B B6 6B B7 7B B8 8產(chǎn)產(chǎn)量量A A1 16 62 26 67 74 42 25 59 96060A A2 24 49 95 53 38 85 58 82 25555A A3 35 52 21 19 97 74 43 33 35151A A4 47 76 67 73 39 92 27 71 14343A A5 52 23 39 95 57 72 26 65 54141A A6 65 55 52 22
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五年度建筑企業(yè)施工人員勞動保障合同2篇
- 二零二五年度工傷免責(zé)風(fēng)險評估與防范合同3篇
- 二零二五年度個體工商戶租賃合同及創(chuàng)業(yè)投資服務(wù)協(xié)議3篇
- 二零二五年度智慧農(nóng)業(yè)設(shè)施安裝與運營合同3篇
- 2025年度版權(quán)購買合同:影視作品全球版權(quán)交易3篇
- 2025年度環(huán)境治理與污染物減排合同3篇
- 2025年度綠色信托投資公司專項借款合同3篇
- 二零二五年度哈爾濱市租賃市場標(biāo)準(zhǔn)協(xié)議3篇
- 2025年度碎石加工廢棄物處理與資源化利用合同3篇
- 2025版數(shù)據(jù)中心按份額擔(dān)保合同范本3篇
- 急診課件:急性呼吸困難完整版
- 分布式光伏項目施工合同
- 金融業(yè)分布式信息系統(tǒng)運維技術(shù)研究報告
- 三角形鋼管懸挑腳手架施工方案
- 電力基建項目管理實施規(guī)劃范本
- 壓力容器風(fēng)險評估報告樣板
- 胃黏膜腸上皮化生
- 汽車離合器設(shè)計畢業(yè)設(shè)計(論文)
- 2023年房屋租賃管理模板
- 全部編版四年級語文下生字讀音、音序、偏旁及組詞
- 藥物的不良反應(yīng)
評論
0/150
提交評論