⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 itksimilarity2dtransformtest.cxx

📁 DTMK软件开发包,此为开源软件,是一款很好的医学图像开发资源.
💻 CXX
📖 第 1 页 / 共 2 页
字号:
    
  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 + -