Skip to content

AIFootballPredictions is an ML-based system to predict if a football match will have over 2.5 goals. Using historical data from top European leagues (Serie A, EPL, Bundesliga, La Liga, Ligue 1), it employs advanced feature engineering and model training techniques to provide accurate predictions. Perfect for sports analytics enthusiasts.

License

Notifications You must be signed in to change notification settings

MauroAndretta/AIFootballPredictions

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

68 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

AIFootballPredictions

🎯 AI Football Predictions: Will There Be Over 2.5 Goals? 🎯

Check out the latest predictions for the upcoming football matches! We've analyzed the data and here are our thoughts: PREDICTIONS DONE: 2024-11-30

Premier League:

  • ⚽ Brentford πŸ†š Leicester: Over 2.5 Goals! πŸ”₯ (96.57% chance)
  • ⚽ Crystal Palace πŸ†š Newcastle: Under 2.5 Goals (91.65% chance)
  • ⚽ Nott'm Forest πŸ†š Ipswich: Under 2.5 Goals (63.14% chance)
  • ⚽ Wolves πŸ†š Bournemouth: Over 2.5 Goals! πŸ”₯ (69.71% chance)
  • ⚽ West Ham πŸ†š Arsenal: Under 2.5 Goals (59.36% chance)
  • ⚽ Chelsea πŸ†š Aston Villa: Under 2.5 Goals (73.61% chance)
  • ⚽ Man United πŸ†š Everton: Under 2.5 Goals (54.59% chance)
  • ⚽ Tottenham πŸ†š Fulham: Over 2.5 Goals! πŸ”₯ (64.9% chance)
  • ⚽ Liverpool πŸ†š Man City: Under 2.5 Goals (56.33% chance)

Serie A:

  • ⚽ Como πŸ†š Monza: Over 2.5 Goals! πŸ”₯ (93.78% chance)
  • ⚽ Milan πŸ†š Empoli: Under 2.5 Goals (74.68% chance)
  • ⚽ Bologna πŸ†š Venezia: Over 2.5 Goals! πŸ”₯ (64.23% chance)
  • ⚽ Udinese πŸ†š Genoa: Under 2.5 Goals (89.12% chance)
  • ⚽ Parma πŸ†š Lazio: Under 2.5 Goals (71.56% chance)
  • ⚽ Torino πŸ†š Napoli: Over 2.5 Goals! πŸ”₯ (79.49% chance)
  • ⚽ Fiorentina πŸ†š Inter: Over 2.5 Goals! πŸ”₯ (98.6% chance)
  • ⚽ Lecce πŸ†š Juventus: Under 2.5 Goals (95.58% chance)
  • ⚽ Roma πŸ†š Atalanta: Under 2.5 Goals (91.71% chance)

Bundesliga:

  • ⚽ RB Leipzig πŸ†š Wolfsburg: Under 2.5 Goals (78.68% chance)
  • ⚽ Werder Bremen πŸ†š Stuttgart: Over 2.5 Goals! πŸ”₯ (73.58% chance)
  • ⚽ Freiburg πŸ†š M'gladbach: Over 2.5 Goals! πŸ”₯ (72.36% chance)
  • ⚽ Augsburg πŸ†š Bochum: Over 2.5 Goals! πŸ”₯ (57.97% chance)
  • ⚽ Union Berlin πŸ†š Leverkusen: Under 2.5 Goals (73.08% chance)
  • ⚽ Dortmund πŸ†š Bayern Munich: Over 2.5 Goals! πŸ”₯ (79.3% chance)
  • ⚽ Mainz πŸ†š Hoffenheim: Over 2.5 Goals! πŸ”₯ (76.37% chance)
  • ⚽ Heidenheim πŸ†š Ein Frankfurt: Over 2.5 Goals! πŸ”₯ (64.31% chance)

La Liga:

  • ⚽ Barcelona πŸ†š Las Palmas: Under 2.5 Goals (74.45% chance)
  • ⚽ Alaves πŸ†š Leganes: Under 2.5 Goals (97.74% chance)
  • ⚽ Espanol πŸ†š Celta: Over 2.5 Goals! πŸ”₯ (73.52% chance)
  • ⚽ Valladolid πŸ†š Ath Madrid: Over 2.5 Goals! πŸ”₯ (66.73% chance)
  • ⚽ Villarreal πŸ†š Girona: Over 2.5 Goals! πŸ”₯ (67.72% chance)
  • ⚽ Real Madrid πŸ†š Getafe: Over 2.5 Goals! πŸ”₯ (87.87% chance)
  • ⚽ Vallecano πŸ†š Ath Bilbao: Over 2.5 Goals! πŸ”₯ (90.16% chance)
  • ⚽ Sociedad πŸ†š Betis: Over 2.5 Goals! πŸ”₯ (61.17% chance)
  • ⚽ Sevilla πŸ†š Osasuna: Under 2.5 Goals (94.75% chance)

