// Boost.Geometry (aka GGL, Generic Geometry Library) // Copyright (c) 2007-2012 Barend Gehrels, Amsterdam, the Netherlands. // Copyright (c) 2008-2012 Bruno Lalande, Paris, France. // Copyright (c) 2009-2012 Mateusz Loskot, London, UK. // Copyright (c) 2017 Adam Wulkiewicz, Lodz, Poland. // This file was modified by Oracle on 2015. // Modifications copyright (c) 2015 Oracle and/or its affiliates. // Contributed and/or modified by Adam Wulkiewicz, on behalf of Oracle // Parts of Boost.Geometry are redesigned from Geodan's Geographic Library // (geolib/GGL), copyright (c) 1995-2010 Geodan, Amsterdam, the Netherlands. // 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_CARTESIAN_CENTROID_AVERAGE_HPP #define BOOST_GEOMETRY_STRATEGIES_CARTESIAN_CENTROID_AVERAGE_HPP #include #include #include #include #include #include #include namespace boost { namespace geometry { namespace strategy { namespace centroid { /*! \brief Centroid calculation taking average of points \ingroup strategies */ template < typename PointCentroid, typename Point = PointCentroid > class average { private : /*! subclass to keep state */ class sum { friend class average; signed_size_type count; PointCentroid centroid; public : inline sum() : count(0) { assign_zero(centroid); } }; public : typedef sum state_type; typedef PointCentroid centroid_point_type; typedef Point point_type; static inline void apply(Point const& p, sum& state) { add_point(state.centroid, p); state.count++; } static inline bool result(sum const& state, PointCentroid& centroid) { centroid = state.centroid; if ( state.count > 0 ) { divide_value(centroid, state.count); return true; } return false; } }; #ifndef DOXYGEN_NO_STRATEGY_SPECIALIZATIONS namespace services { template struct default_strategy < cartesian_tag, pointlike_tag, DimensionCount, Point, Geometry > { typedef average < Point, typename point_type::type > type; }; } // namespace services #endif }} // namespace strategy::centroid }} // namespace boost::geometry #endif // BOOST_GEOMETRY_STRATEGIES_CARTESIAN_CENTROID_AVERAGE_HPP