Skip to content

This project uses a machine learning approach in order to predict the number of goals scored by two teams in a match and then calculates the winning team

Notifications You must be signed in to change notification settings

giovannicampa/football_match_results_prediction

Repository files navigation

Football match results predictor

This project uses a machine learning approach to predict the number of goals scored by two teams in a match and then calculates the winning team.

Project structure

The contained files are:

data_preparation.py

Reads the data from the csv files containing the information about every single football match of various seasons. Then it calculates features such as ranking position of the two teams at the moment of the match, average values of scores per match, yellow cards and others

It is called by prediction_model.py and prediction_model_TF.py and only executed if the prepared data has not been already pickled.

One of the calculated features is the instantaneous ranking of the team

prediction_model.py

Predicts the numeric value of goals scored by the two teams. It is divided in two:

1 - A random forest regressor is trained on the dataset, the best parameters found with a grid search and in the end the outcome is translated to winner home team, winner away team or same score. The accuracy of the outcome is then evaluated by comparing the predicted outcome to the real one

2 - Here the most important features indicated by the random forest regressor are found and this information is then used to reduce the feature set. The best parameters for this algorithm are again found with a grid search. The final model, with the best parameters and the most important features is then trained and evaluated on the final result as winner home team, away team or same score.

prediction_model_TF.py

A multi-output neural network build with tensorflow's the Keras API is used to predict the result of the match by predicting the score of each team. Using the reduced set of features that were found at the previous point did not yield any imporovement.

Hyperparameter search

To find the hyperparameters that yield the best accuracy, a grid search has been used.

The values for the hyperparameters are:

Hyperparameter Search range Best value
Neurons per layer [8,16,32,64] 64
Depth [2,4,8] 2
Activation ["relu", "tanh"] "relu"
Batch size [32, 64] 64
Learning rate [0.1, 0.01] 0.01

Custom accuracy score

As the score prediction is a regression problem and does not consider the discrete nature of the match result, a custom accuracy score has been defined (here integer_accuracy). This metric compares the rounded predicted value with the real one (integer).

Callbacks

Besides the tensorboard callback, also a learning rate scheduler and an early stopping callback have been used.

Tensorboard log for loss and custom accuracy score. The effect of early stopping can be seen

Results

The results of the models have to be evaluated by considering the fact that a random guess has an accuracy of 33% (home team wins, away team wins, draw).

Both the classical machine learning and the deep learning model achieve better accuracies than the random guess.

Random forest with optimal parameters has an accuracy of 50%

MLP (sklearn) with optimal parameters and best subset of features has an accuracy of 55%

TF model with optimal parameters and all features has an accuracy of 59%

Confusion matrix for the keras model with the hyperparameter that yield the highest accuracy

About

This project uses a machine learning approach in order to predict the number of goals scored by two teams in a match and then calculates the winning team

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages