📄 wgs84geoid.hpp
字号:
#pragma ident "$Id: WGS84Geoid.hpp 149 2006-09-26 16:09:42Z architest $"/** * @file WGS84Geoid.hpp * WGS 1984 model of the geoid */#ifndef GPSTK_WGS84GEOID_HPP#define GPSTK_WGS84GEOID_HPP//============================================================================//// This file is part of GPSTk, the GPS Toolkit.//// The GPSTk is free software; you can redistribute it and/or modify// it under the terms of the GNU Lesser General Public License as published// by the Free Software Foundation; either version 2.1 of the License, or// any later version.//// The GPSTk is distributed in the hope that it will be useful,// but WITHOUT ANY WARRANTY; without even the implied warranty of// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the// GNU Lesser General Public License for more details.//// You should have received a copy of the GNU Lesser General Public// License along with GPSTk; if not, write to the Free Software Foundation,// Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA// // Copyright 2004, The University of Texas at Austin////============================================================================//============================================================================////This software developed by Applied Research Laboratories at the University of//Texas at Austin, under contract to an agency or agencies within the U.S. //Department of Defense. The U.S. Government retains all rights to use,//duplicate, distribute, disclose, or release this software. ////Pursuant to DoD Directive 523024 //// DISTRIBUTION STATEMENT A: This software has been approved for public // release, distribution is unlimited.////=============================================================================#include "GeoidModel.hpp"namespace gpstk{ /** @addtogroup geodeticgroup */ //@{ /// This class represents the geodetic model defined in NIMA /// TR8350.2, "Department of Defense World Geodetic System 1984". class WGS84Geoid : public GeoidModel { public: /// Defined in TR8350.2, Appendix A.1 /// @return semi-major axis of Earth in meters. virtual double a() const throw() { return 6378137.0; } /// Derived from TR8350.2, Appendix A.1 /// @return semi-major axis of Earth in km. virtual double a_km() const throw() { return a() / 1000.0; } /** * Derived from TR8350.2, Appendix A.1 * @note This parameter was in gappc as e-2, but a * little calculator work indicates it should really be e-3. * We'll leave it as e-3 for now. * @return flattening (ellipsoid parameter). */ virtual double flattening() const throw() { return 0.335281066475e-3; } /// Defined in TR8350.2, Table 3.3 /// @return eccentricity (ellipsoid parameter). virtual double eccentricity() const throw() { return 8.1819190842622e-2; } /// Defined in TR8350.2, Table 3.3 /// @return eccentricity squared (ellipsoid parameter). virtual double eccSquared() const throw() { return 6.69437999014e-3; } /// Defined in TR8350.2, 3.2.4 line 3-6, or Table 3.1 /// @return angular velocity of Earth in radians/sec. virtual double angVelocity() const throw() { return 7.292115e-5; } /// Defined in TR8350.2, Table 3.1 /// @return geocentric gravitational constant in m**3 / s**2 virtual double gm() const throw() { return 3986004.418e8; } /// Derived from TR8350.2, Table 3.1 /// @return geocentric gravitational constant in km**3 / s**2 virtual double gm_km() const throw() { return 398600.4418; } /// Defined in TR8350.2, 3.3.2 line 3-11 /// @return Speed of light in m/s. virtual double c() const throw() { return 299792458; } /// Derived from TR8350.2, 3.3.2 line 3-11 /// @return Speed of light in km/s virtual double c_km() const throw() { return c()/1000.0; } /// Destructor. virtual ~WGS84Geoid() throw() {}; }; // class WGS84Geoid //@}} // namespace#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -