亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? nnd12ms.m

?? Martin T.Hagan等著,戴葵等譯,神經網絡設計,機械工業出版社,一書的所有例程
?? M
字號:
function nnd12ms(cmd,arg1)
%NND12MS Maquardt step demonstration.
%
%	This demonstration requires the Neural Network Toolbox.

% First Version, 8-31-95.

%==================================================================

% CONSTANTS
me = 'nnd12ms';
max_t = 0.5;
w_max = 10;
p_max = 2;
circle_size = 6;

% FLAGS
change_func = 0;

% DEFAULTS
if nargin == 0, cmd = ''; else cmd = lower(cmd); end

% FIND WINDOW IF IT EXISTS
fig = nnfgflag(me);
if length(get(fig,'children')) == 0, fig = 0; end
  
% GET WINDOW DATA IF IT EXISTS
if fig
  H = get(fig,'userdata');
  fig_axis = H(1);            % window axis
  desc_text = H(2);           % handle to first line of text sequence
  cont_axis = H(3);           % error contour axis
  cont_ptr = H(4);            % pointer to error contour handles
  radios = H(5:7);          % radio buttons
  option_ptr = H(8);         % index of active radio
  path_ptr = H(9);           % pointer to training path handles
end

%==================================================================
% Activate the window.
%
% ME() or ME('')
%==================================================================

if strcmp(cmd,'')
  if fig
    figure(fig)
    set(fig,'visible','on')
  else
    feval(me,'init')
  end

%==================================================================
% Close the window.
%
% ME() or ME('')
%==================================================================

elseif strcmp(cmd,'close') & (fig)
  delete(fig)

%==================================================================
% Initialize the window.
%
% ME('init')
%==================================================================

elseif strcmp(cmd,'init') & (~fig)

  % CHECK FOR NNT
  if ~nntexist(me), return, end

  % CONSTANTS
  W1 = [10; 10];
  b1 = [-5;5];
  W2 = [1 1];
  b2 = [-1];
  P = -2:0.1:2;
  T = logsig(W2*logsig(W1*P,b1),b2);

  % NEW DEMO FIGURE
  fig = nndemof2(me,'DESIGN','Marquardt Step','','Chapter 12');
  set(fig, ...
    'windowbuttondownfcn',nncallbk(me,'down'), ...
    'BackingStore','off',...
    'nextplot','add');
  H = get(fig,'userdata');
  fig_axis = H(1);
  desc_text = H(2);

  % ICON
  nndicon(12,458,363,'shadow')

  % RADIO BUTTONS
  option = 1;
  radio1 = uicontrol(...
    'units','points',...
    'position',[20 335 130 20],...
    'style','radio',...
    'string','W1(1,1), W2(1,1)',...
    'back',nnltgray,...
    'callback',[me '(''radio'',1)'],...
    'value',1);
  radio2 = uicontrol(...
    'units','points',...
    'position',[155 335 115 20],...
    'style','radio',...
    'string','W1(1,1), b1(1)',...
    'back',nnltgray,...
    'callback',[me '(''radio'',2)']);
  radio3 = uicontrol(...
    'units','points',...
    'position',[270 335 105 20],...
    'style','radio',...
    'string','b1(1), b1(2)',...
    'back',nnltgray,...
    'callback',[me '(''radio'',3)']);

  % ERROR SURFACE
  load nndbp1

  cont_axis = nnsfo('a2','',v1,v2,'');
  set(cont_axis, ...
    'units','points',...
    'position',[50 40 280 280],...
    'color',nnltyell,...
    'xlim',range1,...
    'ylim',range2,...
    'colororder',[0 0 0])
  [dummy,cont_h] = contour(x2,y2,E2,levels);
  set(cont_h,'erasemode','none');
  plot3(range1([1 2 2 1 1]),range2([1 1 2 2 1]),1000*ones(1,5),...
    'color',nndkblue);
  cont_h2 = plot(optx,opty,'+','color',nnred);
  cont_h = [cont_h; cont_h2];
  view(2)

  % BUTTONS
  uicontrol(...
    'units','points',...
    'position',[400 110 60 20],...
    'string','Contents',...
    'callback','nndtoc')
  uicontrol(...
    'units','points',...
    'position',[400 75 60 20],...
    'string','Close',...
    'callback',[me '(''close'')'])

  % DATA POINTERS
  cont_ptr = uicontrol('visible','off','userdata',cont_h);
  option_ptr = uicontrol('visible','off','userdata',option);
  path_ptr = uicontrol('visible','off','userdata',[]);

  % SAVE WINDOW DATA AND LOCK
  H = [fig_axis desc_text cont_axis cont_ptr ...
       radio1 radio2 radio3 option_ptr path_ptr];
  set(fig,'userdata',H,'nextplot','new')

  % INSTRUCTION TEXT
  feval(me,'instr');

  % LOCK WINDOW
  set(fig,'nextplot','new','color',nnltgray);

  nnchkfs;

