-
Notifications
You must be signed in to change notification settings - Fork 23
/
Copy pathirtt_sleep.go
42 lines (39 loc) · 993 Bytes
/
irtt_sleep.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
package irtt
import (
"time"
)
func runSleep(args []string) {
printf("Testing sleep accuracy...")
printf("")
durations := []time.Duration{1 * time.Nanosecond,
10 * time.Nanosecond,
100 * time.Nanosecond,
1 * time.Microsecond,
10 * time.Microsecond,
100 * time.Microsecond,
1 * time.Millisecond,
10 * time.Millisecond,
100 * time.Millisecond,
200 * time.Millisecond,
500 * time.Millisecond,
}
printf("Sleep Duration Mean Error %% Error")
for _, d := range durations {
iterations := int(2 * time.Second / d)
if iterations < 5 {
iterations = 5
}
errTotal := time.Duration(0)
start0 := time.Now()
i := 0
for ; i < iterations && time.Since(start0) < 2*time.Second; i++ {
start := time.Now()
time.Sleep(d)
elapsed := time.Since(start)
errTotal += (elapsed - d)
}
errorNs := float64(errTotal) / float64(i)
percentError := 100 * errorNs / float64(d)
printf("%14s%18s%14.1f", d, time.Duration(errorNs), percentError)
}
}