Boost logo

Boost-Commit :

Subject: [Boost-commit] svn:boost r74951 - in sandbox/gtl: boost/polygon/detail libs/polygon/test
From: sydorchuk.andriy_at_[hidden]
Date: 2011-10-15 18:51:07


Author: asydorchuk
Date: 2011-10-15 18:51:06 EDT (Sat, 15 Oct 2011)
New Revision: 74951
URL: http://svn.boost.org/trac/boost/changeset/74951

Log:
Migrated distance predicate tests.
Text files modified:
   sandbox/gtl/boost/polygon/detail/voronoi_calc_kernel.hpp | 10 +-
   sandbox/gtl/libs/polygon/test/voronoi_calc_kernel_test.cpp | 148 ++++++++++++++++++++++++++++++++++++++++
   2 files changed, 154 insertions(+), 4 deletions(-)

Modified: sandbox/gtl/boost/polygon/detail/voronoi_calc_kernel.hpp
==============================================================================
--- sandbox/gtl/boost/polygon/detail/voronoi_calc_kernel.hpp (original)
+++ sandbox/gtl/boost/polygon/detail/voronoi_calc_kernel.hpp 2011-10-15 18:51:06 EDT (Sat, 15 Oct 2011)
@@ -1277,14 +1277,16 @@
         exact_circle_formation_functor_type exact_circle_formation_functor_;
     };
 
