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

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

?? matrix.inl

?? BP人工神經網絡訓練源碼
?? INL
?? 第 1 頁 / 共 2 頁
字號:
// Matrix.inl: implementation of the CMatrix class.
// inline functions
// 朱桂斌
// 2001年3月6日
//////////////////////////////////////////////////////////////////////


// 構造函數

inline CMatrix::CMatrix (unsigned int row, unsigned int col)
{
	RowSiz = Row = row;
	ColSiz = Col = col;
	Val = new double* [row];
	for (unsigned int i=0; i < row; i++)
		Val[i] = new double [col];
}

// 拷貝構造函數

inline CMatrix::CMatrix (const CMatrix& m)
{
	RowSiz = Row = m.Row;
	ColSiz = Col = m.Col;
	
	Val = new double* [Row];
	unsigned int colsize = Col * sizeof(double);
	
	for (unsigned int i=0; i < Row; i++)
	{
		Val[i] = new double [Col];
		memcpy( Val[i], m.Val[i], colsize);
	}
}


// 析構函數

inline CMatrix::~CMatrix (void)
{
	for (unsigned int i=0; i < RowSiz; i++)
		delete [] Val[i];
	delete [] Val;
}


//  重新分配內存
inline void CMatrix::realloc (unsigned int row, unsigned int col)
{
	if (row == RowSiz && col == ColSiz)
	{
		Row = RowSiz;
		Col = ColSiz;
		return;
	}
	unsigned int i;
	double** Val1 = new double* [row];
	for (i=0; i < row; i++)
		Val1[i] = new double [col];
	
	unsigned int colSize = min(Col,col) * sizeof(double);
	unsigned int minRow = min(Row,row);
	
	for (i=0; i < minRow; i++)
		memcpy( Val1[i], Val[i], colSize);
	
	for (i=0; i < RowSiz; i++)
		delete [] Val[i];
	delete [] Val;
	
	RowSiz = Row = row;
	ColSiz = Col = col;
	Val = Val1;
	
	return;
}


//改變矩陣大小
inline void CMatrix::SetSize (unsigned int row, unsigned int col) 
{
	unsigned int i,j;
	unsigned int oldRow = Row;
	unsigned int oldCol = Col;
	
	if (row != RowSiz || col != ColSiz)
		realloc( row, col);
	
	if (row > oldRow)
		for (i=oldRow; i < row; i++)
			for (j=0; j < oldCol; j++)
				Val[i][j] = double(0);
			
			if (col > oldCol)
				for (i=0; i < row; i++)
					for (j=oldCol; j < col; j++)
						Val[i][j] = double(0);
					return;
}

// 下標操作符如(i,j)
inline double& CMatrix::operator () (unsigned int row, unsigned int col) 
{
	VERIFY(row < Row && col < Col);
	
	return Val[row][col];
}

// input stream function
/*inline istream& operator >> (istream& istrm, CMatrix& m)
{
	for (unsigned int i=0; i < m.Row; i++)
		for (unsigned int j=0; j < m.Col; j++)
			istrm >> m.Val[i][j];
		return istrm;
}

// output stream function
inline ostream& operator << (ostream &ostrm, CMatrix& m)
{
	for (unsigned int i=0; i < m.Row; i++)
	{
		for (unsigned int j=0; j < m.Col; j++)
			cout << m.Val[i][j] << '\t';
		cout << endl;
	}
	return ostrm;
}
*/

// 賦值操作符
inline CMatrix& CMatrix::operator = (const CMatrix& m) 
{
	if (Row != m.Row || Col != m.Col)
		realloc( m.Row,m.Col);
	
	unsigned int colbyte = m.Col * sizeof(double);
	
	for (unsigned int i=0; i < m.Row; i++)
		memcpy( Val[i], m.Val[i], colbyte);
	
	return *this;
}

// 拷貝內容,有可能擴大尺寸,但不縮小
inline CMatrix& CMatrix::CopyFrom(const CMatrix& m)
{
	if (Row < m.Row || Col < m.Col)
	{
		unsigned int newrow, newcol;
		newrow=max(Row,m.Row);
		newcol=max(Col,m.Col);
		realloc( newrow,newcol);
	}
	
	unsigned int colbyte = m.Col * sizeof(double);
	
	for (unsigned int i=0; i < m.Row; i++)
		memcpy( Val[i], m.Val[i], colbyte);
	
	return *this;
}

