|
|
|
|
|
|
|
|
import argparse |
|
|
import json |
|
|
import os |
|
|
import os.path as osp |
|
|
import gradio as gr |
|
|
import numpy as np |
|
|
|
|
|
from tasks.eval.recaption import load_results as load_results_recaption |
|
|
from tasks.eval.mvbench import load_results as load_results_mvbench |
|
|
from tasks.eval.vcgbench import load_results as load_results_vcgbench |
|
|
from tasks.eval.videoqabench import load_results as load_results_videoqabench |
|
|
from tasks.eval.demo import pllava_theme |
|
|
|
|
|
|
|
|
load_results_funcs = [ |
|
|
load_results_recaption, |
|
|
load_results_mvbench, |
|
|
load_results_vcgbench, |
|
|
load_results_videoqabench, |
|
|
] |
|
|
|
|
|
|
|
|
def parse_args(): |
|
|
parser = argparse.ArgumentParser() |
|
|
parser.add_argument( |
|
|
'--root_dir', |
|
|
required=True, |
|
|
) |
|
|
args = parser.parse_args() |
|
|
return args |
|
|
|
|
|
args = parse_args() |
|
|
root_dir = args.root_dir |
|
|
|
|
|
def show(result_list_first, result_list_second, result_index): |
|
|
sample2index_second = {} |
|
|
|
|
|
for i, result in enumerate(result_list_second): |
|
|
if 'video_path' not in result: |
|
|
continue |
|
|
|
|
|
question = result['question'] if 'question' in result else '' |
|
|
video_path = result['video_path'] |
|
|
samplehash = question + '--' +video_path |
|
|
sample2index_second[samplehash] = i |
|
|
|
|
|
info = result_list_first[result_index] |
|
|
info_str_first = json.dumps(info, indent=4, ensure_ascii=False) |
|
|
video_path = info['video_path'] |
|
|
question = info['question'] if 'question' in info else '' |
|
|
samplehash = question + '--' +video_path |
|
|
if samplehash in sample2index_second: |
|
|
info = result_list_second[sample2index_second[samplehash]] |
|
|
info_str_second = json.dumps(info, indent=4, ensure_ascii=False) |
|
|
else: |
|
|
info_str_second = f"NO {video_path} IN THE SECOND RESULT DIR" |
|
|
return video_path, info_str_first, info_str_second |
|
|
|
|
|
def reload_results_dirs(): |
|
|
result_dirs = [] |
|
|
|
|
|
for dirpath, dirnames, filenames in os.walk(args.root_dir): |
|
|
if len(dirnames) == 0 and len(filenames) != 0: |
|
|
result_dirs.append(dirpath) |
|
|
return gr.Dropdown(result_dirs, value=result_dirs[0]) |
|
|
|
|
|
def reload_results(result_dir): |
|
|
|
|
|
|
|
|
|
|
|
if result_dir is None or not osp.exists(result_dir): |
|
|
return None |
|
|
|
|
|
for fn in load_results_funcs: |
|
|
result_list = fn(result_dir) |
|
|
if result_list is not None: |
|
|
np.random.shuffle(result_list) |
|
|
break |
|
|
result_index = gr.Slider(0, len(result_list), step=1) |
|
|
|
|
|
return result_list, result_index |
|
|
|
|
|
|
|
|
|
|
|
with gr.Blocks(title="PLLAVA RESULTS", theme=pllava_theme) as demo: |
|
|
result_list_first = gr.State() |
|
|
result_list_second = gr.State() |
|
|
|
|
|
with gr.Row(): |
|
|
with gr.Column(): |
|
|
gr.Markdown("# Showing off Model's Outputs.") |
|
|
gr.Markdown( |
|
|
"You can find all our results, including:\n" |
|
|
"1. results of Captioned Inter4k\n" |
|
|
"2. results of Different Benchmark inference outputs.\n" |
|
|
"Choose a directory to see the different output variant.\n" |
|
|
"You can also choose secondary directory (as long as they are from the same dataset.) to compare on the results.\n" |
|
|
) |
|
|
|
|
|
with gr.Row(): |
|
|
with gr.Column(): |
|
|
show_video = gr.Video(interactive=False) |
|
|
|
|
|
with gr.Column(): |
|
|
button_reload = gr.Button(value='Reload From The Evaluation/Inference Root Directory') |
|
|
result_index = gr.Slider(0, 0, step=1, label="Index") |
|
|
|
|
|
result_dir_first = gr.Dropdown(label='Test Result Path') |
|
|
info_first = gr.Text(interactive=False, label='Detailed Output Information') |
|
|
result_dir_second = gr.Dropdown(label='Test Result Path') |
|
|
info_second = gr.Text(interactive=False, label='Detailed Output Information') |
|
|
|
|
|
|
|
|
button_reload.click(reload_results_dirs, [], [result_dir_first]) |
|
|
button_reload.click(reload_results_dirs, [], [result_dir_second]) |
|
|
result_dir_first.change(reload_results, [result_dir_first], [result_list_first, result_index]) |
|
|
result_dir_second.change(reload_results, [result_dir_second], [result_list_second, result_index]) |
|
|
result_index.change(show, [result_list_first, result_list_second, result_index], [show_video, info_first, info_second]) |
|
|
demo.load(reload_results_dirs, [], [result_dir_first]) |
|
|
demo.load(reload_results_dirs, [], [result_dir_second]) |
|
|
|
|
|
demo.launch(share=True) |