-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathvtkKWHistogram.h
250 lines (202 loc) · 8.25 KB
/
vtkKWHistogram.h
1
2
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
/*=========================================================================
Module: $RCSfile: vtkKWHistogram.h,v $
Copyright (c) Kitware, Inc.
All rights reserved.
See Copyright.txt or http://www.kitware.com/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 notice for more information.
=========================================================================*/
// .NAME vtkKWHistogram - an histogram
// .SECTION Description
#ifndef __vtkKWHistogram_h
#define __vtkKWHistogram_h
#include "vtkObject.h"
#include "vtkKWWidgets.h" // Needed for export symbols directives
class vtkColorTransferFunction;
class vtkDataArray;
class vtkImageData;
class vtkDoubleArray;
class vtkIntArray;
class KWWidgets_EXPORT vtkKWHistogram : public vtkObject
{
public:
static vtkKWHistogram* New();
vtkTypeRevisionMacro(vtkKWHistogram,vtkObject);
void PrintSelf(ostream& os, vtkIndent indent);
// Description:
// Get the histogram range.
// Note that Range[1] is exclusive.
// The Range is updated automatically by the BuildHistogram method to
// match the range of the vtkDataArray passed as parameter.
vtkGetVector2Macro(Range, double);
// Description:
// Direct access to the bins
vtkGetObjectMacro(Bins, vtkDoubleArray);
// Description:
// Get the number of bins
virtual vtkIdType GetNumberOfBins();
// Description:
// Set/Get the maximum number of bins that should be used when
// creating the histogram
vtkSetMacro(MaximumNumberOfBins, vtkIdType);
vtkGetMacro(MaximumNumberOfBins, vtkIdType);
// Description:
// Get min, max, total occurence
virtual double GetMinimumOccurence();
virtual double GetMaximumOccurence();
virtual double GetTotalOccurence();
// Description:
// Get the occurence for the bin holding a given value.
virtual double GetOccurenceAtValue(double value);
// Description:
// Get the value at a given accumulated occurence in the histogram.
// 'exclude_value' is not NULL, it is a pointer to a value which bin
// will be ignored from the computation.
virtual double GetValueAtAccumulatedOccurence(
double acc, double *exclude_value = 0);
// Description:
// Build/update the histogram from scalars (given a component)
// The Range and number of bins are modified automatically
virtual void BuildHistogram(vtkDataArray *scalars, int component);
// Description:
// Set the histogram range.
// Note that Range[1] is exclusive.
// The Range is updated automatically by the BuildHistogram method to
// match the range of the vtkDataArray passed as parameter.
// Nevertheless, you might want to set the Range manually, either after
// calling the BuildHistogram method to restrict the histogram to a subset,
// or before calling the AccumulateHistogram method, which accumulates
// values and update the histogram.
// Use the EstimateHistogramRange method to compute the range that
// is needed to store a set of scalars.
vtkSetVector2Macro(Range, double);
// Description:
// Estimate the range that will be used by BuildHistogram from scalars
// (given a component)
virtual void EstimateHistogramRange(
vtkDataArray *scalars, int component, double range[2]);
// Description:
// Accumulate the histogram from scalars (given a component)
// The Range is *not* modified automatically, you have to set it
// appropriately before calling this method using either:
// - a call to SetRange followed by a call to EmptyHistogram
// (use the EstimateHistogramRange method to compute the range that
// is needed to store a set of scalars)
// - or a call to BuildHistogram first, with the appropriate 'scalars'.
// This method can be called multiple times with a different 'scalars':
// - the 'scalars' range has to lie within the Range ivar.
// - the bins are not reset to 0, the values of 'scalars' are used to
// update the histogram with more data (accumulate)
// => EmptyHistogram will reset the histogram (remove all bins,
// forcing all bins to be set to 0 the next time the number
// of bins is changed).
virtual void AccumulateHistogram(vtkDataArray *scalars, int component);
// Description:
// Empty this histogram (0 bins). The next time the number of bins is
// changed (BuildHistogram or AccumulateHistogram), each bin is set to 0.
virtual void EmptyHistogram();
// Description:
// Compute the image of the histogram in log space (default).
virtual void SetLogMode(int);
vtkBooleanMacro(LogMode, int);
vtkGetMacro(LogMode, int);
protected:
vtkKWHistogram();
~vtkKWHistogram();
double Range[2];
vtkDoubleArray *Bins;
vtkImageData *Image;
vtkIntArray *ImageCoordinates;
unsigned long LastImageBuildTime;
unsigned long LastTransferFunctionTime;
int LogMode;
vtkIdType MaximumNumberOfBins;
virtual void ComputeStatistics();
unsigned long LastStatisticsBuildTime;
double MinimumOccurence;
double MaximumOccurence;
double TotalOccurence;
// Description:
// Update the histogram from scalars (given a component)
// Either reset the range (BuildHistogram) or not (AccumulateHistogram)
virtual void UpdateHistogram(
vtkDataArray *scalars, int component, int reset_range);
// Description:
// Estimate the range that will be used by BuildHistogram from scalars
// (given a component), and the number of bins
virtual void EstimateHistogramRangeAndNumberOfBins(
vtkDataArray *scalars, int component,
double range[2], vtkIdType *nb_of_bins);
public:
// Description:
// Get an image of the histogram. The image parameters are described
// through an instance of the above ImageDescriptor. The histogram
// can be drawn for a given data range.
// If DrawBackground is false, the background pixels are set to be
// transparent and the resulting image is created in RGBA space instead
// of RGB.
//BTX
// @cond nested_class
class KWWidgets_EXPORT ImageDescriptor
{
public:
ImageDescriptor();
int IsValid() const;
int IsEqualTo(const ImageDescriptor *desc);
void Copy(const ImageDescriptor *desc);
int DrawForeground;
int DrawBackground;
int DrawGrid;
int GridSize;
enum
{
StyleBars = 0,
StyleDots
};
int Style;
double Range[2];
void SetRange(double range0, double range1);
void SetRange(double range[2]);
unsigned int Width;
unsigned int Height;
void SetDimensions(unsigned int width, unsigned int height);
double Color[3];
void SetColor(double color[3]);
double BackgroundColor[3];
void SetBackgroundColor(double color[3]);
double OutOfRangeColor[3];
void SetOutOfRangeColor(double color[3]);
double GridColor[3];
void SetGridColor(double color[3]);
vtkColorTransferFunction *ColorTransferFunction;
// When the histogram is drawn, a resampled version of the histogram
// is computed where each column-pixel along the Width is a bin.
// The histogram itself is scaled vertically so that the bin with
// the maximum occurence occupies the full Height.
// Each time it occurs, the LastMaximumOccurence ivar is modified
// to store this maximum occurence.
// If the DefaultMaximumOccurence is set to something other than 0.0
// it will override the maximum occurence found so far and be used
// to scale the histogram vertically (of course, it has to be >=
// to the current maximum occurence).
// Using DefaultMaximumOccurence is right now the way to have two
// histograms being scaled the same way, under some constraints.
double DefaultMaximumOccurence;
double LastMaximumOccurence;
};
// @endcond
virtual int IsImageUpToDate(const ImageDescriptor *desc = 0);
virtual vtkImageData* GetImage(ImageDescriptor *desc);
virtual vtkIntArray* GetImageCoordinates(ImageDescriptor *desc);
//ETX
protected:
//BTX
vtkKWHistogram::ImageDescriptor *LastImageDescriptor;
//ETX
virtual int RefreshImage(ImageDescriptor *desc);
private:
vtkKWHistogram(const vtkKWHistogram&); // Not implemented
void operator=(const vtkKWHistogram&); // Not implemented
};
#endif