forked from simulationcraft/simc
-
Notifications
You must be signed in to change notification settings - Fork 0
/
measure_cpu_time.py
40 lines (32 loc) · 1.43 KB
/
measure_cpu_time.py
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
#!/usr/bin/python
import sys
import subprocess
import math
import numpy as np
import xml.etree.ElementTree as ET
def main():
simc_bin = "../engine/simc"
# profile_dir="../profiles/Tier16H/"
name = "Raid_T18M"
profile = name + ".simc"
extra_options = "deterministic=1"
threads = 1
output_dir = "/home/sc/tmp/"
iterations = 100
num_repetitions = 20
list_cpu_seconds = []
for repetition in range(num_repetitions):
command = "{bin} {profile} {eo} iterations={iterations} threads={threads} output={output} xml={xml}".format(bin=simc_bin, profile=profile, eo=extra_options, iterations=iterations, threads=threads, output=output_dir + profile + ".txt", xml=output_dir + profile + ".xml")
command = command.split(" ")
print("Calling cmd={}".format(command))
subprocess.call(command)
tree = ET.parse(output_dir + profile + ".xml")
root = tree.getroot()
cpu_seconds = float(root.find("performance").find("cpu_seconds").text)
print("Done simulation #{n} of {rep} with iterations={it}: cpu_seconds={t}".format(n=(repetition + 1), rep=num_repetitions, it=iterations, t=cpu_seconds))
list_cpu_seconds.append(cpu_seconds)
print("mean: %s" % (np.mean(list_cpu_seconds)))
print("stddev: %s" % (np.std(list_cpu_seconds)))
print("stddev/sqrt(N): %s" % (np.std(list_cpu_seconds) / math.sqrt(num_repetitions)))
if __name__ == "__main__":
main()