18 #ifndef sitkAffineTransform_h
19 #define sitkAffineTransform_h
49 const std::vector< double> &translation,
50 const std::vector< double> &fixedCenter=std::vector< double >(3, 0.0));
56 std::string
GetName()
const override {
return std::string (
"AffineTransform"); }
59 std::vector<double> GetTranslation( )
const;
60 SITK_RETURN_SELF_TYPE_HEADER SetTranslation(
const std::vector<double>& translation);
62 SITK_RETURN_SELF_TYPE_HEADER SetMatrix(
const std::vector<double> &matrix);
63 std::vector<double> GetMatrix()
const;
66 SITK_RETURN_SELF_TYPE_HEADER SetCenter(
const std::vector<double> ¶ms);
67 std::vector<double> GetCenter( )
const;
70 SITK_RETURN_SELF_TYPE_HEADER Scale(
const std::vector<double> & factor,
bool pre=
false);
71 SITK_RETURN_SELF_TYPE_HEADER Scale(
double factor,
bool pre=
false);
73 SITK_RETURN_SELF_TYPE_HEADER Shear(
int axis1,
int axis2,
double coef,
bool pre=
false);
75 SITK_RETURN_SELF_TYPE_HEADER Translate(
const std::vector<double> &offset,
bool pre=
false);
77 SITK_RETURN_SELF_TYPE_HEADER Rotate(
int axis1,
int axis2,
double angle,
bool pre=
false);
81 void SetPimpleTransform(std::unique_ptr<PimpleTransformBase> && pimpleTransform )
override;
89 template<
typename TransformType >
90 void operator() ( )
const
92 TransformType *t =
dynamic_cast<TransformType*
>(transform);
93 if (t && (
typeid(*t) ==
typeid(TransformType)))
102 template <
typename TransformType>
103 void InternalInitialization(TransformType *transform);
113 std::function<void(
const std::vector<double> &,
bool)>
m_pfScale1;
123 #endif // sitkAffineTransform_h