版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、数学建模与数学实验,非线性规划,主讲教师:鄢化彪,供应与选址,某公司有6个建筑工地要开工,每个工地的位置(用平面坐标系a,b表示,距离单位:km)及水泥日用量d(t)由下表给出目前有两个临时料场位于A(5,1),B(2,7),日储量各有20t假设从料场到工地之间均有直线道路相连 (1)试制定每天的供应计划,即从A,B两料场分别向各工地运送多少水泥,可使总的吨千米数最小 (2)为了进一步减少吨千米数,打算舍弃两个临时料场,改建两个新的,日储量各为20t,问应建在何处,节省的吨千米数有多大?,*非线性规划的基本解法,非线性规划的基本概念,非线性规划,返回,定义 如果目标函数或约束条件中至少有一个是
2、非线性函数,则最优化问题就叫做非线性规划问题,非现性规划的基本概念,一般形式: (1) 其中 , 是定义在 Rn 上的实值函数,简记:,其它情况: 求目标函数的最大值,或约束条件小于等于零两种情况,都可通过取其相反数化为上述一般形式,定义1 把满足问题(1)中条件的解 称为可行解(或可行点),所有可行点的集合称为可行集(或可行域)记为D即 问题(1)可简记为 ,定义2 对于问题(1),设 ,若存在 ,使得对一切 ,且 ,都有 ,则称X*是f(X)在D上的局部极小值点(局部最优解)特别地,当 时,若 ,则称X*是f(X)在D上的严格局部极小值点(严格局部最优解),定义3 对于问题(1),设 ,若
3、对任意的 ,都有 则称X*是f(X)在D上的全局极小值点(全局最优解)特别地,当 时,若 ,则称X*是f(X)在D上的严格全局极小值点(严格全局最优解),返回,非线性规划的基本解法,2、近似规划法,返回,用MATLAB软件求解,其输入格式如下: 1x=quadprog(H,C,A,b); 2x=quadprog(H,C,A,b,Aeq,beq); 3x=quadprog(H,C,A,b,Aeq,beq,VLB,VUB); 4x=quadprog(H,C,A,b, Aeq,beq ,VLB,VUB,X0); 5x=quadprog(H,C,A,b,Aeq,beq,VLB,VUB,X0,optio
4、ns); 6x,fval=quaprog(); 7x,fval,exitflag=quaprog(); 8x,fval,exitflag,output=quaprog();,1二次规划,例1 min f(x1,x2)=-2x1-6x2+x12-2x1x2+2x22 s.t. x1+x22 -x1+2x22 x10, x20,MATLAB(youh1),1写成标准形式:,2输入命令: H=1 -1; -1 2; c=-2 ;-6;A=1 1; -1 2;b=2;2; Aeq=;beq=; VLB=0;0;VUB=; x,z=quadprog(H,c,A,b,Aeq,beq,VLB,VUB),3运
5、算结果为:x =0667 1333 z = -8222,s.t.,1 首先建立M文件fun.m,用来定义目标函数F(X): function f=fun(X); f=F(X);,2一般非线性规划,其中X为n维变元向量,G(X)与Ceq(X)均为非线性函数组成的向量,其他变量的含义与线性规划、二次规划中相同用MATLAB求解上述问题,基本步骤分三步:,3 建立主程序.求解非线性规划的函数是fmincon,命令的基本格式如下: (1) x=fmincon(fun,X0,A,b) (2) x=fmincon(fun,X0,A,b,Aeq,beq) (3) x=fmincon(fun,X0,A,b,
6、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(),输出极值点,M文件,迭代的初值,参数说明,变量上下限,注意: 1 fmincon函数提供了大型优化算法和中型优化算法默认时: 若在fun函数中提供了梯度(options参数
7、的GradObj设置为on),并且只有上下界存在或只有等式约束,fmincon函数将选择大型算法当既有等式约束又有梯度约束时,使用中型算法 2 fmincon函数的中型算法使用的是序列二次规划法在每一步迭代中求解二次规划子问题,并用BFGS法更新拉格朗日Hesse矩阵 3 fmincon函数可能会给出局部最优解,这与初值X0的选取有关,1写成标准形式: s.t.,2x1+3x2 6 s.t. x1+4x2 5 x1,x2 0,例2,2先建立M-文件 fun3m: function f=fun3(x); f=-x(1)-2*x(2)+(1/2)*x(1)2+(1/2)*x(2)2,MATLAB(
8、youh2),3再建立主程序youh2m: x0=1;1; A=2 3 ;1 4; b=6;5; Aeq=;beq=; VLB=0;0; VUB=; x,fval=fmincon(fun3,x0,A,b,Aeq,beq,VLB,VUB),4运算结果为: x = 07647 10588 fval = -20294,1先建立M文件fun4m定义目标函数: function f=fun4(x); f=exp(x(1) *(4*x(1)2+2*x(2)2+4*x(1)*x(2)+2*x(2)+1);,x1+x2=0 s.t. 1.5+x1x2 - x1 - x2 0 -x1x2 10 0,例3,2再建
9、立M文件myconm定义非线性约束: function g,ceq=mycon(x) g=x(1)+x(2);15+x(1)*x(2)-x(1)-x(2); -x(1)*x(2)-10;,3主程序youh3m为: x0=-1;1; A=;b=; Aeq=1 1;beq=0; vlb=;vub=; x,fval=fmincon(fun4,x0,A,b,Aeq,beq,vlb, vub,mycon),MATLAB(youh3),4 运算结果为: x = -12250 12250 fval = 18951,例4,1先建立M文件funm定义目标函数: function f=fun(x); f=-2*x
10、(1)-x(2);,2再建立M文件mycon2m定义非线性约束: function g,ceq=mycon2(x) g=x(1)2+x(2)2-25;x(1)2-x(2)2-7;,3 主程序fxxm为: x0=3;25; VLB=0 0;VUB=5 10; x,fval,exitflag,output =fmincon(fun,x0, VLB,VUB,mycon2),MATLAB(fxx(fun),4 运算结果为: x = 40000 30000 fval =-110000 exitflag = 1 output = iterations: 4 funcCount: 17 stepsize:
11、1 algorithm: 1x44 char firstorderopt: cgiterations: ,返回,应用实例: 供应与选址,某公司有6个建筑工地要开工,每个工地的位置(用平面坐标系a,b表示,距离单位:km)及水泥日用量d(t)由下表给出目前有两个临时料场位于A(5,1),B(2,7),日储量各有20t假设从料场到工地之间均有直线道路相连 (1)试制定每天的供应计划,即从A,B两料场分别向各工地运送多少水泥,可使总的吨千米数最小 (2)为了进一步减少吨千米数,打算舍弃两个临时料场,改建两个新的,日储量各为20t,问应建在何处,节省的吨千米数有多大?,(一)建立模型,记工地的位置为(
12、ai,bi),水泥日用量为di,i=1,6;料场位置为(xj,yj),日储量为ej,j=1,2;料场j向工地i的运送量为Xij,当用临时料场时决策变量为:Xij, 当不用临时料场时决策变量为:Xij,xj,yj,(二)使用临时料场的情形,使用两个临时料场A(5,1),B(2,7)求从料场j向工地i的运送量Xij . 在各工地用量必须满足和各料场运送量不超过日储量的条件下,使总的吨千米数最小,这是线性规划问题 线性规划模型为:,设 X11=X1, X21= X 2, X31= X 3, X41= X 4, X51= X 5, X61= X 6 X12= X 7, X22= X 8, X32= X
13、 9, X42= X 10, X52= X 11, X62= X 12 编写程序gying1m,MATLAB(gying1),计算结果为:,x = 30000 50000 00000 70000 00000 10000 00000 00000 40000 00000 60000 100000 fval = 1362275,(三)改建两个新料场的情形,改建两个新料场,要同时确定料场的位置(xj,yj)和运送量Xij,在同样条件下使总吨千米数最小这是非线性规划问题非线性规划模型为:,设 X11=X1, X21= X 2, X31= X 3, X41= X 4, X51= X 5, X61= X 6
14、 X12= X 7, X22= X 8, X32= X 9, X42= X 10, X52= X 11, X62= X 12 x1=X13, y1=X14, x2=X15, y2=X16,(1)先编写M文件liaochm定义目标函数,MATLAB(liaoch),(2) 取初值为线性规划的计算结果及临时料场的坐标: x0=3 5 0 7 0 1 0 0 4 0 6 10 5 1 2 7; 编写主程序gying2m,MATLAB(gying2),(3) 计算结果为:,x= 30000 50000 00707 70000 0 09293 0 0 39293 0 60000 100707 63875
15、 43943 57511 71867 fval = 1054626 exitflag = 1,(4) 若修改主程序gying2m, 取初值为上面的计算结果: x0= 30000 50000 00707 70000 0 09293 0 0 39293 0 60000 100707 63875 43943 57511 71867,则得结果为: x=30000 50000 03094 70000 00108 06798 0 0 36906 0 59892 103202 55369 49194 58291 72852 fval =1034760 exitflag = 1,总的吨千米数比上面结果略优,(
16、5) 若再取刚得出的结果为初值, 却计算不出最优解,MATLAB(gying2),MATLAB(gying2),(6) 若取初值为: x0=3 5 4 7 1 0 0 0 0 0 5 11 56348 48687 72479 77499, 则计算结果为: x=30000 50000 40000 70000 10000 0 0 0 0 0 50000 110000 56959 49285 72500 77500 fval =898835 exitflag = 1 总的吨千米数898835比上面结果更好,通过此例可看出fmincon函数在选取初值上的重要性,MATLAB(gying2),返回,钢管订购及运输优化模型,2000年“网易杯”全国大学生数学建模竞赛B题,模型
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 平面直角坐标系的概念课件2025-2026学年人教版七年级数学下册
- 职业病危害申报登记制度
- 服务满意度调查实施方案
- 苹果树轮纹病综合预防技术规范
- 雨水管网排污拦截管理规程
- 电力设备新能源行业市场前景及投资研究报告:全球能源锂电机遇
- AI智能汽车行业投资策略分析报告:小鹏吉利Robotaxi提速看好智能化
- 医学本科人体解剖学试题及解析
- 水肥一体化首部设备安装规范
- 蔗飞虱应急防治技术操作规范
- 特应性皮炎治疗药物临床试验技术指导原则
- 三位数加减三位数竖式计算题300道及答案
- Unit1Teenagelife大单元整体教学设计2024-2025学年高中英语人教版
- 第二届全国职业技能大赛数控铣项目(世赛)技术工作文件
- 五年级数学上册简易方程练习100题及答案
- DL∕T 1598-2016 信息机房(A级)综合监控技术规范
- 2025七八年级暑假每日一篇古诗文(八)
- DL-T5160-2015电力工程岩土描述技术规程
- 2013-2022年高考英语语法填空真题汇编(38套含答案解析)
- 过程流程图编制管理规范
- 2024中考复习必背初中英语单词词汇表(苏教译林版)
评论
0/150
提交评论