/*========================================================================= Program: vv http://www.creatis.insa-lyon.fr/rio/vv Authors belong to: - University of LYON http://www.universite-lyon.fr/ - Léon Bérard cancer center http://www.centreleonberard.fr - CREATIS CNRS laboratory http://www.creatis.insa-lyon.fr This software is distributed WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the copyright notices for more information. It is distributed under dual licence - BSD See included LICENSE.txt file - CeCILL-B http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html ===========================================================================**/ #ifndef __clitkDeformationFieldTransform_h #define __clitkDeformationFieldTransform_h #include "clitkList.h" #include "clitkLists.h" // itk #include "itkTransform.h" #include "itkVectorInterpolateImageFunction.h" #include "itkVectorLinearInterpolateImageFunction.h" namespace clitk { template < class TScalarType=double, unsigned int InputDimension=4,unsigned int OutputDimension=4, unsigned int SpaceDimension=3 > class ITK_EXPORT DeformationFieldTransform : public itk::Transform< TScalarType, InputDimension, OutputDimension > { public: /** Standard class typedefs. */ typedef DeformationFieldTransform Self; typedef itk::Transform< TScalarType, InputDimension, OutputDimension > Superclass; typedef itk::SmartPointer Pointer; typedef itk::SmartPointer ConstPointer; /** New macro for creation of through the object factory. */ itkNewMacro( Self ); /** Run-time type information (and related methods). */ itkTypeMacro( DeformationFieldTransform, Transform ); /** Standard coordinate point type for this class. */ typedef itk::Point InputPointType; typedef itk::Point OutputPointType; // typedef typedef itk::Point SpacePointType; typedef itk::Vector DisplacementType; typedef itk::Image DeformationFieldType; typedef itk::VectorInterpolateImageFunction InterpolatorType; typedef itk::VectorLinearInterpolateImageFunction DefaultInterpolatorType; // Members void SetDeformationField (typename DeformationFieldType::Pointer p){m_DeformationField=p; m_Interpolator->SetInputImage(m_DeformationField);} void SetInterpolator (typename InterpolatorType::Pointer i){ m_Interpolator=i; m_Interpolator->SetInputImage(m_DeformationField);} OutputPointType TransformPoint(const InputPointType &point ) const; // Methods needed to inherit from an itk::Transform which should not be used // in this class /** Type of the input parameters. */ typedef typename Superclass::ParametersType ParametersType; typedef typename Superclass::ParametersValueType ParametersValueType; /** Type of the Jacobian matrix. */ typedef typename Superclass::JacobianType JacobianType; /** Standard vector type for this class. */ typedef typename Superclass::InputVectorType InputVectorType; typedef typename Superclass::OutputVectorType OutputVectorType; /** Standard covariant vector type for this class */ typedef typename Superclass::InputCovariantVectorType InputCovariantVectorType; typedef typename Superclass::OutputCovariantVectorType OutputCovariantVectorType; /** Standard vnl_vector type for this class. */ typedef typename Superclass::InputVnlVectorType InputVnlVectorType; typedef typename Superclass::OutputVnlVectorType OutputVnlVectorType; void SetParameters(const ParametersType&) { itkExceptionMacro( << "DeformationFieldTransform doesn't declare SetParameters" ); } void SetFixedParameters(const ParametersType&) { itkExceptionMacro( << "DeformationFieldTransform doesn't declare SetFixedParameters" ); } virtual OutputVectorType TransformVector(const InputVectorType &) const { itkExceptionMacro(<< "Method not applicable for deformable transform." ); return OutputVectorType(); } virtual OutputVnlVectorType TransformVector(const InputVnlVectorType &) const { itkExceptionMacro(<< "Method not applicable for deformable transform. "); return OutputVnlVectorType(); } virtual OutputCovariantVectorType TransformCovariantVector(const InputCovariantVectorType &) const { itkExceptionMacro(<< "Method not applicable for deformable transfrom. "); return OutputCovariantVectorType(); } virtual void ComputeJacobianWithRespectToParameters (const InputPointType &p, JacobianType &jacobian) const { itkExceptionMacro( << "DeformationFieldTransform doesn't declare ComputeJacobianWithRespectToParameters" ); } virtual void ComputeJacobianWithRespectToPosition (const InputPointType &p, JacobianType &jacobian) const { itkExceptionMacro( << "DeformationFieldTransform doesn't declare ComputeJacobianWithRespectToPosition" ); } protected: DeformationFieldTransform(); ~DeformationFieldTransform(){;} private: DeformationFieldTransform(const Self&); //purposely not implemented void operator=(const Self&); //purposely not implemented typename DeformationFieldType::Pointer m_DeformationField; typename InterpolatorType::Pointer m_Interpolator; }; //class DeformationFieldTransform } // namespace itk #ifndef ITK_MANUAL_INSTANTIATION #include "clitkDeformationFieldTransform.txx" #endif #endif /* __clitkDeformationFieldTransform_h */