AIrsenal is a package for using Machine learning to pick a Fantasy Premier League team.
For some background information and details see https://www.turing.ac.uk/research/research-programmes/research-engineering/programme-articles/airsenal.
We have made a mini-league "Prem-AI League" for players using this software. To join, login to the FPL website, and navigate to the page to join a league: https://fantasy.premierleague.com/leagues then click "Join a League". The code to join is: xoz7vm. Hope to see your AI team there!! :)
Our own AIrsenal team's ID for the 2025/26 season is 742663.
jaxlib, AIrsenal doesn't work on Python 3.13 or later.
We recommend using uv for managing Python versions and dependencies. For instructions on how to install uv, go to: https://docs.astral.sh/uv/getting-started/installation/.
With uv (recommended):
git clone https://github.com/alan-turing-institute/AIrsenal.git
cd AIrsenal
uv syncWith pip:
If not using uv you can replace uv sync with pip install . above, but we recommend you do so in a virtual environment, e.g.
git clone https://github.com/alan-turing-institute/AIrsenal.git
cd AIrsenal
python -m venv .venv
source .venv/bin/activate
pip install .The best ways to run AIrsenal on Windows are either to use Windows Subsystem for Linux (WSL), which allows you to run AIrsenal in a Linux environment on your Windows system, or Docker (see below).
You can then follow the installation instructions for Linux and macOS above.
You're free to try installing and using AIrsenal in Windows itself, but so far we haven't got it working. The main difficulties are with installing jax and some database/pickling errors (e.g. #165). If you do get it working we'd love to hear from you!
Rather than building and running natively on your machine, you can instead use a Docker image if you prefer.
Build the docker-image:
$ docker build -t airsenal .Create a volume for data persistance:
$ docker volume create airsenal_dataRun commands with your configuration as environment variables, eg:
$ docker run -it --rm -v airsenal_data:/tmp/ -e "FPL_TEAM_ID=<your_id>" -e "AIRSENAL_HOME=/tmp" airsenal bashor
$ docker run -it --rm -v airsenal_data:/tmp/ -e "FPL_TEAM_ID=<your_id>" -e "AIRSENAL_HOME=/tmp" airsenal airsenal_run_pipelineairsenal_run_pipeline is the default command.
You can now do pip install airsenal in your Python virtual environment of choice, and it should work out-of-the-box, allowing you to run all the airsenal_* commands listed in the Getting Started section.
We will aim to keep the version on PyPi relatively up-to-date, but if you want the very latest developments, they will appear first in Github (on the develop branch if you're feeling brave, or main if you want a more stable version), which would require building from source
AIrsenal has optional dependencies for plotting, running notebooks, and an in development AIrsenal API. To install them run:
- With uv: uv sync --all-extras
- Without uv: pip install ".[api,notebook,plot]"
If using AIrsenal with uv you must either prepend uv run to all the AIrsenal commands below (e.g. uv run airsenal_setup_initial_db), or activate the virtual environment created by uv and then run them as normal. By default the virtual environment can be activated with source .venv/bin/activate.
Once you've installed the module, you will need to set the following parameters:
Required:
- FPL_TEAM_ID: the team ID for your FPL side.
Recommended:
- 
FPL_LOGIN: your FPL login, usually email (this is required to get any changes made to your team since the last gameweek deadline).
- 
FPL_PASSWORD: your FPL password (this is required to get any changes made to your team since the last gameweek deadline).
Optional:
- 
FPL_LEAGUE_ID: a league ID for FPL (this is only required for plotting FPL league standings).
- 
AIRSENAL_DB_FILE: Local path to where you would like to store the AIrsenal sqlite3 database. If not setAIRSENAL_HOME/data.dbwill be used by default.
The values for these should be defined either in environment variables with the names given above, or as files in AIRSENAL_HOME (a directory AIrsenal creates on your system to save config files and the database).
To view the location of AIRSENAL_HOME and the current values of all set AIrsenal environment variables run:
airsenal_env getUse airsenal_env set to set values and store them for future use. For example:
airsenal_env set -k FPL_TEAM_ID -v 123456See airsenal_env --help for other options.
Note: Most the commands below can be run with the --help flag to see additional options and information.
The easiest way to run AIrsenal is to use the pipeline script:
airsenal_run_pipelineThis will create or update the database, compute points predictions, and suggest transfers.  Add --help to see the available options, by default predictions and transfers are calculated for the next 3 gameweeks.
Alternatively, you can run each step of AIrsenal independently, as follows:
Run the following command to create the AIrsenal database:
airsenal_setup_initial_dbThis will fill the database with data from the last 3 seasons, as well as all available fixtures and results for the current season.
Once the database has been created, you just need to update it each time before you run predictions or optimisations. This pulls all the latest data from the FPL API, such as recent match results, changes to fixtures, new players, and player injury/suspension statuses.
airsenal_update_dbThe next step is to predict the expected points for all players for the next fixtures. Player points predictions are computed using two models, a team-level model to predict match scorelines, and a player level model to predict player goal involvements, as well as several heuristics based on historical averages.
This is done using the command
airsenal_run_prediction --weeks_ahead 3Predicting the next 3 gameweeks of fixtures is the default but this can be configured with the argument above.
Finally, we need to run the optimizer to pick the best transfer strategy over the next weeks (and hence the best team for the next week).
airsenal_run_optimization --weeks_ahead 3This will take a while, but should eventually provide a printout of the optimal transfer strategy, in addition to the teamsheet for the next match (including who to make captain, and the order of the substitutes). You can also optimise chip usage with the arguments  --wildcard_week <GW>, --free_hit_week <GW>, --triple_captain_week <GW> and --bench_boost_week <GW>, replacing <GW> with the gameweek you want to play the chip (or use 0 to try playing the chip in all gameweeks).
Note that airsenal_run_optimization should only be used for transfer suggestions after the season has started. If it's before the season has started and you want to generate a full squad for gameweek one you should instead use:
airsenal_make_squad --num_gameweeks 3Note that you must have set FPL_LOGIN and FPL_PASSWORD for these to work (as described in the "Configuration" section above).
To apply the transfers recommended by AIrsenal to your team on the FPL website run airsenal_make_transfers.
- 🚨 This can't be undone and may incur points hits! 🚨 Also, this command can't currently apply chips such as "free hit" or "wildcard", even if those were specified in the airsenal_run_optimizationstep. If you do want to use this command to apply the transfers anyway, you can play the chip at any time before the gameweek deadline via the FPL website.
You can also use airsenal_set_lineup to set your starting lineup, captaincy choices, and substitute order to AIrsenal's recommendation (without making any transfers).
AIrsenal is regularly developed to fix bugs and add new features. If you have any problems during installation or usage please let us know by creating an issue (or have a look through existing issues to see if it's something we're already working on).
You may also like to try the development version of AIrsenal, which has the latest fixes and features. To do this checkout the develop branch of the repo and reinstall:
git checkout develop
git pull
uv sync  # or "pip install --force-reinstall ." if not using uvIf there have been database changes you may also need to run airsenal_setup_initial_db --clean after the above.
We welcome all types of contribution to AIrsenal, for example questions, documentation, bug fixes, new features and more. Please see our contributing guidelines. If you're contributing for the first time but not sure what to do a good place to start may be to look at our current issues, particularly any with the "Good first issue" tag. Also feel free to just say hello!
If you're developing AIrsenal we further recommend using uv.
We also have a pre-commit config to run the code quality tools we use automatically when making commits. To setup the commit hooks run:
pre-commit install --install-hooksAnd tests can be run with
pytest airsenal/tests