poidev.c

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

C
42
字号
#include <math.h>#define PI 3.141592654float poidev(float xm, long *idum){	float gammln(float xx);	float ran1(long *idum);	static float sq,alxm,g,oldm=(-1.0);	float em,t,y;	if (xm < 12.0) {		if (xm != oldm) {			oldm=xm;			g=exp(-xm);		}		em = -1;		t=1.0;		do {			++em;			t *= ran1(idum);		} while (t > g);	} else {		if (xm != oldm) {			oldm=xm;			sq=sqrt(2.0*xm);			alxm=log(xm);			g=xm*alxm-gammln(xm+1.0);		}		do {			do {				y=tan(PI*ran1(idum));				em=sq*y+xm;			} while (em < 0.0);			em=floor(em);			t=0.9*(1.0+y*y)*exp(em*alxm-gammln(em+1.0)-g);		} while (ran1(idum) > t);	}	return em;}#undef PI

⌨️ 快捷键说明

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