Subversion Repositories planix.SVN

Rev

Rev 2 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
2 - 1
#include "astro.h"
2
 
3
void
4
sun(void)
5
{
6
	double mven, merth, mmars, mjup, msat;
7
	double dmoon, mmoon, gmoon;
8
	double pturbb, pturbl, pturbr, lograd;
9
 
10
	ecc = .01675104 - 4.180e-5 * capt - 1.26e-7*capt2;
11
	incl = 0;
12
	node = 0;
13
	argp = 281.220833 + .0000470684*eday + .000453*capt2
14
		 + .000003*capt3;
15
	mrad = 1;
16
	anom = 358.475845 + .9856002670*eday - .000150*capt2
17
		 - .000003*capt3;
18
	motion = .9856473354;
19
 
20
	dmoon = 350.737681+12.1907491914*eday-.001436*capt2;
21
	gmoon = 11.250889 + 13.2293504490*eday - .003212*capt2;
22
	mmoon = 296.104608 + 13.0649924465*eday + 9.192e-3*capt2;
23
	mven  = 212.448 + 1.602121635*eday;
24
	merth = 358.476 + 0.985600267*eday;
25
	mmars = 319.590 + .524024095*eday;
26
	mjup = 225.269 + .083082362*eday;
27
	msat  = 175.593 + .033450794*eday;
28
 
29
	dmoon = fmod(dmoon, 360.)*radian;
30
	gmoon = fmod(gmoon, 360.)*radian;
31
	mmoon = fmod(mmoon, 360.)*radian;
32
	mven  *= radian;
33
	merth *= radian;
34
	mmars *= radian;
35
	mjup *= radian;
36
	msat  *= radian;
37
 
38
	icosadd(sunfp, suncp);
39
	anom += cosadd(4, mmars, merth, mven, mjup)/3600.;
40
	anom += sinadd(5, mmars, merth, mven, mjup, .07884*capt)/3600.;
41
 
42
	incl *= radian;
43
	node *= radian;
44
	argp *= radian;
45
	anom = fmod(anom, 360.)*radian;
46
 
47
/*
48
 *	computation of elliptic orbit
49
 */
50
 
51
	lambda = anom + argp;
52
 
53
	pturbl = (6910.057 - 17.240*capt - 0.052*capt2)*sin(anom)
54
		 + (72.338 - 0.361*capt) * sin(2.*anom)
55
		 + (1.054 - 0.001*capt) * sin(3.*anom)
56
		 + 0.018 * sin(4.*anom);
57
 
58
	lambda += pturbl*radsec;
59
 
60
	beta = 0.;
61
 
62
	lograd = (30.57e-6 - 0.15e-6*capt)
63
		 - (7274.12e-6 - 18.14e-6*capt - 0.05e-6*capt2)*cos(anom)
64
		 - (91.38e-6 - 0.46e-6*capt) * cos(2.*anom)
65
		 - (1.45e-6 - 0.01e-6*capt) * cos(3.*anom)
66
		 - 0.02e-6 * cos(4.*anom);
67
 
68
	pturbl = cosadd(5, mmars, merth, mven, mjup, msat);
69
	pturbl += sinadd(3, dmoon, mmoon, merth) + .9;
70
	pturbl *= radsec;
71
 
72
	pturbb =  cosadd(3, merth, mven, mjup);
73
	pturbb += sinadd(3, gmoon, mmoon, dmoon);
74
	pturbb *= radsec;
75
 
76
	pturbr =  cosadd(5, mmars, merth, mven, mjup, msat);
77
	pturbr += cosadd(3, dmoon, mmoon, merth);
78
 
79
	lambda += pturbl;
80
	if(lambda > pipi)
81
		lambda -= pipi;
82
 
83
	beta += pturbb;
84
 
85
	lograd = (lograd+pturbr) * 2.30258509;
86
	rad = 1 + lograd * (1 + lograd * (.5 + lograd/6));
87
 
88
	motion *= radian*mrad*mrad/(rad*rad);
89
 
90
	semi = 961.182;
91
	if(flags['o'])
92
		semi = 959.63;
93
	mag = -26.5;
94
}