- 在线时间
- 90 小时
- 最后登录
- 2018-12-27
- 注册时间
- 2016-4-22
- 听众数
- 17
- 收听数
- 0
- 能力
- 20 分
- 体力
- 23472 点
- 威望
- 2 点
- 阅读权限
- 200
- 积分
- 7535
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 126
- 主题
- 100
- 精华
- 2
- 分享
- 0
- 好友
- 6
升级   50.7% TA的每日心情 | 开心 2018-6-4 15:01 |
|---|
签到天数: 7 天 [LV.3]偶尔看看II
 群组: 2018年大象老师国赛优 群组: 高考备战 群组: 2018中小学数学建模冬 |
将要规划求解的问题运用各种原理写成要最大化或者最小化的数学公式后,运用MATLAB求解问题。针对非线性规划,MATLAB提供了如下命令:fimincon. 8 D! X- p+ I7 r
MATLAB中非线性规划的数学模型可写成如下形式: / ]& m( J" K% @" U/ C% T! l
' i, K6 \* Y. H5 K) s1 D0 J
f(x)为标量函数,A,B,Aeq,Beq是相应维数的矩阵和向量,C(x),Ceq(x)是非线性向量函数
" |$ ]: G, j5 s* ?7 W ?4 p/ x5 B; D# s
如,求解下列非线性规划: ! _* }" W: S: f$ d! Z
: c& @# r# R3 `' C
先编写funl.m定义目标函数:
/ b! I" Y f, L6 ?- i7 n* u9 b5 Bfunction f = fun1(x);f = sum(x.^2) + 8;
* G) f$ B% d0 v' p4 g文件fun2.m定义了非线性约束条件:5 W" s2 i% h5 j' S! y
function [g,h] = fun2(x);g = [(-x(1)^2 + x(2) - x(3)^2);(x(1) +x(2)^2 + x(3)^2 - 3)];h = [(-x(1) - x(2)^2 + 2);(x(2) + 2*x(3)^2 - 3)];
: t4 b8 }7 r5 X& M# | V+ c& ]. k4 K主程序文件example2.m如下:
; ]) q5 y& s( u, voptions = optimset('largescale','off');[x,y] = fmincon('fun1',rand(3,1),[],[],[],[],zeros(3,1),[],... 'fun2',options)
$ p' N- N: o- d9 P' V结果为:
3 i V& }# \& f% P! N; Gx = 0.5522 1.2033 0.9478y = 10.6511
) j+ ^1 B7 a- ], ?* m
' }/ s, ^1 |1 Y( ?% z- V2 k
: N: b6 _0 g# [: `8 ~: S3 G h. k# q6 X
' m9 N T7 j% D8 l2 h; t
" x! {! ^9 P7 s( b$ d+ J& w |
zan
|