-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathparse_if_eval.py
62 lines (50 loc) · 2.05 KB
/
parse_if_eval.py
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
import json
import os
import argparse
import pandas as pd
from utils.metric_fns import METRIC_FNS
from utils.dataset_loading import get_dataframe_from_local_file
from utils.task_metadata import get_metadata_for_task
from parse_responses import get_pbase_response
from utils.instruction_following_eval.evaluation_main import read_prompt_to_response_dict
def main(main_args):
task_metadata = get_metadata_for_task(main_args.task)
df = get_dataframe_from_local_file(task_metadata, main_args.num_examples)
skipped = []
metric_fn = METRIC_FNS[task_metadata["metric_name"]]
scores = []
with open(main_args.jsonl_responses_path) as file:
for line in file:
prompt_to_response = read_prompt_to_response_dict(main_args.jsonl_responses_path)
response_data = json.loads(line)
metadata = response_data[2]
df_index = metadata["df_index"]
target=df.loc[df.index == df_index]
score = metric_fn(target, prompt_to_response)
scores.append(score)
overall_score = sum(scores) / len(scores)
print(f"Overall {task_metadata['metric_name']}: {overall_score:.3f}")
print(f"Skipped {len(skipped)} examples: {skipped}")
with open(
os.path.join(os.path.dirname(main_args.jsonl_responses_path), f"skipped.txt"),
"w",
) as file:
file.write(f"Skipped {len(skipped)} examples: {skipped}")
with open(
os.path.join(
os.path.dirname(main_args.jsonl_responses_path),
f"{task_metadata['metric_name']}.txt",
),
"w",
) as file:
file.write(f"Overall {task_metadata['metric_name']}: {overall_score:.3f}")
if __name__ == "__main__":
parser = argparse.ArgumentParser(
prog="Parse responses from Predibase.",
description="Parse responses from Predibase.",
)
parser.add_argument("--jsonl_responses_path", required=True)
parser.add_argument("--task", required=True)
parser.add_argument("--num_examples", default=None)
main_args = parser.parse_args()
main(main_args)