22 #include <libnova/ln_types.h>
24 #define LN_LUNAR_STANDART_HORIZON 0.125
132 void LIBNOVA_EXPORT ln_get_lunar_subsolar_coords(
double JD,
struct ln_lnlat_posn *position);
void LIBNOVA_EXPORT ln_get_solar_geom_coords(double JD, struct ln_helio_posn *position)
Calculate solar geometric coordinates.
Definition: solar.c:39
double Z
Definition: ln_types.h:242
double lng
Definition: ln_types.h:205
double 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:1604
void ln_get_lunar_equ_coords(double JD, struct ln_equ_posn *position)
Calculate lunar equatorial coordinates.
Definition: lunar.c:1212
void ln_get_lunar_equ_coords_prec(double JD, struct ln_equ_posn *position, double precision)
Calculate lunar equatorial coordinates.
Definition: lunar.c:1195
Rise, Set and Transit times.
Definition: ln_types.h:314
double LIBNOVA_EXPORT ln_find_max(double(*func)(double, double *), double from, double to, double *arg)
Find local maximum of function f() at given interval by Golden Section method.
Definition: utility.c:720
double X
Definition: ln_types.h:240
double 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:1429
double ra
Definition: ln_types.h:177
double ln_get_lunar_bright_limb(double JD)
Calculate the position angle of the Moon's bright limb.
Definition: lunar.c:1319
double ln_get_earth_solar_dist(double JD)
Calculate the distance between Earth and the Sun.
Definition: earth.c:2772
Heliocentric position.
Definition: ln_types.h:219
double ln_lunar_previous_phase(double jd, double phase)
Find previous moon phase relative to given time expressed as Julian Day.
Definition: lunar.c:1551
void ln_get_lunar_ecl_coords(double JD, struct ln_lnlat_posn *position, double precision)
Calculate lunar ecliptical coordinates.
Definition: lunar.c:1227
double ln_get_lunar_long_perigee(double JD)
Calculate the longitude of the Moon's mean perigee.
Definition: lunar.c:1408
double ln_get_lunar_earth_dist(double JD)
Calculate the distance between the Earth and the Moon.
Definition: lunar.c:1251
void LIBNOVA_EXPORT ln_get_solar_equ_coords(double JD, struct ln_equ_posn *position)
Calculate apparent equatorial coordinates.
Definition: solar.c:56
Definition: aberration.c:29
double LIBNOVA_EXPORT ln_deg_to_rad(double degrees)
degrees to radians
Definition: utility.c:93
double LIBNOVA_EXPORT ln_find_zero(double(*func)(double, double *), double from, double to, double *arg)
Find zero of function f() at given interval by Newton method.
Definition: utility.c:692
double LIBNOVA_EXPORT ln_range_degrees(double angle)
puts a large angle in the correct range 0 - 360 degrees
Definition: utility.c:237
void LIBNOVA_EXPORT ln_get_solar_ecl_coords(double JD, struct ln_lnlat_posn *position)
Calculate apparent ecliptical coordinates.
Definition: solar.c:87
int 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:1355
double LIBNOVA_EXPORT ln_range_radians(double angle)
puts a large angle in the correct range 0 - 2PI radians
Definition: utility.c:252
Definition: lunar-priv.h:10
double ln_lunar_next_phase(double jd, double phase)
Find next moon phase relative to given time expressed as Julian Day.
Definition: lunar.c:1526
double lat
Definition: ln_types.h:206
void ln_get_lunar_opt_libr_coords(double JD, struct ln_lnlat_posn *position)
Calculate selenographic optical libration coordinates.
Definition: lunar.c:1474
Definition: lunar-priv.h:20
double ln_get_lunar_disk(double JD)
Calculate the illuminated fraction of the Moons disk.
Definition: lunar.c:1298
double ln_get_lunar_phase(double JD)
Calculate the phase angle of the Moon.
Definition: lunar.c:1267
double ln_lunar_next_node(double jd, int mode)
Find next moon node relative to given time expressed as Julian Day.
Definition: lunar.c:1632
double Y
Definition: ln_types.h:241
double ln_lunar_previous_node(double jd, int mode)
Find previous lunar node relative to given time expressed as Julian Day.
Definition: lunar.c:1655
void ln_get_lunar_geo_posn(double JD, struct ln_rect_posn *moon, double precision)
Calculate the rectangular geocentric lunar cordinates.
Definition: lunar.c:1092
double LIBNOVA_EXPORT ln_rad_to_deg(double radians)
radians to degrees
Definition: utility.c:87
double 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:1576
double ln_get_lunar_long_asc_node(double JD)
Calculate the longitude of the Moon's mean ascending node.
Definition: lunar.c:1386
Ecliptical (or celestial) Longitude and Latitude.
Definition: ln_types.h:204
Equatorial Coordinates.
Definition: ln_types.h:176
double dec
Definition: ln_types.h:178
int LIBNOVA_EXPORT ln_get_body_rst_horizon(double JD, struct ln_lnlat_posn *observer, void(*get_equ_body_coords)(double, struct ln_equ_posn *), double horizon, struct ln_rst_time *rst)
Calculate the time of rise, set and transit for an object a body, usually Sun, a planet or Moon.
Definition: rise_set.c:320
Definition: lunar-priv.h:2
Rectangular coordinates.
Definition: ln_types.h:239
double ln_get_lunar_sdiam(double JD)
Calculate the semidiameter of the Moon in arc seconds.
Definition: lunar.c:1370