18#ifndef itkDeformableSimplexMesh3DGradientConstraintForceFilter_h
19#define itkDeformableSimplexMesh3DGradientConstraintForceFilter_h
28#include "ITKDeformableMeshExport.h"
47 ImageVoxel(
const int * pos,
const double * subpos,
double val,
double dist,
unsigned int ind)
49 this->m_Vpos[0] = pos[0];
50 this->m_Vpos[1] = pos[1];
51 this->m_Vpos[2] = pos[2];
52 this->m_Spos[0] = subpos[0];
53 this->m_Spos[1] = subpos[1];
54 this->m_Spos[2] = subpos[2];
56 this->m_Distance = dist;
99 friend inline std::ostream &
102 os <<
"Vpos: " << val.
m_Vpos << std::endl;
103 os <<
"Spos: " << val.
m_Spos << std::endl;
104 os <<
"Value: " << val.
m_Value << std::endl;
105 os <<
"Distance: " << val.
m_Distance << std::endl;
106 os <<
"Index: " << val.
m_Index << std::endl;
133extern ITKDeformableMesh_EXPORT std::ostream &
148template <
typename TInputMesh,
typename TOutputMesh>
174 using typename Superclass::GradientIndexType;
175 using typename Superclass::GradientIndexValueType;
176 using typename Superclass::GradientType;
177 using typename Superclass::GradientImageType;
194 itkSetMacro(Range,
int);
195 itkGetConstMacro(Range,
int);
199#if !defined(ITK_LEGACY_REMOVE)
201 static constexpr SIDEEnum NORMAL = SIDEEnum::NORMAL;
202 static constexpr SIDEEnum INVERSE = SIDEEnum::INVERSE;
203 static constexpr SIDEEnum BOTH = SIDEEnum::BOTH;
234 NextVoxel(
const double *
pp,
int * ic,
double * x,
double * y,
double * z);
245 std::vector<ImageVoxel *> m_Positive{};
247 std::vector<ImageVoxel *> m_Negative{};
253#ifndef ITK_MANUAL_INSTANTIATION
254# include "itkDeformableSimplexMesh3DGradientConstraintForceFilter.hxx"
unsigned int GetY() const
returns voxel Y coordinate (voxel row)
unsigned int GetZ() const
returns voxel Z coordinate (voxel plane)
friend std::ostream & operator<<(std::ostream &os, const ImageVoxel &val)
ImageVoxel(const int *pos, const double *subpos, double val, double dist, unsigned int ind)
double GetDistance() const
returns voxel distance to origin
double GetValue() const
returns voxel value
unsigned int GetX() const
returns voxel X coordinate (voxel column)
void SetValue(const double val)
returns voxel position
Templated n-dimensional image class.
Control indentation during Print() invocation.
Light weight base class for most itk classes.
typename OutputMeshType::Pointer OutputMeshPointer
TOutputMesh OutputMeshType
typename InputMeshType::Pointer InputMeshPointer
handle geometric properties for vertices of a simplex mesh
SmartPointer< const Self > ConstPointer
SmartPointer< Self > Pointer
ImageBaseType::IndexType IndexType
ImageBaseType::PointType PointType
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....
*par Constraints *The filter image with at least two dimensions and a vector *length of at least The theory supports extension to scalar but *the implementation of the itk vector classes do not **The template parameter TRealType must be floating so it cannot multithread for data other than in Anisotropic Diffusion of Multivalued Images *with Application to Color IEEE Transactions on Image No pp
ITKCommon_EXPORT std::ostream & operator<<(std::ostream &out, typename AnatomicalOrientation::CoordinateEnum value)