VTK
vtkTemporalStatistics.h
Go to the documentation of this file.
1 // -*- c++ -*-
2 /*=========================================================================
3 
4  Program: Visualization Toolkit
5  Module: vtkTemporalStatistics.h
6 
7  Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
8  All rights reserved.
9  See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
10 
11  This software is distributed WITHOUT ANY WARRANTY; without even
12  the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
13  PURPOSE. See the above copyright notice for more information.
14 
15 =========================================================================*/
16 
17 /*
18  * Copyright 2008 Sandia Corporation.
19  * Under the terms of Contract DE-AC04-94AL85000, there is a non-exclusive
20  * license for use of this work by or on behalf of the
21  * U.S. Government. Redistribution and use in source and binary forms, with
22  * or without modification, are permitted provided that this Notice and any
23  * statement of authorship are reproduced on all copies.
24  */
25 
54 #ifndef _vtkTemporalStatistics_h
55 #define _vtkTemporalStatistics_h
56 
58 
60 class vtkDataSet;
61 class vtkFieldData;
62 class vtkGraph;
63 
65 {
66 public:
68  static vtkTemporalStatistics *New();
69  virtual void PrintSelf(ostream &os, vtkIndent indent);
70 
72 
74  vtkGetMacro(ComputeAverage, int);
75  vtkSetMacro(ComputeAverage, int);
76  vtkBooleanMacro(ComputeAverage, int);
78 
80 
82  vtkGetMacro(ComputeMinimum, int);
83  vtkSetMacro(ComputeMinimum, int);
84  vtkBooleanMacro(ComputeMinimum, int);
86 
88 
90  vtkGetMacro(ComputeMaximum, int);
91  vtkSetMacro(ComputeMaximum, int);
92  vtkBooleanMacro(ComputeMaximum, int);
94 
95  // Definition:
96  // Turn on/off the computation of the standard deviation of the values over
97  // time. On by default. The resulting array names have "_stddev" appended to
98  // them.
99  vtkGetMacro(ComputeStandardDeviation, int);
100  vtkSetMacro(ComputeStandardDeviation, int);
101  vtkBooleanMacro(ComputeStandardDeviation, int);
102 
103 protected:
106 
111 
112  // Used when iterating the pipeline to keep track of which timestep we are on.
114 
116 
117  virtual int RequestDataObject(vtkInformation *request,
118  vtkInformationVector **inputVector,
119  vtkInformationVector *outputVector);
120  virtual int RequestInformation(vtkInformation *request,
121  vtkInformationVector **inputVector,
122  vtkInformationVector *outputVector);
123  virtual int RequestUpdateExtent(vtkInformation *request,
124  vtkInformationVector **inputVector,
125  vtkInformationVector *outputVector);
126  virtual int RequestData(vtkInformation *request,
127  vtkInformationVector **inputVector,
128  vtkInformationVector *outputVector);
129 
130  virtual void InitializeStatistics(vtkDataObject *input,
131  vtkDataObject *output);
132  virtual void InitializeStatistics(vtkDataSet *input, vtkDataSet *output);
133  virtual void InitializeStatistics(vtkGraph *input, vtkGraph *output);
134  virtual void InitializeStatistics(vtkCompositeDataSet *input,
135  vtkCompositeDataSet *output);
136  virtual void InitializeArrays(vtkFieldData *inFd, vtkFieldData *outFd);
137  virtual void InitializeArray(vtkDataArray *array, vtkFieldData *outFd);
138 
139  virtual void AccumulateStatistics(vtkDataObject *input,
140  vtkDataObject *output);
141  virtual void AccumulateStatistics(vtkDataSet *input, vtkDataSet *output);
142  virtual void AccumulateStatistics(vtkGraph *input, vtkGraph *output);
143  virtual void AccumulateStatistics(vtkCompositeDataSet *input,
144  vtkCompositeDataSet *output);
145  virtual void AccumulateArrays(vtkFieldData *inFd, vtkFieldData *outFd);
146 
147  virtual void PostExecute(vtkDataObject *input, vtkDataObject *output);
148  virtual void PostExecute(vtkDataSet *input, vtkDataSet *output);
149  virtual void PostExecute(vtkGraph *input, vtkGraph *output);
150  virtual void PostExecute(vtkCompositeDataSet *input,
151  vtkCompositeDataSet *output);
152  virtual void FinishArrays(vtkFieldData *inFd, vtkFieldData *outFd);
153 
154  virtual vtkDataArray *GetArray(vtkFieldData *fieldData,
155  vtkDataArray *inArray,
156  const char *nameSuffix);
157 
158 private:
159  vtkTemporalStatistics(const vtkTemporalStatistics &); // Not implemented.
160  void operator=(const vtkTemporalStatistics &); // Not implemented.
161 };
162 
163 #endif //_vtkTemporalStatistics_h
virtual int RequestInformation(vtkInformation *, vtkInformationVector **, vtkInformationVector *)
#define VTK_GRAPHICS_EXPORT
Superclass for algorithms that produce output of the same type as input.
Store vtkAlgorithm input/output information.
abstract class to specify dataset behavior
Definition: vtkDataSet.h:58
Base class for graph data types.
Definition: vtkGraph.h:287
virtual int FillInputPortInformation(int port, vtkInformation *info)
abstract superclass for composite (multi-block or AMR) datasets
virtual int RequestUpdateExtent(vtkInformation *, vtkInformationVector **, vtkInformationVector *)
a simple class to control print indentation
Definition: vtkIndent.h:37
abstract superclass for arrays of numeric data
Definition: vtkDataArray.h:53
virtual int RequestDataObject(vtkInformation *request, vtkInformationVector **inputVector, vtkInformationVector *outputVector)
void PrintSelf(ostream &os, vtkIndent indent)
Store zero or more vtkInformation instances.
Compute statistics of point or cell data as it changes over time.
general representation of visualization data
Definition: vtkDataObject.h:70
virtual int RequestData(vtkInformation *, vtkInformationVector **, vtkInformationVector *)
static vtkPassInputTypeAlgorithm * New()
represent and manipulate fields of data
Definition: vtkFieldData.h:58