- template <typename Site, typename Circle>
+ template <typename Site,
+ typename Circle,
+ typename CEP = circle_existence_predicate<Site>,
+ typename CFF = lazy_circle_formation_functor<Site, Circle> >
     class circle_formation_predicate {
     public:
         typedef Site site_type;
         typedef Circle circle_type;
- typedef circle_existence_predicate<site_type> circle_existence_predicate_type;
- typedef lazy_circle_formation_functor<site_type, circle_type>
- circle_formation_functor_type;
+ typedef CEP circle_existence_predicate_type;
+ typedef CFF circle_formation_functor_type;
 
         // Create a circle event from the given three sites.
         // Returns true if the circle event exists, else false.

Modified: sandbox/gtl/libs/polygon/test/voronoi_calc_kernel_test.cpp
==============================================================================
--- sandbox/gtl/libs/polygon/test/voronoi_calc_kernel_test.cpp (original)
+++ sandbox/gtl/libs/polygon/test/voronoi_calc_kernel_test.cpp 2011-10-15 18:51:06 EDT (Sat, 15 Oct 2011)
@@ -24,22 +24,50 @@
 VCK::event_equality_predicate<site_type, circle_type> event_equality;
 
 typedef beach_line_node_key<site_type> key_type;
+typedef VCK::distance_predicate<site_type> distance_predicate_type;
 typedef VCK::node_comparison_predicate<key_type> node_comparison_type;
 typedef std::map<key_type, int, node_comparison_type> beach_line_type;
 typedef beach_line_type::iterator bieach_line_iterator;
+distance_predicate_type distance_predicate;
 node_comparison_type node_comparison;
 
+//typedef VCK::circle_formation_predicate lazy_predicate
+
+#define CHECK_ORIENTATION(P1, P2, P3, R1, R2) \
+ BOOST_CHECK_EQUAL(VCK::get_orientation(P1, P2, P3) == R1, true); \
+ BOOST_CHECK_EQUAL(VCK::get_orientation(P1, P3, P2) == R2, true); \
+ BOOST_CHECK_EQUAL(VCK::get_orientation(P2, P1, P3) == R2, true); \
+ BOOST_CHECK_EQUAL(VCK::get_orientation(P2, P3, P1) == R1, true); \
+ BOOST_CHECK_EQUAL(VCK::get_orientation(P3, P1, P2) == R1, true); \
+ BOOST_CHECK_EQUAL(VCK::get_orientation(P3, P2, P1) == R2, true)
+
 #define CHECK_EVENT_COMPARISON(A, B, R1, R2) \
     BOOST_CHECK_EQUAL(event_comparison(A, B), R1); \
     BOOST_CHECK_EQUAL(event_comparison(B, A), R2); \
     BOOST_CHECK_EQUAL(event_equality(A, B), !R1 && !R2)
 
+#define CHECK_DISTANCE_PREDICATE(S1, S2, S3, RES) \
+ BOOST_CHECK_EQUAL(distance_predicate(S1, S2, S3), RES)
+
 #define CHECK_NODE_COMPARISON(node, nodes, res, sz) \
     for (int i = 0; i < sz; ++i) { \
         BOOST_CHECK_EQUAL(node_comparison(node, nodes[i]), res[i]); \
         BOOST_CHECK_EQUAL(node_comparison(nodes[i], node), !res[i]); \
     }
 
+BOOST_AUTO_TEST_CASE(orientation_test) {
+ int min_int = std::numeric_limits<int>::min();
+ int max_int = std::numeric_limits<int>::max();
+ point_type point1(min_int, min_int);
+ point_type point2(0, 0);
+ point_type point3(max_int, max_int);
+ point_type point4(min_int, max_int);
+ point_type point5(max_int-1, max_int);
+ CHECK_ORIENTATION(point1, point2, point3, VCK::COLLINEAR, VCK::COLLINEAR);
+ CHECK_ORIENTATION(point1, point4, point3, VCK::RIGHT, VCK::LEFT);
+ CHECK_ORIENTATION(point1, point5, point3, VCK::RIGHT, VCK::LEFT);
+}
+
 BOOST_AUTO_TEST_CASE(event_comparison_test1) {
     site_type site(1, 2, 0);
     CHECK_EVENT_COMPARISON(site, site_type(0, 2, 1), false, true);
@@ -85,6 +113,126 @@
     CHECK_EVENT_COMPARISON(circle, site_type(4, 2, 5), true, false);
 }
 
+BOOST_AUTO_TEST_CASE(distance_predicate_test1) {
+ site_type site1(-5, 0, 0);
+ site_type site2(-8, 9, 1);
+ site_type site3(-2, 1, 2);
+ CHECK_DISTANCE_PREDICATE(site1, site2, site_type(0, 5, 3), false);
+ CHECK_DISTANCE_PREDICATE(site3, site1, site_type(0, 5, 3), false);
+ CHECK_DISTANCE_PREDICATE(site1, site2, site_type(0, 4, 3), false);
+ CHECK_DISTANCE_PREDICATE(site3, site1, site_type(0, 4, 3), false);
+ CHECK_DISTANCE_PREDICATE(site1, site2, site_type(0, 6, 3), true);
+ CHECK_DISTANCE_PREDICATE(site3, site1, site_type(0, 6, 3), true);
+}
+
+BOOST_AUTO_TEST_CASE(distance_predicate_test2) {
+ site_type site1(-4, 0, -4, 20, 0);
+ site_type site2(-2, 10, 1);
+ CHECK_DISTANCE_PREDICATE(site2, site1, site_type(0, 11, 2), false);
+ CHECK_DISTANCE_PREDICATE(site2, site1, site_type(0, 9, 2), false);
+ CHECK_DISTANCE_PREDICATE(site1, site2, site_type(0, 11, 2), true);
+ CHECK_DISTANCE_PREDICATE(site1, site2, site_type(0, 9, 2), true);
+}
+
+BOOST_AUTO_TEST_CASE(disntace_predicate_test3) {
+ site_type site1(-5, 5, 2, -2, 0);
+ site1.inverse();
+ site_type site2(-2, 4, 1);
+ CHECK_DISTANCE_PREDICATE(site1, site2, site_type(0, -1, 2), false);
+ CHECK_DISTANCE_PREDICATE(site2, site1, site_type(0, -1, 2), false);
+ CHECK_DISTANCE_PREDICATE(site1, site2, site_type(0, 1, 2), false);
+ CHECK_DISTANCE_PREDICATE(site2, site1, site_type(0, 1, 2), false);
+ CHECK_DISTANCE_PREDICATE(site1, site2, site_type(0, 4, 2), true);
+ CHECK_DISTANCE_PREDICATE(site2, site1, site_type(0, 4, 2), false);
+ CHECK_DISTANCE_PREDICATE(site1, site2, site_type(0, 5, 2), true);
+ CHECK_DISTANCE_PREDICATE(site2, site1, site_type(0, 5, 2), false);
+}
+
+BOOST_AUTO_TEST_CASE(distance_predicate_test4) {
+ site_type site1(-5, 5, 2, -2, 0);
+ site_type site2(-2, -4, 1);
+ site_type site3(-4, 1, 0);
+ CHECK_DISTANCE_PREDICATE(site1, site2, site_type(0, 1, 3), true);
+ CHECK_DISTANCE_PREDICATE(site2, site1, site_type(0, 1, 3), true);
+ CHECK_DISTANCE_PREDICATE(site1, site3, site_type(0, 1, 3), true);
+ CHECK_DISTANCE_PREDICATE(site3, site1, site_type(0, 1, 3), true);
+ CHECK_DISTANCE_PREDICATE(site1, site2, site_type(0, -2, 3), true);
+ CHECK_DISTANCE_PREDICATE(site2, site1, site_type(0, -2, 3), false);
+ CHECK_DISTANCE_PREDICATE(site1, site3, site_type(0, -2, 3), true);
+ CHECK_DISTANCE_PREDICATE(site3, site1, site_type(0, -2, 3), false);
+ CHECK_DISTANCE_PREDICATE(site1, site2, site_type(0, -8, 3), true);
+ CHECK_DISTANCE_PREDICATE(site2, site1, site_type(0, -8, 3), false);
+ CHECK_DISTANCE_PREDICATE(site1, site3, site_type(0, -8, 3), true);
+ CHECK_DISTANCE_PREDICATE(site3, site1, site_type(0, -8, 3), false);
+ CHECK_DISTANCE_PREDICATE(site1, site2, site_type(0, -9, 3), true);
+ CHECK_DISTANCE_PREDICATE(site2, site1, site_type(0, -9, 3), false);
+ CHECK_DISTANCE_PREDICATE(site1, site3, site_type(0, -9, 3), true);
+ CHECK_DISTANCE_PREDICATE(site3, site1, site_type(0, -9, 3), false);
+}
+
+BOOST_AUTO_TEST_CASE(disntace_predicate_test5) {
+ site_type site1(-5, 5, 2, -2, 0);
+ site_type site2 = site1;
+ site2.inverse();
+ site_type site3(-2, 4, 1);
+ site_type site4(-2, -4, 1);
+ site_type site5(-4, 1, 1);
+ CHECK_DISTANCE_PREDICATE(site3, site2, site_type(0, 1, 2), false);
+ CHECK_DISTANCE_PREDICATE(site3, site2, site_type(0, 4, 2), false);
+ CHECK_DISTANCE_PREDICATE(site3, site2, site_type(0, 5, 2), false);
+ CHECK_DISTANCE_PREDICATE(site3, site2, site_type(0, 7, 2), true);
+ CHECK_DISTANCE_PREDICATE(site4, site1, site_type(0, -2, 2), false);
+ CHECK_DISTANCE_PREDICATE(site5, site1, site_type(0, -2, 2), false);
+ CHECK_DISTANCE_PREDICATE(site4, site1, site_type(0, -8, 2), false);
+ CHECK_DISTANCE_PREDICATE(site5, site1, site_type(0, -8, 2), false);
+ CHECK_DISTANCE_PREDICATE(site4, site1, site_type(0, -9, 2), false);
+ CHECK_DISTANCE_PREDICATE(site5, site1, site_type(0, -9, 2), false);
+ CHECK_DISTANCE_PREDICATE(site4, site1, site_type(0, -18, 2), false);
+ CHECK_DISTANCE_PREDICATE(site5, site1, site_type(0, -18, 2), false);
+ CHECK_DISTANCE_PREDICATE(site4, site1, site_type(0, -1, 2), true);
+ CHECK_DISTANCE_PREDICATE(site5, site1, site_type(0, -1, 2), true);
+}
+
+BOOST_AUTO_TEST_CASE(distance_predicate_test6) {
+ site_type site1(-5, 0, 2, 7, 0);
+ site_type site2 = site1;
+ site2.inverse();
+ CHECK_DISTANCE_PREDICATE(site1, site2, site_type(2, 7, 1), false);
+ CHECK_DISTANCE_PREDICATE(site1, site2, site_type(1, 5, 1), false);
+ CHECK_DISTANCE_PREDICATE(site1, site2, site_type(-1, 5, 1), true);
+}
+
+BOOST_AUTO_TEST_CASE(distance_predicate_test7) {
+ site_type site1(-5, 5, 2, -2, 0);
+ site1.inverse();
+ site_type site2(-5, 5, 0, 6, 1);
+ site_type site3(-2, 4, 0, 4, 2);
+ site_type site4(0, 2, 3);
+ site_type site5(0, 5, 4);
+ site_type site6(0, 6, 5);
+ site_type site7(0, 8, 6);
+ CHECK_DISTANCE_PREDICATE(site1, site2, site4, false);
+ CHECK_DISTANCE_PREDICATE(site1, site2, site5, true);
+ CHECK_DISTANCE_PREDICATE(site1, site2, site6, true);
+ CHECK_DISTANCE_PREDICATE(site1, site2, site7, true);
+ CHECK_DISTANCE_PREDICATE(site1, site3, site4, false);
+ CHECK_DISTANCE_PREDICATE(site1, site3, site5, true);
+ CHECK_DISTANCE_PREDICATE(site1, site3, site6, true);
+ CHECK_DISTANCE_PREDICATE(site1, site3, site7, true);
+ site3.inverse();
+ CHECK_DISTANCE_PREDICATE(site3, site1, site4, false);
+ CHECK_DISTANCE_PREDICATE(site3, site1, site5, false);
+ CHECK_DISTANCE_PREDICATE(site3, site1, site6, false);
+ CHECK_DISTANCE_PREDICATE(site3, site1, site7, true);
+}
+
+BOOST_AUTO_TEST_CASE(distatnce_predicate_test8) {
+ site_type site1(-5, 3, -2, 2, 0);
+ site1.inverse();
+ site_type site2(-5, 5, -2, 2, 1);
+ CHECK_DISTANCE_PREDICATE(site1, site2, site_type(-4, 2, 2), false);
+}
+
 BOOST_AUTO_TEST_CASE(node_comparison_test1) {
     beach_line_type beach_line;
     site_type site1(0, 0, 0);


Boost-Commit list run by bdawes at acm.org, david.abrahams at rcn.com, gregod at cs.rpi.edu, cpdaniel at pacbell.net, john at johnmaddock.co.uk