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

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

?? nlequations.cs

?? 使用C#編輯的一些矩陣運算的源程序
?? CS
?? 第 1 頁 / 共 3 頁
字號:
/*
 * 求解非線性方程組的類 NLEquations
 * 
 * 周長發編制
 */

using System;

namespace CSharpAlgorithm.Algorithm
{
	/**
	 * 求解非線性方程組的類 NLEquations
	 *
	 * @author 周長發
	 * @version 1.0
	 */
	public abstract class NLEquations 
	{
		/**
		 * 虛函數:計算方程左端函數值,必須在引申類中覆蓋該類函數
		 * 
		 * @param x - 變量
		 * @return 函數值
		 */
		protected virtual double Func(double x)
		{
			return 0;
		}
	
		/**
		 * 虛函數:計算方程左端函數值,必須在引申類中覆蓋該類函數
		 * 
		 * @param x - 變量值數組
		 * @return 函數值
		 */
		protected virtual double Func(double[] x)
		{
			return 0;
		}


		/**
		 * 虛函數:計算方程左端函數值,必須在引申類中覆蓋該類函數
		 * 
		 * @param x - 變量
		 * @param y - 函數值數組
		 */
		protected virtual void Func(double x, double[] y)
		{
		}
	
		/**
		 * 虛函數:計算方程左端函數值,必須在引申類中覆蓋該類函數
		 * 
		 * @param x - 二元函數的變量
		 * @param y - 二元函數的變量
		 * @return 函數值
		 */
		protected virtual double Func(double x, double y)
		{
			return 0;
		}
	
		/**
		 * 虛函數:計算方程左端函數值,必須在引申類中覆蓋該類函數
		 * 
		 * @param x - 二元函數的變量值數組
		 * @param y - 二元函數的變量值數組
		 * @return 函數值
		 */
		protected virtual double Func(double[] x, double[] y)
		{
			return 0;
		}
	
		/**
		 * 虛函數:計算方程左端函數值,必須在引申類中覆蓋該類函數
		 * 
		 * @param x - 已知變量值數組
		 * @param p - 已知函數值數組
		 */
		protected virtual void FuncMJ(double[] x, double[] p)
		{
		}

		/**
		 * 基本構造函數
		 */
		public NLEquations()
		{
		}

		/**
		 * 求非線性方程實根的對分法
		 * 
		 * 調用時,須覆蓋計算方程左端函數f(x)值的虛函數
		 *        double Func(double x)
		 * 
		 * @param nNumRoots - 在[xStart, xEnd]內實根個數的預估值
		 * @param x - 一維數組,長度為m。返回在區間[xStart, xEnd]內搜索到的實根,
		 *            實根個數由函數值返回
		 * @param xStart - 求根區間的左端點
		 * @param xEnd - 求根區間的右端點
		 * @param dblStep - 搜索求根時采用的步長
		 * @param eps - 精度控制參數
		 * @return int 型,求得的實根的數目
		 */
		public int GetRootBisect(int nNumRoots, double[] x, double xStart, double xEnd, double dblStep, double eps)
		{
			int n,js;
			double z,y,z1,y1,z0,y0;
	
			// 根的個數清0
			n = 0; 
	
			// 從左端點開始搜索
			z = xStart; 
			y = Func(z);
	
			// 循環求解
			while ((z<=xEnd+dblStep/2.0)&&(n!=nNumRoots))
			{ 
				if (Math.Abs(y)<eps)
				{ 
					n=n+1; 
					x[n-1]=z;
					z=z+dblStep/2.0; 
					y=Func(z);
				}
				else
				{ 
					z1=z+dblStep; 
					y1=Func(z1);
	             
					if (Math.Abs(y1)<eps)
					{ 
						n=n+1; 
						x[n-1]=z1;
						z=z1+dblStep/2.0; 
						y=Func(z);
					}
					else if (y*y1>0.0)
					{ 
						y=y1; 
						z=z1;
					}
					else
					{ 
						js=0;
						while (js==0)
						{ 
							if (Math.Abs(z1-z)<eps)
							{ 
								n=n+1; 
								x[n-1]=(z1+z)/2.0;
								z=z1+dblStep/2.0; y=Func(z);
								js=1;
							}
							else
							{ 
								z0=(z1+z)/2.0; 
								y0=Func(z0);
								if (Math.Abs(y0)<eps)
								{ 
									x[n]=z0; 
									n=n+1; 
									js=1;
									z=z0+dblStep/2.0; 
									y=Func(z);
								}
								else if ((y*y0)<0.0)
								{ 
									z1=z0; 
									y1=y0;
								}
								else 
								{ 
									z=z0; 
									y=y0;
								}
							}
						}
					}
				}
			}
	     
			// 返回實根的數目
			return(n);
		}
	