// 邏輯等于操作符
inline bool operator == (const CMatrix& m1, const CMatrix& m2) 
{
	bool retVal = false;
	
	if (m1.Row != m2.Row || m1.Col != m2.Col)
		return retVal;
	
	for (unsigned int i=0; i < m1.Row; i++)
		for (unsigned int j=0; j < m1.Col; i++)
			if (m1.Val[i][j] != m2.Val[i][j])
				return retVal;
			
			return true;
}

// 邏輯不等于操作符
inline bool operator != (const CMatrix& m1, const CMatrix& m2) 
{
    return (m1 == m2) ? false : true;
}


// 加、賦值結合操作
inline CMatrix& CMatrix::operator += (const CMatrix& m) 
{
	VERIFY(Row == m.Row && Col == m.Col);
	for (unsigned int i=0; i < m.Row; i++)
		for (unsigned int j=0; j < m.Col; j++)
			Val[i][j] += m.Val[i][j];
		return *this;
}


// 減、賦值結合操作
inline CMatrix& CMatrix::operator -= (const CMatrix& m) 
{
	
	VERIFY(Row == m.Row && Col == m.Col);
	
	for (unsigned int i=0; i < m.Row; i++)
		for (unsigned int j=0; j < m.Col; j++)
			Val[i][j] -= m.Val[i][j];
		return *this;
}

// 乘以標量并賦值
inline CMatrix& CMatrix::operator *= (const double& c) 
{
	for (unsigned int i=0; i < Row; i++)
		for (unsigned int j=0; j < Col; j++)
			Val[i][j] *= c;
		return *this;
}


// 乘以矩陣并賦值
inline CMatrix& CMatrix::operator *= (const CMatrix& m) 
{
	VERIFY(Col == m.Row);
	
	*this = *this * m;
	return *this;
}


// 除以標量并賦值
inline CMatrix& CMatrix::operator /= (const double& c) 
{
	for (unsigned int i=0; i < Row; i++)
		for (unsigned int j=0; j < Col; j++)
			Val[i][j] /= c;
		
		return *this;
}

// 乘方賦值
inline CMatrix& CMatrix::operator ^= (const unsigned int& pow) 
{
	for (unsigned int i=2; i <= pow; i++)
		*this = *this * *this;
	
	return *this;
}

// 取負運算
inline CMatrix CMatrix::operator - () 
{
	CMatrix temp(Row,Col);
	
	for (unsigned int i=0; i < Row; i++)
		for (unsigned int j=0; j < Col; j++)
			temp.Val[i][j] = - Val[i][j];
		
		return temp;
}

// 加運算
inline CMatrix operator + (const CMatrix& m1, const CMatrix& m2) 
{
	VERIFY(m1.Row == m2.Row || m1.Col == m2.Col);
	
	CMatrix temp(m1.Row,m1.Col);
	
	for (unsigned int i=0; i < m1.Row; i++)
		for (unsigned int j=0; j < m1.Col; j++)
			temp.Val[i][j] = m1.Val[i][j] + m2.Val[i][j];
		
		return temp;
}

// 減運算
inline CMatrix operator - (const CMatrix& m1, const CMatrix& m2) 
{
	VERIFY(m1.Row == m2.Row || m1.Col == m2.Col);
	
	CMatrix temp(m1.Row,m1.Col);
	
	for (unsigned int i=0; i < m1.Row; i++)
		for (unsigned int j=0; j < m1.Col; j++)
			temp.Val[i][j] = m1.Val[i][j] - m2.Val[i][j];
		
		return temp;
}


// 乘以標量
inline CMatrix operator * (const CMatrix& m, const double& no) 
{
	CMatrix temp(m.Row,m.Col);
	
	for (unsigned int i=0; i < m.Row; i++)
		for (unsigned int j=0; j < m.Col; j++)
			temp.Val[i][j] = no * m.Val[i][j];
		
		return temp;
}

//加標量
inline CMatrix operator + (const CMatrix& m, const double& no)
{
	CMatrix temp(m.Row,m.Col);
	
	for (unsigned int i=0; i < m.Row; i++)
		for (unsigned int j=0; j < m.Col; j++)
			temp.Val[i][j] = no + m.Val[i][j];
		
		return temp;
}

