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

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

?? transform.inl

?? 本代碼是《計算機常用數值計算算法與程序 C++版》一書的配套線性方程組求解代碼
?? INL
字號:
//Transform.inl		數學變換頭文件
// Ver 1.0.0.0
// 版權所有(C) 何渝, 2002
// 最后修改: 2002.5.31.

#ifndef _TRANSFORM_INL		//避免多次編譯
#define _TRANSFORM_INL

//傅里葉級數逼近
template <class _Ty>
void FourierSeriesApproach(valarray<_Ty>& f,  
								valarray<_Ty>& a, valarray<_Ty>& b)
{
    _Ty u0, c1(1), s1(0);
	
	int n = a.size() - 1;
    _Ty t = 6.283185306 / (2.0 * n + 1.0);
    _Ty c = cos(t);
	_Ty s = sin(t);
    t = 2.0 / (2.0 * n + 1.0);
		
    for(int i=0; i<=n; i++)
    {
		_Ty u1(0), u2(0);
        for(int j=2*n; j>=1; j--)
        {
			u0 = f[j] + 2.0 * c1 * u1 - u2;
            u2 = u1;
			u1 = u0;
        }
        a[i] = t * (f[0] + u1 * c1 - u2);
        b[i] = t * u1 * s1;
        u0 = c * c1 - s * s1;
		s1 = c * s1 + s * c1;
		c1 = u0;
    }

}

//快速傅里葉變換
template <class _Ty>
void FourierTransform(valarray<complex<_Ty> >& pp, 
						valarray<complex<_Ty> >& ff, int l, int il)
{
	int n = pp.size();		//輸入的點數,n>0
	int it, k(0);				
	
	for(it = 1; ; it *= 2)	//求k值, 要滿足n等于2的k次方
	{
		if(it == n) break;
		k++;
		if(k > 64) return;
	}

	for(it = 0; it<n; it++)
    {
		int m = it, is(0);
        for(int i=0; i<k; i++)
        {
			int j = m / 2;
			is = 2 * is + (m - 2 * j);
			m = j;
		}
		
		ff[it] = pp[is];		
    }

	pp[0] = complex<_Ty>(1.0, 0.0);
	
	_Ty p = 6.283185306 / (1.0 * n);

    pp[1] = complex<_Ty>(cos(p), -sin(p));
    
	if(l != 0) 
		pp[1] =complex<_Ty>(pp[1].real(), -pp[1].imag());
    
	for(int i = 2; i < n; i ++)
    {
		p = pp[i-1].real() * pp[1].real();
		
		_Ty q = pp[i-1].imag() * pp[1].imag();
        _Ty s = (pp[i-1].real() + pp[i-1].imag()) * (pp[1].real() + pp[1].imag());
        
		pp[i] = complex<_Ty>(p - q, s - p - q);
    }
    for(it = 0; it<n-1; it = it + 2)
    {
		_Ty vr=ff[it].real(); 
		_Ty vi=ff[it].imag();

        ff[it] = complex<_Ty>(vr + ff[it+1].real(), vi + ff[it+1].imag());
		ff[it+1] = complex<_Ty>(vr - ff[it+1].real(), vi - ff[it+1].imag());
		
    }
    
	int m=n/2;
	int nv(2);
    
	for(int l0 = k-2; l0>=0; l0--)
    {
		m = m / 2;
		nv = 2 * nv;
        for(it = 0; it <= (m - 1) * nv; it = it + nv)
          for(int j = 0; j < (nv / 2); j ++)
          {
			  p = pp[m*j].real() * ff[it+j+nv/2].real();
              _Ty q = pp[m*j].imag() * ff[it+j+nv/2].imag();
              _Ty s = pp[m*j].real() + pp[m*j].imag();
              
			  s *= (ff[it+j+nv/2].real() + ff[it+j+nv/2].imag());
              _Ty poddr = p - q;
			  _Ty poddi = s - p - q;
              
			  ff[it+j+nv/2] = complex<_Ty>(ff[it+j].real() - poddr, ff[it+j].imag() - poddi);
              ff[it+j] = complex<_Ty>(ff[it+j].real() + poddr, ff[it+j].imag() + poddi);
          }
    }

    if(l != 0)
      for(i = 0; i < n; i ++)
      {
		  ff[i] = complex<_Ty>(ff[i].real() / (1.0*n),ff[i].imag() / (1.0*n));
      }
    if(il!=0)
      for(i=0; i<n; i++)
      {
		  pp[i] = complex<_Ty>(sqrt(ff[i].real() * ff[i].real() + ff[i].imag() * ff[i].imag()),
			                           pp[i].imag());
          if(Abs(ff[i].real()) < 0.000001 * Abs(ff[i].imag()))
          { 
			  if((ff[i].imag() * ff[i].real()) > 0) pp[i] = complex<_Ty>(pp[i].real(), 90.0);
              else pp[i] = complex<_Ty>(pp[i].real(), -90.0);
          }
          else
			  pp[i] = complex<_Ty>(pp[i].real(), (atan(ff[i].imag() / ff[i].real()) * 360.0 / 6.283185306));
			
      }
}

