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

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? matrix.cpp

?? 該軟件為BP網(wǎng)絡(luò)的仿真軟件
?? CPP
?? 第 1 頁(yè) / 共 4 頁(yè)
字號(hào):
		}
	}

}

/////////////////////////////////////////////////////////////////////////////
// InitializeZero()
// 矩陣初始化函數(shù),矩陣的行列數(shù)目被初始化為零,矩陣中的元素全部初始化為零
/////////////////////////////////////////////////////////////////////////////

void CMatrix::InitializeZero()
{
	m_nRow = 0;
	m_nCol = 0;

	m_pTMatrix.resize (m_nRow);
	for(unsigned int i=0; i < m_nRow; i++)
	{
		for(unsigned int j=0; j < m_nCol; j++)
		{
			m_pTMatrix[i].resize (m_nCol);
			m_pTMatrix[i][j] = (double) 0;
		}
	}

}

/////////////////////////////////////////////////////////////////////////////
// RandomInitialize()
// 將矩陣中的元素隨機(jī)初始化函數(shù),元素的值在(-1,1)之間的小數(shù)
/////////////////////////////////////////////////////////////////////////////

void CMatrix::RandomInitialize ()
{
	for(unsigned int i=0; i < m_nRow; i++)
	{
		for(unsigned int j=0; j < m_nCol; j++)
		{
			m_pTMatrix [i][j] = (double)(rand() - (0.5*RAND_MAX)) / (0.5*RAND_MAX);
		}
	}
	
}


/////////////////////////////////////////////////////////////////////////////
// 拷貝矩陣的子矩陣元素到另外一個(gè)矩陣中
// Parameter:
//		[out]	cMatrix ----> 矩陣的子矩陣返回的結(jié)果
//		[in]	nStartX ----> 子矩陣在矩陣中的起始坐標(biāo),對(duì)應(yīng)行,索引從1開(kāi)始
//		[in]	nStartY ----> 子矩陣在矩陣中的起始坐標(biāo),對(duì)應(yīng)列,索引從1開(kāi)始
/////////////////////////////////////////////////////////////////////////////

void CMatrix::CopySubMatrix(CMatrix& cMatrix,unsigned int nStartX,unsigned int nStartY)
{
	if((m_nRow  < cMatrix.m_nRow + nStartY ) | (m_nCol  < cMatrix.m_nCol + nStartX))
	{
		::AfxMessageBox (TEXT("被拷貝的矩陣維數(shù)小于要拷貝的矩陣所需要的維數(shù)!"),MB_OK | MB_ICONERROR);
		return;
	}

	for(unsigned int i=0;  i < cMatrix.m_nRow; i++)
	{
		for(unsigned int j=0; j < cMatrix.m_nCol; j++)
		{
			cMatrix.m_pTMatrix [i][j] = m_pTMatrix [nStartY + i][nStartX + j];	
		}
	}

}

/////////////////////////////////////////////////////////////////////////////
// Copy Matrix
//	Parameter:
//		[in]	cMatrix ----> 被拷貝的矩陣
/////////////////////////////////////////////////////////////////////////////

void CMatrix::CopyMatrix(CMatrix& cMatrix)
{
	m_nRow	= cMatrix.m_nRow ;
	m_nCol	= cMatrix.m_nCol ;

	m_pTMatrix	= cMatrix.m_pTMatrix ;

	for(unsigned int i=0; i < m_nRow; i++)
	{
		for(unsigned int j=0; j < m_nCol; j++)
		{
			m_pTMatrix [i][j] = cMatrix.m_pTMatrix [i][j];
		}

	}

}

/////////////////////////////////////////////////////////////////////////////
//	從一個(gè)列向量中拷貝數(shù)據(jù)到一個(gè)矩陣中
//	Parameter:
//		[out]	cMatrix ----> 函數(shù)的返回結(jié)果
//		[in]	nIndex	----> 在列向量中的索引值
//	Notes:
//		被拷貝的對(duì)象必須是列向量!!!
/////////////////////////////////////////////////////////////////////////////

