penaltyblog.models.DixonColesGoalModel#

class penaltyblog.models.DixonColesGoalModel(goals_home: Sequence[int] | ndarray[Any, dtype[int64]] | Series, goals_away: Sequence[int] | ndarray[Any, dtype[int64]] | Series, teams_home: Sequence[str] | ndarray[Any, dtype[str_]] | Series, teams_away: Sequence[str] | ndarray[Any, dtype[str_]] | Series, weights: float | Sequence[float] | ndarray[Any, dtype[float64]] | Series | None = None)[source]#

Bases: BaseGoalsModel

Dixon and Coles adjusted Poisson model for predicting outcomes of football (soccer) matches

fit()[source]#

fits a Dixon and Coles adjusted Poisson model to the data to calculate the team strengths. Must be called before the model can be used to predict game outcomes

predict(home_team, away_team, max_goals=15)[source]#

predict the outcome of a football (soccer) game between the home_team and away_team

get_params()[source]#

Returns the fitted parameters from the model

__init__(goals_home: Sequence[int] | ndarray[Any, dtype[int64]] | Series, goals_away: Sequence[int] | ndarray[Any, dtype[int64]] | Series, teams_home: Sequence[str] | ndarray[Any, dtype[str_]] | Series, teams_away: Sequence[str] | ndarray[Any, dtype[str_]] | Series, weights: float | Sequence[float] | ndarray[Any, dtype[float64]] | Series | None = None)[source]#

Dixon and Coles adjusted Poisson model for predicting outcomes of football (soccer) matches

Parameters:
  • goals_home (array_like) – The number of goals scored by the home team in each match

  • goals_away (array_like) – The number of goals scored by the away team in each match

  • teams_home (array_like) – The name of the home team in each match

  • teams_away (array_like) – The name of the away team in each match

  • weights (array_like, optional) – The weight of each match, by default None

Methods

__init__(goals_home, goals_away, teams_home, ...)

Dixon and Coles adjusted Poisson model for predicting outcomes of football (soccer) matches

fit()

Fits the model to the data and calculates the team strengths, home advantage and intercept.

get_params()

Returns the model's fitted parameters as a dictionary

load(filepath)

Loads a model from a file.

predict(home_team, away_team[, max_goals])

Predicts the probability of each scoreline for a given home and away team

save(filepath)

Saves the model to a file using pickle.

Attributes

params

Property to retrieve the fitted model parameters.

fit()[source]#

Fits the model to the data and calculates the team strengths, home advantage and intercept. Must be called before predict can be used

get_params() Dict[str, float][source]#

Returns the model’s fitted parameters as a dictionary

Returns:

A dict containing the model’s parameters

Return type:

dict

classmethod load(filepath: str) Any#

Loads a model from a file.

Parameters:

filepath (str) – The path to the file from which the model will be loaded.

Returns:

An instance of the model.

Return type:

Any

property params: dict#

Property to retrieve the fitted model parameters. Same as get_params(), but allows attribute-like access.

Returns:

A dictionary containing attack, defense, home advantage, and correlation parameters.

Return type:

dict

Raises:

ValueError – If the model has not been fitted yet.

predict(home_team: str, away_team: str, max_goals: int = 15) FootballProbabilityGrid[source]#

Predicts the probability of each scoreline for a given home and away team

Parameters:
  • home_team (str) – The name of the home team

  • away_team (str) – The name of the away team

  • max_goals (int, optional) – The maximum number of goals to consider, by default 15

Returns:

A FootballProbabilityGrid object containing the probabilities of each scoreline

Return type:

FootballProbabilityGrid

save(filepath: str)#

Saves the model to a file using pickle.

Parameters:

filepath (str) – The path to the file where the model will be saved.