add app
Browse files- README.md +4 -4
- app.py +221 -0
- qa_pairs.csv +8 -0
- requirements.txt +2 -0
- unlpboard_f.json +13 -0
README.md
CHANGED
@@ -1,8 +1,8 @@
|
|
1 |
---
|
2 |
-
title:
|
3 |
-
emoji:
|
4 |
-
colorFrom:
|
5 |
-
colorTo:
|
6 |
sdk: gradio
|
7 |
sdk_version: 4.19.2
|
8 |
app_file: app.py
|
|
|
1 |
---
|
2 |
+
title: Unlp
|
3 |
+
emoji: ๐
|
4 |
+
colorFrom: pink
|
5 |
+
colorTo: yellow
|
6 |
sdk: gradio
|
7 |
sdk_version: 4.19.2
|
8 |
app_file: app.py
|
app.py
ADDED
@@ -0,0 +1,221 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
import gradio as gr
|
2 |
+
import pandas as pd
|
3 |
+
import random
|
4 |
+
import firebase_admin
|
5 |
+
from firebase_admin import credentials
|
6 |
+
from firebase_admin import firestore
|
7 |
+
|
8 |
+
CSV_FILE_PATH = "qa_pairs.csv"
|
9 |
+
|
10 |
+
cred = credentials.Certificate("unlpboard_f.json")
|
11 |
+
firebase_admin.initialize_app(cred)
|
12 |
+
|
13 |
+
def list_models():
|
14 |
+
df = pd.read_csv(CSV_FILE_PATH)
|
15 |
+
return df['model'].unique().tolist()
|
16 |
+
|
17 |
+
|
18 |
+
def list_questions():
|
19 |
+
df = pd.read_csv(CSV_FILE_PATH)
|
20 |
+
return df['question'].unique().tolist()
|
21 |
+
|
22 |
+
def fetch_questions():
|
23 |
+
questions_ref = db.collection('questions')
|
24 |
+
docs = questions_ref.stream()
|
25 |
+
questions_list = []
|
26 |
+
for doc in docs:
|
27 |
+
question = doc.to_dict()
|
28 |
+
questions_list.append(question)
|
29 |
+
return questions_list
|
30 |
+
|
31 |
+
|
32 |
+
def display_answers(question, model1, model2):
|
33 |
+
df = pd.read_csv(CSV_FILE_PATH)
|
34 |
+
answers = {
|
35 |
+
model1: "No answer available for Model 1",
|
36 |
+
model2: "No answer available for Model 2",
|
37 |
+
}
|
38 |
+
for model in [model1, model2]:
|
39 |
+
filtered_df = df[(df['question'] == question) & (df['model'] == model)]
|
40 |
+
if not filtered_df.empty:
|
41 |
+
answers[model] = f"**{model} Answer:**\n{filtered_df['answer'].iloc[0]}"
|
42 |
+
return answers[model1], answers[model2]
|
43 |
+
|
44 |
+
|
45 |
+
def update_b(q,m1,a1,m2,a2):
|
46 |
+
print('Model1: ', random_model2)
|
47 |
+
print('Model2: ', random_model2)
|
48 |
+
q, m1, a1, m2, a2 = update_symbols(q, m1, a1, m2, a2)
|
49 |
+
b1 = gr.Button("Vote for Model 1",interactive=True)
|
50 |
+
b2 = gr.Button("Itโs a tie!",interactive=True)
|
51 |
+
b3 = gr.Button("Vote for Model 2",interactive=True)
|
52 |
+
b4 = gr.Button("START!", visible = False)
|
53 |
+
return q, m1, a1, m2, a2, b1, b2, b3, b4
|
54 |
+
|
55 |
+
|
56 |
+
def update_symbols1(q,m1,a1,m2,a2):
|
57 |
+
print("Voted for Model 1")
|
58 |
+
log_vote(
|
59 |
+
model1=m1,
|
60 |
+
model2=m2,
|
61 |
+
question=q,
|
62 |
+
output1=a1,
|
63 |
+
output2=a2,
|
64 |
+
outcome=m1
|
65 |
+
)
|
66 |
+
votes_ref = db.collection('votes')
|
67 |
+
vote_doc = votes_ref.document(m1).get()
|
68 |
+
if vote_doc.exists:
|
69 |
+
votes_ref.document(m1).update({'count': firestore.Increment(1)})
|
70 |
+
else:
|
71 |
+
votes_ref.document(m1).set({'count': 1})
|
72 |
+
update_total_votes()
|
73 |
+
return update_symbols(q, m1, a1, m2, a2)
|
74 |
+
|
75 |
+
|
76 |
+
def update_symbols2(q, m1, a1, m2, a2):
|
77 |
+
print("Voted for Spare")
|
78 |
+
log_vote(
|
79 |
+
model1=m1,
|
80 |
+
model2=m2,
|
81 |
+
question=q,
|
82 |
+
output1=a1,
|
83 |
+
output2=a2,
|
84 |
+
outcome='tie'
|
85 |
+
)
|
86 |
+
update_total_votes()
|
87 |
+
return update_symbols(q, m1, a1, m2, a2)
|
88 |
+
|
89 |
+
def update_symbols3(q, m1, a1, m2, a2):
|
90 |
+
print("Voted for Model 2")
|
91 |
+
log_vote(
|
92 |
+
model1=m1,
|
93 |
+
model2=m2,
|
94 |
+
question=q,
|
95 |
+
output1=a1,
|
96 |
+
output2=a2,
|
97 |
+
outcome=m2
|
98 |
+
)
|
99 |
+
votes_ref = db.collection('votes')
|
100 |
+
vote_doc = votes_ref.document(m2).get()
|
101 |
+
if vote_doc.exists:
|
102 |
+
votes_ref.document(m2).update({'count': firestore.Increment(1)})
|
103 |
+
else:
|
104 |
+
votes_ref.document(m2).set({'count': 1})
|
105 |
+
update_total_votes()
|
106 |
+
return update_symbols(q, m1, a1, m2, a2)
|
107 |
+
|
108 |
+
def update_symbols(q,m1,a1,m2,a2):
|
109 |
+
random_question = random.choice(questions)
|
110 |
+
random_model1, random_model2 = random.sample(models, 2)
|
111 |
+
answer1, answer2 = display_answers(random_question, random_model1, random_model2)
|
112 |
+
m1 = gr.Markdown(f"{random_model1}", visible=False)
|
113 |
+
a1 = gr.Markdown(answer1)
|
114 |
+
q = gr.Markdown(f"{random_question}")
|
115 |
+
m2 = gr.Markdown(f"{random_model2}", visible=False)
|
116 |
+
a2 = gr.Markdown(answer2)
|
117 |
+
return q,m1,a1,m2,a2
|
118 |
+
|
119 |
+
def update_total_votes():
|
120 |
+
votes_ref = db.collection('votes')
|
121 |
+
vote_doc = votes_ref.document('total').get()
|
122 |
+
if vote_doc.exists:
|
123 |
+
votes_ref.document('total').update({'count': firestore.Increment(1)})
|
124 |
+
else:
|
125 |
+
votes_ref.document('total').set({'count': 1})
|
126 |
+
|
127 |
+
def log_vote(model1, model2, question, output1, output2, outcome):
|
128 |
+
# Reference to the Firestore collection where votes will be logged
|
129 |
+
votes_log_ref = db.collection('votes_log')
|
130 |
+
|
131 |
+
# Create a new document for this vote
|
132 |
+
vote_data = {
|
133 |
+
'model1': model1,
|
134 |
+
'model2': model2,
|
135 |
+
'question': question,
|
136 |
+
'output1': output1,
|
137 |
+
'output2': output2,
|
138 |
+
'outcome': outcome,
|
139 |
+
'timestamp': firestore.SERVER_TIMESTAMP
|
140 |
+
}
|
141 |
+
|
142 |
+
# Add the vote document to Firestore
|
143 |
+
votes_log_ref.add(vote_data)
|
144 |
+
|
145 |
+
|
146 |
+
def fetch_and_format_leaderboard():
|
147 |
+
vote_counts_ref = db.collection('votes')
|
148 |
+
# Ensure you're using FieldPath.document_id() correctly
|
149 |
+
docs = vote_counts_ref.stream()
|
150 |
+
|
151 |
+
leaderboard = []
|
152 |
+
for doc in docs:
|
153 |
+
model_name = doc.id
|
154 |
+
vote_count = doc.to_dict().get('count', 0)
|
155 |
+
leaderboard.append(f"{model_name}: {vote_count} votes")
|
156 |
+
|
157 |
+
# Optional: Sort the leaderboard by vote count in descending order
|
158 |
+
leaderboard.sort(key=lambda x: int(x.split(': ')[1].split(' ')[0]), reverse=True)
|
159 |
+
|
160 |
+
return "\n".join(leaderboard)
|
161 |
+
|
162 |
+
#questions = list_questions()
|
163 |
+
models = list_models()
|
164 |
+
random_question = 'Click any button to start!'
|
165 |
+
random_model1, random_model2 = '1', '2'
|
166 |
+
answer1, answer2 = display_answers(random_question, random_model1, random_model2)
|
167 |
+
|
168 |
+
|
169 |
+
db = firestore.client()
|
170 |
+
|
171 |
+
questions = []
|
172 |
+
questions_ = fetch_questions()
|
173 |
+
for question in questions_:
|
174 |
+
questions.append(question['question_text'])
|
175 |
+
|
176 |
+
votes_ref = db.collection('votes')
|
177 |
+
|
178 |
+
def create_app():
|
179 |
+
|
180 |
+
print('-----------------------')
|
181 |
+
print(random_question)
|
182 |
+
print(random_model1)
|
183 |
+
print('-----!!!!!!!!!!!!!')
|
184 |
+
|
185 |
+
with gr.Blocks() as app:
|
186 |
+
q = gr.Markdown(f"### Question: {random_question}")
|
187 |
+
|
188 |
+
with gr.Row():
|
189 |
+
with gr.Column():
|
190 |
+
m1 = gr.Markdown(f"{random_model1}", visible=False)
|
191 |
+
a1 = gr.Markdown(answer1)
|
192 |
+
|
193 |
+
with gr.Column():
|
194 |
+
m2 = gr.Markdown(f"{random_model2}", visible=False)
|
195 |
+
a2 = gr.Markdown(answer2)
|
196 |
+
|
197 |
+
with gr.Row():
|
198 |
+
b1 = gr.Button("Vote for Model 1",interactive=False)
|
199 |
+
b2 = gr.Button("Itโs a tie!",interactive=False)
|
200 |
+
b3 = gr.Button("Vote for Model 2",interactive=False)
|
201 |
+
with gr.Row():
|
202 |
+
b4 = gr.Button("START!", interactive=True)
|
203 |
+
#with gr.Row():
|
204 |
+
# b5 = gr.Button("Show Leaderboard")
|
205 |
+
|
206 |
+
initial_leaderboard_data = fetch_and_format_leaderboard()
|
207 |
+
leaderboard_display = gr.Textbox(value=initial_leaderboard_data,label="Leaderboard", placeholder="Leaderboard will be displayed here.",
|
208 |
+
lines=30, visible=True)
|
209 |
+
#b5.click(fn=fetch_and_format_leaderboard, inputs=[], outputs=leaderboard_display)
|
210 |
+
|
211 |
+
b4.click(update_b, inputs=[q,m1,a1,m2,a2], outputs=[q,m1,a1,m2,a2,b1,b2,b3, b4])
|
212 |
+
b1.click(update_symbols1, inputs=[q,m1,a1,m2,a2], outputs=[q,m1,a1,m2,a2])
|
213 |
+
b2.click(update_symbols2, inputs=[q, m1, a1, m2, a2], outputs=[q, m1, a1, m2, a2])
|
214 |
+
b3.click(update_symbols3, inputs=[q, m1, a1, m2, a2], outputs=[q, m1, a1, m2, a2])
|
215 |
+
leaderboard_button = gr.Button("Refresh Leaderboard")
|
216 |
+
leaderboard_button.click(fn=fetch_and_format_leaderboard, inputs=[], outputs=leaderboard_display)
|
217 |
+
|
218 |
+
return app
|
219 |
+
|
220 |
+
app = create_app()
|
221 |
+
app.launch()
|
qa_pairs.csv
ADDED
@@ -0,0 +1,8 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
question,answer,model
|
2 |
+
What is the capital of France?,Paris,Model A
|
3 |
+
What is the capital of France?,Brussels,Model B
|
4 |
+
What is the capital of France?,Kyiv,Model C
|
5 |
+
Who wrote '1984'?,George Orwell,Model A
|
6 |
+
What is the speed of light?,"Approximately 299,792 kilometers per second",Model B
|
7 |
+
What is the largest ocean?,Pacific Ocean,Model B
|
8 |
+
Who painted the Mona Lisa?,Leonardo da Vinci,Model C
|
requirements.txt
ADDED
@@ -0,0 +1,2 @@
|
|
|
|
|
|
|
1 |
+
firebase-admin
|
2 |
+
pandas
|
unlpboard_f.json
ADDED
@@ -0,0 +1,13 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
{
|
2 |
+
"type": "service_account",
|
3 |
+
"project_id": "unlpboard",
|
4 |
+
"private_key_id": "cb34c2f851e6be6a6e1561c3cd5e3bb3492295b6",
|
5 |
+
"private_key": "-----BEGIN PRIVATE KEY-----\nMIIEvwIBADANBgkqhkiG9w0BAQEFAASCBKkwggSlAgEAAoIBAQDGkeL/1Wa1KjeU\nGDM+qDPwn/gVsAZjXiIQPURVxPpOIiX4vEs4qfPSdOIPM5wX3bNZmv/5XJM16d7f\nbG+KTOok43v1TaKML7wpoujzZcGQI+OQGYFjxLHOoMpZZ9Jl24SjjFy6Tm7IW/rT\nOksWYQdeiK6Lu9vaf2gFeOyt8EjS3bR3Qmbtk4qjPP1kTaXmAujJvplMziGWvyfL\n4C508GGHufjP9icdrx6xi/AYNzZX2UU5hDKJdDMHr4VtFWk5yrqi3dauw2ULlQN3\njc0G0gQ/zKpD40o7ypIxdbrMTY119Vl4JPw0lKNDpTj2wE1CmqAZT/MnvRZGC9NJ\nIKkjYhHFAgMBAAECggEACoXWorobXERld5qktJBTWFAR5IxUelWVtoiYo3bx0Mws\nePb5gYI4IpIBHM8eWYFtLLVzFTLbtkKzheGIM6sJyXSosAIyN/2bmhVBBQ0CafIM\n8Cj522CkD5AjyQMgejdc2xHoJBNd+Y4uR51SN1hi/JZ/sXX+G6Ee0RNsb3dJVKtF\nLIaQMzFwRZsfY7QW5xaAkEF42D5H2kKMSa/35oRy5fYdwC50/+zDpX67hMV4mfmK\nvblS7QLxYJhfnjwT1oFT5UYxm8mQDb5qrv9OpjrrtoULaaoP13JipT4z8t+rqlnA\nYtZbe7PxH0lrE81eh/1jhAj8pTKklODR4AUPUHwRwQKBgQDh6+ME1PZUEoJwthtT\nrA5Hznj4h+MX+DJ3gSuAdRbRa6H+Y8EVjQnWzxL5dUzQLNL24YaniI2EGcABsMXy\n5hwdrrS9zfom4+qP/E9jgM52DWLR8TH/CqhNaCSEXrS5qj98CoUUe+Mllq3bABNo\nyQ1tw78r5rg4+Adv+lcumaEgVQKBgQDhAcXJ5l6ZCmW1PA5OKMA+466DFZ956nFg\nAK45NGFh76UCb29vTEI+gRJbJEewuzGYelXNK/VSwBr9F/TKrv+XrQW5bE8wM2zL\n+nhy/h8gs/FCC/ffPaXpHeAgA6C/mOR4U4y3b50o0R5oRFWX75HNnPR1tyhDIrgK\nf0tCjQrbsQKBgQDP7UciYlJX7DUrQR+Dcb4u7mO98Wrb262u+S4taxZWJeaQ+AR0\nLjtY/XpsJz5L9oUvfT9uH6qHYx+pLqXwuUI1O17Ttag+dNOkM0ZpwNnEIuvJZ2Bp\nZ8igfXHmdjeFDaCiLBhxUtgq9zQJdFdowGnglSD0acMxg21s7Q2iMPjvhQKBgQCe\nPWrmRPc+VguVW7kLyqj5EZKHacuQKAq344KjhG0APVMk1U3fThhAcPGB24/3gI6u\nl0qEUmfjXGsel5x2doAWIX6nGr7OPTxEb9AJvyIRE7uWIWifPXHS8knO+f4xAMuc\nu9V4pCw4qmjiFzzC757wpXNe3gKYxG/+IevB0ANU4QKBgQDUSPDmjItR0eFcfwN5\nAme5LpKHM5UsyW5Iq+P6prtYjvZlBUcCQzW9ukW+SGTDPBWdVl3f4NlcfnI0pCdv\ngo7fE8osBBxN81YigdtY50MXH8v0lZbt0PYNjz8wgDQ8iASTnMO2Kezouah5N7gB\ngMLcBMCeNTmPm8uvQL9U4PdvmQ==\n-----END PRIVATE KEY-----\n",
|
6 |
+
"client_email": "[email protected]",
|
7 |
+
"client_id": "103161232823398026076",
|
8 |
+
"auth_uri": "https://accounts.google.com/o/oauth2/auth",
|
9 |
+
"token_uri": "https://oauth2.googleapis.com/token",
|
10 |
+
"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs",
|
11 |
+
"client_x509_cert_url": "https://www.googleapis.com/robot/v1/metadata/x509/firebase-adminsdk-bj4ah%40unlpboard.iam.gserviceaccount.com",
|
12 |
+
"universe_domain": "googleapis.com"
|
13 |
+
}
|