		/**
		 * 求非線性方程一個實根的牛頓法
		 * 
		 * 調用時,須覆蓋計算方程左端函數f(x)及其一階導數f'(x)值的虛函數:
		 * 	void Func(double x, double[] y)
		 * 	y(0) 返回f(x)的值
		 * 	y(1) 返回f'(x)的值
		 * 
		 * @param x - 傳入迭代初值(猜測解),返回在區間求得的一個實根
		 * @param nMaxIt - 遞歸次數
		 * @param eps - 精度控制參數
		 * @return bool 型,求解是否成功
		 */
		public bool GetRootNewton(ref double x, int nMaxIt, double eps)
		{ 
			int l;
			double d,p,x0,x1=0.0;
			double[] y = new double[2];
	
			// 條件值
			l=nMaxIt; 
			x0=x;
			Func(x0,y);
	     
			// 求解,控制精度
			d=eps+1.0;
			while ((d>=eps)&&(l!=0))
			{ 
				if (y[1] == 0.0)
					return false;
	
				x1=x0-y[0]/y[1];
				Func(x1,y);
	         
				d=Math.Abs(x1-x0); 
				p=Math.Abs(y[0]);
				if (p>d) 
					d=p;
				x0=x1; 
				l=l-1;
			}
	     
			x = x1;
	
			return true;
		}
	
		/**
		 * 求非線性方程一個實根的埃特金迭代法
		 * 
		 * 調用時,須覆蓋計算方程左端函數f(x)值的虛函數
		 *       double Func(double x)
		 * 
		 * @param x - 傳入迭代初值(猜測解),返回在區間求得的一個實根
		 * @param nMaxIt - 遞歸次數
		 * @param eps - 精度控制參數
		 * @return bool 型,求解是否成功
		 */
		public bool GetRootAitken(ref double x, int nMaxIt, double eps)
		{ 
			int flag,l;
			double u,v,x0;
	
			// 求解條件
			l=0; 
			x0=x; 
			flag=0;
	
			// 迭代求解
			while ((flag==0)&&(l!=nMaxIt))
			{ 
				l=l+1; 
				u=Func(x0); 
				v=Func(u);
				if (Math.Abs(u-v)<eps) 
				{ 
					x0=v; 
					flag=1; 
				}
				else 
					x0=v-(v-u)*(v-u)/(v-2.0*u+x0);
			}
	     
			x = x0; 
	     
			// 是否在指定的迭代次數內達到求解精度
			return (nMaxIt > l);
		}
	
