亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
国产成人精品网址| 久久色在线观看| 日日骚欧美日韩| 欧美丰满高潮xxxx喷水动漫| 热久久一区二区| 久久影院视频免费| 成人午夜精品一区二区三区| 中文字幕日韩欧美一区二区三区| 91在线观看视频| 亚洲最新在线观看| 欧美一级高清片在线观看| 国产原创一区二区| 成人欧美一区二区三区白人| 欧美三级中文字| 美女视频一区二区| 国产精品视频你懂的| 欧美性xxxxxx少妇| 久久成人免费网| 中文字幕日本不卡| 欧美日韩夫妻久久| 国产精品综合在线视频| 亚洲三级免费电影| 欧美一级夜夜爽| 成人av影院在线| 日韩在线观看一区二区| 欧美高清在线精品一区| 欧美日韩国产成人在线91| 国产精品综合一区二区三区| 一区二区在线看| 日韩午夜在线播放| 99视频国产精品| 奇米影视一区二区三区| 国产精品护士白丝一区av| 7777精品伊人久久久大香线蕉完整版| 久久黄色级2电影| 亚洲视频免费观看| 日韩欧美不卡在线观看视频| 91在线国产福利| 麻豆成人在线观看| 亚洲欧美日韩在线不卡| 日韩精品在线一区| 色哟哟欧美精品| 九九视频精品免费| 亚洲男人的天堂网| 日韩美女视频在线| 一本一道久久a久久精品综合蜜臀| 蜜桃传媒麻豆第一区在线观看| 国产精品情趣视频| 日韩美女一区二区三区| 91成人国产精品| 国产黄色成人av| 婷婷亚洲久悠悠色悠在线播放| 国产色综合一区| 91精品国产91久久综合桃花| aaa欧美色吧激情视频| 激情综合网激情| 亚洲成a人v欧美综合天堂| 国产精品久久影院| 亚洲精品一区在线观看| 欧美日本一区二区三区四区| 成人国产精品视频| 国产在线播放一区| 三级一区在线视频先锋 | 美腿丝袜亚洲色图| 一区二区三区自拍| 欧美国产欧美综合| 欧美成人在线直播| 欧美二区在线观看| 在线观看一区二区视频| 成人福利视频在线| 韩国女主播成人在线| 午夜精品久久久久久久蜜桃app| 亚洲欧洲日本在线| 国产亚洲美州欧州综合国| 日韩欧美一级二级三级| 欧美亚洲另类激情小说| 99久久精品免费| 成人午夜碰碰视频| 国产成人在线看| 国模少妇一区二区三区| 裸体健美xxxx欧美裸体表演| 天天综合网天天综合色 | 亚洲男人电影天堂| 国产精品成人一区二区艾草| 国产日韩欧美电影| www成人在线观看| 精品国产一区二区三区不卡 | 久久久精品天堂| 精品人伦一区二区色婷婷| 欧美一级免费大片| 欧美性视频一区二区三区| 91黄色免费版| 91精品福利在线| 色哟哟欧美精品| 色婷婷一区二区三区四区| 91丨porny丨蝌蚪视频| 91丨九色porny丨蝌蚪| fc2成人免费人成在线观看播放| 福利91精品一区二区三区| 国产精品66部| 国产精品1区2区| 国产精品 欧美精品| 国产成人av电影免费在线观看| 国产精选一区二区三区| 国产999精品久久久久久| 国产成人精品影院| hitomi一区二区三区精品| 99re成人精品视频| 一本在线高清不卡dvd| 91久久精品网| 欧美视频在线一区二区三区 | 成+人+亚洲+综合天堂| 岛国一区二区三区| 99久久99精品久久久久久 | 精品99久久久久久| 久久夜色精品一区| 国产欧美日韩在线| 国产精品高清亚洲| 一区二区三区影院| 亚瑟在线精品视频| 久久精品久久久精品美女| 精品一区二区三区免费观看 | 欧美国产一区二区在线观看| 中文字幕乱码亚洲精品一区| 国产精品久久久久久久久图文区 | 韩国中文字幕2020精品| 国产一本一道久久香蕉| www.亚洲免费av| 色吧成人激情小说| 欧美精品一二三| 久久久久久久久一| 国产精品久久久久久久久免费樱桃 | 国产一区二区久久| av动漫一区二区| 欧美午夜不卡在线观看免费| 91精品国模一区二区三区| 2021国产精品久久精品| 中文字幕va一区二区三区| 一区二区三区在线免费播放| 日韩精品一二三| 国产91精品久久久久久久网曝门| 91麻豆免费看片| 欧美一区二区私人影院日本| 久久婷婷综合激情| 亚洲欧美日韩人成在线播放| 偷拍自拍另类欧美| 国产丶欧美丶日本不卡视频| 在线亚洲高清视频| 欧美v国产在线一区二区三区| 国产精品无人区| 亚洲午夜激情网站| 国产综合色产在线精品| 97久久精品人人做人人爽| 91精品国产91久久综合桃花| 欧美韩国日本一区| 视频一区二区欧美| 成人黄色电影在线| 欧美一区二区三区小说| 国产女人aaa级久久久级 | 蜜臀av亚洲一区中文字幕| 成人深夜福利app| 制服.丝袜.亚洲.中文.综合| 中文字幕欧美国产| 日韩成人精品在线观看| 99久久久久久| 日韩一卡二卡三卡国产欧美| 综合久久久久综合| 激情综合色播五月| 欧美亚洲综合色| 国产三级一区二区三区| 亚洲成人手机在线| 国产成人免费av在线| 欧美蜜桃一区二区三区| 中文字幕乱码一区二区免费| 日本欧美在线看| 91在线视频观看| 久久伊人蜜桃av一区二区| 亚洲成人免费在线观看| www..com久久爱| 欧美不卡一区二区三区| 亚洲色图.com| 国产成人精品亚洲777人妖| 欧美一区二区免费| 亚洲精品日韩综合观看成人91| 国产一本一道久久香蕉| 欧美精品高清视频| 亚洲精品老司机| 高清不卡在线观看av| 日韩一二在线观看| 亚洲成人av一区| 91视频观看视频| 欧美经典一区二区| 捆绑紧缚一区二区三区视频| 欧美手机在线视频| 亚洲人吸女人奶水| 国产91在线看| 久久综合中文字幕| 男人操女人的视频在线观看欧美| 在线观看免费一区| 国产精品国产精品国产专区不片|