gardarjuto
commited on
Commit
·
8446c23
1
Parent(s):
fcffb23
collect results data per question
Browse files
quiz.py
CHANGED
@@ -3,7 +3,7 @@ from dataclasses import dataclass
|
|
3 |
from typing import Any, Dict, List, Optional
|
4 |
import random
|
5 |
import matplotlib.pyplot as plt
|
6 |
-
from score import
|
7 |
|
8 |
|
9 |
# Define benchmarks
|
@@ -48,7 +48,7 @@ DATASETS = {
|
|
48 |
name=BENCHMARKS[dataset_name].get("config_name"),
|
49 |
split=BENCHMARKS[dataset_name].get("split", "train"),
|
50 |
)
|
51 |
-
for dataset_name in BENCHMARKS
|
52 |
}
|
53 |
|
54 |
|
@@ -139,6 +139,7 @@ class QuizState:
|
|
139 |
user_answers: List[Optional[str]]
|
140 |
correct_answers: List[str]
|
141 |
quiz_completed: bool
|
|
|
142 |
|
143 |
|
144 |
@dataclass
|
@@ -166,6 +167,7 @@ class BenchmarkQuiz:
|
|
166 |
user_answers=[None] * len(samples),
|
167 |
correct_answers=correct_answers,
|
168 |
quiz_completed=False,
|
|
|
169 |
)
|
170 |
return self.state
|
171 |
|
@@ -232,37 +234,43 @@ class BenchmarkQuiz:
|
|
232 |
return {"completed": False, "question_data": self.update_question()}
|
233 |
else:
|
234 |
self.state.quiz_completed = True
|
235 |
-
|
236 |
-
|
237 |
-
|
|
|
|
|
|
|
|
|
|
|
238 |
|
239 |
def previous_question(self) -> QuestionData:
|
240 |
if self.state.current_question > 0:
|
241 |
self.state.current_question -= 1
|
242 |
return self.update_question()
|
243 |
|
244 |
-
def
|
245 |
if self.state.benchmark_name == "icelandic-wiki-qa":
|
246 |
queries = [sample["question"] for sample in self.state.samples]
|
247 |
-
return
|
248 |
queries, self.state.user_answers, self.state.correct_answers
|
249 |
)
|
250 |
|
251 |
-
|
252 |
-
user_answer == correct_answer
|
253 |
for user_answer, correct_answer in zip(
|
254 |
self.state.user_answers, self.state.correct_answers
|
255 |
)
|
256 |
-
|
257 |
-
return
|
258 |
|
259 |
-
def plot_score(self,
|
|
|
260 |
scores = {**BENCHMARK_SCORES[self.state.benchmark_name], "Þú": 100 * user_score}
|
261 |
# Sort by score
|
262 |
scores = dict(sorted(scores.items(), key=lambda item: item[1]))
|
263 |
|
264 |
# Define colors for user vs models
|
265 |
-
colors = {name: "tab:blue" for name in scores.keys()}
|
266 |
colors["Þú"] = "tab:green"
|
267 |
|
268 |
fig, ax = plt.subplots(figsize=(10, 6), dpi=250)
|
@@ -276,8 +284,32 @@ class BenchmarkQuiz:
|
|
276 |
)
|
277 |
ax.set_axisbelow(True)
|
278 |
ax.xaxis.grid(True, linestyle="--", alpha=0.6)
|
279 |
-
ax.set_title(
|
|
|
|
|
|
|
280 |
ax.set_xlabel("Stig (%)")
|
281 |
ax.set_xlim(0, 100)
|
282 |
plt.tight_layout()
|
283 |
return fig
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
3 |
from typing import Any, Dict, List, Optional
|
4 |
import random
|
5 |
import matplotlib.pyplot as plt
|
6 |
+
from score import calculate_gpt4o_scores, BENCHMARK_SCORES
|
7 |
|
8 |
|
9 |
# Define benchmarks
|
|
|
48 |
name=BENCHMARKS[dataset_name].get("config_name"),
|
49 |
split=BENCHMARKS[dataset_name].get("split", "train"),
|
50 |
)
|
51 |
+
for dataset_name in BENCHMARKS
|
52 |
}
|
53 |
|
54 |
|
|
|
139 |
user_answers: List[Optional[str]]
|
140 |
correct_answers: List[str]
|
141 |
quiz_completed: bool
|
142 |
+
user_scores: List[Optional[float]]
|
143 |
|
144 |
|
145 |
@dataclass
|
|
|
167 |
user_answers=[None] * len(samples),
|
168 |
correct_answers=correct_answers,
|
169 |
quiz_completed=False,
|
170 |
+
user_scores=[None] * len(samples),
|
171 |
)
|
172 |
return self.state
|
173 |
|
|
|
234 |
return {"completed": False, "question_data": self.update_question()}
|
235 |
else:
|
236 |
self.state.quiz_completed = True
|
237 |
+
user_scores = self.calculate_scores()
|
238 |
+
self.state.user_scores = user_scores
|
239 |
+
plot = self.plot_score(user_scores)
|
240 |
+
return {
|
241 |
+
"completed": True,
|
242 |
+
"plot": plot,
|
243 |
+
"results_data": self.get_results_data(),
|
244 |
+
}
|
245 |
|
246 |
def previous_question(self) -> QuestionData:
|
247 |
if self.state.current_question > 0:
|
248 |
self.state.current_question -= 1
|
249 |
return self.update_question()
|
250 |
|
251 |
+
def calculate_scores(self) -> list[float]:
|
252 |
if self.state.benchmark_name == "icelandic-wiki-qa":
|
253 |
queries = [sample["question"] for sample in self.state.samples]
|
254 |
+
return calculate_gpt4o_scores(
|
255 |
queries, self.state.user_answers, self.state.correct_answers
|
256 |
)
|
257 |
|
258 |
+
scores = [
|
259 |
+
float(user_answer == correct_answer)
|
260 |
for user_answer, correct_answer in zip(
|
261 |
self.state.user_answers, self.state.correct_answers
|
262 |
)
|
263 |
+
]
|
264 |
+
return scores
|
265 |
|
266 |
+
def plot_score(self, user_scores: List[float]):
|
267 |
+
user_score = sum(user_scores) / len(user_scores)
|
268 |
scores = {**BENCHMARK_SCORES[self.state.benchmark_name], "Þú": 100 * user_score}
|
269 |
# Sort by score
|
270 |
scores = dict(sorted(scores.items(), key=lambda item: item[1]))
|
271 |
|
272 |
# Define colors for user vs models
|
273 |
+
colors = {name: "tab:blue" for name in scores.keys()}
|
274 |
colors["Þú"] = "tab:green"
|
275 |
|
276 |
fig, ax = plt.subplots(figsize=(10, 6), dpi=250)
|
|
|
284 |
)
|
285 |
ax.set_axisbelow(True)
|
286 |
ax.xaxis.grid(True, linestyle="--", alpha=0.6)
|
287 |
+
ax.set_title(
|
288 |
+
f"{BENCHMARKS[self.state.benchmark_name]['name']}: Svona stóðstu þig miðað við mállíkönin",
|
289 |
+
pad=20,
|
290 |
+
)
|
291 |
ax.set_xlabel("Stig (%)")
|
292 |
ax.set_xlim(0, 100)
|
293 |
plt.tight_layout()
|
294 |
return fig
|
295 |
+
|
296 |
+
def get_results_data(self) -> List[Dict[str, Any]]:
|
297 |
+
return [
|
298 |
+
{
|
299 |
+
"question_num": i + 1,
|
300 |
+
"question": sample["question"],
|
301 |
+
"user_answer": user_answer,
|
302 |
+
"correct_answer": correct_answer,
|
303 |
+
"options": sample.get("options"),
|
304 |
+
"instruction": sample.get("instruction", ""),
|
305 |
+
"points": score,
|
306 |
+
}
|
307 |
+
for i, (sample, user_answer, correct_answer, score) in enumerate(
|
308 |
+
zip(
|
309 |
+
self.state.samples,
|
310 |
+
self.state.user_answers,
|
311 |
+
self.state.correct_answers,
|
312 |
+
self.state.user_scores,
|
313 |
+
)
|
314 |
+
)
|
315 |
+
]
|