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

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

?? matrix.inl

?? 圖像分割算法
?? INL
?? 第 1 頁 / 共 3 頁
字號:
Matrix<T> Matrix<T>::Cat(int dimension, Vector<T>& m1, Matrix<T>& m2)
{
	return Matrix<T>::Cat(dimension, (Matrix<T>)m1, m2);
}

template< class T >
Matrix<T> Matrix<T>::Cat(int dimension, Vector<T>& m1, Vector<T>& m2)
{
	return Matrix<T>::Cat(dimension, (Matrix<T>)m1, (Matrix<T>)m2);
}


template< class T >
Matrix<T> Matrix<T>::Ones(int side)
{
	Matrix<T> temp(side,side,1);
	return temp;
}


template< class T >
Matrix<T> Matrix<T>::Ones(int rows, int cols)
{
	Matrix<T> temp(rows,cols,1);
	return temp;
}

template< class T >
Matrix<T> Matrix<T>::Zeros(int side)
{
	Matrix<T> temp(side,side,0);
	return temp;
}


template< class T >
Matrix<T> Matrix<T>::Zeros(int rows, int cols)
{
	Matrix<T> temp(rows,cols,0);
	return temp;
}







template< class T >
bool Matrix<T>::IsSquare(Matrix<T>& m)
{
	if(m.xDim == m.yDim)
	{
		return true;
	}
	else
	{
		return false;
	}
}





/// \brief are these matrices (and in this order) are compatible for matrix multiplication
template< class T >
bool Matrix<T>::IsM2MCompatible(Matrix<T>& m1, Matrix<T>& m2)
{
	if(m1.xDim == m2.yDim)
	{
		return true;
	}
	else
	{
		return false;
	}
}


/// \brief Matrix multiplication. Also used to overload & operator.
template< class T >
Matrix<T> Matrix<T>::MMultiply(Matrix<T>& m1, Matrix<T>& m2)
{
	if(!Matrix<T>::IsM2MCompatible(m1, m2))
	{
		cerr << "Line: " << __LINE__ << " File: " << __FILE__ << endl;
		Utility::RunTimeError("Matrix sizes are not compatible for matrix multiplication!");
	}

	Matrix<T> temp(m1.yDim, m2.xDim);
	temp.Init(0);
	for(int i=0; i<m1.yDim; i++)
	{
		for(int j=0; j<m2.xDim; j++)
		{
			for(int k = 0; k<m1.xDim; k++)
			{
				temp[j][i] += m1[k][i]*m2[j][k]; 
			}
		}
	}
	
	return temp;
}


/// \brief Matrix to Vector multiplication. Vector is taken as a column vector.
template< class T >
Matrix<T> Matrix<T>::MMultiply(Matrix<T>& m1, Vector<T>& m2)
{
	if(m1.xDim != m2.length)
	{
		cerr << "Line: " << __LINE__ << " File: " << __FILE__ << endl;
		Utility::RunTimeError("Matrix sizes are not compatible for matrix multiplication!");
	}

	Matrix<T> temp(m1.yDim, 1);
	temp.Init(0);
	for(int i=0; i<m1.yDim; i++)
	{
		for(int j=0; j<m2.length; j++)
		{
			temp.data[i] += m1[j][i]*m2[j]; 
		}
	}
	
	return temp;
}

/// \brief Vector to Matrix multiplication. Vector is taken as a row vector.
template< class T >
Matrix<T> Matrix<T>::MMultiply(Vector<T>& m1, Matrix<T>& m2)
{
	if(m2.Rows() != m1.length)
	{
		cerr << "Line: " << __LINE__ << " File: " << __FILE__ << endl;
		Utility::RunTimeError("Matrix sizes are not compatible for matrix multiplication!");
	}

	Matrix<T> temp(1, m2.Columns());
	temp.Init(0);
	for(int i=0; i<m2.Columns(); i++)
	{
		for(int j=0; j<m1.length; j++)
		{
				temp.data[i] += m2[i][j]*m1[j]; 
		}
	}
	
	return temp;
}


