²é¿´: 4395  |  »Ø¸´: 5

С²¼¶¡121

Òø³æ (СÓÐÃûÆø)

[½»Á÷] psoÓÅ»¯Éñ¾­ÍøÂ磨¾­µä°¸Àýƪ£©ÂÛÎıر¸ ÒÑÓÐ5È˲ÎÓë

ÎÒÓÃpsoÓÅ»¯bpÉñ¾­ÍøÂçÆäÖÐÐÞ¸Äʱ£¬³öÏÖÎÊÌâ²»ÖªµÀÔõôÐÞ¸ÄÊÊÓ¦¶ÈÖµº¯Êý£º
function error = fun(x,inputnum,hiddennum,outputnum,net,inputn,outputn)
%¸Ãº¯ÊýÓÃÀ´¼ÆËãÊÊÓ¦¶ÈÖµ
%x          input     ¸öÌå
%inputnum   input     ÊäÈë²ã½ÚµãÊý
%outputnum  input     Òþº¬²ã½ÚµãÊý
%net        input     ÍøÂç
%inputn     input     ÑµÁ·ÊäÈëÊý¾Ý
%outputn    input     ÑµÁ·Êä³öÊý¾Ý

%error      output    ¸öÌåÊÊÓ¦¶ÈÖµ

%ÌáÈ¡
w1=x(1:inputnum*hiddennum);
B1=x(inputnum*hiddennum+1:inputnum*hiddennum+hiddennum);
w2=x(inputnum*hiddennum+hiddennum+1:inputnum*hiddennum+hiddennum+hiddennum*outputnum);
B2=x(inputnum*hiddennum+hiddennum+hiddennum*outputnum+1:inputnum*hiddennum+hiddennum+hiddennum*outputnum+outputnum);


%ÍøÂç½ø»¯²ÎÊý
net.trainParam.epochs=20;
net.trainParam.lr=0.1;
net.trainParam.goal=0.00001;
net.trainParam.show=100;
net.trainParam.showWindow=0;

%ÍøÂçȨֵ¸³Öµ
net.iw{1,1}=reshape(w1,hiddennum,inputnum);
net.lw{2,1}=reshape(w2,outputnum,hiddennum);
net.b{1}=reshape(B1,hiddennum,1);
net.b{2}=reshape(B2,outputnum,1);
%ÍøÂçѵÁ·
net=train(net,inputn,outputn);

an=sim(net,inputn);

error=sum(abs(an-outputn));


Ö÷º¯Êý %½Úµã¸öÊý
inputnum=20;
hiddennum=60;
outputnum=5;
%¹¹½¨ÍøÂç
net=newff(inputn,outputn,hiddennum);
% ²ÎÊý³õʼ»¯
%Á£×ÓȺËã·¨ÖеÄÁ½¸ö²ÎÊý
c1 = 1.49445;
c2 = 1.49445;

maxgen=100;   % ½ø»¯´ÎÊý  
sizepop=30;   %ÖÖȺ¹æÄ£

Vmax=1;
Vmin=-1;
popmax=5;
popmin=-5;