//快速沃什變換
template <class _Ty>
void WalshTransform(valarray<_Ty>& p, valarray<_Ty>& x)
{
	int i, k(0);
	int n = p.size();			//輸入序列的長度,n>0
	for(i=1; ; i*=2)			//n等于2的k次方
	{
		if(i==n) break;
		k++;
		if(k>64) return;
	}

	int l=n, m(1), it=2, ii=n/2;
    x[0]=1;
	x[ii]=2;
    for(i=1; i<k; i++)
    {
		m=m+m;
		l=l/2;
		it=it+it;
        for(int j=0; j<m; j++)	x[j*l+l/2]=it+1-x[j*l];
    }
    for(i=0; i<n; i++)
    {
		ii=x[i]-1;
		x[i]=p[ii];
	}
    l=1;
    for(i=1; i<=k; i++)
     {
		m=n/(2*l)-1;
        for(int j=0; j<=m; j++)
        {
			it=2*l*j;
            for(int is=0; is<l; is++)
            {
				_Ty q=x[it+is]+x[it+is+l];
                x[it+is+l]=x[it+is]-x[it+is+l];
                x[it+is]=q;
            }
        }
        l=2*l;
    }
}

//五點三次平滑(曲線擬合)
template <class _Ty>
void Smooth5_3(valarray<_Ty>& y, valarray<_Ty>& yy)
{
	int n = y.size();	//給定等距觀測點的個數。要求n>=5
    if(n<5)
		for(int i=0; i<n; i++) yy[i]=y[i];
    else
    {
		yy[0]=69.0*y[0]+4.0*y[1]-6.0*y[2]+4.0*y[3]-y[4];
        yy[0]=yy[0]/70.0;
        yy[1]=2.0*y[0]+27.0*y[1]+12.0*y[2]-8.0*y[3];
        yy[1]=(yy[1]+2.0*y[4])/35.0;
        for (int i=2; i<n-2; i++)
        {
			yy[i]=-3.0*y[i-2]+12.0*y[i-1]+17.0*y[i];
            yy[i]=(yy[i]+12.0*y[i+1]-3.0*y[i+2])/35.0;
        }
        yy[n-2]=2.0*y[n-5]-8.0*y[n-4]+12.0*y[n-3];
        yy[n-2]=(yy[n-2]+27.0*y[n-2]+2.0*y[n-1])/35.0;
        yy[n-1]=-y[n-5]+4.0*y[n-4]-6.0*y[n-3];
        yy[n-1]=(yy[n-1]+4.0*y[n-2]+69.0*y[n-1])/70.0;
    }
}

