libnova v 0.16.0
Loading...
Searching...
No Matches
lunar.h
1/*
2 * This library is free software; you can redistribute it and/or
3 * modify it under the terms of the GNU Lesser General Public
4 * License as published by the Free Software Foundation; either
5 * version 2 of the License, or (at your option) any later version.
6 *
7 * This library is distributed in the hope that it will be useful,
8 * but WITHOUT ANY WARRANTY; without even the implied warranty of
9 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
10 * Lesser General Public License for more details.
11 *
12 * You should have received a copy of the GNU General Public License
13 * along with this program; if not, write to the Free Software
14 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
15 *
16 * Copyright (C) 2000 - 2005 Liam Girdwood
17 */
18
19#ifndef _LN_LUNAR_H
20#define _LN_LUNAR_H
21
22#include <libnova/ln_types.h>
23
24#define LN_LUNAR_STANDART_HORIZON 0.125
25
26#ifdef __cplusplus
27extern "C" {
28#endif
29
41double LIBNOVA_EXPORT ln_get_lunar_sdiam(double JD);
42
48int LIBNOVA_EXPORT ln_get_lunar_rst(double JD, struct ln_lnlat_posn *observer,
49 struct ln_rst_time *rst);
50
55/* ELP 2000-82B theory */
56void LIBNOVA_EXPORT ln_get_lunar_geo_posn(double JD, struct ln_rect_posn *moon,
57 double precision);
58
63void LIBNOVA_EXPORT ln_get_lunar_equ_coords_prec(double JD,
64 struct ln_equ_posn *position, double precision);
65
70void LIBNOVA_EXPORT ln_get_lunar_equ_coords(double JD,
71 struct ln_equ_posn *position);
72
77void LIBNOVA_EXPORT ln_get_lunar_ecl_coords(double JD,
78 struct ln_lnlat_posn *position, double precision);
79
84double LIBNOVA_EXPORT ln_get_lunar_phase(double JD);
85
90double LIBNOVA_EXPORT ln_get_lunar_disk(double JD);
91
96double LIBNOVA_EXPORT ln_get_lunar_earth_dist(double JD);
97
102double LIBNOVA_EXPORT ln_get_lunar_bright_limb(double JD);
103
108double LIBNOVA_EXPORT ln_get_lunar_long_asc_node(double JD);
109
114double LIBNOVA_EXPORT ln_get_lunar_long_perigee(double JD);
115
120double LIBNOVA_EXPORT ln_get_lunar_arg_latitude(double JD);
121
126void LIBNOVA_EXPORT ln_get_lunar_opt_libr_coords(double JD, struct ln_lnlat_posn *position);
127
132void LIBNOVA_EXPORT ln_get_lunar_subsolar_coords(double JD, struct ln_lnlat_posn *position);
133
138double LIBNOVA_EXPORT ln_lunar_next_phase(double jd, double phase);
139
144double LIBNOVA_EXPORT ln_lunar_previous_phase(double jd, double phase);
145
150double LIBNOVA_EXPORT ln_lunar_next_apsis(double jd, int apogee);
151
156double LIBNOVA_EXPORT ln_lunar_previous_apsis(double jd, int apogee);
157
162double LIBNOVA_EXPORT ln_lunar_next_node(double jd, int mode);
163
168double LIBNOVA_EXPORT ln_lunar_previous_node(double jd, int mode);
169
170#ifdef __cplusplus
171};
172#endif
173
174#endif
double LIBNOVA_EXPORT ln_lunar_previous_phase(double jd, double phase)
Find previous moon phase relative to given time expressed as Julian Day.
Definition: lunar.c:1553
double LIBNOVA_EXPORT ln_lunar_previous_apsis(double jd, int apogee)
Find previous moon apogee or perigee relative to given time expressed as Julian Day.
Definition: lunar.c:1606
double LIBNOVA_EXPORT ln_lunar_next_phase(double jd, double phase)
Find next moon phase relative to given time expressed as Julian Day.
Definition: lunar.c:1528
double LIBNOVA_EXPORT ln_lunar_next_node(double jd, int mode)
Find next moon node relative to given time expressed as Julian Day.
Definition: lunar.c:1634
void LIBNOVA_EXPORT ln_get_lunar_geo_posn(double JD, struct ln_rect_posn *moon, double precision)
Calculate the rectangular geocentric lunar cordinates.
Definition: lunar.c:1094
double LIBNOVA_EXPORT ln_lunar_next_apsis(double jd, int apogee)
Find next moon apogee or perigee relative to given time expressed as Julian Day.
Definition: lunar.c:1578
double LIBNOVA_EXPORT ln_get_lunar_long_perigee(double JD)
Calculate the longitude of the Moon's mean perigee.
Definition: lunar.c:1410
void LIBNOVA_EXPORT ln_get_lunar_equ_coords_prec(double JD, struct ln_equ_posn *position, double precision)
Calculate lunar equatorial coordinates.
Definition: lunar.c:1197
double LIBNOVA_EXPORT ln_get_lunar_bright_limb(double JD)
Calculate the position angle of the Moon's bright limb.
Definition: lunar.c:1321
void LIBNOVA_EXPORT ln_get_lunar_ecl_coords(double JD, struct ln_lnlat_posn *position, double precision)
Calculate lunar ecliptical coordinates.
Definition: lunar.c:1229
double LIBNOVA_EXPORT ln_get_lunar_long_asc_node(double JD)
Calculate the longitude of the Moon's mean ascending node.
Definition: lunar.c:1388
int LIBNOVA_EXPORT ln_get_lunar_rst(double JD, struct ln_lnlat_posn *observer, struct ln_rst_time *rst)
Calculate the time of rise, set and transit for the Moon.
Definition: lunar.c:1357
double LIBNOVA_EXPORT ln_get_lunar_disk(double JD)
Calculate the illuminated fraction of the Moons disk.
Definition: lunar.c:1300
double LIBNOVA_EXPORT ln_get_lunar_arg_latitude(double JD)
Calculate the Moon's argument of latitude (mean distance of the Moon from its ascending node)
Definition: lunar.c:1431
double LIBNOVA_EXPORT ln_get_lunar_sdiam(double JD)
Calculate the semidiameter of the Moon in arc seconds.
Definition: lunar.c:1372
double LIBNOVA_EXPORT ln_get_lunar_phase(double JD)
Calculate the phase angle of the Moon.
Definition: lunar.c:1269
void LIBNOVA_EXPORT ln_get_lunar_equ_coords(double JD, struct ln_equ_posn *position)
Calculate lunar equatorial coordinates.
Definition: lunar.c:1214
double LIBNOVA_EXPORT ln_lunar_previous_node(double jd, int mode)
Find previous lunar node relative to given time expressed as Julian Day.
Definition: lunar.c:1657
void LIBNOVA_EXPORT ln_get_lunar_opt_libr_coords(double JD, struct ln_lnlat_posn *position)
Calculate selenographic optical libration coordinates.
Definition: lunar.c:1476
double LIBNOVA_EXPORT ln_get_lunar_earth_dist(double JD)
Calculate the distance between the Earth and the Moon.
Definition: lunar.c:1253
Equatorial Coordinates.
Definition: ln_types.h:176
Ecliptical (or celestial) Longitude and Latitude.
Definition: ln_types.h:204
Rectangular coordinates.
Definition: ln_types.h:239
Rise, Set and Transit times.
Definition: ln_types.h:314