Skip to content

Commit

Permalink
Merge pull request #111 from XinrunDu/main
Browse files Browse the repository at this point in the history
add II-Bench
  • Loading branch information
Luodian authored Jun 13, 2024
2 parents 2797987 + bf14cb8 commit 4bc7224
Show file tree
Hide file tree
Showing 2 changed files with 90 additions and 0 deletions.
20 changes: 20 additions & 0 deletions lmms_eval/tasks/ii_bench/ii_bench.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
dataset_path: lmms-lab/II-Bench
task: "ii-bench"
test_split: test
output_type: generate_until
doc_to_visual: !function utils.ii_bench_doc_to_visual
doc_to_text: !function utils.ii_bench_doc_to_text
doc_to_target: "answers"
generation_kwargs:
max_new_tokens: 32
temperature: 0
do_sample: False
process_results: !function utils.ii_bench_process_results
metric_list:
- metric: submission
aggregation: !function utils.ii_bench_aggregate_submissions
model_specific_prompt_kwargs:
default:
pre_prompt: "Instruction: Please try to answer the single-answer multiple choice question below based on the picture provided.\n"
post_prompt: "\nAnswer:"

70 changes: 70 additions & 0 deletions lmms_eval/tasks/ii_bench/utils.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
import json
import logging
import re
from collections import Counter
from lmms_eval.tasks._task_utils.file_utils import generate_submission_file

PROMPT = """Question: {}
(A) {}
(B) {}
(C) {}
(D) {}
(E) {}
(F) {}"""

def ii_bench_doc_to_text(doc, model_specific_prompt_kwargs):
question = PROMPT.format(doc["question"], doc["option1"], doc["option2"], doc["option3"], doc["option4"], doc["option5"], doc["option6"])
pre_prompt = model_specific_prompt_kwargs["pre_prompt"]
post_prompt = model_specific_prompt_kwargs["post_prompt"]
return f"{pre_prompt}{question}{post_prompt}"


def ii_bench_doc_to_visual(doc):
return [doc["image"].convert("RGB")]


def extract_option_labels(text, options=None):
if isinstance(text, dict):
return 'error'
pattern = r"\(([A-F])\)"
matches = re.findall(pattern, text)

if not matches:
pattern = r"\b([A-F])\b"
matches = re.findall(pattern, text)

if matches:
counter = Counter(matches)
most_common = counter.most_common()
max_count = most_common[0][1]
candidates = [item for item in most_common if item[1] == max_count]
return candidates[-1][0]
else:
if options:
counter = Counter()
for i, option in enumerate(options, start=1):
label = chr(64 + i)
option_stripped = option.strip()
if option_stripped in text:
counter[label] += 1
elif text in option:
counter[label] += 1
if counter:
most_common = counter.most_common()
max_count = most_common[0][1]
candidates = [item for item in most_common if item[1] == max_count]
return candidates[-1][0]
return None


def ii_bench_process_results(doc, results):
response = results[0]
predict = extract_option_labels(response, [doc["option1"], doc["option2"], doc["option3"], doc["option4"], doc["option5"], doc["option6"]])
return {"submission": {"id": doc["id"], "predict_answer": predict, "response": response}}


def ii_bench_aggregate_submissions(results, args):
file = generate_submission_file("ii_bench_test_for_submission.json", args)
with open(file, "w") as f:
json.dump(results, f, indent=4)
logging.getLogger("lmms-eval").info(f"Results saved to {file}")

0 comments on commit 4bc7224

Please sign in to comment.