		/**
		 * 求非線性方程一個實根的連分式解法
		 * 
		 * 調用時,須覆蓋計算方程左端函數f(x)值的虛函數
		 *       double Func(double x)
		 * 
		 * @param x - 傳入迭代初值(猜測解),返回在區間求得的一個實根
		 * @param eps - 精度控制參數
		 * @return bool 型,求解是否成功
		 */
		public bool GetRootPq(ref double x, double eps)
		{ 
			int i,j,m,it=0,l;
			double z,h,x0,q;
			double[] a = new double[10];
			double[] y = new double[10];
	
			// 求解條件
			l=10; 
			q=1.0e+35; 
			x0=x; 
			h=0.0;
	     
			// 連分式求解
			while (l!=0)
			{ 
				l=l-1; 
				j=0; 
				it=l;
				while (j<=7)
				{ 
					if (j<=2) 
						z=x0+0.1*j;
					else 
						z=h;
	 			
					y[j]=Func(z);
					h=z;
					if (j==0) 
						a[0]=z;
					else
					{ 
						m=0; 
						i=0;
						while ((m==0)&&(i<=j-1))
						{ 
							if (Math.Abs(h-a[i])+1.0==1.0) 
								m=1;
							else 
								h=(y[j]-y[i])/(h-a[i]);
	                      
							i=i+1;
						}
						a[j]=h;
						if (m!=0) 
							a[j]=q;
						h=0.0;
						for (i=j-1; i>=0; i--)
						{ 
							if (Math.Abs(a[i+1]+h)+1.0==1.0) 
								h=q;
							else 
								h=-y[i]/(a[i+1]+h);
						}
	                  
						h=h+a[0];
					}
	              
					if (Math.Abs(y[j])>=eps) 
						j=j+1;
					else 
					{ 
						j=10; 
						l=0;
					}
				}
	         
				x0=h;
			}
	
			x = h;
	     
			// 是否在10階連分式內求的實根?
			return (10>it);
		}
	
		/**
		 * 求實系數代數方程全部根的QR方法
		 * 
		 * @param n - 多項式方程的次數
		 * @param dblCoef - 一維數組,長度為n+1,按降冪次序依次存放n次多項式方程的
		 *                  n+1個系數
		 * @param xr - 一維數組,長度為n,返回n個根的實部
		 * @param xi - 一維數組,長度為n,返回n個根的虛部
		 * @param nMaxIt - 迭代次數
		 * @param eps - 精度控制參數
		 * @return bool 型,求解是否成功
		 */
		public bool GetRootQr(int n, double[] dblCoef, double[] xr, double[] xi, int nMaxIt, double eps)
		{ 
			// 初始化矩陣
			Matrix mtxQ = new Matrix();
			mtxQ.Init(n, n);
			double[] q = mtxQ.GetData();
	
			// 構造赫申伯格矩陣
			for (int j=0; j<=n-1; j++)
				q[j]=-dblCoef[n-j-1]/dblCoef[n];
	
			for (int j=n; j<=n*n-1; j++)
				q[j]=0.0;
	
			for (int i=0; i<=n-2; i++)
				q[(i+1)*n+i]=1.0;
	
			// 求赫申伯格矩陣的特征值和特征向量,即為方程的解
			if (mtxQ.ComputeEvHBerg(xr, xi, nMaxIt, eps))
				return true;
	
			return false;
		}
	
