// Boost.Geometry (aka GGL, Generic Geometry Library) // Copyright (c) 2016-2017 Oracle and/or its affiliates. // Contributed and/or modified by Vissarion Fisikopoulos, on behalf of Oracle // Contributed and/or modified by Adam Wulkiewicz, on behalf of Oracle // Use, modification and distribution is subject to the Boost Software License, // Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at // http://www.boost.org/LICENSE_1_0.txt) #ifndef BOOST_GEOMETRY_STRATEGIES_SPHERICAL_AZIMUTH_HPP #define BOOST_GEOMETRY_STRATEGIES_SPHERICAL_AZIMUTH_HPP #include #include #include #include namespace boost { namespace geometry { namespace strategy { namespace azimuth { template < typename CalculationType = void > class spherical { public : inline spherical() {} template static inline void apply(T const& lon1_rad, T const& lat1_rad, T const& lon2_rad, T const& lat2_rad, T& a1, T& a2) { typedef typename boost::mpl::if_ < boost::is_void, T, CalculationType >::type calc_t; geometry::formula::result_spherical result = geometry::formula::spherical_azimuth( calc_t(lon1_rad), calc_t(lat1_rad), calc_t(lon2_rad), calc_t(lat2_rad)); a1 = result.azimuth; a2 = result.reverse_azimuth; } template inline void apply(T const& lon1_rad, T const& lat1_rad, T const& lon2_rad, T const& lat2_rad, T& a1) const { typedef typename boost::mpl::if_ < boost::is_void, T, CalculationType >::type calc_t; geometry::formula::result_spherical result = geometry::formula::spherical_azimuth( calc_t(lon1_rad), calc_t(lat1_rad), calc_t(lon2_rad), calc_t(lat2_rad)); a1 = result.azimuth; } }; #ifndef DOXYGEN_NO_STRATEGY_SPECIALIZATIONS namespace services { template struct default_strategy { typedef strategy::azimuth::spherical type; }; /* template struct default_strategy { typedef strategy::azimuth::spherical type; }; */ } #endif // DOXYGEN_NO_STRATEGY_SPECIALIZATIONS }} // namespace strategy::azimuth }} // namespace boost::geometry #endif // BOOST_GEOMETRY_STRATEGIES_SPHERICAL_AZIMUTH_HPP