diff options
author | Sandro Tosi <sandro.tosi@gmail.com> | 2012-04-24 16:11:46 (GMT) |
---|---|---|
committer | Sandro Tosi <sandro.tosi@gmail.com> | 2012-04-24 16:11:46 (GMT) |
commit | e6c34626073c905f072e7e2910d4d75c95668c10 (patch) | |
tree | 3dcae756552dbdf66c4df1ea6250f735299fcc60 /Doc/library/timeit.rst | |
parent | 08ccbf4be98c8574e30c6d94c03c2ef9aef31a2c (diff) | |
download | cpython-e6c34626073c905f072e7e2910d4d75c95668c10.zip cpython-e6c34626073c905f072e7e2910d4d75c95668c10.tar.gz cpython-e6c34626073c905f072e7e2910d4d75c95668c10.tar.bz2 |
Issue #13478: document timeit.default_timer()
Diffstat (limited to 'Doc/library/timeit.rst')
-rw-r--r-- | Doc/library/timeit.rst | 24 |
1 files changed, 16 insertions, 8 deletions
diff --git a/Doc/library/timeit.rst b/Doc/library/timeit.rst index 0112994..cd2d205 100644 --- a/Doc/library/timeit.rst +++ b/Doc/library/timeit.rst @@ -99,7 +99,19 @@ The module defines the following public class: timeit.Timer('for i in range(10): oct(i)', 'gc.enable()').timeit() -The module also defines two convenience functions: +The module also defines three convenience functions: + + +.. function:: default_timer() + + Define a default timer, in a platform specific manner. On Windows, + :func:`time.clock` has microsecond granularity but :func:`time.time`'s + granularity is 1/60th of a second; on Unix, :func:`time.clock` has 1/100th of + a second granularity and :func:`time.time` is much more precise. On either + platform, :func:`default_timer` measures wall clock time, not the CPU + time. This means that other processes running on the same computer may + interfere with the timing. + .. function:: repeat(stmt='pass', setup='pass', timer=<default timer>, repeat=3, number=1000000) @@ -161,13 +173,9 @@ similarly. If :option:`-n` is not given, a suitable number of loops is calculated by trying successive powers of 10 until the total time is at least 0.2 seconds. -The default timer function is platform dependent. On Windows, -:func:`time.clock` has microsecond granularity but :func:`time.time`'s -granularity is 1/60th of a second; on Unix, :func:`time.clock` has 1/100th of a -second granularity and :func:`time.time` is much more precise. On either -platform, the default timer functions measure wall clock time, not the CPU time. -This means that other processes running on the same computer may interfere with -the timing. The best thing to do when accurate timing is necessary is to repeat +:func:`default_timer` measurations can be affected by other programs running on +the same machine, so +the best thing to do when accurate timing is necessary is to repeat the timing a few times and use the best time. The :option:`-r` option is good for this; the default of 3 repetitions is probably enough in most cases. On Unix, you can use :func:`time.clock` to measure CPU time. |