update data
Browse files- __pycache__/app.cpython-310.pyc +0 -0
- app.py +63 -6
- code_eval_board.csv +11 -11
- src/build.py +19 -14
__pycache__/app.cpython-310.pyc
DELETED
Binary file (2.24 kB)
|
|
app.py
CHANGED
@@ -1,26 +1,83 @@
|
|
1 |
import gradio as gr
|
2 |
-
import numpy as np
|
3 |
import pandas as pd
|
|
|
4 |
|
5 |
df = pd.read_csv("code_eval_board.csv")
|
6 |
df = df.sort_values(by=["Average score"], ascending=False)
|
7 |
-
|
8 |
headers = df.columns.to_list()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
9 |
demo = gr.Blocks()
|
10 |
with demo:
|
11 |
with gr.Row():
|
12 |
gr.Markdown(
|
13 |
"""<div style="text-align: center;"><h1> ⭐ Base <span style='color: #e6b800;'>Code</span> Models <span style='color: #e6b800;'>Evaluation</span></h1></div>\
|
14 |
<br>\
|
15 |
-
<p>We compare base code generation models on <a href="https://huggingface.co/datasets/openai_humaneval">HumanEval</a> benchmark and <a href="https://huggingface.co/datasets/nuprl/MultiPL-E">MultiPL-E</a>, in addition to throughput measurment\
|
16 |
and information about the model. We only compare pre-trained models without instruction tuning.</p>"""
|
17 |
)
|
18 |
|
19 |
with gr.Column():
|
20 |
-
|
21 |
-
|
22 |
-
|
|
|
|
|
23 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
24 |
with gr.Row():
|
25 |
gr.Markdown(
|
26 |
"""Notes:
|
|
|
1 |
import gradio as gr
|
|
|
2 |
import pandas as pd
|
3 |
+
import plotly.graph_objects as go
|
4 |
|
5 |
df = pd.read_csv("code_eval_board.csv")
|
6 |
df = df.sort_values(by=["Average score"], ascending=False)
|
|
|
7 |
headers = df.columns.to_list()
|
8 |
+
|
9 |
+
def plot_throughput(bs=1):
|
10 |
+
throughput_column = 'Throughput (tokens/s)' if bs==1 else 'Throughput (tokens/s) bs=50'
|
11 |
+
|
12 |
+
df['symbol'] = 2 # Triangle
|
13 |
+
df['color'] = ''
|
14 |
+
df.loc[df['Models'].str.contains('StarCoder|SantaCoder'), 'color'] = 'orange'
|
15 |
+
df.loc[df['Models'].str.contains('CodeGen'), 'color'] = 'pink'
|
16 |
+
df.loc[df['Models'].str.contains('Replit'), 'color'] = 'purple'
|
17 |
+
|
18 |
+
fig = go.Figure()
|
19 |
+
|
20 |
+
for i in df.index:
|
21 |
+
fig.add_trace(go.Scatter(
|
22 |
+
x=[df.loc[i, throughput_column]],
|
23 |
+
y=[df.loc[i, 'Average score']],
|
24 |
+
mode='markers',
|
25 |
+
marker=dict(
|
26 |
+
size=[df.loc[i, 'Size (B)'] + 10],
|
27 |
+
color=df.loc[i, 'color'],
|
28 |
+
symbol=df.loc[i, 'symbol']
|
29 |
+
),
|
30 |
+
name=df.loc[i, 'Models'],
|
31 |
+
hovertemplate =
|
32 |
+
'<b>%{text}</b><br><br>' +
|
33 |
+
'throughput_column: %{x}<br>' +
|
34 |
+
'Average Score: %{y}<br>' +
|
35 |
+
'Peak Memory (MB): ' + str(df.loc[i, 'Peak Memory (MB)']) + '<br>' +
|
36 |
+
'Human Eval (Python): ' + str(df.loc[i, 'humaneval-python']),
|
37 |
+
text=[df.loc[i, 'Models']],
|
38 |
+
showlegend=True
|
39 |
+
))
|
40 |
+
|
41 |
+
fig.update_layout(
|
42 |
+
autosize=False,
|
43 |
+
width=1000,
|
44 |
+
height=800,
|
45 |
+
title=f'Average Score Vs Throughput (A100-80GB, Batch Size {bs}, Float16)',
|
46 |
+
xaxis_title='throughput_column',
|
47 |
+
yaxis_title='Average Code Score',
|
48 |
+
)
|
49 |
+
return fig
|
50 |
+
|
51 |
+
|
52 |
demo = gr.Blocks()
|
53 |
with demo:
|
54 |
with gr.Row():
|
55 |
gr.Markdown(
|
56 |
"""<div style="text-align: center;"><h1> ⭐ Base <span style='color: #e6b800;'>Code</span> Models <span style='color: #e6b800;'>Evaluation</span></h1></div>\
|
57 |
<br>\
|
58 |
+
<p>We compare base multilingual code generation models on <a href="https://huggingface.co/datasets/openai_humaneval">HumanEval</a> benchmark and <a href="https://huggingface.co/datasets/nuprl/MultiPL-E">MultiPL-E</a>, in addition to throughput measurment\
|
59 |
and information about the model. We only compare pre-trained models without instruction tuning.</p>"""
|
60 |
)
|
61 |
|
62 |
with gr.Column():
|
63 |
+
with gr.Tabs(elem_classes="A100-tabs") as A100_tabs:
|
64 |
+
with gr.TabItem("🔍 Evaluation table", id=0):
|
65 |
+
leaderboard_df = gr.components.Dataframe(
|
66 |
+
value=df, headers=headers, datatype=["str" for _ in range(len(headers))]
|
67 |
+
)
|
68 |
|
69 |
+
with gr.TabItem("📊 Performance Plot", id=1):
|
70 |
+
with gr.Row():
|
71 |
+
bs_1_plot = gr.components.Plot(
|
72 |
+
value=plot_throughput(bs=1),
|
73 |
+
elem_id="bs1-plot",
|
74 |
+
show_label=False,
|
75 |
+
)
|
76 |
+
bs_50_plt = gr.components.Plot(
|
77 |
+
value=plot_throughput(bs=50),
|
78 |
+
elem_id="bs50-plot",
|
79 |
+
show_label=False,
|
80 |
+
)
|
81 |
with gr.Row():
|
82 |
gr.Markdown(
|
83 |
"""Notes:
|
code_eval_board.csv
CHANGED
@@ -1,11 +1,11 @@
|
|
1 |
-
Models,Size (B),Average score,Throughput (tokens/s),Seq_length,#Languages,humaneval-python,java,javascript,cpp,php,julia,d,lua,r,ruby,racket,rust,swift,Peak Memory (MB)
|
2 |
-
StarCoder-15B,15.0,22.83,38.6,8192,
|
3 |
-
StarCoderBase-15B,15.0,22.0,44.2,8192,
|
4 |
-
StarCoderBase-7B,7.0,20.04,43.1,8192,
|
5 |
-
CodeGen25-7B-multi,7.0,19.86,32.6,2048,
|
6 |
-
StarCoderBase-3B,3.0,14.41,50.0,8192,
|
7 |
-
CodeGen25-7B-mono,7.0,12.1,34.1,2048,
|
8 |
-
CodeGen-16B-Multi,16.0,11.81,17.2,2048,6,19.26,22.2,19.15,21.0,8.37,0.0,7.68,8.5,6.45,0.0,0.66,4.21,1.25,32890
|
9 |
-
Replit-2.7B,2.7,
|
10 |
-
StarCoderBase-1.1B,1.1,9.81,71.4,8192,
|
11 |
-
SantaCoder-1.1B,1.1,9.72,50.8,2048,3,18.12,15.0,15.47,6.2,1.5,0.0,0.0,0.1,0.0,0.0,0.0,2.0,0.7,4602
|
|
|
1 |
+
Models,Size (B),Average score,Throughput (tokens/s),Throughput (tokens/s) bs=50,Seq_length,#Languages,humaneval-python,java,javascript,cpp,php,julia,d,lua,r,ruby,racket,rust,swift,Peak Memory (MB)
|
2 |
+
StarCoder-15B,15.0,22.83,38.6,1490.0,8192,86,33.57,30.22,30.79,31.55,26.08,23.02,13.57,23.89,15.5,1.24,0.07,21.84,22.74,33461
|
3 |
+
StarCoderBase-15B,15.0,22.0,44.2,1460.0,8192,86,30.35,28.53,31.7,30.56,26.75,21.09,10.01,26.61,10.18,17.25,11.77,24.46,16.74,32366
|
4 |
+
StarCoderBase-7B,7.0,20.04,43.1,1700.0,8192,86,28.37,24.44,27.35,23.3,22.12,21.77,8.1,23.35,14.51,18.39,11.08,22.6,15.1,16512
|
5 |
+
CodeGen25-7B-multi,7.0,19.86,32.6,680.0,2048,86,28.7,26.01,26.27,25.75,21.98,19.11,8.84,23.44,11.59,17.72,10.37,21.84,16.62,15336
|
6 |
+
StarCoderBase-3B,3.0,14.41,50.0,1770.0,8192,86,21.5,19.25,21.32,19.43,18.55,16.1,4.97,18.04,10.1,3.93,7.87,16.32,9.98,8414
|
7 |
+
CodeGen25-7B-mono,7.0,12.1,34.1,687.0,2048,86,33.08,19.75,23.22,18.62,16.75,4.65,4.32,6.75,4.41,0.0,4.07,7.83,1.71,15336
|
8 |
+
CodeGen-16B-Multi,16.0,11.81,17.2,0.0,2048,6,19.26,22.2,19.15,21.0,8.37,0.0,7.68,8.5,6.45,0.0,0.66,4.21,1.25,32890
|
9 |
+
Replit-2.7B,2.7,11.55,42.2,577.0,2048,20,20.12,21.39,20.18,20.37,16.14,1.24,6.41,2.11,7.2,10.75,3.22,15.19,5.88,7176
|
10 |
+
StarCoderBase-1.1B,1.1,9.81,71.4,2360.0,8192,86,15.17,14.2,13.38,11.68,9.94,11.31,4.65,12.52,5.73,0.31,5.03,10.24,3.92,4586
|
11 |
+
SantaCoder-1.1B,1.1,9.72,50.8,2270.0,2048,3,18.12,15.0,15.47,6.2,1.5,0.0,0.0,0.1,0.0,0.0,0.0,2.0,0.7,4602
|
src/build.py
CHANGED
@@ -17,21 +17,22 @@ data = {
|
|
17 |
],
|
18 |
"Size (B)": [16, 15, 15, 7, 3, 2.7, 1.1, 1.1, 7, 7],
|
19 |
"Throughput (tokens/s)": [17.20, 38.60, 44.20, 43.10, 50.00, 42.20, 50.80, 71.40, 34.10, 32.60],
|
|
|
20 |
"Seq_length": [2048, 8192, 8192, 8192, 8192, 2048, 2048, 8192, 2048, 2048],
|
21 |
-
"#Languages": [6,
|
22 |
-
"humaneval-python": [19.26, 33.57, 30.35, 28.37, 21.50, 20.
|
23 |
-
"java": [22.20, 30.22, 28.53, 24.44, 19.25,
|
24 |
-
"javascript": [19.15, 30.79, 31.70, 27.35, 21.32,
|
25 |
-
"cpp": [21.00, 31.55, 30.56, 23.30, 19.43,
|
26 |
-
"php": [8.37, 26.08, 26.75, 22.12, 18.55,
|
27 |
-
"julia": [0.00, 23.02, 21.09, 21.77, 16.10,
|
28 |
-
"d": [7.68, 13.57, 10.01, 8.10, 4.97,
|
29 |
-
"lua": [8.50, 23.89, 26.61, 23.35, 18.04, 2.
|
30 |
-
"r": [6.45, 15.50, 10.18, 14.51, 10.10,
|
31 |
"ruby": [0.00, 1.24, 17.25, 18.39, 3.93, 10.75, 0.00, 0.31, 0.00, 17.72],
|
32 |
-
"racket": [0.66, 0.07, 11.77, 11.08, 7.87,
|
33 |
-
"rust": [4.21, 21.84, 24.46, 22.60, 16.32,
|
34 |
-
"swift": [1.25, 22.74, 16.74, 15.10, 9.98, 5.
|
35 |
"Peak Memory (MB)": [32890, 33461, 32366, 16512, 8414, 7176, 4602, 4586, 15336, 15336],
|
36 |
}
|
37 |
|
@@ -43,10 +44,14 @@ temp_df = temp_df.apply(pd.to_numeric, errors="coerce")
|
|
43 |
temp_df[temp_df <= 1] = np.nan
|
44 |
|
45 |
# get average over all columns from index 4 until -1 not included
|
46 |
-
temp_ = temp_df.iloc[:,
|
|
|
47 |
df.insert(2, "Average score", temp_.mean(axis=1).round(2))
|
|
|
|
|
48 |
|
49 |
# sort with regard to column average
|
50 |
df = df.sort_values(by=["Average score"], ascending=False)
|
51 |
|
52 |
df.to_csv("/fsx/loubna/code/code-leaderboard/starcoder-models-eval/code_eval_board.csv", index=False)
|
|
|
|
17 |
],
|
18 |
"Size (B)": [16, 15, 15, 7, 3, 2.7, 1.1, 1.1, 7, 7],
|
19 |
"Throughput (tokens/s)": [17.20, 38.60, 44.20, 43.10, 50.00, 42.20, 50.80, 71.40, 34.10, 32.60],
|
20 |
+
"Throughput (tokens/s) bs=50": [0.00, 1490.00, 1460.00, 1700.00, 1770.00, 577.00, 2270.00, 2360.00, 687.00, 680.00],
|
21 |
"Seq_length": [2048, 8192, 8192, 8192, 8192, 2048, 2048, 8192, 2048, 2048],
|
22 |
+
"#Languages": [6, 86, 86, 86, 86, 20, 3, 86, 86, 86],
|
23 |
+
"humaneval-python": [19.26, 33.57, 30.35, 28.37, 21.50, 20.12, 18.12, 15.17, 33.08, 28.70],
|
24 |
+
"java": [22.20, 30.22, 28.53, 24.44, 19.25, 21.39, 15.00, 14.20, 19.75, 26.01],
|
25 |
+
"javascript": [19.15, 30.79, 31.70, 27.35, 21.32, 20.18, 15.47, 13.38, 23.22, 26.27],
|
26 |
+
"cpp": [21.00, 31.55, 30.56, 23.30, 19.43, 20.37, 6.20, 11.68, 18.62, 25.75],
|
27 |
+
"php": [8.37, 26.08, 26.75, 22.12, 18.55, 16.14, 1.50, 9.94, 16.75, 21.98],
|
28 |
+
"julia": [0.00, 23.02, 21.09, 21.77, 16.10, 1.24, 0.00, 11.31, 4.65, 19.11],
|
29 |
+
"d": [7.68, 13.57, 10.01, 8.10, 4.97, 6.41, 0.00, 4.65, 4.32, 8.84],
|
30 |
+
"lua": [8.50, 23.89, 26.61, 23.35, 18.04, 2.11, 0.10, 12.52, 6.75, 23.44],
|
31 |
+
"r": [6.45, 15.50, 10.18, 14.51, 10.10, 7.20, 0.00, 5.73, 4.41, 11.59],
|
32 |
"ruby": [0.00, 1.24, 17.25, 18.39, 3.93, 10.75, 0.00, 0.31, 0.00, 17.72],
|
33 |
+
"racket": [0.66, 0.07, 11.77, 11.08, 7.87, 3.22, 0.00, 5.03, 4.07, 10.37],
|
34 |
+
"rust": [4.21, 21.84, 24.46, 22.60, 16.32, 15.19, 2.00, 10.24, 7.83, 21.84],
|
35 |
+
"swift": [1.25, 22.74, 16.74, 15.10, 9.98, 5.88, 0.70, 3.92, 1.71, 16.62],
|
36 |
"Peak Memory (MB)": [32890, 33461, 32366, 16512, 8414, 7176, 4602, 4586, 15336, 15336],
|
37 |
}
|
38 |
|
|
|
44 |
temp_df[temp_df <= 1] = np.nan
|
45 |
|
46 |
# get average over all columns from index 4 until -1 not included
|
47 |
+
temp_ = temp_df.iloc[:, 6:-1]
|
48 |
+
print(temp_)
|
49 |
df.insert(2, "Average score", temp_.mean(axis=1).round(2))
|
50 |
+
#print average score
|
51 |
+
print(df["Average score"])
|
52 |
|
53 |
# sort with regard to column average
|
54 |
df = df.sort_values(by=["Average score"], ascending=False)
|
55 |
|
56 |
df.to_csv("/fsx/loubna/code/code-leaderboard/starcoder-models-eval/code_eval_board.csv", index=False)
|
57 |
+
print(df)
|