Skip to content

Commit

Permalink
Strategy example, using session.drivers to plot in correct order
Browse files Browse the repository at this point in the history
  • Loading branch information
Casper-Guo committed May 12, 2023
1 parent fd0f9fb commit 59ad4ae
Showing 1 changed file with 82 additions and 0 deletions.
82 changes: 82 additions & 0 deletions examples/plot_strategy.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
"""
Tyre strategies during a race
=============================
Plot all drivers' tyre strategies during a race.
"""

import fastf1 as f
import fastf1.plotting as p
from matplotlib import pyplot as plt

###############################################################################
# Load the race session and create the plot

session = f.get_session(2022, "Hungary", 'R')
session.load()

fig, ax = plt.subplots(figsize=(5, 10))

laps = session.laps

###############################################################################
# Get the list of driver numbers
drivers = session.drivers
print(drivers)

###############################################################################
# Convert the driver numbers to three letter abbreviations
drivers = [session.get_driver(driver)["Abbreviation"] for driver in drivers]
print(drivers)

###############################################################################
# We need to find the stint length and compound used
# for every stint by every driver
# We do this by grouping the laps by the driver,
# the stint number, and the compound
# And counting the number of laps in each group
stints = laps[["Driver", "Stint", "Compound", "LapNumber"]]
stints = stints.groupby(["Driver", "Stint", "Compound"])
stints = stints.count().reset_index()

###############################################################################
# The number in the LapNumber column stands for the stint length
stints = stints.rename(columns={"LapNumber": "StintLength"})
print(stints)

###############################################################################
# Now we can plot the strategies for each driver

for driver in drivers:
driver_stints = stints.loc[stints["Driver"] == driver]

previous_stint_end = 0
for idx, row in driver_stints.iterrows():
#######################################################################
# Each row contains the compound name and stint length
# We can use these information to draw horizontal bars
plt.barh(
y=driver,
width=row["StintLength"],
left=previous_stint_end,
color=p.COMPOUND_COLORS[row["Compound"]],
edgecolor="black",
fill=True
)

previous_stint_end += row["StintLength"]

###############################################################################
# Make the plot more readable
plt.title("2022 Hungarian Grand Prix Strategies")
plt.xlabel("Lap Number")
plt.grid(False)
ax.invert_yaxis()

###############################################################################
# Plot aesthetics
ax.spines['top'].set_visible(False)
ax.spines['right'].set_visible(False)
ax.spines['left'].set_visible(False)

plt.show()

0 comments on commit 59ad4ae

Please sign in to comment.