// Boost.Geometry (aka GGL, Generic Geometry Library) // Unit Test // Copyright (c) 2016-2018, Oracle and/or its affiliates. // Contributed and/or modified by Vissarion Fysikopoulos, on behalf of Oracle // Licensed under the Boost Software License version 1.0. // http://www.boost.org/users/license.html #ifndef BOOST_TEST_MODULE #define BOOST_TEST_MODULE test_distance_geographic_pointlike_linear #endif #include #include #include #include "test_distance_geo_common.hpp" #include "test_empty_geometry.hpp" typedef bg::cs::geographic cs_type; typedef bg::model::point point_type; typedef bg::model::segment segment_type; typedef bg::model::multi_point multi_point_type; typedef bg::model::segment segment_type; typedef bg::model::linestring linestring_type; typedef bg::model::multi_linestring multi_linestring_type; typedef bg::cs::geographic cs_type_rad; typedef bg::model::point point_type_rad; typedef bg::model::segment segment_type_rad; //=========================================================================== template inline bg::default_distance_result::type pp_distance(std::string const& wkt1, std::string const& wkt2, Strategy const& strategy) { point_type p1, p2; bg::read_wkt(wkt1, p1); bg::read_wkt(wkt2, p2); return bg::distance(p1, p2, strategy); } template inline bg::default_distance_result::type ps_distance(std::string const& wkt1, std::string const& wkt2, Strategy const& strategy) { point_type p; segment_type s; bg::read_wkt(wkt1, p); bg::read_wkt(wkt2, s); return bg::distance(p, s, strategy); } //=========================================================================== template void test_distance_point_segment(Strategy_pp const& strategy_pp, Strategy_ps const& strategy_ps, bool WGS84) { #ifdef BOOST_GEOMETRY_TEST_DEBUG std::cout << std::endl; std::cout << "point/segment distance tests" << std::endl; #endif typedef test_distance_of_geometries tester; tester::apply("p-s-01", "POINT(0 0)", "SEGMENT(2 0,3 0)", pp_distance("POINT(0 0)", "POINT(2 0)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-02", "POINT(2.5 3)", "SEGMENT(2 0,3 0)", pp_distance("POINT(2.5 3)", "POINT(2.5 0)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-03", "POINT(2 0)", "SEGMENT(2 0,3 0)", 0, strategy_ps, true, true); tester::apply("p-s-04", "POINT(3 0)", "SEGMENT(2 0,3 0)", 0, strategy_ps, true, true); tester::apply("p-s-05", "POINT(2.5 0)", "SEGMENT(2 0,3 0)", 0, strategy_ps, true, true); tester::apply("p-s-06", "POINT(3.5 3)", "SEGMENT(2 0,3 0)", pp_distance("POINT(3 0)", "POINT(3.5 3)", strategy_pp), strategy_ps, true, true); if(WGS84) { tester::apply("p-s-07", "POINT(15 80)", "SEGMENT(10 15,30 15)", 7204174.8264546748, strategy_ps, true, true); tester::apply("p-s-08", "POINT(15 10)", "SEGMENT(10 15,30 15)", 571412.71247283253, strategy_ps, true, true); } tester::apply("p-s-09", "POINT(5 10)", "SEGMENT(10 15,30 15)", pp_distance("POINT(5 10)", "POINT(10 15)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-10", "POINT(35 10)", "SEGMENT(10 15,30 15)", pp_distance("POINT(35 10)", "POINT(30 15)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-11", "POINT(5 10)", "SEGMENT(30 15,10 15)", pp_distance("POINT(5 10)", "POINT(10 15)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-12", "POINT(35 10)", "SEGMENT(30 15,10 15)", pp_distance("POINT(35 10)", "POINT(30 15)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-right-up", "POINT(3.5 3)", "SEGMENT(2 2,3 2)", pp_distance("POINT(3 2)", "POINT(3.5 3)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-left-up", "POINT(1.5 3)", "SEGMENT(2 2,3 2)", pp_distance("POINT(2 2)", "POINT(1.5 3)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-up-1", "POINT(2 3)", "SEGMENT(2 2,3 2)", pp_distance("POINT(2.0003 2)", "POINT(2 3)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-up-2", "POINT(3 3)", "SEGMENT(2 2,3 2)", pp_distance("POINT(2.9997 2)", "POINT(3 3)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-right-down", "POINT(3.5 1)", "SEGMENT(2 2,3 2)", pp_distance("POINT(3 2)", "POINT(3.5 1)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-left-down", "POINT(1.5 1)", "SEGMENT(2 2,3 2)", pp_distance("POINT(2 2)", "POINT(1.5 1)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-down-1", "POINT(2 1)", "SEGMENT(2 2,3 2)", pp_distance("POINT(2 2)", "POINT(2 1)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-down-2", "POINT(3 1)", "SEGMENT(2 2,3 2)", pp_distance("POINT(3 2)", "POINT(3 1)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-south", "POINT(3 -1)", "SEGMENT(2 -2,3 -2)", pp_distance("POINT(3 -2)", "POINT(3 -1)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-antimeridian-1", "POINT(3 1)", "SEGMENT(220 2,3 2)", pp_distance("POINT(3 2)", "POINT(3 1)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-antimeridian-2", "POINT(220 1)", "SEGMENT(220 2,3 2)", pp_distance("POINT(220 2)", "POINT(220 1)", strategy_pp), strategy_ps, true, true); // equator special case tester::apply("p-s-eq1", "POINT(2.5 0)", "SEGMENT(2 0,3 0)", 0, strategy_ps, true, true); tester::apply("p-s-eq2", "POINT(2.5 2)", "SEGMENT(2 0,3 0)", pp_distance("POINT(2.5 0)", "POINT(2.5 2)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-eq3", "POINT(2 2)", "SEGMENT(2 0,3 0)", pp_distance("POINT(2 0)", "POINT(2 2)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-eq4", "POINT(3 2)", "SEGMENT(2 0,3 0)", pp_distance("POINT(3 0)", "POINT(3 2)", strategy_pp), strategy_ps, true, true); // meridian special case tester::apply("p-s-mer1", "POINT(2.5 2)", "SEGMENT(2 2,2 4)", pp_distance("POINT(2.5 2)", "POINT(2 2.000076608014728)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-mer3", "POINT(2.5 5)", "SEGMENT(2 2,2 4)", pp_distance("POINT(2.5 5)", "POINT(2 4)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-mer4", "POINT(0 20)", "SEGMENT(0 40,180 80)", pp_distance("POINT(0 20)", "POINT(0 40)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-mer5", "POINT(0 20)", "SEGMENT(0 40,0 80)", pp_distance("POINT(0 20)", "POINT(0 40)", strategy_pp), strategy_ps, true, true); //degenerate segment tester::apply("p-s-deg", "POINT(1 80)", "SEGMENT(0 0,0 0)", pp_distance("POINT(0 0)", "POINT(1 80)", strategy_pp), strategy_ps, true, true); //point on segment tester::apply("p-s-deg", "POINT(0 80)", "SEGMENT(0 0,0 90)", 0, strategy_ps, true, true); // very small distances to segment tester::apply("p-s-07", "POINT(90 1e-3)", "SEGMENT(0.5 0,175.5 0)", pp_distance("POINT(90 0)", "POINT(90 1e-3)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-08", "POINT(90 1e-4)", "SEGMENT(0.5 0,175.5 0)", pp_distance("POINT(90 0)", "POINT(90 1e-4)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-09", "POINT(90 1e-5)", "SEGMENT(0.5 0,175.5 0)", pp_distance("POINT(90 0)", "POINT(90 1e-5)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-10", "POINT(90 1e-6)", "SEGMENT(0.5 0,175.5 0)", pp_distance("POINT(90 0)", "POINT(90 1e-6)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-11", "POINT(90 1e-7)", "SEGMENT(0.5 0,175.5 0)", pp_distance("POINT(90 0)", "POINT(90 1e-7)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-12", "POINT(90 1e-8)", "SEGMENT(0.5 0,175.5 0)", pp_distance("POINT(90 0)", "POINT(90 1e-8)", strategy_pp), strategy_ps, true, true); // very large distance to segment tester::apply("p-s-13", "POINT(90 90)", "SEGMENT(0.5 0,175.5 0)", pp_distance("POINT(90 0)", "POINT(90 90)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-14", "POINT(90 90)", "SEGMENT(0.5 -89,175.5 -89)", pp_distance("POINT(90 -89)", "POINT(90 90)", strategy_pp), strategy_ps, true, true); // degenerate segment tester::apply("p-s-15", "POINT(90 90)", "SEGMENT(0.5 -90,175.5 -90)", pp_distance("POINT(0.5 -90)", "POINT(90 90)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-16", "POINT(90 90)", "SEGMENT(0.5 -90,175.5 -90)", pp_distance("POINT(90 -90)", "POINT(90 90)", strategy_pp), strategy_ps, true, true); // equatorial segment tester::apply("p-s-17", "POINT(90 90)", "SEGMENT(0 0,175.5 0)", pp_distance("POINT(90 90)", "POINT(0 0)", strategy_pp), strategy_ps, true, true); // segment pass by pole tester::apply("p-s-18", "POINT(90 90)", "SEGMENT(0 0,180 0)", 0, strategy_ps, true, true); tester::apply("p-s-20", "POINT(80 89)", "SEGMENT(0 0,180 0)", pp_distance("POINT(80 89)", "POINT(0 89.82633489283377)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-21", "POINT(80 89)", "SEGMENT(0 -1,180 1)", pp_distance("POINT(80 89)", "POINT(0 89.82633489283377)", strategy_pp), strategy_ps, true, true); // meridian special case tester::apply("p-s-mer1", "POINT(2.5 3)", "SEGMENT(2 2,2 4)", pp_distance("POINT(2.5 3)", "POINT(2 3.000114792872075)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-mer2", "POINT(1 80)", "SEGMENT(0 0,0 90)", pp_distance("POINT(1 80)", "POINT(0 80.00149225834545)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-mer3", "POINT(2 0)", "SEGMENT(1 -1,1 0)", pp_distance("POINT(2 0)", "POINT(1 0)", strategy_pp), strategy_ps, true, true); tester::apply("p-s-acos", "POINT(0 90)", "SEGMENT(90 0,0 1.000005)", pp_distance("POINT(0 90)", "POINT(0.3017072304435489 1.000018955050697)", strategy_pp), strategy_ps, true, true); } template void test_distance_point_segment_no_thomas(Strategy_pp const& strategy_pp, Strategy_ps const& strategy_ps) { #ifdef BOOST_GEOMETRY_TEST_DEBUG std::cout << std::endl; std::cout << "point/segment distance tests" << std::endl; #endif typedef test_distance_of_geometries tester; // thomas strategy is failing for those test cases // this is because of inaccurate results for points close to poles tester::apply("p-s-19", "POINT(90 89)", "SEGMENT(0 0,180 0)", pp_distance("POINT(90 89)", "POINT(90 90)", strategy_pp), strategy_ps, true, true); } template void test_distance_point_segment_rad_mix(Strategy_pp const& strategy_pp, Strategy_ps const& strategy_ps) { #ifdef BOOST_GEOMETRY_TEST_DEBUG std::cout << std::endl; std::cout << "point/segment distance tests" << std::endl; #endif typedef test_distance_of_geometries tester1; typedef test_distance_of_geometries tester2; typedef test_distance_of_geometries tester3; typedef test_distance_of_geometries tester4; const double d2r = bg::math::d2r(); std::ostringstream s1; s1 << 1*d2r; std::ostringstream s2; s2 << 2*d2r; std::ostringstream s3; s3 << 3*d2r; tester1::apply("p-s-mix1", "POINT(3 1)", "SEGMENT(2 2,3 2)", pp_distance("POINT(3 2)", "POINT(3 1)", strategy_pp), strategy_ps, true, true); tester2::apply("p-s-mix2", "POINT(" + s3.str() + " " + s1.str() + ")", "SEGMENT(2 2,3 2)", pp_distance("POINT(3 2)", "POINT(3 1)", strategy_pp), strategy_ps, true, true); tester3::apply("p-s-mix3", "POINT(3 1)", "SEGMENT(" + s2.str() + " " + s2.str() + "," + s3.str() + " " + s2.str() + ")", pp_distance("POINT(3 2)", "POINT(3 1)", strategy_pp), strategy_ps, true, true); tester4::apply("p-s-mix4", "POINT(" + s3.str() + " " + s1.str() + ")", "SEGMENT(" + s2.str() + " " + s2.str() + "," + s3.str() + " " + s2.str() + ")", pp_distance("POINT(3 2)", "POINT(3 1)", strategy_pp), strategy_ps, true, true); } //=========================================================================== template void test_distance_point_linestring(Strategy_pp const& strategy_pp, Strategy_ps const& strategy_ps) { #ifdef BOOST_GEOMETRY_TEST_DEBUG std::cout << std::endl; std::cout << "point/linestring distance tests" << std::endl; #endif typedef test_distance_of_geometries tester; tester::apply("p-l-01", "POINT(0 0)", "LINESTRING(2 0,2 0)", pp_distance("POINT(0 0)", "POINT(2 0)", strategy_pp), strategy_ps, true, false, false); tester::apply("p-l-02", "POINT(0 0)", "LINESTRING(2 0,3 0)", pp_distance("POINT(0 0)", "POINT(2 0)", strategy_pp), strategy_ps, true, false, false); tester::apply("p-l-03", "POINT(2.5 3)", "LINESTRING(2 0,3 0)", pp_distance("POINT(2.5 3)", "POINT(2.5 0)", strategy_pp), strategy_ps, true, false, false); tester::apply("p-l-04", "POINT(2 0)", "LINESTRING(2 0,3 0)", 0, strategy_ps, true, false, false); tester::apply("p-l-05", "POINT(3 0)", "LINESTRING(2 0,3 0)", 0, strategy_ps, true, false, false); tester::apply("p-l-06", "POINT(2.5 0)", "LINESTRING(2 0,3 0)", 0, strategy_ps, true, false, false); tester::apply("p-l-07", "POINT(7.5 10)", "LINESTRING(1 0,2 0,3 0,4 0,5 0,6 0,7 0,8 0,9 0)", ps_distance("POINT(7.5 10)", "SEGMENT(7 0,8 0)", strategy_ps), strategy_ps, true, false, false); tester::apply("p-l-08", "POINT(7.5 10)", "LINESTRING(1 1,2 1,3 1,4 1,5 1,6 1,7 1,20 2,21 2)", ps_distance("POINT(7.5 10)", "SEGMENT(7 1,20 2)", strategy_ps), strategy_ps, true, false, false); } void test_distance_point_linestring_strategies() { typedef test_distance_of_geometries tester; tester::apply("p-l-s-01", "POINT(2.5 3)", "LINESTRING(2 1,3 1)", 221147.24332788656, vincenty_ps(), true, false, false); tester::apply("p-l-s-02", "POINT(2.5 3)", "LINESTRING(2 1,3 1)", 221147.36682199029, thomas_ps(), true, false, false); tester::apply("p-l-s-03", "POINT(2.5 3)", "LINESTRING(2 1,3 1)", 221144.76527049288, andoyer_ps(), true, false, false); } //=========================================================================== template void test_distance_point_multilinestring(Strategy_pp const& strategy_pp, Strategy_ps const& strategy_ps) { #ifdef BOOST_GEOMETRY_TEST_DEBUG std::cout << std::endl; std::cout << "point/multilinestring distance tests" << std::endl; #endif typedef test_distance_of_geometries < point_type, multi_linestring_type > tester; tester::apply("p-ml-01", "POINT(0 0)", "MULTILINESTRING((-5 0,-3 0),(2 0,3 0))", pp_distance("POINT(0 0)", "POINT(2 0)", strategy_pp), strategy_ps, true, false, false); tester::apply("p-ml-02", "POINT(2.5 3)", "MULTILINESTRING((-5 0,-3 0),(2 0,3 0))", pp_distance("POINT(2.5 3)", "POINT(2.5 0)", strategy_pp), strategy_ps, true, false, false); tester::apply("p-ml-03", "POINT(2 0)", "MULTILINESTRING((-5 0,-3 0),(2 0,3 0))", 0, strategy_ps, true, false, false); tester::apply("p-ml-04", "POINT(3 0)", "MULTILINESTRING((-5 0,-3 0),(2 0,3 0))", 0, strategy_ps, true, false, false); tester::apply("p-ml-05", "POINT(2.5 0)", "MULTILINESTRING((-5 0,-3 0),(2 0,3 0))", 0, strategy_ps, true, false, false); tester::apply("p-ml-06", "POINT(7.5 10)", "MULTILINESTRING((-5 0,-3 0),(2 0,3 0,4 0,5 0,6 0,20 1,21 1))", ps_distance("POINT(7.5 10)", "SEGMENT(6 0,20 1)", strategy_ps), strategy_ps, true, false, false); tester::apply("p-ml-07", "POINT(-8 10)", "MULTILINESTRING((-20 10,-19 11,-18 10,-6 0,-5 0,-3 0),(2 0,6 0,20 1,21 1))", ps_distance("POINT(-8 10)", "SEGMENT(-6 0,-18 10)", strategy_ps), strategy_ps, true, false, false); } //=========================================================================== template void test_distance_linestring_multipoint(Strategy_pp const& strategy_pp, Strategy_ps const& strategy_ps) { #ifdef BOOST_GEOMETRY_TEST_DEBUG std::cout << std::endl; std::cout << "linestring/multipoint distance tests" << std::endl; #endif typedef test_distance_of_geometries < linestring_type, multi_point_type > tester; tester::apply("l-mp-01", "LINESTRING(2 0,0 2,100 80)", "MULTIPOINT(0 0,1 0,0 1,1 1)", ps_distance("POINT(1 1)", "SEGMENT(2 0,0 2)", strategy_ps), strategy_ps, true, false, false); tester::apply("l-mp-02", "LINESTRING(4 0,0 4,100 80)", "MULTIPOINT(0 0,1 0,0 1,1 1)", ps_distance("POINT(1 1)", "SEGMENT(0 4,4 0)", strategy_ps), strategy_ps, true, false, false); tester::apply("l-mp-03", "LINESTRING(1 1,2 2,100 80)", "MULTIPOINT(0 0,1 0,0 1,1 1)", 0, strategy_ps, true, false, false); tester::apply("l-mp-04", "LINESTRING(3 3,4 4,100 80)", "MULTIPOINT(0 0,1 0,0 1,1 1)", pp_distance("POINT(1 1)", "POINT(3 3)", strategy_pp), strategy_ps, true, false, false); tester::apply("l-mp-05", "LINESTRING(0 0,10 0,10 10,0 10,0 0)", "MULTIPOINT(1 -1,80 80,5 0,150 90)", 0, strategy_ps, true, false, false); tester::apply("l-mp-06", "LINESTRING(90 0,0 1.00005)", "MULTIPOINT((0 0),(0 0),(0 0),(0 0),(0 0),(0 0),(0 0 ),(0 0),\ (0 0),(0 0 ),(0 0),(0 0),(69.35235 155.0205),\ (75.72081 37.97683),(0 0),(0 0),(0 0))", pp_distance("POINT(0 0)", "POINT(0 1.00005)", strategy_pp), strategy_ps, true, false, false); } //=========================================================================== template void test_distance_multipoint_multilinestring(Strategy_pp const& strategy_pp, Strategy_ps const& strategy_ps) { #ifdef BOOST_GEOMETRY_TEST_DEBUG std::cout << std::endl; std::cout << "multipoint/multilinestring distance tests" << std::endl; #endif typedef test_distance_of_geometries < multi_point_type, multi_linestring_type > tester; tester::apply("mp-ml-01", "MULTIPOINT(0 0,1 0,0 1,1 1)", "MULTILINESTRING((2 0,0 2),(2 2,3 3))", ps_distance("POINT(1 1)", "SEGMENT(2 0,0 2)", strategy_ps), strategy_ps, true, false, false); tester::apply("mp-ml-02", "MULTIPOINT(0 0,1 0,0 1,1 1)", "MULTILINESTRING((3 0,0 3),(4 4,5 5))", ps_distance("POINT(1 1)", "SEGMENT(3 0,0 3)", strategy_ps), strategy_ps, true, false, false); tester::apply("mp-ml-03", "MULTIPOINT(0 0,1 0,0 1,1 1)", "MULTILINESTRING((4 4,5 5),(1 1,2 2))", 0, strategy_ps, true, false, false); tester::apply("mp-ml-04", "MULTIPOINT(0 0,1 0,0 1,1 1)", "MULTILINESTRING((4 4,3 3),(4 4,5 5))", pp_distance("POINT(1 1)", "POINT(3 3)", strategy_pp), strategy_ps, true, false, false); } //=========================================================================== template void test_distance_multipoint_segment(Strategy_pp const& strategy_pp, Strategy_ps const& strategy_ps) { #ifdef BOOST_GEOMETRY_TEST_DEBUG std::cout << std::endl; std::cout << "multipoint/segment distance tests" << std::endl; #endif typedef test_distance_of_geometries tester; tester::apply("mp-s-01", "MULTIPOINT(0 0,1 0,0 1,1 1)", "SEGMENT(2 0,0 2)", ps_distance("POINT(1 1)", "SEGMENT(2 0,0 2)", strategy_ps), strategy_ps, true, false, false); tester::apply("mp-s-02", "MULTIPOINT(0 0,1 0,0 1,1 1)", "SEGMENT(0 -3,1 -10)", pp_distance("POINT(0 0)", "POINT(0 -3)", strategy_pp), strategy_ps, true, false, false); tester::apply("mp-s-03", "MULTIPOINT(0 0,1 0,0 1,1 1)", "SEGMENT(1 1,2 2)", 0, strategy_ps, true, false, false); tester::apply("mp-s-04", "MULTIPOINT(0 0,1 0,0 1,1 1)", "SEGMENT(3 3,4 4)", pp_distance("POINT(1 1)", "POINT(3 3)", strategy_pp), strategy_ps, true, false, false); tester::apply("mp-s-05", "MULTIPOINT(0 0,1 0,0 1,1 1)", "SEGMENT(0.5 -3,1 -10)", pp_distance("POINT(1 0)", "POINT(0.5 -3)", strategy_pp), strategy_ps, true, false, false); } //=========================================================================== //=========================================================================== //=========================================================================== template void test_all_pl_l(Strategy_pp pp_strategy, Strategy_ps ps_strategy, bool WGS84 = true) { test_distance_point_segment(pp_strategy, ps_strategy, WGS84); test_distance_point_linestring(pp_strategy, ps_strategy); test_distance_point_multilinestring(pp_strategy, ps_strategy); test_distance_linestring_multipoint(pp_strategy, ps_strategy); test_distance_multipoint_multilinestring(pp_strategy, ps_strategy); test_distance_multipoint_segment(pp_strategy, ps_strategy); test_more_empty_input_pointlike_linear(ps_strategy); } BOOST_AUTO_TEST_CASE( test_all_pointlike_linear ) { test_all_pl_l(vincenty_pp(), vincenty_ps_bisection()); test_all_pl_l(vincenty_pp(), vincenty_ps()); test_all_pl_l(thomas_pp(), thomas_ps()); test_all_pl_l(andoyer_pp(), andoyer_ps()); // test with different spheroid stype spheroid(6372000, 6370000); test_all_pl_l(andoyer_pp(spheroid), andoyer_ps(spheroid), false); test_distance_point_segment_no_thomas(vincenty_pp(), vincenty_ps()); //test_distance_point_segment_no_thomas(thomas_pp(), thomas_ps()); test_distance_point_segment_no_thomas(andoyer_pp(), andoyer_ps()); test_distance_point_segment_rad_mix(vincenty_pp(), vincenty_ps()); test_distance_point_segment_rad_mix(thomas_pp(), thomas_ps()); test_distance_point_segment_rad_mix(andoyer_pp(), andoyer_ps()); }