aboutsummaryrefslogtreecommitdiff
path: root/test/unit/test_operation.cpp
diff options
context:
space:
mode:
authorEven Rouault <even.rouault@spatialys.com>2018-12-13 00:55:10 +0100
committerEven Rouault <even.rouault@spatialys.com>2018-12-13 00:55:10 +0100
commitbe7adb85aa92dd601a92313d5b725270596b1a95 (patch)
treee67af5c817e54aebed540876e185a1159a87eb09 /test/unit/test_operation.cpp
parentc566213d28d488df622eeebb52b9aa44fd231189 (diff)
downloadPROJ-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.cpp36
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));
+}