Skip to content

itk::ParticleImageDomainWithCurvature

More...

#include <itkParticleImageDomainWithCurvature.h>

Inherits from itk::ParticleImageDomainWithGradN< T >, itk::ParticleImageDomainWithGradients< T >, itk::ParticleImageDomain< T >, itk::ParticleRegionDomain, itk::ParticleDomain, DataObject

Inherited by itk::ParticleImplicitSurfaceDomain< T >

Public Types

Name
typedef ParticleImageDomainWithGradN< T > Superclass
typedef Superclass::PointType PointType
typedef Superclass::ImageType ImageType
typedef Superclass::VnlMatrixType VnlMatrixType

Public Functions

Name
void SetImage(ImageType * I, double narrow_band)
virtual double GetCurvature(const PointType & p, int idx) const override
virtual double GetSurfaceMeanCurvature() const override
virtual double GetSurfaceStdDevCurvature() const override

Protected Functions

Name
ParticleImageDomainWithCurvature()
void PrintSelf(std::ostream & os, Indent indent) const
virtual ~ParticleImageDomainWithCurvature()

Additional inherited members

Public Types inherited from itk::ParticleImageDomainWithGradN< T >

Name
typedef SmartPointer< ParticleImageDomainWithGradN > Pointer
typedef Superclass::GradNType GradNType

Public Functions inherited from itk::ParticleImageDomainWithGradN< T >

Name
virtual GradNType SampleGradNAtPoint(const PointType & p, int idx) const override
virtual void DeletePartialDerivativeImages() override
virtual void DeleteImages() override

Protected Functions inherited from itk::ParticleImageDomainWithGradN< T >

Name
ParticleImageDomainWithGradN()
virtual ~ParticleImageDomainWithGradN()

Public Types inherited from itk::ParticleImageDomainWithGradients< T >

Name
typedef SmartPointer< ParticleImageDomainWithGradients< T > > Pointer
typedef FixedArray< T, DIMENSION > VectorType
typedef vnl_vector_fixed< T, DIMENSION > VnlVectorType

Public Functions inherited from itk::ParticleImageDomainWithGradients< T >

Name
virtual vnl_vector_fixed< float, DIMENSION > SampleGradientAtPoint(const PointType & p, int idx) const
virtual vnl_vector_fixed< float, DIMENSION > SampleNormalAtPoint(const PointType & p, int idx) const
virtual vnl_vector_fixed< double, DIMENSION > ProjectVectorToSurfaceTangent(vnl_vector_fixed< double, DIMENSION > & gradE, const PointType & pos, int idx) const override
virtual void DeleteImages() override

Protected Functions inherited from itk::ParticleImageDomainWithGradients< T >

Name
ParticleImageDomainWithGradients()
virtual ~ParticleImageDomainWithGradients()
openvdb::VectorGrid::Ptr GetVDBGradient()

Public Types inherited from itk::ParticleImageDomain< T >

Name
typedef SmartPointer< ParticleImageDomain > Pointer

Public Functions inherited from itk::ParticleImageDomain< T >

Name
virtual double GetSurfaceArea() const override
PointType GetOrigin() const
ImageType::SizeType GetSize() const
ImageType::SpacingType GetSpacing() const
ImageType::RegionType::IndexType GetIndex() const
virtual PointType GetValidLocationNear(PointType p) const override
T Sample(const PointType & p) const
virtual double GetMaxDiameter() const override
virtual void DeleteImages() override
virtual void UpdateZeroCrossingPoint() override

Protected Functions inherited from itk::ParticleImageDomain< T >

Name
openvdb::FloatGrid::Ptr GetVDBImage() const
ParticleImageDomain()
virtual ~ParticleImageDomain()
openvdb::math::Transform::Ptr transform() const
openvdb::Vec3R ToVDBCoord(const PointType & p) const

Public Types inherited from itk::ParticleRegionDomain

Name
typedef SmartPointer< ParticleRegionDomain > Pointer

Public Functions inherited from itk::ParticleRegionDomain

Name
virtual bool ApplyConstraints(PointType & p) const
virtual const PointType & GetUpperBound() const
virtual const PointType & GetLowerBound() const
void SetUpperBound(const PointType _UpperBound)
void SetLowerBound(const PointType _LowerBound)
void SetRegion(const PointType & lowerBound, const PointType & upperBound)

Protected Functions inherited from itk::ParticleRegionDomain

Name
ParticleRegionDomain()
virtual ~ParticleRegionDomain()
bool IsInsideBuffer(const PointType & p) const

Public Types inherited from itk::ParticleDomain