void CMatrix::CopySubMatrixFromVector(CMatrix& cMatrix,unsigned int nIndex)
{
	if(m_nCol != 1)
	{
		::AfxMessageBox (TEXT("被拷貝的矩陣不是列向量!!!"),MB_OK | MB_ICONERROR);
		return;
	}

	for(unsigned int j=0; j < cMatrix.m_nCol; j++)
	{
		for(unsigned int i=0; i < cMatrix.m_nRow; i++)
		{
			cMatrix.m_pTMatrix [i][j] = m_pTMatrix [nIndex + j * cMatrix.m_nRow + i ][(unsigned int)0];
		}
	}

}

/////////////////////////////////////////////////////////////////////////////
// 對(duì)矩陣進(jìn)列拓展
//	實(shí)現(xiàn)功能:
//		對(duì)矩陣的列數(shù)進(jìn)行拓展,nTimes是每列拓展的次數(shù)
/////////////////////////////////////////////////////////////////////////////

void CMatrix::nncpyi(CMatrix &cMatrix, unsigned int nTimes)
{
	m_nRow	=	cMatrix.m_nRow ;
	m_nCol	=	cMatrix.m_nCol *	nTimes;

	// 根據(jù)空間分配內(nèi)存
	m_pTMatrix.resize (m_nRow);
	for(unsigned int i=0; i < m_nRow; i++)
	{
		for(unsigned int j=0; j < m_nCol; j++)
		{
			m_pTMatrix[i].resize (m_nCol);
			m_pTMatrix[i][j] = (double) 0;
		}
	}

	// 賦值
	for(i=0; i < m_nRow; i++)
	{
		for(unsigned int j=0; j < cMatrix.m_nCol; j++)
		{
			for(unsigned int k=0; k < nTimes; k++)
			{
				m_pTMatrix [i][j * nTimes + k] = cMatrix.m_pTMatrix [i][j];
			}
		}
	}

}

/////////////////////////////////////////////////////////////////////////////
// 對(duì)矩陣進(jìn)行拓展
//	實(shí)現(xiàn)功能:
//		對(duì)矩陣的列數(shù)進(jìn)行拓展
//	matrix =	[ 
//			1	2	3
//			4	5	6
//			7	8	9
//				]
//
//		nncpyd(matrix)	=	[
//			1	0	0	2	0	0	3	0	0
//			0	4	0	0	5	0	0	6	0
//			0	0	7	0	0	8	0	0	9
//							]
/////////////////////////////////////////////////////////////////////////////

void CMatrix::nncpyd(CMatrix &cMatrix)
{
	m_nRow	=	cMatrix.m_nRow ;
	m_nCol	=	cMatrix.m_nCol * cMatrix.m_nRow ;

	// 根據(jù)空間分配內(nèi)存
	m_pTMatrix.resize (m_nRow);
	for(unsigned int i=0; i < m_nRow; i++)
	{
		for(unsigned int j=0; j < m_nCol; j++)
		{
			m_pTMatrix[i].resize (m_nCol);
			m_pTMatrix[i][j] = (double) 0;
		}
	}

	// 給矩陣賦值
	for(i=0; i < m_nRow; i++)
	{
		for(unsigned int j=0; j < cMatrix.m_nCol; j++)
		{
			for(unsigned int k=0; k < cMatrix.m_nRow; k++)
			{
				if(i == (j * cMatrix.m_nRow + k) % cMatrix.m_nRow )
					m_pTMatrix [i][j * cMatrix.m_nRow + k] = cMatrix.m_pTMatrix [i][j];
			}
		}
	}

}

/////////////////////////////////////////////////////////////////////////////
// 對(duì)矩陣進(jìn)行拓展
//	實(shí)現(xiàn)功能:
//		對(duì)矩陣的列數(shù)進(jìn)行拓展,nTimes是每列拓展的次數(shù)
//	matrix =	[ 
//			1	2	3
//			4	5	6
//			7	8	9
//				]
//		nTimes = 2
//
//		nncpyd(matrix)	=	[
//					1	2	3	1	2	3
//					4	5	6	4	5	6
//					7	8	9	7	8	9
//							]
/////////////////////////////////////////////////////////////////////////////

