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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? nonlinearequation.inl

?? 通過此程序能夠得到非線性方程組的數(shù)值解
?? INL
?? 第 1 頁 / 共 2 頁
字號:
//NonLinearEquation.inl 	非線性方程(組)求解函數(shù)(方法)定義
// Ver 1.0.0.0
// 版權(quán)所有(C) 何渝, 2002
// 最后修改: 2002.5.31.

#ifndef _NONLINEAREQUATION_INL
#define _NONLINEAREQUATION_INL

//用二分法搜索方程f(x)=0在區(qū)間[a,b]內(nèi)的全部實根
template <class _Ty>
inline size_t 
RootHalves(_Ty a, _Ty b, _Ty step, _Ty eps, valarray<_Ty>& x, size_t m)
{
    int n(0), js;
    _Ty z=a, z1, y, y1, z0, y0;
   
	y = FunctionValueRH(z);
    while((z<=b+step/2.0)&&(n!=m))
	{ 
	  if(Abs(y) < eps)
      {
		n = n + 1;
		x[n-1] = z;
		z = z + step / 2.0;
		y=FunctionValueRH(z);
      }
      else
      {
		z1=z+step;
		y1=FunctionValueRH(z1);
        if(Abs(y1)<eps)
        {
			n=n+1;
			x[n-1]=z1;
            z=z1+step/2.0;
			y=FunctionValueRH(z);
        }
        else
			if(y*y1>0.0)
            {
				y=y1;
				z=z1;
			}
            else
            {
				js=0;
                while(js==0)
                {
					if(Abs(z1-z)<eps)
                    {
						n=n+1;
						x[n-1]=(z1+z)/2.0;
                        z=z1+step/2.0;
						y=FunctionValueRH(z);
                        js=1;
                    }
                    else
                    {
						z0=(z1+z)/2.0;
						y0=FunctionValueRH(z0);
                        if(Abs(y0)<eps)
                        {
							x[n]=z0; n=n+1; js=1;
                            z=z0+step/2.0;
							y=FunctionValueRH(z);
                        }
                        else
							if((y*y0) < 0.0)
							{
								z1 = z0;
								y1 = y0;
							}
							else
							{
								z = z0;
								y = y0;
							}
                      }
                  }
              }
          }
	}
    return(n);	//返回搜索到的實根個數(shù)
}

//牛頓(Newton)法求解非線性方程一個實根
template <class _Ty>
inline int 
RootNewton( _Ty& x, _Ty eps, size_t js)
{ 
    int k = 1, r = js;
    _Ty  x1;
	_Ty x0 = x;
	valarray<_Ty> y(2);

    FunctionValueRN(x0, y);
    _Ty d=eps + 1.0;
    while((d > eps || FloatEqual(d, eps))&&(r != 0))
    {
		if(FloatEqual(y[1],0))	return(-1);
        x1 = x0 - y[0] / y[1];
        FunctionValueRN(x1,y);
        d=Abs(x1 - x0);
		_Ty p=Abs(y[0]);
        if(p > d) d = p;
        x0 = x1;
		r -= 1;
    }
    x = x1;
    k = js - r;
    return(k);
}

//埃特金(Aitken)法求解非線性方程一個實根
template <class _Ty>
inline int 
RootAitken( _Ty& x, _Ty eps, size_t js)
{
    _Ty u, v, x0;
    int r(0), flag(0);

	x0 = x;

    while((flag == 0) && (r != js))
    {	
		r++; 
        u = FunctionValueRA(x0);
		v = FunctionValueRA(u);
        if(Abs(u-v)<eps)
		{
			x0 = v;
			flag = 1;
		}
        else x0=v-(v-u)*(v-u)/(v-2.0*u+x0);
    }
    x = x0;
	r = js - r;
    return(r);
}

