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

📄 sobseq.c

📁 适合大型数值计算代码 现在网络上已经找不到了 购买需要20$
💻 C
字号:
#define NRANSI#include "nrutil.h"#define MAXBIT 30#define MAXDIM 6void sobseq(int *n, float x[]){	int j,k,l;	unsigned long i,im,ipp;	static float fac;	static unsigned long in,ix[MAXDIM+1],*iu[MAXBIT+1];	static unsigned long mdeg[MAXDIM+1]={0,1,2,3,3,4,4};	static unsigned long ip[MAXDIM+1]={0,0,1,1,2,1,4};	static unsigned long iv[MAXDIM*MAXBIT+1]={		0,1,1,1,1,1,1,3,1,3,3,1,1,5,7,7,3,3,5,15,11,5,15,13,9};	if (*n < 0) {		for (k=1;k<=MAXDIM;k++) ix[k]=0;		in=0;		if (iv[1] != 1) return;		fac=1.0/(1L << MAXBIT);		for (j=1,k=0;j<=MAXBIT;j++,k+=MAXDIM) iu[j] = &iv[k];		for (k=1;k<=MAXDIM;k++) {			for (j=1;j<=mdeg[k];j++) iu[j][k] <<= (MAXBIT-j);			for (j=mdeg[k]+1;j<=MAXBIT;j++) {				ipp=ip[k];				i=iu[j-mdeg[k]][k];				i ^= (i >> mdeg[k]);				for (l=mdeg[k]-1;l>=1;l--) {					if (ipp & 1) i ^= iu[j-l][k];					ipp >>= 1;				}				iu[j][k]=i;			}		}	} else {		im=in++;		for (j=1;j<=MAXBIT;j++) {			if (!(im & 1)) break;			im >>= 1;		}		if (j > MAXBIT) nrerror("MAXBIT too small in sobseq");		im=(j-1)*MAXDIM;		for (k=1;k<=IMIN(*n,MAXDIM);k++) {			ix[k] ^= iv[im+k];			x[k]=ix[k]*fac;		}	}}#undef MAXBIT#undef MAXDIM#undef NRANSI

⌨️ 快捷键说明

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