forked from graemeg/epiktimer
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathREADME.txt
126 lines (95 loc) · 5.21 KB
/
README.txt
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
Description: Precision timer/stopwatch component for Lazarus/FPC
Author: Tom Lisjac <[email protected]>
Contributors: Please see the Git repository commit history
License: Modifyed LGPL (The same as Free Pascal RTL and LCL)
Copyright (C) 2003-2006 by Tom Lisjac
Latest version can be obtained at: http://wiki.lazarus.freepascal.org/EpikTimer
Contents:
1. The EpikTimer.pas component and palette icon
2. ETPackage.lpk package for installation
3. ETDemo demonstration app and host system clock evaluator
-----------------------------------------------------------------
The EpikTimer Component
Documentation:
See epiktimer.pas for detailed discussion of timebase sources, timing
accuracy and clock correlation techniques that can provide traceable
precision during long term measurements.
Installation:
- In Components/Open Package File, open etpackage.lpk.
- Compile the component to verify that everything is there.
- Install and let Lazarus rebuild
- Component will be in the System Palette (stopwatch-ruler icon)
Usage:
Drop the component on a form. The component contains a single timer
instance and parameterless calls to start, stop, elapsed and clear
will implicitly reference it. If the timer is named ET:
Procedure InstrumentedCall;
Begin
ET.Clear; // optional... timer is cleared at creation
ET.Start;
ExecuteFirstTimedSection;
ET.Stop; // the timer is actually paused and can be restarted later
TimedSection1:=ET.Elapsed; // store the elapsed in a global
MakeAnUntimedOverheadCall; // not counted in the timer
ET.Start; //resume the timer... continue accumulating ticks
CallTimedSection2;
TimedSection2:=ET.Elapsed; //timer keeps running... we've just sample it.
CallTimedSection3;
CallSomethingElse;
TimedSection3:=ET.Elapsed; //keep counting... tap the elapsed
CallTimedSection4;
TimedSection4:=ET.Elapsed; //keep counting... tap the elapsed
ET.clear // done... timer is stopped and zeroed
end;
You can also create any number of timers from a single component on
the form by declaring a TimerData record and passing it as a parameter
to start, stop, elapsed and clear using the overloaded methods in the
component. An example would be:
Function TimedExecution:Extended;
Var DiskAccessTime:TimerData;
Begin
ET.Clear(DiskAccessTimer); // Declared timers *must* be cleared before use.
ET.Start(DiskAccessTimer);
ExecuteTheTimedSection;
Result:=ET.Elapsed(DiskAccessTimer); // the timer keeps running...
etc...
See etdemo.pas for additional examples of component usage
The ETDemo Application
The ETDemo application does not require EpikTimer to be installed in order
to compile and operate. I never liked having to install a palette full of
components only to find out that I didn't like any of them! :)
Installation
Open etdemo.lpi and compile it.
Operation
As the program comes up, it will create and initialize 10 invisible timer
forms that can be spawned from the main program's Stopwatch group box. A
progress bar is supposed to reduce the boredom.
Host Hardware Information
This group evaluates the host system and reports if it finds hardware
support for the Pentium Time Stamp Counter. If so, you'll be able to get
a snapshot of it's value along with the microsecond ticks from your
OS clock. The sizes of the hardware and system ticks isn't as important
as the rates that they change. On a Linux system, the system ticks value
represent microseconds of Epoch time.
Timebase Calibration
If your system lacks the TSC or a microsecond resolution system clock,
EpikTimer falls back to using gated measurements for setting the
internal tick frequencies. Timing is non-deterministic when calling
the Linux kernel so some averaging and smoothing of the resulting jitter
is helpful. If EpikTimer is in this mode, long term accuracy isn't
guaranteed... but short term comparitive measurements can still be made.
Pressing "Calibrate" performs overhead extraction and gates the selected
timebase against the best timebase gate available on a given host. The
results are displayed in the memo boxes.
Timebase Correlation
This is the default mode for measuring the TSC frequency and provides a
reliable mechanism for synchronizing the TSC ticks to the system clock.
If the system clock is maintained via NTP and the CorrelateTimebases
method is called at regular intervals, the TSC stream can display the
same long term accuracy (at very high resolutions) as the quality of
the system's synchronizing time source.
Timer/Stopwatch Functions
This section implements a single stopwatch using the component's internal
timer data record. The Spawn Timers group box will bring up the 10 timers
that were created and initialized during program startup.
----------------- End of EpikTimer Release Documentation ------------------