1 // Boost.Geometry (aka GGL, Generic Geometry Library) 2 // Unit Test 3 4 // Copyright (c) 2007-2016 Barend Gehrels, Amsterdam, the Netherlands. 5 // Copyright (c) 2008-2016 Bruno Lalande, Paris, France. 6 // Copyright (c) 2009-2016 Mateusz Loskot, London, UK. 7 8 // This file was modified by Oracle on 2016,2017. 9 // Modifications copyright (c) 2016-2017, Oracle and/or its affiliates. 10 // Contributed and/or modified by Adam Wulkiewicz, on behalf of Oracle 11 12 // Parts of Boost.Geometry are redesigned from Geodan's Geographic Library 13 // (geolib/GGL), copyright (c) 1995-2010 Geodan, Amsterdam, the Netherlands. 14 15 // Use, modification and distribution is subject to the Boost Software License, 16 // Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at 17 // http://www.boost.org/LICENSE_1_0.txt) 18 19 #include <iostream> 20 #include <string> 21 22 #include "test_union.hpp" 23 #include <algorithms/test_overlay.hpp> 24 25 #include <algorithms/overlay/overlay_cases.hpp> 26 #include <boost/geometry/geometries/point_xy.hpp> 27 28 29 #define TEST_UNION(caseid, clips, holes, points, area) \ 30 (test_one<Polygon, Polygon, Polygon>) \ 31 ( #caseid, caseid[0], caseid[1], clips, holes, points, area) 32 33 #define TEST_UNION_REV(caseid, clips, holes, points, area) \ 34 (test_one<Polygon, Polygon, Polygon>) \ 35 ( #caseid "_rev", caseid[1], caseid[0], clips, holes, points, area) 36 37 #if ! defined(BOOST_GEOMETRY_USE_RESCALING) \ 38 && defined(BOOST_GEOMETRY_USE_KRAMER_RULE) \ 39 && ! defined(BOOST_GEOMETRY_TEST_FAILURES) 40 // These testcases are failing for non-rescaled Kramer rule 41 #define BOOST_GEOMETRY_EXCLUDE 42 #endif 43 44 45 template <typename Ring, typename Polygon> test_areal()46 void test_areal() 47 { 48 typedef typename bg::coordinate_type<Polygon>::type ct; 49 50 test_one<Polygon, Polygon, Polygon>("simplex_normal", 51 simplex_normal[0], simplex_normal[1], 52 1, 0, 13, 11.526367); 53 54 test_one<Polygon, Polygon, Polygon>("simplex_with_empty_1", 55 simplex_normal[0], polygon_empty, 56 1, 0, 4, 8.0); 57 test_one<Polygon, Polygon, Polygon>("simplex_with_empty_2", 58 polygon_empty, simplex_normal[0], 59 1, 0, 4, 8.0); 60 61 test_one<Polygon, Polygon, Polygon>("star_ring", example_star, example_ring, 62 1, 0, 23, 5.67017141); 63 64 // This sample was selected because of the border case, and ttmath generates one point more. 65 test_one<Polygon, Polygon, Polygon>("star_poly", example_star, example_polygon, 66 1, 1, 67 if_typed_tt<ct>(28, 27), 5.647949); 68 69 // Pseudo-box as Polygon 70 // (note, internally, the intersection points is different, so yes, 71 // it has to be tested) 72 test_one<Polygon, Polygon, Polygon>("box_poly3", "POLYGON((1.5 1.5 , 1.5 2.5 , 4.5 2.5 , 4.5 1.5 , 1.5 1.5))", 73 "POLYGON((2 1.3,2.4 1.7,2.8 1.8,3.4 1.2,3.7 1.6,3.4 2,4.1 2.5,5.3 2.5,5.4 1.2,4.9 0.8,2.9 0.7,2 1.3))", 74 1, 1, 15, 5.93625); 75 76 test_one<Polygon, Polygon, Polygon>("first_within_second", 77 first_within_second[0], first_within_second[1], 78 1, 0, 5, 25.0); 79 80 test_one<Polygon, Polygon, Polygon>("second_within_first", 81 first_within_second[1], first_within_second[0], 82 1, 0, 5, 25.0); 83 84 test_one<Polygon, Polygon, Polygon>("first_within_hole_of_second", 85 first_within_hole_of_second[0], first_within_hole_of_second[1], 86 2, 1, 15, 17.0); 87 88 test_one<Polygon, Polygon, Polygon>("new_hole", 89 new_hole[0], new_hole[1], 90 1, 1, 14, 23.0); 91 92 test_one<Polygon, Polygon, Polygon>("side_side", 93 side_side[0], side_side[1], 1, 0, 7, 2.0); 94 95 test_one<Polygon, Polygon, Polygon>("identical", 96 identical[0], identical[1], 1, 0, 5, 1.0); 97 98 test_one<Polygon, Polygon, Polygon>("disjoint", 99 disjoint[0], disjoint[1], 2, 0, 10, 2.0); 100 101 test_one<Polygon, Polygon, Polygon>("intersect_holes_intersect", 102 intersect_holes_intersect[0], intersect_holes_intersect[1], 103 1, 1, 14, 39.75); 104 105 test_one<Polygon, Polygon, Polygon>("intersect_holes_intersect_and_disjoint", 106 intersect_holes_intersect_and_disjoint[0], intersect_holes_intersect_and_disjoint[1], 107 1, 1, 14, 39.75); 108 109 test_one<Polygon, Polygon, Polygon>("intersect_holes_intersect_and_touch", 110 intersect_holes_intersect_and_touch[0], intersect_holes_intersect_and_touch[1], 111 1, 1, 14, 39.75); 112 113 test_one<Polygon, Polygon, Polygon>("intersect_holes_new_ring", 114 intersect_holes_new_ring[0], intersect_holes_new_ring[1], 115 1, 2, 15, 253.8961); 116 117 test_one<Polygon, Polygon, Polygon>("intersect_holes_disjoint", 118 intersect_holes_disjoint[0], 119 intersect_holes_disjoint[1], 120 1, 0, 9, 40.0); 121 122 test_one<Polygon, Polygon, Polygon>("within_holes_disjoint", 123 within_holes_disjoint[0], within_holes_disjoint[1], 124 1, 0, 5, 49.0); 125 126 test_one<Polygon, Polygon, Polygon>("winded", 127 winded[0], winded[1], 128 1, 5, 30, 114.0); 129 130 test_one<Polygon, Polygon, Polygon>("two_bends", 131 two_bends[0], two_bends[1], 132 1, 0, 7, 40.0); 133 134 test_one<Polygon, Polygon, Polygon>("star_comb_15", 135 star_comb_15[0], star_comb_15[1], 136 1, 27, 204, 898.09693338); 137 138 test_one<Polygon, Polygon, Polygon>("equal_holes_disjoint", 139 equal_holes_disjoint[0], equal_holes_disjoint[1], 140 1, 1, 10, 81 - 3 * 7); 141 142 test_one<Polygon, Polygon, Polygon>("only_hole_intersections1", 143 only_hole_intersections[0], only_hole_intersections[1], 144 1, 2, 13, 190.9090909); 145 test_one<Polygon, Polygon, Polygon>("only_hole_intersections2", 146 only_hole_intersections[0], only_hole_intersections[2], 147 1, 2, 13, 190.9090909); 148 149 test_one<Polygon, Polygon, Polygon>("intersect_exterior_and_interiors_winded", 150 intersect_exterior_and_interiors_winded[0], intersect_exterior_and_interiors_winded[1], 151 1, 1, 26, 66.5333333); 152 153 test_one<Polygon, Polygon, Polygon>("crossed", 154 crossed[0], crossed[1], 155 1, 3, 17, 23.5); // Area from SQL Server - was somehow wrong before 156 157 test_one<Polygon, Polygon, Polygon>("fitting", 158 fitting[0], fitting[1], 159 1, 0, 5, 25); 160 161 test_one<Polygon, Polygon, Polygon>("distance_zero", 162 distance_zero[0], distance_zero[1], 163 1, 0, 8, 9.0098387); 164 165 test_one<Polygon, Polygon, Polygon>("wrapped_a", 166 wrapped[0], wrapped[1], 167 1, 1, 16, 16); 168 test_one<Polygon, Polygon, Polygon>("wrapped_b", 169 wrapped[0], wrapped[2], 170 1, 1, 16, 16); 171 172 test_one<Polygon, Polygon, Polygon>("9", 173 case_9[0], case_9[1], 2, 0, 8, 11); 174 test_one<Polygon, Polygon, Polygon>("22", 175 case_22[0], case_22[1], 2, 0, 8, 9.5); 176 test_one<Polygon, Polygon, Polygon>("25", 177 case_25[0], case_25[1], 2, 0, 8, 7); 178 test_one<Polygon, Polygon, Polygon>("26", 179 case_26[0], case_26[1], 2, 0, 9, 7.5); 180 test_one<Polygon, Polygon, Polygon>("31", 181 case_31[0], case_31[1], 2, 0, 8, 4.5); 182 test_one<Polygon, Polygon, Polygon>("32", 183 case_32[0], case_32[1], 2, 0, 8, 4.5); 184 test_one<Polygon, Polygon, Polygon>("33", 185 case_33[0], case_33[1], 2, 0, 8, 4.5); 186 test_one<Polygon, Polygon, Polygon>("36", 187 case_36[0], case_36[1], 1, 1, 10, 14.375); 188 test_one<Polygon, Polygon, Polygon>("40", 189 case_40[0], case_40[1], 2, 0, 18, 11); 190 191 // Test rings which should be generated by assemble 192 test_one<Polygon, Polygon, Polygon>("53_iet", 193 case_53[0], case_53[2], 1, 1, 16, 16); 194 test_one<Polygon, Polygon, Polygon>("58_iet", 195 case_58[0], case_58[2], 1, 3, 20, 12.16666); 196 197 test_one<Polygon, Polygon, Polygon>("59_iet", 198 case_59[0], case_59[2], 1, 1, 14, 17.20833); 199 200 test_one<Polygon, Polygon, Polygon>("80", 201 case_80[0], case_80[1], 2, 2, 18, 129.0); 202 203 test_one<Polygon, Polygon, Polygon>("81", 204 case_81[0], case_81[1], 1, 2, 15, 163.5); 205 206 test_one<Polygon, Polygon, Polygon>("82", 207 case_82[0], case_82[1], 1, 1, 21, 19.75); 208 209 test_one<Polygon, Polygon, Polygon>("83", 210 case_83[0], case_83[1], 1, 0, 7, 20.0); 211 212 test_one<Polygon, Polygon, Polygon>("90", 213 case_90[0], case_90[1], 1, 2, 17, 221.3688); 214 215 test_one<Polygon, Polygon, Polygon>("91", 216 case_91[0], case_91[1], 1, 1, 9, 147.5); 217 218 test_one<Polygon, Polygon, Polygon>("92", 219 case_92[0], case_92[1], 2, 0, 9, 175.0); 220 221 test_one<Polygon, Polygon, Polygon>("93", 222 case_93[0], case_93[1], 1, 2, 12, 172.9167); 223 224 test_one<Polygon, Polygon, Polygon>("94", 225 case_94[0], case_94[1], 2, 0, 12, 170.0); 226 227 // Has two separate but touching interior rings 228 test_one<Polygon, Polygon, Polygon>("95", 229 case_95[0], case_95[1], 1, 2, 15, 1320.0); 230 231 test_one<Polygon, Polygon, Polygon>("96", 232 case_96[0], case_96[1], 1, 1, 10, 1500.0); 233 234 test_one<Polygon, Polygon, Polygon>("97", 235 case_97[0], case_97[1], 1, 0, 10, 286.799); 236 237 test_one<Polygon, Polygon, Polygon>("98", 238 case_98[0], case_98[1], 1, 1, 14, 653.067); 239 240 test_one<Polygon, Polygon, Polygon>("99", 241 case_99[0], case_99[1], 1, 0, 5, 1600.0); 242 243 test_one<Polygon, Polygon, Polygon>("100", 244 case_100[0], case_100[1], 1, 1, 13, 19.125); 245 246 test_one<Polygon, Polygon, Polygon>("101", 247 case_101[0], case_101[1], 1, 0, 9, 21.0); 248 249 test_one<Polygon, Polygon, Polygon>("102", 250 case_102[0], case_102[1], 1, 1, 17, 8.75); 251 252 test_one<Polygon, Polygon, Polygon>("103", 253 case_103[0], case_103[1], 254 1, 0, 5, 1.0); 255 test_one<Polygon, Polygon, Polygon>("104", 256 case_104[0], case_104[1], 257 1, 0, 5, 100.0); 258 259 test_one<Polygon, Polygon, Polygon>("105", 260 case_105[0], case_105[1], 1, 0, 5, 100); 261 262 test_one<Polygon, Polygon, Polygon>("108", 263 case_108[0], case_108[1], 1, 0, 13, 5.0); 264 265 TEST_UNION(case_precision_1, 1, 0, -1, 22.0); 266 TEST_UNION(case_precision_2, 1, 0, -1, 22.0); 267 TEST_UNION(case_precision_3, 1, 0, -1, 22.0); 268 TEST_UNION(case_precision_4, 1, 0, -1, 22.0); 269 TEST_UNION(case_precision_5, 1, 0, -1, 22.0); 270 TEST_UNION(case_precision_6, 1, 0, -1, 71.0); 271 TEST_UNION(case_precision_7, 1, 0, -1, 22.0); 272 TEST_UNION(case_precision_8, 1, 1, -1, 73.0); 273 TEST_UNION(case_precision_9, 1, 1, -1, 73.0); 274 TEST_UNION(case_precision_10, 1, 1, -1, 73.0); 275 TEST_UNION(case_precision_11, 1, 1, -1, 73.0); 276 TEST_UNION(case_precision_12, 1, 0, -1, 14.0); 277 TEST_UNION(case_precision_13, 1, 0, -1, 14.0); 278 TEST_UNION(case_precision_14, 1, 0, -1, 22.0); 279 TEST_UNION(case_precision_15, 1, 1, -1, 73.0); 280 TEST_UNION(case_precision_16, 1, 1, -1, 73.0); 281 TEST_UNION(case_precision_17, 1, 1, -1, 73.0); 282 TEST_UNION(case_precision_18, 1, 1, -1, 73.0); 283 TEST_UNION(case_precision_19, 1, 1, -1, 73.0); 284 TEST_UNION(case_precision_20, 1, 0, -1, 22.0); 285 TEST_UNION(case_precision_21, 1, 0, -1, 22.0); 286 TEST_UNION(case_precision_22, 1, 1, -1, 73.0); 287 TEST_UNION(case_precision_23, 1, 1, -1, 73.0); 288 TEST_UNION(case_precision_24, 1, 0, -1, 22.0); 289 TEST_UNION(case_precision_25, 1, 0, -1, 22.0); 290 TEST_UNION(case_precision_26, 1, 1, -1, 73.0); 291 292 TEST_UNION_REV(case_precision_1, 1, 0, -1, 22.0); 293 TEST_UNION_REV(case_precision_2, 1, 0, -1, 22.0); 294 TEST_UNION_REV(case_precision_3, 1, 0, -1, 22.0); 295 TEST_UNION_REV(case_precision_4, 1, 0, -1, 22.0); 296 TEST_UNION_REV(case_precision_5, 1, 0, -1, 22.0); 297 TEST_UNION_REV(case_precision_6, 1, 0, -1, 71.0); 298 TEST_UNION_REV(case_precision_7, 1, 0, -1, 22.0); 299 TEST_UNION_REV(case_precision_8, 1, 1, -1, 73.0); 300 TEST_UNION_REV(case_precision_9, 1, 1, -1, 73.0); 301 TEST_UNION_REV(case_precision_10, 1, 1, -1, 73.0); 302 TEST_UNION_REV(case_precision_11, 1, 1, -1, 73.0); 303 TEST_UNION_REV(case_precision_12, 1, 0, -1, 14.0); 304 TEST_UNION_REV(case_precision_13, 1, 0, -1, 14.0); 305 TEST_UNION_REV(case_precision_14, 1, 0, -1, 22.0); 306 TEST_UNION_REV(case_precision_15, 1, 1, -1, 73.0); 307 TEST_UNION_REV(case_precision_16, 1, 1, -1, 73.0); 308 TEST_UNION_REV(case_precision_17, 1, 1, -1, 73.0); 309 TEST_UNION_REV(case_precision_18, 1, 1, -1, 73.0); 310 TEST_UNION_REV(case_precision_19, 1, 1, -1, 73.0); 311 TEST_UNION_REV(case_precision_20, 1, 0, -1, 22.0); 312 TEST_UNION_REV(case_precision_21, 1, 0, -1, 22.0); 313 TEST_UNION_REV(case_precision_22, 1, 1, -1, 73.0); 314 TEST_UNION_REV(case_precision_23, 1, 1, -1, 73.0); 315 TEST_UNION_REV(case_precision_24, 1, 0, -1, 22.0); 316 TEST_UNION_REV(case_precision_25, 1, 0, -1, 22.0); 317 TEST_UNION_REV(case_precision_26, 1, 1, -1, 73.0); 318 319 /* 320 test_one<Polygon, Polygon, Polygon>(102, 321 simplex_normal[0], simplex_reversed[1], 322 1, 0, 7, X); 323 324 test_one<Polygon, Polygon, Polygon>(103, 325 simplex_reversed[0], simplex_normal[1], 326 1, 0, 7, 24.0); 327 328 test_one<Polygon, Polygon, Polygon>(104, 329 simplex_reversed[0], simplex_reversed[1], 330 1, 0, 7, 24.0); 331 332 test_one<Polygon, Polygon, Polygon>(100, 333 star_15, comb_15, 334 1, 10, 7, 24.0); 335 */ 336 337 // test some other input/output types 338 339 // 1 input Ring 340 test_one<Polygon, Polygon, Ring>("identical_pr", identical[0], identical[1], 1, 0, 5, 1.0); 341 test_one<Polygon, Ring, Polygon>("identical_rp", identical[0], identical[1], 1, 0, 5, 1.0); 342 343 // 2 input rings 344 test_one<Polygon, Ring, Ring>("identical_rr", identical[0], identical[1], 1, 0, 5, 1.0); 345 346 // output is also Ring 347 test_one<Ring, Ring, Ring>("identical_rrr", identical[0], identical[1], 1, 0, 5, 1.0); 348 349 // "new hole", tested with Ring -> the newly formed hole will be omitted 350 test_one<Ring, Ring, Ring>("new_hole_discarded", new_hole[0], new_hole[1], 1, 0, 9, 24.0); 351 352 test_one<Polygon, Polygon, Polygon>("ggl_list_20110306_javier", 353 ggl_list_20110306_javier[0], ggl_list_20110306_javier[1], 354 1, 1, 16, 80456.4904910401); 355 356 test_one<Polygon, Polygon, Polygon>("ggl_list_20110307_javier", 357 ggl_list_20110307_javier[0], ggl_list_20110307_javier[1], 358 1, 1, 13, 20016.4); 359 360 test_one<Polygon, Polygon, Polygon>("ggl_list_20110627_phillip", 361 ggl_list_20110627_phillip[0], ggl_list_20110627_phillip[1], 362 1, 0, 8, 14729.07145); 363 364 test_one<Polygon, Polygon, Polygon>("ggl_list_20110716_enrico", 365 ggl_list_20110716_enrico[0], ggl_list_20110716_enrico[1], 366 1, 1, 15, 129904.197692871); 367 368 #if ! defined(BOOST_GEOMETRY_EXCLUDE) 369 test_one<Polygon, Polygon, Polygon>("ggl_list_20110820_christophe", 370 ggl_list_20110820_christophe[0], ggl_list_20110820_christophe[1], 371 -1, // Either 1 or 2, depending if the intersection/turn point (eps.region) is missed 372 0, 373 if_typed_tt<ct>(9, 8), 374 67.3550722317627); 375 #endif 376 377 { 378 ut_settings settings; 379 settings.percentage = 0.1; 380 settings.set_test_validity(BG_IF_RESCALED(true, false)); 381 382 test_one<Polygon, Polygon, Polygon>("isovist", 383 isovist1[0], isovist1[1], 384 1, 385 0, 386 -1, 387 313.36036462, settings); 388 389 // SQL Server gives: 313.360374193241 390 // PostGIS gives: 313.360364623393 391 } 392 393 TEST_UNION(ggl_list_20190307_matthieu_1, 1, 1, -1, 0.83773); 394 TEST_UNION(ggl_list_20190307_matthieu_2, 1, 0, -1, 16.0); 395 396 // Ticket 5103 https://svn.boost.org/trac/boost/ticket/5103 397 // This ticket was actually reported for Boost.Polygon 398 // We check it for Boost.Geometry as well. 399 // SQL Server gives: 2515271331437.69 400 // PostGIS gives: 2515271327070.52 401 // Boost.Geometry gives: 2515271327070.5237746891 (ttmath) 402 // 2515271327070.5156 (double) 403 // 2515271320603.0000 (int) 404 // Note the int-test was tested outside of this unit test. 405 // It is in two points 0.37 off (logical for an int). 406 // Because of the width of the polygon (400000 meter) 407 // this causes a substantial difference. 408 409 test_one<Polygon, Polygon, Polygon>("ticket_5103", 410 ticket_5103[0], ticket_5103[1], 411 1, 0, 25, 2515271327070.5); 412 413 TEST_UNION(ticket_8310a, 1, 0, 5, 10.5000019595); 414 TEST_UNION(ticket_8310b, 1, 0, 5, 10.5000019595); 415 TEST_UNION(ticket_8310c, 1, 0, 5, 10.5000019595); 416 TEST_UNION_REV(ticket_8310a, 1, 0, 5, 10.5000019595); 417 TEST_UNION_REV(ticket_8310b, 1, 0, 5, 10.5000019595); 418 TEST_UNION_REV(ticket_8310c, 1, 0, 5, 10.5000019595); 419 420 test_one<Polygon, Polygon, Polygon>("ticket_9081_15", 421 ticket_9081_15[0], ticket_9081_15[1], 422 1, 0, -1, 0.0403425433); 423 424 { 425 ut_settings settings; 426 settings.set_test_validity(BG_IF_RESCALED(true, false)); 427 test_one<Polygon, Polygon, Polygon>("ticket_9563", ticket_9563[0], ticket_9563[1], 428 1, 0, 13, 150.0, settings); 429 } 430 431 // Float result is OK but a bit larger 432 test_one<Polygon, Polygon, Polygon>("ticket_9756", ticket_9756[0], ticket_9756[1], 433 1, 0, 10, if_typed<ct, float>(1291.5469, 1289.08374)); 434 435 // Can generate one polygon, or two splitted, both is OK 436 #if ! defined(BOOST_GEOMETRY_USE_KRAMER_RULE) 437 TEST_UNION(ticket_10108_a, 2, 0, 8, 0.0435229); 438 TEST_UNION(ticket_10108_b, 1, 0, 10, 2424.3449); 439 #else 440 TEST_UNION(ticket_10108_a, BG_IF_RESCALED(2, 1), 0, 8, 0.0435229); 441 TEST_UNION(ticket_10108_b, BG_IF_RESCALED(1, 2), 0, 10, 2424.3449); 442 #endif 443 444 test_one<Polygon, Polygon, Polygon>("ticket_10866", ticket_10866[0], ticket_10866[1], 445 1, 0, 14, if_typed<ct, float>(332752493.0, 332760303.5)); 446 447 test_one<Polygon, Polygon, Polygon>("ticket_11725", ticket_11725[0], ticket_11725[1], 448 1, 1, 10, 7.5); 449 450 #if ! defined(BOOST_GEOMETRY_USE_RESCALING) || defined(BOOST_GEOMETRY_TEST_FAILURES) 451 // With rescaling an extra overlapping polygon is generated 452 TEST_UNION(issue_548, 1, 0, -1, 617382720000); 453 #endif 454 455 TEST_UNION(issue_566_a, 1, 0, -1, 214.3728); 456 TEST_UNION(issue_566_b, 1, 0, -1, 214.3728); 457 TEST_UNION_REV(issue_566_a, 1, 0, -1, 214.3728); 458 TEST_UNION_REV(issue_566_b, 1, 0, -1, 214.3728); 459 460 if (! BOOST_GEOMETRY_CONDITION((boost::is_same<ct, float>::value)) ) 461 { 462 ut_settings ignore_validity; 463 ignore_validity.set_test_validity(false); 464 ignore_validity.percentage = 0.01; 465 test_one<Polygon, Polygon, Polygon>("geos_1", geos_1[0], geos_1[1], 466 1, 0, -1, 3461.3203125, 467 ignore_validity); 468 } 469 test_one<Polygon, Polygon, Polygon>("geos_2", geos_2[0], geos_2[1], 470 1, 0, -1, 350.55102539); 471 test_one<Polygon, Polygon, Polygon>("geos_3", geos_3[0], geos_3[1], 472 1, 0, -1, 29391548.4998779); 473 test_one<Polygon, Polygon, Polygon>("geos_4", geos_4[0], geos_4[1], 474 1, 0, -1, 2304.4163115); 475 476 // Robustness issues, followed out buffer-robustness-tests, test them also reverse 477 { 478 // Area can vary depending on joining point of nearly parallel lines 479 ut_settings settings; 480 settings.percentage = 0.01; 481 test_one<Polygon, Polygon, Polygon>("buffer_rt_a", buffer_rt_a[0], buffer_rt_a[1], 482 1, 0, -1, 19.28, settings); 483 test_one<Polygon, Polygon, Polygon>("buffer_rt_a_rev", buffer_rt_a[1], buffer_rt_a[0], 484 1, 0, -1, 19.28, settings); 485 } 486 #if ! defined(BOOST_GEOMETRY_EXCLUDE) 487 test_one<Polygon, Polygon, Polygon>("buffer_rt_f", buffer_rt_f[0], buffer_rt_f[1], 488 1, 0, -1, 4.60853); 489 test_one<Polygon, Polygon, Polygon>("buffer_rt_f_rev", buffer_rt_f[1], buffer_rt_f[0], 490 1, 0, -1, 4.60853); 491 #endif 492 test_one<Polygon, Polygon, Polygon>("buffer_rt_g", buffer_rt_g[0], buffer_rt_g[1], 493 1, 0, -1, 16.571); 494 test_one<Polygon, Polygon, Polygon>("buffer_rt_g_rev", buffer_rt_g[1], buffer_rt_g[0], 495 1, 0, -1, 16.571); 496 test_one<Polygon, Polygon, Polygon>("buffer_rt_i", buffer_rt_i[0], buffer_rt_i[1], 497 1, 0, -1, 13.6569); 498 test_one<Polygon, Polygon, Polygon>("buffer_rt_i_rev", buffer_rt_i[1], buffer_rt_i[0], 499 1, 0, -1, 13.6569); 500 test_one<Polygon, Polygon, Polygon>("buffer_rt_j", buffer_rt_j[0], buffer_rt_j[1], 501 1, 0, -1, 16.5711); 502 test_one<Polygon, Polygon, Polygon>("buffer_rt_j_rev", buffer_rt_j[1], buffer_rt_j[0], 503 1, 0, -1, 16.5711); 504 505 test_one<Polygon, Polygon, Polygon>("buffer_rt_l", buffer_rt_l[0], buffer_rt_l[1], 506 1, 0, -1, 19.3995); 507 test_one<Polygon, Polygon, Polygon>("buffer_rt_l_rev", buffer_rt_l[1], buffer_rt_l[0], 508 1, 0, -1, 19.3995); 509 510 test_one<Polygon, Polygon, Polygon>("buffer_rt_m1", buffer_rt_m1[0], buffer_rt_m1[1], 511 1, 0, 9, 19.4852); 512 test_one<Polygon, Polygon, Polygon>("buffer_rt_m1_rev", buffer_rt_m1[1], buffer_rt_m1[0], 513 1, 0, 9, 19.4852); 514 515 test_one<Polygon, Polygon, Polygon>("buffer_rt_m2", buffer_rt_m2[0], buffer_rt_m2[1], 516 1, 0, -1, 21.4853); 517 test_one<Polygon, Polygon, Polygon>("buffer_rt_m2_rev", buffer_rt_m2[1], buffer_rt_m2[0], 518 1, 0, 15, 21.4853); 519 520 test_one<Polygon, Polygon, Polygon>("buffer_rt_q", buffer_rt_q[0], buffer_rt_q[1], 521 1, 0, -1, 18.5710); 522 test_one<Polygon, Polygon, Polygon>("buffer_rt_q_rev", buffer_rt_q[1], buffer_rt_q[0], 523 1, 0, -1, 18.5710); 524 #if ! defined(BOOST_GEOMETRY_EXCLUDE) 525 test_one<Polygon, Polygon, Polygon>("buffer_rt_r", buffer_rt_r[0], buffer_rt_r[1], 526 1, 0, -1, 21.07612); 527 test_one<Polygon, Polygon, Polygon>("buffer_rt_r_rev", buffer_rt_r[1], buffer_rt_r[0], 528 1, 0, -1, 21.07612); 529 #endif 530 test_one<Polygon, Polygon, Polygon>("buffer_rt_t", buffer_rt_t[0], buffer_rt_t[1], 531 1, 0, -1, 15.6569); 532 test_one<Polygon, Polygon, Polygon>("buffer_rt_t_rev", buffer_rt_t[1], buffer_rt_t[0], 533 1, 0, -1, 15.6569); 534 535 test_one<Polygon, Polygon, Polygon>("buffer_mp1", buffer_mp1[0], buffer_mp1[1], 536 1, 0, if_typed_tt<ct>(93, 91), 22.815); 537 538 test_one<Polygon, Polygon, Polygon>("buffer_mp2", buffer_mp2[0], buffer_mp2[1], 539 1, -1, 217, 36.752837); 540 541 test_one<Polygon, Polygon, Polygon>("mysql_21964079_1", 542 mysql_21964079_1[0], mysql_21964079_1[1], 543 2, 1, -1, 234.5); 544 test_one<Polygon, Polygon, Polygon>("mysql_21964079_2", 545 mysql_21964079_2[0], mysql_21964079_2[1], 546 2, 1, -1, 112.0); 547 548 test_one<Polygon, Polygon, Polygon>("mysql_23023665_1", 549 mysql_23023665_1[0], mysql_23023665_1[1], 550 2, 1, -1, 92.0 + 142.5); 551 test_one<Polygon, Polygon, Polygon>("mysql_23023665_2", 552 mysql_23023665_2[0], mysql_23023665_2[1], 553 2, 1, -1, 96.0 + 16.0); 554 test_one<Polygon, Polygon, Polygon>("mysql_23023665_3", 555 mysql_23023665_3[0], mysql_23023665_3[1], 556 2, 1, -1, 225.0 + 66.0); 557 test_one<Polygon, Polygon, Polygon>("mysql_21964049", 558 mysql_21964049[0], mysql_21964049[1], 559 1, 1, -1, 220.5); 560 } 561 562 template <typename P> test_all()563 void test_all() 564 { 565 typedef bg::model::polygon<P> polygon; 566 typedef bg::model::ring<P> ring; 567 typedef bg::model::box<P> box; 568 569 test_areal<ring, polygon>(); 570 571 #if ! defined(BOOST_GEOMETRY_TEST_ONLY_ONE_TYPE) 572 // Open 573 test_areal<bg::model::ring<P, true, false>, bg::model::polygon<P, true, false> >(); 574 575 // Counter clockwise 576 test_areal<bg::model::ring<P, false>, bg::model::polygon<P, false> >(); 577 578 // Counter clockwise and open 579 test_areal<bg::model::ring<P, false, false>, bg::model::polygon<P, false, false> >(); 580 #endif 581 582 test_one<polygon, box, polygon>("box_ring", example_box, example_ring, 583 1, 1, 15, 6.38875); 584 585 test_one<polygon, box, polygon>("box_poly", example_box, example_polygon, 586 1, 3, 23, 6.30983); 587 588 589 test_one<polygon, box, polygon>("box_poly1", example_box, 590 "POLYGON((3.4 2,4.1 3,5.3 2.6,5.4 1.2,4.9 0.8,2.9 0.7,2 1.3,2.4 1.7,2.8 1.8,3.4 1.2,3.7 1.6,3.4 2))", 591 1, 1, 15, 6.38875); 592 test_one<polygon, box, polygon>("box_poly2", example_box, 593 "POLYGON((2 1.3,2.4 1.7,2.8 1.8,3.4 1.2,3.7 1.6,3.4 2,4.1 2.5,5.3 2.5,5.4 1.2,4.9 0.8,2.9 0.7,2 1.3))", 594 1, 1, 15, 5.93625); 595 596 // 3: see areal 597 598 test_one<polygon, box, polygon>("box_poly4", example_box, 599 "POLYGON((2 1.3,2.4 1.7,2.8 1.8,3.4 1.2,3.7 1.6,3.4 2,4.1 2.5,4.5 2.5,4.5 1.2,4.9 0.8,2.9 0.7,2 1.3))", 600 1, 1, 15, 4.651245); 601 602 test_one<polygon, box, polygon>("box_poly5", example_box, 603 "POLYGON((2 1.3,2.4 1.7,2.8 1.8,3.4 1.2,3.7 1.6,3.4 2,4.1 2.5,4.5 2.5,4.5 2.3,5.0 2.3,5.0 2.1,4.5 2.1,4.5 1.9,4.0 1.9,4.5 1.2,4.9 0.8,2.9 0.7,2 1.3))", 604 1, 1, 21, 4.7191); 605 606 test_one<polygon, box, polygon>("box_poly6", example_box, 607 "POLYGON((2 1.3,2.4 1.7,2.8 1.8,3.4 1.2,3.7 1.6,3.4 2,4.1 2.5,4.5 1.2,2.9 0.7,2 1.3))", 608 1, 1, 15, 4.2174); 609 610 test_one<polygon, box, polygon>("box_poly7", example_box, 611 "POLYGON((2 1.3,2.4 1.7,2.8 1.8,3.4 1.2,3.7 1.6,3.4 2,4.0 3.0,5.0 2.0,2.9 0.7,2 1.3))", 612 1, 1, 17, 4.270554); 613 614 test_one<polygon, box, polygon>("box_poly8", "box(0 0, 3 3)", 615 "POLYGON((2 2, 1 4, 2 4, 3 3, 2 2))", 616 1, 0, 8, 10.25); 617 } 618 619 test_main(int,char * [])620 int test_main(int, char* []) 621 { 622 BoostGeometryWriteTestConfiguration(); 623 test_all<bg::model::d2::point_xy<default_test_type> >(); 624 625 #if ! defined(BOOST_GEOMETRY_TEST_ONLY_ONE_TYPE) 626 627 test_all<bg::model::d2::point_xy<float> >(); 628 test_all<bg::model::d2::point_xy<long double> >(); 629 630 #if defined(HAVE_TTMATH) 631 std::cout << "Testing TTMATH" << std::endl; 632 test_all<bg::model::d2::point_xy<ttmath_big> >(); 633 #endif 634 #endif 635 636 #if defined(BOOST_GEOMETRY_TEST_FAILURES) 637 BoostGeometryWriteExpectedFailures(3, 6); 638 #endif 639 640 return 0; 641 } 642