sun.c 2.2 KB

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