void CMatrix::nncpy(CMatrix& cMatrix,unsigned int nTimes)
{
	m_nRow = cMatrix.m_nRow ;
	m_nCol = cMatrix.m_nCol * nTimes;

	// 根據(jù)空間分配內(nèi)存
	m_pTMatrix.resize (m_nRow);
	for(unsigned int i=0; i < m_nRow; i++)
	{
		for(unsigned int j=0; j < m_nCol; j++)
		{
			m_pTMatrix[i].resize (m_nCol);
			m_pTMatrix[i][j] = (double) 0;
		}
	}

	// 對(duì)矩陣賦值
	for(i=0; i < m_nRow; i++)
	{
		for(unsigned int j=0; j < nTimes; j++)
		{
			for(unsigned int k=0; k < cMatrix.m_nCol; k++)
			{
				m_pTMatrix [i][j * cMatrix.m_nCol + k] = cMatrix.m_pTMatrix [i][k];
			}
		}
	}

}

/////////////////////////////////////////////////////////////////////////////
// 對(duì)矩陣中所有的元素進(jìn)行一次非線性變換:
//		變換后的值y與變換前的值的關(guān)系是:
//			y = f(x) = 1 / (1 + exp(-x))	( 0 < f(x) < 1)
//
/////////////////////////////////////////////////////////////////////////////

CMatrix CMatrix::Sigmoid()
{
	CMatrix cMatrix = *this;

	for(unsigned int i=0; i < m_nRow; i++)
	{
		for(unsigned int j=0; j < m_nCol; j++)
		{
			cMatrix.m_pTMatrix [i][j] = 1 / (1 + exp(-m_pTMatrix [i][j]));
		}

	}
	
	return cMatrix;
}


/////////////////////////////////////////////////////////////////////////////
// 對(duì)矩陣中所有的元素進(jìn)行一次非線性變換:
//		變換后的值y與變換前的值的關(guān)系是:
//			y = tanh(x) = (1 - exp(-x)) / (1 + exp(-x))
//					 =  1 - 2 * exp(-x) / (1 + exp(-x))	( -1 < f(x) < 1)
//
/////////////////////////////////////////////////////////////////////////////

CMatrix CMatrix::tanh ()
{
	CMatrix cMatrix = *this;

	for(unsigned int i=0; i < m_nRow; i++)
	{
		for(unsigned int j=0; j < m_nCol; j++)
		{
			cMatrix.m_pTMatrix [i][j] = 1 - (2 * exp(-m_pTMatrix [i][j])) / (1 + exp(-m_pTMatrix [i][j]));
		}

	}
	
	return cMatrix;
}

/////////////////////////////////////////////////////////////////////////////
// 對(duì)矩陣中所有的元素進(jìn)行一次非線性變換:
//		變換后的值y與變換前的值的關(guān)系是:
//			y = Tansig(x) = 2 / (1 + exp(-2 * x)) -1
/////////////////////////////////////////////////////////////////////////////

CMatrix CMatrix::Tansig()
{
	CMatrix cMatrix = *this;

	for(unsigned int i=0; i < m_nRow; i++)
	{
		for(unsigned int j=0; j < m_nCol; j++)
		{
			cMatrix.m_pTMatrix [i][j] = 2 / (1 + exp(- 2 * m_pTMatrix [i][j])) - 1;
		}
	}
	
	return cMatrix;

}

/////////////////////////////////////////////////////////////////////////////
// 對(duì)矩陣中所有的元素進(jìn)行一次非線性變換:
//		變換后的值y與變換前的值的關(guān)系是:
//			y = Tansig'(x) = (2 / (1 + exp(-2 * x)) -1)'
//				= (2 / (1 + exp(-2 * x)) -1) * (2 / (1 + exp(-2 * x)) -1) -1
/////////////////////////////////////////////////////////////////////////////

CMatrix CMatrix::TansigDerivative()
{
	CMatrix cMatrix = *this;

	for(unsigned int i=0; i < m_nRow; i++)
	{
		for(unsigned int j=0; j < m_nCol; j++)
		{
			cMatrix.m_pTMatrix [i][j] = (2 / (1 + exp(- 2 * m_pTMatrix [i][j])) - 1) * (2 / (1 + exp(- 2 * m_pTMatrix [i][j])) - 1) - 1;
		}
	}

	return cMatrix;

}

/////////////////////////////////////////////////////////////////////////////
// 對(duì)矩陣中的元素進(jìn)行一次操作:
//		使所有行中的相對(duì)應(yīng)的列元素相等
//	Parameter:
//		nRowIndex	---->	行索引值(從零開(kāi)始)
//							以此行做為標(biāo)準(zhǔn),使矩陣中其余的行相對(duì)應(yīng)的列的值
//							與此行相對(duì)應(yīng)的列的值相等
/////////////////////////////////////////////////////////////////////////////
	