%==================================================================
% Display the instructions.
%
% ME('instr')
%==================================================================

elseif strcmp(cmd,'instr') & (fig)
  nnsettxt(desc_text,...
    'Click in the contour',...
    'graph to do a single',...
    'step of the Marquardt',...
    'learning algorithm.',...
    '',...
    'The black arrow',...
    'indicates the Gauss-',...
    'Newton step, the red',...
    'arrow indicates the',...
    'gradient direction.',...
    'The blue line',...
    'indicates the',...
    'Marquardt step as',...
    'mu is adjusted.')
    
%==================================================================
% Respond to radio buttons.
%
% ME('radio',i)
%==================================================================

elseif strcmp(cmd,'radio') & (fig) & (nargin == 2)

  % GET DATA
  option = get(option_ptr,'userdata');
  
  % ALTER TRAINABLE PARAMETERS
  if (arg1 ~= option)

    % HIGHLIGHT NEW RADIO BUTTON
    set(radios(option),'value',0)
    set(radios(arg1),'value',1)
    option = arg1;

    % CLEAR AXES
    delete(get(cont_axis,'children'))

    % CONSTANTS
    W1 = [10; 10];
    b1 = [-5;5];
    W2 = [1 1];
    b2 = [-1];
    P = -2:0.1:2;
    T = logsig(W2*logsig(W1*P,b1),b2);

    % ERROR SURFACE & VARIABLE NAMES
    if option == 1
      load nndbp1
    elseif option == 2
      load nndbp2
    else
      load nndbp3
    end

    set(fig,'nextplot','add')
    axes(cont_axis)
    set(get(cont_axis,'xlabel'),'string',v1)
    set(get(cont_axis,'ylabel'),'string',v2)
    set(cont_axis,'xlim',range1,'ylim',range2)
    [dummy,cont_h] = contour(x2,y2,E2,levels);
    set(cont_h,'erasemode','none');
    plot3(range1([1 2 2 1 1]),range2([1 1 2 2 1]),1000*ones(1,5),...
      'color',nndkblue);
    cont_h2 = plot(optx,opty,'+','color',nnred);
    cont_h = [cont_h; cont_h2];
    view(2)

    % STORE DATA
    set(cont_ptr,'userdata',cont_h);
    set(path_ptr,'userdata',[]);
    set(option_ptr,'userdata',option);
  end

%==================================================================
% Respond to mouse down.
%
% ME('down')
%==================================================================

