QQ登录

只需要一步,快速开始

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

[问题求助] 粒子群算法中适应度函数的调入

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

2

主题

3

听众

28

积分

升级  24.21%

  • TA的每日心情
    擦汗
    2011-12-25 09:55
  • 签到天数: 5 天

    [LV.2]偶尔看看I

    跳转到指定楼层
    1#
    发表于 2011-9-20 08:51 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    我最近参考别人的程序写了一个自己的程序但是代入不了fitness函数,请大家指点一下:
    ' Z. p; O, y( Z# V  z$ h4 Y我要做的是y(k)=a1*y(k-1)+b1*u(k-1)+a2*y(k-2)+a3*y(k-3)函数求a1,a2,a3,b1.已知y和u,我把适应度取为399组数据的【y(k)-a1*y(k-1)-b1*u(k-1)-a2*y(k-2)-a3*y(k-3)】^2最小,
    ! M9 j, B5 c' t, Mfunction [out]=fitness(x)# o0 E  T- Z1 L& f0 K
         ai=x(i,           %第几组数据就是取第几个! R2 ?6 {- H2 I" d  ?; K
        a1=ai(1): c9 ~: b, h# E8 [
        a2=ai(2)
    - G8 L; N* N, _. h; {2 w    a3=ai(3)
    0 j/ T0 K1 c2 q! N, U8 N  \. e    a4=ai(4)4 L2 B! O0 L7 _1 e
        u=load('F:\测试记录控制.txt');u1=u(2:399,2);" j; L% @3 j+ b. b& [' K
        y=load('F:\测试记录反馈.txt');y1=y(2:400,2);+ E4 m( x' Z6 _7 J$ l; _6 k
        c=0;
    8 w/ U- G  ^* k  x, s    for k=3:399
    ( D8 v! L4 z, v7 |        f=[y(k)-a1*y1(k-1)-a2*y1(k-2)-a3*y1(k-3)-b1*u1(k-1)]^2        %求出各级数据的平方和并逐渐相加得到一组对对应变量的适应度        ' `+ b* K6 E4 s7 `6 h* f
            c=c+f9 V$ \& R( Y  E2 p8 q0 g  U
            Msum(k)=c
    4 @7 o% P, j3 A4 V6 p" H) O    end
    * t+ I8 @. Z/ ]! n8 T$ j  jout=Msum(:,k);                %输出适应度
    5 {' ?* r4 J1 F: G# _# K5 |那么在粒子群算法中应如何调用这个函数呢?当位置和速度更新后,怎么计算这时的适应度呢?
      Q9 t, K2 R4 P6 V6 kfitness(i)=fitness(pop(i,)这样调用为什么会出错呢?请各位帮我这个新手解答一下,谢谢。
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    s20090281        

    2

    主题

    3

    听众

    28

    积分

    升级  24.21%

  • TA的每日心情
    擦汗
    2011-12-25 09:55
  • 签到天数: 5 天

    [LV.2]偶尔看看I

    回复

    使用道具 举报

    s20090281        

    2

    主题

    3

    听众

    28

    积分

    升级  24.21%

  • TA的每日心情
    擦汗
    2011-12-25 09:55
  • 签到天数: 5 天

    [LV.2]偶尔看看I

    问题有新的变化,就是只能进行第一个运算,当计算第二个输入时就会出现??? Subscript indices must either be real positive integers or logicals.$ T  c, K" ^/ A& F" k0 W4 K

    3 U/ O( G: x3 LError in ==> myPSO at 14# s# }# _; x% F$ X( P3 g
        fitness(i)=fitness(pop(i,)" u$ o2 J! B& f% R( a2 V2 u
    请问这怎么改呢?5 T' ?& `; L2 W7 _# E
    回复

    使用道具 举报

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

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

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

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

    蒙公网安备 15010502000194号

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

    GMT+8, 2026-5-26 00:18 , Processed in 0.446326 second(s), 64 queries .

    回顶部