from pathlib import Path
import json

def format_number(num):
    s = f"{num:.2f}"
    if s.startswith('-0'):
        return '-' + s[2:]
    elif s.startswith('0'):
        return s[1:]
    return s
g = format_number
print(format_number(0.256))   # 输出 .25
print(format_number(-0.256))  # 输出 -.25
print(format_number(1.254))   # 输出 1.25
print(format_number(0.005))   # 输出 .00

database_path = Path(__file__).resolve().parent.parent / "database"
final_res_file = database_path / "final_res.json"
with open(final_res_file, "r") as fp:
    final_res = json.load(fp)

llm_names = ["CogVideoX1.5-5b", "Hailuo", "Pika", "pyramid_flux", "CogVideoX-2b", "videocrafter2_base", "CogVideoX-5b", "HunyuanVideo", "Gen-3-Alpha"]

for llm_name, res in final_res.items():
    print(f'{llm_name} & {g(res["nan_ratio"])} & ${g(res["metric_1_all_ignore"]["mean"])}\mathsmaller{{\pm {g(res["metric_1_all_ignore"]["std"])}}}$' +\
          f' & ${g(res["metric_1_roots_ignore"]["mean"])}\mathsmaller{{\pm {g(res["metric_1_roots_ignore"]["std"])}}}$' +\
          f' & ${g(res["metric_2_truth"]["mean"])}\mathsmaller{{\pm {g(res["metric_2_truth"]["std"])}}}$' +\
          f' & ${g(res["metric_2_observe"]["mean"])}\mathsmaller{{\pm {g(res["metric_2_observe"]["std"])}}}$' +\
          f' & ${g(res["metric_3_truth"]["mean"])}\mathsmaller{{\pm {g(res["metric_3_truth"]["std"])}}}$' +\
          f' & ${g(res["metric_3_observe"]["mean"])}\mathsmaller{{\pm {g(res["metric_3_observe"]["std"])}}}$'
          )
    
    print(f'{llm_name} & {g(res["level_1"]["nan_ratio"])} & {g(res["level_1"]["correct_ratio"])} & {g(1-res["level_1"]["nan_ratio"]-res["level_1"]["correct_ratio"])}')
    
print_threshold = True
if print_threshold:
    thresholds = [0.65, 0.75, 0.85, 0.95]
    final_res_threshold_file = database_path / "final_res_threshold.json"
    with open(final_res_threshold_file, "r") as fp:
        res_t = json.load(fp)
    
    for llm_name, res in res_t.items():
        out_str = f"{llm_name} "
        for metric in ["metric_3_truth", "metric_3_observe"]:
            for threshold in thresholds:
                key = f"{metric}_{threshold}"
                term = res[key]
                out_str += f'& ${g(term["mean"])} \mathsmaller{{\pm {g(term["std"])}}}$ '
        print(out_str)
