-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathreporter.go
46 lines (36 loc) · 1.08 KB
/
reporter.go
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
package parallel
//#include <time.h>
import "C"
import "time"
// reporter types report the amount of CPU usage between the current and last
// call to the usage method.
type reporter struct {
lastTime time.Time
lastTick C.clock_t
}
// MARK: Initializers
// newReporter creates and returns a new CPU reporter.
func newReporter() *reporter {
return &reporter{
lastTime: time.Now(),
lastTick: C.clock(),
}
}
// MARK: Public methods
// usage returns the decimal percent of CPU usage used by the process. If this
// is the first time to call this method, then the usage reported will be
// calculated between this call and the last call to reset (or instantiation).
func (r *reporter) usage() float64 {
nowClock := C.clock()
nowActual := time.Now()
clockSeconds := float64(nowClock-r.lastTick) / float64(C.CLOCKS_PER_SEC)
r.lastTick = nowClock
actualSeconds := nowActual.Sub(r.lastTime).Seconds()
r.lastTime = nowActual
return clockSeconds / actualSeconds
}
// Reset resets the reporter's last time and tick.
func (r *reporter) reset() {
r.lastTime = time.Now()
r.lastTick = C.clock()
}