Name
typedef SmartPointer< ParticleDomain > Pointer
typedef vnl_matrix_fixed< float, DIMENSION, DIMENSION > GradNType

Public Functions inherited from itk::ParticleDomain

Name
virtual bool ApplyConstraints(PointType & p, int idx, bool dbg =false) const =0
virtual PointType UpdateParticlePosition(const PointType & point, int idx, vnl_vector_fixed< double, DIMENSION > & update) const =0
virtual void InvalidateParticlePosition(int idx) const
virtual vnl_vector_fixed< double, DIMENSION > ProjectVectorToSurfaceTangent(vnl_vector_fixed< double, DIMENSION > & gradE, const PointType & pos, int idx) const =0
virtual vnl_vector_fixed< float, DIMENSION > SampleGradientAtPoint(const PointType & point, int idx) const =0
virtual vnl_vector_fixed< float, DIMENSION > SampleNormalAtPoint(const PointType & point, int idx) const =0
virtual GradNType SampleGradNAtPoint(const PointType & p, int idx) const =0
virtual double Distance(const PointType & a, int idx_a, const PointType & b, int idx_b, vnl_vector_fixed< double, DIMENSION > * out_grad =nullptr) const
virtual double SquaredDistance(const PointType & a, int idx_a, const PointType & b, int idx_b) const
virtual bool IsWithinDistance(const PointType & a, int idx_a, const PointType & b, int idx_b, double test_dist, double & distance) const
virtual const PointType & GetLowerBound() const =0
virtual const PointType & GetUpperBound() const =0
virtual PointType GetZeroCrossingPoint() const =0
virtual double GetSurfaceArea() const =0
virtual PointType GetValidLocationNear(PointType p) const =0
virtual double GetMaxDiameter() const =0
virtual void DeleteImages() =0
virtual void DeletePartialDerivativeImages() =0
virtual void UpdateZeroCrossingPoint() =0
bool IsDomainFixed() const
virtual shapeworks::DomainType GetDomainType() const =0
std::shared_ptr< Constraints > GetConstraints() const
virtual PointType GetPositionAfterSplit(const PointType & pt, const vnl_vector_fixed< double, 3 > & random, double epsilon) const
void SetDomainID(int id)
void SetDomainName(std::string name)

Protected Functions inherited from itk::ParticleDomain

Name
ParticleDomain()
virtual ~ParticleDomain()

Protected Attributes inherited from itk::ParticleDomain

Name
bool m_FixedDomain
int m_DomainID
std::string m_DomainName
std::shared_ptr< Constraints > constraints

Detailed Description

template <class T >
class itk::ParticleImageDomainWithCurvature;

See:

An image domain that extends ParticleImageDomainWithGradN with curvature information.

Public Types Documentation

typedef Superclass

typedef ParticleImageDomainWithGradN<T> itk::ParticleImageDomainWithCurvature< T >::Superclass;

Standard class typedefs

typedef PointType

typedef Superclass::PointType itk::ParticleImageDomainWithCurvature< T >::PointType;

typedef ImageType

typedef Superclass::ImageType itk::ParticleImageDomainWithCurvature< T >::ImageType;

typedef VnlMatrixType

typedef Superclass::VnlMatrixType itk::ParticleImageDomainWithCurvature< T >::VnlMatrixType;

Public Functions Documentation

function SetImage

inline void SetImage(
    ImageType * I,
    double narrow_band
)

Set/Get the itk::Image specifying the particle domain. The set method modifies the parent class LowerBound and UpperBound.

function GetCurvature

inline virtual double GetCurvature(
    const PointType & p,
    int idx
) const override

Reimplements: itk::ParticleDomain::GetCurvature

Used in ParticleMeanCurvatureAttribute

function GetSurfaceMeanCurvature

inline virtual double GetSurfaceMeanCurvature() const override

Reimplements: itk::ParticleDomain::GetSurfaceMeanCurvature

Used in ParticleMeanCurvatureAttribute

function GetSurfaceStdDevCurvature

inline virtual double GetSurfaceStdDevCurvature() const override

Reimplements: itk::ParticleDomain::GetSurfaceStdDevCurvature

Used in ParticleMeanCurvatureAttribute

Protected Functions Documentation

function ParticleImageDomainWithCurvature

inline ParticleImageDomainWithCurvature()

function PrintSelf

inline void PrintSelf(
    std::ostream & os,
    Indent indent
) const

function ~ParticleImageDomainWithCurvature

inline virtual ~ParticleImageDomainWithCurvature()

Updated on 2022-03-31 at 09:51:18 -0600