Skip to content

Probabilistic Athlete Performance Evaluation & Ranking Software (V2).

License

Notifications You must be signed in to change notification settings

seanyoon777/PAPERS

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

20 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

PAPERS V2: Probabilistic Athlete Performance Evaluation & Ranking Software V2

Introduction and Motivation

The motivation behind creating this software was mostly to rank individual fencers based on their performance based on rudimentary data. Although there has been a surge in the usage of physiologic and movement data for analyzing athletic performance driven by the growth of the wearable device industry, such technology is not widely available due to cost, and thus there exists vast difficulties in recording and analyzing data.

That justifies half of the motivation. But why fencing? Well, first of all, the 2024 Paris olympics are coming up, and they plan to hold the fencing matches in this beautiful stadium. How could we not talk about fencing?

Ah, I love France.
Ah, I love France.

Also, with COVID striking the world a few years ago, I thought the tech world, one of the sectors hit the hardest by COVID, just have to pay fencing a sort of tribute for being the most sensible sport. Everyone wears masks, gloves, and stabs whoever that doesn't socially distance.

Fencing and COVID.
Fig 1. The intricate relationship between fencing and COVID

So, why not fencing?

Thus, me and my friends had wrote a paper (available HERE) on developing a holistic athlete ranking algorithm, and this software is drawn from this paper. This version, however, contains some updates from the paper to increase usability (memory efficiency, runtime, etc), and model accuracy. Also, while the initial model had been developed to find a time-independent GOAT (Greatest of All Time), this model has undergone some changes to accord greater weight on current performance.

On an additional note, although it had been developed for fencing, it can be used for any individually played sport.

More serious stuff

So, how does the software work? Below is an illustration of the ideas behind the paper.

Model illustration.
Visualization of the Model

Three key ideas behind the paper are: (1) a probability distribution assigned to each athlete to represent performance, (2) a holistic performance indicator for each match, and (3) an iterative observation and non-observation update process.

Firstly, a probability distribution with a Gaussian prior and likelihood is assigned to each athlete to quantify performance, instead of a single value as in most models.

For each match, both athletes are given a "performance indicator," a value bounded between 0 to 2 to assess the performance of the athlete in that match. This indicator takes the athlete's win/loss, score difference, and difficulty of the opponent.

Then, the model undergoes an iterative process to update the probability distributions during each observation process (season, competition, etc) followed by a subsequent non-observation process (caused by non-season, injury, etc). The observation updates are based on a Bayesian model, while the non-observation process is done by decaying the parameters of the probability distributions. This addresses a common challenge in current models, which is that they cannot account for rankings across multiple competitions or seasons.

Usage

The software will return three pdf files in a specified directory, with a randomly generated SLURM-job-id-esque unique_id to avoid confusion:

  • rankings_[unique_id].pdf: The rankings of each athlete and their overall performance indicators.
  • performance_graphs_[unique_id].pdf: The performance graphs for each observation period.
  • performance_values_[unique_id].pdf: The performance values for each athlete across observation periods.

Example Results

This repository also contains two example datasets under the directory 'example_outputs', which are from men's epee Olympic results from 1932 to 2016, and women's foil world championship results from 2014 to 2021 (the women's dataset was from this Kaggle dataset).

As an example, this a ranking of the top 6 athletes in the women's foil world championship results from this model. Medal records are included as a metric for the accuracy of the model.

Rank Athlete Name Average Performance Medal Record
1 Valentina Vezzali 1.72344604894846 🥇x42 🥈x14 🥉x9
2 Luan Jujie 1.66563834581381 🥇x2
3 Kerstin Palm 1.56306080265530 (Seven olympics)
4 Larisa Korobeynikova 1.53342541388233 🥇x7 🥈x10 🥉x5
5 Arianna Errigo 1.52210614397329 🥇x11 🥈x8 🥉x6
6 Katja Wachter 1.49383561355017 🥇x10 🥈x3 🥉x6

Setup

To use the software,

  1. Clone the repository onto your local machine:
git clone [email protected]:seanyoon777/PAPERS.git PAPERS

You can replace the PAPERS with any directory path of your choice.

  1. Now, set up the Conda environment. Most of the requirements are widely used packages, such as scipy or pandas, except fpdf. So run either
conda install -c conda-forge fpdf

or

conda env create -f environment.yml

and run

conda activate papers
  1. Navigate into the current directory.

  2. The input data should be a csv file with seven columns: Year, Player1, Country1, Player2, Country2, Score1, Score2. Year is the year the match had taken place, and Player1 and Player2 is the player name or equivalent uniquely identifiable name. Score1 and Score2 are scores for each player in the given match. Country1 and Country2 should be the country codes for players, although it is only for player identification purposes.

  3. To use the model, run the below command on your terminal:

python main.py -f [directory of your csv file] -d [directory you want the pdf files to be created in]

Acknowledgements

The initial paper was drafted by Sean Yoon, Moonhyuk Chang, Seungwon Yoo, and Seoyoon Park, with equal contribution.

About

Probabilistic Athlete Performance Evaluation & Ranking Software (V2).

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages