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

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

?? bpdlg.cpp

?? 該程序通過BP算法實現0-9的數字識別
?? CPP
字號:
// bpDlg.cpp : implementation file
//

#include "stdafx.h"
#include "bp.h"
#include "bpDlg.h"

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

/////////////////////////////////////////////////////////////////////////////
// CAboutDlg dialog used for App About

class CAboutDlg : public CDialog
{
public:
	CAboutDlg();

// Dialog Data
	//{{AFX_DATA(CAboutDlg)
	enum { IDD = IDD_ABOUTBOX };
	//}}AFX_DATA

	// ClassWizard generated virtual function overrides
	//{{AFX_VIRTUAL(CAboutDlg)
	protected:
	virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV support
	//}}AFX_VIRTUAL

// Implementation
protected:
	//{{AFX_MSG(CAboutDlg)
	//}}AFX_MSG
	DECLARE_MESSAGE_MAP()
};

CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
{
	//{{AFX_DATA_INIT(CAboutDlg)
	//}}AFX_DATA_INIT
}

void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CAboutDlg)
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
	//{{AFX_MSG_MAP(CAboutDlg)
		// No message handlers
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CBpDlg dialog

CBpDlg::CBpDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CBpDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CBpDlg)
		// NOTE: the ClassWizard will add member initialization here
	//}}AFX_DATA_INIT
	// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CBpDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CBpDlg)
		// NOTE: the ClassWizard will add DDX and DDV calls here
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CBpDlg, CDialog)
	//{{AFX_MSG_MAP(CBpDlg)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_TRAIN, OnTrain)
	ON_BN_CLICKED(IDC_RECOG, OnRecog)
	ON_BN_CLICKED(IDC_CLR, OnClr)
	ON_BN_CLICKED(IDC_SAMPLE, OnSample)
	ON_BN_CLICKED(IDC_CENTER, OnCenter)
	ON_WM_LBUTTONDOWN()
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CBpDlg message handlers

BOOL CBpDlg::OnInitDialog()
{
	CDialog::OnInitDialog();

	// Add "About..." menu item to system menu.

	// IDM_ABOUTBOX must be in the system command range.
	ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
	ASSERT(IDM_ABOUTBOX < 0xF000);

	CMenu* pSysMenu = GetSystemMenu(FALSE);
	if (pSysMenu != NULL)
	{
		CString strAboutMenu;
		strAboutMenu.LoadString(IDS_ABOUTBOX);
		if (!strAboutMenu.IsEmpty())
		{
			pSysMenu->AppendMenu(MF_SEPARATOR);
			pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
		}
	}

	// Set the icon for this dialog.  The framework does this automatically
	//  when the application's main window is not a dialog
	SetIcon(m_hIcon, TRUE);			// Set big icon
	SetIcon(m_hIcon, FALSE);		// Set small icon
	
	// TODO: Add extra initialization here
	m_brSquare.CreateSolidBrush (RGB(255,0,0));
    //背景色畫刷
	m_brBack.CreateSolidBrush (RGB(255,255,255));
	//網格線畫刷
	m_hPen.CreatePen (PS_SOLID,1,RGB(0,192,192));
   	
	m_bInitDraw=true;
	ach=true;
    //初始化輸入矩陣
	for(int i=0;i<LEN;i++)
	{
		for(int j=0;j<LEN;j++)
		{
			m_bArray[i][j]=false;
			m_InputArray[i][j]=0;       
		}
	}
	return TRUE;  // return TRUE  unless you set the focus to a control
}

void CBpDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
	if ((nID & 0xFFF0) == IDM_ABOUTBOX)
	{
		CAboutDlg dlgAbout;
		dlgAbout.DoModal();
	}
	else
	{
		CDialog::OnSysCommand(nID, lParam);
	}
}

// If you add a minimize button to your dialog, you will need the code below
//  to draw the icon.  For MFC applications using the document/view model,
//  this is automatically done for you by the framework.

