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

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

?? nnd12cg.m

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

% First Version, 8-31-95.

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


% CONSTANTS
me = 'nnd12cg';
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','Conjugate Gradient Backprop','','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,...
    'Use the radio buttons',...
    'to select the network',...
    'parameters to train',...
    'with backpropagation.',...
    '',...
    'The corresponding',...
    'contour plot is',...
    'shown to the left.',...
    '',...
    'Click in the contour',...
    'graph to start the',...
    'conjugate gradient',...
    'learning algorithm.')
    
%==================================================================
% 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');

    % 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')];
    drawnow

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

    % 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);
    E = T-A2;
    fa=sumsqr(E);

    D2 = feval('deltalog',A2,E);
    D1 = feval('deltalog',A1,D2,W2);
    [gW1,gb1] = feval('learnbp',P,D1,1);
    [gW2,gb2] = feval('learnbp',A1,D2,1);

    if (option == 1)
      nrmo = gW1(1,1)^2 + gW2(1,1)^2;
    elseif(option == 2)
      nrmo = gW1(1,1)^2 + gb1(1)^2;
    else
      nrmo = gb1(1)^2 + gb1(2)^2;
    end

    % NORM OF GRADIENT
    nrmrt=sqrt(nrmo);

    % INITIALIZE DIRECTION
    dW1old=gW1;db1old=gb1;dW2old=gW2;db2old=gb2;
    dW1=gW1/nrmrt;db1=gb1/nrmrt;dW2=gW2/nrmrt;db2=gb2/nrmrt;

    % ASSIGN PARAMETERS
    tau=0.618;
    tau1=1-tau;
    scaletol=20;
    delta=0.32;
    delta1=.03;
    tol=delta1/scaletol;
    scale=2.0;
    bmax=26;
    n=2;                 %number of steps before reset


    % MAIN LOOP
    max_epoch = 15;
    xx = [x zeros(1,max_epoch)];
    yy = [y zeros(1,max_epoch)];
    for i=2:(max_epoch+1)
    
      % INITIALIZE A
      a=0;
      aold=0;
      b=delta;
      faold=fa;

      % CALCULATE INITIAL SSE 
      W1t = W1; b1t = b1;
      W2t = W2; b2t = b2;
      if (option == 1)
        newx = W1(1,1) + b*dW1(1,1); W1t(1,1) = newx;
        newy = W2(1,1) + b*dW2(1,1); W2t(1,1) = newy;
      elseif(option == 2)
        newx = W1(1,1) + b*dW1(1,1); W1t(1,1) = newx;
        newy = b1(1)   + b*db1(1);   b1t(1) = newy;
      else
        newx = b1(1) + b*db1(1);   b1t(1) = newx;
        newy = b1(2) + b*db1(2);   b1t(2) = newy;
      end
    
      fb = sumsqr(T - logsig(W2t*logsig(W1t*P,b1t),b2t));
    
      % FIND INITIAL INTERVAL WHERE SSE MINIMUM OCCURS
      while (fa>fb)&(b<bmax)
        aold=a;
        faold=fa;
        fa=fb;
        a=b;
        b=scale*b;
        if (option == 1)
          newx = W1(1,1) + b*dW1(1,1); W1t(1,1) = newx;
          newy = W2(1,1) + b*dW2(1,1); W2t(1,1) = newy;
        elseif(option == 2)
          newx = W1(1,1) + b*dW1(1,1); W1t(1,1) = newx;
          newy = b1(1)   + b*db1(1);   b1t(1) = newy;
        else
          newx = b1(1) + b*db1(1);   b1t(1) = newx;
          newy = b1(2) + b*db1(2);   b1t(2) = newy;
        end
        fb = sumsqr(T - logsig(W2t*logsig(W1t*P,b1t),b2t));
      end
      a=aold;
      fa=faold;
    
      % SHOW INITIAL INTERVAL
      if (option == 1)
        newx = W1(1,1) + a*dW1(1,1);
        newy = W2(1,1) + a*dW2(1,1);
      elseif(option == 2)
        newx = W1(1,1) + a*dW1(1,1);
        newy = b1(1)   + a*db1(1);
      else
        newx = b1(1) + a*db1(1);
        newy = b1(2) + a*db1(2);
      end
    
      if (option == 1)
        newx = W1(1,1) + b*dW1(1,1);
        newy = W2(1,1) + b*dW2(1,1);
      elseif(option == 2)
        newx = W1(1,1) + b*dW1(1,1);
        newy = b1(1)   + b*db1(1);
      else
        newx = b1(1) + b*db1(1);
        newy = b1(2) + b*db1(2);
      end
    
      % INITIALIZE C AND D
      c=a+tau1*(b-a);
      if (option == 1)
        newx = W1(1,1) + c*dW1(1,1); W1t(1,1) = newx;
        newy = W2(1,1) + c*dW2(1,1); W2t(1,1) = newy;
      elseif(option == 2)
        newx = W1(1,1) + c*dW1(1,1); W1t(1,1) = newx;
        newy = b1(1)   + c*db1(1);   b1t(1) = newy;
      else
        newx = b1(1) + c*db1(1);   b1t(1) = newx;
        newy = b1(2) + c*db1(2);   b1t(2) = newy;
      end
      fc = sumsqr(T - logsig(W2t*logsig(W1t*P,b1t),b2t));
      d=b-tau1*(b-a);
      if (option == 1)
        newx = W1(1,1) + d*dW1(1,1); W1t(1,1) = newx;
        newy = W2(1,1) + d*dW2(1,1); W2t(1,1) = newy;
      elseif(option == 2)
        newx = W1(1,1) + d*dW1(1,1); W1t(1,1) = newx;
        newy = b1(1)   + d*db1(1);   b1t(1) = newy;
      else
        newx = b1(1) + d*db1(1);   b1t(1) = newx;
        newy = b1(2) + d*db1(2);   b1t(2) = newy;
      end
      fd = sumsqr(T - logsig(W2t*logsig(W1t*P,b1t),b2t));
    
      % MINIMIZE ALONG A LINE
      k=0;
      while (b-a)>tol 
        if ( (fc<fd)&(fb>=min([fa fc fd])) ) | fa<min([fb fc fd])
          b=d; d=c; fb=fd;
          c=a+tau1*(b-a);
          fd=fc;
          if (option == 1)
            newx = W1(1,1) + c*dW1(1,1); W1t(1,1) = newx;
            newy = W2(1,1) + c*dW2(1,1); W2t(1,1) = newy;
          elseif(option == 2)
            newx = W1(1,1) + c*dW1(1,1); W1t(1,1) = newx;
            newy = b1(1)   + c*db1(1);   b1t(1) = newy;
          else
            newx = b1(1) + c*db1(1);   b1t(1) = newx;
            newy = b1(2) + c*db1(2);   b1t(2) = newy;
          end
          fc = sumsqr(T - logsig(W2t*logsig(W1t*P,b1t),b2t));
    
        else
          a=c; c=d; fa=fc;
          d=b-tau1*(b-a);
          fc=fd;
          if (option == 1)
            newx = W1(1,1) + d*dW1(1,1); W1t(1,1) = newx;
            newy = W2(1,1) + d*dW2(1,1); W2t(1,1) = newy;
          elseif(option == 2)
            newx = W1(1,1) + d*dW1(1,1); W1t(1,1) = newx;
            newy = b1(1)   + d*db1(1);   b1t(1) = newy;
          else
            newx = b1(1) + d*db1(1);   b1t(1) = newx;
            newy = b1(2) + d*db1(2);   b1t(2) = newy;
          end
          fd = sumsqr(T - logsig(W2t*logsig(W1t*P,b1t),b2t));
        end
      end

      % UPDATE VARIABLES
      if (option == 1)
        newx = W1(1,1) + a*dW1(1,1); W1(1,1) = newx;
        newy = W2(1,1) + a*dW2(1,1); W2(1,1) = newy;
      elseif(option == 2)
        newx = W1(1,1) + a*dW1(1,1); W1(1,1) = newx;
        newy = b1(1)   + a*db1(1);   b1(1) = newy;
      else
        newx = b1(1) + a*db1(1);   b1(1) = newx;
        newy = b1(2) + a*db1(2);   b1(2) = newy;
      end
      xx(i) = newx;
      yy(i) = newy;
    
      % CALCULATE GRADIENT
      A1 = logsig(W1*P,b1);
      A2 = logsig(W2*A1,b2);
      E = T-A2;
      D2 = feval('deltalog',A2,E);
      D1 = feval('deltalog',A1,D2,W2);
      [gW1,gb1] = feval('learnbp',P,D1,1);
      [gW2,gb2] = feval('learnbp',A1,D2,1);
    
      % NORM SQUARE OF GRADIENT
      if (option == 1)
        nrmn = gW1(1,1)^2 + gW2(1,1)^2;
      elseif(option == 2)
        nrmn = gW1(1,1)^2 + gb1(1)^2;
      else
        nrmn = gb1(1)^2 + gb1(2)^2;
      end

      % CALCULATE DIRECTION
      if rem(i,n)==0
        Z=0;
      else
        Z=nrmn/nrmo;
      end

      % CALCULATE NEW DIRECTIONS
      dW1new = gW1 + dW1old*Z; db1new = gb1 + db1old*Z;
      dW2new = gW2 + dW2old*Z; db2new = gb2 + db2old*Z;

      % SAVE NEW DIRECTIONS
      dW1old = dW1new; db1old = db1new;
      dW2old = dW2new; db2old = db2new;
      nrmo=nrmn;

      %NORMALIZE DIRECTIONS
      if (option == 1)
        nrm = sqrt(dW1new(1,1)^2 + dW2new(1,1)^2);
      elseif(option == 2)
        nrm = sqrt(dW1new(1,1)^2 + db1new(1)^2);
      else
        nrm = sqrt(db1new(1)^2 + db1new(2)^2);
      end
      dW1=dW1new/nrm;db1=db1new/nrm;dW2=dW2new/nrm;db2=db2new/nrm;
    end

    % CONTOUR PLOT
    path = [path; plot(xx,yy,'color',nnred); plot(xx,yy,'o','color',nnred,'markersize',6)];
    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一区二区三区免费野_久草精品视频
