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

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

?? nnview.cpp

?? 一個VC編寫的神經網絡算法程序
?? CPP
字號:
// NNView.cpp : implementation of the CNNView class
//

#include "stdafx.h"
#include "NN.h"

#include "NNDoc.h"
#include "NNView.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// CNNView

IMPLEMENT_DYNCREATE(CNNView, CView)

BEGIN_MESSAGE_MAP(CNNView, CView)
	//{{AFX_MSG_MAP(CNNView)
	ON_COMMAND(ID_MODAL_BP, OnModalBp)
	ON_COMMAND(ID_MODAL_REVERSE, OnModalReverse)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CNNView construction/destruction

CNNView::CNNView()
{
	// TODO: add construction code here

}

CNNView::~CNNView()
{
}

BOOL CNNView::PreCreateWindow(CREATESTRUCT& cs)
{
	// TODO: Modify the Window class or styles here by modifying
	//  the CREATESTRUCT cs

	return CView::PreCreateWindow(cs);
}

/////////////////////////////////////////////////////////////////////////////
// CNNView drawing

void CNNView::OnDraw(CDC* pDC)
{
	CNNDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	// TODO: add draw code for native data here
	pDC->TextOut (10,10,"詳細說明見word文檔.............");
}

/////////////////////////////////////////////////////////////////////////////
// CNNView diagnostics

#ifdef _DEBUG
void CNNView::AssertValid() const
{
	CView::AssertValid();
}

void CNNView::Dump(CDumpContext& dc) const
{
	CView::Dump(dc);
}

CNNDoc* CNNView::GetDocument() // non-debug version is inline
{
	ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CNNDoc)));
	return (CNNDoc*)m_pDocument;
}
#endif //_DEBUG