elseif strcmp(cmd,'down') & (fig) & (nargin == 1)

  pt = get(cont_axis,'currentpoint');

  x = pt(1);
  y = pt(3);
  xlim = get(cont_axis,'xlim');
  ylim = get(cont_axis,'ylim');

  if (x > xlim(1) & x < xlim(2) & y > ylim(1) & y < ylim(2))

    % GET DATA
    option = get(option_ptr,'userdata');
    path = get(path_ptr,'userdata');
    cont_h = get(cont_ptr,'userdata');

    % CONSTANTS
    t=(.01:.01:1)'*2*pi;
    circ_x1=sin(t)*.1;
    circ_y1=cos(t)*.1;
    circ_x2=sin(t)*.2;
    circ_y2=cos(t)*.2;
    circ_x3=sin(t)*.3;
    circ_y3=cos(t)*.3;
    circ_x4=sin(t)*.4;
    circ_y4=cos(t)*.4;

    % REMOVE PREVIOUS PATH
    set(fig,'nextplot','add')
    set(path,'erasemode','normal');
    delete(path);

    % INITIAL VALUES
    W1 = [10; 10];
    b1 = [-5;5];
    W2 = [1 1];
    b2 = [-1];
    P = -2:0.1:2;
    T = logsig(W2*logsig(W1*P,b1),b2);

    % PLOT START POINT
    dkblue = nndkblue;
    red = nnred;
    axes(cont_axis);
    path = [...
      plot(x,y,'o','color',dkblue,'markersize',8,'erasemode','none');
      plot(x,y,'o','color',[1 1 1],'markersize',10,'erasemode','none');
      plot(x,y,'o','color',dkblue,'markersize',12,'erasemode','none')];

    % OPTIMAL SOLUTIONS
    if option == 1
      optx = 10;
      opty = 1;
    elseif option == 2
      optx = 10;
      opty = -5;
    else
      optx = -5;
      opty = 5;
    end
    xc=circ_x2+optx;
    yc=circ_y2+opty;
    % path = [path; fill(xc,yc,'w','erasemode','none','EdgeColor',nnred)];
    drawnow

    % PLOT PATH
    set(fig,'pointer','watch')

    % DEFINE SIZES
    [R,Q] = size(P); 
    [S2,Q] = size(T);
    S1 = 2;
    RS = S1*R; RS1 = RS+1; RSS = RS + S1; RSS1 = RSS + 1;
    RSS2 = RSS + S1*S2; RSS3 = RSS2 + 1; RSS4 = RSS2 + S2;

    % INITIALIZE TRAINING
    Lx = x;
    Ly = y;
    if option == 1
      W1(1,1) = x;
      W2(1,1) = y;
    elseif option == 2
      W1(1,1) = x;
      b1(1) = y;
    else
      b1(1) = x;
      b1(2) = y;
    end

    A1 = logsig(W1*P,b1);
    A2 = logsig(W2*A1,b2);
    E1 = T-A2;
    f1 = sumsqr(E1);
    
    % ASSIGN PARAMETERS
    max_epoch = 1;
    err_goal = 0.001;
    disp_freq = 1;
    mu_initial = 0.0012;
    v = 1.2;
    maxmu=1e10;
    mingrad=0;
    mu=mu_initial;
    ii=eye(2);
    meu=zeros(max_epoch,1);
    mer=meu;grad=meu;

    % MAIN LOOP
    for k=1:(max_epoch)
    
      % INITIALIZE A
      mu=mu/v;
      mer(k)=f1;
      meu(k)=mu;
      tst=1;

      % FIND JACOBIAN
      A1 = kron(A1,ones(1,S2));
      D2 = nnmdlog(A2);
      D1 = nnmdlog(A1,D2,W2);
      jac1 = nnlmarq(kron(P,ones(1,S2)),D1);
      jac2 = nnlmarq(A1,D2);
      jac=[jac1,D1',jac2,D2'];
    
      % PULL OUT APPROPRIATE TERMS
      if (option == 1)
        jac = [jac(:,1) jac(:,5)];
      elseif(option == 2)
        jac = [jac(:,1) jac(:,3)];
      else
        jac = [jac(:,3) jac(:,4)];
      end

      % CHECK THE MAGNITUDE OF THE GRADIENT
      E1=E1(:);
      je=jac'*E1;
      grad(k)=norm(je);
      if grad(k)<mingrad,
        mer=mer(1:k);
        meu=meu(1:k);
        grad=grad(1:k);
        disp('Gradient too small.')
        fprintf('Magnitude of gradient = %g.\n',grad(k));
        fprintf('Minimum gradient magnitude = %g.\n',mingrad);
        break
      end

      % DRAW LINE FOR GAUSS-NEWTON
      jj=jac'*jac;
      dw = -(jj+ii*mu)\je;

      gx = dw(1);
      gy = dw(2);
      dist = sqrt(gx^2+gy^2);
      path = [path; nndrwvec([Lx Lx+gx],[Ly Ly+gy],2,0.5,'k')];
      Lx1 = Lx+gx;
      Ly1 = Ly+gy;


      % DRAW LINE FOR GRADIENT
      dw = -je;

      gx = dw(1);
      gy = dw(2);
      gx1 = dist*gx/sqrt(gx^2+gy^2);
      gy1 = dist*gy/sqrt(gx^2+gy^2);
      path = [path; nndrwvec([Lx Lx+gx1],[Ly Ly+gy1],2,0.5,nnred)];


      % INNER LOOP, INCREASE mu UNTIL THE ERRORS ARE REDUCED
      jj=jac'*jac;
      while tst>0,
        dw=-(jj+ii*mu)\je;

        W1n=W1;b1n=b1;W2n=W2;
        b2n=b2;

        % UPDATE VARIABLES
        if (option == 1)
          newx = W1(1,1) + dw(1); W1n(1,1) = newx;
          newy = W2(1,1) + dw(2); W2n(1,1) = newy;
        elseif(option == 2)
          newx = W1(1,1) + dw(1); W1n(1,1) = newx;
          newy = b1(1)   + dw(2);   b1n(1) = newy;
        else
          newx = b1(1) + dw(1);   b1n(1) = newx;
          newy = b1(2) + dw(2);   b1n(2) = newy;
        end

        xc=circ_x2+newx;
        yc=circ_y2+newy;
        path = [path; plot([Lx1 newx],[Ly1 newy],'-b','linewidth',1,'erasemode','none')];
        Lx1 = newx;
        Ly1 = newy;

        A1 = logsig(W1n*P,b1n);
        A2 = logsig(W2n*A1,b2n);
        E2 = T-A2;
        f2=sumsqr(E2);	
        if (abs(f2-f1)>.001*f1),
          mu=mu*v;

          % TEST FOR MAXIMUM mu
          if (mu > maxmu),
            mer=mer(1:k);
            meu=[meu(1:k);mu];
            grad=grad(1:k);
            disp('Maximum mu exceeded.')
            fprintf('mu = %g.\n',mu);
            fprintf('Maximum allowable mu = %g.\n',maxmu);
            break;
          end
        else
          tst=0;
        end  					
      end

    %  TEST IF THE ERROR REACHES THE ERROR GOAL
      if f2<=err_goal,
        f1=f2;
        W1=W1n;b1=b1n;W2=W2n;b2=b2n;
        mer=[mer(1:k);f2];
        meu=[meu(1:k);mu];
        grad=grad(1:k);
        disp('Error goal reached.')
        break; 
      end

      if(mu>maxmu),
        break;
      end

      W1=W1n;b1=b1n;W2=W2n;b2=b2n;E1=E2;
      f1=f2;

      % EVALUATE & DISPLAY
      errors = [errors f1];
 
      % DISPLAY PROGRESS
      if rem(k,disp_freq) == 0
        xc=circ_x3+newx;
        yc=circ_y3+newy;
        Lx = newx;
        Ly = newy;
      end
    end
    
    % CONTOUR PLOT
    set(fig,'nextplot','new')
    
    % SAVE DATA
    set(path_ptr,'userdata',path);
    set(fig,'pointer','arrow')

  end
