// Boost.Geometry // Copyright (c) 2018, Oracle and/or its affiliates. // Contributed and/or modified by Vissarion Fysikopoulos, on behalf of Oracle // Licensed under the Boost Software License version 1.0. // http://www.boost.org/users/license.html #ifndef BOOST_GEOMETRY_STRATEGIES_CARTESIAN_LINE_INTERPOLATE_HPP #define BOOST_GEOMETRY_STRATEGIES_CARTESIAN_LINE_INTERPOLATE_HPP #include #include #include #include #include #include namespace boost { namespace geometry { namespace strategy { namespace line_interpolate { /*! \brief Interpolate point on a cartesian segment. \ingroup strategies \tparam CalculationType \tparam_calculation \tparam DistanceStrategy The underlying point-point distance strategy \qbk{ [heading See also] \* [link geometry.reference.algorithms.line_interpolate.line_interpolate_4_with_strategy line_interpolate (with strategy)] } */ template < typename CalculationType = void, typename DistanceStrategy = distance::pythagoras > class cartesian { public: // point-point strategy getters struct distance_pp_strategy { typedef DistanceStrategy type; }; inline typename distance_pp_strategy::type get_distance_pp_strategy() const { typedef typename distance_pp_strategy::type distance_type; return distance_type(); } template inline void apply(Point const& p0, Point const& p1, Fraction const& fraction, Point & p, Distance const&) const { typedef typename select_calculation_type_alt < CalculationType, Point >::type calc_t; typedef model::point < calc_t, geometry::dimension::value, cs::cartesian > calc_point_t; calc_point_t cp0, cp1; geometry::detail::conversion::convert_point_to_point(p0, cp0); geometry::detail::conversion::convert_point_to_point(p1, cp1); //segment convex combination: p0*fraction + p1*(1-fraction) Fraction const one_minus_fraction = 1-fraction; for_each_coordinate(cp1, detail::value_operation < Fraction, std::multiplies >(fraction)); for_each_coordinate(cp0, detail::value_operation < Fraction, std::multiplies >(one_minus_fraction)); for_each_coordinate(cp1, detail::point_operation < calc_point_t, std::plus >(cp0)); assert_dimension_equal(); geometry::detail::conversion::convert_point_to_point(cp1, p); } }; #ifndef DOXYGEN_NO_STRATEGY_SPECIALIZATIONS namespace services { template <> struct default_strategy { typedef strategy::line_interpolate::cartesian<> type; }; } // namespace services #endif // DOXYGEN_NO_STRATEGY_SPECIALIZATIONS }} // namespace strategy::line_interpolate }} // namespace boost::geometry #endif // BOOST_GEOMETRY_STRATEGIES_CARTESIAN_LINE_INTERPOLATE_HPP