//連分式(Fraction)法求解非線性方程一個實根
template <class _Ty>
inline int 
RootFraction(_Ty& x, _Ty eps)
{
	int r(10), i, j, m, it;
    _Ty x0, q(1.0e+35), h(0), z;
	valarray<_Ty> a(10), y(10);
	
	x0 = x; 

    while(r!=0)
    { 
		r = r - 1; 
		j = 0; 
		it = r;
        while(j<=7)
        {
			if(j<=2)
				z = x0 + 0.1 * j;
            else
				z = h;
            y[j] = FunctionValueRF(z);
            h = z;
            if(j==0)
				a[0] = z;
            else
            {
				m = 0;
				i = 0;
                while((m==0)&&(i<j))
                {
					if(FloatEqual((h-a[i]),0))
						m = 1;
                    else
						h=(y[j]-y[i])/(h-a[i]);
                    i++;
                }
                a[j] = h;
                if(m!=0) a[j]=q;
                h=0.0;
                for(i=j-1; i>=0; i--)
                {
					if(FloatEqual((a[i+1]+h),0))
						h = q;
                    else
						h=-y[i]/(a[i+1]+h);
                }
                h = h + a[0];
            }
            if(Abs(y[j])>=eps) j++;
            else 
			{
				j = 10;
				r = 0;
			}
        }
        x0 = h;
    }
    x = h;
    return(10-it);
}

//QR法求代數(shù)方程全部根
template <class _Ty, class _Tz>
inline int 
RootQR(valarray<_Ty>& a, valarray<_Tz>& x, _Ty eps, size_t jt)
{
	int i, j, n;

    n = x.size();			//多項式方程的次數(shù)

	matrix<_Ty> q(n, n);

    for(j=0; j<n; j++)
		q(0,j) = -a[n-j-1] / a[n];

    for(j=1; j<n; j++)
		for(i=0; i<n; i++)
			q(j,i) = 0;

	for(i=0; i<n-1; i++)
      q(i+1, i) = 1;
	
	i = EigenvalueVectorHessenbergQR(q,x,eps,jt);	//求全部特征值的QR方法
    
	return(i);
}

//牛頓下山(NewtonHillDown)法求解實系數(shù)代數(shù)方程全部根(實根和復(fù)根)
template <class _Ty, class _Tz>
inline int 
RootNewtonHillDown(valarray<_Ty>& a, valarray<_Tz>& cx)
{
	int m, i, jt, k, is, it, n;
    _Ty t, x, y, x1, y1, dx, dy, dd, dc, c, g, g1;
	_Ty w, u, p, q, pq, v, u1, v1;
  
    n = cx.size();			//多項式方程的次數(shù)
    m = n;

    while((m > 0) && (FloatEqual(a[m], 0.0))) m--;

    if(m <= 0) return(-1);
    
	for(i = 0; i <= m; i++) a[i] /= a[m];

    for(i = 0; i <= m / 2; i++)
    {
		w = a[i];
		a[i] = a[m - i];
		a[m - i] = w;
	}

    k = m;
	is = 0;
	w = 1.0;
    jt = 1;
    while(jt == 1)
    {
		pq = Abs(a[k]);
		while(pq < LONGDOUBLEERROR)
        {
			cx[k - 1] = complex<_Ty>(0.0, 0.0);
			k = k - 1;
            if(k == 1)
            {
				cx[0] = complex<_Ty>(-a[1] * w / a[0], 0.0);
                return(1);
            }
            pq = Abs(a[k]);
        }
		q = log(pq);
		q = q / (1.0 * k);
		q = exp(q);
        p = q;
		w = w * p;
        for(i = 1; i <= k; i++)
        {
			a[i] /= q;
			q *= p;
		}
        x = 0.0001;
		x1 = x; 
		y = 0.2;
		y1 = y; 
		dx = 1.0;
        g = 1.0e+37; 
 
zjn:    u = a[0];
		v = 0.0;
        for(i = 1; i <= k; i++)
        { 
			p = u * x1;
			q = v * y1;
            pq = (u + v) * (x1 + y1);
            u = p - q + a[i];
			v = pq - p - q;
        }
        g1 = u * u + v * v;

        if(g1 >= g)
        { 
			if(is != 0)
			{ 
				it = 1;
				g65(x, y, x1, y1, dx, dy, dd, dc, c, k, is, it);
				if(it == 0)
					goto zjn;
			}
			else
			{
				g60(t, x, y, x1, y1, dx, dy, p, q, k, it);
				if(t >= 1.0e-03)  goto zjn;
				if(g > 1.0e-18)
				{
					it = 0;
					g65(x, y, x1, y1, dx, dy, dd, dc, c, k, is, it);
					if(it == 0) goto zjn;
				}

			}
			g90(cx , a, x, y, p, q, w, k);
        }
        else
        {
			g = g1;
			x = x1;
			y = y1;
			is = 0;
            if(g <= 1.0e-22)	
				g90(cx, a, x, y, p, q, w, k);
            else
            {
				u1 = k * a[0]; 
				v1 = 0.0;
                for(i = 2; i <= k; i++)
                {
					p = u1 * x;
					q = v1 * y;
					pq = (u1 + v1) * (x + y);
                    u1 = p - q + (k - i + 1) * a[i - 1];
                    v1 = pq - p - q;
                }
                p = u1 * u1 + v1 * v1;
                if(p <= 1.0e-20)
                {
					it = 0;
                    g65(x, y, x1, y1, dx, dy, dd, dc, c, k, is, it);
                    if(it == 0)	goto zjn;
                    g90(cx, a, x, y, p, q, w, k);
                }
                else
                {
					dx = (u * u1 + v * v1) / p;
                    dy = (u1 * v - v1 * u) / p;
                    t = 1.0 + 4.0 / k;
                    g60(t, x, y, x1, y1, dx, dy, p, q, k, it);
                    if(t >= 1.0e-03) goto zjn;
                    if(g > 1.0e-18)
                    {
						it = 0;
                        g65(x, y, x1, y1, dx, dy, dd, dc, c, k, is, it);
                        if(it == 0) goto zjn;
                    }
                    g90(cx, a, x, y, p, q, w, k);
                }
            }
        }

        if(k == 1) jt = 0;
        else jt = 1;
    }
    return(1);
}