Ligue 1:

  • ⚽ Rennes πŸ†š St Etienne: Over 2.5 Goals! πŸ”₯ (70.12% chance)
  • ⚽ Brest πŸ†š Strasbourg: Under 2.5 Goals (78.37% chance)
  • ⚽ Paris SG πŸ†š Nantes: Over 2.5 Goals! πŸ”₯ (55.35% chance)
  • ⚽ Montpellier πŸ†š Lille: Over 2.5 Goals! πŸ”₯ (85.69% chance)
  • ⚽ Le Havre πŸ†š Angers: Over 2.5 Goals! πŸ”₯ (93.88% chance)
  • ⚽ Toulouse πŸ†š Auxerre: Over 2.5 Goals! πŸ”₯ (88.96% chance)
  • ⚽ Lyon πŸ†š Nice: Over 2.5 Goals! πŸ”₯ (55.64% chance)
  • ⚽ Marseille πŸ†š Monaco: Over 2.5 Goals! πŸ”₯ (72.71% chance)

Table of Contents

  1. Project Overview
  2. Directory Structure
  3. Setup and Installation
  4. Data Acquisition
  5. Data Preprocessing
  6. Model Training
  7. Upcoming Matches Acquisition
  8. Making Predictions
  9. Supported Leagues
  10. Contributing
  11. License
  12. Disclaimer

Project Overview

AIFootballPredictions aims to create a predictive model to forecast whether a football match will exceed 2.5 goals. The project is divided into four main stages:

  1. Data Acquisition: Download and merge historical football match data from multiple European leagues.
  2. Data Preprocessing: Process the raw data to engineer features, handle missing values, and select the most relevant features.
  3. Model Training: Train several machine learning models, perform hyperparameter tuning, and combine the best models into a voting classifier to make predictions.
  4. Making Predictions: Use the trained models to predict outcomes for upcoming matches and generate a formatted message for sharing.

Directory Structure

The project is organized into the following directories:

└─── `AIFootballPredictions`
    β”œβ”€β”€β”€ `conda`: all the conda environemnts
    β”œβ”€β”€β”€ `data`: the folder for the data
    β”‚       β”œβ”€β”€β”€ `processed`
    β”‚       └─── `raw`
    β”œβ”€β”€β”€ `models`: the folder with the saved and trained models
    β”œβ”€β”€β”€ `notebooks`: all the notebooks if any
    └─── `scripts`: all the python scripts
            β”œβ”€β”€β”€ `data_acquisition.py`
            β”œβ”€β”€β”€ `data_preprocessing.py`
            β”œβ”€β”€β”€ `train_models.py`
            β”œβ”€β”€β”€ `acquire_next_matches.py`
            └─── `make_predictions.py`

Key Scripts

  • data_acquisition.py: Downloads and merges football match data from specified leagues and seasons.
  • data_preprocessing.py: Preprocesses the raw data, performs feature engineering, and selects the most relevant features.
  • train_models.py: Trains machine learning models, performs hyperparameter tuning, and saves the best models.
  • acquire_next_matches.py: Acquires the next football matches data, updates team names using a mapping file, and saves the results to a JSON file.
  • make_predictions.py: Uses the trained models to predict outcomes for upcoming matches and formats the results into a readable txt message.

Note: it is suggested to avoid path error, to execute all the scripts in the root folder.

Setup and Installation

To set up the environment for this project, follow these steps:

  1. Clone the repository:

    git clone https://github.com/yourusername/AIFootballPredictions.git
    cd AIFootballPredictions
  2. Create a conda environment

    conda env create -f conda/aifootball_predictions.yaml
    conda activate aifootball_predictions

Data Acquisition

To download and merge football match data, run the data_acquisition.py script:

python scripts/data_acquisition.py --leagues E0 I1 SP1 F1 D1 --seasons 2425 2324 2223 --raw_data_output_dir data/raw