//離散隨機線性系統的卡爾曼濾波
template <class _Ty>
int SievingKalman(matrix<_Ty>& f, matrix<_Ty>& q, matrix<_Ty>& r, 
					matrix<_Ty>& h, matrix<_Ty>& y, matrix<_Ty>& x, 
									matrix<_Ty>& p, matrix<_Ty>& g)
{
	int i,j,kk,ii,jj,js;

	int n = g.GetRowNum();		//動態系統的維數
	int m = g.GetColNum();		//觀測系統的維數
	int k = y.GetRowNum();		//觀測序列的長度

	matrix<_Ty> e(m,m);
	int l=m;
    if(l<n) l=n;
	matrix<_Ty> a(l,l);
	matrix<_Ty> b(l,l);
    for(i=0; i<n; i++)
      for(j=0; j<n; j++)
      {
		  a(i,j)=0.0;
          for(kk=0; kk<n; kk++)	a(i,j)=a(i,j)+p(i,kk)*f(j,kk);
      }
    for(i=0; i<n; i++)
    for(j=0; j<n; j++)
    { 
	  p(i,j)=q(i,j);
      for(kk=0; kk<n; kk++) p(i,j)=p(i,j)+f(i,kk)*a(kk,j);
    }
    for(ii=2; ii<=k; ii++)
    { 
		for(i=0; i<n; i++)
	    for(j=0; j<m; j++)
		{
			jj=i*l+j;
			a(i,j)=0.0;
			for(kk=0; kk<n; kk++)
				a(i,j)=a(i,j)+p(i,kk)*h(j,kk);
		}
		for(i=0; i<m; i++)
			for(j=0; j<m; j++)
			{
				jj=i*m+j; 
				e(i,j)=r(i,j);
				for(kk=0; kk<n; kk++)
					e(i,j)=e(i,j)+h(i,kk)*a(kk,j);
			}

		js=MatrixInversionGS(e);	//調用全選主元高斯-約當消去法求逆

		if(js==0)
		{
			cout << "Error! No inversion!" << endl;
			return(js);				//求增益矩陣過程中求逆失敗
		}
        
		for(i=0; i<n; i++)
        for(j=0; j<m; j++)
        { 
			jj=i*m+j;
			g(i,j)=0.0;
            for(kk=0; kk<m; kk++)
				g(i,j)=g(i,j)+a(i,kk)*e(j,kk);
        }
        for(i=0; i<n; i++)
        { 
			jj=(ii-1)*n+i; 
			x(ii-1,i)=0.0;
            for(j=0; j<n; j++)
				x(ii-1,i)=x(ii-1,i)+f(i,j)*x(ii-2,j);
        }
        for(i=0; i<m; i++)
        { 
			jj=i*l; 
			b(i,0)=y(ii-1,i);
            for(j=0; j<n; j++)
				b(i,0)=b(i,0)-h(i,j)*x(ii-1,j);
        }
        for(i=0; i<n; i++)
        { 
			jj=(ii-1)*n+i;
            for(j=0; j<m; j++)
				x(ii-1,i)=x(ii-1,i)+g(i,j)*b(j,0);
        }
        if(ii<k)
        { 
			for(i=0; i<n; i++)
            for(j=0; j<n; j++)
            {
				jj=i*l+j;
				a(i,j)=0.0;
                for(kk=0; kk<m; kk++)
					a(i,j)=a(i,j)-g(i,kk)*h(kk,j);
                if(i==j) a(i,j)=1.0+a(i,j);
            }
            for(i=0; i<n; i++)
            for(j=0; j<n; j++)
            { 
				jj=i*l+j; 
				b(i,j)=0.0;
                for(kk=0; kk<n; kk++)
					b(i,j)=b(i,j)+a(i,kk)*p(kk,j);
            }
            for(i=0; i<n; i++)
            for(j=0; j<n; j++)
            { 
				jj=i*l+j; 
				a(i,j)=0.0;
                for(kk=0; kk<n; kk++)
					a(i,j)=a(i,j)+b(i,kk)*f(j,kk);
            }
            for(i=0; i<n; i++)
            for(j=0; j<n; j++)
            { 
				jj=i*n+j;
				p(i,j)=q(i,j);
                for(kk=0; kk<n; kk++)
					p(i,j)=p(i,j)+f(i,kk)*a(j,kk);
          }
      }
  }
  return(js);
}