for i=1:sizepop
    pop(i,=5*rands(1,1565);
    V(i,=rands(1,21);
    fitness(i)=fun(pop(i,,inputnum,hiddennum,outputnum,net,inputn,outputn);
end

% ¸öÌ弫ֵºÍȺÌ弫ֵ
[bestfitness bestindex]=min(fitness);
zbest=pop(bestindex,;   %È«¾Ö×î¼Ñ
gbest=pop;    %¸öÌå×î¼Ñ
fitnessgbest=fitness;   %¸öÌå×î¼ÑÊÊÓ¦¶ÈÖµ
fitnesszbest=bestfitness;   %È«¾Ö×î¼ÑÊÊÓ¦¶ÈÖµ

%% µü´úѰÓÅ
for i=1:maxgen
    i;

    for j=1:sizepop

        %ËٶȸüÐÂ
        V(j, = V(j, + c1*rand*(gbest(j, - pop(j,) + c2*rand*(zbest - pop(j,);
        V(j,find(V(j,>Vmax))=Vmax;
        V(j,find(V(j,<Vmin))=Vmin;

        %ÖÖȺ¸üÐÂ
        pop(j,=pop(j,+0.2*V(j,;
        pop(j,find(pop(j,>popmax))=popmax;
        pop(j,find(pop(j,<popmin))=popmin;

        %×ÔÊÊÓ¦±äÒì
        pos=unidrnd(21);
        if rand>0.95
            pop(j,pos)=5*rands(1,1);
        end

        %ÊÊÓ¦¶ÈÖµ
        fitness(j)=fun(pop(j,,inputnum,hiddennum,outputnum,net,inputn,outputn);
    end

    for j=1:sizepop
    %¸öÌå×îÓŸüÐÂ
    if fitness(j) < fitnessgbest(j)
        gbest(j, = pop(j,;
        fitnessgbest(j) = fitness(j);
    end

    %ȺÌå×îÓŸüÐÂ
    if fitness(j) < fitnesszbest
        zbest = pop(j,;
        fitnesszbest = fitness(j);
    end

    end

    yy(i)=fitnesszbest;   

end

%% ½á¹û·ÖÎö
plot(yy)
title(['ÊÊÓ¦¶ÈÇúÏß  ' 'ÖÕÖ¹´úÊý£½' num2str(maxgen)]);
xlabel('½ø»¯´úÊý');ylabel('ÊÊÓ¦¶È');

x=zbest;
%% °Ñ×îÓųõʼ·§ÖµÈ¨Öµ¸³ÓèÍøÂçÔ¤²â
% %ÓÃÒÅ´«Ëã·¨ÓÅ»¯µÄBPÍøÂç½øÐÐÖµÔ¤²â
w1=x(1:inputnum*hiddennum);
B1=x(inputnum*hiddennum+1:inputnum*hiddennum+hiddennum);
w2=x(inputnum*hiddennum+hiddennum+1:inputnum*hiddennum+hiddennum+hiddennum*outputnum);
B2=x(inputnum*hiddennum+hiddennum+hiddennum*outputnum+1:inputnum*hiddennum+hiddennum+hiddennum*outputnum+outputnum);

net.iw{1,1}=reshape(w1,hiddennum,inputnum);
net.lw{2,1}=reshape(w2,outputnum,hiddennum);
net.b{1}=reshape(B1,hiddennum,1);
net.b{2}=B2;


net.trainParam.epochs=100;
net.trainParam.lr=0.1;
net.trainParam.goal=0.00001;
²»ÖªµÀÊÊÓ¦¶ÈÖµº¯ÊýÔõôÐÞ¸ÄÀÏÊdzöÏÖÎÊÌâ
Error using fun (line 13)
Not enough input arguments.
»Ø¸´´ËÂ¥

» ²ÂÄãϲ»¶

ÒÑÔÄ   »Ø¸´´ËÂ¥   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû

124351

гæ (³õÈëÎÄ̳)

ÎÊÌâ½â¾öÁËÂð
2Â¥2016-03-11 20:35:29
ÒÑÔÄ   »Ø¸´´ËÂ¥   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû

1990d03z27x

гæ (СÓÐÃûÆø)

¡ï
Сľ³æ: ½ð±Ò+0.5, ¸ø¸öºì°ü£¬Ð»Ð»»ØÌû
ÏëÇë½Ìһϣ¬Õâ¸öPSOÓÅ»¯BP³ÌÐò£¬Ôõôºó±ß³öÏÖÒÅ´«Ëã·¨ÓÅ»¯£¬ÊÇÁªºÏÓÅ»¯Ã´£¿
·Ç³£¸Ðл
3Â¥2016-09-05 18:09:17
ÒÑÔÄ   »Ø¸´´ËÂ¥   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû

Õűó1993

гæ (³õÈëÎÄ̳)

¡ï
Сľ³æ: ½ð±Ò+0.5, ¸ø¸öºì°ü£¬Ð»Ð»»ØÌû
ÎÒÒ²ÊÇÓÃÕâ¸öËã·¨£¬¿ÉÒÔ¼ÓÒ»ÏÂ΢ÐÅ»òqqÂð

·¢×ÔСľ³æAndroid¿Í»§¶Ë
4Â¥2018-08-03 10:48:25
ÒÑÔÄ   »Ø¸´´ËÂ¥   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû

Sherry-Ìð

гæ (³õÈëÎÄ̳)

¡ï
Сľ³æ: ½ð±Ò+0.5, ¸ø¸öºì°ü£¬Ð»Ð»»ØÌû
ÎÒ×î½üÒ²ÔÚÕûÕâ¸öÄ£ÐÍ£¬²»ÖªµÀpsoÔõô´¦ÀíÓÅ»¯µÄbpÍøÂç

·¢×ÔСľ³æAndroid¿Í»§¶Ë
5Â¥2018-11-05 14:57:25
ÒÑÔÄ   »Ø¸´´ËÂ¥   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû

wangwei0916

гæ (³õÈëÎÄ̳)

¡ï
Сľ³æ: ½ð±Ò+0.5, ¸ø¸öºì°ü£¬Ð»Ð»»ØÌû
Æäʵ¾ÍÊÇÀûÓÃPSOÓÅ»¯BPÄ£Ð͵ÄȨֵ¼°ãÐÖµ£¬Ìá¸ßBPÄ£Ð;«¶È£¡³õʼֵÉ趨ºÜÓ°ÏìBPµÄ¾«¶È¡£¿ÉÒÔÈ¥¿´Ò»Ï¡¶MATLABÉñ¾­ÍøÂç43¸ö°¸Àý·ÖÎö¡·Õâ±¾Ê飡

·¢×ÔСľ³æIOS¿Í»§¶Ë
6Â¥2018-11-09 15:09:01
ÒÑÔÄ   »Ø¸´´ËÂ¥   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû
Ïà¹Ø°æ¿éÌø×ª ÎÒÒª¶©ÔÄÂ¥Ö÷ С²¼¶¡121 µÄÖ÷Ìâ¸üÐÂ
×î¾ßÈËÆøÈÈÌûÍÆ¼ö [²é¿´È«²¿] ×÷Õß »Ø/¿´ ×îºó·¢±í
[¿¼ÑÐ] 306Çóµ÷¼Á +5 À´ºÃÔËÀ´À´À´ 2026-03-22 5/250 2026-03-22 16:17 by BruceLiu320
[¿¼ÑÐ] Ò»Ö¾Ô¸±±¾©»¯¹¤´óѧ070300 ѧ˶336Çóµ÷¼Á +5 vvÃÔ 2026-03-21 8/400 2026-03-22 14:20 by ColorlessPI
[¿¼ÑÐ] 326Çóµ÷¼Á +5 ŵ±´¶û»¯Ñ§½±êéê 2026-03-15 8/400 2026-03-21 19:33 by ColorlessPI
[¿¼ÑÐ] Ò»Ö¾Ô¸ÄÏ´ó£¬0703»¯Ñ§£¬·ÖÊý336£¬Çóµ÷¼Á +3 ÊÕµ½VS 2026-03-21 3/150 2026-03-21 18:42 by ѧԱ8dgXkO
[¿¼ÑÐ] Çóµ÷¼Á +3 .m.. 2026-03-21 4/200 2026-03-21 16:25 by barlinike
[»ù½ðÉêÇë] ѧУÒѾ­Ìá½»µ½NSFC£¬»¹ÄÜÐÞ¸ÄÂ𣿠40+4 babangida 2026-03-19 9/450 2026-03-21 16:12 by babangida
[¿¼ÑÐ] 22 350 ±¾¿Æ985Çóµ÷¼Á£¬ÇóÀϵÇÊÕÁô +3 ÀîéóÄÐ003 2026-03-20 3/150 2026-03-21 13:28 by ²«»÷518
[¿¼ÑÐ] 306Çóµ÷¼Á +4 chuanzhu´¨Öò 2026-03-18 4/200 2026-03-21 08:25 by laoshidan
[¿¼ÑÐ] 316Çóµ÷¼Á +6 ÁºÜçö© 2026-03-19 6/300 2026-03-21 06:32 by Ecowxq666£¡
[¿¼ÑÐ] 346Çóµ÷¼Á[0856] +4 WayneLim327 2026-03-16 7/350 2026-03-21 04:02 by JourneyLucky
[¿¼ÑÐ] ²ÄÁÏ 336 Çóµ÷¼Á +3 An@. 2026-03-18 4/200 2026-03-21 01:39 by JourneyLucky
[¿¼ÑÐ] ¿¼Ñе÷¼ÁÇóÑ§Ð£ÍÆ¼ö +3 ²®ÀÖ29 2026-03-18 5/250 2026-03-20 22:59 by JourneyLucky
[¿¼ÑÐ] ±±¿Æ281ѧ˶²ÄÁÏÇóµ÷¼Á +5 tcxiaoxx 2026-03-20 5/250 2026-03-20 21:35 by laoshidan
[¿¼ÑÐ] 295¸´ÊÔµ÷¼Á +8 ¼òľChuFront 2026-03-19 8/400 2026-03-20 20:44 by zhukairuo
[¿¼ÑÐ] 086500 325 Çóµ÷¼Á +3 Áì´øÐ¡ÐÜ 2026-03-19 3/150 2026-03-20 18:38 by ¾¡Ë´Ò¢1
[¿¼ÑÐ] 288Çóµ÷¼Á£¬Ò»Ö¾Ô¸»ªÄÏÀí¹¤´óѧ071005 +5 ioodiiij 2026-03-17 5/250 2026-03-19 18:22 by zcl123
[˶²©¼ÒÔ°] ºþ±±¹¤Òµ´óѧ ÉúÃü¿ÆÑ§Ó뽡¿µÑ§Ôº-¿ÎÌâ×éÕÐÊÕ2026¼¶Ê³Æ·/ÉúÎï·½Ïò˶ʿ +3 1ϲ´º8 2026-03-17 5/250 2026-03-17 17:18 by ber´¨cool×Ó
[¿¼ÑÐ] ÓÐûÓеÀÌú/ÍÁľµÄÏëµ÷¼ÁÄÏÁÖ£¬¸ø×Ô¼ºÕÐʦµÜÖС« +3 TqlXswl 2026-03-16 7/350 2026-03-17 15:23 by TqlXswl
[¿¼ÑÐ] 11408 Ò»Ö¾Ô¸Î÷µç£¬277·ÖÇóµ÷¼Á +3 zhouzhen654 2026-03-16 3/150 2026-03-17 07:03 by laoshidan
[¿¼ÑÐ] 321Çóµ÷¼Á +5 ´óÃ×·¹£¡ 2026-03-15 5/250 2026-03-16 16:33 by houyaoxu
ÐÅÏ¢Ìáʾ
ÇëÌî´¦ÀíÒâ¼û