| 12
 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
 
 | /*=========================================================================
Program:   VMTK
Module:    $RCSfile: vtkvmtkConstrainedLaplacianPolyDataFilter.h,v $
Language:  C++
Date:      $Date: 2006/04/06 16:48:25 $
Version:   $Revision: 1.3 $
  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.
  Portions of this code are covered under the ITK copyright.
  See ITKCopyright.txt or http://www.itk.org/HTML/Copyright.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 vtkvmtkConstrainedLaplacianPolyDataFilter - ...
  // .SECTION Description
  // .
#ifndef __vtkvmtkConstrainedLaplacianPolyDataFilter_h
#define __vtkvmtkConstrainedLaplacianPolyDataFilter_h
#include "vtkPolyDataToPolyDataFilter.h"
#include "vtkvmtkWin32Header.h"
class vtkIdList;
class VTK_VMTK_SEGMENTATION_EXPORT vtkvmtkConstrainedLaplacianPolyDataFilter : public vtkPolyDataToPolyDataFilter
{
  public: 
  vtkTypeRevisionMacro(vtkvmtkConstrainedLaplacianPolyDataFilter,vtkPolyDataToPolyDataFilter);
  void PrintSelf(ostream& os, vtkIndent indent); 
  static vtkvmtkConstrainedLaplacianPolyDataFilter *New();
  vtkSetMacro(Convergence, double);
  vtkGetMacro(Convergence, double);
  vtkSetMacro(RelaxationFactor, double);
  vtkGetMacro(RelaxationFactor, double);
  vtkSetMacro(NumberOfIterations, int);
  vtkGetMacro(NumberOfIterations, int);
  vtkSetMacro(BoundarySmoothing, int);
  vtkGetMacro(BoundarySmoothing, int);
  vtkBooleanMacro(BoundarySmoothing, int);
  virtual void SetConstrainedPointIds(vtkIdList *);
  vtkGetObjectMacro(ConstrainedPointIds, vtkIdList);
  protected:
  vtkvmtkConstrainedLaplacianPolyDataFilter();
  ~vtkvmtkConstrainedLaplacianPolyDataFilter();  
  void Execute();
  vtkIdList *ConstrainedPointIds;
  
  double Convergence;
  double RelaxationFactor;
  int NumberOfIterations;
  int BoundarySmoothing;
  private:
  vtkvmtkConstrainedLaplacianPolyDataFilter(const vtkvmtkConstrainedLaplacianPolyDataFilter&);  // Not implemented.
  void operator=(const vtkvmtkConstrainedLaplacianPolyDataFilter&);  // Not implemented.
};
#endif
 |