/// \brief Transpose of a matrix. Allocates a new Matrix.
template< class T >
Matrix<T> Matrix<T>::Transpose(Matrix<T>& m)
{
	Matrix<T> temp(m.Columns(), m.Rows());
	for(int i=0; i<m.Rows(); i++)
	{
		for(int j=0; j<m.Columns(); j++)
		{
			temp[i][j] = m[j][i]; 
		}
	}
	return temp;
}


/// \brief Transpose of a matrix. Does not allocate a new Matrix. Creates transpose inline.
template< class T >
Matrix<T>& Matrix<T>::Transpose()
{
	if(!Matrix<T>::IsSquare(*this))
	{
		cerr << "Line: " << __LINE__ << " File: " << __FILE__ << endl;
		Utility::RunTimeError("Matrix is not square!");
	}
	
	for(int i=0; i<yDim; i++)
	{
		for(int j=0; j<i; j++)
		{
			T temp = columns[j][i];
			columns[j][i] = columns[i][j];
			columns[i][j] = temp;
		}
	}
	return *this;

}


/// \brief Check if two matrices have the same sizes.
template< class T >
bool Matrix<T>::IsCompatible(Matrix<T>& m1, Matrix<T>& m2)
{
	if(m1.xDim != m2.xDim || m1.yDim != m2.yDim)
	{
		return false;
	}
	else
	{
		return true;
	}

}


// //////////////////
// Boolean Operations...
// //////////////////

/// \brief Elementwise AND operator. Returns 1 or 0 for each element.
template< class T >
Matrix<int> Matrix<T>::And(Matrix<T>& m1, Matrix<T>& m2)
{
	if(!Matrix<T>::IsCompatible(m1, m2))
	{
		cerr << "Line: " << __LINE__ << " File: " << __FILE__ << endl;
		Utility::RunTimeError("Matrix sizes are not compatible!");
	}

	Matrix<int> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.Length();i++)
	{
		temp.Data()[i] = (m1.data[i] != 0 && m2.data[i] != 0) ? 1 : 0;
	}
	
	return temp;
}


/// \brief Elementwise OR operator. Returns 1 or 0 for each element.
template< class T >
Matrix<int> Matrix<T>::Or(Matrix<T>& m1, Matrix<T>& m2)
{
	if(!Matrix<T>::IsCompatible(m1, m2))
	{
		cerr << "Line: " << __LINE__ << " File: " << __FILE__ << endl;
		Utility::RunTimeError("Matrix sizes are not compatible!");
	}

	Matrix<int> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.Length();i++)
	{
		temp.Data()[i] = (m1.data[i] == 0 && m2.data[i] == 0) ? 0 : 1;
	}
	
	return temp;
}

/// \brief Elementwise < (less than) operator. Returns 1 or 0 for each element.
template< class T >
Matrix<int> Matrix<T>::Lt(Matrix<T>& m1, Matrix<T>& m2)
{
	if(!Matrix<T>::IsCompatible(m1, m2))
	{
		cerr << "Line: " << __LINE__ << " File: " << __FILE__ << endl;
		Utility::RunTimeError("Matrix sizes are not compatible!");
	}

	Matrix<int> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.Length();i++)
	{
		temp.Data()[i] = (m1.data[i] < m2.data[i]) ? 1 : 0;
	}
	
	return temp;
}

/// \brief Elementwise > (greater than) operator. Returns 1 or 0 for each element.
template< class T >
Matrix<int> Matrix<T>::Gt(Matrix<T>& m1, Matrix<T>& m2)
{
	if(!Matrix<T>::IsCompatible(m1, m2))
	{
		cerr << "Line: " << __LINE__ << " File: " << __FILE__ << endl;
		Utility::RunTimeError("Matrix sizes are not compatible!");
	}

	Matrix<int> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.Length();i++)
	{
		temp.Data()[i] = (m1.data[i] > m2.data[i]) ? 1 : 0;
	}
	
	return temp;
}