void CMatrix::MakeAllColumnElementsSameValue(unsigned int nRowIndex)
{
	for(unsigned int i=0; i < m_nRow; i++)
	{
		if(i == nRowIndex)
			continue;

		for(unsigned int j=0; j < m_nCol; j++)
		{
			m_pTMatrix [i][j] = m_pTMatrix [nRowIndex][j];
		}
	}

}


/////////////////////////////////////////////////////////////////////////////
// 對(duì)矩陣中所有的元素進(jìn)行一次非線性變換:
//		變換后的值y與變換前的值的關(guān)系是:
//			y = f'(x) = (1 / (1 + exp(-x)))'	( 0 < f(x) < 1)
//			  = exp(-x)/((1 + exp(-x))*(1 + exp(-x)))
/////////////////////////////////////////////////////////////////////////////

CMatrix CMatrix::SigmoidDerivative()
{
	CMatrix cMatrix = *this;

	for(unsigned int i=0; i < m_nRow; i++)
	{
		for(unsigned int j=0; j < m_nCol; j++)
		{
			cMatrix.m_pTMatrix [i][j] = exp(-m_pTMatrix [i][j]) / ((1 + exp(-m_pTMatrix [i][j])) * (1 + exp(-m_pTMatrix [i][j])));
		}

	}
	
	return cMatrix;
}


/////////////////////////////////////////////////////////////////////////////
// 對(duì)矩陣中所有的元素進(jìn)行一次非線性變換:
//		變換后的值y與變換前的值的關(guān)系是:
//			y = tanh'(x) = ((1 - exp(-x)) / (1 + exp(-x)))'	( -1 < f(x) < 1)
//					 = 	2*exp(-x)/((1 + exp(-x))*(1 + exp(-x)))
/////////////////////////////////////////////////////////////////////////////

CMatrix CMatrix::tanhDerivative()
{
	CMatrix cMatrix = *this;

	for(unsigned int i=0; i < m_nRow; i++)
	{
		for(unsigned int j=0; j < m_nCol; j++)
		{
			cMatrix.m_pTMatrix [i][j] = 2 * exp(-m_pTMatrix [i][j]) / ((1 + exp(-m_pTMatrix [i][j])) * (1 + exp(-m_pTMatrix [i][j])));
		}

	}

	return cMatrix;
}


/////////////////////////////////////////////////////////////////////////////
// 實(shí)現(xiàn)對(duì)點(diǎn)乘操作符的重載
/////////////////////////////////////////////////////////////////////////////

CMatrix CMatrix::operator / (CMatrix& cMatrixB)
{
	CMatrix cMatrix = *this;

	if( (m_nRow != cMatrixB.m_nRow) || (m_nCol != cMatrixB.m_nCol) )
	{
		::AfxMessageBox (TEXT("兩個(gè)矩陣的維數(shù)不相等,不滿足矩陣點(diǎn)乘的條件!"),MB_OK | MB_ICONERROR);
		return cMatrix;	// return a invalid value
	}
	
	for(unsigned int i=0; i < m_nRow; i++)
	{
		for(unsigned int j=0; j < m_nCol; j++)
		{
			cMatrix.m_pTMatrix [i][j] = m_pTMatrix [i][j] * cMatrixB.m_pTMatrix [i][j];
		}

	}

	return cMatrix;

}



//***************************************************************************
// ordinary function
//

/////////////////////////////////////////////////////////////////////////////
// 重載 'double - CMatrix' 運(yùn)算符
/////////////////////////////////////////////////////////////////////////////

CMatrix operator - (double nValue,CMatrix& cMatrixB)
{
	CMatrix	cMatrix = cMatrixB;

	for(unsigned int i=0; i < cMatrix.GetMatrixRowNumber (); i++)
	{
		for(unsigned int j=0; j < cMatrix.GetMatrixColNumber (); j++)
		{
			cMatrix.m_pTMatrix [i][j] = nValue - cMatrixB.m_pTMatrix [i][j];
		}
	}

	return cMatrix;
}



