From 5e733de01f9c2dfacafa4a2acd3ed870085a5601 Mon Sep 17 00:00:00 2001 From: Menelaos Karavelas Date: Fri, 21 Feb 2014 13:42:54 +0200 Subject: [PATCH] added print-outs for the two geometries, the intersection results for g1,g2 and g2,g1 when the output is an MLS as well as the intersection result when the output is a multipoint --- test/algorithms/test_intersection1.hpp | 36 ++++++++++++++++++++++++++ 1 file changed, 36 insertions(+) diff --git a/test/algorithms/test_intersection1.hpp b/test/algorithms/test_intersection1.hpp index f04e23326..a4dc3caf0 100644 --- a/test/algorithms/test_intersection1.hpp +++ b/test/algorithms/test_intersection1.hpp @@ -14,6 +14,7 @@ #include #include #include +#include #include #include @@ -239,6 +240,39 @@ struct test_intersection_of_geometries #endif } + void base_test_all(Geometry1 const& geometry1, + Geometry2 const& geometry2) const + { + typedef typename boost::range_value::type LineString; + typedef typename bg::point_type::type Point; + typedef bg::model::multi_point MultiPoint; + + MultiLineString mls12_output, mls21_output; + MultiPoint mp12_output, mp21_output; + + bg::intersection(geometry1, geometry2, mls12_output); + bg::intersection(geometry1, geometry2, mp12_output); + bg::intersection(geometry2, geometry1, mls21_output); + bg::intersection(geometry2, geometry1, mp21_output); + + std::cout << "************************************" << std::endl; + std::cout << "Geometry #1: " << bg::wkt(geometry1) << std::endl; + std::cout << "Geometry #2: " << bg::wkt(geometry2) << std::endl; + std::cout << "intersection(1,2) [MLS] : " << bg::wkt(mls12_output) + << std::endl; + std::cout << "intersection(2,1) [MLS]: " << bg::wkt(mls21_output) + << std::endl; + std::cout << std::endl; + std::cout << "intersection(1,2) [MP]: " << bg::wkt(mp12_output) + << std::endl; + std::cout << "intersection(2,1) [MP]: " << bg::wkt(mp21_output) + << std::endl; + std::cout << std::endl; + std::cout << "************************************" << std::endl; + std::cout << std::endl; + std::cout << std::endl; + } + void operator()(Geometry1 const& geometry1, Geometry2 const& geometry2, @@ -256,6 +290,8 @@ struct test_intersection_of_geometries base_test(rg1, geometry2, mls_int1, mls_int2); base_test(rg1, rg2, mls_int1, mls_int2); + base_test_all(geometry1, geometry2); + #ifdef GEOMETRY_TEST_DEBUG std::cout << std::endl; std::cout << std::endl;