From e873edd34259f770ec7c88092483736e5f5fa672 Mon Sep 17 00:00:00 2001 From: boxanm Date: Fri, 17 Nov 2023 13:24:12 -0500 Subject: [PATCH] Uncomment failing Transformation tests --- utest/ui/Transformations.cpp | 200 +++++++++++++++++------------------ 1 file changed, 99 insertions(+), 101 deletions(-) diff --git a/utest/ui/Transformations.cpp b/utest/ui/Transformations.cpp index d2fb43d4..1dd32d71 100644 --- a/utest/ui/Transformations.cpp +++ b/utest/ui/Transformations.cpp @@ -258,46 +258,45 @@ TEST(Transformation, ComputeRigidTransformDataPoints2D) } } -//// (CRITICAL) ToDo: investigate unit-test failure (ref task NMO-301) -//TEST(Transformation, ComputeRigidTransformDataPoints3D) -//{ -// std::shared_ptr transformator = PM::get().REG(Transformation).create("RigidTransformation"); -// -// // Identity. -// { -// const Eigen::Matrix translation{ 0, 0, 0 }; -// const Eigen::Quaternion rotation{ 1, 0, 0, 0 }; -// const Eigen::Transform transformation = buildUpTransformation3D(translation, rotation); -// // Transform and assert on the result. -// assertOnDataPointsTransformation(data3D, transformation.matrix(), transformator); -// } -// -// // Pure translation. -// { -// const Eigen::Matrix translation{ -1.0001, 5, -12321.234 }; -// const Eigen::Quaternion rotation{ 1, 0, 0, 0 }; -// const Eigen::Transform transformation = buildUpTransformation3D(translation, rotation); -// // Transform and assert on the result. -// assertOnDataPointsTransformation(data3D, transformation.matrix(), transformator); -// } -// // Pure rotation. -// { -// const Eigen::Matrix translation{ 0, 0, 0 }; -// const Eigen::Quaternion rotation{ 1, -5, 23, 0.5 }; -// const Eigen::Transform transformation = buildUpTransformation3D(translation, rotation); -// // Transform and assert on the result. -// assertOnDataPointsTransformation(data3D, transformation.matrix(), transformator); -// } -// // Translation + rotation. -// { -// const NumericType kEpsilonNumericalError = 1e-6; -// const Eigen::Matrix translation{ 1, -3, -4 }; -// const Eigen::Quaternion rotation{ 0, -2.54, 0, 0.5 }; -// const Eigen::Transform transformation = buildUpTransformation3D(translation, rotation); -// // Transform and assert on the result. -// assertOnDataPointsTransformation(data3D, transformation.matrix(), transformator, kEpsilonNumericalError); -// } -//} +TEST(Transformation, ComputeRigidTransformDataPoints3D) +{ + std::shared_ptr transformator = PM::get().REG(Transformation).create("RigidTransformation"); + + // Identity. + { + const Eigen::Matrix translation{ 0, 0, 0 }; + const Eigen::Quaternion rotation{ 1, 0, 0, 0 }; + const Eigen::Transform transformation = buildUpTransformation3D(translation, rotation); + // Transform and assert on the result. + assertOnDataPointsTransformation(data3D, transformation.matrix(), transformator); + } + + // Pure translation. + { + const Eigen::Matrix translation{ -1.0001, 5, -12321.234 }; + const Eigen::Quaternion rotation{ 1, 0, 0, 0 }; + const Eigen::Transform transformation = buildUpTransformation3D(translation, rotation); + // Transform and assert on the result. + assertOnDataPointsTransformation(data3D, transformation.matrix(), transformator); + } + // Pure rotation. + { + const Eigen::Matrix translation{ 0, 0, 0 }; + const Eigen::Quaternion rotation{ 1, -5, 23, 0.5 }; + const Eigen::Transform transformation = buildUpTransformation3D(translation, rotation); + // Transform and assert on the result. + assertOnDataPointsTransformation(data3D, transformation.matrix(), transformator); + } + // Translation + rotation. + { + const NumericType kEpsilonNumericalError = 1e-6; + const Eigen::Matrix translation{ 1, -3, -4 }; + const Eigen::Quaternion rotation{ 0, -2.54, 0, 0.5 }; + const Eigen::Transform transformation = buildUpTransformation3D(translation, rotation); + // Transform and assert on the result. + assertOnDataPointsTransformation(data3D, transformation.matrix(), transformator, kEpsilonNumericalError); + } +} TEST(Transformation, ComputeSimilarityTransformDataPoints2D) { @@ -359,64 +358,63 @@ TEST(Transformation, ComputeSimilarityTransformDataPoints2D) } } -//// (CRITICAL) ToDo: investigate unit-test failure (ref task NMO-301) -//TEST(Transformation, ComputeSimilarityTransformDataPoints3D) -//{ -// std::shared_ptr transformator = PM::get().REG(Transformation).create("SimilarityTransformation"); -// -// // Identity. -// { -// const Eigen::Matrix translation{ 0, 0, 0 }; -// const Eigen::Quaternion rotation{ 1, 0, 0, 0 }; -// const NumericType scale{ 1.0 }; -// const Eigen::Transform transformation = buildUpTransformation3D(translation, rotation, scale); -// // Transform and assert on the result. -// assertOnDataPointsTransformation(data3D, transformation.matrix(), transformator); -// } -// // Pure Upscaling. -// { -// const Eigen::Matrix translation{ 0, 0, 0 }; -// const Eigen::Quaternion rotation{ 1, 0, 0, 0 }; -// const NumericType scale{ 5.0 }; -// const Eigen::Transform transformation = buildUpTransformation3D(translation, rotation, scale); -// // Transform and assert on the result. -// assertOnDataPointsTransformation(data3D, transformation.matrix(), transformator); -// } -// // Pure Downscaling. -// { -// const Eigen::Matrix translation{ 0, 0, 0 }; -// const Eigen::Quaternion rotation{ 1, 0, 0, 0 }; -// const NumericType scale{ 0.1 }; -// const Eigen::Transform transformation = buildUpTransformation3D(translation, rotation, scale); -// // Transform and assert on the result. -// assertOnDataPointsTransformation(data3D, transformation.matrix(), transformator); -// } -// // Pure translation + Downscaling. -// { -// const Eigen::Matrix translation{ -1.0001, 5, -12321.234 }; -// const Eigen::Quaternion rotation{ 1, 0, 0, 0 }; -// const NumericType scale{ 0.5 }; -// const Eigen::Transform transformation = buildUpTransformation3D(translation, rotation, scale); -// // Transform and assert on the result. -// assertOnDataPointsTransformation(data3D, transformation.matrix(), transformator); -// } -// // Pure rotation + Upscaling. -// { -// const Eigen::Matrix translation{ 0, 0, 0 }; -// const Eigen::Quaternion rotation{ 1, -5, 23, 0.5 }; -// const NumericType scale{ 1.9 }; -// const Eigen::Transform transformation = buildUpTransformation3D(translation, rotation, scale); -// // Transform and assert on the result. -// assertOnDataPointsTransformation(data3D, transformation.matrix(), transformator); -// } -// // Translation + rotation + Upscaling. -// { -// const NumericType kEpsilonNumericalError = 1e-6; -// const Eigen::Matrix translation{ 1, -3, -4 }; -// const Eigen::Quaternion rotation{ 0, -2.54, 0, 0.5 }; -// const NumericType scale{ 1.9 }; -// const Eigen::Transform transformation = buildUpTransformation3D(translation, rotation, scale); -// // Transform and assert on the result. -// assertOnDataPointsTransformation(data3D, transformation.matrix(), transformator, kEpsilonNumericalError); -// } -//} +TEST(Transformation, ComputeSimilarityTransformDataPoints3D) +{ + std::shared_ptr transformator = PM::get().REG(Transformation).create("SimilarityTransformation"); + + // Identity. + { + const Eigen::Matrix translation{ 0, 0, 0 }; + const Eigen::Quaternion rotation{ 1, 0, 0, 0 }; + const NumericType scale{ 1.0 }; + const Eigen::Transform transformation = buildUpTransformation3D(translation, rotation, scale); + // Transform and assert on the result. + assertOnDataPointsTransformation(data3D, transformation.matrix(), transformator); + } + // Pure Upscaling. + { + const Eigen::Matrix translation{ 0, 0, 0 }; + const Eigen::Quaternion rotation{ 1, 0, 0, 0 }; + const NumericType scale{ 5.0 }; + const Eigen::Transform transformation = buildUpTransformation3D(translation, rotation, scale); + // Transform and assert on the result. + assertOnDataPointsTransformation(data3D, transformation.matrix(), transformator); + } + // Pure Downscaling. + { + const Eigen::Matrix translation{ 0, 0, 0 }; + const Eigen::Quaternion rotation{ 1, 0, 0, 0 }; + const NumericType scale{ 0.1 }; + const Eigen::Transform transformation = buildUpTransformation3D(translation, rotation, scale); + // Transform and assert on the result. + assertOnDataPointsTransformation(data3D, transformation.matrix(), transformator); + } + // Pure translation + Downscaling. + { + const Eigen::Matrix translation{ -1.0001, 5, -12321.234 }; + const Eigen::Quaternion rotation{ 1, 0, 0, 0 }; + const NumericType scale{ 0.5 }; + const Eigen::Transform transformation = buildUpTransformation3D(translation, rotation, scale); + // Transform and assert on the result. + assertOnDataPointsTransformation(data3D, transformation.matrix(), transformator); + } + // Pure rotation + Upscaling. + { + const Eigen::Matrix translation{ 0, 0, 0 }; + const Eigen::Quaternion rotation{ 1, -5, 23, 0.5 }; + const NumericType scale{ 1.9 }; + const Eigen::Transform transformation = buildUpTransformation3D(translation, rotation, scale); + // Transform and assert on the result. + assertOnDataPointsTransformation(data3D, transformation.matrix(), transformator); + } + // Translation + rotation + Upscaling. + { + const NumericType kEpsilonNumericalError = 1e-6; + const Eigen::Matrix translation{ 1, -3, -4 }; + const Eigen::Quaternion rotation{ 0, -2.54, 0, 0.5 }; + const NumericType scale{ 1.9 }; + const Eigen::Transform transformation = buildUpTransformation3D(translation, rotation, scale); + // Transform and assert on the result. + assertOnDataPointsTransformation(data3D, transformation.matrix(), transformator, kEpsilonNumericalError); + } +}