A package for loading, synchronizing, and analyzing your soccer event- and tracking data.
This package is developed to create a standardized way to analyse soccer matches using both event- and tracking data. Other packages, like kloppy and floodlight, already standardize the import of data sources. The current package goes a step further in combining different data streams from the same match. In this case, the Match
object combines information from the event and tracking data. The main current feature is the smart synchronization of the tracking and event data. We utilize the Needleman-Wunch algorithm, inspired by this article, to align the tracking and even data, while ensuring the order of the events, something that is not done when only using (different) cost functions.
Although reading in and synchronising data is already very helpfull to get started with your analysis, it's only the first step. Even after this first step, getting your first 'simple' metrics out of the data might be more difficult than anticipated. Therefore, the primary end goal for this package is to create a space where (scientific) soccer metrics are implemented and can be used in a few lines. We even plan to go further and show clear notebooks (to combine text and code) with visualizations for all the features we implement. This way, you will not only get easy access to the features/metrics, but also understand exactly how it is calculated. We hope this will inspire others (both developers and scientist) to further improve the current features, and come up with valuable new ones. If you are interested in some of the features we implemented, see our official documentation.
- Added event data parser for SciSports
- Added expected threat model from Karun Singh to on ball events
- Add function to add which team has ball possession based on the synchronised event data.
- Solved encoding bug for Windows
- Added function to obtain acceleration
- Improved standardization and performance of synchronisation
- Made save match clip more robust
- Added function to calculate covered distances in different velocity and acceleration zones
- Updated the documentation
$ pip install databallpy
The package is centered around the Match
object. A Match
has tracking data, event data metadata about the match.
For a more elaborate example, see the Getting Started.
$ from databallpy import get_match, get_open_match
$
$ match = get_match(
$ tracking_data_loc="../data/tracking_data.dat",
$ tracking_metadata_loc="../data/tracking_metadata.xml",
$ tracking_data_provider="tracab"
$ event_data_loc="../data/event_data_f24.xml",
$ event_metadata_loc="../data/event_metadata_f7.xml",
$ event_data_provider="opta",
$ )
$
$ # or to load an open metrica dataset of tracking and event data
$ match = get_open_match()
$
$ match.home_team_name # the team name of the home playing team
$ match.away_players # pandas dataframe with the names, ids, shirt numbers and positions of the away team
$ match.tracking_data # pandas dataframe with tracking data of the match
$ match.event_data # pandas dataframe with event data of the match
See the documentation of the Match
object and the example usage for more options. Note that this package is developed to combine event and tracking data, for now both datastreams are necessary to create a Match
object.
- Data Filtering: Filter the data based on the quality of the tracking data.
- Adding velocity and Acceleration: Add velocity and acceleration to the tracking data.
See our elaborate synchronisation page in the documentation for more information!
Tracking and event data is often poorly synchronized. For instance, when taking the event data of Opta and tracking data of Tracab, you can sync the fist frame with the kick-off pass. Now you can sync the other events with the tracking data based on the time difference between the event and the kick off pass. If you do this, how get something like this:
not_synced.mp4
As you can see, the timing (and placing) of the events do not correspond good with the tracking data locations, especially when events follow up quickly or around shots. Using the methodology of this article, this package is able to synchronize tracking and event data using the Needleman-Wunsch algorithm.
After running the following command, the events are better synchronized to the tracking data:
$ match.synchronise_tracking_and_event_data()
synced.mp4
For a more elaborate example of how we synchronize the tracking and event data, see the Synchronisation Page in our documentation.
DataBallPy offers a variety of visualizations to help you understand the data better. For example, you can visualize the tracking data with synchronised event as shown above. Also, you can visualize events and tracking data separately. For more information, see the Visualizations Page in our documentation.
- Covered Distance: Calculate the covered distance in different velocity and acceleration zones.
- Pressure: Calculate the pressure any player in the match (Herold & Kempe, 2022).
- Team Possession: Calculate the team possession based on the synchronised event data.
- Individual Player Possession: Calculate the individual player possession based on the tracking data (Vidal-Codina et al., 2022).
- Simple Expected Goals (xG) model: Calculate the simple expected goals model.
- Expected Threat model: Calculate the expected threat model from Karun Singh to on ball events.
- Voronoi Model: Calculate the Voronoi space occupation based on the tracking data.
- Gaussian Model: Calculate the Gaussian space occupation based on the tracking data (Fernandez & Born, 2018).
The official documentation can be found here.
For now we limited providers. We are planning on adding more providers later on.
Event data providers:
- Opta
- Metrica
- Instat
- SciSports
Tracking data providers:
- Tracab
- Metrica
- Inmotio
Interested in contributing? Check out the contributing guidelines. Please note that this project is released with a Code of Conduct. By contributing to this project, you agree to abide by its terms.
databallpy
was created by Alexander Oonk & Daan Grob. It is licensed under the terms of the MIT license.
Although we think this package helps when starting to analyse soccer data, other packages may be better suited for your specific needs. Make sure to check out the following packages as well:
And for a more specific toturials on how to get started with soccer data"