⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 svdcmp.c

📁 学习跟踪的好程序
💻 C
字号:
#include <math.h>#define NRANSI#include "nrutil.h"void svdcmp(float **a, int m, int n, float w[], float **v){	float pythag(float a, float b);	int flag,i,its,j,jj,k,l,nm;	float anorm,c,f,g,h,s,scale,x,y,z,*rv1;	rv1=vector(1,n);	g=scale=anorm=0.0;	for (i=1;i<=n;i++) {		l=i+1;		rv1[i]=scale*g;		g=s=scale=0.0;		if (i <= m) {			for (k=i;k<=m;k++) scale += (float)fabs(a[k][i]);			if (scale) {				for (k=i;k<=m;k++) {					a[k][i] /= scale;					s += a[k][i]*a[k][i];				}				f=a[i][i];				g = (float)(-SIGN(sqrt(s),f));				h=f*g-s;				a[i][i]=f-g;				for (j=l;j<=n;j++) {					for (s=0.0,k=i;k<=m;k++) s += a[k][i]*a[k][j];					f=s/h;					for (k=i;k<=m;k++) a[k][j] += f*a[k][i];				}				for (k=i;k<=m;k++) a[k][i] *= scale;			}		}		w[i]=scale *g;		g=s=scale=0.0;		if (i <= m && i != n) {			for (k=l;k<=n;k++) scale += (float)fabs(a[i][k]);			if (scale) {				for (k=l;k<=n;k++) {					a[i][k] /= scale;					s += a[i][k]*a[i][k];				}				f=a[i][l];				g = (float)(-SIGN(sqrt(s),f));				h=f*g-s;				a[i][l]=f-g;				for (k=l;k<=n;k++) rv1[k]=a[i][k]/h;				for (j=l;j<=m;j++) {					for (s=0.0,k=l;k<=n;k++) s += a[j][k]*a[i][k];					for (k=l;k<=n;k++) a[j][k] += s*rv1[k];				}				for (k=l;k<=n;k++) a[i][k] *= scale;			}		}		anorm=FMAX(anorm,(float)(fabs(w[i])+fabs(rv1[i])));	}	for (i=n;i>=1;i--) {		if (i < n) {			if (g) {				for (j=l;j<=n;j++)					v[j][i]=(a[i][j]/a[i][l])/g;				for (j=l;j<=n;j++) {					for (s=0.0,k=l;k<=n;k++) s += a[i][k]*v[k][j];					for (k=l;k<=n;k++) v[k][j] += s*v[k][i];				}			}			for (j=l;j<=n;j++) v[i][j]=v[j][i]=0.0;		}		v[i][i]=1.0;		g=rv1[i];		l=i;	}	for (i=IMIN(m,n);i>=1;i--) {		l=i+1;		g=w[i];		for (j=l;j<=n;j++) a[i][j]=0.0;		if (g) {			g=(float)1.0/g;			for (j=l;j<=n;j++) {				for (s=0.0,k=l;k<=m;k++) s += a[k][i]*a[k][j];				f=(s/a[i][i])*g;				for (k=i;k<=m;k++) a[k][j] += f*a[k][i];			}			for (j=i;j<=m;j++) a[j][i] *= g;		} else for (j=i;j<=m;j++) a[j][i]=0.0;		++a[i][i];	}	for (k=n;k>=1;k--) {		for (its=1;its<=30;its++) {			flag=1;			for (l=k;l>=1;l--) {				nm=l-1;				if ((float)(fabs(rv1[l])+anorm) == anorm) {					flag=0;					break;				}				if ((float)(fabs(w[nm])+anorm) == anorm) break;			}			if (flag) {				c=0.0;				s=1.0;				for (i=l;i<=k;i++) {					f=s*rv1[i];					rv1[i]=c*rv1[i];					if ((float)(fabs(f)+anorm) == anorm) break;					g=w[i];					h=pythag(f,g);					w[i]=h;					h=(float)1.0/h;					c=g*h;					s = -f*h;					for (j=1;j<=m;j++) {						y=a[j][nm];						z=a[j][i];						a[j][nm]=y*c+z*s;						a[j][i]=z*c-y*s;					}				}			}			z=w[k];			if (l == k) {				if (z < 0.0) {					w[k] = -z;					for (j=1;j<=n;j++) v[j][k] = -v[j][k];				}				break;			}			if (its == 30) {			
				//nrerror("no convergence in 30 svdcmp iterations");
				break;
			}			x=w[l];			nm=k-1;			y=w[nm];			g=rv1[nm];			h=rv1[k];			f=(float)(((y-z)*(y+z)+(g-h)*(g+h))/(2.0*h*y));			g=pythag(f,1.0);			f=(float)(((x-z)*(x+z)+h*((y/(f+SIGN(g,f)))-h))/x);			c=s=1.0;			for (j=l;j<=nm;j++) {				i=j+1;				g=rv1[i];				y=w[i];				h=s*g;				g=c*g;				z=pythag(f,h);				rv1[j]=z;				c=f/z;				s=h/z;				f=x*c+g*s;				g = g*c-x*s;				h=y*s;				y *= c;				for (jj=1;jj<=n;jj++) {					x=v[jj][j];					z=v[jj][i];					v[jj][j]=x*c+z*s;					v[jj][i]=z*c-x*s;				}				z=pythag(f,h);				w[j]=z;				if (z) {					z=(float)1.0/z;					c=f*z;					s=h*z;				}				f=c*g+s*y;				x=c*y-s*g;				for (jj=1;jj<=m;jj++) {					y=a[jj][j];					z=a[jj][i];					a[jj][j]=y*c+z*s;					a[jj][i]=z*c-y*s;				}			}			rv1[l]=0.0;			rv1[k]=f;			w[k]=x;		}	}	free_vector(rv1,1,n);}#undef NRANSI

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -