-
Notifications
You must be signed in to change notification settings - Fork 0
/
process.js
111 lines (83 loc) · 2.15 KB
/
process.js
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
const fs = require('fs');
const os = require('os');
const path = require('path');
const ROMPTH = /^OMP_NUM_THREADS=(\d+)/m;
const RRESLT = /^\{run=(.+?), thread=(.+?), node=(.+?), core=(.+?), time=(.+?)ms, flops=(.+?)\}/m;
// *-FILE
// ------
function readFile(pth) {
var d = fs.readFileSync(pth, 'utf8');
return d.replace(/\r?\n/g, '\n');
}
function writeFile(pth, d) {
d = d.replace(/\r?\n/g, os.EOL);
fs.writeFileSync(pth, d);
}
// *-CSV
// -----
function writeCsv(pth, rows) {
var cols = Object.keys(rows[0]);
var a = cols.join()+'\n';
for (var r of rows)
a += [...Object.values(r)].map(v => `"${v}"`).join()+'\n';
writeFile(pth, a);
}
// *-LOG
// -----
function readLogLine(ln, data, state) {
ln = ln.replace(/^\d+-\d+-\d+ \d+:\d+:\d+\s+/, '');
if (ROMPTH.test(ln)) {
var [, omp_num_threads] = ROMPTH.exec(ln);
state.omp_num_threads = parseFloat(omp_num_threads);
if (!data.has(state.graph || '')) data.set(state.graph || '', []);
}
else if (RRESLT.test(ln)) {
var [, run, thread, node, core, time, flops] = RRESLT.exec(ln);
data.get(state.graph || '').push(Object.assign({}, state, {
run: parseFloat(run),
thread: parseFloat(thread),
node: parseFloat(node),
core: parseFloat(core),
time: parseFloat(time),
flops: parseFloat(flops),
}));
}
return state;
}
function readLog(pth) {
var text = readFile(pth);
var lines = text.split('\n');
var data = new Map();
var state = {};
for (var ln of lines)
state = readLogLine(ln, data, state);
return data;
}
// PROCESS-*
// ---------
function processCsv(data) {
var a = [];
for (var rows of data.values())
a.push(...rows);
return a;
}
// MAIN
// ----
function main(cmd, log, out) {
var data = readLog(log);
if (path.extname(out)==='') cmd += '-dir';
switch (cmd) {
case 'csv':
var rows = processCsv(data);
writeCsv(out, rows);
break;
case 'csv-dir':
for (var [graph, rows] of data)
writeCsv(path.join(out, graph+'.csv'), rows);
break;
default:
console.error(`error: "${cmd}"?`);
break;
}
}
main(...process.argv.slice(2));