//a-b-r濾波
template <class _Ty>
void SievingABR(valarray<_Ty>& x, _Ty t, _Ty a, _Ty b,
											_Ty r, valarray<_Ty>& y)
{
    _Ty aa(0), vv(0), ss(0);

	int n = x.size();		//量測數據的點數
    
	for(int i=0; i<n; i++)
    { 
		_Ty s1=ss+t*vv+t*t*aa/2.0;
        _Ty v1=vv+t*aa;
		_Ty a1=aa;
        ss=s1+a*(x[i]-s1);
		y[i]=ss;
        vv=v1+b*(x[i]-s1);
        aa=a1+2.0*r*(x[i]-s1)/(t*t);
    }

}

#endif		// _TRANSFORM_INL

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产成人午夜高潮毛片| 欧美亚洲国产一区二区三区| 不卡在线观看av| 日韩精品在线网站| 亚洲免费高清视频在线| 久久电影网站中文字幕| 欧美午夜精品一区二区蜜桃| 国产日韩欧美高清| 日本sm残虐另类| 在线亚洲精品福利网址导航| 欧美精品一区二区三区蜜桃视频| 亚洲国产综合在线| 91老师国产黑色丝袜在线| 精品成人在线观看| 麻豆91小视频| 欧美精品丝袜久久久中文字幕| 日韩美女精品在线| 丁香婷婷综合激情五月色| 日韩欧美电影一二三| 亚洲丰满少妇videoshd| 在线免费观看日韩欧美| 亚洲精品中文字幕乱码三区| 大白屁股一区二区视频| 欧美激情一区二区三区| 国产成人亚洲综合a∨婷婷图片| 精品国产一区二区三区久久影院| 免费高清不卡av| 日韩一区二区不卡| 久久国产三级精品| 精品91自产拍在线观看一区| 日韩不卡一区二区三区| 在线不卡中文字幕播放| 日韩成人一级大片| 91精品久久久久久蜜臀| 久久精品国产一区二区| 精品区一区二区| 激情欧美一区二区| 国产日产欧美一区二区视频| 成人免费视频免费观看| 中文字幕在线不卡一区二区三区| 成人av小说网| 亚洲精品福利视频网站| 在线成人午夜影院| 国产在线精品一区二区| 国产精品视频你懂的| 色猫猫国产区一区二在线视频| 亚洲韩国精品一区| 日韩视频国产视频| 成人免费高清视频| 亚洲午夜久久久久久久久电影网 | 日韩美一区二区三区| 韩国一区二区在线观看| 国产精品入口麻豆原神| 色妞www精品视频| 天天影视涩香欲综合网| 久久影音资源网| 99久久99久久免费精品蜜臀| 亚洲成人av一区二区三区| 欧美成人r级一区二区三区| 国产在线精品一区二区| 一二三四区精品视频| 日韩免费观看高清完整版| 成人av小说网| 青青草国产成人av片免费| 欧美精彩视频一区二区三区| 色综合久久综合中文综合网| 麻豆视频观看网址久久| 亚洲欧美日韩在线| 日韩三级视频在线观看| 99视频在线观看一区三区| 日韩二区三区四区| 亚洲色图欧洲色图| 精品久久一区二区| 91福利小视频| 国产精品一区专区| 日韩精品三区四区| 一区二区中文视频| 久久久久久久网| 欧美三级在线看| 不卡av在线网| 老司机免费视频一区二区三区| 亚洲永久免费视频| 国产欧美日韩在线| 欧美一级高清片| 欧美色图12p| av一区二区三区四区| 国内精品在线播放| 午夜免费久久看| 亚洲激情在线播放| 欧美激情中文不卡| 久久综合视频网| 91.xcao| 欧美无人高清视频在线观看| 国产91丝袜在线播放| 美女视频黄久久| 三级欧美在线一区| 亚洲国产欧美在线| 亚洲欧美乱综合| 国产精品久久夜| 久久精品一区二区三区四区| 91精品国产91久久久久久一区二区| 99精品国产热久久91蜜凸| 黑人精品欧美一区二区蜜桃 | 国产精品原创巨作av| 婷婷久久综合九色国产成人| 亚洲精品高清视频在线观看| 欧美激情一区二区三区蜜桃视频| 日韩欧美国产1| 日韩天堂在线观看| 欧美一区二区啪啪| 5月丁香婷婷综合| 91精品国产综合久久婷婷香蕉| 在线看不卡av| 欧美亚州韩日在线看免费版国语版| 成人午夜av影视| av成人动漫在线观看| 粉嫩av一区二区三区在线播放 | 亚洲免费观看在线观看| 欧美私模裸体表演在线观看| 99精品视频在线播放观看| 不卡一区在线观看| 91在线观看视频| 91久久精品一区二区| 在线亚洲人成电影网站色www| 91老师片黄在线观看| 色婷婷av一区二区| 欧美亚洲丝袜传媒另类| 欧美理论在线播放| 日韩女优电影在线观看| 久久视频一区二区| 中文字幕中文字幕一区| 亚洲精品国产无套在线观| 香蕉av福利精品导航| 免费人成在线不卡| 国产成人三级在线观看| av一区二区三区| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 欧美日本一道本| 久久综合九色综合欧美就去吻| 国产日韩欧美高清| 亚洲一区二区三区四区在线观看 | 欧美福利视频一区| 久久夜色精品国产欧美乱极品| 国产精品第四页| 天堂一区二区在线免费观看| 国产麻豆91精品| 色播五月激情综合网| 日韩一区二区三区电影| 国产欧美精品国产国产专区| 一区二区三区.www| 蜜桃免费网站一区二区三区| 菠萝蜜视频在线观看一区| 欧美日韩免费在线视频| 国产日本欧洲亚洲| 亚洲国产欧美在线| 不卡视频免费播放| 日韩久久免费av| 一区二区欧美视频| 国产成人啪免费观看软件| 欧美午夜视频网站| 国产精品久久综合| 蜜臀a∨国产成人精品| 色哟哟欧美精品| 国产日韩欧美综合一区| 亚洲成av人在线观看| 成人免费视频一区二区| 精品捆绑美女sm三区| 亚洲国产精品人人做人人爽| 国产jizzjizz一区二区| 日韩精品自拍偷拍| 亚洲一区二区三区精品在线| 丁香五精品蜜臀久久久久99网站| 91精品国模一区二区三区| 亚洲欧美成人一区二区三区| 精品综合久久久久久8888| 欧美日韩免费电影| 综合精品久久久| 国产成人aaa| 国产亚洲精品bt天堂精选| 免费成人av资源网| 欧美日韩日日夜夜| 亚洲一区二区三区影院| 91亚洲精品久久久蜜桃| 国产精品久久久久久久岛一牛影视 | 91福利国产精品| 综合久久一区二区三区| 粉嫩在线一区二区三区视频| 精品久久久网站| 免费在线看成人av| 欧美日韩一级片网站| 亚洲综合在线免费观看| 91天堂素人约啪| 日韩一区在线播放| aa级大片欧美| 亚洲图片激情小说| 91美女视频网站| 亚洲精品国产第一综合99久久| 99国产精品久久久久久久久久| 国产日韩精品一区二区浪潮av| 国产超碰在线一区|