VTK
dox/Filters/ParallelStatistics/vtkPOrderStatistics.h
Go to the documentation of this file.
00001 /*=========================================================================
00002 
00003 Program:   Visualization Toolkit
00004 Module:    vtkPOrderStatistics.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 2011 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   -------------------------------------------------------------------------*/
00042 #ifndef __vtkPOrderStatistics_h
00043 #define __vtkPOrderStatistics_h
00044 
00045 #include "vtkFiltersParallelStatisticsModule.h" // For export macro
00046 #include "vtkOrderStatistics.h"
00047 
00048 //BTX
00049 #include <map> // STL Header
00050 //ETX
00051 
00052 class vtkIdTypeArray;
00053 class vtkMultiBlockDataSet;
00054 class vtkMultiProcessController;
00055 
00056 class VTKFILTERSPARALLELSTATISTICS_EXPORT vtkPOrderStatistics : public vtkOrderStatistics
00057 {
00058  public:
00059   static vtkPOrderStatistics* New();
00060   vtkTypeMacro(vtkPOrderStatistics, vtkOrderStatistics);
00061   void PrintSelf(ostream& os, vtkIndent indent);
00062 
00064 
00066   virtual void SetController(vtkMultiProcessController*);
00067   vtkGetObjectMacro(Controller, vtkMultiProcessController);
00069 
00071 
00072   virtual void Learn( vtkTable*,
00073                       vtkTable*,
00074                       vtkMultiBlockDataSet* );
00076 
00077  protected:
00078   vtkPOrderStatistics();
00079   ~vtkPOrderStatistics();
00080 
00081 //BTX
00083 
00085   bool Reduce( vtkIdTypeArray*,
00086                vtkDataArray* );
00088 
00090 
00092   bool Reduce( vtkIdTypeArray*,
00093                vtkIdType&,
00094                char*,
00095                std::map<vtkStdString,vtkIdType>& );
00097 
00099 
00101   bool Broadcast( std::map<vtkStdString,vtkIdType>&,
00102                   vtkIdTypeArray*,
00103                   vtkStringArray*,
00104                   vtkIdType );
00105 //ETX
00107 
00108   vtkMultiProcessController* Controller;
00109  private:
00110   vtkPOrderStatistics(const vtkPOrderStatistics&); // Not implemented.
00111   void operator=(const vtkPOrderStatistics&); // Not implemented.
00112 };
00113 
00114 #endif