void CBpDlg::OnPaint() 
{
	 CWnd *pwnd;
    CRect rc;
    //CBrush br(RGB(0,0,255));
    pwnd=GetDlgItem(IDC_INPUTDLG);
    pwnd->GetWindowRect(&rc);
   // CClientDC dc(this);
    ScreenToClient(&rc);
    sizeHeight=rc.Height ()/16;//求出方塊的長
	float x=rc.left;
	sizeWidth=rc.Width ()/16;//方塊的寬
	float y=rc.top;
	float newsize=0; 
		for(int i=0;i<LEN;i++)
		{
			for(int j=0;j<LEN;j++)
			{
				m_rectArray[i][j].left =x;
				m_rectArray[i][j].right =m_rectArray[i][j].left+sizeWidth;
			    m_rectArray[i][j].top =y;
			    m_rectArray[i][j].bottom =m_rectArray[i][j].top+sizeHeight;
			    //y=y+sizeHeight;
				x=x+sizeWidth;
			}
			//y=rc.top;
			//x=x+sizeWidth;
			x=rc.left;
			y=y+sizeHeight;
		}
    CClientDC dc(this);
	CBrush *pOldBr=dc.SelectObject (&m_brBack);
    //dc.Rectangle(&rc);

    dc.SelectObject (&m_hPen);	
	newsize=0;
	for(i=0;i<=LEN;i++,newsize+=sizeHeight)
	{
		dc.MoveTo (rc.left,newsize+rc.top);
		dc.LineTo (rc.left+rc.Width (),newsize+rc.top);       //畫背景橫向網格	 
	}

	newsize=0;
	for( i=0;i<=LEN;newsize+=sizeWidth,i++)
	{
		dc.MoveTo (newsize+rc.left,rc.top);
		dc.LineTo (newsize+rc.left,rc.Height ()+rc.top);       //畫背景縱向網格
	}

	dc.SelectObject(&m_brSquare);                              //這里是開始點小方格的部分
	for( i=0;i<LEN;i++)
	{
		for(int j=0;j<LEN;j++)
		{
			if(m_bArray[i][j]==true)
			{
				dc.Rectangle (m_rectArray[i][j]);        //填充小方塊                
            }
		}
	}
	dc.SelectObject (pOldBr);
    for( i=0;i<LEN;i++)
	{
		for(int j=0;j<LEN;j++)
		{
			if(m_bArray[i][j]==false)
			{
				dc.Rectangle (m_rectArray[i][j]);        //填充小方塊                
            }
		}
	} 
}

// The system calls this to obtain the cursor to display while the user drags
//  the minimized window.
HCURSOR CBpDlg::OnQueryDragIcon()
{
	return (HCURSOR) m_hIcon;
}

