File: cmpack_amass.h

package info (click to toggle)
c-munipack 2.1.39-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 55,888 kB
  • sloc: ansic: 200,762; cpp: 106,129; lex: 9,035; yacc: 4,916; sh: 4,074; fortran: 2,613; xml: 2,105; python: 1,182; makefile: 546; perl: 104
file content (132 lines) | stat: -rw-r--r-- 5,489 bytes parent folder | download | duplicates (2)
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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
/**
	\file
	\brief Functions for the air mass coefficient computation

	Set of functions defined in this module allows user to include
	the air mass coefficients to a table stored in the file.
	
	\author David Motl <dmotl@volny.cz>
	
	\par Copying
	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, version 2.
	
	$Id: cmpack_amass.h,v 1.1 2015/07/06 08:33:22 dmotl Exp $
*/

#ifndef _CMPACK_AMASS_H_INCLUDED
#define _CMPACK_AMASS_H_INCLUDED

#include "cmpack_console.h"
#include "cmpack_table.h"
#include "cmpack_fset.h"

/**********************   Public constants   ***********************************/

/**
	\brief Air-mass coefficient control flags
*/
typedef enum _CmpackAMassFlags
{
	CMPACK_AMASS_DEFAULT	= 0,		/**< Default behavior */
	CMPACK_AMASS_NOALTITUDE	= (1<<0),	/**< Do not add altitude in degrees */
	CMPACK_AMASS_NOAIRMASS	= (1<<1),  	/**< Do not add air mass coefficients */
	CMPACK_AMASS_FRAME_IDS	= (1<<2)	/**< Include frame identifiers */
} CmpackAMassFlags;

/********************   Public functions   *************************************/

#ifdef __cplusplus
extern "C" {
#endif

/**
	\brief Computes air mass coefficient
	\details The function computes the air mass coefficient for
	given Julian date, object coordinates and observer coordinates.
	It also computes the altitude of the object in degrees. The function
	returns value of the air mass coefficient or negative value if 
	the object is below the horizon.
	\param[in] jd			Julian date (UT)
	\param[in] ra			right ascension of object in hours
	\param[in] declination	declination of object in degrees
	\param[in] longitude	longitude of observer in degrees
	\param[in] latitude		latitude of observer in degrees
	\param[out] airmass		air mass coeficient
	\param[out] altitude	altitude in degrees (optional)
	\return zero on success, error code on failure
*/
	CMPACK_EXPORT(int, cmpack_airmass, (double jd, double ra, double declination, double longitude,
		double latitude, double* airmass, double* altitude));

/**
	\brief Include air mass coefficients to a table
	\details The function computes air mass coefficients for all
	rows in the table. The table must have a column named 'JD', its
	values must be geocentric Julian date of obsrvation. The value
	of air mass coefficient and altitude of the object are stored
	to the column 'AIRMASS' and 'ALTITUDE' respectively. If such
	columns do not exist, the function appends them after the last
	column. The function also updates the table's header to set
	the object designation and coordinates and location name and
	observer coordinates.
	\param[in] table		table
	\param[in] objname		object designation (can be NULL)
	\param[in] ra			right ascension of object in hours
	\param[in] declination	declination of object in degrees
	\param[in] location		location name (can be NULL)
	\param[in] longitude	longitude of observer in degrees
	\param[in] latitude		latitude of observer in degrees
	\param[in] console		used to print debug outputs (can be NULL)
	\param[in] flags		see CMPACK_AMASS_xxx constants
	\return zero on success or error code on failure.
*/
	CMPACK_EXPORT(int, cmpack_airmass_table, (CmpackTable* table, const char* objname, double ra,
		double declination, const char* location, double longitude, double latitude,
		CmpackConsole* console, unsigned flags));

/**
	\brief Update air mass coefficients in a frame set
	\details The function updates the air mass coefficients and
	the altitudes based on the Julian date of each frame. The object
	parameters and observer parameters are updated as well.
	\param[in] fset			frame set
	\param[in] objname		object designation (can be NULL)
	\param[in] ra			right ascension of object in hours
	\param[in] declination	declination of object in degrees
	\param[in] location		location name (can be NULL)
	\param[in] longitude	longitude of observer in degrees
	\param[in] latitude		latitude of observer in degrees
	\param[in] console		used to print debug outputs (can be NULL)
	\return zero on success or error code on failure.
*/
	CMPACK_EXPORT(int, cmpack_airmass_fset, (CmpackFrameSet* fset, const char* objname, double ra,
		double declination, const char* location, double longitude, double latitude,
		CmpackConsole* console));

/**
	\brief Make a air mass curve from a frame set
	\details The function create a new table consisting of JD, AIRMASS and
	ALTITUDE columns. Optionally, it can consits FRAME column, too.
	\param[in] fset			frame set
	\param[out] table		new table with the air mass curve
	\param[in] objname		object designation (can be NULL)
	\param[in] ra			right ascension of object in hours
	\param[in] declination	declination of object in degrees
	\param[in] location		location name (can be NULL)
	\param[in] longitude	longitude of observer in degrees
	\param[in] latitude		latitude of observer in degrees
	\param[in] flags		flags
	\param[in] console		used to print debug outputs (can be NULL)
	\return zero on success or error code on failure.
*/
	CMPACK_EXPORT(int, cmpack_airmass_curve, (CmpackFrameSet* fset, CmpackTable** table, const char* objname, double ra,
		double declination, const char* location, double longitude, double latitude,
		CmpackAMassFlags flags, CmpackConsole* console));

#ifdef __cplusplus
}
#endif

#endif