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

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

?? linearequation.inl

?? 主要是關(guān)于一些數(shù)值計(jì)算中所要用到的頭文件,希望對(duì)大家有所幫助
?? INL
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
//LinearEquation.inl		線性方程(組)求解函數(shù)(方法)定義
// Ver 1.0.0.0
// 版權(quán)所有(C) 何渝, 2002
// 最后修改: 2002.5.31

#ifndef _LINEAREQUATION_INL
#define _LINEAREQUATION_INL

//全選主元高斯消去法
template <class _Ty>
int LE_TotalChoiceGauss(matrix<_Ty>& a, valarray<_Ty>& b)  
{ 
	long double MaxValue, tmp;		//記錄主元絕對(duì)值
	int l(1), i, j, is;
    bool yn;
    
	int n = a.GetColNum();			//方程組階數(shù)
	
	valarray<int> js(n);			//保存換列位置
    
	for(int k = 0; k < n - 1; k++)	//全選主元
	{	
		MaxValue = 0.0;				//給保存主元絕對(duì)值變量賦初值
		        
		for(i = k; i < n; i++)
			for(j = k; j < n; j++)
            {		
				tmp = Abs(a(i, j));	//求m(i,j)絕對(duì)值
				if(tmp > MaxValue)	//發(fā)現(xiàn)一個(gè)更大的主元
				{ 
					MaxValue = tmp;	//保存新主元絕對(duì)值
					js[k] = j;		//新主元所在列
					is = i;			//新主元所在行
				}
            }
			
		yn = FloatEqual(MaxValue, 0);
        if(yn) l = 0;				//主元為0
		else
		{
			if(js[k] != k)			//換列
				for(i = 0; i < n; i++) swap(a(i, k), a(i, js[k]));
								
			if(is != k)				//換行
			{ 
				for (j = k; j < n; j++)	swap(a(k, j), a(is, j));

				swap(b[k], b[is]);	//方程組右邊第k元素與第is元素交換
			}
		}
        
		if(l == 0)					//矩陣奇異(主元為0)
		{
			printf("fail 1\n");
            return 0;				// 求解失敗,返回0值
		}
        
		MaxValue =  Abs(a(k, k));

        for(j = k + 1; j < n; j++)	a(k, j) /= a(k, k); //MaxValue;
        
		b[k] /= a(k, k); //MaxValue;
        for(i = k + 1; i < n; i++)
		{
			for(j = k + 1; j < n; j++)
			{
                a(i, j) = a(i, j) - a(i, k) * a(k, j);
			}
            
			b[i] = b[i] - a(i, k) * b[k];
		}
	}
    
	MaxValue = Abs(a((n - 1), (n - 1)));	//主元

	yn = FloatEqual(MaxValue, 0);
    if(yn)							//主元為0
	{
		cout<<"fail 2"<<endl;
        return(0);					//求解失敗,返回0值
	}

	b[n - 1] /= a((n - 1), (n - 1));//求解方程組右邊X的解

    for(i = n - 2; i >= 0; i--)		//回代過(guò)程
	{
		_Ty t = 0.0;
        
		for(j = i + 1; j < n; j++)	t = t + a(i, j) * b[j];
        
		b[i] = b[i] - t;
	}
    
	js[n - 1] = n - 1;				//X最后一個(gè)元素不用換
    for(k = n - 2; k >= 0; k --)	//k可以從n-2開(kāi)始
		if(js[k] != k)				//交換X的元素位置(由全選換列產(chǎn)生的)
			swap(b[k], b[js[k]]);
    
	return(1);						//方程組求解成功!
}