/////////////////////////////////////////////////////////////////////////////
// 矩陣合并運(yùn)算符
//	合并規(guī)則:
//		1. 參與合并運(yùn)算的兩個(gè)矩陣的行數(shù)必須相等;
//		2. 參與合并的兩個(gè)矩陣的列數(shù)可以不相等;
//		3. 合并后返回的矩陣的行數(shù)與參與合并的矩陣的行數(shù)相等,列數(shù)是參與合并的
//			兩個(gè)矩陣的列數(shù)之和;
/////////////////////////////////////////////////////////////////////////////

CMatrix MergeMatrix(CMatrix& cMatrixA,CMatrix& cMatrixB)
{
	//	條件檢測(cè)
	if( cMatrixA.GetMatrixRowNumber () != cMatrixB.GetMatrixRowNumber () )
	{
		::AfxMessageBox (TEXT("參與合并的兩個(gè)矩陣的行數(shù)不相等!"),MB_OK | MB_ICONERROR);
	
		return cMatrixA;	// return invalid value
	}

	CMatrix cMatrix(cMatrixA.GetMatrixRowNumber (),cMatrixA.GetMatrixColNumber () + cMatrixB.GetMatrixColNumber ());

	for(unsigned int i=0; i < cMatrixA.GetMatrixRowNumber (); i++)
	{
		for(unsigned int j=0; j < cMatrixA.GetMatrixColNumber (); j++)
		{
			cMatrix.m_pTMatrix [i][j] = cMatrixA.m_pTMatrix [i][j];
		}

		for(unsigned int k=0; k < cMatrixB.GetMatrixColNumber (); k++)
		{
			cMatrix.m_pTMatrix [i][cMatrixA.GetMatrixColNumber () + k] = cMatrixB.m_pTMatrix [i][k];
		}

	}


	return cMatrix;
}

