# utils/metrics.py
"""
Utility metrics and statistical tests: hit-rate, paired t-test, Wilcoxon, plotting helper.
"""
import numpy as np
from scipy.stats import ttest_rel, wilcoxon
import matplotlib.pyplot as plt

def hit_rate_from_rewards(total_reward, max_reward):
    if max_reward == 0:
        return 0.0
    return total_reward / max_reward

def paired_tests(a_list, b_list):
    t_stat, p_t = ttest_rel(a_list, b_list)
    try:
        w_p = wilcoxon(a_list, b_list).pvalue
    except Exception:
        w_p = None
    return {"ttest_p": p_t, "wilcoxon_p": w_p}

def plot_hitrate_bar(labels, values, out_path=None):
    plt.figure()
    plt.bar(labels, values, edgecolor='black')
    plt.ylim(0,1)
    plt.tight_layout()
    if out_path:
        plt.savefig(out_path)
    else:
        plt.show()
