]> git.saurik.com Git - wxWidgets.git/blame - wxPython/wxSWIG/swig_lib/timers.i
My RPM spec now uses the --enable-rpath
[wxWidgets.git] / wxPython / wxSWIG / swig_lib / timers.i
CommitLineData
c90f71dd
RD
1//
2// $Header$
3//
4// timers.i
5// A SWIG file for adding various timing functions.
6// Really, this is modeled after the timers in the CMMD
7// message passing library for the CM-5.
8//
9// Dave Beazley
10// April 2, 1996
11//
12/* Revision history
13 * $Log$
14 * Revision 1.1 2002/04/29 19:56:49 RD
15 * Since I have made several changes to SWIG over the years to accomodate
16 * special cases and other things in wxPython, and since I plan on making
17 * several more, I've decided to put the SWIG sources in wxPython's CVS
18 * instead of relying on maintaining patches. This effectivly becomes a
19 * fork of an obsolete version of SWIG, :-( but since SWIG 1.3 still
20 * doesn't have some things I rely on in 1.1, not to mention that my
21 * custom patches would all have to be redone, I felt that this is the
22 * easier road to take.
23 *
24 * Revision 1.1.1.1 1999/02/28 02:00:53 beazley
25 * Swig1.1
26 *
27 * Revision 1.1 1996/05/22 17:27:01 beazley
28 * Initial revision
29 *
30 */
31
32%module timers
33%{
34
35#include <time.h>
36#define SWIG_NTIMERS 64
37
38static clock_t telapsed[SWIG_NTIMERS];
39static clock_t tstart[SWIG_NTIMERS];
40static clock_t tend[SWIG_NTIMERS];
41
42/*-----------------------------------------------------------------
43 * SWIG_timer_clear(int i)
44 *
45 * Clears timer i.
46 *----------------------------------------------------------------- */
47
48void
49SWIG_timer_clear(int i)
50{
51 if ((i >= 0) && (i < SWIG_NTIMERS))
52 telapsed[i] = 0;
53}
54
55
56/*-----------------------------------------------------------------
57 * SWIG_timer_start(int i)
58 *
59 * Starts timer i
60 *----------------------------------------------------------------- */
61
62void
63SWIG_timer_start(int i)
64{
65 if ((i >= 0) && (i < SWIG_NTIMERS))
66 tstart[i] = clock();
67}
68
69
70/*-----------------------------------------------------------------
71 * SWIG_timer_stop(int i)
72 *
73 * Stops timer i and accumulates elapsed time
74 *----------------------------------------------------------------- */
75
76void
77SWIG_timer_stop(int i)
78{
79 if ((i >= 0) && (i < SWIG_NTIMERS)) {
80 tend[i] = clock();
81 telapsed[i] += (tend[i] - tstart[i]);
82 }
83}
84
85/*-----------------------------------------------------------------
86 * SWIG_timer_elapsed(int i)
87 *
88 * Returns the time elapsed on timer i in seconds.
89 *----------------------------------------------------------------- */
90
91double
92SWIG_timer_elapsed(int i)
93{
94 double t;
95 if ((i >= 0) && (i < SWIG_NTIMERS)) {
96 t = (double) telapsed[i]/(double) CLOCKS_PER_SEC;
97 return(t);
98 } else {
99 return 0;
100 }
101}
102
103%}
104
105%section "Timer Functions",pre,after,chop_left=3,nosort,info,chop_right = 0, chop_top=0,chop_bottom=0
106
107%text %{
108%include timers.i
109
110This module provides a collection of timing functions designed for
111performance analysis and benchmarking of different code fragments.
112
113A total of 64 different timers are available. Each timer can be
114managed independently using four functions :
115
116 timer_clear(int n) Clears timer n
117 timer_start(int n) Start timer n
118 timer_stop(int n) Stop timer n
119 timer_elapsed(int n) Return elapsed time (in seconds)
120
121All timers measure CPU time.
122
123Since each timer can be accessed independently, it is possible
124to use groups of timers for measuring different aspects of code
125performance. To use a timer, simply use code like this :
126%}
127
128#if defined(SWIGTCL)
129%text %{
130 timer_clear 0
131 timer_start 0
132 .. a bunch of Tcl code ...
133 timer_stop 0
134 puts "[timer_elapsed 0] seconds of CPU time"
135%}
136#elif defined(SWIGPERL)
137%text %{
138 timer_clear(0);
139 timer_start(0);
140 .. a bunch of Perl code ...
141 timer_stop(0);
142 print timer_elapsed(0)," seconds of CPU time\n";
143%}
144#elif defined(SWIGPYTHON)
145%text %{
146 timer_clear(0)
147 timer_start(0)
148 ... a bunch of Python code ...
149 timer_stop(0)
150 print timer_elapsed(0)," seconds of CPU time"
151%}
152#endif
153
154%text %{
155A single timer can be stopped and started repeatedly to provide
156a cummulative timing effect.
157
158As a general performance note, making frequent calls to the timing
159functions can severely degrade performance (due to operating system
160overhead). The resolution of the timers may be poor for extremely
161short code fragments. Therefore, the timers work best for
162computationally intensive operations.
163%}
164
165
166%name(timer_clear) void SWIG_timer_clear(int n);
167/* Clears timer n. */
168
169%name(timer_start) void SWIG_timer_start(int n);
170/* Starts timer n. */
171
172%name(timer_stop) void SWIG_timer_stop(int n);
173/* Stops timer n. */
174
175%name(timer_elapsed) double SWIG_timer_elapsed(int n);
176/* Return the elapsed time (in seconds) of timer n */
177
178
179
180