diff options
| author | Even Rouault <even.rouault@spatialys.com> | 2018-12-13 00:55:10 +0100 |
|---|---|---|
| committer | Even Rouault <even.rouault@spatialys.com> | 2018-12-13 00:55:10 +0100 |
| commit | be7adb85aa92dd601a92313d5b725270596b1a95 (patch) | |
| tree | e67af5c817e54aebed540876e185a1159a87eb09 /test/unit/test_operation.cpp | |
| parent | c566213d28d488df622eeebb52b9aa44fd231189 (diff) | |
| download | PROJ-be7adb85aa92dd601a92313d5b725270596b1a95.tar.gz PROJ-be7adb85aa92dd601a92313d5b725270596b1a95.zip | |
improve isEquivalentTo() when comparing Helmert transformations
Diffstat (limited to 'test/unit/test_operation.cpp')
| -rw-r--r-- | test/unit/test_operation.cpp | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/test/unit/test_operation.cpp b/test/unit/test_operation.cpp index 3d1cfc42..b5bd188c 100644 --- a/test/unit/test_operation.cpp +++ b/test/unit/test_operation.cpp @@ -6654,3 +6654,39 @@ TEST(operation, lcc2sp_to_lcc1sp_invalid_eccentricity) { EPSG_CODE_METHOD_LAMBERT_CONIC_CONFORMAL_1SP); EXPECT_FALSE(targetConv != nullptr); } + +// --------------------------------------------------------------------------- + +TEST(operation, three_param_equivalent_to_seven_param) { + + auto three_param = Transformation::createGeocentricTranslations( + PropertyMap(), GeographicCRS::EPSG_4269, GeographicCRS::EPSG_4326, 1.0, + 2.0, 3.0, {}); + + auto seven_param_pv = Transformation::createPositionVector( + PropertyMap(), GeographicCRS::EPSG_4269, GeographicCRS::EPSG_4326, 1.0, + 2.0, 3.0, 0.0, 0.0, 0.0, 0.0, {}); + + auto seven_param_cf = Transformation::createCoordinateFrameRotation( + PropertyMap(), GeographicCRS::EPSG_4269, GeographicCRS::EPSG_4326, 1.0, + 2.0, 3.0, 0.0, 0.0, 0.0, 0.0, {}); + + auto seven_param_non_eq = Transformation::createPositionVector( + PropertyMap(), GeographicCRS::EPSG_4269, GeographicCRS::EPSG_4326, 1.0, + 2.0, 3.0, 1.0, 0.0, 0.0, 0.0, {}); + + EXPECT_TRUE(three_param->isEquivalentTo( + seven_param_pv.get(), IComparable::Criterion::EQUIVALENT)); + + EXPECT_TRUE(three_param->isEquivalentTo( + seven_param_cf.get(), IComparable::Criterion::EQUIVALENT)); + + EXPECT_TRUE(seven_param_cf->isEquivalentTo( + three_param.get(), IComparable::Criterion::EQUIVALENT)); + + EXPECT_TRUE(seven_param_pv->isEquivalentTo( + three_param.get(), IComparable::Criterion::EQUIVALENT)); + + EXPECT_FALSE(three_param->isEquivalentTo( + seven_param_non_eq.get(), IComparable::Criterion::EQUIVALENT)); +} |
