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

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

?? svd.cpp

?? 矩陣的奇異值分解算法
?? CPP
字號:
#include "svd.h"

/*********************************************************************
 * 矩陣的奇異值分解,參見《c 常用算法程序集》徐世良P169
 * 參數說明:
 * a m*n的實矩陣,返回時其對角線給出奇異值(非遞增順序),其余元素為0
 * m,n 矩陣A的行數和列數
 * u m*m的矩陣,存放左奇異向量
 * v n*n的矩陣,存放右奇異向量
 * eps 雙精度實型變量,給定精度要求
 * ka 整形變量,其值為max(m,n)+1
 * 返回值:如果返回標志小于0,則說明出現了迭代MAX_ITERA次還未求得某個
 * 奇異值的情況,此時矩陣A的分解式為UAV,如果返回標志大于0,則說明
 * 程序正常運行
 ********************************************************************/
int dluav(double a[],int m,int n,double u[],double v[],double eps,int ka)
{
	int i,j,k,l,it,ll,kk,ix,iy,mm,nn,iz,ml,ks;
	double d,dd,t,sm,sml,eml,sk,ek,b,c,shh,fg[2],cs[2];
	double *s,*e,*w;
	s=(double*)malloc(ka*sizeof(double));
	e=(double*)malloc(ka*sizeof(double));
	w=(double*)malloc(ka*sizeof(double));
	for(i=1;i<=m;i++)
	{
		ix=(i-1)*m+i-1;
		u[ix]=0;
	}
	for(i=1;i<=n;i++)
	{
		iy=(i-1)*n+i-1;
		v[iy]=0;
	}
	it=MAX_ITERA;k=n;
	if(m-1<n)
		k=m-1;
	l=m;
	if(n-2<m) l=n-2;
	if(l<0) l=0;
	ll=k;
	if(l>k) ll=l;
	if(ll>=1)
	{
		for(kk=1;kk<=ll;kk++)
		{
			if(kk<=k)
			{
				d=0.0;
				for(i=kk;i<=m;i++)
				{
					ix=(i-1)*n+kk-1;d=d+a[ix]*a[ix];
				}
				s[kk-1]=sqrt(d);
				//if(s[kk-1]!=0.0)
				if(fabs(s[kk-1])>MIN_DOUBLE)
				{
					ix=(kk-1)*n+kk-1;
					//if(a[ix]!=0.0)
					if(fabs(a[ix])>MIN_DOUBLE)
					{
						s[kk-1]=fabs(s[kk-1]);
						if(a[ix]<0.0) s[kk-1]=-s[kk-1];
					}
					for(i=kk;i<=m;i++)
					{
						iy=(i-1)*n+kk-1;
						a[iy]=a[iy]/s[kk-1];
					}
					a[ix]=1.0+a[ix];
				}
				s[kk-1]=-s[kk-1];
			}
			if(n>=kk+1)
			{
				for(j=kk+1;j<=n;j++)
				{
					//if((kk<=k)&&(s[kk-1]!=0.0))
					if((kk<=k)&&(fabs(s[kk-1])>MIN_DOUBLE))
					{
						d=0.0;
						for(i=kk;i<=m;i++)
						{
							ix=(i-1)*n+kk-1;
							iy=(i-1)*n+j-1;
							d=d+a[ix]*a[iy];
						}
						d=-d/a[(kk-1)*n+kk-1];
						for(i=kk;i<=m;i++)
						{
							ix=(i-1)*n+j-1;
							iy=(i-1)*n+kk-1;
							a[ix]=a[ix]+d*a[iy];
						}
					}
					e[j-1]=a[(kk-1)*n+j-1];
				}
			}
			if(kk<=k)
			{
				for(i=kk;i<=m;i++)
				{
					ix=(i-1)*m+kk-1;iy=(i-1)*n+kk-1;
					u[ix]=a[iy];
				}
			}
			if(kk<=l)
			{
				d=0.0;
				for(i=kk+1;i<=n;i++)
					d=d+e[i-1]*e[i-1];
				e[kk-1]=sqrt(d);
				//if(e[kk-1]!=0.0)
				if(fabs(e[kk-1])>MIN_DOUBLE)
				{
					//if(e[kk]!=0.0)
					if(fabs(e[kk])>MIN_DOUBLE)
					{
						e[kk-1]=fabs(e[kk-1]);
						if(e[kk]<0.0)
							e[kk-1]=-e[kk-1];
					}
					for(i=kk+1;i<=n;i++)
						e[i-1]=e[i-1]/e[kk-1];
					e[kk]=1.0+e[kk];
				}
				e[kk-1]=-e[kk-1];
				//if((kk+1<=m)&&(e[kk-1]!=0.0))
				if((kk+1<=m)&&(fabs(e[kk-1])>MIN_DOUBLE))
				{
					for(i=kk+1;i<=m;i++) w[i-1]=0.0;
					for(j=kk+1;j<=n;j++)
						for(i=kk+1;i<=m;i++)
							w[i-1]=w[i-1]+e[j-1]*a[(i-1)*n+j-1];
					for(j=kk+1;j<=n;j++)
						for(i=kk+1;i<=m;i++)
						{
							ix=(i-1)*n+j-1;
							a[ix]=a[ix]-w[i-1]*e[j-1]/e[kk];
						}
				}
				for(i=kk+1;i<=n;i++)
					v[(i-1)*n+kk-1]=e[i-1];
			}
		}
	}
	mm=n;
	if(m+1<n) mm=m+1;
	if(k<n) s[k]=a[k*n+k];
	if(m<mm) s[mm-1]=0.0;
	if(l+1<mm) e[l]=a[l*n+mm-1];
	e[mm-1]=0.0;
	nn=m;
	if(m>n) nn=n;
	if(nn>=k+1)
	{
		for(j=k+1;j<=nn;j++)
		{
			for(i=1;i<=m;i++)
				u[(i-1)*m+j-1]=0.0;
			u[(j-1)*m+j-1]=1.0;
		}
	}
	if(k>=1)/////////////////////////////////
	{
		for(ll=1;ll<=k;ll++)
		{
			kk=k-ll+1;iz=(kk-1)*m+kk-1;
			//if(s[kk-1]!=0.0)
			if(fabs(s[kk-1])>MIN_DOUBLE)
			{
				if(nn>=kk+1)
					for(j=kk+1;j<=nn;j++)
					{
						d=0.0;
						for(i=kk;i<=m;i++)
						{
							ix=(i-1)*m+kk-1;
							iy=(i-1)*m+j-1;
							d=d+u[ix]*u[iy]/u[iz];
						}
						d=-d;
						for(i=kk;i<=m;i++)
						{
							ix=(i-1)*m+j-1;
							iy=(i-1)*m+kk-1;
							u[ix]=u[ix]+d*u[iy];
						}
					}
					for(i=kk;i<=m;i++)
					{
						ix=(i-1)*m+kk-1;
						u[ix]=-u[ix];
					}
					u[iz]=1.0+u[iz];
					if(kk-1>=1)//////////////////////////////////////
						for(i=1;i<=kk-1;i++)
							u[(i-1)*m+kk-1]=0.0;
			}
			else
			{
				for(i=1;i<=m;i++)
					u[(i-1)*m+kk-1]=0.0;
				u[(kk-1)*m+kk-1]=1.0;
			}
		}
	}
	for(ll=1;ll<=n;ll++)
	{
		kk=n-ll+1;iz=kk*n+kk-1;
		//if((kk<=l)&&(e[kk-1]!=0.0))/////////////////////////////
		if((kk<=l)&&(fabs(e[kk-1])>MIN_DOUBLE))
		{
			for(j=kk+1;j<=n;j++)
			{
				d=0.0;
				for(i=kk+1;i<=n;i++)
				{
				ix=(i-1)*n+kk-1;iy=(i-1)*n+j-1;
				d=d+v[ix]*v[iy]/v[iz];
				}
				d=-d;
				for(i=kk+1;i<=n;i++)
				{
					ix=(i-1)*n+j-1;iy=(i-1)*n+kk-1;
					v[ix]=v[ix]+d*v[iy];
				}
			}
		}
		for(i=1;i<=n;i++)
			v[(i-1)*n+kk-1]=0.0;
		v[iz-n]=1.0;
	}
	for(i=1;i<=m;i++)
		for(j=1;j<=n;j++)
			a[(i-1)*n+j-1]=0.0;
	ml=mm;
	it=MAX_ITERA;
	while(1==1)//////////////////////////////////
	{
		if(mm==0)
		{
			ppp(a,e,s,v,m,n);
			free(s);free(e);free(w);
			return l;
		}
		if(it==0)
		{
			ppp(a,e,s,v,m,n);
			free(s);free(e);free(w);
			return -1;
		}
		kk=mm-1;
		//while((kk!=0)&&(fabs(e[kk-1])!=0.0))
		while((kk!=0)&&(fabs(e[kk-1])>MIN_DOUBLE))
		{
			d=fabs(s[kk-1])+fabs(s[kk]);
			dd=fabs(e[kk-1]);
			if(dd>eps*d)
				kk=kk-1;
			else
				e[kk-1]=0.0;
		}
		if(kk==mm-1)
		{
			kk=kk+1;
			if(s[kk-1]<0.0)
			{
				s[kk-1]=-s[kk-1];
				for(i=1;i<=n;i++)
				{
					ix=(i-1)*n+kk-1;
					v[ix]=-v[ix];
				}
			}
			while((kk!=ml)&&(s[kk-1]<s[kk]))
			{
				d=s[kk-1];s[kk-1]=s[kk];s[kk]=d;
				if(kk<n)
					for(i=1;i<=n;i++)
					{
						ix=(i-1)*n+kk-1;iy=(i-1)*n+kk;
						d=v[ix];v[ix]=v[iy];v[iy]=d;
					}
					if(kk<m)
						for(i=1;i<=m;i++)
						{
							ix=(i-1)*m+kk-1;
							iy=(i-1)*m+kk;
							d=u[ix];u[ix]=u[iy];u[iy]=d;
						}
						kk=kk+1;
			}
			it=MAX_ITERA;
			mm=mm-1;
		}
		else
		{
			ks=mm;
			//while((ks>kk)&&(fabs(s[ks-1])!=0.0))
			while((ks>kk)&&(fabs(s[ks-1])>MIN_DOUBLE))
			{
				d=0.0;
				if(ks!=mm)
					d=d+fabs(e[ks-1]);
				if(ks!=kk+1) d=d+fabs(e[ks-2]);
				dd=fabs(s[ks-1]);
				if(dd>eps*d)
					ks=ks-1;
				else
					s[ks-1]=0.0;
			}
			if(ks==kk)
			{
				kk=kk+1;
				d=fabs(s[mm-1]);
				t=fabs(s[mm-2]);
				if(t>d)
					d=t;
				t=fabs(e[mm-2]);
				if(t>d)
					d=t;
				t=fabs(s[kk-1]);
				if(t>d)
					d=t;
				t=fabs(e[kk-1]);
				if(t>d)
					d=t;
				sm=s[mm-1]/d;sml=s[mm-2]/d;
				eml=e[mm-2]/d;
				sk=s[kk-1]/d;ek=e[kk-1]/d;
				b=((sml+sm)*(sml-sm)+eml*eml)/2.0;
				c=sm*eml;c=c*c;shh=0.0;
				//if((b!=0.0)||(c!=0.0))
				if((fabs(b)>MIN_DOUBLE)||(fabs(c)>MIN_DOUBLE))
				{
					shh=sqrt(b*b+c);
					if(b<0.0)
						shh=-shh;
					shh=c/(b+shh);
				}
				fg[0]=(sk+sm)*(sk-sm)-shh;
				fg[1]=sk*ek;
				for(i=kk;i<=mm-1;i++)
				{
					sss(fg,cs);
					if(i!=kk)
						e[i-2]=fg[0];
					fg[0]=cs[0]*s[i-1]+cs[1]*e[i-1];
					e[i-1]=cs[0]*e[i-1]-cs[1]*s[i-1];
					fg[1]=cs[1]*s[i];
					s[i]=cs[0]*s[i];
					//if((cs[0]!=1.0)||(cs[1]!=0.0))
					if((fabs(cs[0]-1.0)>MIN_DOUBLE)||(fabs(cs[1])>MIN_DOUBLE))
						for(j=1;j<=n;j++)
						{
							ix=(j-1)*n+i-1;
							iy=(j-1)*n+i;
							d=cs[0]*v[ix]+cs[1]*v[iy];
							v[iy]=-cs[1]*v[ix]+cs[0]*v[iy];
							v[ix]=d;
						}
					sss(fg,cs);
					s[i-1]=fg[0];
					fg[0]=cs[0]*e[i-1]+cs[1]*s[i];
					s[i]=-cs[1]*e[i-1]+cs[0]*s[i];
					fg[1]=cs[1]*e[i];
					e[i]=cs[0]*e[i];
					if(i<m)
						//if((cs[0]!=1.0)||(cs[1]!=0.0))
						if((fabs(cs[0]-1.0)>MIN_DOUBLE)||(fabs(cs[1])>MIN_DOUBLE))
							for(j=1;j<=m;j++)
							{
								ix=(j-1)*m+i-1;
								iy=(j-1)*m+i;
								d=cs[0]*u[ix]+cs[1]*u[iy];
								u[iy]=-cs[1]*u[ix]+cs[0]*u[iy];
								u[ix]=d;
							}
				}
				e[mm-2]=fg[0];
				it=it-1;
			}
			else
			{
				if(ks==mm)
				{
					kk=kk+1;
					fg[1]=e[mm-2];e[mm-2]=0.0;
					for(ll=kk;ll<=mm-1;ll++)
					{
						i=mm+kk-ll-1;
						fg[0]=s[i-1];
						sss(fg,cs);
						s[i-1]=fg[0];
						if(i!=kk)
						{
							fg[1]=-cs[1]*e[i-2];
							e[i-2]=cs[0]*e[i-2];
						}
						//if((cs[0]!=1.0)||(cs[1]!=0.0))
						if((fabs(cs[0]-1.0)>MIN_DOUBLE)||(fabs(cs[1])>MIN_DOUBLE))
							for(j=1;j<=n;j++)
							{
								ix=(j-1)*n+i-1;
								iy=(j-1)*n+mm-1;
								d=cs[0]*v[ix]+cs[1]*v[iy];
								v[iy]=-cs[1]*v[ix]+cs[0]*v[iy];
								v[ix]=d;
							}
					}
				}
				else
				{
					kk=ks+1;
					fg[1]=e[kk-2];
					e[kk-2]=0.0;
					for(i=kk;i<=mm;i++)
					{
						fg[0]=s[i-1];
						sss(fg,cs);
						s[i-1]=fg[0];
						fg[1]=-cs[1]*e[i-1];
						e[i-1]=cs[0]*e[i-1];
						//if((cs[0]!=1.0)||(cs[1]!=0.0))
						if((fabs(cs[0]-1.0)>MIN_DOUBLE)||(fabs(cs[1])>MIN_DOUBLE))
							for(j=1;j<=m;j++)
							{
								ix=(j-1)*m+i-1;
								iy=(j-1)*m+kk-2;
								d=cs[0]*u[ix]+cs[1]*u[iy];								
								u[iy]=-cs[1]*u[ix]+cs[0]*u[iy];
								u[ix]=d;
							}
					}
				}
			}
			}
			}
			free(s);free(e);free(w);
			return l;
}
void ppp(double a[],double e[],double s[],double v[],int m,int n)
{
	int i,j,p,q;
	double d;
	if(m>=n)
		i=n;
	else
		i=m;
	for(j=1;j<=i-1;j++)
	{
		a[(j-1)*n+j-1]=s[j-1];
		a[(j-1)*n+j]=e[j-1];
	}
	a[(i-1)*n+i-1]=s[i-1];
	if(m<n)
		a[(i-1)*n+i]=e[i-1];
	for(i=1;i<=n-1;i++)
	for(j=i+1;j<=n;j++)
	{
		p=(i-1)*n+j-1;
		q=(j-1)*n+i-1;
		d=v[p];v[p]=v[q];v[q]=d;
	}
	return;
}
void sss(double fg[2],double cs[2])
{
	double r,d;
	//if((fabs(fg[0])+fabs(fg[1]))==0.0)
	if((fabs(fg[0])+fabs(fg[1]))<MIN_DOUBLE)
	{
		cs[0]=1.0;cs[1]=0.0;d=0.0;
	}
	else
	{
		d=sqrt(fg[0]*fg[0]+fg[1]*fg[1]);
		if(fabs(fg[0])>fabs(fg[1]))
		{
			d=fabs(d);
			if(fg[0]<0.0)
				d=-d;
		}
		if(fabs(fg[1])>=fabs(fg[0]))
		{
			d=fabs(d);
			if(fg[1]<0.0)
				d=-d;
		}
		cs[0]=fg[0]/d;
		cs[1]=fg[1]/d;
	}
	r=1.0;
	if(fabs(fg[0])>fabs(fg[1]))
		r=cs[1];
	else
		//if(cs[0]!=0.0)
		if(fabs(cs[0])>MIN_DOUBLE)
			r=1.0/cs[0];
	fg[0]=d;
	fg[1]=r;
	return;
}
//矩陣相乘
void damul(double a[],double b[],int m,int n,int k,double c[])
{
	int i,j,l,u;
	for(i=0;i<=m-1;i++)
		for(j=0;j<=k-1;j++)
		{
			u=i*k+j;
			c[u]=0;
			for(l=0;l<=n-1;l++)
				c[u]=c[u]+a[i*n+l]*b[l*k+j];
		}
	return;
}
























