📄 itksimilarity2dtransformtest.cxx
字号:
std::cout << "Test Clone(): ";
if( !CheckEqual( p2, p4 ) )
{
return EXIT_FAILURE;
}
// Test compose
TransformType::Pointer t4 = TransformType::New();
parameters[0] = 0.6;
parameters[1] = 14.7 / 180.0 * vnl_math::pi;
parameters[2] = 4.0;
parameters[3] = 4.0;
center[0] = 67.1;
center[1] = 67.1;
t4->SetParameters( parameters );
t4->SetCenter( center );
TransformType::Pointer t5;
t1->CloneTo( t5 );
t5->Compose( t4, false );
TransformType::InputPointType p5, p6, p7;
p5 = t1->TransformPoint( p1 );
p6 = t4->TransformPoint( p5 );
p7 = t5->TransformPoint( p1 );
std::cout << "Test Compose(.,false): ";
if( !CheckEqual( p6, p7 ) )
{
return EXIT_FAILURE;
}
t1->CloneTo( t5 );
t5->Compose( t4, true );
p5 = t4->TransformPoint( p1 );
p6 = t1->TransformPoint( p5 );
p7 = t5->TransformPoint( p1 );
std::cout << "Test Compose(.,true): ";
if( !CheckEqual( p6, p7 ) )
{
return EXIT_FAILURE;
}
// Really test the jacobian
std::cout << "Testing Jacobian: ";
TransformType::JacobianType jacobian;
jacobian = t4->GetJacobian( p1 );
TransformType::JacobianType approxJacobian = jacobian;
for( unsigned int k = 0; k < t1->GetNumberOfParameters(); k++ )
{
const double delta = 0.001;
TransformType::ParametersType plusParameters;
TransformType::ParametersType minusParameters;
plusParameters = parameters;
minusParameters = parameters;
plusParameters[k] += delta;
minusParameters[k] -= delta;
TransformType::OutputPointType plusPoint;
TransformType::OutputPointType minusPoint;
t4->SetParameters( plusParameters );
plusPoint = t4->TransformPoint( p1 );
t4->SetParameters( minusParameters );
minusPoint = t4->TransformPoint( p1 );
for( unsigned int j = 0; j < 2; j++ )
{
double approxDerivative = ( plusPoint[j] - minusPoint[j] ) / ( 2.0 * delta );
double computedDerivative = jacobian[j][k];
approxJacobian[j][k] = approxDerivative;
if ( vnl_math_abs( approxDerivative - computedDerivative ) > 1e-4 )
{
std::cerr << "Error computing Jacobian [" << j << "][" << k << "]" << std::endl;
std::cerr << "Result should be: " << approxDerivative << std::endl;
std::cerr << "Reported result is: " << computedDerivative << std::endl;
std::cerr << " [ FAILED ] " << std::endl;
return EXIT_FAILURE;
} // if
} // for j
} // for k
std::cout << " [ PASSED ] " << std::endl;
}
{
// Test instantiation, inverse computation, back transform etc.
typedef SimilarityTransformType TransformType;
TransformType::Pointer t1 = TransformType::New();
// Set parameters
TransformType::ParametersType parameters( t1->GetNumberOfParameters() );
parameters[0] = 2.0;
parameters[1] = -21.0 / 180.0 * vnl_math::pi;
parameters[2] = 12.0;
parameters[3] = -8.9;
parameters[4] = 67.8;
parameters[5] = -0.2;
t1->SetParameters( parameters );
TransformType::InputPointType p1;
p1[0] = 96.8;
p1[1] = -3.2;
TransformType::InputPointType p2;
p2 = t1->TransformPoint( p1 );
// Test inverse
TransformType::Pointer t2;
t1->CloneInverseTo( t2 );
TransformType::InputPointType p3;
p3 = t2->TransformPoint( p2 );
std::cout << "Test CloneInverseTo(): ";
if( !CheckEqual( p1, p3 ) )
{
return EXIT_FAILURE;
}
TransformType::Pointer t2dash = TransformType::New();
t1->GetInverse( t2dash );
TransformType::InputPointType p3dash;
p3dash = t2dash->TransformPoint( p2 );
std::cout << "Test GetInverse(): ";
if( !CheckEqual( p1, p3dash ) )
{
return EXIT_FAILURE;
}
// Test clone
TransformType::Pointer t3;
t1->CloneTo( t3 );
TransformType::InputPointType p4;
p4 = t3->TransformPoint( p1 );
std::cout << "Test Clone(): ";
if( !CheckEqual( p2, p4 ) )
{
return EXIT_FAILURE;
}
// Test compose
TransformType::Pointer t4 = TransformType::New();
parameters[0] = 0.6;
parameters[1] = 14.7 / 180.0 * vnl_math::pi;
parameters[2] = 4.0;
parameters[3] = 4.0;
parameters[4] = 67.1;
parameters[5] = 67.1;
t4->SetParameters( parameters );
TransformType::Pointer t5;
t1->CloneTo( t5 );
t5->Compose( t4, false );
TransformType::InputPointType p5, p6, p7;
p5 = t1->TransformPoint( p1 );
p6 = t4->TransformPoint( p5 );
p7 = t5->TransformPoint( p1 );
std::cout << "Test Compose(.,false): ";
if( !CheckEqual( p6, p7 ) )
{
return EXIT_FAILURE;
}
t1->CloneTo( t5 );
t5->Compose( t4, true );
p5 = t4->TransformPoint( p1 );
p6 = t1->TransformPoint( p5 );
p7 = t5->TransformPoint( p1 );
std::cout << "Test Compose(.,true): ";
if( !CheckEqual( p6, p7 ) )
{
return EXIT_FAILURE;
}
// Really test the jacobian
std::cout << "Testing Jacobian: ";
TransformType::JacobianType jacobian;
jacobian = t4->GetJacobian( p1 );
TransformType::JacobianType approxJacobian = jacobian;
for( unsigned int k = 0; k < t1->GetNumberOfParameters(); k++ )
{
const double delta = 0.001;
TransformType::ParametersType plusParameters;
TransformType::ParametersType minusParameters;
plusParameters = parameters;
minusParameters = parameters;
plusParameters[k] += delta;
minusParameters[k] -= delta;
TransformType::OutputPointType plusPoint;
TransformType::OutputPointType minusPoint;
t4->SetParameters( plusParameters );
plusPoint = t4->TransformPoint( p1 );
t4->SetParameters( minusParameters );
minusPoint = t4->TransformPoint( p1 );
for( unsigned int j = 0; j < 2; j++ )
{
double approxDerivative = ( plusPoint[j] - minusPoint[j] ) / ( 2.0 * delta );
double computedDerivative = jacobian[j][k];
approxJacobian[j][k] = approxDerivative;
if ( vnl_math_abs( approxDerivative - computedDerivative ) > 1e-4 )
{
std::cerr << "Error computing Jacobian [" << j << "][" << k << "]" << std::endl;
std::cerr << "Result should be: " << approxDerivative << std::endl;
std::cerr << "Reported result is: " << computedDerivative << std::endl;
std::cerr << " [ FAILED ] " << std::endl;
return EXIT_FAILURE;
} // if
} // for j
} // for k
std::cout << " [ PASSED ] " << std::endl;
}
{
// Test Set/Get Matrix and Set/Get Offset
typedef itk::Similarity2DTransform<double> TransformType;
TransformType::Pointer t1 = TransformType::New();
TransformType::Pointer t2 = TransformType::New();
TransformType::InputPointType center;
center[0] = 9.0;
center[1] = 10.0;
TransformType::ParametersType parameters( t1->GetNumberOfParameters() );
for( unsigned int j = 0; j < t1->GetNumberOfParameters(); j++ )
{
parameters[j] = static_cast<double>( j ) + 1.0;
}
parameters[1] *= vnl_math::pi / 180.0;
t1->SetCenter( center );
t1->SetParameters( parameters );
t2->SetCenter( center );
t2->SetMatrix( t1->GetMatrix() );
t2->SetOffset( t1->GetOffset() );
// check the transformed points are the same
TransformType::InputPointType ip;
ip[0] = 8.0;
ip[1] = 9.0;
TransformType::OutputPointType op1, op2;
op1 = t1->TransformPoint( ip );
op2 = t2->TransformPoint( ip );
t1->Print(std::cout);
std::cout << "Test Set/GetMatrix() and Set/GetOffset(): ";
if( !CheckEqual( op1, op2 ) )
{
return EXIT_FAILURE;
}
// check that parameters are the same
TransformType::ParametersType pdash = t2->GetParameters();
std::cout << "Test Set/GetMatrix() and Set/GetOffset(): ";
for( unsigned int j = 0; j < t1->GetNumberOfParameters(); j++ )
{
if ( fabs( parameters[j] - pdash[j] ) > epsilon )
{
std::cout << "Expected: " << parameters << std::endl;
std::cout << "Got: " << pdash << std::endl;
std::cout << " [ FAILED ] " << std::endl;
return EXIT_FAILURE;
}
}
std::cout << " [ PASSED ] " << std::endl;
}
return EXIT_SUCCESS;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -