-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathdata_extraction.py
118 lines (72 loc) · 2.84 KB
/
data_extraction.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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
import pandas
import argparse
import os
from textwrap import dedent
from texttable import Texttable
# Sets the interval for the data we want to look at (1-400):
interval = 20
f = open("log.txt", "w+")
def progressSinceLastInterval(file_seq, path, id, packageNr):
fileNumber = int(file_seq) - interval
fileNumerAsString = str(fileNumber).zfill(8)
if fileNumber > 0:
progressOld = pandas.read_csv(
path + "/progress_dump" + fileNumerAsString + ".dat", delimiter=';')
# print(progressOld)
else:
return
progressNew = pandas.read_csv(
path + "/progress_dump" + file_seq + ".dat", delimiter=';')
if interval>19:
progress = int(progressNew.iloc[id, packageNr]) - \
int(progressOld.iloc[id, packageNr])
return progress
else:
return
def printTable(coord, progress, storage, file_seq, path):
print("--------------------------------------------------------")
print("Looking @ " + file_seq)
print("--------------------------------------------------------")
f.write("\n Looking @ " + file_seq + "\n")
t = Texttable()
t.add_rows(
[['Node ID', 'X', 'Y', 'Storage', 'Progress', '+%(1)', '+%(2)', 'Neighbors']])
A = 0
neighbors = path + "/neighbors_dump" + file_seq + ".dat"
for line in open(neighbors):
neighbors_list = line.rstrip(';\n').split(';')
t.add_row([coord.iloc[A, 0], coord.iloc[A, 1], coord.iloc[A, 2], storage.iloc[A, 1], progress.iloc[
A, :], progressSinceLastInterval(file_seq, path, A, 1), progressSinceLastInterval(file_seq, path, A, 2), neighbors_list])
A += 1
print(t.draw())
f.write(t.draw())
t.reset()
def getCoords(file_seq, path):
coord = pandas.read_csv(path + "/graph_dump" +
file_seq + ".dat", header=None, delimiter=';')
# print(coord)
return coord
def getProgress(file_seq, path):
progress = pandas.read_csv(
path + "/progress_dump" + file_seq + ".dat", delimiter=';')
# print(progress)
return progress
def getStorage(file_seq, path):
storage = pandas.read_csv(
path + "/storage_dump" + file_seq + ".dat", delimiter=';')
# print(storage)
return(storage)
if __name__ == '__main__':
parser = argparse.ArgumentParser(
description='turn datafile into 2d map of nodes')
parser.add_argument('path', type=str, help='path to .dat Files')
args = parser.parse_args()
Files = []
for dat in os.listdir(args.path):
if dat.startswith("graph") and dat.endswith(".dat"):
Files.append(dat.lstrip("graph_dump").rstrip(".dat"))
for seq in sorted(Files):
if int(seq) % interval == 0:
printTable(getCoords(seq, args.path), getProgress(
seq, args.path), getStorage(seq, args.path), seq, args.path)
f.close()