		/**
		 * 求實系數代數方程全部根的牛頓下山法
		 * 
		 * @param n - 多項式方程的次數
		 * @param dblCoef - 一維數組,長度為n+1,按降冪次序依次存放n次多項式方程的
		 *                  n+1個系數
		 * @param xr - 一維數組,長度為n,返回n個根的實部
		 * @param xi - 一維數組,長度為n,返回n個根的虛部
		 * @return bool 型,求解是否成功
		 */
		public bool GetRootNewtonDownHill(int n, double[] dblCoef, double[] xr, double[] xi)
		{ 
			int m=0,i=0,jt=0,k=0,nis=0,it=0;
			double t=0,x=0,y=0,x1=0,y1=0,dx=0,dy=0,p=0,q=0,w=0,dd=0,dc=0,c=0;
			double g=0,u=0,v=0,pq=0,g1=0,u1=0,v1=0;
	     
			// 初始判斷
			m=n;
			while ((m>0)&&(Math.Abs(dblCoef[m])+1.0==1.0)) 
				m=m-1;
	
			// 求解失敗
			if (m<=0)
				return false;
	
			for (i=0; i<=m; i++)
				dblCoef[i]=dblCoef[i]/dblCoef[m];
	     
			for (i=0; i<=m/2; i++)
			{ 
				w=dblCoef[i]; 
				dblCoef[i]=dblCoef[m-i]; 
				dblCoef[m-i]=w;
			}
	     
			// 迭代求解
			k=m; 
			nis=0; 
			w=1.0;
			jt=1;
			while (jt==1)
			{ 
				pq=Math.Abs(dblCoef[k]);
				while (pq<1.0e-12)
				{ 
					xr[k-1]=0.0; 
					xi[k-1]=0.0; 
					k=k-1;
					if (k==1)
					{ 
						xr[0]=-dblCoef[1]*w/dblCoef[0]; 
						xi[0]=0.0;
	                 
						return true;
					}
	             
					pq=Math.Abs(dblCoef[k]);
				}
	 	
				q=Math.Log(pq); 
				q=q/(1.0*k); 
				q=Math.Exp(q);
				p=q; 
				w=w*p;
				for (i=1; i<=k; i++)
				{ 
					dblCoef[i]=dblCoef[i]/q; 
					q=q*p;
				}
	         
				x=0.0001; 
				x1=x; 
				y=0.2; 
				y1=y; 
				dx=1.0;
				g=1.0e+37;
	        
				while (true)
				{
					u=dblCoef[0]; v=0.0;
					for (i=1; i<=k; i++)
					{ 
						p=u*x1; 
						q=v*y1;
						pq=(u+v)*(x1+y1);
						u=p-q+dblCoef[i]; 
						v=pq-p-q;
					}
		         
					g1=u*u+v*v;
					if (g1>=g)
					{ 
						if (nis!=0)
						{ 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久亚洲私人国产精品va媚药| 成人国产精品免费观看视频| 美女网站一区二区| 精品午夜一区二区三区在线观看 | 色综合久久中文综合久久97| 欧洲国产伦久久久久久久| 日韩午夜激情视频| 国产精品传媒视频| 午夜精品一区二区三区三上悠亚| 麻豆视频一区二区| 成人av小说网| 91精品国产综合久久久蜜臀粉嫩| 国产区在线观看成人精品 | 欧美午夜精品电影| 久久综合九色综合97婷婷| 亚洲品质自拍视频| 久久精品国产精品亚洲综合| 99国产欧美久久久精品| 日韩视频在线永久播放| 亚洲欧美日韩一区| 国内精品免费在线观看| 91精品福利视频| 久久综合久久综合亚洲| 亚洲午夜久久久久中文字幕久| 韩国精品久久久| 色先锋aa成人| 国产亚洲成av人在线观看导航| 亚洲午夜精品久久久久久久久| 激情欧美一区二区| 欧美美女黄视频| 中文字幕一区av| 蜜桃av一区二区| 在线一区二区三区| 欧美国产禁国产网站cc| 蜜臀91精品一区二区三区| 一本色道久久综合亚洲精品按摩| 欧美大尺度电影在线| 亚洲国产精品影院| 97久久超碰精品国产| 久久亚洲精华国产精华液 | 欧美成人vps| 亚洲一区二区在线观看视频| 岛国精品在线观看| 精品国产一区久久| 天天操天天综合网| 色噜噜偷拍精品综合在线| 国产欧美视频在线观看| 久久se精品一区精品二区| 欧美日韩午夜影院| 一个色在线综合| 色视频成人在线观看免| 国产精品视频免费看| 狠狠色丁香久久婷婷综合_中| 欧美狂野另类xxxxoooo| 一区二区三区欧美日韩| 91一区二区三区在线观看| 国产情人综合久久777777| 国产一区二区剧情av在线| 日韩一区二区三区视频| 视频一区二区国产| 欧美日本一道本在线视频| 一区二区免费看| 91热门视频在线观看| 国产精品国产自产拍高清av| 国产91精品久久久久久久网曝门 | 国产很黄免费观看久久| 精品免费99久久| 久久精品国产77777蜜臀| 欧美一二三在线| 奇米777欧美一区二区| 678五月天丁香亚洲综合网| 三级一区在线视频先锋| 欧美人xxxx| 日本三级韩国三级欧美三级| 91精品国产色综合久久不卡电影| 亚洲成人午夜电影| 91精品国产综合久久福利软件| 日韩影视精彩在线| 欧美一级夜夜爽| 男人的天堂亚洲一区| 欧美成人女星排行榜| 韩国视频一区二区| 欧美极品美女视频| 91免费版在线| 亚洲成人高清在线| 日韩一卡二卡三卡四卡| 久久成人精品无人区| 久久精品一区四区| a亚洲天堂av| 亚洲夂夂婷婷色拍ww47| 51精品视频一区二区三区| 日本一道高清亚洲日美韩| 欧美mv日韩mv| 高清不卡一二三区| 亚洲另类在线视频| 678五月天丁香亚洲综合网| 九色综合国产一区二区三区| 国产偷国产偷精品高清尤物| a美女胸又www黄视频久久| 亚洲国产美女搞黄色| 欧美一区二区三区在线电影| 国内外成人在线| 亚洲天堂久久久久久久| 欧美年轻男男videosbes| 久久国产精品72免费观看| 国产精品私人自拍| 欧美在线观看视频在线| 久久精品国产第一区二区三区| 国产视频一区二区在线| 99精品视频在线观看免费| 亚洲成av人片一区二区三区| 26uuu亚洲综合色欧美| 99视频一区二区三区| 日韩高清一区二区| 国产精品成人免费| 777色狠狠一区二区三区| 盗摄精品av一区二区三区| 性感美女久久精品| 国产农村妇女精品| 欧美乱妇一区二区三区不卡视频| 国产一区999| 亚洲一二三四在线| 久久新电视剧免费观看| 色94色欧美sute亚洲13| 国产真实乱子伦精品视频| 亚洲免费电影在线| 日韩欧美在线一区二区三区| caoporn国产精品| 蜜臀av性久久久久蜜臀av麻豆| 亚洲欧美综合色| 欧美一区二区三区免费大片| 99综合影院在线| 精品一区二区av| 亚洲五码中文字幕| 国产精品私人自拍| 欧美va亚洲va| 欧美日韩中字一区| 成人精品视频一区二区三区 | 久久婷婷国产综合国色天香| 在线视频一区二区三| 国产成人av资源| 免费看精品久久片| 亚洲激情欧美激情| 亚洲国产精品黑人久久久| 日韩精品一区二区三区视频播放| 色婷婷综合久久久久中文一区二区 | 99久久综合狠狠综合久久| 久久精品国产99国产精品| 亚洲图片自拍偷拍| 国产精品剧情在线亚洲| 2欧美一区二区三区在线观看视频| 欧美日韩国产免费| 色婷婷综合视频在线观看| 成人一区二区视频| 激情图片小说一区| 久久激情综合网| 三级欧美韩日大片在线看| 亚洲综合久久av| 亚洲日本va在线观看| 国产精品美女久久久久aⅴ| 欧美精品一区视频| 日韩亚洲欧美成人一区| 欧美日韩精品电影| 欧美性一二三区| 在线亚洲+欧美+日本专区| 波波电影院一区二区三区| 国产成人啪午夜精品网站男同| 久久99精品一区二区三区| 日本免费新一区视频| 亚洲va国产天堂va久久en| 亚洲国产一区二区三区青草影视| 亚洲婷婷在线视频| 亚洲欧美日韩国产成人精品影院 | 在线欧美一区二区| 一本大道久久a久久综合婷婷| 99视频在线精品| 91在线观看成人| 91小视频在线免费看| 91在线免费视频观看| 色欲综合视频天天天| 色久优优欧美色久优优| 91久久精品网| 欧美日韩精品一二三区| 欧美日韩精品欧美日韩精品| 欧美三级视频在线观看| 欧美日韩综合在线| 8v天堂国产在线一区二区| 日韩色在线观看| 精品国产三级a在线观看| 精品福利一二区| 久久精品夜色噜噜亚洲a∨| 国产亚洲短视频| 亚洲天堂av老司机| 一区二区三区四区激情| 亚洲福利一二三区| 日韩va欧美va亚洲va久久| 久久99最新地址| 国产成人a级片| 日本高清不卡视频| 欧美精品欧美精品系列|