// Boost.Geometry Index // // boxes union/intersection area/volume // // Copyright (c) 2011-2018 Adam Wulkiewicz, Lodz, Poland. // // This file was modified by Oracle on 2019. // Modifications copyright (c) 2019 Oracle and/or its affiliates. // 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_INDEX_DETAIL_ALGORITHMS_INTERSECTION_CONTENT_HPP #define BOOST_GEOMETRY_INDEX_DETAIL_ALGORITHMS_INTERSECTION_CONTENT_HPP #include #include #include namespace boost { namespace geometry { namespace index { namespace detail { // Util to distinguish between default and non-default index strategy template inline bool disjoint_box_box(Box const& box1, Box const& box2, Strategy const&) { return geometry::detail::disjoint::disjoint_box_box(box1, box2, typename Strategy::disjoint_box_box_strategy_type()); } template inline bool disjoint_box_box(Box const& box1, Box const& box2, default_strategy const& ) { typedef typename strategy::disjoint::services::default_strategy::type strategy_type; return geometry::detail::disjoint::disjoint_box_box(box1, box2, strategy_type()); } /** * \brief Compute the area, volume, ... of the intersection of b1 and b2 */ template inline typename default_content_result::type intersection_content(Box const& box1, Box const& box2, Strategy const& strategy) { bool const intersects = ! index::detail::disjoint_box_box(box1, box2, strategy); // NOTE: the code below may be inconsistent with the disjoint_box_box() // however intersection_box_box checks if the boxes intersect on the fly so it should be ok // but this also means that disjoint_box_box() is probably not needed if ( intersects ) { Box box_intersection; bool const ok = geometry::detail::intersection::intersection_box_box < 0, geometry::dimension::value >::apply(box1, box2, 0, box_intersection, 0); if ( ok ) { return index::detail::content(box_intersection); } } return 0; } template inline typename default_content_result::type intersection_content(Box const& box1, Box const& box2) { return intersection_content(box1, box2, default_strategy()); } }}}} // namespace boost::geometry::index::detail #endif // BOOST_GEOMETRY_INDEX_DETAIL_ALGORITHMS_INTERSECTION_CONTENT_HPP