-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmarkovpredict.js
More file actions
75 lines (63 loc) · 1.4 KB
/
Copy pathmarkovpredict.js
File metadata and controls
75 lines (63 loc) · 1.4 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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
function markovPredictNextHat(p) {
let ph = p.pastHats;
let tm = {};
for (let i = 0; i < ph.length - 1; i++) {
let cs = ph[i];
let ns = ph[i + 1];
let csKey = JSON.stringify({
h: cs.skin,
t: cs.tail,
s: cs.shame,
p: cs.pr,
r: cs.sr,
tr: cs.tr,
it: cs.inTrap,
spd: cs.speed
});
let nsKey = JSON.stringify({
h: ns.skin,
t: ns.tail,
s: ns.shame,
p: ns.pr,
r: ns.sr,
tr: ns.tr,
it: ns.inTrap,
spd: ns.speed
});
if (!tm[csKey]) {
tm[csKey] = {};
}
if (!tm[csKey][nsKey]) {
tm[csKey][nsKey] = 0;
}
tm[csKey][nsKey]++;
}
let rs = ph[ph.length - 1];
let rsKey = JSON.stringify({
h: rs.skin,
t: rs.tail,
s: rs.shame,
p: rs.pr,
r: rs.sr,
tr: rs.tr,
it: rs.inTrap,
spd: rs.speed
});
if (!tm[rsKey]) {
return -1;
}
let nsKey = -1;
let maxC = 0;
for (let sk in tm[rsKey]) {
let count = tm[rsKey][sk];
if (count > maxC) {
nsKey = sk;
maxC = count;
}
}
if (nsKey !== -1) {
let ns = JSON.parse(nsKey);
return ns.h;
}
return -1;
}