Subversion Repositories planix.SVN

Rev

Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed

#include "astro.h"

void
sun(void)
{
        double mven, merth, mmars, mjup, msat;
        double dmoon, mmoon, gmoon;
        double pturbb, pturbl, pturbr, lograd;

        ecc = .01675104 - 4.180e-5 * capt - 1.26e-7*capt2;
        incl = 0;
        node = 0;
        argp = 281.220833 + .0000470684*eday + .000453*capt2
                 + .000003*capt3;
        mrad = 1;
        anom = 358.475845 + .9856002670*eday - .000150*capt2
                 - .000003*capt3;
        motion = .9856473354;

        dmoon = 350.737681+12.1907491914*eday-.001436*capt2;
        gmoon = 11.250889 + 13.2293504490*eday - .003212*capt2;
        mmoon = 296.104608 + 13.0649924465*eday + 9.192e-3*capt2;
        mven  = 212.448 + 1.602121635*eday;
        merth = 358.476 + 0.985600267*eday;
        mmars = 319.590 + .524024095*eday;
        mjup = 225.269 + .083082362*eday;
        msat  = 175.593 + .033450794*eday;

        dmoon = fmod(dmoon, 360.)*radian;
        gmoon = fmod(gmoon, 360.)*radian;
        mmoon = fmod(mmoon, 360.)*radian;
        mven  *= radian;
        merth *= radian;
        mmars *= radian;
        mjup *= radian;
        msat  *= radian;

        icosadd(sunfp, suncp);
        anom += cosadd(4, mmars, merth, mven, mjup)/3600.;
        anom += sinadd(5, mmars, merth, mven, mjup, .07884*capt)/3600.;

        incl *= radian;
        node *= radian;
        argp *= radian;
        anom = fmod(anom, 360.)*radian;

/*
 *      computation of elliptic orbit
 */

        lambda = anom + argp;

        pturbl = (6910.057 - 17.240*capt - 0.052*capt2)*sin(anom)
                 + (72.338 - 0.361*capt) * sin(2.*anom)
                 + (1.054 - 0.001*capt) * sin(3.*anom)
                 + 0.018 * sin(4.*anom);

        lambda += pturbl*radsec;

        beta = 0.;

        lograd = (30.57e-6 - 0.15e-6*capt)
                 - (7274.12e-6 - 18.14e-6*capt - 0.05e-6*capt2)*cos(anom)
                 - (91.38e-6 - 0.46e-6*capt) * cos(2.*anom)
                 - (1.45e-6 - 0.01e-6*capt) * cos(3.*anom)
                 - 0.02e-6 * cos(4.*anom);

        pturbl = cosadd(5, mmars, merth, mven, mjup, msat);
        pturbl += sinadd(3, dmoon, mmoon, merth) + .9;
        pturbl *= radsec;

        pturbb =  cosadd(3, merth, mven, mjup);
        pturbb += sinadd(3, gmoon, mmoon, dmoon);
        pturbb *= radsec;

        pturbr =  cosadd(5, mmars, merth, mven, mjup, msat);
        pturbr += cosadd(3, dmoon, mmoon, merth);

        lambda += pturbl;
        if(lambda > pipi)
                lambda -= pipi;

        beta += pturbb;

        lograd = (lograd+pturbr) * 2.30258509;
        rad = 1 + lograd * (1 + lograd * (.5 + lograd/6));

        motion *= radian*mrad*mrad/(rad*rad);

        semi = 961.182;
        if(flags['o'])
                semi = 959.63;
        mag = -26.5;
}