/// \brief Elementwise <= (less than or equal) operator. Returns 1 or 0 for each element.
template< class T >
Matrix<int> Matrix<T>::Le(Matrix<T>& m1, Matrix<T>& m2)
{
	if(!Matrix<T>::IsCompatible(m1, m2))
	{
		cerr << "Line: " << __LINE__ << " File: " << __FILE__ << endl;
		Utility::RunTimeError("Matrix sizes are not compatible!");
	}

	Matrix<int> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.Length();i++)
	{
		temp.Data()[i] = (m1.data[i] <= m2.data[i]) ? 1 : 0;
	}
	
	return temp;
}

/// \brief Elementwise >= (greater than or equal) operator. Returns 1 or 0 for each element.
template< class T >
Matrix<int> Matrix<T>::Ge(Matrix<T>& m1, Matrix<T>& m2)
{
	if(!Matrix<T>::IsCompatible(m1, m2))
	{
		cerr << "Line: " << __LINE__ << " File: " << __FILE__ << endl;
		Utility::RunTimeError("Matrix sizes are not compatible!");
	}

	Matrix<int> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.Length();i++)
	{
		temp.Data()[i] = (m1.data[i] >= m2.data[i]) ? 1 : 0;
	}
	
	return temp;
}

/// \brief Elementwise == operator. Returns 1 or 0 for each element.
template< class T >
Matrix<int> Matrix<T>::Eq(Matrix<T>& m1, Matrix<T>& m2)
{
	if(!Matrix<T>::IsCompatible(m1, m2))
	{
		cerr << "Line: " << __LINE__ << " File: " << __FILE__ << endl;
		Utility::RunTimeError("Matrix sizes are not compatible!");
	}

	Matrix<int> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.Length();i++)
	{
		temp.Data()[i] = (m1.data[i] == m2.data[i]) ? 1 : 0;
	}
	
	return temp;
}

/// \brief Elementwise != (not equal) operator. Returns 1 or 0 for each element.
template< class T >
Matrix<int> Matrix<T>::Ne(Matrix<T>& m1, Matrix<T>& m2)
{
	if(!Matrix<T>::IsCompatible(m1, m2))
	{
		cerr << "Line: " << __LINE__ << " File: " << __FILE__ << endl;
		Utility::RunTimeError("Matrix sizes are not compatible!");
	}

	Matrix<int> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.Length();i++)
	{
		temp.Data()[i] = (m1.data[i] != m2.data[i]) ? 1 : 0;
	}
	
	return temp;
}




// ////////////////
// Boolean Operations with value types...
// ////////////////


/// \brief AND operator between Matrix elements and a value. Returns 1 or 0 for each element.
template< class T >
Matrix<int> Matrix<T>::And(Matrix<T>& m1, T v)
{
	Matrix<int> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.Length();i++)
	{
		temp.Data()[i] = (m1.data[i] != 0 && v != 0) ? 1 : 0;
	}
	
	return temp;
}


/// \brief OR operator between Matrix elements and a value. Returns 1 or 0 for each element.
template< class T >
Matrix<int> Matrix<T>::Or(Matrix<T>& m1, T v)
{
	Matrix<int> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.Length();i++)
	{
		temp.Data()[i] = (m1.data[i] == 0 && v == 0) ? 0 : 1;
	}
	
	return temp;
}


/// \brief < (Less than) operator between Matrix elements and a value. Returns 1 or 0 for each element.
template< class T >
Matrix<int> Matrix<T>::Lt(Matrix<T>& m1, T v)
{
	Matrix<int> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.Length();i++)
	{
		temp.Data()[i] = (m1.data[i] < v) ? 1 : 0;
	}
	
	return temp;
}


/// \brief > (Greater than) operator between Matrix elements and a value. Returns 1 or 0 for each element.
template< class T >
Matrix<int> Matrix<T>::Gt(Matrix<T>& m1, T v)
{
	Matrix<int> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.Length();i++)
	{
		temp.Data()[i] = (m1.data[i] > v) ? 1 : 0;
	}
	
	return temp;
}


/// \brief <= (Less than or equal) operator between Matrix elements and a value. Returns 1 or 0 for each element.
template< class T >
Matrix<int> Matrix<T>::Le(Matrix<T>& m1, T v)
{
	Matrix<int> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.Length();i++)
	{
		temp.Data()[i] = (m1.data[i] <= v) ? 1 : 0;
	}
	
	return temp;
}


