- 在线时间
- 1084 小时
- 最后登录
- 2015-9-10
- 注册时间
- 2014-4-18
- 听众数
- 162
- 收听数
- 1
- 能力
- 10 分
- 体力
- 43980 点
- 威望
- 6 点
- 阅读权限
- 255
- 积分
- 15251
- 相册
- 0
- 日志
- 0
- 记录
- 1
- 帖子
- 3471
- 主题
- 2620
- 精华
- 1
- 分享
- 0
- 好友
- 513
升级   0% TA的每日心情 | 开心 2015-3-12 15:35 |
|---|
签到天数: 207 天 [LV.7]常住居民III
 群组: 第六届国赛赛前冲刺培 群组: 国赛讨论 群组: 2014美赛讨论 群组: 2014研究生数学建模竞 群组: 数学中国试看培训视频 |
!* 说明: 1.本程序为复合形法 *- n% N: J6 n# d- X j C! G
!* *- y- O1 B7 u0 f
!* 2.程序功能是求解约束最优化问题 *
* V$ }" J7 c8 D T: ?. E# J: O- Q6 n!* max F(x1,x2,…,xn) *
2 [& x4 m+ g, m- j!* s.t. Gi≤xi≤Hi *9 q9 n# j0 U2 g
!* 其中 x1,x2,…,xn为独立自变量, *
: l. n; y: ~8 c" o9 n- ^0 I!* xn+1~xm为隐式变量,是x1,x2,…,xn的函数,Gi,Hi为下界和上界,它们可以是常数(显式约束),*4 o) j$ ~ b$ w4 T! B
!* 也可以是自变量的函数(隐式约束) *
5 f) g- v7 h1 b, i0 u!* 主程序中提供自变量的初始值,输入已知参数及打印最后结果 *
+ y$ w, x0 j7 ?# }) D!* *
, \0 |# k3 ^: N# c7 @ p2 i" `7 L!* 3.输入变量说明 *0 `' J* S& a5 ?* I& u
!* N--显式自变量数 *
' q u( c {. J!* M--约束组数 * P5 M& q) c/ J2 ~+ }! R% J3 s' X1 O
!* K--构成复合形的顶点数,常用N+1,可多取 *( Q$ h1 P9 W# @, l5 Z6 e. t' `3 w1 k
!* ITMAX--允许最多迭代次数 *2 M$ \' M4 ^: R9 ^+ l+ L
!* IPRINT--打印控制参数,IPRINT=1,打印中间结果,IPRINT=0,不打印中间结果 *' w% Y* z& ^. x0 |& A- X
!* ALPHA--反射因子,常用1.3 *6 y" I X# \1 E" ]4 h4 o- N. F0 [
!* BETA--收敛参数,例如函数的幅值乘1E-4 *
s, f# a; f. d2 R. p. l5 Q3 i!* GAMMA--收敛参数,整数,常用值为5 *" d# Q' j0 s) T1 T
!* DELTA--显式约束违反校正,小正数,如X向量幅值乘1E-4 *
& L6 b# Y2 J* x' F1 i' W!* X(1,J)--自变量初始可行点,=1,N *
( ^3 r8 f$ Y0 [' Q# X2 k!* *
: a) n* Y4 l; _( X8 P, @!* 4.输出变量说明 *2 L0 \8 U; S; F; b
!* F--目标函数最大值勤 *, ^$ @ e) W: Q
!* X(I)--自变量最优值,I=1,N *
2 F2 F. [, u0 i* O* Y# h!* *
& V' D( i8 W% S" G!* 5.使用方法 *+ C: ~. @# Q7 B, I7 k) @6 t0 E: @+ J
!* 1)用户按照待解问题修改主程序PARAMETER的N,M,K值 *
/ W. q1 p K1 I, [; R5 e!* 2)在子程序FUNC中给定目标函数 *+ T \4 Q% r4 e9 e" {9 s0 Z
!* 3)在子程序CONST中给定Hi和Gi,显式约束必须放在隐式约束前面 *
% d7 y9 f5 C5 i! Q( {. _7 v* t& d U. P!* 4)编写一个数据文件COMPDAT,文件中的数据依次为下列变量的值,每个数之间用逗号分开 *
9 C( m5 |; n! c( s!* ITMAX,IPRINT,ALPHA,BETA,GAMMA,DELTA,X(1,1),X(1,2),…,X(1,N) *; F/ g& a9 d0 E8 Z, H3 H
!* 6.程序内容 *
}$ x" q' g: W6 f1 }!* 1)本程序由一个主程序和六个子程序组成,主程序首先给定N,M,K值,然后定义数组维数 *( l' v* _0 a' @
!* PARAMETER(N=,M=,K=) *# C) W y: j) u( {4 S
!* DIMENSION X(K,M),R(K,N),F(K),G(M),H(M),XC(N) *& Z( g# e, M9 k4 f$ n. w! U" o0 l
!* 主程序中提供自变量的初始值,输入已知参数及打印最后结果面 *
! r( `6 b0 U9 S& U) N" k+ j" j!* 2)各子程序的作用分别为了 *
; ~$ { `4 ~& G4 |4 Q/ p, Q!* CONSX—这是一个主要子程序,调用其它于程序及输出中间结果 *! @. k; e* {) [0 f9 V2 [2 o/ ^
!* CHECK—检查所有的点是否满足约束条件,对违背约束的点进行校正 *
0 [; u8 d( c- F4 B2 K!* CENTR—计算中心点 ** \5 y4 z# i# `/ j' d' \
!* FUNC —目标函数,由用户提供 *: y" r6 A' d4 Y6 L, N
!* CONST—规定显式和隐式约束 *
% @9 g1 ^8 [! d+ n/ g7 j!* RANDU—产生随机数 *6 S! h- S' U5 x- \1 [3 L& p9 I
!************************************************************************************************** y& T8 K' \- k s; F# U: U
* F9 h- P- \, C
3 D. g) N& P" K7 n; E4 S: V0 {0 }4 L, w) d
|
zan
|