//全選主元高斯-約當(dāng)消去法
template <class _Ty>
int LE_TotalChoiceGaussJordan(matrix<_Ty> & a, matrix<_Ty> & b)
{ 
	long double MaxValue, tmp;	//主元絕對(duì)值
	int l(1), k, i, j, is;
	bool yn;
	
    int n = a.GetColNum();		//方程組階數(shù)
	int m = b.GetColNum();		//方程組右端常數(shù)向量的個(gè)數(shù)

	valarray<int> js(n);  
	for(k = 0; k < n; k++)
	{
		MaxValue = long double(0.0);
        
		for(i = k; i < n; i++)
			for(j = k; j < n; j++)
            {
				tmp = Abs( a(i, j) );
				if(tmp > MaxValue)
				{ 
					MaxValue = tmp;
					js[k] = j;
					is = i;
				}
            }
		
		yn = FloatEqual(MaxValue, 0);
		if(yn) l = 0; 		
		else
		{
			if(js[k] != k)
				for(i = 0; i < n; i++)
					swap(a(i, k), a(i, js[k]));
				
			if(is != k)
			{
				for(j = k; j < n; j++)
					swap(a(k, j), a(is, j));
				
				for(j = 0; j < m; j++)
					swap(b(k, j), b(is, j));

			}
		}

		if(l == 0)
		{
			cout<<"fail"<<endl;
			return 0;
		}
		
		for(j = k + 1; j < n; j++)
			a(k, j) /= a(k, k);

		for(j = 0; j < m; j++)
			b(k, j) /= a(k, k);				

		for(j = k + 1; j < n; j++)
			for(i = 0; i < n; i++)
				if(i != k)
					a(i, j) -= a(i, k) * a(k, j);

		for(j = 0; j < m; j++)
			for(i = 0; i< n; i++)
				if(i != k)
					b(i, j) -= a(i, k) * b(k, j);					
	}

    for(k = n - 1; k >= 0; k --)
	{
		if(js[k] != k)
			for(j = 0 ; j < m;  j++)
				swap(b(k, j), b(js[k], j));

	}
	return 1;				//成功返回
}

//求解三對(duì)角線方程組的追趕法
template <class _Ty>
int LE_TridiagonalEquationGauss(valarray<_Ty>& b, valarray<_Ty>& d)
{
	int j, k;
    _Ty s;
	bool yn;

    int n = d.size();	//方程組階數(shù)
	//m為n階三對(duì)角矩陣三條對(duì)角線上的元素個(gè)數(shù),也是一維數(shù)組b的長(zhǎng)度。
	//它的值應(yīng)為m=3n-2, 在本函數(shù)中要對(duì)此值作檢查
	int m = b.size();	

    if(m != (3 * n - 2))	//驗(yàn)證m是否等于3*n-2
	{
		cout << "Error!" << endl;
		return(-2);
	}
    
	for(k = 0; k < n - 1; k++)
	{
		j = 3 * k;
		s = b[j];

		yn = FloatEqual(s, 0.0);
		if(yn)						//主元為0
		{
			cout << "Fail!" << endl;
			return(0);
		}

        b[j + 1] = b[j + 1] / s;
        d[k] = d[k] / s;
        b[j + 3] = b[j + 3] - b[j + 2] * b[j + 1];
        d[k + 1] = d[k + 1] - b[j + 2] * d[k];
	}
    
	s = b[3 * n - 3];
    
	yn = FloatEqual(s, 0.0);
	if(yn)						//主元為0
	{
		cout << "Fail!" << endl;
		return(0);
	}
    
	d[n - 1] = d[n - 1] / s;
    
	for(k = n - 2; k >= 0; k--)
		d[k] = d[k] - b[3 * k + 1] * d[k + 1];
    
	return (2);	//運(yùn)算成功,正常返回
}