void CBpDlg::OnTrain() 
{
	// TODO: Add your control notification handler code here
	int dataNum,typeNum,i,j,k;
	float sum,dError[10][5][10],dError_output[10],dError_hide1[100],wOffset_intoh[256][100],wOffset_hide1[100][20];
	bp.InitWeight();
	InitSample();
   for (int time=0;time<TIME;time++)
	{
        for (dataNum=0;dataNum<10;dataNum++)
		{
           for (typeNum=0;typeNum<5;typeNum++)
		   {
                for (j=0;j<LEN*LEN;j++)
				{
					bp.output0[j]=temp[dataNum][typeNum][j];      //第0層各神經元的輸出
				}
                for (i=0;i<M1;i++)
				{
					sum=0;
					for (j=0;j<N;j++)
					{
						sum+=bp.intoh_w[j][i]*bp.output0[j];
					}
					bp.output1[i]=FX(sum);      //第1層各神經元的輸出
				}
				for (i=0;i<P;i++)
				{
					sum=0;
					for (j=0;j<M1;j++)
					{
						sum+=bp.hide1_w[j][i]*bp.output1[j];
					}
					bp.output[i]=FX(sum);         //輸出層的值
					dError[dataNum][typeNum][i]=fabs(bp.t[dataNum][i]-bp.output[i]);
					dError_output[i]=(bp.t[dataNum][i]-bp.output[i])*bp.output[i]*(1-bp.output[i]);
				}
                 //求取各層誤差值
			/*	for (j=0;j<M1;j++)
				{
					sum=0;
					for (k=0;k<P;k++)
					{
						sum+=bp.hide1_w[j][k]*dError_output[k];
					}
					dError_hide1[j]=bp.output1[j]*(1-bp.output1[j])*sum;
				}*/
                for (j=0;j<M1;j++)
				{
					sum=0;
					for (k=0;k<P;k++)
					{
						sum+=bp.hide1_w[j][k]*dError_output[k];
					}
					dError_hide1[j]=bp.output1[j]*(1-bp.output1[j])*sum;
				}
                //根據誤差值調整各層的權值
				for (i=0;i<N;i++)
				{
					for (j=0;j<M1;j++)
					{
						wOffset_intoh[i][j]=Q*dError_hide1[j]*bp.output0[i];
						bp.intoh_w[i][j]+=wOffset_intoh[i][j];		
					}
				}
               for(i=0;i<M1;i++)
			   {
				   for(j=0;j<P;j++)
				   {
                        wOffset_hide1[i][j]=Q*dError_output[j]*bp.output1[i];
					   	bp.hide1_w[i][j]+=wOffset_hide1[i][j];
				   }
			   }
		   }
		}              //所有樣本一次訓練結束
               int errortotal=0;
		       for(i=0;i<10;i++)
				   for(j=0;j<5;j++)
					   for(k=0;k<10;k++)
                         if(dError[i][j][k]<0.3) 
							 errortotal+=1;
			   if(errortotal==500)
			   {
                   bp.bSuccess=true;
                   char ss[20];
				   sprintf(ss,"樣本訓練結束!迭代次數:%d",time);
                   CPaintDC dc(this);
                   AfxMessageBox(ss);
				   FILE *output;
	               output=fopen("weight\\intoh_w.txt","w");
				     for(i=0;i<256;i++)
						 for(j=0;j<100;j++)
                          fprintf(output,"%f ",bp.intoh_w[i][j]);
                   fclose(output);
				   output=fopen("weight\\hide1_w.txt","w");
				     for(i=0;i<100;i++)
						 for(j=0;j<10;j++)
                          fprintf(output,"%f ",bp.hide1_w[i][j]);
                   fclose(output);
				   break;
			   }
			   else if(time==TIME-1)
			   {
                   CPaintDC dc(this); 
				   AfxMessageBox("樣本訓練失敗,請重新訓練!");
			   }
	}
}

void CBpDlg::OnRecog() 
{
	// TODO: Add your control notification handler code here
	int i,j,output0[256];
    float dError,sum,intoh_w[256][100],hide1_w[100][10],output1[100],output[10];
	FILE *out;
	out=fopen("weight\\intoh_w.txt","r");
    for(i=0;i<256;i++)
		for(j=0;j<100;j++)
              fscanf(out,"%f ",&intoh_w[i][j]);
         fclose(out);
	out=fopen("weight\\hide1_w.txt","r");
	for(i=0;i<100;i++)
		for(j=0;j<10;j++)
              fscanf(out,"%f ",&hide1_w[i][j]);
          fclose(out);
     for (i=0;i<16;i++)
	{
		for (j=0;j<16;j++)
		{
			output0[i*LEN+j]=m_InputArray[i][j];      //第0層各神經元的輸出			}
		}
	}
    for (i=0;i<M1;i++)
	{
		sum=0;
		for (j=0;j<N;j++)
		{
			sum+=intoh_w[j][i]*output0[j];
		}
		output1[i]=FX(sum);      //第1層各神經元的輸出
	}
    for (i=0;i<P;i++)
	{
		sum=0;
		for (j=0;j<M1;j++)
		{
			sum+=hide1_w[j][i]*output1[j];
		}
		output[i]=FX(sum);       //第2層各神經元的輸出
	}
     for (i=0;i<P;i++)
	{	
		dError=0;
		sum=0;
		for (j=0;j<P;j++)
		{
			if (fabs(output[j]-bp.t[i][j])<0.3)
			{
				sum+=1;
			}
			dError+=fabs(output[j]-bp.t[i][j]);
		}
		if (sum==10)
		{
			//SetDlgItemInt(IDC_EDIT1,i);
             
			//char s[10];
			//sprintf(s,"%f",dError);
			//SetDlgItemText(IDC_EDIT2,s);
            char cc[20];
			sprintf(cc,"識別結果 %d 誤差 %f",i,dError);
            CPaintDC dc(this); 
            AfxMessageBox(cc);
			break;
		}
		else if (i==9)
		{
			CPaintDC dc(this); 
			AfxMessageBox("抱歉,不能識別!");
			break;
		}
	}
}