在线播放中文字幕一区| 激情综合亚洲精品| 欧洲国内综合视频| 亚洲va欧美va国产va天堂影院| 色欧美日韩亚洲| 亚洲sss视频在线视频| 欧美一卡2卡3卡4卡| 精品一区二区三区在线视频| 久久丝袜美腿综合| av在线这里只有精品| 亚洲激情在线激情| 5566中文字幕一区二区电影| 久久99国产精品免费| 欧美激情一区二区三区在线| 91香蕉国产在线观看软件| 亚洲一级二级在线| 日韩久久免费av| proumb性欧美在线观看| 亚洲综合色自拍一区| 日韩免费视频线观看| 国产成人av一区二区三区在线| 成人免费一区二区三区视频| 欧美午夜宅男影院| 国产一区二区三区黄视频 | 亚洲日穴在线视频| 欧美一区二区三区系列电影| 成人性生交大片免费看中文网站| 一二三四区精品视频| 欧美变态tickling挠脚心| 91在线无精精品入口| 青草国产精品久久久久久| 国产精品色婷婷久久58| 欧美日韩免费在线视频| 国产寡妇亲子伦一区二区| 一区二区三区四区在线免费观看| 精品国产一区二区三区忘忧草| k8久久久一区二区三区| 日韩电影免费在线看| 中文字幕一区二区三区乱码在线 | 国产精品不卡一区二区三区| 欧美日韩精品一区二区三区| 成人91在线观看| 久久99国产精品麻豆| 一区二区三区在线观看网站| 国产亚洲成年网址在线观看| 91 com成人网| 在线视频一区二区三| 成人免费观看男女羞羞视频| 美腿丝袜亚洲一区| 亚洲r级在线视频| 亚洲免费观看视频| 亚洲国产高清在线| 久久久久综合网| 日韩精品一区二区三区视频| 色94色欧美sute亚洲线路一ni| 国产xxx精品视频大全| 精品亚洲aⅴ乱码一区二区三区| 亚洲网友自拍偷拍| 亚洲欧美激情小说另类| 欧美国产精品专区| 国产精品久久二区二区| 久久久久久9999| 精品国产乱码久久久久久蜜臀| 欧美日韩1234| 欧美日本精品一区二区三区| 在线观看免费亚洲| 色哟哟在线观看一区二区三区| 国产99久久久精品| 国产99久久久国产精品潘金网站| 韩国毛片一区二区三区| 欧美aaa在线| 美女www一区二区| 青椒成人免费视频| 麻豆国产91在线播放| 久久精品国产精品亚洲精品| 日本不卡不码高清免费观看| 日韩国产欧美视频| 青青青伊人色综合久久| 日韩二区三区四区| 美女在线观看视频一区二区| 蜜乳av一区二区三区| 韩国欧美一区二区| 国产成人午夜精品影院观看视频 | 免费在线观看精品| 麻豆成人91精品二区三区| 久久国产精品无码网站| 麻豆国产欧美一区二区三区| 国产呦萝稀缺另类资源| 国产成人午夜精品影院观看视频 | 午夜精品福利视频网站| 天天色综合天天| 青青草97国产精品免费观看无弹窗版| 日韩成人av影视| 国内精品不卡在线| 成人免费高清在线| 色94色欧美sute亚洲线路一ni| 欧美在线一区二区| 91精品婷婷国产综合久久竹菊| 欧美一区二区成人6969| 国产午夜精品美女毛片视频| 国产精品欧美久久久久无广告| 亚洲免费观看高清完整版在线观看熊 | av动漫一区二区| 日本高清不卡aⅴ免费网站| 欧美日韩一区高清| 久久青草欧美一区二区三区| 亚洲欧美综合色| 婷婷夜色潮精品综合在线| 国产在线播放一区三区四| 99re这里只有精品首页| 欧美日韩高清一区二区不卡 | 欧美美女一区二区在线观看| 日韩精品一区二区在线| 亚洲欧洲在线观看av| 亚洲va欧美va天堂v国产综合| 国产精品一区二区无线| 色综合久久99| 精品国产乱码久久| 一区二区久久久| 国产毛片精品视频| 欧美在线一区二区| 国产性色一区二区| 午夜精品久久久久影视| 国产成人精品影视| 91精品久久久久久久91蜜桃| 国产精品网站一区| 免费成人在线影院| 91久久精品一区二区三区| 中文字幕av一区 二区| 午夜欧美在线一二页| 波多野结衣亚洲一区| 日韩一区二区三| 亚洲一区二区成人在线观看| 丁香六月久久综合狠狠色| 日韩一区二区不卡| 亚洲h在线观看| 色香色香欲天天天影视综合网| 精品久久久久久久久久久院品网| 亚洲电影在线播放| 成人av电影在线| www国产成人| 激情久久久久久久久久久久久久久久| 色噜噜久久综合| 日韩视频在线一区二区| 玉米视频成人免费看| 大桥未久av一区二区三区中文| 欧美精品在线一区二区| 欧美激情在线观看视频免费| 成人夜色视频网站在线观看| 欧美一级xxx| 午夜精品福利久久久| 色综合久久久久久久| 国产精品入口麻豆原神| 激情小说欧美图片| 69av一区二区三区| 亚洲一区在线观看免费 | 中文字幕在线不卡一区| 国产老肥熟一区二区三区| 欧美va亚洲va| 日本不卡的三区四区五区| 91精品国产福利| 亚洲gay无套男同| 欧美日韩卡一卡二| 亚洲无线码一区二区三区| 欧美三级视频在线| 亚洲一区二区在线免费看| 91国产免费看| 亚洲综合成人在线视频| 欧美在线免费播放| 亚洲成av人在线观看| 欧美日韩精品综合在线| 亚洲成人av中文| 欧美一区日本一区韩国一区| 蜜桃91丨九色丨蝌蚪91桃色| 日韩欧美不卡在线观看视频| 国内成人精品2018免费看| 久久人人超碰精品| 粉嫩av一区二区三区粉嫩| 国产精品久久久久久久裸模| 91啪在线观看| 亚洲v精品v日韩v欧美v专区 | 久久久久久久久岛国免费| 国产成人av电影在线播放| 国产精品福利一区二区| 色婷婷综合五月| 午夜精品福利一区二区蜜股av| 91精品国产综合久久久蜜臀粉嫩| 视频一区二区不卡| 日韩精品专区在线| 国产成人99久久亚洲综合精品| 国产精品成人网| 一本色道久久综合精品竹菊| 亚洲成人av一区二区三区| 欧美一级午夜免费电影| 国产精品一区二区在线观看不卡 | 综合欧美一区二区三区| 欧美日韩一区不卡| 国内精品伊人久久久久av一坑| 国产精品久久久久久久久晋中 | 国产成人精品影院|