File size: 2,727 Bytes
1c6d55d
 
 
 
 
 
 
30c2633
1c6d55d
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
85
86
87
88
89
from email.utils import parseaddr
from huggingface_hub import HfApi
import os
import datetime
import pandas as pd


RESULTS_PATH = "boyiwei/CoTaEval_leaderboard"
api = HfApi()
TOKEN = os.environ.get("TOKEN", None)
YEAR_VERSION = "2024"

def format_error(msg):
    return f"<p style='color: red; font-size: 20px; text-align: center;'>{msg}</p>"

def format_warning(msg):
    return f"<p style='color: orange; font-size: 20px; text-align: center;'>{msg}</p>"

def format_log(msg):
    return f"<p style='color: green; font-size: 20px; text-align: center;'>{msg}</p>"

def model_hyperlink(link, model_name):
    return f'<a target="_blank" href="{link}" style="color: var(--link-text-color); text-decoration: underline;text-decoration-style: dotted;">{model_name}</a>'


def input_verification(model, model_family, forget_rate, url, path_to_file, organisation, mail):
    for input in [model, model_family, forget_rate, url, organisation]:
        if input == "":
            return format_warning("Please fill all the fields.")
    
    # Very basic email parsing
    _, parsed_mail = parseaddr(mail)
    if not "@" in parsed_mail:
        return format_warning("Please provide a valid email adress.")

    
    if path_to_file is None:
        return format_warning("Please attach a file.")
    
    return parsed_mail

def add_new_eval(
    model: str,
    model_family: str,
    forget_rate: str,
    url: str,
    path_to_file: str,
    organisation: str,
    mail: str,
):
    
    parsed_mail  = input_verification(model, model_family, forget_rate, url, path_to_file, organisation, mail)
    
    # load the file 
    df = pd.read_csv(path_to_file)

    # modify the df to include metadata
    df["model"] = model
    df["model_family"] = model_family
    df["forget_rate"] = forget_rate
    df["url"] = url
    df["organisation"] = organisation
    df["mail"] = parsed_mail
    df["timestamp"] = datetime.datetime.now()

    #upload to spaces using the hf api at 
    
    path_in_repo = f"versions/{model_family}-{forget_rate.replace('%', 'p')}"
    file_name = f"{model}-{organisation}-{datetime.datetime.now().strftime('%Y-%m-%d')}.csv"
    
    # upload the df to spaces
    import io
    
    buffer = io.BytesIO()
    df.to_csv(buffer, index=False)  # Write the DataFrame to a buffer in CSV format
    buffer.seek(0)  # Rewind the buffer to the beginning

    api.upload_file(
        repo_id = RESULTS_PATH,
        path_in_repo = f"{path_in_repo}/{file_name}",
        path_or_fileobj = buffer,
        token=TOKEN,
        repo_type="space",
    )

    return format_log(f"Model {model} submitted by {organisation} successfully. \nPlease refresh the leaderboard, and wait a bit to see the score displayed")