// 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-2021. // Modifications copyright (c) 2015-2021 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 Ignored1 = void, typename Ignored2 = void > class average { private : /*! subclass to keep state */ template class sum { friend class average; signed_size_type count; ResultPoint centroid; public : inline sum() : count(0) { assign_zero(centroid); } }; public : template struct state_type { typedef sum type; }; template static inline void apply(GeometryPoint const& p, sum& state) { add_point(state.centroid, p); state.count++; } template static inline bool result(sum const& state, ResultPoint& 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