flmoon.c

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

C
30
字号
#include <math.h>

#define RAD (3.14159265/180.0)

void flmoon(n,nph,jd,frac)
int n,nph;
long *jd;
float *frac;
{
	int i;
	float am,as,c,t,t2,xtra;
	void nrerror();

	c=n+nph/4.0;
	t=c/1236.85;
	t2=t*t;
	as=359.2242+29.105356*c;
	am=306.0253+385.816918*c+0.010730*t2;
	*jd=2415020+28L*n+7L*nph;
	xtra=0.75933+1.53058868*c+((1.178e-4)-(1.55e-7)*t)*t2;
	if (nph == 0 || nph == 2)
		xtra += (0.1734-3.93e-4*t)*sin(RAD*as)-0.4068*sin(RAD*am);
	else if (nph == 1 || nph == 3)
		xtra += (0.1721-4.0e-4*t)*sin(RAD*as)-0.6280*sin(RAD*am);
	else nrerror("nph is unknown in FLMOON");
	i=(xtra >= 0.0 ? (int) floor(xtra) : (int) ceil(xtra-1.0));
	*jd += i;
	*frac=xtra-i;
}

⌨️ 快捷键说明

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