void CBpDlg::OnClr() 
{
	// TODO: Add your control notification handler code here	
	int i,j;
	for(i=0;i<LEN;i++)
	{
		for(j=0;j<LEN;j++)
		{
			m_bArray[i][j]=false;
			m_InputArray[i][j]=0;
		}
	}
	this->Invalidate();
	this->UpdateWindow();
}

void CBpDlg::OnSample() 
{
	// TODO: Add your control notification handler code here
    FILE *output;
	output=fopen("samples\\sample9\\sample4.txt","w");
	for (int i=0;i<16;i++)
		{
			for (int j=0;j<16;j++)
			{
					fprintf(output,"%d ",m_InputArray[i][j]); 
			}
		}
        fclose(output); 
}

void CBpDlg::OnCenter() 
{
	// TODO: Add your control notification handler code here
		// TODO: Add your control notification handler code here
	int iLeft=LEN,iRight=0,iTop=LEN,iBottom=0;
	int i,j;

	//調整坐標使輸入居中 

	for(i=0;i<LEN;i++)
	{
		for(j=0;j<LEN;j++)
		{
			if(m_bArray[i][j])
			{
				if (iTop>j)iTop=j;             //識別方陣的最左
			   
				if(iBottom<j)iBottom=j;        //方陣的最右
			   
			    if(iLeft>i)iLeft=i;            //方陣的最上
			   
			    if(iRight<i)iRight=i;          //方陣的最下
			}
		}
	}

    int xMiddle=0,yMiddle=0;
	xMiddle=(iRight-iLeft)/2+1;          
	yMiddle=(iBottom-iTop)/2+1;           

	iLeft=iLeft+xMiddle;              //中間點的x
	iTop=iTop+yMiddle;                //中間點的y

	int dx=iLeft-LEN/2;                  //求出坐標差
	int dy=iTop-LEN/2;                  //求出坐標差

	//平移坐標
    for(i=0;i<LEN;i++)
       for(j=0;j<LEN;j++)
          m_InputArray[i][j]=0;
	for(i=0;i<LEN;i++) 
	{
		for(j=0;j<LEN;j++)
		{
		  if(m_bArray[i][j])
			  m_InputArray[i-dx][j-dy]=1; 
		}
	}

	for(i=0;i<LEN;i++)
	{
		for(j=0;j<LEN;j++)
		{
			m_bArray[i][j]=false;
		}
	}

	for(i=0;i<LEN;i++)
	{
		for(j=0;j<LEN;j++)
		{
			if(m_InputArray[i][j]==1)
				m_bArray[i][j]=true;
			else m_bArray[i][j]=false;
		}		   
	}
	this->Invalidate();
	this->UpdateWindow();
}

