| 1 | #include <math.h>
 | 
|---|
| 2 | 
 | 
|---|
| 3 | #include "astro.h"
 | 
|---|
| 4 | 
 | 
|---|
| 5 | #undef sqr
 | 
|---|
| 6 | #define sqr(x)          ((x)*(x))
 | 
|---|
| 7 | 
 | 
|---|
| 8 | /* given a planet, the sun, the planet's eq pole position and a
 | 
|---|
| 9 |  * position of a satellite (as eq x=+e y=+s z=front in planet radii) find x,y
 | 
|---|
| 10 |  * position of shadow.
 | 
|---|
| 11 |  * return 0 if ok else -1 if shadow not on planet
 | 
|---|
| 12 |  */
 | 
|---|
| 13 | int
 | 
|---|
| 14 | plshadow (Obj *op, Obj *sop, double polera, double poledec, double x,
 | 
|---|
| 15 | double y, double z, float *sxp, float *syp)
 | 
|---|
| 16 | {
 | 
|---|
| 17 |         /* equatorial to ecliptic sky-plane rotation */
 | 
|---|
| 18 |         double sa = cos(op->s_dec) * cos(poledec) *
 | 
|---|
| 19 |                         (cos(op->s_ra)*sin(polera) - sin(op->s_ra)*cos(polera));
 | 
|---|
| 20 |         double ca = sqrt (1.0 - sa*sa);
 | 
|---|
| 21 | 
 | 
|---|
| 22 |         /* rotate moon from equatorial to ecliptic */
 | 
|---|
| 23 |         double ex =  x*ca + y*sa;
 | 
|---|
| 24 |         double ey = -x*sa + y*ca;
 | 
|---|
| 25 | 
 | 
|---|
| 26 |         /* find angle subtended by earth-sun from planet */
 | 
|---|
| 27 |         double a = asin (sin(op->s_hlong - sop->s_hlong)/op->s_edist);
 | 
|---|
| 28 |         double b = asin (-sin(op->s_hlat)/op->s_edist);
 | 
|---|
| 29 | 
 | 
|---|
| 30 |         /* find displacement in sky plane */
 | 
|---|
| 31 |         double x0 = ex - z*tan(a);
 | 
|---|
| 32 |         double y0 = ey - z*tan(b);
 | 
|---|
| 33 | 
 | 
|---|
| 34 |         /* projection onto unit sphere */
 | 
|---|
| 35 |         double x1 = x0 + (ex-x0)/sqrt(sqr(ex-x0)+sqr(z));
 | 
|---|
| 36 |         double y1 = y0 + (ey-y0)/sqrt(sqr(ey-y0)+sqr(z));
 | 
|---|
| 37 | 
 | 
|---|
| 38 |         /* check behind or off edge */
 | 
|---|
| 39 |         if (z < 0 || sqr(x1) + sqr(y1) > 1)
 | 
|---|
| 40 |             return (-1);
 | 
|---|
| 41 | 
 | 
|---|
| 42 |         /* rotate back to equatorial */
 | 
|---|
| 43 |         *sxp = x1*ca - y1*sa;
 | 
|---|
| 44 |         *syp = x1*sa + y1*ca;
 | 
|---|
| 45 | 
 | 
|---|
| 46 |         return (0);
 | 
|---|
| 47 | }
 | 
|---|
| 48 | 
 | 
|---|
| 49 | /* For RCS Only -- Do Not Edit */
 | 
|---|
| 50 | static char *rcsid[2] = {(char *)rcsid, "@(#) $RCSfile: plshadow.c,v $ $Date: 2005-01-17 10:13:06 $ $Revision: 1.2 $ $Name: not supported by cvs2svn $"};
 | 
|---|