import pandas as pd
from pathlib import Path
from datasets import load_dataset
import numpy as np
import os
import re
UNVERIFIED_MODELS = [
]
CONTAMINATED_MODELS = [
]
# From Open LLM Leaderboard
def model_hyperlink(link, model_name):
# if model_name is above 50 characters, return first 47 characters and "..."
if len(model_name) > 50:
model_name = model_name[:47] + "..."
if model_name == "random":
output = "random"
elif model_name == "Cohere March 2024":
output = f'{model_name}'
elif "openai" == model_name.split("/")[0]:
output = f'{model_name}'
elif "Anthropic" == model_name.split("/")[0]:
output = f'{model_name}'
elif "google" == model_name.split("/")[0]:
output = f'{model_name}'
elif "PoLL" == model_name.split("/")[0]:
output = model_name
output = f'{model_name}'
if model_name in UNVERIFIED_MODELS:
output += " *"
if model_name in CONTAMINATED_MODELS:
output += " ⚠️"
return output
def undo_hyperlink(html_string):
# Regex pattern to match content inside > and <
pattern = r'>[^<]+<'
match = re.search(pattern, html_string)
if match:
# Extract the matched text and remove leading '>' and trailing '<'
return match.group(0)[1:-1]
else:
return "No text found"
# Define a function to fetch and process data
def load_all_data(data_repo, subdir:str, subsubsets=False): # use HF api to pull the git repo
dir = Path(data_repo)
data_dir = dir / subdir
# get all files
models_names = [f.split(".json")[0] for f in os.listdir(data_dir)
if os.path.isfile(os.path.join(data_dir, f)) and f.endswith(".json")]
# create empty dataframe to add all data to
df = pd.DataFrame()
# load all json data in the list models_results one by one to avoid not having the same entries
for model_name in models_names:
model_data = load_dataset("json", data_files=os.path.join(data_dir, model_name + ".json"), split="train")
model_data = model_data.add_column("model", [model_name])
df2 = pd.DataFrame(model_data)
# add to df
df = pd.concat([df2, df])
return df
def prep_df(df):
# sort columns alphabetically
df = df.reindex(sorted(df.columns), axis=1)
# move column "model" to the front
cols = list(df.columns)
cols.insert(0, cols.pop(cols.index('model')))
df = df.loc[:, cols]
# apply model_hyperlink function to column "model"
df["model"] = df.apply(lambda row: model_hyperlink(f"https://huggingface.co/{row['path']}", row['model']), axis=1)
df = df.drop(columns=["path"])
# select all columns except "model" and convert to score
cols = df.columns.tolist()
cols.remove("model")
cols = [c for c in cols if "rank" not in c]
df[cols] = (df[cols]*100)
# move average column to the second
cols = list(df.columns)
cols.insert(1, cols.pop(cols.index('average')))
df = df.loc[:, cols]
df = df.rename(columns={
"model": "Model",
"average": "Average",
"brainstorm": "Brainstorm",
"open_qa": "Open QA",
"closed_qa": "Closed QA",
"extract": "Extract",
"generation": "Generation",
"rewrite": "Rewrite",
"summarize": "Summarize",
"classify": "Classify",
"reasoning_over_numerical_data": "Reasoning Over Numerical Data",
"multi-document_synthesis": "Multi-Document Synthesis",
"fact_checking_or_attributed_qa": "Fact Checking or Attributed QA",
})
# Format for different columns
# if Score exists, round to 2 decimals
# if "Average" in df.columns:
# df["Average"] = np.array([f"{v:.2f}" for v in df["Average"].values])
# # round all others to 1 decimal
# for col in df.columns:
# if col not in ["Model", "Average"]:
# # replace any df[col].values == '' with np.nan
# df[col] = df[col].replace('', np.nan)
# df[col] = np.array([f"{v:.1f}" for v in df[col].values])
return df
def sort_by_category(df, category):
new_df = df.copy()
col_rank = category.lower().replace(" ", "_") + "_rank"
# sort
new_df = new_df.sort_values(by=[col_rank, category], ascending=[True, False])
# move column ranking to the front
cols = list(new_df.columns)
cols.insert(0, cols.pop(cols.index(col_rank)))
new_df = new_df.loc[:, cols]
new_df = new_df.rename(columns={col_rank: "Rank"})
# move selected column to the third
cols = list(new_df.columns)
cols.insert(2, cols.pop(cols.index(category)))
new_df = new_df.loc[:, cols]
# # move selected column to the fourth
# cols = list(new_df.columns)
# cols.insert(3, cols.pop(cols.index("Average")))
# new_df = new_df.loc[:, cols]
# drop all ranking
new_df = new_df.drop(columns=[c for c in new_df.columns if c.endswith("rank")])
return new_df