void CBpDlg::OnLButtonDown(UINT nFlags, CPoint point) 
{
	// TODO: Add your message handler code here and/or call default
		CWnd *pwnd;
    CRect rc;
    pwnd=GetDlgItem(IDC_INPUTDLG);
    pwnd->GetWindowRect(&rc);
     ScreenToClient(&rc);
 	for(int i=0;i<LEN;i++)
 	{
 		for(int j=0;j<LEN;j++)
		{
 			if(m_rectArray[i][j].PtInRect (point))
 			{
                //m_InputArray[i][j]=1;
                m_InputArray[i][j]=1;  
				m_bArray[i][j]=!m_bArray[i][j];
                //Invalidate();
                InvalidateRect(&m_rectArray[i][j],false);
 				break;
			}
 		}
 	}
	CDialog::OnLButtonDown(nFlags, point);
}

void CBpDlg::InitSample()
{
    int i,j,m,p;
	int k=0;
	CString str;
	for(i=0;i<10;i++)
	{
		for(p=0;p<5;p++)
		{
    str.Format("samples\\sample%d\\sample%d.txt",i,p);
	FILE *output;
	output=fopen(str,"r");
		for (j=0;j<16;j++)
			{
				for (k=0;k<16;k++)
				{
					fscanf(output,"%d",&temp[i][p][j*16+k]); 
				}
			}
        fclose(output);
		}
	}
   //CPaintDC dc(this); 
   //AfxMessageBox("數據導入完成");
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91一区在线观看| 亚洲一二三区视频在线观看| 国产一区亚洲一区| 91精品国产色综合久久| 美腿丝袜亚洲三区| 精品成人私密视频| 成人激情免费视频| 亚洲狠狠丁香婷婷综合久久久| 91精彩视频在线| 日韩二区三区四区| 国产亚洲一区二区在线观看| 国产91精品精华液一区二区三区| 综合色中文字幕| 精品视频色一区| 久久er精品视频| 久久精品男人的天堂| 99国产精品一区| 一级中文字幕一区二区| 欧美一区二区三区婷婷月色| 国产成人综合自拍| 一区二区三区鲁丝不卡| 日韩美一区二区三区| 成人av在线一区二区三区| 亚洲综合一区二区三区| 日韩午夜电影av| 97精品国产97久久久久久久久久久久| 亚洲综合在线免费观看| 日韩欧美电影在线| 成人国产精品免费观看| 日韩不卡免费视频| 中文一区一区三区高中清不卡| 在线观看日韩电影| 经典一区二区三区| 一区二区在线电影| 亚洲精品在线一区二区| 色国产综合视频| 激情欧美一区二区三区在线观看| 亚洲免费av高清| 久久综合九色综合97_久久久| 色猫猫国产区一区二在线视频| 韩国视频一区二区| 天堂午夜影视日韩欧美一区二区| 中文字幕电影一区| 日韩一区二区免费在线电影| 欧美亚洲国产bt| 国产成人自拍在线| 五月激情综合色| 综合色中文字幕| 久久久午夜电影| 91麻豆精品91久久久久久清纯| 成人不卡免费av| 黄色小说综合网站| 首页亚洲欧美制服丝腿| 亚洲人成精品久久久久久| 久久色.com| 日韩一级高清毛片| 欧美日韩日日夜夜| 91丨九色丨国产丨porny| 黄网站免费久久| 91麻豆精东视频| 国产成人精品亚洲日本在线桃色| 久久精品72免费观看| 亚欧色一区w666天堂| 一区二区在线观看免费| 日韩美女久久久| 国产午夜亚洲精品理论片色戒 | 国产香蕉久久精品综合网| 欧美精品在线一区二区三区| 在线精品视频免费播放| 一本色道久久综合亚洲精品按摩| 成人精品亚洲人成在线| 成人免费观看视频| 成人综合激情网| 成人永久看片免费视频天堂| 国产麻豆视频一区二区| 国产精品18久久久久久vr| 国产精品资源网| 国产成人自拍网| 国产91精品免费| 床上的激情91.| 成人av电影免费观看| av在线这里只有精品| 99热99精品| 色婷婷av一区二区三区之一色屋| 色综合天天综合网国产成人综合天| 91美女在线看| 在线国产亚洲欧美| 91精品国产综合久久国产大片 | 欧美视频一区在线观看| 欧美三级三级三级爽爽爽| 91麻豆精品国产| 欧美精品一区二区三区一线天视频| 精品福利一区二区三区| 国产欧美日韩亚州综合| 亚洲免费观看在线观看| 三级久久三级久久| 国产毛片精品视频| 91香蕉视频在线| 欧美日韩日本视频| 精品国产免费人成在线观看| 国产精品美女久久久久久久| 一区二区三区四区高清精品免费观看 | 成+人+亚洲+综合天堂| 91免费看视频| 欧美日韩黄色影视| 久久精品男人天堂av| 亚洲精品亚洲人成人网在线播放| 性欧美疯狂xxxxbbbb| 国产一区二区免费看| 91女神在线视频| 日韩视频国产视频| 亚洲色欲色欲www| 日本欧美在线观看| 99在线精品视频| 91精品国产91热久久久做人人 | 国产精品综合视频| 国产亚洲精品aa| 一区二区三区鲁丝不卡| 韩国v欧美v日本v亚洲v| 91官网在线免费观看| 亚洲精品一区二区三区香蕉| 最新久久zyz资源站| 男女激情视频一区| 91麻豆福利精品推荐| 久久日一线二线三线suv| 亚洲老司机在线| 国产制服丝袜一区| 欧美电影一区二区三区| 欧美国产日本视频| 日本不卡中文字幕| 一本一本久久a久久精品综合麻豆| 欧美xfplay| 亚洲妇熟xx妇色黄| 99久久精品免费看国产| 久久夜色精品国产噜噜av| 亚洲国产精品久久久男人的天堂| 高清在线观看日韩| 日韩精品一区二区三区在线 | 91网站视频在线观看| 欧美精品一区二区三区四区| 日韩精彩视频在线观看| 色婷婷综合久色| 亚洲国产精华液网站w| 蜜臀av一区二区| 在线电影欧美成精品| 最好看的中文字幕久久| 国产suv一区二区三区88区| 精品99999| 久久99最新地址| 日韩视频一区二区| 蜜桃精品在线观看| 4438x成人网最大色成网站| 亚洲最大的成人av| 一本大道av一区二区在线播放| 欧美国产丝袜视频| 国产.欧美.日韩| 中文字幕国产一区| 懂色av一区二区三区免费看| 久久精品欧美一区二区三区不卡 | 欧美精品三级日韩久久| 洋洋成人永久网站入口| 一本色道a无线码一区v| 亚洲人成精品久久久久| 99精品1区2区| 亚洲欧洲日韩在线| 99久久精品国产毛片| 亚洲天堂2014| 91国偷自产一区二区开放时间| 亚洲欧美日韩国产手机在线| 色欧美片视频在线观看在线视频| 亚洲精品成人悠悠色影视| 一本大道久久a久久精品综合| 亚洲激情在线激情| 欧美撒尿777hd撒尿| 香蕉av福利精品导航| 欧美夫妻性生活| 精品在线播放免费| 精品国产乱码久久久久久闺蜜| 国产一区二区电影| 国产女人水真多18毛片18精品视频| 丰满亚洲少妇av| 日韩毛片一二三区| 欧美体内she精高潮| 免费人成网站在线观看欧美高清| 日韩欧美国产一区二区三区 | 久久婷婷成人综合色| 国产成人在线视频免费播放| 国产精品不卡在线| 欧美曰成人黄网| 亚洲bt欧美bt精品| 欧美www视频| 成a人片亚洲日本久久| 亚洲成人动漫在线免费观看| 日韩欧美国产不卡| av在线一区二区三区| 五月天欧美精品| 国产性色一区二区| 欧美视频在线观看一区二区| 国内精品国产成人国产三级粉色 | 一本一道综合狠狠老|