AccuRating is a library for accurate player ranking based on match results.
Project description
AccuRating
Library computing accurate ratings based on match results.
Is AccuRating accurate?
Yes. With the same data, AccuRating will return much more accurate ratings than chess ELO or EGD. For instance if a player Leon manages to win against player Caesar, Leon will "get" some X points for that victory. If later Caesar will win against strong players Alusia and EmCee, his rating will increase, but that would not affect Leon's rating in chess or EGD. If we want to use data efficienty Leon's rating should be adjusted because Caesar clearly demonstrated his power and it was not long ago that poor Leon lucked out a victory against Caesar.
EGD, Chess ELO go over the data once, so they have no way of taking that into account. AccuRating shows that we need about 1500 - 2000 passes over the data to converge to accurate ratings.
AccuRating is a variant of Whole-History-Rating, which is also used at https://www.goratings.org/.
Interesting discussion on why WHR is good.
What AccuRating ratings numbers mean exactly?
Only differences matter, i.e. adding say 100 to all the ratings would yield equally valid points.
- 100 AccuRating point difference is 1:2 win odds (33% vs 66%)
- 200 AccuRating point difference is 1:5 win odds (20% vs 80%)
- 300 AccuRating point difference is 1:9 win odds (11% vs 89%)
The exact formula is $P(win) = 1 / (1 + 2^{d / 100})$. Optimization algorithm find ratings that maximize probability of the data.
Compared to Chess ELO
Chess ELO is similar, but the points are rescaled by 1.20412:
- 120.412 chess ELO difference for 1:2 win odds (33% vs 66%)
- 240.824 chess ELO difference for 1:5 win odds (20% vs 80%)
- 361.236 chess ELO difference for 1:9 win odds (11% vs 89%)
The Chess ELO formula is $P(win) = 1 / (1 + 10^{d / 400})$
Compared to EGD
In EGD, winning odds for 100 points of rating is not fixed. This is beacuse: 1 dan/kyu difference = 100 EGD = 1 handicap. The nature of Go is that 1 handicap (i.e. 100 EGD) means more on a dan level than on a kyu level.
On the dan level:
- 90 EGD point difference is approximately 1:2 win odds (33% vs 66%)
- 180 EGD point difference is approximately 1:5 win odds (20% vs 80%)
- 270 EGD point difference is approximately 1:9 win odds (11% vs 89%)
On the kyu level:
- 300 EGD point difference is approximately 1:2 win odds (33% vs 66%)
- 600 EGD point difference is approximately 1:5 win odds (20% vs 80%)
- 900 EGD point difference is approximately 1:9 win odds (11% vs 89%)
If AccuRating is so accurate why other systems are not using it?
Typical ELO systems (like EGD) use every game result only once and update rating based on it. This model can do 1500 passes over the data until it converged (the first pass returns numbers more or less like standard ELO system, equations are almost the same). However so many passes is too expensive when the number of games is as big as EGD.
What it AccuRating bad for?
This system does not have any gamification incentives so it is bad to player motivation. It uses data efficiently and nicely approximates true strength. It can be compared to hidden MMR used for match-making in games like Starcraft 2, not to the player-visible motivating points with various "bonus points".
Model details
The model finds a single number (ELO strength) for each player. Given ELO of two players, the model predicts probability of win in a game: If we assume that $P$ and $Q$ are rankings of two players, the model assumes:
$$P(\text{P vs Q win}) = \frac{2^P}{2^P + 2^Q} = \frac{1}{1 + 2^{Q-P}} $$
This means that if both rankings are equal to $a$, then: $P(win) = \frac{2^a}{2^a+2^a} = 0.5$. If a ranking difference is one point, we have $P(win) = \frac{2^{a+1}}{2^{a+1}+2^{a}} = \frac{2}{2+1}$ Two point adventage yields $P(win) = \frac{1}{5}$ $n$ point adventage yields $P(win) = \frac{1}{1+2^n}$
For readability reasons we rescale the points by 100. This is exactly equivalent to using this equation:
$$ \frac{1}{1 + 2^{\frac{Q-P}{100}}} $$
Comparison to single-pass systems.
In single pass systems, if you play a game, it will not affect the model estimation of your rating yesterday. In multi-pass system we can estimate every player's rating for every season (or even every day). Then iteratively pass over the data again and again until we find rating curves that best fit the data.
There is a parameter that controlls how fast the rating can change. WHR model assumes that player rating is a gaussian process in time, and this parameter is variance of this gaussian process.
The consequence is that data flows both time directions: if you play game in season 20, it will also affect your ratings for season 19 (a bit) and season 18 (very small bit) etc. The data also flows over the whole graph of games and players on each iteration.
Can I convert these ratings to EGD?
Because EGD is using different exponent base, it is not that easy to convert directly. These is a monotonic conversion function but it is non-linear, and it would take some work to derive the formula.
It would be interesting to plot EGD ratings against AccuRating ratings.
What's implemented
This repo implements:
- Implement Bradley-Terry (BT) model for player ranking (better variant of ELO).
- Generalization BT model to a variant of WHR model with time as seasons.
ToDo and ideas
- distribution fit to account for heavy tail
- Chess units
- EGD conversion
- Fit player variance (high variance player can more easily win against stonger players and more easily lose against weaker players)
- Follow this: https://www.marwandebbiche.com/posts/python-package-tooling/
Development
git config --global core.hooksPath .githooks/
git clone https://github.com/lukaszlew/accurating
virtualenv /tmp/venv
source /tmp/venv/bin/activate
pip install poetry
poetry install
poetry run pytest
poetry run mypy .
# edit stuff; increase version
poetry build
poetry publish
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file accurating-0.6.0.tar.gz
.
File metadata
- Download URL: accurating-0.6.0.tar.gz
- Upload date:
- Size: 11.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.11.8 Linux/6.6.15-2rodete2-amd64
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2eba4704bcb8dfb931cde39a6ba8997cb442a046d9d8ff6f3ffde96de3084898 |
|
MD5 | af158b506728e077885e54e13638b245 |
|
BLAKE2b-256 | dd54574f332e45c310f10c78905d69f49e3ebbfa6c56797b5f0175f0e048d84f |
File details
Details for the file accurating-0.6.0-py3-none-any.whl
.
File metadata
- Download URL: accurating-0.6.0-py3-none-any.whl
- Upload date:
- Size: 10.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.11.8 Linux/6.6.15-2rodete2-amd64
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 74398513d514f2a6950fe0d0e0edfcf0fa61a29010d0ef55a4a1f3d124b423ba |
|
MD5 | e372e2e3882bf4f7b9ee00a27d7c0c18 |
|
BLAKE2b-256 | 6fe1b6ac6e03eadfcb2e8fb1134aaca078d1a5ec7e4a4b817a5f825fed5dd589 |