File size: 2,396 Bytes
bcf020e
bb00581
c46cec1
 
 
 
 
f94c9eb
c46cec1
5bb732d
bf24d8a
 
cefa7ac
bf24d8a
5bb732d
 
ae21b2a
 
 
 
5bb732d
87aae5e
bb00581
 
 
64f0dfb
a09d793
bb00581
 
 
87aae5e
bb00581
c46cec1
bb00581
bcf020e
 
87aae5e
c46cec1
e5d2e0d
0054bfa
c46cec1
0054bfa
bb00581
c46cec1
bb00581
 
 
c46cec1
bb00581
 
 
87aae5e
c46cec1
bcf020e
b3344b3
87aae5e
 
 
 
 
 
 
bb00581
 
 
 
c46cec1
bb00581
 
 
c46cec1
87aae5e
 
0054bfa
87aae5e
c46cec1
bb00581
 
 
bcf020e
 
ed4ba7d
 
0d0ff81
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
from shiny import App, ui, render, reactive
from shinywidgets import output_widget, render_widget
import fastf1 as ff1
import matplotlib.pyplot as plt
from matplotlib.collections import LineCollection
from matplotlib import cm
import numpy as np
import os

try:    
    script_dir = os.path.dirname(os.path.abspath(__file__))
    cache_folder = 'cache'
    cache_dir = os.path.join(script_dir, cache_folder)
    ff1.Cache.enable_cache(cache_dir)
except:
    print('Cache error!!')

#Default session
f1_session = ff1.get_session(2023, "Austria", "R")
f1_session.load()
    

app_ui = ui.page_fluid(
    ui.div(
        ui.input_select(
            "track", label="Track",
            choices=["Austria", "Hungary", "Spanish Grand Prix"]
        ),
        class_="d-flex gap-3"
    ),
    ui.output_plot("gear")
)

def server(input, output, session):
    @reactive.Calc
    def get_data():
        

        f1_session = ff1.get_session(2023, input.track(), 'R')
        f1_session.load()

        lap = f1_session.laps.pick_fastest()
        tel = lap.get_telemetry()

        #converting data to numpy data tables
        x = np.array(tel['X'].values)
        y = np.array(tel['Y'].values)

        points = np.array([x, y]).T.reshape(-1, 1, 2)
        segments = np.concatenate([points[:-1], points[1:]], axis=1)
        gear = tel['nGear'].to_numpy().astype(float)
        return lap, tel, x, y, points, segments, gear

    @output
    @render.plot
    def gear():
        lap = get_data().lap
        tel = get_data().tel
        points = get_data().points
        segments = get_data().segments

        
        cmap = cm.get_cmap('Paired')
        lc_comp = LineCollection(segments, norm=plt.Normalize(1, cmap.N+1), cmap=cmap)
        lc_comp.set_array(gear)
        lc_comp.set_linewidth(4)

        plt.gca().add_collection(lc_comp)
        plt.axis('equal')
        plt.tick_params(labelleft=False, left=False, labelbottom=False, bottom=False)

        ##title = plt.suptitle(
        ##        f"Fastest Lap Gear Shift Visualization\n"
        ##        f"{lap['Driver']} - {f1_session.event['EventName']} {f1_session.event.year}"
        ##        )

        cbar = plt.colorbar(mappable=lc_comp, label="Gear", boundaries=np.arange(1, 10))
        cbar.set_ticks(np.arange(1.5, 9.5))
        cbar.set_ticklabels(np.arange(1, 9))
            
    return plt


app = App(app_ui, server)