§2 非线性规划模型
一.非线性规划课题 实例1 表面积为36平方米的最大长方体体积。 建立数学模型: 设x、y、z分别为长方体的三个棱长,f为长方体体积。 max f = x y (36-2 x y)/2 (x+y) 实例2 投资决策问题 某公司准备用5000万元用于A、B两个项目的投资,设x1、x2分别表示配给项目A、B的投资。预计项目A、B的年收益分别为20%和16%。同时,投资后总的风险损失将随着总投资和单位投资的增加而增加,已知总的风险损失为2x12+x22+(x1+x2)2.问应如何分配资金,才能使期望的收益最大,同时使风险损失为最小。 建立数学模型: 目标函数中的λ≥0是权重系数。 由以上实例去掉实际背景,其目标函数与约束条件至少有一处是非线性的,称其为非线性问题。 非线性规划问题可分为无约束问题和有约束问题。实例1为无约束问题,实例2为有约束问题。 二.无约束非线性规划问题: 求解无约束最优化问题的方法主要有两类:直接搜索法(Search method)和梯度法(Gradient method). 1.fminunc函数 调用格式:
说明:fun为需最小化的目标函数,x0为给定的搜索的初始点。options指定优化参数。 返回的x为最优解向量;fval为x处的目标函数值;exitflag描述函数的输出条件;output返回优化信息;grad返回目标函数在x处的梯度。Hessian返回在x处目标函数的Hessian矩阵信息。 例1 : 求 程序:编辑ff1.m文件
通过绘图确定一个初始点:
选初始点:
结果: x =-4.0000 0.6667 fval =-17.3333 exitflag =1 例2: 程序:编辑ff2.m文件:
取初始点:
结果: x =1.0e-007 * -0.1721 0.1896 fval =2.7239e-016 exitflag =1 例3:将上例用提供的梯度g最小化函数进行优化计算。 修改M文件为:
通过下面将优化选项结构options.GradObj设置为’on’来得到梯度值。
结果: x =1.0e-015 * -0.2220 -0.2220 fval =5.4234e-031 exitflag =1 2. minsearch函数 调用格式:
说明:参数及返回变量同上一函数。对求解二次以上的问题,fminsearch函数比fminunc函数有效。 3. 多元非线性最小二乘问题: 非线线性最小二乘问题的数学模型为: 其中L为常数。 调用格式:
说明:x返回解向量;resnorm返回x处残差的平方范数值:sum(fun(x).^2);residual返回x处的残差值fun(x);lambda返回包含x处拉格朗日乘子的结构参数;jacobian返回解x处的fun函数的雅可比矩阵。 lsqnonlin默认时选择大型优化算法。Lsqnonlin通过将options.LargeScale设置为’off’来作中型优化算法。其采用一维搜索法。 例4.求 minf=4(x2-x1)2+(x2-4)2 ,选择初始点x0(1,1) 程序:
结果: x =3.9896 3.9912 reshorm =5.0037e-009 例5:求 ,选择初始点x0(0.2,0.3) 求解:先编辑ff5.m文件:
然后作程序:
结果 : x =0.2578 0.2578 resnorm =124.3622 二. 有约束非线性规划问题: 数学模型: , 在有约束非线性规划问题中,通常要将该问题转换为更简单的子问题,这些子问题可以求并作为迭代过程的基础。其基于K-T方程解的方法。它的K-T方程可表达为: 方程第一行描述了目标函数和约束条件在解处梯度的取消。由于梯度取消,需要用拉格朗日乘子λi来平衡目标函数与约束梯度间大小的差异。 调用格式:
说明: x=fmincon(f,x0,A,b)返回值x为最优解向量。其中:x0为初始点。A,b为不等式约束的系数矩阵和右端列向量。 x=fmincon(f,x0,A,b,Aeq,beq) 作有等式约束的问题。若没有不等式约束,则令A=[ ]、b=[ ] 。 x=fmincon(f, x0,A,b,Aeq,beq,lb,ub, nonlcon ,options) 中lb ,ub为变量x的下界和上界;nonlcon=@fun,由M文件fun.m给定非线性不等式约束c (x) ≤0和等式约束g(x)=0;options为指定优化参数进行最小化。 例6:求解: 程序:首先建立ff6.m文件:
然后在工作空间键入程序:
结果: x =1.0000 1.0000 fval =3.1936e-011 例7:求解: 首先建立目标函数文件ff7.m文件:
然后将约束条件改写成如下不等式:
在工作空间键入程序:
结果: x = 24.0000 12.0000 12.0000 fval =-3456 例8求解: 程序:首先建立目标函数文件ff8.m文件:
再建立非线性的约束条件文件:ff8g.m
然后在工作空间键入程序:
结果: x =-2.5000 1.0000 fval =3.3244 exitflag =1 当有等式约束时,要放在矩阵g的位置,如上例中加等式约束: x(1)+2*x(1)=0 程序:首先建立 fun1.m文件:
然后在工作空间键入程序:
结果: x =-2.2361 1.1180 fval =3.6576 exitflag =1 |
max f=2x1+5x2
s.t
min(-f)=- 2x1-5x2
minf=5x1-x2+2x3+3x4-8x5
s.t –2x1+x2-x3+x4-3x5≤6
2x1+x2-x3+4x4+x5≤7
0≤xj≤15 j=1,2,3,4,5
minf=5x1+x2+2x3+3x4+x5
s.t –2x1+x2-x3+x4-3x5≤1
2x1+3x2-x3+2x4+x5≤-2
0≤xj≤1 j=1,2,3,4,5
设x1、x2分别为生产甲、乙产品的件数。f为该厂所获总润。
max f=70x1+120x2
s.t 9x1+4x2≤3600
4x1+5x2≤2000
3x1+10x2≤3000
x1,x2≥0
min f=-70x1-120x2
s.t 9x1+4x2≤3600
4x1+5x2≤2000
3x1+10x2≤3000
x1,x2≥0
max f=0.15x1+0.1x2+0.08 x3+0.12 x4
s.t x1-x2- x3- x4≤0
x2+ x3- x4≥0
x1+x2+x3+ x4=1
xj≥0 j=1,2,3,4
min z=-0.15x1-0.1x2-0.08 x3-0.12 x4
s.t x1-x2- x3- x4≤0
-x2- x3+ x4≤0
x1+x2+x3+ x4=1
xj≥0 j=1,2,3,4
max f=20x1+16x2-λ[2x12+x22+(x1+x2)2]
s.t x1+x2≤5000
x 1≥0,x2≥0
min F(x)
s.t Gi (x) ≤0 i=1,…,m
Gj (x) =0 j=m+1,…,n
xl≤x≤xu
其中:F(x)为多元实值函数,G(x)为向量值函数
min 100(x2-x12 )2+(1-x1)2
s.t x1≤2;
x2≤2
minf=ex1(6x12+3x22+2x1x2+4x2+1)
s.t x1x2-x1-x2+1≤0
-2x1x2-5≤0
min +x12+2x22-2x1x2-4x1-12x2
s.t x1+x2≤2
-x1+2x2≤2
2x1+x2≤3
0≤x1, 0≤x2
max f1(x)=70x1+66x2
min f2(x)= 0.02x12+0.01x22+0.04(x1+x2)2
s.t x1+x2≤5000
0≤x1, 0≤x2
线性加权构造目标函数: max f=0.5f1(x) –0.5f2(x)
化最小值问题: min (-f)=- 0.5f1(x) +0.5f2(x)
min f1(x)=2x1+5x2
min f2(x)=4x1+x2
s.t x1≤5
x2≤6
x1+x2≥7
x1 ,x2≥0
min f1=6x1+8x2
max f2=100(x1+x2)
max f3=x2
s.t 6x1+8x2≤48
x2≥5
x1 ,x2≥0
min f1=6x1+8x2
min - f2=-100(x1+x2)
min - f3=-x2
s.t 6x1+8x2≤48
-x2≤-5
x1 ,x2≥0
GMT+8, 2025-4-11 21:31 , Processed in 0.066342 second(s), 25 queries , Gzip On.
Powered by Discuz! X3.4
Copyright © 2001-2021, Tencent Cloud.