File: cmpack_hcorr.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 (111 lines) | stat: -rw-r--r-- 4,498 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
/**
	\file
	\brief Functions for the heliocentric correction

	Set of functions defined in this module allows user to 
	apply heliocentric correction to light-curve data files.
	
	\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_hcorr.h,v 1.1 2015/07/06 08:33:22 dmotl Exp $
*/
#ifndef _CMPACK_HCORR_H_INCLUDED
#define _CMPACK_HCORR_H_INCLUDED

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

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

/**
	\brief Correction flags
*/
typedef enum _CmpackHCorrFlags
{
	CMPACK_HCORR_DEFAULT	= 0,			/**< Default behavior */
	CMPACK_HCORR_REVERSE	= (1<<0),		/**< Compute geocentric JD from heliocentric JD */
	CMPACK_HCORR_NOHELCOR	= (1<<1),		/**< Do not add a new column with heliocentric correction */
	CMPACK_HCORR_NOJULDAT	= (1<<2),		/**< Do not add a new column with heliocentric JD */
	CMPACK_HCORR_MODIFYJD	= (1<<3),		/**< Modify JD -> JDHEL, do not add new columns */
	CMPACK_HCORR_FRAME_IDS	= (1<<4)		/**< Include frame identifiers */
} CmpackHCorrFlags;

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

#ifdef __cplusplus
extern "C" {
#endif

/**
	\brief Computes heliocentric correction
	\details The function computes value of heliocentric correction
	for given Julian date and object coordinates.
	\param[in] jd			Julian date (UT)
	\param[in] ra			right ascension of object in hours
	\param[in] declination	declination of object in degrees
	\return heliocentric correction in days
*/
	CMPACK_EXPORT(double, cmpack_helcorr, (double jd, double ra, double declination));

/**
	\brief Make heliocentric correction of data stored in a table
	\details The function computes heliocentric correction for all
	rows in the table. The table must have a column named 'JD', its
	values must be geocentric Julian date of observation. The value
	of correction in days and heliocentric Julian date are stored
	to the column 'HELCOR' and 'JDHEL' 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.
	\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] console		used to print debug outputs (can be NULL)
	\param[in] flags		see CMPACK_HCORR_xxx constants
	\return zero on success or error code on failure.
*/
	CMPACK_EXPORT(int, cmpack_helcorr_table, (CmpackTable* table, const char* objname, double ra,
		double declination, CmpackConsole* console, CmpackHCorrFlags flags));

/**
	\brief Make heliocentric correction curve 
	\details The function create a new table that consists of JD,
	HELCOR and JDHEL 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] console		used to print debug outputs (can be NULL)
	\param[in] flags		see CMPACK_HCORR_xxx constants
	\return zero on success or error code on failure.
*/
	CMPACK_EXPORT(int, cmpack_helcorr_curve, (CmpackFrameSet* fset, CmpackTable** table, const char* objname,
		double ra, double declination, CmpackHCorrFlags flags, CmpackConsole* console));

/**
	\brief Make heliocentric correction of data stored in a frame set
	\details The function updates the heliocentric correction and heliocentric
	Julin dates for each frame. The object 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] console		used to print debug outputs (can be NULL)
	\return zero on success or error code on failure.
*/
	CMPACK_EXPORT(int, cmpack_helcorr_fset, (CmpackFrameSet* fset, const char* objname, double ra,
		double declination, CmpackConsole* console));

#ifdef __cplusplus
}
#endif

#endif