xref: /plan9/sys/src/cmd/astro/search.c (revision 7dd7cddf99dd7472612f1413b4da293630e6b1bc)
13e12c5d1SDavid du Colombier #include "astro.h"
23e12c5d1SDavid du Colombier 
33e12c5d1SDavid du Colombier char*	solstr[] =
43e12c5d1SDavid du Colombier {
53e12c5d1SDavid du Colombier 	"Fall equinox",
63e12c5d1SDavid du Colombier 	"Winter solstice",
73e12c5d1SDavid du Colombier 	"Spring equinox",
83e12c5d1SDavid du Colombier 	"Summer solstice",
93e12c5d1SDavid du Colombier };
103e12c5d1SDavid du Colombier 
113e12c5d1SDavid du Colombier struct
123e12c5d1SDavid du Colombier {
133e12c5d1SDavid du Colombier 	double	beta;
143e12c5d1SDavid du Colombier 	int	rta;
153e12c5d1SDavid du Colombier 	int	dec;
163e12c5d1SDavid du Colombier 	char	*betstr;
173e12c5d1SDavid du Colombier } bettab[] =
183e12c5d1SDavid du Colombier {
193e12c5d1SDavid du Colombier 	-1.3572, 231,	50,	"Quadrantid",
203e12c5d1SDavid du Colombier 	 0.7620, 336,	0,	"Eta aquarid",
213e12c5d1SDavid du Colombier 	 1.5497, 260,	-20,	"Ophiuchid",
223e12c5d1SDavid du Colombier 	 2.1324, 315,	-15,	"Capricornid",
233e12c5d1SDavid du Colombier 	 2.1991, 339,	-17,	"Delta aquarid",
243e12c5d1SDavid du Colombier 	 2.2158, 340,	-30,	"Pisces australid",
253e12c5d1SDavid du Colombier 	 2.4331, 46,	58,	"Perseid",
263e12c5d1SDavid du Colombier 	-2.6578, 95,	15,	"Orionid",
273e12c5d1SDavid du Colombier 	-1.8678, 15,	-55,	"Phoenicid",
283e12c5d1SDavid du Colombier 	-1.7260, 113,	32,	"Geminid",
293e12c5d1SDavid du Colombier 	0
303e12c5d1SDavid du Colombier };
313e12c5d1SDavid du Colombier 
323e12c5d1SDavid du Colombier void
search(void)333e12c5d1SDavid du Colombier search(void)
343e12c5d1SDavid du Colombier {
353e12c5d1SDavid du Colombier 	Obj2 *p, *q;
363e12c5d1SDavid du Colombier 	int i, j;
373e12c5d1SDavid du Colombier 	double t;
383e12c5d1SDavid du Colombier 
393e12c5d1SDavid du Colombier 	for(i=0; objlst[i]; i++) {
403e12c5d1SDavid du Colombier 		p = objlst[i];
413e12c5d1SDavid du Colombier 		if(p == &oshad)
423e12c5d1SDavid du Colombier 			continue;
433e12c5d1SDavid du Colombier 		t = rise(p, -.833);
443e12c5d1SDavid du Colombier 		if(t >= 0.)
453e12c5d1SDavid du Colombier 			event("%s rises at ", p->name, "", t,
463e12c5d1SDavid du Colombier 				i==0? PTIME: PTIME|DARK);
473e12c5d1SDavid du Colombier 		t = set(p, -.833);
483e12c5d1SDavid du Colombier 		if(t >= 0.)
493e12c5d1SDavid du Colombier 			event("%s sets at ", p->name, "", t,
503e12c5d1SDavid du Colombier 				i==0? PTIME: PTIME|DARK);
513e12c5d1SDavid du Colombier 		if(p == &osun) {
523e12c5d1SDavid du Colombier 			for(j=0; j<4; j++) {
533e12c5d1SDavid du Colombier 				t = solstice(j);
543e12c5d1SDavid du Colombier 				if(t >= 0)
553e12c5d1SDavid du Colombier 					event("%s at ", solstr[j], "", t,
563e12c5d1SDavid du Colombier 						SIGNIF|PTIME);
573e12c5d1SDavid du Colombier 			}
583e12c5d1SDavid du Colombier 			for(j=0; bettab[j].beta!=0; j++) {
593e12c5d1SDavid du Colombier 				t = betcross(bettab[j].beta);
603e12c5d1SDavid du Colombier 				if(t >= 0)
613e12c5d1SDavid du Colombier 					event("%s  meeteeor shouwer",
623e12c5d1SDavid du Colombier 					bettab[j].betstr, "", t, SIGNIF);
633e12c5d1SDavid du Colombier 			}
643e12c5d1SDavid du Colombier 			t = rise(p, -18);
653e12c5d1SDavid du Colombier 			if(t >= 0)
663e12c5d1SDavid du Colombier 				event("Twilight starts at ", "", "", t, PTIME);
673e12c5d1SDavid du Colombier 			t = set(p, -18);
683e12c5d1SDavid du Colombier 			if(t >= 0)
693e12c5d1SDavid du Colombier 				event("Twilight ends at ", "", "", t, PTIME);
703e12c5d1SDavid du Colombier 		}
713e12c5d1SDavid du Colombier 		if(p == &omoon)
723e12c5d1SDavid du Colombier 		for(j=0; j<NPTS; j++) {
733e12c5d1SDavid du Colombier 			if(p->point[j].mag > .75 && p->point[j+1].mag < .25)
743e12c5d1SDavid du Colombier 				event("New moon", "", "", 0, 0);
753e12c5d1SDavid du Colombier 			if(p->point[j].mag <= .25 && p->point[j+1].mag > .25)
763e12c5d1SDavid du Colombier 				event("First quarter moon", "", "", 0, 0);
773e12c5d1SDavid du Colombier 			if(p->point[j].mag <= .50 && p->point[j+1].mag > .50)
783e12c5d1SDavid du Colombier 				event("Full moon", "", "", 0, 0);
793e12c5d1SDavid du Colombier 			if(p->point[j].mag <= .75 && p->point[j+1].mag > .75)
803e12c5d1SDavid du Colombier 				event("Last quarter moon", "", "", 0, 0);
813e12c5d1SDavid du Colombier 		}
823e12c5d1SDavid du Colombier 		if(p == &omerc || p == &ovenus) {
833e12c5d1SDavid du Colombier 			t = melong(p);
843e12c5d1SDavid du Colombier 			if(t >= 0) {
853e12c5d1SDavid du Colombier 				t = rise(p, 0) - rise(&osun, 0);
86*7dd7cddfSDavid du Colombier 				if(t < 0)
87*7dd7cddfSDavid du Colombier 					t += NPTS;
88*7dd7cddfSDavid du Colombier 				if(t > NPTS)
89*7dd7cddfSDavid du Colombier 					t -= NPTS;
90*7dd7cddfSDavid du Colombier 				if(t > NPTS/2)
913e12c5d1SDavid du Colombier 				event("Morning elongation of %s", p->name,
923e12c5d1SDavid du Colombier 					"", 0, SIGNIF);
933e12c5d1SDavid du Colombier 				else
943e12c5d1SDavid du Colombier 				event("Evening elongation of %s", p->name,
953e12c5d1SDavid du Colombier 					"", 0, SIGNIF);
963e12c5d1SDavid du Colombier 			}
973e12c5d1SDavid du Colombier 		}
983e12c5d1SDavid du Colombier 		for(j=i; objlst[j]; j++) {
993e12c5d1SDavid du Colombier 			if(i == j)
1003e12c5d1SDavid du Colombier 				continue;
1013e12c5d1SDavid du Colombier 			q = objlst[j];
1023e12c5d1SDavid du Colombier 			if(p == &omoon || q == &omoon) {
1033e12c5d1SDavid du Colombier 				occult(p, q, 0);
1043e12c5d1SDavid du Colombier 				if(occ.t3 < 0)
1053e12c5d1SDavid du Colombier 					continue;
1063e12c5d1SDavid du Colombier 				if(p == &osun || q == &oshad) {
1073e12c5d1SDavid du Colombier 					if(occ.t1 >= 0)
1083e12c5d1SDavid du Colombier 					event("Partial eclipse of %s begins at ", p->name, "",
1093e12c5d1SDavid du Colombier 						occ.t1, SIGNIF|PTIME);
1103e12c5d1SDavid du Colombier 					if(occ.t2 >= 0)
1113e12c5d1SDavid du Colombier 					event("Total eclipse of %s begins at ", p->name, "",
1123e12c5d1SDavid du Colombier 						occ.t2, SIGNIF|PTIME);
1133e12c5d1SDavid du Colombier 					if(occ.t4 >= 0)
1143e12c5d1SDavid du Colombier 					event("Total eclipse of %s ends at ", p->name, "",
1153e12c5d1SDavid du Colombier 						occ.t4, SIGNIF|PTIME);
1163e12c5d1SDavid du Colombier 					if(occ.t5 >= 0)
1173e12c5d1SDavid du Colombier 					event("Partial eclipse of %s ends at ", p->name, "",
1183e12c5d1SDavid du Colombier 						occ.t5, SIGNIF|PTIME);
1193e12c5d1SDavid du Colombier 				} else {
1203e12c5d1SDavid du Colombier 					if(occ.t1 >= 0)
1213e12c5d1SDavid du Colombier 					event("Occultation of %s begins at ", q->name, "",
1223e12c5d1SDavid du Colombier 						occ.t1, SIGNIF|PTIME);
1233e12c5d1SDavid du Colombier 					if(occ.t5 >= 0)
1243e12c5d1SDavid du Colombier 					event("Occultation of %s ends at ", q->name, "",
1253e12c5d1SDavid du Colombier 						occ.t5, SIGNIF|PTIME);
1263e12c5d1SDavid du Colombier 				}
1273e12c5d1SDavid du Colombier 				continue;
1283e12c5d1SDavid du Colombier 			}
1293e12c5d1SDavid du Colombier 			if(p == &osun) {
1303e12c5d1SDavid du Colombier 				if(q != &omerc && q != &ovenus)
1313e12c5d1SDavid du Colombier 					continue;
132*7dd7cddfSDavid du Colombier 				occult(p, q, -1);
1333e12c5d1SDavid du Colombier 				if(occ.t3 >= 0.) {
1343e12c5d1SDavid du Colombier 					if(occ.t1 >= 0)
1353e12c5d1SDavid du Colombier 					event("Transit of %s begins at ", q->name, "",
1363e12c5d1SDavid du Colombier 						occ.t1, SIGNIF|LIGHT|PTIME);
1373e12c5d1SDavid du Colombier 					if(occ.t5 >= 0)
1383e12c5d1SDavid du Colombier 					event("Transit of %s ends at ", q->name, "",
1393e12c5d1SDavid du Colombier 						occ.t5, SIGNIF|LIGHT|PTIME);
1403e12c5d1SDavid du Colombier 				}
1413e12c5d1SDavid du Colombier 				continue;
1423e12c5d1SDavid du Colombier 			}
1433e12c5d1SDavid du Colombier 			t = dist(&p->point[0], &q->point[0]);
1443e12c5d1SDavid du Colombier 			if(t > 5000)
1453e12c5d1SDavid du Colombier 				continue;
1463e12c5d1SDavid du Colombier 			event("%s is in the house of %s",
1473e12c5d1SDavid du Colombier 				p->name, q->name, 0, 0);
1483e12c5d1SDavid du Colombier 		}
1493e12c5d1SDavid du Colombier 	}
1503e12c5d1SDavid du Colombier 	if(flags['o'])
1513e12c5d1SDavid du Colombier 		stars();
1523e12c5d1SDavid du Colombier 	if(flags['a'])
1533e12c5d1SDavid du Colombier 		satels();
1543e12c5d1SDavid du Colombier 	evflush();
1553e12c5d1SDavid du Colombier }
156