midexp.c

来自「数值算法」· C语言 代码 · 共 38 行

C
38
字号
#include <math.h>

#define FUNC(x) ((*funk)(-log(x))/(x))

float midexp(funk,aa,bb,n)
float aa,bb;
float (*funk)();	/* ANSI: float (*funk)(float); */
int n;
{
	float x,tnm,sum,del,ddel,b,a;
	static float s;
	static int it;
	int j;

	b=exp(-aa);
	a=0.0;
	if (n == 1) {
		it=1;
		return (s=(b-a)*FUNC(0.5*(a+b)));
	} else {
		tnm=it;
		del=(b-a)/(3.0*tnm);
		ddel=del+del;
		x=a+0.5*del;
		sum=0.0;
		for (j=1;j<=it;j++) {
			sum += FUNC(x);
			x += ddel;
			sum += FUNC(x);
			x += del;
		}
		it *= 3;
		return (s=(s+(b-a)*sum/tnm)/3.0);
	}
}

#undef FUNC

⌨️ 快捷键说明

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