//標量減矩陣
inline CMatrix operator - (const double& no, const CMatrix& m)
{
	CMatrix temp(m.Row,m.Col);
	
	for (unsigned int i=0; i < m.Row; i++)
		for (unsigned int j=0; j < m.Col; j++)
			temp.Val[i][j] = no - m.Val[i][j];
		
		return temp;
	
}
// 相乘運算(multiplication)
inline  CMatrix operator * (const CMatrix& m1, const CMatrix& m2) 
{
	VERIFY(m1.Col == m2.Row);
	
	CMatrix temp(m1.Row,m2.Col);
	
	for (unsigned int i=0; i < m1.Row; i++)
		for (unsigned int j=0; j < m2.Col; j++)
		{
			temp.Val[i][j] = double(0);
			for (unsigned int k=0; k < m1.Col; k++)
				temp.Val[i][j] += m1.Val[i][k] * m2.Val[k][j];
		}
		return temp;
}

// 乘方(power)
inline CMatrix operator ^ (const CMatrix& m, const unsigned int& pow) 
{
	CMatrix temp(m);
	
	for (unsigned int i=2; i <= pow; i++)
		temp = temp * temp;
	
	return temp;
}


// 轉置運算(transpose)
inline CMatrix operator  ~ (const CMatrix& m) 
{
	CMatrix temp(m.Col,m.Row);
	
	for (unsigned int i=0; i < m.Row; i++)
		for (unsigned int j=0; j < m.Col; j++)
			temp.Val[j][i] = m.Val[i][j];
		
		return temp;
}