This script downloads match data from football-data.co.uk for the specified leagues and seasons, merges them, and saves the results to the specified output directory.

To avoid error please see the Supported Leagues sections.

Data Preprocessing

Once the raw data is downloaded, preprocess it by running the data_preprocessing.py script:

python scripts/data_preprocessing.py --raw_data_input_dir data/raw --processed_data_output_dir data/processed --num_features 20 --clustering_threshold 0.5

This script processes each CSV file in the input folder, performs feature engineering, selects relevant features while addressing feature correlation, handles missing values, and saves the processed data.

Model Training

To train machine learning models and create a voting classifier, use the train_models.py script:

python scripts/train_models.py --processed_data_input_dir data/processed --trained_models_output_dir models --metric_choice accuracy --n_splits 10 --voting soft

This script processes each CSV file individually, trains several machine learning models, performs hyperparameter tuning, combines the best models into a voting classifier, and saves the trained voting classifier for each league.

Upcoming Matches Acquisition

To acquire the next football matches data and update the team names, run the acquire_next_matches.py script:

python scripts/acquire_next_matches.py --get_teams_names_dir data/processed --next_matches_output_file data/next_matches.json

This script will:

  • Fetch the next matches data from the football-data.org API.
  • Read the unique team names from the processed data files.
  • Update the team names in the next matches data using the mapping file.
  • Save the updated next matches to a JSON file.

Setu up the API_KEY

In order to properly execute the acquire_next_matches.py script it is first necessary to set up the API_KEY to gather the next matches information. Below the procedure on how to properly set up the variable:

  1. Register for an API Key:

  2. Create a ~/.env File:

    • This file will be used by the load_dotenv library to set up the API_FOOTBALL_DATA environment variable.
    • To create the file:
      • Open your terminal and run the command: vim ~/.env
      • This will create a new ~/.env file if it doesn't already exist.
  3. Insert the API Key:

    • After running the vim command, press the i key (for "insert mode").
    • Write down the following line, replacing your_personal_key with your actual API key:
      • API_FOOTBALL_DATA=your_personal_key
  4. Save and Exit:

    • Press the Esc key to exit insert mode.
    • Then, type :wq! and press Enter to save the changes and exit the editor.
  5. Verify the Variable:

    • To check if the variable has been properly set, run the following command from the terminal:
      • cat ~/.env
    • You should see the API_FOOTBALL_DATA variable listed with your API key.

Making Predictions

To predict the outcomes for upcoming matches and generate a formatted message for sharing, run the make_predictions.py script:

python scripts/make_predictions.py --models_dir models --data_dir data/processed --output_file final_predictions.txt --json_competitions data/next_matches.json

This script will:

  • Load the pre-trained models and the processed data.
  • Make predictions for upcoming matches based on the next matches data.
  • Format the predictions into a redable .txt message and save it to the specified output file.

Supported Leagues

For the moment, the team name mapping has been done manually. The predictions currently support the following leagues:

  • Premier League: E0
  • Serie A: I1
  • Ligue 1: F1
  • La Liga (Primera Division): SP1
  • Bundesliga: D1

For this reason be carful when executing the data acquisition step.

Contributing

If you want to contribute to this project, please fork the repository and submit a pull request. For major changes, please open an issue first to discuss what you would like to change.

License

This project is licensed under the BSD-3-Claude license - see the LICENSE file for details.

Disclaimer

This project is intended for educational and informational purposes only. While the AIFootballPredictions system aims to provide accurate predictions for football matches, it is important to understand that predictions are inherently uncertain and should not be used as the sole basis for any decision-making, including betting or financial investments.

The predictions generated by this system can be used as an additional tool during the decision-making process. However, they should be considered alongside other factors and sources of information.

The authors of this project do not guarantee the accuracy, reliability, or completeness of any information provided. Use the predictions at your own risk, and always consider the unpredictability of sports events.

By using this software, you agree that the authors and contributors are not responsible or liable for any losses or damages of any kind incurred as a result of using the software or relying on the predictions made by the system.

About

AIFootballPredictions is an ML-based system to predict if a football match will have over 2.5 goals. Using historical data from top European leagues (Serie A, EPL, Bundesliga, La Liga, Ligue 1), it employs advanced feature engineering and model training techniques to provide accurate predictions. Perfect for sports analytics enthusiasts.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published