libnova
v 0.16.0
|
Functions | |
double | ln_solve_kepler (double e, double M) |
Calculate the eccentric anomaly. More... | |
double | ln_get_ell_mean_anomaly (double n, double delta_JD) |
Calculate the mean anomaly. More... | |
double | ln_get_ell_true_anomaly (double e, double E) |
Calculate the true anomaly. More... | |
double | ln_get_ell_radius_vector (double a, double e, double E) |
Calculate the radius vector. More... | |
double | ln_get_ell_smajor_diam (double e, double q) |
Calculate the semi major diameter. More... | |
double | ln_get_ell_sminor_diam (double e, double a) |
Calculate the semi minor diameter. More... | |
double | ln_get_ell_mean_motion (double a) |
Calculate the mean daily motion (degrees/day). More... | |
void | ln_get_ell_geo_rect_posn (struct ln_ell_orbit *orbit, double JD, struct ln_rect_posn *posn) |
Calculate the objects rectangular geocentric position. More... | |
void | ln_get_ell_helio_rect_posn (struct ln_ell_orbit *orbit, double JD, struct ln_rect_posn *posn) |
Calculate the objects rectangular heliocentric position. More... | |
double | ln_get_ell_orbit_len (struct ln_ell_orbit *orbit) |
Calculate the orbital length in AU. More... | |
double | ln_get_ell_orbit_vel (double JD, struct ln_ell_orbit *orbit) |
Calculate orbital velocity in km/s. More... | |
double | ln_get_ell_orbit_pvel (struct ln_ell_orbit *orbit) |
Calculate orbital velocity at perihelion in km/s. More... | |
double | ln_get_ell_orbit_avel (struct ln_ell_orbit *orbit) |
Calculate the orbital velocity at aphelion in km/s. More... | |
double | ln_get_ell_body_phase_angle (double JD, struct ln_ell_orbit *orbit) |
Calculate the phase angle of the body. The angle Sun - body - Earth. More... | |
double | ln_get_ell_body_elong (double JD, struct ln_ell_orbit *orbit) |
Calculate the bodies elongation to the Sun.. More... | |
double | ln_get_ell_body_solar_dist (double JD, struct ln_ell_orbit *orbit) |
Calculate the distance between a body and the Sun. More... | |
double | ln_get_ell_body_earth_dist (double JD, struct ln_ell_orbit *orbit) |
Calculate the distance between a body and the Earth. More... | |
void | ln_get_ell_body_equ_coords (double JD, struct ln_ell_orbit *orbit, struct ln_equ_posn *posn) |
Calculate a bodies equatorial coords. More... | |
int | ln_get_ell_body_rst (double JD, struct ln_lnlat_posn *observer, struct ln_ell_orbit *orbit, struct ln_rst_time *rst) |
Calculate the time of rise, set and transit for a body with an elliptic orbit. More... | |
int | ln_get_ell_body_rst_horizon (double JD, struct ln_lnlat_posn *observer, struct ln_ell_orbit *orbit, double horizon, struct ln_rst_time *rst) |
Calculate the time of rise, set and transit for a body with an elliptic orbit. More... | |
int | ln_get_ell_body_next_rst (double JD, struct ln_lnlat_posn *observer, struct ln_ell_orbit *orbit, struct ln_rst_time *rst) |
Calculate the time of rise, set and transit for a body with an elliptic orbit. More... | |
int | ln_get_ell_body_next_rst_horizon (double JD, struct ln_lnlat_posn *observer, struct ln_ell_orbit *orbit, double horizon, struct ln_rst_time *rst) |
Calculate the time of rise, set and transit for a body with an elliptic orbit. More... | |
int | ln_get_ell_body_next_rst_horizon_future (double JD, struct ln_lnlat_posn *observer, struct ln_ell_orbit *orbit, double horizon, int day_limit, struct ln_rst_time *rst) |
Calculate the time of rise, set and transit for a body with an elliptic orbit. | |
double | ln_get_ell_last_perihelion (double epoch_JD, double M, double n) |
Calculate the julian day of the last perihelion. More... | |
Functions relating to the elliptic motion of bodies.
All angles are expressed in degrees.
double ln_get_ell_body_earth_dist | ( | double | JD, |
struct ln_ell_orbit * | orbit | ||
) |
Calculate the distance between a body and the Earth.
JD | Julian day. |
orbit | Orbital parameters |
Calculate the distance between an body and the Earth for the given julian day.
References ln_get_ell_geo_rect_posn(), ln_rect_posn::X, ln_rect_posn::Y, and ln_rect_posn::Z.
Referenced by ln_get_ell_body_phase_angle().
double ln_get_ell_body_elong | ( | double | JD, |
struct ln_ell_orbit * | orbit | ||
) |
Calculate the bodies elongation to the Sun..
JD | Julian day |
orbit | Orbital parameters |
Calculate the bodies elongation to the Sun..
References ln_ell_orbit::a, ln_ell_orbit::e, ln_ell_orbit::JD, ln_get_earth_solar_dist(), ln_get_ell_body_solar_dist(), ln_get_ell_mean_anomaly(), ln_get_ell_mean_motion(), ln_get_ell_radius_vector(), ln_rad_to_deg(), ln_range_degrees(), ln_solve_kepler(), and ln_ell_orbit::n.
void ln_get_ell_body_equ_coords | ( | double | JD, |
struct ln_ell_orbit * | orbit, | ||
struct ln_equ_posn * | posn | ||
) |
Calculate a bodies equatorial coords.
JD | Julian Day. |
orbit | Orbital parameters. |
posn | Pointer to hold asteroid position. |
Calculate a bodies equatorial coordinates for the given julian day.
References ln_equ_posn::dec, ln_get_ell_helio_rect_posn(), ln_get_solar_geo_coords(), ln_rad_to_deg(), ln_range_degrees(), ln_equ_posn::ra, ln_rect_posn::X, ln_rect_posn::Y, and ln_rect_posn::Z.
Referenced by ln_get_ell_body_next_rst_horizon(), ln_get_ell_body_next_rst_horizon_future(), and ln_get_ell_body_rst_horizon().
double ln_get_ell_body_next_rst | ( | double | JD, |
struct ln_lnlat_posn * | observer, | ||
struct ln_ell_orbit * | orbit, | ||
struct ln_rst_time * | rst | ||
) |
Calculate the time of rise, set and transit for a body with an elliptic orbit.
JD | Julian day |
observer | Observers position |
orbit | Orbital parameters |
rst | Pointer to store Rise, Set and Transit time in JD |
Calculate the time of next rise, set and transit (crosses the local meridian at upper culmination) time of a body with an elliptic orbit for the given Julian day.
This function guarantee, that rise, set and transit will be in <JD, JD+1> range.
Note: this functions returns 1 if the body is circumpolar, that is it remains the whole day above the horizon. Returns -1 when it remains the whole day below the horizon.
References ln_get_ell_body_next_rst_horizon().
double ln_get_ell_body_next_rst_horizon | ( | double | JD, |
struct ln_lnlat_posn * | observer, | ||
struct ln_ell_orbit * | orbit, | ||
double | horizon, | ||
struct ln_rst_time * | rst | ||
) |
Calculate the time of rise, set and transit for a body with an elliptic orbit.
JD | Julian day |
observer | Observers position |
orbit | Orbital parameters |
horizon | Horizon height |
rst | Pointer to store Rise, Set and Transit time in JD |
Calculate the time of next rise, set and transit (crosses the local meridian at upper culmination) time of a body with an elliptic orbit for the given Julian day.
This function guarantee, that rise, set and transit will be in <JD, JD+1> range.
Note: this functions returns 1 if the body is circumpolar, that is it remains the whole day above the horizon. Returns -1 when it remains the whole day below the horizon.
JD | Julian day |
observer | Observers position |
orbit | Orbital parameters |
horizon | Horizon height |
day_limit | Maximal number of days that will be searched for next rise and set |
rst | Pointer to store Rise, Set and Transit time in JD |
Calculate the time of next rise, set and transit (crosses the local meridian at upper culmination) time of a body with an elliptic orbit for the given Julian day.
This function guarantee, that rise, set and transit will be in <JD, JD + day_limit> range.
Note: this functions returns 1 if the body is circumpolar, that is it remains the whole day above the horizon. Returns -1 when it remains the whole day below the horizon.
References ln_get_ell_body_equ_coords().
Referenced by ln_get_ell_body_next_rst().
double ln_get_ell_body_phase_angle | ( | double | JD, |
struct ln_ell_orbit * | orbit | ||
) |
Calculate the phase angle of the body. The angle Sun - body - Earth.
JD | Julian day |
orbit | Orbital parameters |
Calculate the phase angle of the body. The angle Sun - body - Earth.
References ln_ell_orbit::a, ln_ell_orbit::e, ln_ell_orbit::JD, ln_deg_to_rad(), ln_get_ell_body_earth_dist(), ln_get_ell_body_solar_dist(), ln_get_ell_mean_anomaly(), ln_get_ell_mean_motion(), ln_get_ell_radius_vector(), ln_range_degrees(), ln_solve_kepler(), and ln_ell_orbit::n.
double ln_get_ell_body_rst | ( | double | JD, |
struct ln_lnlat_posn * | observer, | ||
struct ln_ell_orbit * | orbit, | ||
struct ln_rst_time * | rst | ||
) |
Calculate the time of rise, set and transit for a body with an elliptic orbit.
JD | Julian day |
observer | Observers position |
orbit | Orbital parameters |
rst | Pointer to store Rise, Set and Transit time in JD |
Calculate the time the rise, set and transit (crosses the local meridian at upper culmination) time of a body with an elliptic orbit for the given Julian day.
Note: this functions returns 1 if the body is circumpolar, that is it remains the whole day above the horizon. Returns -1 when it remains the whole day below the horizon.
References ln_get_ell_body_rst_horizon().
double ln_get_ell_body_rst_horizon | ( | double | JD, |
struct ln_lnlat_posn * | observer, | ||
struct ln_ell_orbit * | orbit, | ||
double | horizon, | ||
struct ln_rst_time * | rst | ||
) |
Calculate the time of rise, set and transit for a body with an elliptic orbit.
JD | Julian day |
observer | Observers position |
orbit | Orbital parameters |
horizon | Horizon height |
rst | Pointer to store Rise, Set and Transit time in JD |
Calculate the time the rise, set and transit (crosses the local meridian at upper culmination) time of a body with an elliptic orbit for the given Julian day.
Note: this functions returns 1 if the body is circumpolar, that is it remains the whole day above the horizon. Returns -1 when it remains the whole day below the horizon.
References ln_get_ell_body_equ_coords().
Referenced by ln_get_ell_body_rst().
double ln_get_ell_body_solar_dist | ( | double | JD, |
struct ln_ell_orbit * | orbit | ||
) |
Calculate the distance between a body and the Sun.
JD | Julian Day. |
orbit | Orbital parameters |
Calculate the distance between a body and the Sun.
References ln_get_ell_helio_rect_posn(), ln_rect_posn::X, ln_rect_posn::Y, and ln_rect_posn::Z.
Referenced by ln_get_ell_body_elong(), ln_get_ell_body_phase_angle(), ln_get_ell_comet_mag(), and ln_get_ell_orbit_vel().
void ln_get_ell_geo_rect_posn | ( | struct ln_ell_orbit * | orbit, |
double | JD, | ||
struct ln_rect_posn * | posn | ||
) |
Calculate the objects rectangular geocentric position.
orbit | Orbital parameters of object. |
JD | Julian day |
posn | Position pointer to store objects position |
Calculate the objects rectangular geocentric position given it's orbital elements for the given julian day.
References ln_get_earth_helio_coords(), ln_get_ell_helio_rect_posn(), ln_get_rect_from_helio(), ln_rect_posn::X, ln_rect_posn::Y, and ln_rect_posn::Z.
Referenced by ln_get_ell_body_earth_dist().
void ln_get_ell_helio_rect_posn | ( | struct ln_ell_orbit * | orbit, |
double | JD, | ||
struct ln_rect_posn * | posn | ||
) |
Calculate the objects rectangular heliocentric position.
orbit | Orbital parameters of object. |
JD | Julian day |
posn | Position pointer to store objects position |
Calculate the objects rectangular heliocentric position given it's orbital elements for the given julian day.
References ln_ell_orbit::a, ln_helio_posn::B, ln_ell_orbit::e, ln_ell_orbit::i, ln_ell_orbit::JD, ln_deg_to_rad(), ln_get_ell_mean_anomaly(), ln_get_ell_mean_motion(), ln_get_ell_radius_vector(), ln_get_ell_true_anomaly(), ln_solve_kepler(), ln_ell_orbit::n, ln_ell_orbit::omega, ln_helio_posn::R, ln_ell_orbit::w, ln_rect_posn::X, ln_rect_posn::Y, and ln_rect_posn::Z.
Referenced by ln_get_ell_body_equ_coords(), ln_get_ell_body_solar_dist(), and ln_get_ell_geo_rect_posn().
double ln_get_ell_last_perihelion | ( | double | epoch_JD, |
double | M, | ||
double | n | ||
) |
Calculate the julian day of the last perihelion.
epoch_JD | Julian day of epoch |
M | Mean anomaly |
n | daily motion in degrees |
Calculate the julian day of the last perihelion.
double ln_get_ell_mean_anomaly | ( | double | n, |
double | delta_JD | ||
) |
Calculate the mean anomaly.
n | Mean motion (degrees/day) |
delta_JD | Time since perihelion |
Calculate the mean anomaly.
Referenced by ln_get_ell_body_elong(), ln_get_ell_body_phase_angle(), ln_get_ell_comet_mag(), and ln_get_ell_helio_rect_posn().
double ln_get_ell_mean_motion | ( | double | a | ) |
Calculate the mean daily motion (degrees/day).
a | Semi major diameter in AU |
Calculate the mean daily motion (degrees/day).
Referenced by ln_get_ell_body_elong(), ln_get_ell_body_phase_angle(), ln_get_ell_comet_mag(), and ln_get_ell_helio_rect_posn().
double ln_get_ell_orbit_avel | ( | struct ln_ell_orbit * | orbit | ) |
Calculate the orbital velocity at aphelion in km/s.
orbit | Orbital parameters |
Calculate the orbital velocity at aphelion in km/s.
References ln_ell_orbit::a, and ln_ell_orbit::e.
double ln_get_ell_orbit_len | ( | struct ln_ell_orbit * | orbit | ) |
Calculate the orbital length in AU.
orbit | Orbital parameters |
Calculate the orbital length in AU.
Accuracy:
References ln_ell_orbit::a, ln_ell_orbit::e, and ln_get_ell_sminor_diam().
double ln_get_ell_orbit_pvel | ( | struct ln_ell_orbit * | orbit | ) |
Calculate orbital velocity at perihelion in km/s.
orbit | Orbital parameters |
Calculate orbital velocity at perihelion in km/s.
References ln_ell_orbit::a, and ln_ell_orbit::e.
double ln_get_ell_orbit_vel | ( | double | JD, |
struct ln_ell_orbit * | orbit | ||
) |
Calculate orbital velocity in km/s.
JD | Julian day. |
orbit | Orbital parameters |
Calculate orbital velocity in km/s for the given julian day.
References ln_ell_orbit::a, and ln_get_ell_body_solar_dist().
double ln_get_ell_radius_vector | ( | double | a, |
double | e, | ||
double | E | ||
) |
Calculate the radius vector.
a | Semi-Major axis in AU |
e | Orbital eccentricity |
E | Eccentric anomaly |
Calculate the radius vector.
References ln_deg_to_rad().
Referenced by ln_get_ell_body_elong(), ln_get_ell_body_phase_angle(), ln_get_ell_comet_mag(), and ln_get_ell_helio_rect_posn().
double ln_get_ell_smajor_diam | ( | double | e, |
double | q | ||
) |
Calculate the semi major diameter.
e | Eccentricity |
q | Perihelion distance in AU |
Calculate the semi major diameter.
double ln_get_ell_sminor_diam | ( | double | e, |
double | a | ||
) |
Calculate the semi minor diameter.
e | Eccentricity |
a | Semi-Major diameter in AU |
Calculate the semi minor diameter.
Referenced by ln_get_ell_orbit_len().
double ln_get_ell_true_anomaly | ( | double | e, |
double | E | ||
) |
Calculate the true anomaly.
e | Orbital eccentricity |
E | Eccentric anomaly |
Calculate the true anomaly.
References ln_deg_to_rad(), ln_rad_to_deg(), and ln_range_degrees().
Referenced by ln_get_ell_helio_rect_posn().
double ln_solve_kepler | ( | double | E, |
double | M | ||
) |
Calculate the eccentric anomaly.
E | Orbital eccentricity |
M | Mean anomaly |
Calculate the eccentric anomaly. This method was devised by Roger Sinnott. (Sky and Telescope, Vol 70, pg 159)
References ln_deg_to_rad(), and ln_rad_to_deg().
Referenced by ln_get_ell_body_elong(), ln_get_ell_body_phase_angle(), ln_get_ell_comet_mag(), and ln_get_ell_helio_rect_posn().