// 取逆運算(inversion)
inline CMatrix operator ! (CMatrix m) 
{
	unsigned int i,j,k;
	double a1,a2,*rowptr;
	
	VERIFY (m.Row == m.Col);
	
	CMatrix temp(m.Row,m.Col);
	
	temp.Unit();
	for (k=0; k < m.Row; k++)
	{
		int indx = m.pivot(k);
		VERIFY (indx != -1);
		
		if (indx != 0)
		{
			rowptr = temp.Val[k];
			temp.Val[k] = temp.Val[indx];
			temp.Val[indx] = rowptr;
		}
		a1 = m.Val[k][k];
		for (j=0; j < m.Row; j++)
		{
			m.Val[k][j] /= a1;
			temp.Val[k][j] /= a1;
		}
		for (i=0; i < m.Row; i++)
			if (i != k)
			{
				a2 = m.Val[i][k];
				for (j=0; j < m.Row; j++)
				{
					m.Val[i][j] -= a2 * m.Val[k][j];
					temp.Val[i][j] -= a2 * temp.Val[k][j];
				}
			}
	}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
经典三级一区二区| 国产精品成人免费| 亚洲综合精品久久| 国产99久久精品| 国产精品福利一区二区三区| 精品国产免费人成在线观看| 国产乱人伦偷精品视频免下载| 久久精品视频一区| 色妞www精品视频| 国产欧美精品一区| 色就色 综合激情| 在线视频观看一区| 国产精品66部| 成人av网站免费观看| 亚洲永久免费av| 亚洲国产一区二区在线播放| 欧美精品一区二区久久久| 精品国产一区二区三区久久久蜜月| 欧美成人一区二区| 91免费视频观看| 蜜臂av日日欢夜夜爽一区| 久久久91精品国产一区二区精品 | 国产精品久久久久四虎| 国产精品免费av| 欧美r级在线观看| 国产午夜精品一区二区| 亚洲一区二区三区四区不卡| 日韩二区三区四区| 亚洲激情五月婷婷| 国产日产欧美一区二区视频| 亚洲靠逼com| 激情综合五月天| 一本久久a久久精品亚洲| 欧美日韩大陆在线| 在线视频你懂得一区| 欧美草草影院在线视频| 国产精品久久久久久久久免费丝袜 | 一区二区三区国产| 亚洲国产成人自拍| 久久精品视频一区二区| 一区二区三区四区不卡视频| 免费久久99精品国产| 久久精品国产亚洲5555| 美女脱光内衣内裤视频久久网站 | 色成人在线视频| 欧美第一区第二区| 4hu四虎永久在线影院成人| 91高清在线观看| 久久一区二区三区国产精品| 26uuu色噜噜精品一区二区| 一区二区三区免费观看| 国产成人在线网站| 成人av网站免费| 日韩精品一区二区三区视频播放| 一区二区三区在线影院| 国产不卡视频一区二区三区| 日韩一区二区在线看| 精品黑人一区二区三区久久| 亚洲一区二区三区四区中文字幕| 福利一区福利二区| 日韩三级在线观看| 亚洲影视资源网| 一本高清dvd不卡在线观看| 久久精品一二三| 经典一区二区三区| 亚洲精品在线一区二区| 日韩av电影免费观看高清完整版| 在线看国产一区二区| 国产精品国产馆在线真实露脸| 国产一区二区在线影院| 不卡一区二区三区四区| 久久综合九色综合欧美亚洲| 日韩不卡在线观看日韩不卡视频| 欧美日韩综合在线| 久久久久久久综合| 一区二区三区四区视频精品免费| 成人短视频下载| 国产精品久久久久久久浪潮网站| 国产成人综合精品三级| 久久免费电影网| 成人一道本在线| 5566中文字幕一区二区电影| 亚洲成av人片一区二区三区| 九九九久久久精品| 欧美电影免费观看高清完整版在| 久久激情五月激情| 久久久99免费| 9人人澡人人爽人人精品| 日韩一区二区麻豆国产| 久久av资源站| 亚洲国产电影在线观看| 91免费国产在线| 亚洲午夜激情网站| 欧美精品v国产精品v日韩精品| 日韩毛片精品高清免费| 久久成人18免费观看| 国产亚洲欧美色| 91网站最新地址| 亚洲电影一区二区三区| 日韩欧美亚洲国产精品字幕久久久 | 天堂蜜桃91精品| 色综合视频一区二区三区高清| 一区二区日韩av| 精品国产伦一区二区三区观看方式 | 综合久久综合久久| 欧美一区永久视频免费观看| 一区二区三区波多野结衣在线观看 | 在线一区二区视频| 男女男精品网站| 亚洲欧洲韩国日本视频| 成人免费看视频| 亚洲一区二区成人在线观看| 欧美不卡123| 色八戒一区二区三区| 狠狠狠色丁香婷婷综合久久五月| 777xxx欧美| 夫妻av一区二区| 美女网站在线免费欧美精品| 亚洲图片另类小说| 精品国产免费久久| 欧美乱妇一区二区三区不卡视频| 国产美女一区二区| 午夜精品123| 555夜色666亚洲国产免| 成人激情午夜影院| 蜜桃av一区二区三区电影| 亚洲美女偷拍久久| 91国产福利在线| www.亚洲色图| 韩国av一区二区| 蜜臀精品一区二区三区在线观看| 亚洲色图制服诱惑 | 国产真实乱对白精彩久久| 亚洲宅男天堂在线观看无病毒 | eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 亚洲女女做受ⅹxx高潮| 久久亚洲精品国产精品紫薇| 欧美丰满高潮xxxx喷水动漫| 欧美伊人久久久久久久久影院| 日韩精品福利网| 亚洲精品第一国产综合野| 国产精品伦理在线| ww亚洲ww在线观看国产| 日韩午夜精品视频| 在线综合+亚洲+欧美中文字幕| 色综合网色综合| 裸体一区二区三区| 日本在线播放一区二区三区| 亚洲五码中文字幕| 亚洲一区二区三区影院| 亚洲欧美激情小说另类| 综合久久久久久| 亚洲欧美另类久久久精品| 亚洲美女淫视频| 亚洲国产成人av| 美女诱惑一区二区| 国产福利精品一区| 国产宾馆实践打屁股91| 成人免费视频网站在线观看| 成人黄色777网| 成人精品免费网站| 播五月开心婷婷综合| 91丨九色丨蝌蚪丨老版| 欧美在线观看视频一区二区三区 | 蜜桃av一区二区| 国产一区二区三区久久悠悠色av| 激情五月婷婷综合| 成人激情小说网站| 欧美中文字幕一区二区三区| 欧美日韩久久一区| 欧美电视剧在线观看完整版| 久久精品在线免费观看| 亚洲女同一区二区| 日韩成人一级片| 高清国产一区二区| 色拍拍在线精品视频8848| 91精品午夜视频| 国产精品久久午夜夜伦鲁鲁| 亚洲精品国产品国语在线app| 天天综合网天天综合色| 激情深爱一区二区| 99久久er热在这里只有精品66| 日韩影视精彩在线| 狠狠色狠狠色合久久伊人| 97久久精品人人做人人爽| 欧美精品一二三| 欧美激情综合网| 五月综合激情婷婷六月色窝| 国内精品视频一区二区三区八戒| 欧美日韩性生活| 欧美激情一区二区三区蜜桃视频| 亚洲激情图片qvod| 国产精品18久久久| 欧美日韩一级黄| 中文字幕va一区二区三区| 午夜久久久影院| hitomi一区二区三区精品| 欧美xxxxxxxx| 亚洲午夜久久久久久久久久久 | 91精品福利视频|