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

📄 medfit.c

📁 适合大型数值计算代码 现在网络上已经找不到了 购买需要20$
💻 C
字号:
#include <math.h>#define NRANSI#include "nrutil.h"int ndatat;float *xt,*yt,aa,abdevt;void medfit(float x[], float y[], int ndata, float *a, float *b, float *abdev){	float rofunc(float b);	int j;	float bb,b1,b2,del,f,f1,f2,sigb,temp;	float sx=0.0,sy=0.0,sxy=0.0,sxx=0.0,chisq=0.0;	ndatat=ndata;	xt=x;	yt=y;	for (j=1;j<=ndata;j++) {		sx += x[j];		sy += y[j];		sxy += x[j]*y[j];		sxx += x[j]*x[j];	}	del=ndata*sxx-sx*sx;	aa=(sxx*sy-sx*sxy)/del;	bb=(ndata*sxy-sx*sy)/del;	for (j=1;j<=ndata;j++)		chisq += (temp=y[j]-(aa+bb*x[j]),temp*temp);	sigb=sqrt(chisq/del);	b1=bb;	f1=rofunc(b1);	b2=bb+SIGN(3.0*sigb,f1);	f2=rofunc(b2);	if (b2 == b1) {		*a=aa;		*b=bb;		*abdev=abdevt/ndata;		return;	}	while (f1*f2 > 0.0) {		bb=b2+1.6*(b2-b1);		b1=b2;		f1=f2;		b2=bb;		f2=rofunc(b2);	}	sigb=0.01*sigb;	while (fabs(b2-b1) > sigb) {		bb=b1+0.5*(b2-b1);		if (bb == b1 || bb == b2) break;		f=rofunc(bb);		if (f*f1 >= 0.0) {			f1=f;			b1=bb;		} else {			f2=f;			b2=bb;		}	}	*a=aa;	*b=bb;	*abdev=abdevt/ndata;}#undef NRANSI

⌨️ 快捷键说明

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