| """Utility functions for working with SPADL dataframes.""" | |
| from typing import cast | |
| from pandera.typing import DataFrame | |
| from . import config as spadlconfig | |
| from .schema import SPADLSchema | |
| def add_names(actions: DataFrame[SPADLSchema]) -> DataFrame[SPADLSchema]: | |
| """Add the type name, result name and bodypart name to a SPADL dataframe. | |
| Parameters | |
| ---------- | |
| actions : pd.DataFrame | |
| A SPADL dataframe. | |
| Returns | |
| ------- | |
| pd.DataFrame | |
| The original dataframe with a 'type_name', 'result_name' and | |
| 'bodypart_name' appended. | |
| """ | |
| return cast( | |
| DataFrame[SPADLSchema], | |
| actions.drop(columns=["type_name", "result_name", "bodypart_name"], errors="ignore") | |
| .merge(spadlconfig.actiontypes_df(), how="left") | |
| .merge(spadlconfig.results_df(), how="left") | |
| .merge(spadlconfig.bodyparts_df(), how="left") | |
| .set_index(actions.index), | |
| ) | |
| def play_left_to_right( | |
| actions: DataFrame[SPADLSchema], home_team_id: int | |
| ) -> DataFrame[SPADLSchema]: | |
| """Perform all action in the same playing direction. | |
| This changes the start and end location of each action, such that all actions | |
| are performed as if the team that executes the action plays from left to | |
| right. | |
| Parameters | |
| ---------- | |
| actions : pd.DataFrame | |
| The SPADL actins of a game. | |
| home_team_id : int | |
| The ID of the home team. | |
| Returns | |
| ------- | |
| list(pd.DataFrame) | |
| All actions performed left to right. | |
| See Also | |
| -------- | |
| socceraction.vaep.features.play_left_to_right : For transforming gamestates. | |
| """ | |
| ltr_actions = actions.copy() | |
| away_idx = actions.team_id != home_team_id | |
| for col in ["start_x", "end_x"]: | |
| ltr_actions.loc[away_idx, col] = spadlconfig.field_length - actions[away_idx][col].values | |
| for col in ["start_y", "end_y"]: | |
| ltr_actions.loc[away_idx, col] = spadlconfig.field_width - actions[away_idx][col].values | |
| return ltr_actions | |