/// \brief <= (Greater than or equal) operator between Matrix elements and a value. Returns 1 or 0 for each element.
template< class T >
Matrix<int> Matrix<T>::Ge(Matrix<T>& m1, T v)
{
	Matrix<int> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.Length();i++)
	{
		temp.Data()[i] = (m1.data[i] >= v) ? 1 : 0;
	}
	
	return temp;
}


/// \brief == operator between Matrix elements and a value. Returns 1 or 0 for each element.
template< class T >
Matrix<int> Matrix<T>::Eq(Matrix<T>& m1, T v)
{
	Matrix<int> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.Length();i++)
	{
		temp.Data()[i] = (m1.data[i] == v) ? 1 : 0;
	}
	
	return temp;
}


/// \brief != (Not equal) operator between Matrix elements and a value. Returns 1 or 0 for each element.
template< class T >
Matrix<int> Matrix<T>::Ne(Matrix<T>& m1, T v)
{
	Matrix<int> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.Length();i++)
	{
		temp.Data()[i] = (m1.data[i] != v) ? 1 : 0;
	}
	
	return temp;
}











// /////////////////
// Elementwise matrix arithmetic
// ////////////////


template< class T >
Matrix<T> Matrix<T>::Add(Matrix<T>& m1, Matrix<T>& m2)
{
	if(!Matrix<T>::IsCompatible(m1, m2))
	{
		cerr << "Line: " << __LINE__ << " File: " << __FILE__ << endl;
		Utility::RunTimeError("Matrix sizes are not compatible!");
	}

	Matrix<T> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.length;i++)
	{
		temp.data[i] = m1.data[i] + m2.data[i];
	}
	
	return temp;
}


template< class T >
Matrix<T> Matrix<T>::Subtract(Matrix<T>& m1, Matrix<T>& m2)
{
	if(!Matrix<T>::IsCompatible(m1, m2))
	{
		cerr << "Line: " << __LINE__ << " File: " << __FILE__ << endl;
		Utility::RunTimeError("Matrix sizes are not compatible!");
	}

	Matrix<T> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.length;i++)
	{
		temp.data[i] = m1.data[i] - m2.data[i];
	}
	
	return temp;
}

template< class T >
Matrix<T> Matrix<T>::Multiply(Matrix<T>& m1, Matrix<T>& m2)
{
	if(!Matrix<T>::IsCompatible(m1, m2))
	{
		cerr << "Line: " << __LINE__ << " File: " << __FILE__ << endl;
		Utility::RunTimeError("Matrix sizes are not compatible!");
	}

	Matrix<T> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.length;i++)
	{
		temp.data[i] = m1.data[i] * m2.data[i];
	}
	
	return temp;
}

template< class T >
Matrix<T> Matrix<T>::Divide(Matrix<T>& m1, Matrix<T>& m2)
{
	if(!Matrix<T>::IsCompatible(m1, m2))
	{
		cerr << "Line: " << __LINE__ << " File: " << __FILE__ << endl;
		Utility::RunTimeError("Matrix sizes are not compatible!");
	}

	Matrix<T> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.length;i++)
	{
		//FW: catch division exception instead...
		if(m2.data[i] != 0)
		{
			temp.data[i] = m1.data[i] / m2.data[i];
		}
		else
		{
			cerr << "Line: " << __LINE__ << " File: " << __FILE__ << endl;
			Utility::RunTimeError("Divide by zero in matrix division!");
		}
	}
	
	return temp;
}

// ////////
// Arithmetic operations between a matrix and a value.
// ////////


template< class T >
Matrix<T> Matrix<T>::Add(Matrix<T>& m1, T v2)
{
	Matrix<T> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.length;i++)
	{
		temp.data[i] = m1.data[i] + v2;
	}
	return temp;
}

template< class T >
Matrix<T> Matrix<T>::Subtract(Matrix<T>& m1, T v2)
{
	Matrix<T> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.length;i++)
	{
		temp.data[i] = m1.data[i] - v2;
	}
	return temp;
}

