1 // constants.h -- various constant definitions
3 // Written by Curtis Olson, started February 2000.
5 // Copyright (C) 2000 Curtis L. Olson - http://www.flightgear.org/~curt/
7 // This library is free software; you can redistribute it and/or
8 // modify it under the terms of the GNU Library General Public
9 // License as published by the Free Software Foundation; either
10 // version 2 of the License, or (at your option) any later version.
12 // This library is distributed in the hope that it will be useful,
13 // but WITHOUT ANY WARRANTY; without even the implied warranty of
14 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 // Library General Public License for more details.
17 // You should have received a copy of the GNU General Public License
18 // along with this program; if not, write to the Free Software
19 // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
24 * Various constant definitions.
28 #ifndef _SG_CONSTANTS_H
29 #define _SG_CONSTANTS_H
32 #include <simgear/compiler.h>
34 #ifdef SG_HAVE_STD_INCLUDES
37 # ifdef SG_MATH_EXCEPTION_CLASH
38 # define exception C_exception
46 // Make sure PI is defined in its various forms
48 // SG_PI and SGD_PI (float and double) come from plib/sg.h
51 #define SGD_2PI 6.28318530717958647692
55 # define SGD_PI_2 M_PI_2
57 # define SGD_PI_2 1.57079632679489661923
61 #define SGD_PI_4 0.78539816339744830961
67 # define SG_E 2.7182818284590452354
70 /** pi/180/60/60, or about 100 feet at earths' equator */
71 #define SG_ONE_SECOND 4.848136811E-6
74 /** Radius of Earth in kilometers at the equator. Another source had
75 * 6378.165 but this is probably close enough */
76 #define SG_EARTH_RAD 6378.155
78 // Maximum terrain elevation from sea level
79 #define SG_MAX_ELEVATION_M 9000.0
81 // Earth parameters for WGS 84, taken from LaRCsim/ls_constants.h
83 /** Value of earth radius from LaRCsim (ft) */
84 #define SG_EQUATORIAL_RADIUS_FT 20925650.
86 /** Value of earth radius from LaRCsim (meter) */
87 #define SG_EQUATORIAL_RADIUS_M 6378138.12
89 /** Radius squared (ft) */
90 #define SG_EQ_RAD_SQUARE_FT 437882827922500.
92 /** Radius squared (meter) */
93 #define SG_EQ_RAD_SQUARE_M 40680645877797.1344
97 /** Arc seconds to radians. (arcsec*pi)/(3600*180) = rad */
98 #define SG_ARCSEC_TO_RAD 4.84813681109535993589e-06
100 /** Radians to arc seconds. (rad*3600*180)/pi = arcsec */
101 #define SG_RAD_TO_ARCSEC 206264.806247096355156
103 /** Feet to Meters */
104 #define SG_FEET_TO_METER 0.3048
106 /** Meters to Feet */
107 #define SG_METER_TO_FEET 3.28083989501312335958
109 /** Meters to Nautical Miles. 1 nm = 6076.11549 feet */
110 #define SG_METER_TO_NM 0.0005399568034557235
112 /** Nautical Miles to Meters */
113 #define SG_NM_TO_METER 1852.0000
115 /** Meters to Statute Miles. */
116 #define SG_METER_TO_SM 0.0006213699494949496
118 /** Statute Miles to Meters. */
119 #define SG_SM_TO_METER 1609.3412196
121 /** Radians to Nautical Miles. 1 nm = 1/60 of a degree */
122 #define SG_NM_TO_RAD 0.00029088820866572159
124 /** Nautical Miles to Radians */
125 #define SG_RAD_TO_NM 3437.7467707849392526
127 /** Miles per second to Knots */
128 #define SG_MPS_TO_KT 1.9438444924406046432
130 /** Knots to Miles per second */
131 #define SG_KT_TO_MPS 0.5144444444444444444
133 /** Feet per second to Knots */
134 #define SG_FPS_TO_KT 0.5924838012958962841
136 /** Knots to Feet per second */
137 #define SG_KT_TO_FPS 1.6878098571011956874
139 /** Miles per second to Miles per hour */
140 #define SG_MPS_TO_MPH 2.2369362920544020312
142 /** Miles per hour to Miles per second */
143 #define SG_MPH_TO_MPS 0.44704
145 /** Meters per second to Kilometers per hour */
146 #define SG_MPS_TO_KMH 3.6
148 /** Kilometers per hour to Miles per second */
149 #define SG_KMH_TO_MPS 0.2777777777777777778
151 /** Pascal to Inch Mercury */
152 #define SG_PA_TO_INHG 0.0002952998330101010
154 /** Inch Mercury to Pascal */
155 #define SG_INHG_TO_PA 3386.388640341
158 /** For divide by zero avoidance, this will be close enough to zero */
159 #define SG_EPSILON 0.0000001
161 /** Highest binobj format version we know how to read/write. This starts at
162 * 0 and can go up to 65535 */
163 #define SG_BINOBJ_VERSION 6
165 /** for backwards compatibility */
166 #define SG_SCENERY_FILE_FORMAT "0.4"
169 #endif // _SG_CONSTANTS_H