- 在线时间
- 1084 小时
- 最后登录
- 2015-9-10
- 注册时间
- 2014-4-18
- 听众数
- 162
- 收听数
- 1
- 能力
- 10 分
- 体力
- 43976 点
- 威望
- 6 点
- 阅读权限
- 255
- 积分
- 15250
- 相册
- 0
- 日志
- 0
- 记录
- 1
- 帖子
- 3471
- 主题
- 2620
- 精华
- 1
- 分享
- 0
- 好友
- 513
升级   0% TA的每日心情 | 开心 2015-3-12 15:35 |
---|
签到天数: 207 天 [LV.7]常住居民III
 群组: 第六届国赛赛前冲刺培 群组: 国赛讨论 群组: 2014美赛讨论 群组: 2014研究生数学建模竞 群组: 数学中国试看培训视频 |
!* 说明: 1.本程序为复合形法 *1 V: o( Q9 G& m9 K0 j- l; t L
!* *
1 ^) ^( _' H" T. M!* 2.程序功能是求解约束最优化问题 *4 W+ x& Y2 ]1 O: }' a
!* max F(x1,x2,…,xn) *
* }4 E$ B! Y' y" i!* s.t. Gi≤xi≤Hi *
. i$ [& j3 N+ y) q( g6 q6 z!* 其中 x1,x2,…,xn为独立自变量, *
! H7 s8 o% J" f Y5 w8 U: z( M: ~$ p8 q!* xn+1~xm为隐式变量,是x1,x2,…,xn的函数,Gi,Hi为下界和上界,它们可以是常数(显式约束),*
- `) s' ?+ P/ \1 G. [, r!* 也可以是自变量的函数(隐式约束) *0 u+ a5 L( ]: ^
!* 主程序中提供自变量的初始值,输入已知参数及打印最后结果 *
6 c0 W" }: b+ O) w0 b!* *7 w# ^, |" e3 s
!* 3.输入变量说明 ** x: h4 ?" B. J) M/ W; q+ }+ R
!* N--显式自变量数 *# O s/ R S7 z4 K% |. }" _
!* M--约束组数 *
9 G) t8 n0 F9 h+ G6 S" f: n% y* j& ~!* K--构成复合形的顶点数,常用N+1,可多取 * T, I& p% F6 m0 ~$ L X# D7 k6 ^
!* ITMAX--允许最多迭代次数 *
8 h/ ]' w8 ]: H9 ^!* IPRINT--打印控制参数,IPRINT=1,打印中间结果,IPRINT=0,不打印中间结果 *
4 u. y2 B( {/ }8 @!* ALPHA--反射因子,常用1.3 *# C% I1 n/ M; ?- @* ^8 S$ t/ i
!* BETA--收敛参数,例如函数的幅值乘1E-4 *
& V8 w0 z4 x' \ b V6 M) g!* GAMMA--收敛参数,整数,常用值为5 *5 e" \3 W! x3 P! N# l0 r6 J
!* DELTA--显式约束违反校正,小正数,如X向量幅值乘1E-4 *; h c! T, N+ o* @! v
!* X(1,J)--自变量初始可行点,=1,N ** G, X' G# {4 a/ u1 J g6 w
!* *: R& ^8 J3 K, h1 Z2 S* Y/ P
!* 4.输出变量说明 *8 ]& S, F' ~( W+ d2 e+ b
!* F--目标函数最大值勤 * M) K9 ?& m$ g3 \" h) x
!* X(I)--自变量最优值,I=1,N *
0 a; {! x/ l7 J& B" w' h; T!* *
" j) }( j% w' L3 B* f; ?1 P!* 5.使用方法 *# J% k0 j9 F3 K6 e, s
!* 1)用户按照待解问题修改主程序PARAMETER的N,M,K值 *
/ E& X8 ^, Y7 n1 C- a# N- E!* 2)在子程序FUNC中给定目标函数 *
k* Y1 N# h6 u$ T7 H' b; ^7 _!* 3)在子程序CONST中给定Hi和Gi,显式约束必须放在隐式约束前面 *
- ]5 V: R1 ~$ i7 J1 z: |6 [: b5 ?!* 4)编写一个数据文件COMPDAT,文件中的数据依次为下列变量的值,每个数之间用逗号分开 *
6 @+ y, {2 K# n* a6 O% [% O# L!* ITMAX,IPRINT,ALPHA,BETA,GAMMA,DELTA,X(1,1),X(1,2),…,X(1,N) *' T8 P. q) {& W( t) Z' V. D
!* 6.程序内容 *' F8 n: K# m' S. h
!* 1)本程序由一个主程序和六个子程序组成,主程序首先给定N,M,K值,然后定义数组维数 *
$ t- ~6 E) G8 O& T& J!* PARAMETER(N=,M=,K=) ** i/ N5 c+ @9 b( T/ r, v* ~
!* DIMENSION X(K,M),R(K,N),F(K),G(M),H(M),XC(N) *5 H8 q/ r1 }2 y% c
!* 主程序中提供自变量的初始值,输入已知参数及打印最后结果面 *
- }" c. ^3 n# i; D: U% Q) z7 u% t!* 2)各子程序的作用分别为了 * ( a) w2 K6 T4 M6 `2 ~
!* CONSX—这是一个主要子程序,调用其它于程序及输出中间结果 *2 R% l5 Z% G9 A9 g
!* CHECK—检查所有的点是否满足约束条件,对违背约束的点进行校正 *; s9 y% E# F$ z! o: y6 W
!* CENTR—计算中心点 *
: w$ F7 J0 }, l$ E( {!* FUNC —目标函数,由用户提供 *6 c# _! V7 [) w( p2 i4 F
!* CONST—规定显式和隐式约束 *% C P+ J0 _; u, ?* d) I
!* RANDU—产生随机数 *
7 d8 L s- w$ E8 H. Q' ^: Y!*************************************************************************************************
0 f; k6 G' y9 H; _4 q. T J
) o$ ]4 \7 j" P4 u! \) f
9 {* k1 e( j4 k- Q7 ^1 r* K
8 _3 }& E2 @9 m9 [ |
zan
|