1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186
|
/*=========================================================================
Program: VMTK
Module: $RCSfile: vtkvmtkNonManifoldFastMarching.h,v $
Language: C++
Date: $Date: 2006/04/06 16:46:43 $
Version: $Revision: 1.5 $
Copyright (c) Luca Antiga, David Steinman. All rights reserved.
See LICENCE file for details.
Portions of this code are covered under the VTK copyright.
See VTKCopyright.txt or http://www.kitware.com/VTKCopyright.htm
for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notices for more information.
=========================================================================*/
// .NAME vtkvmtkNonManifoldFastMarching - Implementation of the Fast Marching Method on polygonal non-manifolds.
// .SECTION Description
// This class is used to solve the Eikonal equation \f[|\nabla T(\mathbf{x})| = F(\mathbf{x})\f] on non-manifolds made of convex polygons, using the Fast Marching Method, by J.A. Sethian (see below). The solution to the Eikonal equation represents the arrival times of a wave propagating on a domain with speed \f$F^{-1}(\mathbf{x})\f$ from given seed points (or regions). If F(x)=1, T(x) represents the geodesic distance field to the seed points (Note: F(x) can be equivalently interpreted as a cost function). The Fast Marching Method takes O(N logN). For more insight see J.A. Sethian, Level Set Methods and Fast Marching Methods, Cambridge University Press, 2nd Edition, 1999.
//
// The implementation given in this class is an extension of the Fast Marching Method for triangulated 2-manifolds proposed by Kimmel et al. (R. Kimmel and J.A. Sethian. Computing geodesic paths on manifolds. PNAS, 95(15): 8431-8435, Jul 1998.) to non-manifolds made of convex polygons, such as the Voronoi diagram.
//
// The propagation starts from a set of seeds. By default the seed points are given a propagation time of 0.0, but activating InitializeFromScalars and providing the point data array of name InitializationArrayName, it is possible to assign nonzero initialization times (this is useful when the zero propagation time point lies inside a cell).
// For the specification of F(x), the user must either provide a point data array of name CostFunctionArrayName, or activate UnitSpeed, which sets F(x)=1 everywhere, thus yielding a geodesic distance field.
// The propagation stops when all the points in the domain path-connected to the seeds have been visited. Alternatively it is possible to limit the propagation by setting StopTravelTime or StopNumberOfPoints.
// The solution is stored in a point data array of name SolutionArrayName (name provided by the user, "EikonalSolution" by default).
//
// The Regularization value adds a constant term to F(x), which acts as a regularization term for the minimal cost paths (see L.D. Cohen and R. Kimmel. Global minimum of active contour models: a minimal path approach. IJCV, 24(1): 57-78, Aug 1997).
//
// .SECTION See Also
// vtkVoronoiDiagram3D vtkMinHeap
#ifndef __vtkvmtkNonManifoldFastMarching_h
#define __vtkvmtkNonManifoldFastMarching_h
#include "vtkPolyDataAlgorithm.h"
#include "vtkIdList.h"
#include "vtkIntArray.h"
#include "vtkPolyData.h"
#include "vtkvmtkMinHeap.h"
#include "vtkvmtkConstants.h"
//#include "vtkvmtkComputationalGeometryWin32Header.h"
#include "vtkvmtkWin32Header.h"
const char VTK_VMTK_ACCEPTED_STATUS = 0x01;
const char VTK_VMTK_CONSIDERED_STATUS = 0x02;
const char VTK_VMTK_FAR_STATUS = 0x04;
class vtkDoubleArray;
class vtkCharArray;
class VTK_VMTK_COMPUTATIONAL_GEOMETRY_EXPORT vtkvmtkNonManifoldFastMarching : public vtkPolyDataAlgorithm
{
public:
vtkTypeRevisionMacro(vtkvmtkNonManifoldFastMarching,vtkPolyDataAlgorithm);
void PrintSelf(ostream& os, vtkIndent indent);
static vtkvmtkNonManifoldFastMarching *New();
// Description:
// Set/Get maximum travel time for travel time-based stop criterion.
vtkSetMacro(StopTravelTime,double);
vtkGetMacro(StopTravelTime,double);
// Description:
// Set/Get maximum number of visited points for number of visited points-based stop criterion.
vtkSetMacro(StopNumberOfPoints,int);
vtkGetMacro(StopNumberOfPoints,int);
// Description:
// Set/Get minimal cost path regularization amount.
vtkSetMacro(Regularization,double);
vtkGetMacro(Regularization,double);
// Description:
// Toggle on/off boundary conditions expressed as a list of seeds.
vtkSetMacro(SeedsBoundaryConditions,int);
vtkGetMacro(SeedsBoundaryConditions,int);
vtkBooleanMacro(SeedsBoundaryConditions,int);
// Description:
// Toggle on/off boundary conditions expressed as poly data.
vtkSetMacro(PolyDataBoundaryConditions,int);
vtkGetMacro(PolyDataBoundaryConditions,int);
vtkBooleanMacro(PolyDataBoundaryConditions,int);
// Description:
// Set/Get seeds were boundary conditions are specified.
vtkSetObjectMacro(Seeds,vtkIdList);
vtkGetObjectMacro(Seeds,vtkIdList);
// Description:
// Set/Get poly data were boundary conditions are specified.
vtkSetObjectMacro(BoundaryPolyData,vtkPolyData);
vtkGetObjectMacro(BoundaryPolyData,vtkPolyData);
// Description:
// Set/Get the name of the 2-component point data array of boundary poly data where point ids of edges of the input intersected by boundary poly data are stored.
vtkSetStringMacro(IntersectedEdgesArrayName);
vtkGetStringMacro(IntersectedEdgesArrayName);
// Description:
// Toggle on/off using point data array of name InitializationArrayName for the solution value of seed points. If off, a value of 0.0 is used for all seeds.
vtkSetMacro(InitializeFromScalars,int);
vtkGetMacro(InitializeFromScalars,int);
vtkBooleanMacro(InitializeFromScalars,int);
// Description:
// Set/Get the name of point data InitializationArray
vtkSetStringMacro(InitializationArrayName);
vtkGetStringMacro(InitializationArrayName);
// Description:
// Toggle on/off using a unit speed field over the whole domain (used to obtain geodesic distances). If off, a CostFunctionArray must be provided.
vtkSetMacro(UnitSpeed,int);
vtkGetMacro(UnitSpeed,int);
vtkBooleanMacro(UnitSpeed,int);
// Description:
// Set/Get the name of point data CostFunctionArray
vtkSetStringMacro(CostFunctionArrayName);
vtkGetStringMacro(CostFunctionArrayName);
// Description:
// Set/Get the name of point data SolutionArray
vtkSetStringMacro(SolutionArrayName);
vtkGetStringMacro(SolutionArrayName);
protected:
vtkvmtkNonManifoldFastMarching();
~vtkvmtkNonManifoldFastMarching();
virtual int RequestData(vtkInformation *, vtkInformationVector **, vtkInformationVector *);
void InitPropagation(vtkPolyData* input);
void SolveQuadratic(double a, double b, double c, char &nSol, double &x0, double &x1);
void GetNeighbors(vtkPolyData* input, vtkIdType pointId, vtkIdList* neighborIds);
double ComputeUpdateFromCellNeighbor(vtkPolyData* input, vtkIdType neighborId, vtkIdType* trianglePts);
void UpdateNeighbor(vtkPolyData* input, vtkIdType neighborId);
void UpdateNeighborhood(vtkPolyData* input, vtkIdType pointId);
void Propagate(vtkPolyData* input);
static double Max(double a, double b)
{ return a-b > VTK_VMTK_DOUBLE_TOL ? a : b; }
static double Min(double a, double b)
{ return a-b < - VTK_VMTK_DOUBLE_TOL ? a : b; }
vtkDoubleArray* TScalars;
vtkCharArray* StatusScalars;
vtkvmtkMinHeap* ConsideredMinHeap;
vtkIdList* Seeds;
vtkPolyData* BoundaryPolyData;
double Regularization;
double StopTravelTime;
vtkIdType StopNumberOfPoints;
int UnitSpeed;
int InitializeFromScalars;
char* IntersectedEdgesArrayName;
char* InitializationArrayName;
char* SolutionArrayName;
char* CostFunctionArrayName;
int SeedsBoundaryConditions;
int PolyDataBoundaryConditions;
vtkIdType NumberOfAcceptedPoints;
int AllowLineUpdate;
int UpdateFromConsidered;
private:
vtkvmtkNonManifoldFastMarching(const vtkvmtkNonManifoldFastMarching&); // Not implemented.
void operator=(const vtkvmtkNonManifoldFastMarching&); // Not implemented.
};
#endif
|