end

    

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲欧洲三级电影| 日本韩国欧美一区| 久久久99久久| 精品视频123区在线观看| 国产一区在线观看麻豆| 中文字幕在线不卡视频| 精品国产一二三| 欧美日高清视频| av一二三不卡影片| 九九热在线视频观看这里只有精品| 亚洲欧洲韩国日本视频| 久久久噜噜噜久久人人看 | 日韩激情一二三区| 国产精品无遮挡| 久久嫩草精品久久久久| 欧美一区二区三区在线观看视频| 波多野洁衣一区| 欧美一区二区三区白人| 99精品视频免费在线观看| 久久99国内精品| 国产乱码精品一区二区三区av| 青青草国产精品亚洲专区无| 日韩国产欧美视频| 国产综合久久久久影院| 国产精品一二二区| 成人免费视频免费观看| 成人网男人的天堂| av一区二区三区| 欧美色综合网站| 欧美美女网站色| 日韩欧美中文字幕制服| 日韩精品一区二区三区视频播放| 精品美女被调教视频大全网站| 精品国产免费一区二区三区香蕉| 2019国产精品| 国产日韩欧美精品综合| 最新国产の精品合集bt伙计| 又紧又大又爽精品一区二区| 青草av.久久免费一区| 国产东北露脸精品视频| 91视视频在线直接观看在线看网页在线看| 欧美日韩一级大片网址| 国产拍揄自揄精品视频麻豆| 亚洲成人精品一区| 成人午夜免费电影| 91精品国产综合久久国产大片| 久久品道一品道久久精品| 亚洲不卡在线观看| gogo大胆日本视频一区| 欧美一区二区国产| 性做久久久久久免费观看 | 欧洲一区二区三区免费视频| 日韩欧美综合一区| 亚洲一区二区三区四区在线| 国产成人精品一区二区三区四区| 在线成人高清不卡| 亚洲国产日日夜夜| 91高清视频在线| 最新久久zyz资源站| 国产99久久久国产精品潘金网站| 日韩三级视频在线观看| 日本美女一区二区三区视频| 欧美图区在线视频| 亚洲国产精品人人做人人爽| 欧美日韩一区中文字幕| 日日噜噜夜夜狠狠视频欧美人| 一本大道av一区二区在线播放 | 亚洲日本va在线观看| 成人av高清在线| 亚洲美女精品一区| 欧美日韩国产欧美日美国产精品| 樱桃视频在线观看一区| 欧美系列一区二区| 精品一区二区av| 成人免费在线观看入口| 在线观看亚洲精品| 久久99精品久久久| 国产欧美一区二区三区沐欲 | 欧美在线观看一二区| 日韩av二区在线播放| 精品国产乱子伦一区| jizzjizzjizz欧美| 麻豆极品一区二区三区| 久久精品视频免费| 欧美日韩国产综合一区二区三区| 欧美中文字幕不卡| 美女视频黄久久| 亚洲男人天堂av| 欧美电影免费观看高清完整版在线观看| 成人精品一区二区三区四区| 亚洲图片欧美一区| 久久天天做天天爱综合色| 欧美性一区二区| 丰满少妇久久久久久久| 日韩av一区二区在线影视| 国产精品国产自产拍高清av王其| 7777女厕盗摄久久久| 欧美性xxxxxxxx| 99这里只有精品| 国产在线一区观看| 美腿丝袜亚洲综合| 午夜视频一区二区三区| 亚洲三级视频在线观看| 国产三级精品视频| 久久久久久久综合色一本| 日韩一区二区三区电影| 91麻豆精品国产91久久久资源速度 | 懂色中文一区二区在线播放| 国产精品18久久久久| 国产经典欧美精品| 91麻豆自制传媒国产之光| 91视频在线观看| 色就色 综合激情| 欧美视频一区二| 欧美视频完全免费看| 91麻豆精品国产91久久久资源速度| 欧美性欧美巨大黑白大战| 91精品国产综合久久香蕉的特点| 欧美日韩免费一区二区三区| 91精品国产一区二区三区香蕉| 欧美一级片免费看| 欧美高清在线视频| 亚洲香肠在线观看| 久久精品国产77777蜜臀| 国产成人在线电影| 日韩一本二本av| 亚洲黄网站在线观看| 精品一区二区三区欧美| www.日韩大片| 日韩视频国产视频| 一区二区三区四区在线播放| 麻豆成人免费电影| 欧美日韩视频一区二区| 精品奇米国产一区二区三区| 亚洲你懂的在线视频| 国产高清一区日本| 日韩欧美一级二级三级| 午夜精品久久久久久久99水蜜桃 | 九九在线精品视频| 欧美一级片免费看| 日本少妇一区二区| 欧美三级资源在线| 亚洲第一福利一区| 欧美美女bb生活片| 亚洲欧美日韩电影| 91精品福利在线| 亚洲成人一二三| 欧美精品一二三| 亚洲成人动漫在线观看| 91久久一区二区| 日韩高清一区在线| 91精品国产乱码| 国内精品久久久久影院色 | 国产精品欧美久久久久一区二区| 国产一区二区三区不卡在线观看 | 激情综合网av| 亚洲欧洲成人av每日更新| 日本黄色一区二区| 日韩电影免费在线| 久久伊人中文字幕| 色婷婷综合久久久中文字幕| 午夜精品一区二区三区免费视频| 91精品国产一区二区| jizz一区二区| 日韩高清在线电影| 国产精品国产精品国产专区不蜜 | 欧美成人国产一区二区| av在线综合网| 麻豆成人久久精品二区三区红| 国产农村妇女精品| 欧美精品久久久久久久久老牛影院| 美女mm1313爽爽久久久蜜臀| 中文字幕不卡在线观看| 91麻豆精品国产91久久久使用方法 | 视频一区在线视频| 一区在线中文字幕| 欧美一级二级在线观看| 91同城在线观看| 国产 日韩 欧美大片| 九九**精品视频免费播放| 一级做a爱片久久| 亚洲欧洲美洲综合色网| 久久精品一区二区三区不卡牛牛| 91麻豆精品久久久久蜜臀 | 日韩欧美国产一二三区| 欧美老肥妇做.爰bbww视频| 色综合天天视频在线观看| bt7086福利一区国产| 99国产一区二区三精品乱码| 国产成人精品亚洲777人妖 | 日韩毛片一二三区| 综合网在线视频| 一区二区三区中文字幕精品精品| 国产精品丝袜91| 中文字幕亚洲一区二区av在线| 中文成人av在线| 亚洲精品国产一区二区精华液| 中文字幕综合网| 亚洲免费三区一区二区| 亚洲mv在线观看|