3 // Copyright (c) 2021, Oracle and/or its affiliates.
5 // Contributed and/or modified by Adam Wulkiewicz, on behalf of Oracle
7 // Licensed under the Boost Software License version 1.0.
8 // http://www.boost.org/users/license.html
10 #ifndef BOOST_GEOMETRY_STRATEGIES_DISTANCE_CARTESIAN_HPP
11 #define BOOST_GEOMETRY_STRATEGIES_DISTANCE_CARTESIAN_HPP
14 //#include <boost/geometry/strategies/cartesian/azimuth.hpp>
16 #include <boost/geometry/strategies/cartesian/distance_projected_point.hpp>
17 #include <boost/geometry/strategies/cartesian/distance_pythagoras.hpp>
18 #include <boost/geometry/strategies/cartesian/distance_pythagoras_box_box.hpp>
19 #include <boost/geometry/strategies/cartesian/distance_pythagoras_point_box.hpp>
20 #include <boost/geometry/strategies/cartesian/distance_segment_box.hpp>
22 #include <boost/geometry/strategies/detail.hpp>
23 #include <boost/geometry/strategies/distance/comparable.hpp>
24 #include <boost/geometry/strategies/distance/detail.hpp>
25 #include <boost/geometry/strategies/distance/services.hpp>
27 //#include <boost/geometry/strategies/normalize.hpp>
28 #include <boost/geometry/strategies/relate/cartesian.hpp>
30 #include <boost/geometry/util/type_traits.hpp>
33 namespace boost { namespace geometry
36 namespace strategies { namespace distance
39 template <typename CalculationType = void>
41 : public strategies::relate::cartesian<CalculationType>
43 template <typename Geometry1, typename Geometry2>
44 static auto distance(Geometry1 const&, Geometry2 const&,
45 detail::enable_if_pp_t<Geometry1, Geometry2> * = nullptr)
47 return strategy::distance::pythagoras<CalculationType>();
50 template <typename Geometry1, typename Geometry2>
51 static auto distance(Geometry1 const&, Geometry2 const&,
52 detail::enable_if_ps_t<Geometry1, Geometry2> * = nullptr)
54 return strategy::distance::projected_point
57 strategy::distance::pythagoras<CalculationType>
61 template <typename Geometry1, typename Geometry2>
62 static auto distance(Geometry1 const&, Geometry2 const&,
63 detail::enable_if_pb_t<Geometry1, Geometry2> * = nullptr)
65 return strategy::distance::pythagoras_point_box<CalculationType>();
68 template <typename Geometry1, typename Geometry2>
69 static auto distance(Geometry1 const&, Geometry2 const&,
70 detail::enable_if_sb_t<Geometry1, Geometry2> * = nullptr)
72 return strategy::distance::cartesian_segment_box
75 strategy::distance::pythagoras<CalculationType>
79 template <typename Geometry1, typename Geometry2>
80 static auto distance(Geometry1 const&, Geometry2 const&,
81 detail::enable_if_bb_t<Geometry1, Geometry2> * = nullptr)
83 return strategy::distance::pythagoras_box_box<CalculationType>();
91 template <typename Geometry1, typename Geometry2>
92 struct default_strategy<Geometry1, Geometry2, cartesian_tag, cartesian_tag>
94 using type = strategies::distance::cartesian<>;
98 template <typename CT>
99 struct strategy_converter<strategy::distance::pythagoras<CT> >
101 template <typename S>
102 static auto get(S const&)
104 return strategies::distance::cartesian<CT>();
108 template <typename CT, typename PPS>
109 struct strategy_converter<strategy::distance::projected_point<CT, PPS> >
110 : strategy_converter<PPS>
113 template <typename CT>
114 struct strategy_converter<strategy::distance::pythagoras_point_box<CT> >
116 static auto get(strategy::distance::pythagoras_point_box<CT> const&)
118 return strategies::distance::cartesian<CT>();
122 template <typename CT, typename PPS>
123 struct strategy_converter<strategy::distance::cartesian_segment_box<CT, PPS> >
124 : strategy_converter<PPS>
127 template <typename CT>
128 struct strategy_converter<strategy::distance::pythagoras_box_box<CT> >
130 static auto get(strategy::distance::pythagoras_box_box<CT> const&)
132 return strategies::distance::cartesian<CT>();
137 template <typename CT>
138 struct strategy_converter<strategy::distance::comparable::pythagoras<CT> >
140 template <typename S>
141 static auto get(S const&)
143 return strategies::distance::detail::make_comparable(
144 strategies::distance::cartesian<CT>());
148 template <typename CT>
149 struct strategy_converter<strategy::distance::comparable::pythagoras_point_box<CT> >
151 static auto get(strategy::distance::comparable::pythagoras_point_box<CT> const&)
153 return strategies::distance::detail::make_comparable(
154 strategies::distance::cartesian<CT>());
158 template <typename CT>
159 struct strategy_converter<strategy::distance::comparable::pythagoras_box_box<CT> >
161 static auto get(strategy::distance::comparable::pythagoras_box_box<CT> const&)
163 return strategies::distance::detail::make_comparable(
164 strategies::distance::cartesian<CT>());
169 } // namespace services
171 }} // namespace strategies::distance
173 }} // namespace boost::geometry
175 #endif // BOOST_GEOMETRY_STRATEGIES_DISTANCE_CARTESIAN_HPP