//一般帶型方程組的求解
template <class _Ty>
int LE_StrapEquationGauss(matrix<_Ty>& b, matrix<_Ty>& d, int l, int il)
{
	int ls, k, i, j, is, u, v, x, y, hh, xx, yy, xxx, yyy;
    _Ty p, t, tt;
	bool yn;
    
	int n = b.GetRowNum();		//矩陣b的行數(shù)
    int nn = b.GetColNum();
	int mm = d.GetColNum();		//方程組右邊常數(shù)向量的個(gè)數(shù)
	
    if(il != (2 * l + 1))		//參數(shù)中半帶寬l與帶寬il的關(guān)系不對(duì)
	{
		cout<<"fail 1"<<endl;
		return(-2);
	}
    
	ls = l;
    
	for(k = 0; k < n - 1; k++)
	{
		p = 0.0;

        for(i = k ; i <= ls; i++)
		{
			u = i * il;
			y = u % nn;  x = (u - y) / nn;
			t = Abs(b(x, y));
            if(t > p) 
			{ 
				p = t;
				is = i;
			}
		}
        
		if( FloatEqual(p, 0.0) )		
		{
			cout << "fail 2" << endl;
			return(0);
		}
        
		for(j = 0; j < mm; j++)
		{
			u = k * mm + j;
			v = is * mm + j;
			y = u % mm;
			x = (u - y) / mm;
			yy = v % mm;
			xx = (v - yy) / mm;
    		tt = d(x, y);
			d(x, y) = d(xx, yy);
			d(xx, yy) = tt;
        }
        
		for(j = 0; j < il; j++)
		{
			u = k * il + j; 
			v = is * il + j;
            y = u % nn;  
			x = (u - y) / nn;
			yy = v % nn; 
			xx = (v - yy) / nn;
    		tt = b(x, y);
			b(x, y) = b(xx, yy); 
			b(xx, yy) = tt;
		}

        for(j = 0; j < mm; j++)
		{
			u = k * mm + j; v = k * il;
			y = u % mm;  x = (u - y) / mm;
            yy = v % nn;  xx = (v - yy) / nn;
	
			d(x, y) = d(x, y) / b(xx, yy);
		}

        for(j = 1; j < il; j++)
		{
			u = k * il + j;
			v = k * il;
			y = u % nn;  x = (u - y) / nn;
			yy = v % nn;  xx = (v - yy) / nn;
			b(x, y) = b(x, y) / b(xx, yy);
		}
        
		for(i = k + 1; i <= ls; i++)
		{
            hh = i * il;
		    y = hh % nn;
			x = (hh - y) / nn;
			t = b(x, y);
            for(j = 0; j < mm; j++)
			{
				u = i * mm + j;
				v = k * mm + j;
				y = u % mm;
				x = (u - y) / mm;
				yy = v % mm;
				xx = (v - yy) / mm;    
                d(x, y) = d(x, y) - t * d(xx, yy);
			}
            
			for(j = 1; j < il; j++)
			{
				u=i * il  +j;
				v = k * il + j;
				y = u % nn;  
				x = (u - y) / nn;
				yy = v % nn; 
				xx = (v - yy) / nn;
                yyy = (u - 1) % nn;  xxx = (u - yyy - 1) / nn;
                b(xxx, yyy) = b(x, y) - t * b(xx, yy);
			}
            
			u = i * il + il - 1; 
			y = u % nn;  x = (u - y) / nn;
			
			b(x, y) = 0.0;
		}
        
		if(ls != (n - 1))	ls++;
	}
    
	u = (n - 1) * il; 
	y = u % nn;  
	x = (u - y) / nn;
	p = b(x, y);
    
	yn = FloatEqual(p, 0.0);
	if(yn)
	{
		cout<<"fail 3"<<endl;
		return(0);
	}
    
	for(j = 0; j < mm; j++)
	{
		u = (n - 1) * mm + j; 
		y = u % mm;  
		x = (u - y) / mm;
		d(x, y) = d(x, y) / p;
	}

    ls = 1;
    for(i = n  - 2; i >= 0; i--)
	{
		for(k = 0; k < mm; k++)
		{ 
			u = i * mm + k;
            for(j = 1; j <= ls; j++)
			{
				v = i * il +j;
				is = (i + j) * mm + k;
                y = u % mm;  
				x = (u - y) / mm;
				yy = v % nn;  
				xx = (v - yy) / nn;
                yyy = is % mm;  
				xxx = (is - yyy) / mm;
                d(x, y) = d(x, y) - b(xx, yy) * d(xxx, yyy);
			}
		}
        if(ls != (il - 1)) ls++;
	}
    
	return 2;	//運(yùn)算成功,正常返回
}

