Timer
structure
signature TIMER
structure Timer
:> TIMER
The Timer
structure provides facilities for measuring the passing of wall clock (real) time and the amount of time the running process has had the CPU (user time), has been active in the OS kernel (system time), and has spent on garbage collection (GC time).
type cpu_timer
type real_timer
val startCPUTimer : unit -> cpu_timer
val checkCPUTimes : cpu_timer
-> {
nongc : {
usr : Time.time,
sys : Time.time
},
gc : {
usr : Time.time,
sys : Time.time
}
}
val checkCPUTimer : cpu_timer
-> {usr : Time.time, sys : Time.time}
val checkGCTime : cpu_timer -> Time.time
val totalCPUTimer : unit -> cpu_timer
val startRealTimer : unit -> real_timer
val checkRealTimer : real_timer -> Time.time
val totalRealTimer : unit -> real_timer
type cpu_timer
type real_timer
real_timer
is the type of wall clock (real) timers, and cpu_timer
is the type of CPU timers.
val startCPUTimer : unit -> cpu_timer
checkCPUTimes timer
nongc
) and time spent in the garbage collector (gc
). For each of these categories, the time is further split into time spent by code in user space (usr
) and time spent in the operating system on behalf of the program (sys
). The total CPU time used by the program will be the sum of these four values.
checkCPUTimer timer
usr
) and system time (sys
) that have accumulated since the timer timer was started. This function is equivalent to
fun checkCPUTimer ct = let val {nongc, gc} = checkCPUTimes ct in { usr = Time.+(#usr nongc, #usr gc), sys = Time.+(#sys nongc, #sys gc) } end
checkGCTime timer
fun checkGCTime ct = #usr(#gc(checkCPUTimes ct))
val totalCPUTimer : unit -> cpu_timer
val startRealTimer : unit -> real_timer
checkRealTimer rt
val totalRealTimer : unit -> real_timer
Time
The accuracy of the user, system, and GC times depends on the resolution of the system timer and the function call overhead in the OS interface. In particular, very small intervals might not be reported accurately.
On a Unix system, the user and system time reported by a CPU timer do not include the time spent in child processes.
Implementation note:
Some operating systems may lack the ability to measure CPU time consumption, in which case the real time should be returned instead.
Generated April 12, 2004
Last Modified October 31, 1997
Comments to John Reppy.
This document may be distributed freely over the internet as long as the copyright notice and license terms below are prominently displayed within every machine-readable copy.
Copyright © 2004 AT&T and Lucent Technologies. All rights reserved.
Permission is granted for internet users to make one paper copy for their
own personal use. Further hardcopy reproduction is strictly prohibited.
Permission to distribute the HTML document electronically on any medium
other than the internet must be requested from the copyright holders by
contacting the editors.
Printed versions of the SML Basis Manual are available from Cambridge
University Press.
To order, please visit
www.cup.org (North America) or
www.cup.cam.ac.uk (outside North America). |