QQ登录

只需要一步,快速开始

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

问下大神这是个用模拟退火坐的非线性拟合函数哪里错了呀

[复制链接]
字体大小: 正常 放大
曹某某        

3

主题

9

听众

142

积分

升级  21%

  • TA的每日心情
    无聊
    2017-5-12 07:54
  • 签到天数: 47 天

    [LV.5]常住居民I

    自我介绍
    大家好~~~

    新人进步奖

    群组2017算法基础课程

    群组学术交流B

    群组数学建模培训课堂2

    群组国赛讨论

    跳转到指定楼层
    1#
    发表于 2014-8-7 11:21 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    5体力
    function [err] = h(sol) %构造目标函数
    t = 1:14;
    L = [1016.1 84.89 553.4 339.7 268.5 414.7 416.3 317.5 242.2 141.2 80.4 115.9 70.3 22.9];
    [m,n] = size (L) ;
    err = zeros(1,n) ;
    A = sol(1) ; B = sol(2)
    err = 0;
    for i = 1: n
    err = err + (L(i) - 10.^(A +B*i)).^2
    err
    end
    close all   %主程序
    clear
    bound = [0 -1;4 0];
    [m,n] = size(bound) ;
    D = bound (1, 1: n) ;
    U = bound (2, 1: n) ;
    for i = 1: n
    x1 ( i) =D ( i) + rand*(U ( i) - D ( i) ) ;
    end
    x1
    N = 1;
    T = 1000;
    T0 = 01001;
    k = 250;
    a = 01965;
    step = 01001;
    T1 = clock;
    s = sprintf ('程序运行正在进行,请稍等……') ;
    disp ( s) ;
    while T > T0
    for t = 1: k
    f1 = h ( x1) ;
    for i = 1: n
    x2 ( i) = x1 ( i) + step*( rand - 0.5) ;
    while x2 ( i) <D ( i) || x2 ( i) >U ( i)
    x2 ( i) = x1 ( i) + step*( rand - 015) ;
    end
    end
    f2 = h ( x2) ;
    if f2 - f1 < 0
    x1 = x2;
    elseif exp ( ( f1 - f2) /T) > rand
    x1 = x2;
    end
    temp_x( t, 1: n) = x1;
    temp_y( t, 1) = h ( x1) ;
    end
    [ ty, ti ] =min ( temp_y) ;
    x1 = temp_x( ti, 1: n) ;
    X (N, 1: n) = x1;
    Y(N) = h ( x1) ;
    N =N + 1;
    T = a
    3
    T;
    end
    T2 = clock;
    CostTime = T2 - T1;
    if CostTime (6) < 0
    CostTime (6) =CostTime (6) + 60;
    CostTime (5) =CostTime (5) - 1;
    end
    if CostTime (5) < 0
    CostTime (5) = CostTime ( 5) + 60; CostTime ( 4) = Cost2
    Time (4) - 1;
    end
    问下大神这是个用模拟退火坐的非线性拟合函数哪里错了呀

    最佳答案

    madio 查看完整内容

    试了一下,程序可以运行呀,你把它保存为一个h.m的文件,然后再matlab的命令行中就可以调用函数,不过误差是比较大的,你是不是说这个问题?下面是运行的过程 >> h([10,5]) B = 5 err = 1.0000e+030 err = 1.0000e+030 err = 1.0000e+040 err = 1.0000e+040 err = 1.0000e+050 err = 1.0000e+050 err = 1.0000e+060 err = 1.0000e+0 ...
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    madio        

    3万

    主题

    1310

    听众

    5万

    积分

  • TA的每日心情
    奋斗
    2024-7-1 22:21
  • 签到天数: 2014 天

    [LV.Master]伴坛终老

    自我介绍
    数学中国站长

    社区QQ达人 邮箱绑定达人 优秀斑竹奖 发帖功臣 风雨历程奖 新人进步奖 最具活力勋章

    群组数学建模培训课堂1

    群组数学中国美赛辅助报名

    群组Matlab讨论组

    群组2013认证赛A题讨论群组

    群组2013认证赛C题讨论群组

    试了一下,程序可以运行呀,你把它保存为一个h.m的文件,然后再matlab的命令行中就可以调用函数,不过误差是比较大的,你是不是说这个问题?下面是运行的过程
    >> h([10,5])

    B =

         5


    err =

      1.0000e+030


    err =

      1.0000e+030


    err =

      1.0000e+040


    err =

      1.0000e+040


    err =

      1.0000e+050


    err =

      1.0000e+050


    err =

      1.0000e+060


    err =

      1.0000e+060


    err =

      1.0000e+070


    err =

      1.0000e+070


    err =

      1.0000e+080


    err =

      1.0000e+080


    err =

      1.0000e+090


    err =

      1.0000e+090


    err =

      1.0000e+100


    err =

      1.0000e+100


    err =

      1.0000e+110


    err =

      1.0000e+110


    err =

      1.0000e+120


    err =

      1.0000e+120


    err =

      1.0000e+130


    err =

      1.0000e+130


    err =

      1.0000e+140


    err =

      1.0000e+140


    err =

      1.0000e+150


    err =

      1.0000e+150


    err =

      1.0000e+160


    err =

      1.0000e+160


    x1 =

        3.2589   -0.0942

    程序运行正在进行,请稍等……
    数学建模社会化
    回复

    使用道具 举报

    曹某某        

    3

    主题

    9

    听众

    142

    积分

    升级  21%

  • TA的每日心情
    无聊
    2017-5-12 07:54
  • 签到天数: 47 天

    [LV.5]常住居民I

    自我介绍
    大家好~~~

    新人进步奖

    群组2017算法基础课程

    群组学术交流B

    群组数学建模培训课堂2

    群组国赛讨论

    madio 发表于 2014-8-7 16:03
    试了一下,程序可以运行呀,你把它保存为一个h.m的文件,然后再matlab的命令行中就可以调用函数,不过误差是 ...

    大神我们那个运行初始应该是1000,但是我们没敢用1000用的300,运行后就说已达到最大递归限制 300。使用 set(0,'RecursionLimit',N) 可更改此限制。请注意,超出可用堆栈空间可能会使 MATLAB 和/或计算机崩溃。
    而且这是在matlab的2014做的如果用到matlab7.0中就显示第六行出错~~我们也不知道为啥
      收起(2)
    回复

    使用道具 举报

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

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

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

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

    蒙公网安备 15010502000194号

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

    GMT+8, 2025-5-22 20:32 , Processed in 0.563349 second(s), 63 queries .

    回顶部