VTK
Public Types | Public Member Functions | Static Public Member Functions | Public Attributes | Protected Member Functions
vtkFiniteDifferenceGradientEstimator Class Reference

Use finite differences to estimate gradient. More...

#include <vtkFiniteDifferenceGradientEstimator.h>

Inheritance diagram for vtkFiniteDifferenceGradientEstimator:
Inheritance graph
[legend]
Collaboration diagram for vtkFiniteDifferenceGradientEstimator:
Collaboration graph
[legend]

List of all members.

Public Types

typedef vtkEncodedGradientEstimator Superclass

Public Member Functions

virtual int IsA (const char *type)
vtkFiniteDifferenceGradientEstimatorNewInstance () const
void PrintSelf (ostream &os, vtkIndent indent)
virtual void SetSampleSpacingInVoxels (int)
virtual int GetSampleSpacingInVoxels ()

Static Public Member Functions

static int IsTypeOf (const char *type)
static
vtkFiniteDifferenceGradientEstimator
SafeDownCast (vtkObjectBase *o)
static
vtkFiniteDifferenceGradientEstimator
New ()

Public Attributes

int SampleSpacingInVoxels

Protected Member Functions

virtual vtkObjectBaseNewInstanceInternal () const
 vtkFiniteDifferenceGradientEstimator ()
 ~vtkFiniteDifferenceGradientEstimator ()
void UpdateNormals (void)

Detailed Description

Use finite differences to estimate gradient.

vtkFiniteDifferenceGradientEstimator is a concrete subclass of vtkEncodedGradientEstimator that uses a central differences technique to estimate the gradient. The gradient at some sample location (x,y,z) would be estimated by:

 nx = (f(x-dx,y,z) - f(x+dx,y,z)) / 2*dx;
 ny = (f(x,y-dy,z) - f(x,y+dy,z)) / 2*dy;
 nz = (f(x,y,z-dz) - f(x,y,z+dz)) / 2*dz;

This value is normalized to determine a unit direction vector and a magnitude. The normal is computed in voxel space, and dx = dy = dz = SampleSpacingInVoxels. A scaling factor is applied to convert this normal from voxel space to world coordinates.

See also:
vtkEncodedGradientEstimator
Tests:
vtkFiniteDifferenceGradientEstimator (Tests)

Definition at line 47 of file vtkFiniteDifferenceGradientEstimator.h.


Member Typedef Documentation

Reimplemented from vtkEncodedGradientEstimator.

Definition at line 50 of file vtkFiniteDifferenceGradientEstimator.h.


Constructor & Destructor Documentation


Member Function Documentation

static int vtkFiniteDifferenceGradientEstimator::IsTypeOf ( const char *  name) [static]

Return 1 if this class type is the same type of (or a subclass of) the named class. Returns 0 otherwise. This method works in combination with vtkTypeMacro found in vtkSetGet.h.

Reimplemented from vtkEncodedGradientEstimator.

virtual int vtkFiniteDifferenceGradientEstimator::IsA ( const char *  name) [virtual]

Return 1 if this class is the same type of (or a subclass of) the named class. Returns 0 otherwise. This method works in combination with vtkTypeMacro found in vtkSetGet.h.

Reimplemented from vtkEncodedGradientEstimator.

Reimplemented from vtkEncodedGradientEstimator.

Reimplemented from vtkEncodedGradientEstimator.

Reimplemented from vtkEncodedGradientEstimator.

void vtkFiniteDifferenceGradientEstimator::PrintSelf ( ostream &  os,
vtkIndent  indent 
) [virtual]

Methods invoked by print to print information about the object including superclasses. Typically not called by the user (use Print() instead) but used in the hierarchical print process to combine the output of several classes.

Reimplemented from vtkEncodedGradientEstimator.

Construct a vtkFiniteDifferenceGradientEstimator with a SampleSpacingInVoxels of 1.

Reimplemented from vtkObject.

Set/Get the spacing between samples for the finite differences method used to compute the normal. This spacing is in voxel units.

Set/Get the spacing between samples for the finite differences method used to compute the normal. This spacing is in voxel units.

void vtkFiniteDifferenceGradientEstimator::UpdateNormals ( void  ) [protected, virtual]

Recompute the encoded normals and gradient magnitudes.

Implements vtkEncodedGradientEstimator.


Member Data Documentation

Definition at line 61 of file vtkFiniteDifferenceGradientEstimator.h.


The documentation for this class was generated from the following file: