ref: a7c01127f9749fe471367c6461cde357403cc3b3
dir: /sys/src/cmd/astro/search.c/
#include "astro.h" char* solstr[] = { "Fall equinox", "Winter solstice", "Spring equinox", "Summer solstice", }; struct { double beta; int rta; int dec; char *betstr; } bettab[] = { -1.3572, 231, 50, "Quadrantid", 0.7620, 336, 0, "Eta aquarid", 1.5497, 260, -20, "Ophiuchid", 2.1324, 315, -15, "Capricornid", 2.1991, 339, -17, "Delta aquarid", 2.2158, 340, -30, "Pisces australid", 2.4331, 46, 58, "Perseid", -2.6578, 95, 15, "Orionid", -1.8678, 15, -55, "Phoenicid", -1.7260, 113, 32, "Geminid", 0 }; void search(void) { Obj2 *p, *q; int i, j; double t; for(i=0; objlst[i]; i++) { p = objlst[i]; if(p == &oshad) continue; t = rise(p, -.833); if(t >= 0.) event("%s rises at ", p->name, "", t, i==0? PTIME: PTIME|DARK); t = set(p, -.833); if(t >= 0.) event("%s sets at ", p->name, "", t, i==0? PTIME: PTIME|DARK); if(p == &osun) { for(j=0; j<4; j++) { t = solstice(j); if(t >= 0) event("%s at ", solstr[j], "", t, SIGNIF|PTIME); } for(j=0; bettab[j].beta!=0; j++) { t = betcross(bettab[j].beta); if(t >= 0) event("%s meteor shower", bettab[j].betstr, "", t, SIGNIF); } t = rise(p, -18); if(t >= 0) event("Twilight starts at ", "", "", t, PTIME); t = set(p, -18); if(t >= 0) event("Twilight ends at ", "", "", t, PTIME); } if(p == &omoon) for(j=0; j<NPTS; j++) { if(p->point[j].mag > .75 && p->point[j+1].mag < .25) event("New moon", "", "", 0, 0); if(p->point[j].mag <= .25 && p->point[j+1].mag > .25) event("First quarter moon", "", "", 0, 0); if(p->point[j].mag <= .50 && p->point[j+1].mag > .50) event("Full moon", "", "", 0, 0); if(p->point[j].mag <= .75 && p->point[j+1].mag > .75) event("Last quarter moon", "", "", 0, 0); } if(p == &omerc || p == &ovenus) { t = melong(p); if(t >= 0) { t = rise(p, 0) - rise(&osun, 0); if(t < 0) t += NPTS; if(t > NPTS) t -= NPTS; if(t > NPTS/2) event("Morning elongation of %s", p->name, "", 0, SIGNIF); else event("Evening elongation of %s", p->name, "", 0, SIGNIF); } } for(j=i; objlst[j]; j++) { if(i == j) continue; q = objlst[j]; if(p == &omoon || q == &omoon) { occult(p, q, 0); if(occ.t3 < 0) continue; if(p == &osun || q == &oshad) { if(occ.t1 >= 0) event("Partial eclipse of %s begins at ", p->name, "", occ.t1, SIGNIF|PTIME); if(occ.t2 >= 0) event("Total eclipse of %s begins at ", p->name, "", occ.t2, SIGNIF|PTIME); if(occ.t4 >= 0) event("Total eclipse of %s ends at ", p->name, "", occ.t4, SIGNIF|PTIME); if(occ.t5 >= 0) event("Partial eclipse of %s ends at ", p->name, "", occ.t5, SIGNIF|PTIME); } else { if(occ.t1 >= 0) event("Occultation of %s begins at ", q->name, "", occ.t1, SIGNIF|PTIME); if(occ.t5 >= 0) event("Occultation of %s ends at ", q->name, "", occ.t5, SIGNIF|PTIME); } continue; } if(p == &osun) { if(q != &omerc && q != &ovenus) continue; occult(p, q, -1); if(occ.t3 >= 0.) { if(occ.t1 >= 0) event("Transit of %s begins at ", q->name, "", occ.t1, SIGNIF|LIGHT|PTIME); if(occ.t5 >= 0) event("Transit of %s ends at ", q->name, "", occ.t5, SIGNIF|LIGHT|PTIME); } continue; } t = dist(&p->point[0], &q->point[0]); if(t > 5000) continue; event("%s is in the house of %s", p->name, q->name, 0, 0); } } if(flags['o']) stars(); if(flags['a']) satels(); evflush(); }