//求解對(duì)稱(chēng)方程組的分解法
template <class _Ty>
int LE_SymmetryEquation(matrix<_Ty>& a, matrix<_Ty>& c)
{
	int i, j, k, k1, k2, k3;
    _Ty p;
	bool yn;

	if(MatrixSymmetry(a)!=true)
		return (-1);			//方程組不對(duì)稱(chēng)
    
	int n = a.GetColNum();		//方程組階數(shù)
	int m = c.GetColNum();		//方程組右邊常數(shù)向量的個(gè)數(shù)
    
	yn = FloatEqual(a(0,0), 0.0);
	if(yn)						//主元為0
	{
		cout << "fail" << endl;
		return (-2);
	}

    for(i = 1; i < n; i++)
		a(i, 0) /= a(0, 0);

    for(i = 1; i < n - 1; i++)
	{
        for(j = 1; j <= i; j++)
            a(i, i) -= a(i, (j - 1)) * a(i, (j - 1)) * a((j - 1), (j - 1));
        
		p = a(i,i);
        yn = FloatEqual(p, 0.0);
		if(yn)						//主元為0
		{
			cout<<"fail"<<endl;
			return (-2);
		}
        
		for(k = i + 1; k < n; k++)
		{
            for(j = 1; j <= i; j++)
				a(k, i) -= a(k, (j - 1)) * a(i,(j - 1)) * a((j - 1), (j - 1));
            a(k, i) /= p;
		}
	}
    
	
    for(j = 1; j < n; j++)
	    a((n-1), (n-1)) -= a((n - 1), (j - 1)) * a((n - 1), (j - 1)) * a((j - 1), (j - 1));
    
	p=a((n - 1), (n - 1));
    yn = FloatEqual(p, 0.0);
	if(yn)						//主元為0
	{
		cout<<"fail"<<endl;
		return (-2);
	}
    
	for(j = 0; j < m; j++)
		for(i = 1; i < n; i++)
			for(k = 1; k <= i; k++)
				c(i, j) -= a(i, (k - 1)) * c((k - 1),j);
		
	for(i = 1; i < n; i++)
		for(j = i; j < n; j++)
            a((i - 1), j) = a((i - 1), (i - 1)) * a(j, (i - 1));
    
	for(j = 0; j < m; j++)  
    {
		c((n - 1), j) /= p;
		for(k = 1; k < n; k++)
		{
			k1 = n - k; 
			k3 = k1 - 1; 
            for(k2 = k1; k2 < n; k2++)
                c(k3, j) -= a(k3, k2) * c(k2, j);
			c(k3, j) /= a(k3, k3);
		}
	}
    
	return (1);	//運(yùn)算成功,正常返回
}

