1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
|
/************************************************************************
*
* Copyright (C) 2017-2025 IRCAD France
* Copyright (C) 2017-2018 IHU Strasbourg
*
* This file is part of Sight.
*
* Sight is free software: you can redistribute it and/or modify it under
* the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Sight is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with Sight. If not, see <https://www.gnu.org/licenses/>.
*
***********************************************************************/
#include <data/matrix4.hpp>
#include <io/itk/helper/transform.hpp>
#include <doctest/doctest.h>
#include <itkMatrix.h>
TEST_SUITE("sight::io::itk::transform")
{
TEST_CASE("conversion")
{
::itk::Matrix<double, 4, 4> mat;
auto sight_mat = std::make_shared<sight::data::matrix4>();
for(std::uint8_t i = 0 ; i < 4 ; ++i)
{
for(std::uint8_t j = 0 ; j < 4 ; j++)
{
mat(i, j) = i + j * 4.0;
}
}
sight::io::itk::helper::transform::convert_from_itk(mat, sight_mat);
for(std::uint8_t i = 0 ; i < 4 ; ++i)
{
for(std::uint8_t j = 0 ; j < 4 ; j++)
{
CHECK_EQ(mat(i, j), (*sight_mat)(i, j));
}
}
sight::data::matrix4::csptr sight_mat2 = sight_mat;
::itk::Matrix<double, 4, 4> mat2 = sight::io::itk::helper::transform::convert_to_itk(sight_mat2);
for(std::uint8_t i = 0 ; i < 4 ; ++i)
{
for(std::uint8_t j = 0 ; j < 4 ; j++)
{
CHECK_EQ(mat(i, j), mat2(i, j));
}
}
}
} // TEST_SUITE
|