//牛頓下山(NewtonHillDown)法求解復(fù)系數(shù)代數(shù)方程全部根(實根和復(fù)根)
//重載RootNewtonHillDown()
template <class _Ty>
inline int 
RootNewtonHillDown(complex<_Ty> a[], valarray<complex<_Ty> >& cx)
{
	int m, i, jt, k, is, it, n;
    _Ty t, x, y, x1, y1, dx, dy, dd, dc, c, g, g1, mo, sb, xb;
	_Ty w, u, p, q, pq, v, u1, v1;
    
	n = cx.size();			//多項式方程的次數(shù)
    m = n;
	
    while((m > 0) && (FloatEqual(Abs(a[m]), 0))) m--;

    if(m <= 0) return(-1);

    mo = Abs(a[m]);

	for(i = 0; i <= m; i++) a[i] /= mo;

    for(i = 0; i <= m / 2; i++)
    {
		swap(a[i], a[m-i]);		
	}

    k = m;
	is = 0;
	w = 1.0;
    jt = 1;
    while(jt == 1)
    {
		pq = Abs(a[k]);
		while(pq < LONGDOUBLEERROR)
        {
			cx[k - 1] = complex<_Ty>(0.0, 0.0);
			k--;
            if(k == 1)
            {
				mo = a[0].real() * a[0].real() + a[0].imag() * a[0].imag();
				sb = -w * (a[0].real() * a[1].real() + a[0].imag() * a[1].imag()) / mo;
				xb =  w * (a[1].real() * a[0].real() - a[0].imag() * a[1].imag()) / mo;
				cx[0] = complex<_Ty>(sb, xb);
                return(1); 
            }
			pq = Abs(a[k]);
        }

		q = log(pq);
		q = q / (1.0 * k);
		q = exp(q);
        p = q;
		w = w * p;
        
		for(i = 1; i <= k; i++)
        {
			a[i] /= q;
			q *= p;
		}
        
		x = 0.0001;
		x1 = x; 
		y = 0.2;
		y1 = y; 
		dx = 1.0;
        g = 1.0e+37; 
 
zjn:   
		u = a[0].real();
		v = a[0].imag();
        
		for(i = 1; i <= k; i ++)
        { 
			p = u * x1;
			q = v * y1;
            pq = (u + v) * (x1 + y1);
            u = p - q + a[i].real();
			v = pq - p - q + a[i].imag();
        }
        g1 = u * u + v * v;

        if(g1 >= g)
        { 
			if(is != 0)
			{ 
				it = 1;
				g65(x, y, x1, y1, dx, dy, dd, dc, c, k, is, it);
				if(it == 0)
					goto zjn;
			}
			else
			{
				gg60(t, x, y, x1, y1, dx, dy, p, q, k, it);
				if(t >= 1.0e-03)  goto zjn;
				if(g > 1.0e-18)
				{
					it = 0;
					g65(x, y, x1, y1, dx, dy, dd, dc, c, k, is, it);
					if(it == 0) goto zjn;
				}
			}

			gg90(cx, a, x, y, p, q, w, k);
        }
        else
        {
			g = g1;
			x = x1;
			y = y1;
			is = 0;

            if(g <= 1.0e-22)	
				gg90(cx, a, x, y, p, q, w, k);
            else
            {
				u1 = k * a[0].real(); 
				v1 = a[0].imag();
                for(i = 2; i <= k; i++)
                {
					p = u1 * x;
					q = v1 * y;
					pq = (u1 + v1) * (x + y);
                    u1 = p - q + (k - i + 1) * a[i - 1].real();
                    v1 = pq - p - q + (k - i + 1) * a[i - 1].imag();
                }
                p = u1 * u1 + v1 * v1;
                if(p <= 1.0e-20)
                {
					it = 0;
                    g65(x, y, x1, y1, dx, dy, dd, dc, c, k, is, it);
                    if(it == 0)	goto zjn;
                    gg90(cx, a, x, y, p, q, w, k);
                }
                else
                {
					dx = (u * u1 + v * v1) / p;
                    dy = (u1 * v - v1 * u) / p;
                    t = 1.0 + 4.0 / k;
                    gg60(t, x, y, x1, y1, dx, dy, p, q, k, it);
                    if(t >= 1.0e-03) goto zjn;
                    if(g > 1.0e-18)

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美精品三级| 日韩一区二区三区免费看 | 欧美主播一区二区三区| 天天综合日日夜夜精品| 成人免费在线观看入口| 久久久久久久久久久电影| 欧美日本在线一区| 91浏览器打开| 99视频精品全部免费在线| 国产一区二区久久| 久久国产精品一区二区| 日韩av在线免费观看不卡| 亚洲国产成人精品视频| 亚洲影院久久精品| 亚洲国产你懂的| 同产精品九九九| 亚洲一区二区三区四区在线观看 | 9i在线看片成人免费| 久久99精品一区二区三区三区| 亚洲乱码一区二区三区在线观看| 亚洲色图在线看| 亚洲精品高清在线| 亚洲一区二区美女| 香蕉成人伊视频在线观看| 亚洲一区二区三区爽爽爽爽爽 | 欧美变态tickle挠乳网站| 91精品国产综合久久久久久久| 欧美日韩亚洲综合在线 | 国产日韩精品久久久| 亚洲人成亚洲人成在线观看图片| 亚洲裸体xxx| 免费观看30秒视频久久| 国产成人精品免费视频网站| 成人一区二区三区视频| 欧美少妇bbb| 久久精品亚洲精品国产欧美kt∨ | 欧美丝袜丝交足nylons| 日韩免费在线观看| 亚洲欧洲日韩一区二区三区| 午夜精品一区二区三区免费视频| 久久精品国产精品亚洲红杏| 91色porny蝌蚪| 久久综合色8888| 亚洲一区二区三区美女| 韩国一区二区三区| 欧美日韩久久不卡| 亚洲图片欧美激情| 久久99国产精品久久99果冻传媒| 色老汉av一区二区三区| 欧美国产日韩在线观看| 日韩成人午夜电影| 欧美色图天堂网| 亚洲素人一区二区| 国产成人免费在线观看不卡| 777午夜精品视频在线播放| 中文字幕在线观看一区| 激情欧美一区二区三区在线观看| 在线观看不卡一区| **性色生活片久久毛片| 成人丝袜18视频在线观看| 日韩欧美一区二区视频| 亚洲综合免费观看高清完整版| av在线免费不卡| 亚洲欧洲成人精品av97| 成人黄动漫网站免费app| 国产日韩欧美制服另类| 国产高清精品在线| 久久精品一区蜜桃臀影院| 国产乱码一区二区三区| 亚洲欧洲日韩综合一区二区| 成人av电影在线网| 视频在线观看91| 欧美视频你懂的| 蜜臀av性久久久久av蜜臀妖精 | 亚洲一区二区三区影院| 欧美亚洲高清一区二区三区不卡| 亚洲gay无套男同| 911精品产国品一二三产区| 麻豆91在线看| 中文字幕欧美国产| 欧美在线小视频| 久久精品国产免费看久久精品| 久久久午夜电影| 色视频成人在线观看免| 国产成人免费在线| 色婷婷国产精品| 久久精品国产网站| 亚洲视频一二三区| 欧美一级日韩不卡播放免费| 美女视频一区二区三区| 中文字幕中文字幕一区二区 | 亚洲靠逼com| 精品国产免费一区二区三区四区| 成人国产一区二区三区精品| 亚洲v中文字幕| 国产精品女人毛片| 精品少妇一区二区三区在线播放| 99国产精品一区| 韩日欧美一区二区三区| 性做久久久久久免费观看| 欧美极品少妇xxxxⅹ高跟鞋| 欧美午夜精品一区二区三区| 国产电影一区在线| 蜜桃av一区二区在线观看| 一级日本不卡的影视| 欧美国产激情二区三区| 久久久久久影视| 日韩一二三区视频| 欧美人妇做爰xxxⅹ性高电影| 波多野结衣精品在线| 国产成人aaaa| 国产成人综合在线观看| 免费观看91视频大全| 青娱乐精品在线视频| 亚洲高清三级视频| 亚洲第一综合色| 亚洲一区二区在线视频| 亚洲精品欧美综合四区| 亚洲欧美中日韩| 1024亚洲合集| 亚洲综合一二三区| 午夜精品一区二区三区免费视频 | 日日噜噜夜夜狠狠视频欧美人| 亚洲欧美福利一区二区| 国产一区二区按摩在线观看| 国产自产2019最新不卡| 国内精品国产成人国产三级粉色 | 欧美一区二区在线视频| 国产精品久久久久久久久搜平片 | 亚洲人妖av一区二区| 亚洲三级免费观看| 午夜精品久久久久| 男男视频亚洲欧美| 久久99国产精品尤物| av网站免费线看精品| 欧美日韩dvd在线观看| 日韩美女一区二区三区四区| 久久精品亚洲精品国产欧美 | 97成人超碰视| 日韩久久久精品| 亚洲视频在线一区| 久久av老司机精品网站导航| 成人免费黄色在线| 3751色影院一区二区三区| 久久精品夜色噜噜亚洲aⅴ| 亚洲男人的天堂在线aⅴ视频| 日韩黄色小视频| 一本一道久久a久久精品综合蜜臀| 欧美肥妇毛茸茸| 中文字幕亚洲在| 精品伊人久久久久7777人| 日本大香伊一区二区三区| 久久综合九色综合97婷婷| 亚洲图片欧美综合| av不卡在线观看| 亚洲国产成人一区二区三区| 日日夜夜精品视频免费| 国产精品免费视频观看| 麻豆专区一区二区三区四区五区| www.日韩在线| 国产亚洲成aⅴ人片在线观看| 麻豆一区二区99久久久久| 91麻豆精品国产91久久久| 日韩毛片视频在线看| 成人一区二区三区视频 | 成人性生交大合| 精品久久国产字幕高潮| 精品综合久久久久久8888| 欧美视频一区二区三区在线观看 | 亚洲综合色噜噜狠狠| 色8久久人人97超碰香蕉987| 欧美韩日一区二区三区四区| 国产酒店精品激情| 国产人妖乱国产精品人妖| 国产精品自拍毛片| 国产精品三级av| 99国产精品国产精品久久| 亚洲美女区一区| 这里只有精品视频在线观看| 色综合中文字幕| 三级久久三级久久久| 欧美成人精品二区三区99精品| 国产伦理精品不卡| 国产农村妇女精品| 色8久久人人97超碰香蕉987| 日韩精品亚洲一区| xvideos.蜜桃一区二区| 99久久精品免费看国产| 伊人色综合久久天天| 日韩女优av电影| 99久久久久久99| 麻豆国产欧美一区二区三区| 国产亚洲精品久| 欧美日韩激情在线| 国产乱国产乱300精品| 亚洲综合色婷婷| 国产精品成人网| 91麻豆精品国产91久久久久久久久| 国产精品一区二区x88av| 亚洲精品高清在线观看|