/////////////////////////////////////////////////////////////////////////////
// CNNView message handlers
void CNNView::OnModalBp() ///////bp網絡辨識
{	
	RECT rect;
	GetClientRect(&rect);
	CClientDC dc(this);
	dc.Rectangle(0,0,rect.right ,rect.bottom);  /////清除客戶區
	////////定義變量//////////
	CPoint zero(20,300);               ////原點坐標 
    const int ni=5,nh1=20,nh2=10;     ////,no=1;///四層網絡,各層節點數
	double w12[ni+1][nh1+1],w23[nh1+1][nh2+1],w34[nh2+1];  ////權值
 	double e2[nh1+1],e3[nh2+1],e4;        ///誤差
	double xin[ni+1],h1[nh1+1],h2[nh2+1],yout;     ////網絡各層輸出
	const int s_number=800;             ////采樣點個數        
	double u[s_number+1];              ////輸入
	double y[s_number+1];             //////實際輸出
    int i,j,k,n	,m;                      ///循環變量
	double alpha ;                  ///學習因子
	///...........
	const int train_times=10000;      /////訓練次數
	const int train_number=100;      ////訓練點數
	double e_all;                    ////誤差平方和
	const double error_limit=0.0001;     /////誤差限 mspe
	double mspe=1;
	CString str;
    double amax=2.0,amin=0.1,A=10.0;    /////自適應  計算alpha 用
	int kx=200;          /////放大倍數---畫曲線用
	int yy;              /////輸出坐標---畫曲線用      
    /////////////.........
	dc.SelectStockObject (BLACK_PEN);
	dc.TextOut (10,2,"訓練中......." );
	dc.TextOut (10,60,"綠色的曲線是網絡輸出......");
	dc.TextOut (10,40,"紅色的曲線是對象輸出....");
/////////////////////////////////////////////
//////////畫對象輸出///////////////////
	////坐標線
	dc.MoveTo (zero);            /////x坐標
	dc.LineTo (rect.right-50,zero.y);
	dc.MoveTo (zero.x ,rect.bottom -50);
	dc.LineTo (zero.x ,rect.top +100);
	dc.MoveTo (zero.x ,rect.top +100);              /////here
	dc.LineTo (zero.x-5 ,rect.top +110);
	dc.MoveTo (zero.x ,rect.top +100);
	dc.LineTo (zero.x+5 ,rect.top +110);
	dc.MoveTo (rect.right-50  ,zero.y );   ///y坐標
	dc.LineTo (rect.right-60  ,zero.y-5 ); 
	dc.MoveTo (rect.right-50  ,zero.y );  
	dc.LineTo (rect.right-60  ,zero.y+5 );
    ////參考線y  +0.5 ---  -0.5	
	dc.MoveTo (zero);
	dc.MoveTo (zero.x ,zero.y -0.5*kx);
	dc.LineTo (zero.x+10 ,zero.y -0.5*kx);
	dc.TextOut (30,zero.y-0.5*kx-22,"0.5");
	dc.MoveTo (zero.x ,zero.y +0.5*kx);
	dc.LineTo (zero.x+10,zero.y +0.5*kx);
	dc.TextOut (30,zero.y +0.5*kx-22,"-0.5");
	////參考線x
	dc.MoveTo (zero);
	for(i=0;i<=s_number-140;i+=20)
	{
		dc.MoveTo (zero.x+i,zero.y);
        dc.LineTo (zero.x+i,zero.y-10);
	}
	for(i=0;i<=s_number-100;i+=100)
	{
		str.Format ("%d",i);
	        dc.TextOut (zero.x+i-10,zero.y+2,str);
	}

	/////初始化輸入  u[k]    
	for (i=1;i<=s_number;i++)
		 u[i]=sin(2*3.1415926535*i/250);
    /////計算實際輸出  y[k]  
	y[3]=y[1]=y[2]=0;
    for(k=4;k<=s_number;k++)
		y[k]=(y[k-1]*y[k-2]*u[k-1]*(y[k-3]-1)+u[k-2])/(1+y[k-1]*y[k-1]+y[k-2]*y[k-2]);
   	/////劃線
	CPen apen;                                ////////a new pen 
	apen.CreatePen(PS_SOLID,1,RGB(255,0,0));
	dc.SelectObject (apen);
	dc.MoveTo (zero);
	for (i=1;i<=s_number;i++)  //s_number=800;   //采樣點個數
	{
        yy=zero.y -y[i]*kx;    // kx=200;  //放大倍數---畫曲線用
		dc.LineTo (zero.x+i,yy);
		dc.MoveTo (zero.x+i,yy);
	};


//////////////////////////////////////
/// srand((unsigned)time(NULL));  
	/////初始化訓練信號
//	int mm[16]={1,1,1,1,0,0,0,1,0,0,1,1,0,1,0};
	 for (i=1;i<=s_number;i++)                       
		u[i]=sin(2*3.1415926535*i/250);
		      //((double)rand()/(double)RAND_MAX)*2.0-1.0;
	          //mm[i-i/16]*0.01;
	         //(rand()/RAND_MAX)*0.2-0.1;
	/////計算訓練輸入的對象輸出  
	y[3]=y[1]=y[2]=0;
    for(k=4;k<=s_number;k++)
	   y[k]=(y[k-1]*y[k-2]*u[k-1]*(y[k-3]-1)+u[k-2])/(1+y[k-1]*y[k-1]+y[k-2]*y[k-2]);
	
////////////////////////////////////////
///////////////////訓練網絡/////////////
    ///隨機數 ---  權值賦初值
 	for(i=1;i<=ni;i++)
 	   for(j=1;j<=nh1;j++)
	   {   //// random   between  -0.1--+0.1
		w12[i][j]=rand();
	    w12[i][j]=w12[i][j]/RAND_MAX;
	    w12[i][j]=(2*w12[i][j]-1)*0.1; 
	   };
   for(i=0;i<=nh1;i++)
	for(j=0;j<=nh2;j++)
	{   //// random   between  -0.1--+0.1
		w23[i][j]=rand();
		w23[i][j]=w23[i][j]/RAND_MAX;
		w23[i][j]=(2*w23[i][j]-1)*0.1;
	};
    for(i=0;i<=nh2;i++)
	{   //// random   between  -0.1--+0.1
		w34[i]=rand();
		w34[i]=w34[i]/RAND_MAX;
		w34[i]=(2*w34[i]-1)*0.1;    
	};
	 
///////////////////////////////////////////////
    //////開始訓練網絡/////////
        	// train_times=10000;      /////訓練次數
        	// train_number=100;       /////訓練點數
	for (n=1;n<=train_times;n++)
	{
 		e_all=0;
		for(k=3+20;k<=train_number+20;k++)  ////  只取了300個點
		{	///構成輸入向量
			xin[1]=y[k-1];
			xin[2]=y[k-2];
			xin[3]=y[k-3];
			xin[4]=u[k-1];
			xin[5]=u[k-2];  
			////////////////////
			h1[0]=0;h2[0]=0;
			for(i=1;i<=nh1;i++)        ////  隱層h1輸出求得
			{	h1[i]=0.0;
				for(j=1;j<=ni;j++)
					h1[i]=h1[i]+xin[j]*w12[j][i];
			}
			for(i=1;i<=nh2;i++)        ////  隱層h2輸出求得
			{	h2[i]=0.0;
				for(j=1;j<=nh1;j++)
					h2[i]=h2[i]+h1[j]*w23[j][i];
			}
			yout=0.0;           ////  輸出層yout求得
			for(j=1;j<=nh2;j++)       
				 yout=yout+h2[j]*w34[j];
			///////////////////
			e_all+=(yout-y[k])*(yout-y[k]);  // 總誤差!!!
			//////反向傳播修正權值
			alpha=amax+(amin-amax)*exp(-A*mspe);                  
			/////////輸出層權值  w34//////////////
			e4= (y[k]-yout)*yout*(1-yout); 
			for(j=1;j<=nh2;j++)
				w34[j]=w34[j]+alpha*e4*h2[j];
			////////////隱層權值     w23///////////////
			for(i=1;i<=nh2;i++)       /////計算誤差e3
				e3[i]=e4*w34[i]*h2[i]*(1-h2[i]);
			for(j=1;j<=nh1;j++)       ////w23
				for(i=1;i<=nh2;i++)
					w23[j][i]=w23[j][i]+alpha*e3[i]*h1[j];
			//////////隱層權值     w12/////////////		
			for(i=1;i<=nh1;i++)       ////計算誤差e2
			{	e2[i]=0;
				for(m=1;m<=nh2;m++)
					e2[i]=e2[i]+e3[m]*w23[i][m];
				e2[i]=e2[i]*h1[i]*(1-h1[i]);
			}                     
			for(j=1;j<=ni;j++)    //////w12
				for(i=1;i<=nh1;i++)
					w12[j][i]=w12[j][i]+alpha*e2[i]*xin[j];
		};  //////k個樣本訓練完畢  計算均方誤差

		mspe=e_all/(train_number*2);
		if (mspe<error_limit)
		{  dc.TextOut (10,2,"達到誤差要求......" );
		   str.Format (" %d %s %s  %d %s",train_number,"個樣本","訓練了",n,"次.....");
		   dc.TextOut (zero.y ,2,str );
		   break;	    /////exit for(n=1;n<=train_times;n++)
		}
	}
///////////////訓練結束////////////////
    	if(n>=train_times)
		{   str.Format ("%s %d","達到訓練次數...",train_times);
		    dc.TextOut (10,20 ,str);
		}
	    if (mspe>error_limit)
		  dc.TextOut (10,2,"誤差未達到要求......" );
		str.Format ("%s%f","MSPE=",mspe);
		   dc.TextOut (zero.y,22,str);
/////////////////////////////////////////////
//////////////////////輸出結果///////////////
	/////初始化輸入  
	for (i=1;i<=s_number;i++)
		 u[i]=sin(2*3.1415926535*i/250);
    /////計算實際輸出  
	y[3]=y[1]=y[2]=0;
    for(k=4;k<=s_number;k++)
		y[k]=(y[k-1]*y[k-2]*u[k-1]*(y[k-3]-1)+u[k-2])/(1+y[k-1]*y[k-1]+y[k-2]*y[k-2]);
    ///////////////
    CPen bpen;
    bpen.CreatePen(PS_SOLID,1,RGB(0,255,0));
	dc.SelectObject (bpen);    
	dc.MoveTo (zero);
    /////計算并畫出網絡輸出///////////
	for(k=4;k<=s_number;k++) 
	{	///構成輸入向量
		xin[1]=y[k-1];
		xin[2]=y[k-2];
		xin[3]=y[k-3];
		xin[4]=u[k-1];
		xin[5]=u[k-2];  
        ///////////////////
		for(i=1;i<=nh1;i++)        ////  隱層h1輸出求得
		{	h1[i]=0;
            for(j=1;j<=ni;j++)
	            h1[i]=h1[i]+xin[j]*w12[j][i];
		};
		for(i=1;i<=nh2;i++)        ////  隱層h2輸出求得
		{	h2[i]=0;
            for(j=1;j<=nh1;j++)
	            h2[i]=h2[i]+h1[j]*w23[j][i];
		};
		yout=0;           ////  輸出層yout求得
		for(j=1;j<=nh2;j++)       
		     yout=yout+h2[j]*w34[j];
		////draw
	    yy=zero.y -yout*kx;
		dc.LineTo (zero.x+k,yy);
		dc.MoveTo (zero.x+k,yy);
	};
};

