VTK
dox/Infovis/BoostGraphAlgorithms/vtkBoostKruskalMinimumSpanningTree.h
Go to the documentation of this file.
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