amotsa.c

来自「适合大型数值计算代码 现在网络上已经找不到了 购买需要20$」· C语言 代码 · 共 39 行

C
39
字号
#include <math.h>#define NRANSI#include "nrutil.h"extern long idum;extern float tt;float amotsa(float **p, float y[], float psum[], int ndim, float pb[],	float *yb, float (*funk)(float []), int ihi, float *yhi, float fac){	float ran1(long *idum);	int j;	float fac1,fac2,yflu,ytry,*ptry;	ptry=vector(1,ndim);	fac1=(1.0-fac)/ndim;	fac2=fac1-fac;	for (j=1;j<=ndim;j++)		ptry[j]=psum[j]*fac1-p[ihi][j]*fac2;	ytry=(*funk)(ptry);	if (ytry <= *yb) {		for (j=1;j<=ndim;j++) pb[j]=ptry[j];		*yb=ytry;	}	yflu=ytry-tt*log(ran1(&idum));	if (yflu < *yhi) {		y[ihi]=ytry;		*yhi=yflu;		for (j=1;j<=ndim;j++) {			psum[j] += ptry[j]-p[ihi][j];			p[ihi][j]=ptry[j];		}	}	free_vector(ptry,1,ndim);	return yflu;}#undef NRANSI

⌨️ 快捷键说明

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