forked from lichess-org/lila
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhistory2.js
52 lines (48 loc) · 1.32 KB
/
history2.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
var batchSize = 20000;
var collection = db.history;
var games = db.game4.find(
{'p.ed':{$exists:true}},
{'p.elo': true, 'p.ed': true, 'p.uid': true, 'ca': true}
).sort({ca: 1});
var dat = new Date().getTime() / 1000, it = 0;
print("Counting games...");
var max = games.count();
print("Migrating " + max + " games to user histories");
collection.drop();
function flush(cache) {
for(uid in cache) {
collection.update({_id: uid}, {$pushAll: { entries: cache[uid] }}, {upsert: true});
}
}
var cache = {};
games.forEach(function(game) {
for (pi in game.p) {
try {
var p = game.p[pi], op = game.p[1 - pi];
var entry = [
parseInt(game.ca.getTime() / 1000),
parseInt(p.elo + p.ed),
parseInt(op.elo)
];
if(typeof cache[p.uid] == "undefined") cache[p.uid] = [entry];
else cache[p.uid].push(entry);
} catch(e) {
print("game " + game._id + " => " + e);
}
}
++it;
if (it % batchSize == 0) {
if (it % (batchSize * 7) == 0) {
print("FLUSH");
flush(cache);
cache = {};
}
var percent = Math.round((it / max) * 100);
var dat2 = new Date().getTime() / 1000;
var perSec = Math.round(batchSize / (dat2 - dat));
dat = dat2;
print((it / 1000) + "k " + percent + "% " + perSec + "/s");
}
});
print("FLUSH");
flush(cache);