?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美亚洲一区二区在线| 亚洲图片欧美一区| 国产九色sp调教91| 久久久久久久性| 国产xxx精品视频大全| 日本一区二区不卡视频| 91农村精品一区二区在线| 亚洲一二三四区| 欧美二区三区的天堂| 美国av一区二区| 中文字幕二三区不卡| 色婷婷一区二区| 日韩成人免费看| 日本一区二区三区免费乱视频| 国产精品伊人色| 亚洲视频每日更新| 欧美一区二区成人6969| 国产高清久久久久| 一个色妞综合视频在线观看| 欧美理论片在线| 国产一区二区剧情av在线| 国产精品欧美久久久久一区二区| 91九色02白丝porn| 男男gaygay亚洲| 国产精品久久久久久久久免费桃花 | 蜜臀av性久久久久蜜臀aⅴ四虎 | 奇米四色…亚洲| 中文字幕国产精品一区二区| 欧美日本一道本在线视频| 青青草国产成人99久久| 中文字幕一区二区三区在线播放 | 久久久久久久久久久久电影 | 极品瑜伽女神91| 最新国产精品久久精品| 日韩欧美一级片| 99热精品国产| 极品少妇xxxx精品少妇偷拍| 亚洲欧美日韩人成在线播放| 精品欧美一区二区久久| 91福利视频久久久久| 国内精品伊人久久久久av一坑 | 国产精品人人做人人爽人人添| 欧美日韩一区三区| 成人av动漫网站| 韩国在线一区二区| 视频在线观看一区二区三区| 欧美激情一区二区三区在线| 欧美日韩另类国产亚洲欧美一级| 国产传媒欧美日韩成人| 全国精品久久少妇| 亚洲美女视频在线观看| 国产欧美日韩中文久久| 日韩美一区二区三区| 欧美日韩精品系列| 91在线视频在线| 成人免费视频视频在线观看免费 | 日韩精品一区二区三区在线播放| 日本韩国一区二区三区视频| 高清不卡一区二区在线| 国产真实精品久久二三区| 日韩福利电影在线观看| 成人激情免费视频| 国精产品一区一区三区mba视频 | 韩国成人精品a∨在线观看| 无码av免费一区二区三区试看| 1000部国产精品成人观看| 国产欧美一区二区三区鸳鸯浴 | 另类小说欧美激情| 视频在线观看91| 偷拍与自拍一区| 午夜精品久久一牛影视| 亚洲国产成人av网| 亚洲www啪成人一区二区麻豆| 亚洲美女屁股眼交3| 亚洲视频免费在线观看| 一区二区三区在线视频免费| 国产精品白丝在线| 亚洲女与黑人做爰| 一个色在线综合| 亚洲成人黄色小说| 日精品一区二区三区| 视频一区免费在线观看| 蜜臀av一区二区三区| 六月丁香婷婷久久| 激情av综合网| 成人永久看片免费视频天堂| 成年人国产精品| 色天使色偷偷av一区二区| 日本韩国欧美三级| 欧美日韩免费观看一区二区三区 | 亚洲最大色网站| 亚洲va欧美va国产va天堂影院| 亚洲va韩国va欧美va精品| 日韩不卡在线观看日韩不卡视频| 蜜芽一区二区三区| 国产乱色国产精品免费视频| 豆国产96在线|亚洲| 91视频在线看| 欧美日韩高清一区二区| 精品国产电影一区二区| 国产精品免费aⅴ片在线观看| 亚洲欧美色一区| 午夜视频在线观看一区| 国产在线一区二区| 91在线高清观看| 日韩一区二区三区av| 欧美激情一区二区三区全黄| 一区二区三区四区不卡视频| 日本网站在线观看一区二区三区 | 欧美一区二区三区白人| 久久综合一区二区| 亚洲色欲色欲www| 蜜臀av性久久久久蜜臀aⅴ流畅| 国产精品一二三区在线| 欧美亚洲日本国产| 亚洲精品一区在线观看| 一区二区三区 在线观看视频| 美女尤物国产一区| 91丨porny丨中文| 一区二区免费在线播放| 男女视频一区二区| 91麻豆免费观看| 日韩精品中文字幕在线不卡尤物 | 欧美日韩日日夜夜| 欧美韩国一区二区| 五月天一区二区| 国产69精品久久99不卡| 欧美精品一二三区| 国产精品久久久久影院亚瑟| 欧美aaaaaa午夜精品| 日本黄色一区二区| 国产亚洲制服色| 日本不卡一二三区黄网| 91亚洲精华国产精华精华液| 欧美成人精品高清在线播放| 亚洲黄色性网站| 成人国产在线观看| 精品欧美乱码久久久久久1区2区| 国产欧美精品在线观看| 蜜桃一区二区三区四区| 在线视频国内一区二区| 国产精品无码永久免费888| 日本在线不卡一区| 97久久超碰国产精品| 久久久99精品久久| 日韩av不卡一区二区| 欧美亚洲高清一区| 亚洲日本在线天堂| av一本久道久久综合久久鬼色| 精品国产百合女同互慰| 日日噜噜夜夜狠狠视频欧美人| 色综合久久99| 亚洲日本丝袜连裤袜办公室| 成人做爰69片免费看网站| 久久久久国产精品人| 黄一区二区三区| 久久久蜜桃精品| 国产一区欧美日韩| 久久综合九色综合欧美就去吻| 日本成人中文字幕| 在线不卡免费av| 日韩va亚洲va欧美va久久| 欧美日韩在线三级| 五月激情综合网| 91精品国产91热久久久做人人| 亚洲v精品v日韩v欧美v专区| 欧美日韩一区成人| 日韩精品乱码免费| 日韩西西人体444www| 日本aⅴ亚洲精品中文乱码| 宅男在线国产精品| 秋霞午夜av一区二区三区| 欧美一区二区三区四区久久| 日韩av成人高清| 久久久久久免费| 成人免费毛片片v| 国产 欧美在线| 国产精品乱人伦中文| 91同城在线观看| 亚洲一区二区三区四区在线观看| 欧美在线免费观看视频| 五月天网站亚洲| 日韩亚洲欧美在线观看| 国产精品一级黄| 亚洲欧美另类久久久精品| 欧美日韩午夜影院| 极品瑜伽女神91| 亚洲人一二三区| 欧美日韩卡一卡二| 国内成人免费视频| 最近日韩中文字幕| 欧美裸体一区二区三区| 久久福利资源站| 亚洲欧洲日韩女同| 欧美日本高清视频在线观看| 黄色小说综合网站| 亚洲天堂精品在线观看| 欧美精品tushy高清| 国产成人av网站| 亚洲午夜免费视频|