VTK
|
Time filter execution. More...
#include <vtkExecutionTimer.h>
Time filter execution.
This object monitors a single filter for StartEvent and EndEvent. Each time it hears StartEvent it records the time. Each time it hears EndEvent it measures the elapsed time (both CPU and wall-clock) since the most recent StartEvent. Internally we use vtkTimerLog for measurements.
By default we simply store the elapsed time. You are welcome to subclass and override TimerFinished() to do anything you want.
Definition at line 43 of file vtkExecutionTimer.h.
Reimplemented from vtkObject.
Definition at line 46 of file vtkExecutionTimer.h.
vtkExecutionTimer::vtkExecutionTimer | ( | ) | [protected] |
vtkExecutionTimer::~vtkExecutionTimer | ( | ) | [protected] |
static int vtkExecutionTimer::IsTypeOf | ( | const char * | name | ) | [static] |
Return 1 if this class type is the same type of (or a subclass of) the named class. Returns 0 otherwise. This method works in combination with vtkTypeMacro found in vtkSetGet.h.
Reimplemented from vtkObject.
virtual int vtkExecutionTimer::IsA | ( | const char * | name | ) | [virtual] |
Return 1 if this class is the same type of (or a subclass of) the named class. Returns 0 otherwise. This method works in combination with vtkTypeMacro found in vtkSetGet.h.
Reimplemented from vtkObject.
static vtkExecutionTimer* vtkExecutionTimer::SafeDownCast | ( | vtkObjectBase * | o | ) | [static] |
Reimplemented from vtkObject.
virtual vtkObjectBase* vtkExecutionTimer::NewInstanceInternal | ( | ) | const [protected, virtual] |
Reimplemented from vtkObject.
vtkExecutionTimer* vtkExecutionTimer::NewInstance | ( | ) | const |
Reimplemented from vtkObject.
void vtkExecutionTimer::PrintSelf | ( | ostream & | os, |
vtkIndent | indent | ||
) | [virtual] |
static vtkExecutionTimer* vtkExecutionTimer::New | ( | ) | [static] |
Construct a new timer with no attached filter. Use SetFilter() to specify the vtkAlgorithm whose execution you want to time.
Reimplemented from vtkObject.
void vtkExecutionTimer::SetFilter | ( | vtkAlgorithm * | filter | ) |
Set/get the filter to be monitored. The only real constraint here is that the vtkExecutive associated with the filter must fire StartEvent and EndEvent before and after the filter is executed. All VTK executives should do this.
virtual vtkAlgorithm* vtkExecutionTimer::GetFilter | ( | ) | [virtual] |
Set/get the filter to be monitored. The only real constraint here is that the vtkExecutive associated with the filter must fire StartEvent and EndEvent before and after the filter is executed. All VTK executives should do this.
virtual double vtkExecutionTimer::GetElapsedCPUTime | ( | ) | [virtual] |
Get the total CPU time (in seconds) that elapsed between StartEvent and EndEvent. This is undefined before the filter has finished executing.
virtual double vtkExecutionTimer::GetElapsedWallClockTime | ( | ) | [virtual] |
Get the total wall clock time (in seconds) that elapsed between StartEvent and EndEvent. This is undefined before the filter has finished executing.
void vtkExecutionTimer::StartTimer | ( | ) | [protected] |
Convenience functions -- StartTimer clears out the elapsed times and records start times; StopTimer records end times and computes the elapsed time
void vtkExecutionTimer::StopTimer | ( | ) | [protected] |
Convenience functions -- StartTimer clears out the elapsed times and records start times; StopTimer records end times and computes the elapsed time
virtual void vtkExecutionTimer::TimerFinished | ( | ) | [protected, virtual] |
This is where you can do anything you want with the progress event. By default this does nothing.
static void vtkExecutionTimer::EventRelay | ( | vtkObject * | caller, |
unsigned long | eventId, | ||
void * | clientData, | ||
void * | callData | ||
) | [static, protected] |
This is the callback that VTK will invoke when it sees StartEvent and EndEvent. Its responsibility is to pass the event on to an instance of this observer class.
vtkCallbackCommand* vtkExecutionTimer::Callback [protected] |
Definition at line 82 of file vtkExecutionTimer.h.
vtkAlgorithm* vtkExecutionTimer::Filter [protected] |
Definition at line 85 of file vtkExecutionTimer.h.
double vtkExecutionTimer::CPUStartTime [protected] |
Definition at line 88 of file vtkExecutionTimer.h.
double vtkExecutionTimer::CPUEndTime [protected] |
Definition at line 89 of file vtkExecutionTimer.h.
double vtkExecutionTimer::WallClockStartTime [protected] |
Definition at line 91 of file vtkExecutionTimer.h.
double vtkExecutionTimer::WallClockEndTime [protected] |
Definition at line 92 of file vtkExecutionTimer.h.
double vtkExecutionTimer::ElapsedCPUTime [protected] |
Definition at line 94 of file vtkExecutionTimer.h.
double vtkExecutionTimer::ElapsedWallClockTime [protected] |
Definition at line 95 of file vtkExecutionTimer.h.