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

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

?? nonlinearequation.inl

?? Chap16 特殊函數(shù) 計算機(jī)常用數(shù)值算法與程序(C++版)
?? 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| 国产精品久久久久aaaa| 欧美一区二区视频在线观看| 欧美一区二区三区四区视频| 91精品国产综合久久小美女| 日韩精品一区二区三区中文精品| 欧美日韩精品系列| 日韩久久久精品| 精品国产一区二区三区忘忧草| 精品国产乱子伦一区| 久久免费精品国产久精品久久久久 | 日韩精品一区二区三区中文不卡| 色哟哟国产精品| 7777精品伊人久久久大香线蕉的| 91精品综合久久久久久| 精品精品欲导航| 国产精品系列在线| 一区二区三区四区不卡视频| 亚洲国产日韩在线一区模特| 欧美bbbbb| www.欧美精品一二区| 色先锋资源久久综合| 欧美一区二区三区电影| 国产日韩精品久久久| 亚洲女人的天堂| 日韩av网站在线观看| 国产一区二区免费在线| 色综合色狠狠天天综合色| 777午夜精品免费视频| 精品国产乱码久久久久久蜜臀 | 91美女片黄在线观看| 欧美酷刑日本凌虐凌虐| 久久久久国产精品麻豆| 亚洲精品久久久蜜桃| 久久69国产一区二区蜜臀| 99久久伊人久久99| 精品国产91洋老外米糕| 亚洲欧美福利一区二区| 另类中文字幕网| 99久久亚洲一区二区三区青草| 欧美一级免费观看| 亚洲日本免费电影| 国产一区二区导航在线播放| 91麻豆自制传媒国产之光| 久久众筹精品私拍模特| 午夜精品123| 99久久精品国产导航| 精品国产伦一区二区三区观看体验| 亚洲精品高清在线观看| 国内成人精品2018免费看| 欧美日韩精品是欧美日韩精品| 国产精品人人做人人爽人人添| 日本三级亚洲精品| 欧美在线观看禁18| 亚洲欧美中日韩| 国精产品一区一区三区mba桃花| 欧美日韩一区二区在线观看 | 国产视频一区二区在线| 日韩和欧美一区二区三区| 99精品视频在线观看| 国产网红主播福利一区二区| 久久国产精品一区二区| 欧美人与z0zoxxxx视频| 一区二区三区美女视频| 91在线无精精品入口| 国产欧美视频一区二区| 国产一区二区不卡在线| 日韩欧美综合在线| 蜜臀久久99精品久久久久宅男| 欧美性做爰猛烈叫床潮| 亚洲一区视频在线| 欧美日韩午夜在线| 亚洲大片在线观看| 777久久久精品| 另类专区欧美蜜桃臀第一页| 精品国产一区二区三区av性色| 美女视频黄频大全不卡视频在线播放| 精品视频一区 二区 三区| 午夜久久电影网| 日韩三级电影网址| 国产一区二区三区四区五区入口| 久久久亚洲欧洲日产国码αv| 国产精一区二区三区| 精品成人免费观看| 白白色亚洲国产精品| 中文字幕在线视频一区| 91免费观看在线| 午夜视频一区二区三区| 欧美tickling挠脚心丨vk| 韩国精品主播一区二区在线观看 | 精品福利一二区| 国产精品中文字幕一区二区三区| 久久精品一区四区| 91色.com| 日韩在线a电影| 国产亚洲综合av| 91同城在线观看| 日韩av成人高清| 国产人妖乱国产精品人妖| 不卡大黄网站免费看| 亚洲大型综合色站| 亚洲欧洲另类国产综合| 欧美日韩一区二区三区在线| 奇米777欧美一区二区| 国产视频一区二区在线| 欧美三级电影精品| 国产99久久久国产精品潘金 | 99久久99久久免费精品蜜臀| 夜夜夜精品看看| 精品国产伦一区二区三区观看体验| 波多野结衣在线aⅴ中文字幕不卡| 性做久久久久久免费观看| 精品嫩草影院久久| 欧美在线免费观看亚洲| 国产一区在线精品| 亚洲国产精品久久不卡毛片| 久久蜜桃香蕉精品一区二区三区| 色吧成人激情小说| 成人免费观看av| 美女高潮久久久| 亚洲一区二区三区免费视频| 国产精品丝袜在线| 日韩视频免费观看高清完整版| 91无套直看片红桃| 国产自产高清不卡| 五月天激情综合| 亚洲激情网站免费观看| 国产日韩欧美a| 日韩一区二区在线观看视频| 在线亚洲+欧美+日本专区| 国产不卡在线视频| 狠狠色综合日日| 婷婷激情综合网| 一区二区三区欧美在线观看| 国产精品久久久久久亚洲伦| 国产午夜亚洲精品不卡| 精品国产乱码久久久久久浪潮 | 国产一区91精品张津瑜| 免费观看日韩av| 日韩国产在线一| 视频精品一区二区| 蜜桃精品视频在线| 亚洲午夜私人影院| 一区二区三区在线观看视频| 国产精品美女一区二区三区| 国产欧美综合在线| 久久亚洲一区二区三区四区| 欧美电视剧免费全集观看| 91精品国产色综合久久 | 激情综合色综合久久综合| 视频在线观看一区| 日日噜噜夜夜狠狠视频欧美人| 亚洲激情图片qvod| 夜夜爽夜夜爽精品视频| 亚洲综合无码一区二区| 亚洲丰满少妇videoshd| 午夜精品久久久久久久99樱桃| 午夜精品国产更新| 男人的天堂久久精品| 捆绑调教一区二区三区| 极品少妇xxxx偷拍精品少妇| 国产成人精品亚洲777人妖| 国产精品一二一区| 99久久精品免费看国产 | 制服丝袜av成人在线看| 日韩精品一区二区在线观看| 久久久亚洲高清| 国产精品青草综合久久久久99| 国产精品你懂的| 亚洲欧美二区三区| 日韩国产一二三区| 国产精品综合二区| 91香蕉视频mp4| 欧美精品日日鲁夜夜添| 久久久久88色偷偷免费| 最新日韩av在线| 香蕉成人伊视频在线观看| 成人小视频免费观看| 色哟哟亚洲精品| 日韩午夜在线播放| 中文字幕日韩av资源站| 午夜免费欧美电影| 国产99久久久国产精品潘金网站| 欧美亚洲一区三区| 精品国产精品一区二区夜夜嗨| 中国色在线观看另类| 污片在线观看一区二区| 国产高清无密码一区二区三区| 99re这里只有精品6| 日韩一区二区在线看| 亚洲精品免费在线| 国产精品资源网| 欧美久久久久中文字幕| 国产精品久久久久久久岛一牛影视| 亚洲v日本v欧美v久久精品| 国产激情一区二区三区桃花岛亚洲| 欧美在线视频不卡| 综合亚洲深深色噜噜狠狠网站| 麻豆视频一区二区|