template< class T >
Matrix<T> Matrix<T>::Subtract(T v2, Matrix<T>& m1)
{
	Matrix<T> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.length;i++)
	{
		temp.data[i] = v2 - m1.data[i];
	}
	return temp;
}


template< class T >
Matrix<T> Matrix<T>::Multiply(Matrix<T>& m1, T v2)
{
	Matrix<T> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.length;i++)
	{
		temp.data[i] = m1.data[i] * v2;
	}
	return temp;
}

template< class T >
Matrix<T> Matrix<T>::Divide(Matrix<T>& m1, T v2)
{
	if(v2 == 0)
	{
		cerr << "Line: " << __LINE__ << " File: " << __FILE__ << endl;
		Utility::RunTimeError("Divide by zero in matrix by value division!");
	}

	Matrix<T> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.length;i++)
	{
		temp.data[i] = m1.data[i] / v2;
	}
	return temp;
}

template< class T >
Matrix<T> Matrix<T>::Divide(T v2, Matrix<T>& m1)
{
	Matrix<T> temp(m1.yDim, m1.xDim);
	for(int i=0;i<temp.length;i++)
	{
		if(m1.data[i] != 0)
		{
			temp.data[i] = v2 / m1.data[i];
		}
		else
		{
			cerr << "Line: " << __LINE__ << " File: " << __FILE__ << endl;
			Utility::RunTimeError("Divide by zero in value by matrix division!");
		}
	}
	return temp;
}