void CNNView::OnModalReverse()     //////逆模型1 非線性對象 單層網絡
{
	RECT rect;
	GetClientRect(&rect);
	CClientDC dc(this);
	dc.Rectangle(0,0,rect.right ,rect.bottom);
	const int ni=6;                 ///輸入層節點數
	const int sample_points=170;    ///采樣點
	const int traintimes=10000;
	double u[sample_points+1];         
	double y[sample_points+1];       ////對象輸入和輸出
	double x[ni+1];                ///網絡輸入向量 
	double wi[ni+1];                ///輸入權值向量
    double yout[sample_points+1];  ////網絡輸出
	double e=0,lin=0;
	double alpha=0.8;             ///步長
	int i,j,k;
	int kx=4,ky=100;                  ////作圖的放大系數  
	CPoint zero(20,280);             ////原點
	double yy;
	CString str;
	dc.TextOut (10,10,"訓練中..............");
	dc.TextOut (10,rect.bottom-60 ,"藍色的曲線是輸入......");
	dc.TextOut (10,rect.bottom -40,"紅色的曲線是對象輸出....");
	dc.TextOut (10,rect.bottom -20,"綠色的曲線是訓練后的網絡輸出......");
//////////////////畫坐標軸////////
	//坐標軸x
	dc.MoveTo (zero);
	dc.LineTo (rect.right ,zero.y );
	dc.MoveTo(rect.right-5 ,zero.y );
	dc.LineTo(rect.right-15 ,zero.y-5);
	dc.MoveTo(rect.right-5 ,zero.y );
	dc.LineTo(rect.right-15 ,zero.y+5);
	//坐標軸y
    dc.MoveTo(zero.x ,rect.bottom-60);
	dc.LineTo(zero.x ,rect.top + 50);
	dc.MoveTo (zero.x,rect.top + 50);
	dc.LineTo (zero.x-5,rect.top + 60);
	dc.MoveTo (zero.x,rect.top + 50);
	dc.LineTo (zero.x+5,rect.top + 60);
	 ////參考線y  	
	dc.MoveTo (zero);
	for(i=-4;i<=2;i++)
	{
		dc.MoveTo (zero.x,zero.y+i*ky*0.5);
        dc.LineTo (zero.x+10,zero.y+i*ky*0.5);   ///小短線
        str.Format ("%1.1f",-i*0.5);
	    dc.TextOut (zero.x+10,zero.y+i*ky*0.5-20,str); ///標記
	}
	/*
	dc.MoveTo (zero.x ,zero.y -0.5*kx);
	dc.LineTo (zero.x+10 ,zero.y -0.5*kx);
	dc.TextOut (30,zero.y-0.5*kx-22,"0.5");
	dc.MoveTo (zero.x ,zero.y +0.5*kx);
	dc.LineTo (zero.x+10,zero.y +0.5*kx);
	dc.TextOut (30,zero.y +0.5*kx-22,"-0.5");*/
	////參考線x
	dc.MoveTo (zero);
	for(i=0;i<=sample_points*kx;i+=20)
	{
		dc.MoveTo (zero.x+i*kx,zero.y);
        dc.LineTo (zero.x+i*kx,zero.y-10);
	}
	for(i=0;i<=sample_points;i+=10)
	{
		str.Format ("%d",i);
	        dc.TextOut (zero.x+i*kx-10,zero.y+2,str);
	}

    ////////初始化網絡權值
	for(i=1;i<=ni;i++)  wi[i]=0.5;
    ////輸入
    for(i=1;i<=sample_points;i++)
	{
		if (i<=20)
			u[i]=1.0;
		else if(i<=40)
			u[i]=(double)i/20;///1.0+(i-20)/20;
		else if(i<=60)
			u[i]=4.0-(double)i/20;//2.0-(i-40)/20;
		else
			u[i]=1.0+sin(0.1*i-6.1);
	}
	/////輸入曲線
	dc.MoveTo (zero);
	CPen pen0;
	pen0.CreatePen (PS_SOLID,1,RGB(0,0,255));
	dc.SelectObject (pen0);
	for(k=1;k<=sample_points;k++)       
	{
	    yy=zero.y-u[k]*ky;
		dc.LineTo (k*kx+zero.x,yy);
		dc.MoveTo (k*kx+zero.x,yy);
	}
	////對象輸出
	 ///for(i=1;i<=sample_points;i++)  u[i]=1.0;
	y[1]=0;
	for(i=2;i<=sample_points;i++)
		y[i]=(y[i-1]*exp(-y[i-1])+u[i-1])/(1.0+u[i-1]*exp(-y[i-1]));
	/////畫對象輸出曲線
	dc.MoveTo (zero);
	CPen pen1;
	pen1.CreatePen (PS_SOLID,1,RGB(255,0,0));   ////red
	dc.SelectObject (pen1);
	for(k=1;k<=sample_points;k++)       
	{
	    yy=zero.y -y[k]*ky;
		dc.LineTo (k*kx+zero.x,yy);
		dc.MoveTo (k*kx+zero.x,yy);
	}
///////訓練網絡
	double e_all;
for(i=1;i<=traintimes;i++)
{
	e_all=0.0;
	for(k=7;k<=sample_points;k++)
	{
		x[1]=y[k-1];
		x[2]=y[k-2];
		x[3]=y[k-3];
		x[4]=y[k-4];
		x[5]=y[k-5];
        x[6]=y[k-6];            ////構成輸入向量
		yout[k]=0;
		for(j=1;j<=ni;j++)
			yout[k]+=wi[j]*x[j];
        e=y[k]-yout[k];
		e_all+=e*e;
	    lin=0.0;
		for(j=1;j<=ni;j++) lin+=x[j]*x[j];
		lin=alpha*e/lin;
		for (j=1;j<=ni;j++)       ////修正網絡權值
			wi[j]+=lin*x[j];
	}
}
dc.TextOut (10,10,"訓練結束........................");
//////////////訓練結束   畫網絡輸出
 /*  for(i=1;i<=sample_points;i++)
	{
		if (i<=20)
			u[i]=1.0;
		else if(i<=40)
			u[i]=(double)i/20;///1.0+(i-20)/20;
		else if(i<=60)
			u[i]=4.0-(double)i/20;//2.0-(i-40)/20;
		else
			u[i]=1.0+sin(0.1*i-6.1);
	}
	////對象輸出
	y[1]=0;
	for(i=2;i<=sample_points;i++)
		y[i]=(y[i-1]*exp(-y[i-1])+u[i-1])/(1.0+u[i-1]*exp(-y[i-1]));
*/
  for(k=7;k<=sample_points;k++)
	{
		x[1]=y[k-1];
		x[2]=y[k-2];
		x[3]=y[k-3];
		x[4]=y[k-4];
		x[5]=y[k-5];
        x[6]=y[k-6];            ////構成輸入向量
		yout[k]=0;
		for(i=1;i<=ni;i++)
			yout[k]+=wi[i]*x[i];
	}
	dc.MoveTo (zero);
	CPen pen2;
	pen2.CreatePen (PS_SOLID,1,RGB(0,255,0));
	dc.SelectObject (pen2);
	for(k=7;k<=sample_points;k++)       
	{
	    yy=zero.y-yout[k]*ky;
		dc.LineTo (k*kx+zero.x,yy);
		dc.MoveTo (k*kx+zero.x,yy);
	}



}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美亚洲高清一区二区三区不卡| 亚洲国产精品成人综合色在线婷婷| 欧美一区二区三区的| 久久久久九九视频| 亚洲一区中文在线| 成人综合婷婷国产精品久久蜜臀| 欧美日韩国产综合视频在线观看| 国产精品美女一区二区三区| 蜜桃av一区二区| 欧美主播一区二区三区美女| 国产欧美精品在线观看| 蜜桃视频在线一区| 欧美日本视频在线| 亚洲自拍偷拍欧美| 99国产精品久久久久久久久久久| 精品久久久久99| 日韩电影免费在线| 欧美性猛片xxxx免费看久爱| 国产精品不卡一区| 高清久久久久久| 国产日产亚洲精品系列| 激情图片小说一区| 日韩欧美激情在线| 美腿丝袜亚洲一区| 欧美一级日韩免费不卡| 同产精品九九九| 欧美色精品天天在线观看视频| 亚洲视频一区在线| 成人国产在线观看| 亚洲欧洲国产日韩| 99riav一区二区三区| 国产精品每日更新| 成人福利视频网站| 中文字幕色av一区二区三区| 99精品在线观看视频| ...av二区三区久久精品| 99精品热视频| 亚洲免费色视频| 色哟哟国产精品免费观看| 亚洲男女毛片无遮挡| 欧洲一区二区三区在线| 亚洲图片欧美色图| 欧美一区二区三区免费观看视频 | 韩国三级在线一区| 久久精品亚洲麻豆av一区二区| 韩国一区二区视频| 国产精品美女久久久久aⅴ国产馆| 成人激情黄色小说| 夜夜揉揉日日人人青青一国产精品| 色天天综合色天天久久| 亚欧色一区w666天堂| 欧美成人一区二区三区在线观看| 国内久久精品视频| 国产精品福利在线播放| 在线观看91精品国产入口| 午夜电影网亚洲视频| 精品国产免费一区二区三区四区| 国产成人精品www牛牛影视| 亚洲欧美激情插| 这里是久久伊人| 国内成人自拍视频| 一区二区三区久久| 欧美xfplay| 99久久精品国产观看| 五月综合激情婷婷六月色窝| 亚洲精品一区二区三区影院| 99精品久久只有精品| 奇米影视一区二区三区| 中文字幕日韩欧美一区二区三区| 欧美日韩精品一区二区天天拍小说| 久久99精品国产麻豆婷婷| 成人欧美一区二区三区视频网页| 欧美久久久一区| 丰满岳乱妇一区二区三区| 亚洲精品第1页| 久久蜜臀中文字幕| 欧美日韩一区二区三区高清 | 亚洲综合激情小说| 久久精品一区二区三区四区 | www..com久久爱| 男人的天堂久久精品| 综合久久综合久久| www国产成人免费观看视频 深夜成人网| 9l国产精品久久久久麻豆| 毛片av一区二区| 亚洲精品五月天| 国产日韩亚洲欧美综合| 欧美精品日韩一区| 色乱码一区二区三区88| 成人在线视频一区| 老鸭窝一区二区久久精品| 亚洲国产精品久久久久秋霞影院| 国产精品久久久久影视| 久久综合色天天久久综合图片| 欧美日韩国产系列| 色婷婷综合中文久久一本| 成人网在线免费视频| 精品中文av资源站在线观看| 偷窥少妇高潮呻吟av久久免费| 1000部国产精品成人观看| 国产欧美精品一区二区色综合| 日韩一级精品视频在线观看| 欧美日韩一区二区在线视频| 在线精品亚洲一区二区不卡| 99国产精品久久久久久久久久 | 麻豆精品国产传媒mv男同| 亚洲综合色区另类av| 亚洲视频一区二区免费在线观看| 国产嫩草影院久久久久| 国产视频亚洲色图| 久久毛片高清国产| 国产亚洲人成网站| 中文字幕乱码日本亚洲一区二区| 久久毛片高清国产| 欧美国产视频在线| 国产精品乱人伦| 国产精品免费丝袜| 亚洲精品中文字幕乱码三区| 亚洲色图欧洲色图婷婷| 亚洲精品日韩综合观看成人91| 亚洲视频在线一区| 亚洲图片欧美综合| 日韩vs国产vs欧美| 久久草av在线| 国产尤物一区二区| 成人黄色在线视频| 欧美在线你懂得| 欧美三电影在线| 日韩欧美国产一区在线观看| 久久女同互慰一区二区三区| 国产精品网曝门| 一区二区三区四区激情| 亚洲成人精品一区二区| 久久精品国产一区二区三区免费看| 久久99久久精品| 菠萝蜜视频在线观看一区| 一本大道久久a久久精二百| 欧美麻豆精品久久久久久| 久久网站最新地址| 亚洲美女视频一区| 麻豆成人av在线| 成人久久久精品乱码一区二区三区| 91福利资源站| 日韩精品一区二区三区视频| 国产精品免费免费| 日韩成人免费在线| 高清不卡在线观看| 欧美日韩免费观看一区三区| 精品欧美久久久| 亚洲蜜臀av乱码久久精品| 蜜桃av噜噜一区| 99久久久精品免费观看国产蜜| 欧美精品色综合| 国产精品不卡视频| 麻豆91精品91久久久的内涵| 99久久精品国产一区二区三区| 91精品国产色综合久久不卡电影| 国产欧美一二三区| 日本亚洲电影天堂| 91在线码无精品| 精品盗摄一区二区三区| 一区二区三区不卡视频| 国产精品一区二区果冻传媒| 欧美日韩一区二区电影| 亚洲国产成人一区二区三区| 日韩电影免费一区| 91久久精品一区二区三| 精品福利二区三区| 亚洲一区二区三区在线| 成人福利视频网站| 亚洲精品在线免费播放| 五月天网站亚洲| 色悠悠久久综合| 欧美国产日韩一二三区| 久草这里只有精品视频| 欧美日韩在线三级| 亚洲乱码中文字幕| 成人听书哪个软件好| 欧美mv日韩mv亚洲| 日韩影院免费视频| 欧美三级视频在线观看| 国产精品不卡一区| 成人午夜电影小说| 国产日韩欧美a| 国产一区二区三区四区五区入口| 3d动漫精品啪啪| 亚洲高清免费在线| 91福利社在线观看| 亚洲精品国产高清久久伦理二区| 成人激情av网| 中文字幕在线不卡一区| 国产一区二区三区最好精华液| 日韩三级在线观看| 美日韩一区二区| 精品国产一区二区三区四区四| 五月婷婷综合网| 91精品国产综合久久精品性色 | 国产黄色精品视频| 久久久久久一二三区| 国产大片一区二区|