-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathExperimentTrack.py
More file actions
60 lines (48 loc) · 1.77 KB
/
ExperimentTrack.py
File metadata and controls
60 lines (48 loc) · 1.77 KB
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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
#!/usr/bin/env python2
import atexit
from datetime import datetime, timedelta
import json
import os
import shutil
import time
class ExperimentTrack(object):
def __init__(self, dataBaseDir, trialInfo, save):
timestamp = datetime.today().strftime('%Y_%m_%d_%H_%M_%S')
self.dataDir = os.path.join(dataBaseDir, timestamp)
self.save = save
self.starttime = int(time.time())
if self.save and not os.path.exists(self.dataDir):
print "Saving experiment data in: %s\n" % self.dataDir
# create directory
os.makedirs(self.dataDir)
# save trial info
with open(os.path.join(self.dataDir, 'TRIAL_INFO.txt'), 'w') as f:
f.write('\n'.join(trialInfo) + '\n')
self.cleanExit = False
def exitFunc():
# cleanup directory on failure exit
if not self.cleanExit:
shutil.rmtree(self.dataDir)
return
# add runtime to the trial info
runtime = int(time.time()) - self.starttime
t = timedelta(seconds=runtime)
d = datetime(1,1,1) + t
timeString = ("%02d:%02d:%02d:%02d" %
(d.day-1, d.hour, d.minute, d.second))
with open(os.path.join(self.dataDir, 'TRIAL_INFO.txt'), 'a') as f:
f.write('\nRuntime (DD:HH:MM:SS): %s\n' % timeString)
atexit.register(exitFunc)
def getDirName(self):
return self.dataDir
def setCleanExit(self):
self.cleanExit = True
def dumpData(self, data):
if not self.save:
return
with open(os.path.join(self.dataDir, 'DATA.json'), 'w') as f:
json.dump(data, f, indent=2)
@staticmethod
def loadData(filePath):
with open(filePath) as f:
return json.load(f)