//求解對(duì)稱(chēng)正定方程組的平方根法
template <class _Ty>
int LE_SymmetryRegularEuationSquareRoot(matrix<_Ty> & a, matrix<_Ty> & d)
{
	int i, j, k;

	if(MatrixSymmetryRegular(a,1) != 2)	//判別矩陣a是否對(duì)稱(chēng)正定
		return(-1);						//矩陣a不對(duì)稱(chēng)正定
    
	int n = a.GetColNum();				//方程組階數(shù)
	int m = d.GetColNum();				//方程組右邊常數(shù)向量的個(gè)數(shù)
	
	a(0,0) = sqrt( a(0, 0) );

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品国产色综合久久久蜜香臀| 亚洲一区免费观看| 2020国产精品久久精品美国| 欧美精品一二三区| 91精品欧美一区二区三区综合在| 欧美三级三级三级| 欧美日韩在线观看一区二区| 欧美挠脚心视频网站| 欧美日韩激情一区二区| 在线电影欧美成精品| 欧美日本在线视频| 日韩久久免费av| 精品福利一区二区三区免费视频| 久久人人97超碰com| 久久久.com| 成人欧美一区二区三区白人| 亚洲你懂的在线视频| 亚洲一区二区三区四区五区黄 | 久久久久久99精品| 国产视频一区二区在线观看| 国产精品毛片高清在线完整版| 成人免费在线视频观看| 亚洲一区中文日韩| 蜜臀久久久久久久| 国产精品一区二区久久不卡| 成人av电影观看| 91黄色激情网站| 欧美一级片免费看| 久久久777精品电影网影网| 亚洲欧洲精品一区二区精品久久久| 亚洲裸体xxx| 日本一区中文字幕| 成人网页在线观看| 欧美影视一区在线| 欧美刺激午夜性久久久久久久| 国产亚洲欧美中文| 亚洲美女区一区| 蜜桃久久av一区| 97精品久久久久中文字幕| 欧美美女直播网站| 国产日韩欧美精品综合| 亚洲一区二区三区四区五区中文| 久久成人久久鬼色| 91女厕偷拍女厕偷拍高清| 777xxx欧美| 自拍偷拍亚洲综合| 日本成人在线一区| 91小宝寻花一区二区三区| 日韩一区二区三区四区 | 久久草av在线| 91国偷自产一区二区三区观看| 91精品国产91久久久久久一区二区| 国产欧美一区二区三区在线老狼| 亚洲大片免费看| 成人午夜免费视频| 欧美久久一二区| 国产精品短视频| 六月丁香综合在线视频| 91极品美女在线| 中文字幕欧美激情一区| 日韩电影在线免费看| 97久久精品人人爽人人爽蜜臀| 日韩视频一区在线观看| 亚洲欧美国产三级| 激情综合网av| 欧美午夜片在线观看| 国产精品国产三级国产aⅴ入口| 全部av―极品视觉盛宴亚洲| 色先锋aa成人| 国产丝袜欧美中文另类| 日本中文一区二区三区| 欧美专区日韩专区| 中文字幕一区二区视频| 激情国产一区二区| 欧美久久久久久久久中文字幕| 亚洲欧美日韩国产中文在线| 国产寡妇亲子伦一区二区| 欧美一区二区三区性视频| 依依成人精品视频| av在线免费不卡| 久久精品免视看| 久久99精品视频| 欧美一区二区视频在线观看2020| 亚洲精品日韩一| 91小视频在线| 亚洲三级在线免费观看| 高清视频一区二区| 国产女同性恋一区二区| 国产一区二区三区不卡在线观看| 91精品免费观看| 三级精品在线观看| 欧美视频一二三区| 亚洲永久精品国产| 色狠狠综合天天综合综合| 国产精品伦理在线| 99视频精品在线| 国产精品乱人伦中文| 北条麻妃一区二区三区| 国产午夜精品一区二区三区嫩草 | 蜜臀久久99精品久久久画质超高清| 欧美午夜精品一区二区蜜桃| 亚洲一区二区三区视频在线播放 | 国产精品久久久久久久久动漫| 经典三级一区二区| 2020国产精品自拍| 国产精品1024久久| 国产精品麻豆久久久| av一二三不卡影片| 亚洲人快播电影网| 在线观看视频一区二区 | 91久久精品一区二区| 一区二区三区国产精华| 欧美亚洲综合久久| 午夜精品一区二区三区电影天堂 | 宅男噜噜噜66一区二区66| 亚洲国产日韩在线一区模特 | 亚洲综合另类小说| 欧美三级蜜桃2在线观看| 亚洲v精品v日韩v欧美v专区| 欧美一区二区免费观在线| 老司机精品视频一区二区三区| 精品999久久久| 成人午夜电影久久影院| 亚洲欧洲在线观看av| 精品视频在线看| 久久国产欧美日韩精品| 国产精品免费观看视频| 欧洲在线/亚洲| 日韩精品久久久久久| 久久久精品综合| 91捆绑美女网站| 日韩av二区在线播放| 久久久天堂av| 日本电影欧美片| 美女免费视频一区二区| 国产精品色噜噜| 欧美另类高清zo欧美| 国产一区福利在线| 亚洲精品美腿丝袜| 欧美成人一级视频| 91丨porny丨户外露出| 亚洲国产一区二区三区| 26uuu国产日韩综合| 在线亚洲一区二区| 久久精品国产精品青草| 亚洲视频小说图片| 日韩欧美一级片| 91亚洲精品久久久蜜桃| 久久精品久久精品| 中文字幕欧美一区| 欧美va天堂va视频va在线| 不卡一区在线观看| 免费在线观看精品| 亚洲美女偷拍久久| 精品国产一区二区三区不卡| 91久久精品一区二区三区| 国产综合色在线视频区| 夜夜嗨av一区二区三区四季av| 欧美成人精品二区三区99精品| 99精品热视频| 激情久久久久久久久久久久久久久久| 亚洲男同性视频| 国产午夜精品久久久久久免费视| 欧美日韩在线免费视频| 成人免费毛片a| 精品一区二区三区视频 | 91视频免费播放| 经典三级在线一区| 亚洲3atv精品一区二区三区| 国产精品卡一卡二| 日韩精品中文字幕在线一区| 日本精品一级二级| 丰满亚洲少妇av| 青青草成人在线观看| 亚洲愉拍自拍另类高清精品| 亚洲国产精品精华液2区45| 日韩一区二区电影在线| 精品视频一区二区不卡| 欧美三级电影在线观看| 成人中文字幕电影| 久久国产精品露脸对白| 污片在线观看一区二区 | 91免费在线看| 国产69精品久久久久毛片| 蜜桃久久久久久久| 午夜一区二区三区视频| 亚洲欧美日韩在线不卡| 亚洲国产精品成人综合| 久久精品男人的天堂| 精品对白一区国产伦| 欧美一级在线视频| 欧美日韩免费在线视频| 色婷婷综合久色| 色综合一个色综合亚洲| 波多野结衣欧美| 成人国产一区二区三区精品| 国产高清无密码一区二区三区| 九一久久久久久| 久久精品国产精品亚洲综合| 麻豆精品视频在线观看视频|