// End of ordinary function
//***************************************************************************

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
8x8x8国产精品| 国产精品456露脸| 蜜桃视频一区二区三区在线观看| 国产麻豆视频一区| jlzzjlzz亚洲日本少妇| 欧美裸体一区二区三区| 精品电影一区二区三区| 亚洲免费观看在线观看| 美女视频网站久久| 99国产精品99久久久久久| 欧美老年两性高潮| 中文在线资源观看网站视频免费不卡| 亚洲自拍偷拍网站| 国产精品99精品久久免费| 在线观看一区二区视频| 久久综合久久综合亚洲| 亚洲精选视频免费看| 久草中文综合在线| 色综合久久88色综合天天 | 日韩国产一区二| 处破女av一区二区| 91精品在线麻豆| 中文字幕在线不卡一区二区三区| 日韩精品一二三区| 99久久99久久精品国产片果冻| 欧美一级黄色录像| 亚洲精品国产成人久久av盗摄| 国产一区亚洲一区| 欧美日韩一级大片网址| 国产精品三级视频| 蜜臀久久99精品久久久画质超高清 | 欧美中文字幕一区二区三区| 久久久精品中文字幕麻豆发布| 亚洲h在线观看| 91免费视频网址| 欧美国产精品中文字幕| 日本美女一区二区三区视频| 91麻豆成人久久精品二区三区| 久久综合色播五月| 美日韩一级片在线观看| 欧美在线观看视频一区二区 | 91美女在线看| 欧美国产日韩在线观看| 久久国产精品免费| 欧美另类videos死尸| 亚洲免费在线视频一区 二区| 国产1区2区3区精品美女| 日韩情涩欧美日韩视频| 日韩在线播放一区二区| 91国模大尺度私拍在线视频| 国产精品乱码一区二区三区软件| 久久99久久久欧美国产| 欧美一区二区三区免费视频| 一区二区三区成人在线视频| 91麻豆免费看| 国产精品国产成人国产三级| 国产成人夜色高潮福利影视| 精品国产自在久精品国产| 日本怡春院一区二区| 欧美日本一道本| 亚洲一二三区不卡| 欧美视频三区在线播放| 亚洲一区二区三区自拍| 色综合久久久久综合| 亚洲三级在线观看| 91麻豆国产在线观看| 中文字幕一区日韩精品欧美| 99国产欧美另类久久久精品| 中文字幕视频一区二区三区久| 成人av免费网站| 国产精品免费人成网站| 99精品欧美一区二区三区综合在线| 欧美韩国日本综合| 91在线视频播放| 亚洲免费观看高清完整| 在线一区二区三区四区五区| 亚洲国产一二三| 欧美日韩成人一区| 美日韩一区二区| 久久综合五月天婷婷伊人| 国产精品乡下勾搭老头1| 国产精品伦理一区二区| 一本一道久久a久久精品| 亚洲激情图片一区| 欧美日韩国产成人在线免费| 日韩精品福利网| 精品日韩欧美一区二区| 国产成人av电影在线观看| 国产日韩欧美电影| 一本一道综合狠狠老| 婷婷六月综合网| 精品国产电影一区二区| 大美女一区二区三区| 亚洲精品免费一二三区| 欧美日本在线播放| 精品写真视频在线观看| 国产欧美精品一区aⅴ影院| av男人天堂一区| 婷婷夜色潮精品综合在线| 精品对白一区国产伦| 成人毛片老司机大片| 夜夜精品视频一区二区| 日韩一二在线观看| 不卡在线视频中文字幕| 一区二区三区四区在线| 日韩午夜电影在线观看| 国产suv精品一区二区883| 亚洲欧美激情插| 欧美一区二区大片| 成人app网站| 午夜精品久久久久久久久久| 2022国产精品视频| 色爱区综合激月婷婷| 久久99久久精品| 国产精品久久777777| 91精品国产乱| 99久久免费国产| 免费观看一级特黄欧美大片| 国产蜜臀av在线一区二区三区| 欧美最新大片在线看| 国产精品456| 亚洲国产精品一区二区久久| 国产亚洲一区二区三区在线观看| 日本韩国一区二区| 国产乱人伦偷精品视频不卡| 亚洲第一搞黄网站| 久久久精品国产99久久精品芒果| 在线精品亚洲一区二区不卡| 国产伦精品一区二区三区免费 | 在线成人av网站| 成人v精品蜜桃久久一区| 免费久久99精品国产| 亚洲精品中文在线| 久久综合色天天久久综合图片| 欧美无砖砖区免费| 国产suv一区二区三区88区| 香蕉久久一区二区不卡无毒影院 | 97精品久久久午夜一区二区三区 | 国产欧美精品一区二区色综合朱莉 | 中文字幕一区三区| 精品国产成人在线影院| 欧美日韩一级二级| 91在线精品一区二区三区| 黄色日韩网站视频| 日日夜夜精品视频免费| 亚洲黄色免费网站| 亚洲国产精品成人综合| 精品国产人成亚洲区| 欧美精品第1页| 欧美中文字幕一区二区三区亚洲| 成人黄色综合网站| 国产一区二三区好的| 蜜臀av性久久久久蜜臀aⅴ流畅 | 欧美精品v日韩精品v韩国精品v| 成人97人人超碰人人99| 经典一区二区三区| 免费视频一区二区| 五月激情综合色| 亚洲一区二区三区不卡国产欧美| 国产精品久久看| 国产肉丝袜一区二区| 精品三级av在线| 日韩欧美一级在线播放| 日韩一区二区三区四区| 欧美二区三区91| 欧美日韩一区二区电影| 欧美在线看片a免费观看| 91国偷自产一区二区使用方法| 94色蜜桃网一区二区三区| 成人免费毛片片v| 国产不卡免费视频| 国产精品一区二区在线观看网站| 久久精品国产精品亚洲精品 | 久久免费电影网| 欧美不卡在线视频| 欧美成人在线直播| 日韩精品在线看片z| 日韩午夜在线播放| 精品久久人人做人人爽| 精品1区2区在线观看| ww亚洲ww在线观看国产| 精品国产一区二区三区av性色| 精品国产三级a在线观看| 久久一区二区三区国产精品| 26uuu另类欧美| 国产丝袜欧美中文另类| 国产精品情趣视频| 亚洲色欲色欲www| 曰韩精品一区二区| 亚洲尤物在线视频观看| 亚洲3atv精品一区二区三区| 日韩 欧美一区二区三区| 麻豆精品精品国产自在97香蕉| 久久精品理论片| 国产成人自拍高清视频在线免费播放| 国产精品一区二区果冻传媒| 成人一级视频在线观看| 99精品热视频| 欧美色大人视频| 日韩一区二区精品葵司在线|