VTK
|
00001 /*========================================================================= 00002 00003 Program: Visualization Toolkit 00004 Module: vtkBoostKruskalMinimumSpanningTree.h 00005 00006 Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen 00007 All rights reserved. 00008 See Copyright.txt or http://www.kitware.com/Copyright.htm for details. 00009 00010 This software is distributed WITHOUT ANY WARRANTY; without even 00011 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR 00012 PURPOSE. See the above copyright notice for more information. 00013 00014 =========================================================================*/ 00015 /*------------------------------------------------------------------------- 00016 Copyright 2008 Sandia Corporation. 00017 Under the terms of Contract DE-AC04-94AL85000 with Sandia Corporation, 00018 the U.S. Government retains certain rights in this software. 00019 -------------------------------------------------------------------------*/ 00037 #ifndef __vtkBoostKruskalMinimumSpanningTree_h 00038 #define __vtkBoostKruskalMinimumSpanningTree_h 00039 00040 #include "vtkInfovisBoostGraphAlgorithmsModule.h" // For export macro 00041 #include "vtkStdString.h" // For string type 00042 #include "vtkVariant.h" // For variant type 00043 00044 #include "vtkSelectionAlgorithm.h" 00045 00046 class VTKINFOVISBOOSTGRAPHALGORITHMS_EXPORT vtkBoostKruskalMinimumSpanningTree : public vtkSelectionAlgorithm 00047 { 00048 public: 00049 static vtkBoostKruskalMinimumSpanningTree *New(); 00050 vtkTypeMacro(vtkBoostKruskalMinimumSpanningTree, vtkSelectionAlgorithm); 00051 void PrintSelf(ostream& os, vtkIndent indent); 00052 00054 00058 vtkSetStringMacro(EdgeWeightArrayName); 00060 00062 00065 vtkSetStringMacro(OutputSelectionType); 00067 00069 00073 void SetNegateEdgeWeights(bool value); 00074 vtkGetMacro(NegateEdgeWeights, bool); 00075 vtkBooleanMacro(NegateEdgeWeights, bool); 00077 00078 protected: 00079 vtkBoostKruskalMinimumSpanningTree(); 00080 ~vtkBoostKruskalMinimumSpanningTree(); 00081 00082 int RequestData( 00083 vtkInformation *, 00084 vtkInformationVector **, 00085 vtkInformationVector *); 00086 00087 int FillInputPortInformation( 00088 int port, vtkInformation* info); 00089 00090 int FillOutputPortInformation( 00091 int port, vtkInformation* info); 00092 00093 private: 00094 char* EdgeWeightArrayName; 00095 char* OutputSelectionType; 00096 bool NegateEdgeWeights; 00097 float EdgeWeightMultiplier; 00098 00099 vtkBoostKruskalMinimumSpanningTree(const vtkBoostKruskalMinimumSpanningTree&); // Not implemented. 00100 void operator=(const vtkBoostKruskalMinimumSpanningTree&); // Not implemented. 00101 }; 00102 00103 #endif