File: Astro.cpp

package info (click to toggle)
xygrib 1.2.6.1-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 32,024 kB
  • sloc: cpp: 28,210; ansic: 2,636; sh: 158; xml: 144; makefile: 12
file content (61 lines) | stat: -rw-r--r-- 2,133 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
/**********************************************************************
XyGrib: meteorological GRIB file viewer
Copyright (C) 2008-2012 - Jacques Zaninetti - http://www.zygrib.org

This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program.  If not, see <http://www.gnu.org/licenses/>.
***********************************************************************/

#include "Astro.h"


//----------------------------------------------------------------
Almanac Astro::getSunMoonAlmanac (time_t t, double lat, double lon)
{
	struct ln_rst_time rst;
	struct ln_lnlat_posn observer;
	double JD;
	Almanac alm;
	alm.date = t;
	alm.lat = lat;
	alm.lon = lon;
	observer.lat = lat; 
	observer.lng = lon;  
	t = Util::timestampSetHour (t, 0,0,0);		// the day begins at midnight
	JD = ln_get_julian_from_timet (&t);  
	//----------------------------------------
	if (ln_get_solar_rst (JD, &observer, &rst) == 1)  {
			alm.sunRise = alm.sunTransit = alm.sunSet = 0;  // Sun is circumpolar 
	}
	else {
			ln_get_timet_from_julian (rst.rise,    &alm.sunRise);
			ln_get_timet_from_julian (rst.transit, &alm.sunTransit);
			ln_get_timet_from_julian (rst.set,     &alm.sunSet);
	}
	//----------------------------------------
	if (ln_get_lunar_rst (JD, &observer, &rst) == 1)  {
			alm.moonRise = alm.moonTransit = alm.moonSet = 0;  // Sun is circumpolar 
	}
	else {
			ln_get_timet_from_julian (rst.rise,    &alm.moonRise);
			ln_get_timet_from_julian (rst.transit, &alm.moonTransit);
			ln_get_timet_from_julian (rst.set,     &alm.moonSet);
	}
	alm.moonPhase = ln_get_lunar_phase (JD);
	alm.moonDisk = ln_get_lunar_disk (JD);
	return alm;
}