-
Notifications
You must be signed in to change notification settings - Fork 192
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #137 from shuyansy/main
add MLVU task
- Loading branch information
Showing
3 changed files
with
145 additions
and
0 deletions.
There are no files selected for viewing
Binary file not shown.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
dataset_path: sy1998/temp | ||
dataset_kwargs: | ||
token: True | ||
cache_dir: mlvu | ||
video: True | ||
task: mlvu | ||
test_split: test | ||
output_type: generate_until | ||
doc_to_visual: !function utils.mlvu_doc_to_visual | ||
doc_to_text: !function utils.mlvu_doc_to_text | ||
doc_to_target: "answer" | ||
# The return value of process_results will be used by metrics | ||
process_results: !function utils.mlvu_process_results | ||
# Note that the metric name can be either a registed metric function (such as the case for GQA) or a key name returned by process_results | ||
metric_list: | ||
- metric: mlvu_percetion_score | ||
aggregation: !function utils.mlvu_aggregate_results | ||
higher_is_better: true | ||
|
||
|
||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,124 @@ | ||
from collections import defaultdict | ||
import os | ||
import datetime | ||
import json | ||
from lmms_eval.tasks._task_utils.file_utils import generate_submission_file | ||
from pathlib import Path | ||
import yaml | ||
import sys | ||
from typing import List, Dict, Optional, Union | ||
import re | ||
import cv2 | ||
import numpy as np | ||
from loguru import logger as eval_logger | ||
|
||
TASK_TYPES = [ | ||
"TR", | ||
"AR", | ||
"VS", | ||
"NQA", | ||
"ER", | ||
"PQA", | ||
"SSC", | ||
"AO", | ||
"AC" | ||
] | ||
|
||
|
||
|
||
hf_home = os.getenv("HF_HOME", "./~/.cache/huggingface") | ||
base_cache_dir = os.path.expanduser(hf_home) | ||
|
||
with open(Path(__file__).parent / "mlvu.yaml", "r") as f: | ||
raw_data = f.readlines() | ||
safe_data = [] | ||
for i, line in enumerate(raw_data): | ||
# remove function definition since yaml load cannot handle it | ||
if "!function" not in line: | ||
safe_data.append(line) | ||
cache_name = yaml.safe_load("".join(safe_data))["dataset_kwargs"]["cache_dir"] | ||
|
||
|
||
|
||
def mlvu_doc_to_visual(doc): | ||
|
||
cache_dir = os.path.join(base_cache_dir, cache_name) | ||
video_path = doc["video_name"] | ||
video_path = os.path.join(cache_dir, video_path) | ||
if os.path.exists(video_path): | ||
video_path = video_path | ||
else: | ||
sys.exit(f"video path:{video_path} does not exist, please check") | ||
return [video_path] | ||
|
||
|
||
def mlvu_doc_to_text(doc, model_specific_prompt_kwargs=None): | ||
# option_prompt="Carefully watch this video and pay attention to every detail. Based on your observations, select the best option that accurately addresses the question." | ||
option_prompt="" | ||
question = doc["question"] + "\nOnly give the best option.\n" | ||
full_prompt=option_prompt+"\n"+question+"\n"+"Best option: (" | ||
return full_prompt | ||
|
||
|
||
def extract_characters_regex(s): | ||
s = s.strip() | ||
if ")" in s: | ||
index=s.index(")") | ||
pred=s[index-1:index] | ||
return pred | ||
else: | ||
return s | ||
|
||
def mlvu_process_results(doc, results): | ||
""" | ||
Args: | ||
doc: a instance of the eval dataset | ||
results: [pred] | ||
Returns: | ||
a dictionary with key: metric name (in this case videomme score), value: metric value | ||
""" | ||
pred = results[0] | ||
# print("****************",pred) | ||
pred_ans = extract_characters_regex(pred) | ||
|
||
task_type = doc["task_type"] | ||
data_dict = {"question_id": doc["question"], "task_type": task_type, "pred_answer": pred_ans, "answer": doc["answer"]} | ||
|
||
return {f"mlvu_percetion_score": data_dict} | ||
|
||
|
||
def mlvu_aggregate_results(results): | ||
""" | ||
Args: | ||
results: a list of values returned by process_results | ||
Returns: | ||
A score | ||
""" | ||
category2score = {} | ||
for task_type in TASK_TYPES: | ||
category2score[task_type] = {"correct": 0, "answered": 0} | ||
|
||
|
||
for result in results: | ||
task_type = result["task_type"] | ||
category2score[task_type]["answered"] += 1 | ||
category2score[task_type]["correct"] += result["pred_answer"] == result["answer"] | ||
|
||
|
||
for task_cate in TASK_TYPES: | ||
total_correct = 0 | ||
total_answered = 0 | ||
for k, v in category2score.items(): | ||
if task_cate in k: | ||
total_correct += v["correct"] | ||
total_answered += v["answered"] | ||
eval_logger.info(f"Evaluation on Task Categories: {task_cate}: {100 * total_correct / total_answered if total_answered > 0 else 0 : .1f}%") | ||
|
||
total_correct = 0 | ||
total_answered = 0 | ||
for k, v in category2score.items(): | ||
total_correct += v["correct"] | ||
total_answered += v["answered"] | ||
eval_logger.info(f"Overall Performance: {100 * total_correct / total_answered if total_answered > 0 else 0 : .1f}%") | ||
|
||
return 100 * total_correct / total_answered if total_answered > 0 else 0 |