// //////////
// Elementwise matrix arithmetic with "this" matrix
// /////////

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲欧美在线aaa| 日韩一级在线观看| 国产精品电影一区二区| 成人蜜臀av电影| 欧美国产一区视频在线观看| 成人午夜激情影院| 自拍偷拍亚洲综合| 91久久久免费一区二区| 亚洲成人一二三| 日韩精品一区二区在线| 国产99一区视频免费| 最新日韩av在线| 欧美日韩精品电影| 久久激情综合网| 国产精品女主播av| 欧美艳星brazzers| 精品综合免费视频观看| 国产午夜精品福利| 欧美午夜寂寞影院| 麻豆精品视频在线观看| 国产精品午夜春色av| 在线观看国产精品网站| 蜜桃av一区二区三区电影| 国产亚洲欧洲一区高清在线观看| 成av人片一区二区| 日韩1区2区3区| 国产欧美精品一区| 欧美伦理影视网| 国产精品99久久久久久似苏梦涵 | 欧美午夜片在线看| 免费看欧美女人艹b| 久久综合九色综合久久久精品综合 | 国产精品亚洲一区二区三区妖精| 中文字幕亚洲在| 欧美一级片在线看| 91免费在线视频观看| 老司机一区二区| 亚洲精品视频在线看| 精品国精品国产尤物美女| 色婷婷精品久久二区二区蜜臀av| 另类小说欧美激情| 亚洲国产一区二区a毛片| 久久久影院官网| 欧美日韩mp4| 成人久久久精品乱码一区二区三区| 亚洲黄色在线视频| 欧美国产精品一区| 欧美xxxx老人做受| 欧洲一区在线电影| 成人动漫在线一区| 黄页网站大全一区二区| 日韩专区在线视频| 亚洲黄一区二区三区| 国产蜜臀av在线一区二区三区| 欧美精品一卡二卡| 91美女在线视频| 国产jizzjizz一区二区| 久久精品国产免费看久久精品| 一区二区三区av电影| 中文久久乱码一区二区| 精品国产sm最大网站| 777午夜精品视频在线播放| 91麻豆免费看| 92精品国产成人观看免费| 国产91精品欧美| 国产精品一区专区| 国内精品在线播放| 麻豆久久久久久久| 蜜臀av亚洲一区中文字幕| 午夜视频一区在线观看| 一级女性全黄久久生活片免费| 中文字幕一区二区三区视频| 久久精品亚洲精品国产欧美| 亚洲精品一区二区三区四区高清| 日韩视频一区二区在线观看| 日韩一级片网址| 日韩一级大片在线| 日韩欧美区一区二| 欧美成人三级在线| 日韩av高清在线观看| 国产精品538一区二区在线| 一区二区三区在线影院| 欧美国产精品中文字幕| 国产精品三级在线观看| 国产日韩欧美精品电影三级在线| 久久精品人人做人人综合| 精品一区二区三区香蕉蜜桃| 国产成a人亚洲| 国产 日韩 欧美大片| 欧美性色综合网| 亚洲国产激情av| 日韩在线一区二区| 91在线观看污| 精品成人在线观看| 亚洲第一狼人社区| 国产成人啪免费观看软件| 欧美性生活一区| 国产精品麻豆欧美日韩ww| 日韩中文字幕麻豆| 一本色道a无线码一区v| 亚洲精品一区二区三区精华液 | 自拍偷拍欧美精品| 国内精品免费**视频| 精品视频免费在线| 亚洲欧洲在线观看av| 国产在线视频一区二区三区| 在线日韩一区二区| 国产精品看片你懂得| 精品一区二区三区的国产在线播放 | 欧美一区二区三区四区五区| 亚洲欧美综合另类在线卡通| 久久精品999| 欧美日韩一区二区在线视频| 最新国产成人在线观看| 国产一区二区网址| 日韩美女一区二区三区四区| 亚洲一区在线观看视频| 99精品国产热久久91蜜凸| www激情久久| 美国十次综合导航| 欧美人与性动xxxx| 亚洲一区二区在线视频| 色综合久久天天| 中文字幕日本乱码精品影院| 国产成人av网站| 国产婷婷色一区二区三区 | 亚洲成人中文在线| 色噜噜狠狠色综合中国| 亚洲视频电影在线| 99综合影院在线| 国产精品污www在线观看| 国产精品一区二区在线观看不卡| 精品免费国产二区三区| 久久成人精品无人区| 精品久久久久久久久久久院品网 | 亚洲国产成人精品视频| 91视频一区二区三区| 综合久久久久久| 91在线视频18| 一区二区三区欧美在线观看| 91麻豆免费观看| 亚洲一线二线三线视频| 欧美性受极品xxxx喷水| 五月天中文字幕一区二区| 欧美日韩一区二区三区免费看| 亚洲超碰精品一区二区| 欧美在线观看视频一区二区三区| 亚洲一区二区四区蜜桃| 欧美日韩亚洲综合在线 | 午夜视频在线观看一区| 欧美一区二区三区免费观看视频| 奇米影视7777精品一区二区| 2024国产精品| 成人午夜激情视频| 亚洲精品乱码久久久久久| 欧美日韩免费一区二区三区视频| 天使萌一区二区三区免费观看| 欧美一区二区在线免费播放| 韩国av一区二区| 中文字幕精品一区二区三区精品| 一本色道久久综合亚洲精品按摩| 午夜视频在线观看一区二区| 日韩欧美三级在线| 成人午夜激情片| 亚洲va国产天堂va久久en| 日韩一区二区三区视频在线观看| 国产精品影视在线观看| 国产精品传媒入口麻豆| 欧美日韩久久久一区| 精品亚洲成a人| 国产精品久久久久一区二区三区共| 色综合久久综合| 美女在线视频一区| 国产精品美女久久久久aⅴ| 欧美三级日韩三级| 激情六月婷婷久久| 亚洲欧美一区二区三区极速播放| 欧美三级在线看| 国产成人精品免费视频网站| 亚洲乱码国产乱码精品精98午夜| 欧美电影一区二区三区| 成人午夜视频免费看| 天涯成人国产亚洲精品一区av| 国产亚洲精品福利| 欧美亚洲综合久久| 丁香婷婷综合网| 婷婷激情综合网| 国产精品传媒视频| 欧美一级日韩不卡播放免费| 91网站在线观看视频| 卡一卡二国产精品 | 久久国产精品露脸对白| 亚洲欧洲三级电影| 欧美一级黄色大片| 一本色道亚洲精品aⅴ| 国产剧情一区在线| 午夜视黄欧洲亚洲| 1000精品久久久久久久久| 久久综合久久久久88| 欧美日本免费一区二区三区|