QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3850|回复: 5
打印 上一主题 下一主题

Forcal全局优化库FcOpt更新

[复制链接]
字体大小: 正常 放大
forcal 实名认证       

45

主题

3

听众

282

积分

升级  91%

  • TA的每日心情
    难过
    2012-8-27 18:22
  • 签到天数: 1 天

    [LV.1]初来乍到

    跳转到指定楼层
    1#
    发表于 2011-2-8 12:33 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    本帖最后由 forcal 于 2011-2-8 12:37 编辑 ! `% M2 }2 [  G* r  X

    ( q3 w) W* R! m/ Y: iForcal优化库FcOpt最近进行了更新,全局优化能力显著增强,使用更加方便,同时增加了隐函数全部解,非线性方程(组)全部解求解函数,更新了微分方程参数优化(拟合)实例。
    / f5 q4 u1 K6 P, v# f5 X参考:http://www.forcal.net/sysm/forcal9/fchtm/fcopt.htm
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    musuchan 实名认证       

    1

    主题

    6

    听众

    40

    积分

    升级  36.84%

    该用户从未签到

    回复

    使用道具 举报

    杨帆 实名认证       

    4

    主题

    4

    听众

    626

    积分

    升级  6.5%

  • TA的每日心情
    奋斗
    2012-12-4 13:38
  • 签到天数: 314 天

    [LV.8]以坛为家I

    新人进步奖 最具活力勋章 发帖功臣

    群组数学趣味、游戏、IQ等

    群组数学建模

    群组我们一定会赢

    回复

    使用道具 举报

    forcal 实名认证       

    45

    主题

    3

    听众

    282

    积分

    升级  91%

  • TA的每日心情
    难过
    2012-8-27 18:22
  • 签到天数: 1 天

    [LV.1]初来乍到

    谢谢楼上两位朋友!8 S! J9 a$ c% ^# `2 g" g

    ( Z3 g: O) {# Y* D' r使用Forcal优化库FcOpt做优化时,无论简单的优化,还是复杂的优化(例如含积分的优化、共享参数优化、复数优化、微分方程参数优化等等),基本步骤都是一样的:
    0 I4 [) }5 {5 K7 h% k/ ~( A* H! @  B) D9 h
    1、给出拟合数据,一般保存在数组中。如果没有数据,这一步就省了。4 [* S+ B. E- z5 l
    2、编写目标函数,做优化时就是要得到目标函数值最小时的最优参数值。自己写目标函数,似乎是麻烦了些,但非常灵活,前面提到的各种各样的优化都可以通过自己写目标函数来实现。正所谓以不变应万变也。! O1 v6 b6 G$ N# n3 [
    3、选择优化函数进行优化。
    3 \  s" A! A' J6 n- P% D  g9 h3 ~  J1 ~. b
    在FcOpt中,我最喜欢用的优化函数是Opt,下面给出一个使用Opt做优化的例子:% V+ O- l' H+ O1 P% Z/ |
    # a& n# f$ \! w7 ^* O1 f) A
    例子:拟合公式:y = (p1)+(p2*exp(-p3*x/p5)+p4/(1+p4*p5*x))
    + P/ z# |$ e6 f* M$ t: O+ H' P
    1 B- ~8 c0 u' ?p1,p2,p3,p4,p5为待求参数  r( u+ p2 ?5 H, K0 t
    / m) G( N. k' l
    数据(x, y)
    ' @  T6 d( U, ]0 ~0,                0.928
    ( y5 ^! p7 x& p6 w, k0.0000098, 1.02
    ; N; h( t) O+ o, C7 U0.0000195, 1.12
    & M/ h, r, e2 l3 @1 g0.0000293, 1.25/ Q8 ]8 N- f% y
    0.0000391, 1.42
    # f$ r  ~0 E7 P' ]0.0000488, 1.73 d& ?; F* p1 P5 C; j3 b: L4 K  F8 v
    0.0000586, 2.015 M1 \  h6 i3 u7 K. e3 [) z
    0.0000684, 2.26
    9 y* y9 n2 Z0 z( B' H2 R& @$ Z0.0000781, 2.46, \+ s  m/ n! X. ^  f  y
    0.0000879, 2.63/ Q, ]  t$ l; G" G6 o
    0.0000977, 2.82$ x4 W* \; P  S/ Q7 i
    0.0001074, 3.01
    1 o/ x+ U3 G& G% R- h+ l% o0.0001172, 3.2
    # g6 E' B: s2 r1 _* ^+ \: U0.000127,  3.41
    / H2 S7 m% W$ l+ ^; T: Q1 d: u0.0001367, 3.59
    / E5 b+ W- \+ t9 x5 K( M0.0001465, 3.72
    6 |) ?) x" t8 X' y4 D6 L0.0001562, 3.85) D) ]* `: X2 ~0 Y( g; ^
    0.000166,  3.98
    * U1 q* R. }* s8 F$ e) g3 y) T0.0001758, 4.082 k  W  s7 I7 ~% a5 i
    # i8 N1 F# t8 W
    Forcal代码:
    ) {% z% t9 E1 n
    1. !using["fcopt","math"];9 e& G& X/ x2 U) }
    2. init(::Array,max)= //准备数据
    3. ) |\\" Z6 m  Y; h& k, F) S* X
    4. {2 Q5 Y$ B1 K$ n9 O1 U
    5.     max=19,
    6. 2 D# P; W' u/ M, M9 f: m+ O+ d# G
    7.     Array=arrayinit{2,max,2 :
    8. + ~8 H: U- |+ Q- P1 c- K! }  k
    9.         0,         0.928,
    10. $ w3 g' C; l6 C& H7 ^' a) V
    11.         0.0000098, 1.02,
    12. 0 t; T* U8 T6 D6 `. k; {6 S1 D. V- F# @
    13.         0.0000195, 1.12,( u6 ~7 s3 Y- I' l# y8 B8 F: r
    14.         0.0000293, 1.25,& w\\" Q\\" [1 F5 h& B2 R0 X
    15.         0.0000391, 1.42,
    16. \\" x; G\\" B1 _6 f$ l
    17.         0.0000488, 1.7,
    18. 1 F% @$ u1 Q/ t( n& E& i9 z+ ]) z
    19.         0.0000586, 2.01,
    20. : X* `0 h8 ]: y/ X* O
    21.         0.0000684, 2.26,
    22.   {3 ?2 O/ M5 Q. ?# S: P, l
    23.         0.0000781, 2.46,
    24. 4 F% C8 Q4 S2 T; o0 f  K7 G
    25.         0.0000879, 2.63,* f, R. Q\\" L% z\\" J% D7 n\\" y+ V
    26.         0.0000977, 2.82,
    27. ! C! @; N3 o9 O1 X$ J9 [7 `' ?
    28.         0.0001074, 3.01,
    29. % v& E7 J. X% t\\" `
    30.         0.0001172, 3.2,3 q% K- A* R; A& C1 Y0 }9 m
    31.         0.000127,  3.41,4 G3 S: z0 s/ m/ b+ m
    32.         0.0001367, 3.59,
    33. 0 I0 H' o5 q% Z  a3 m
    34.         0.0001465, 3.72,8 @9 O# e* A2 k; R
    35.         0.0001562, 3.85,
    36. & i/ U; ^0 l: i8 l\\" Y; h2 y$ u
    37.         0.000166,  3.98,: \9 ?9 k, H3 q: D' `3 ?' Z0 O
    38.         0.0001758, 4.08$ q  e! \8 Q4 X2 d) {! R' r* p5 ?
    39.     }.free()7 t+ n) }4 }4 W+ e! V) U
    40. };! e3 {! h2 j3 }) P7 |
    41. f(p1,p2,p3,p4,p5 : i,s,x,y : Array,max)= //目标函数( u# y\\" {, t' L8 d+ k+ j# {  J+ Z/ c
    42. {
    43. ( S5 v' ?2 B, d! V, Y3 y
    44.     s=0,i=0,(i<max).while{
    45. / `+ T7 p4 M! X5 y3 |
    46.         x=Array[i,0], y=Array[i,1],
    47. ( E' f& ?/ b! ]( c
    48.         s=s+[(p1)+(p2*exp(-p3*x/p5)+p4/(1+p4*p5*x))-y]^2,
    49. : |% C, N6 U2 E3 i* r1 }& t
    50.         i++
    51. \\" V- i, z$ [+ a  p2 r3 S
    52.     },
    53. 4 T3 T! i\\" R  G) b. g4 l4 ?
    54.     sqrt[s/max]# B' g% [* J; K1 ~0 L8 x; a
    55. };) u# I' x6 s- `0 a
    56. Opt[HFor("f"), optwaysimdeep, optwayconfra, optdeep,50]; //比较难的优化,我就这样使用Opt函数
    8 J3 i- M4 k: x7 V
    结果(需求解几次,前面的数是最优参数,最后一个数是目标函数值):
    ! i( I, @7 L/ k$ f2 s
    8 m: A6 p% }. x4 _8 ?8 b6.855486033798995 4.813449005068769 -54298054.6899329 -10.72898361613976 -1516.502649185066 3.337716353170544e-002
    8 Q3 u! X/ H/ U0 B5 E' U( U8 G# s% S5 }& c5 K. d- {2 d3 z
    感觉做这个优化题,是稍稍有些难度的,换句话说,如果题目难度不超过此题,Forcal可以轻松求解。* S5 d$ Y5 \/ \. g+ `1 g

    . g, X7 `# h; a+ a4 Q喜欢优化的朋友可以尝试一下。+ m! _* f4 |% L, \/ u% W

    % i, I; Y7 r* d* e( T5 d% u目前我知道1stOpt可以轻松求解此题,还有一位优化高手也可以轻松求解此题,还想知道更多可以求解此题的朋友或软件。2 b+ {, l+ c0 e. X& B5 `

    2 q/ `# E1 [: E
    回复

    使用道具 举报

    forcal 实名认证       

    45

    主题

    3

    听众

    282

    积分

    升级  91%

  • TA的每日心情
    难过
    2012-8-27 18:22
  • 签到天数: 1 天

    [LV.1]初来乍到

    本帖最后由 forcal 于 2011-2-25 19:50 编辑
    ( e1 h  e$ Z- z
    # t$ m9 j6 e) K+ O$ _美国国家标准与技术研究院(NIST: National Institute of Standards and Technology)提供有一套27道非线性拟合测试题,世界上几乎所有著名的数据分析软件包都以能通过该套测试题集为验证标准。Forcal全部能以任意随机初始值求得最优解。% n. H: h8 n$ m7 a; X# f

    " A9 E" l2 O0 j1 U

    , w* `: S. @, X. R. [- _参考:http://www.forcal.net/yyhz/optnist.htm! [3 X$ E) T  f& O5 F- v2 f
    回复

    使用道具 举报

    17

    主题

    3

    听众

    2216

    积分

  • TA的每日心情
    开心
    2012-1-30 23:29
  • 签到天数: 39 天

    [LV.5]常住居民I

    群组小草的客厅

    群组数学建模

    群组Matlab讨论组

    群组LINGO

    群组中南民族大学

    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2025-11-16 00:33 , Processed in 0.850952 second(s), 79 queries .

    回顶部