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

📄 fit.c

📁 适合大型数值计算代码 现在网络上已经找不到了 购买需要20$
💻 C
字号:
#include <math.h>#define NRANSI#include "nrutil.h"void fit(float x[], float y[], int ndata, float sig[], int mwt, float *a,	float *b, float *siga, float *sigb, float *chi2, float *q){	float gammq(float a, float x);	int i;	float wt,t,sxoss,sx=0.0,sy=0.0,st2=0.0,ss,sigdat;	*b=0.0;	if (mwt) {		ss=0.0;		for (i=1;i<=ndata;i++) {			wt=1.0/SQR(sig[i]);			ss += wt;			sx += x[i]*wt;			sy += y[i]*wt;		}	} else {		for (i=1;i<=ndata;i++) {			sx += x[i];			sy += y[i];		}		ss=ndata;	}	sxoss=sx/ss;	if (mwt) {		for (i=1;i<=ndata;i++) {			t=(x[i]-sxoss)/sig[i];			st2 += t*t;			*b += t*y[i]/sig[i];		}	} else {		for (i=1;i<=ndata;i++) {			t=x[i]-sxoss;			st2 += t*t;			*b += t*y[i];		}	}	*b /= st2;	*a=(sy-sx*(*b))/ss;	*siga=sqrt((1.0+sx*sx/(ss*st2))/ss);	*sigb=sqrt(1.0/st2);	*chi2=0.0;	if (mwt == 0) {		for (i=1;i<=ndata;i++)			*chi2 += SQR(y[i]-(*a)-(*b)*x[i]);		*q=1.0;		sigdat=sqrt((*chi2)/(ndata-2));		*siga *= sigdat;		*sigb *= sigdat;	} else {		for (i=1;i<=ndata;i++)			*chi2 += SQR((y[i]-(*a)-(*b)*x[i])/sig[i]);		*q=gammq(0.5*(ndata-2),0.5*(*chi2));	}}#undef NRANSI

⌨️ 快捷键说明

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