-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathcalculate_overall_accuracy.go
112 lines (98 loc) · 2.5 KB
/
calculate_overall_accuracy.go
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
package main
import (
"fmt"
"math"
"sort"
"github.com/fatih/color"
)
// CLUSTERFUCK AHEAD DO NOT TOUCH
type calculateOverallAccuracyElement struct {
mode int
accuracy *float64
pp *float64
}
func (c calculateOverallAccuracyElement) g() float64 {
return *c.pp
}
type coaeCollection []calculateOverallAccuracyElement
func (c coaeCollection) Swap(i, j int) {
c[i], c[j] = c[j], c[i]
}
func (c coaeCollection) Less(i, j int) bool {
return c[i].g() > c[j].g()
}
func (c coaeCollection) Len() int {
return len(c)
}
// https://git.zxq.co/ripple/old-frontend/src/70faf80910742c9418ed4e4a13a622a6d7cca9cb/inc/functions.php#L1293-L1319
func (c coaeCollection) Weighten() float64 {
var total float64
var divideTotal float64
for i, el := range c {
add := math.Pow(0.95, float64(i)) * 100
total += *el.accuracy * add
divideTotal += add
}
if divideTotal == 0 {
return 0
}
return total / divideTotal
}
type coaeCollectionCollection [4]coaeCollection
func (c *coaeCollectionCollection) Add(n calculateOverallAccuracyElement) error {
if c == nil {
return fmt.Errorf("fuck")
}
c[n.mode] = append(c[n.mode], n)
return nil
}
func opCalculateOverallAccuracy() {
defer wg.Done()
data := make(map[int]*coaeCollectionCollection)
const memeQuery = "SELECT users.id, scores.play_mode, scores.accuracy, scores.pp FROM scores INNER JOIN users ON users.id = scores.userid WHERE completed = '3'"
rows, err := db.Query(memeQuery)
if err != nil {
queryError(err, memeQuery)
return
}
for rows.Next() {
var (
uid int
el calculateOverallAccuracyElement
)
err = rows.Scan(&uid, &el.mode, &el.accuracy, &el.pp)
if err != nil {
queryError(err, memeQuery)
continue
}
// silently ignore invalid modes, and null accuracies which for some
// reason are a thing. i hate our db schema
if el.mode < 0 || el.mode > 3 || el.accuracy == nil || el.pp == nil {
continue
}
if data[uid] == nil {
data[uid] = new(coaeCollectionCollection)
}
data[uid].Add(el)
}
for _, v := range data {
// VARIABLE SHADOWING FTW
for _, v := range v {
sort.Sort(v)
}
}
for userid, info := range data {
var accuracies string
var params []interface{}
for mode, scores := range info {
accuracies += "avg_accuracy_" + modes[mode] + " = ?"
params = append(params, scores.Weighten())
if mode != len(info)-1 {
accuracies += ", "
}
}
params = append(params, userid)
op("UPDATE users_stats SET "+accuracies+" WHERE id = ?", params...)
}
color.Green("> CalculateOverallAccuracy: done!")
}