import os
import numpy as np
import matplotlib.pyplot as plt

def load_configs():
    """加载问题配置"""
    with open('problem_configs.txt', 'r', encoding='utf-8') as f:
        config_content = f.read()
    config_content = config_content.replace("problem_configs = ", "")
    return eval(config_content)

def set_plot_style():
    """设置全局绘图样式"""
    plt.rcParams['font.family'] = 'Times New Roman'
    plt.rcParams['axes.unicode_minus'] = False
    plt.rcParams['mathtext.fontset'] = 'stix'  # 数学公式字体
    plt.rcParams['xtick.major.size'] = 0  # 删除刻度线
    plt.rcParams['ytick.major.size'] = 0  # 删除刻度线
    plt.rcParams['axes.spines.top'] = False  # 移除上边框
    plt.rcParams['axes.spines.right'] = False  # 移除右边框
    plt.rcParams['axes.spines.left'] = False  # 保留左边框
    plt.rcParams['axes.spines.bottom'] = False  # 保留下边框
    plt.rcParams['axes.facecolor'] = '#f0f0f0'  # 设置非常淡的灰色背景

def get_sigma_values():
    """获取所有的σ值"""
    return [0, 0.33, 0.66, 1, 2, 3]

def get_action_model_for_sigma(sigma):
    """根据σ值获取对应的action_model"""
    sigma_to_model = {
        0: 0,
        0.33: 1,
        0.66: 2,
        1: 3,
        2: 4,
        3: 5
    }
    return sigma_to_model.get(sigma, None)

def calculate_average_probability():
    """计算每个σ值对应的平均概率"""
    prob_dir = "probability"
    problem_configs = load_configs()
    sigma_values = get_sigma_values()
    sigma_probs = {sigma: [] for sigma in sigma_values}

    # 遍历每个问题
    for problem_name in problem_configs.keys():
        # 对每个σ值
        for sigma in sigma_values:
            action_model = get_action_model_for_sigma(sigma)
            if action_model is None:
                continue

            # 读取对应的概率文件
            prob_file = os.path.join(prob_dir, f"{problem_name}_action{action_model}_probability.txt")
            if not os.path.exists(prob_file):
                continue

            # 读取概率数据
            with open(prob_file, 'r') as f:
                lines = f.readlines()[1:]  # 跳过标题行
                probs = [float(line.strip().split('\t')[1]) for line in lines]
                # 计算这个轨迹的平均概率
                avg_prob = np.mean(probs)
                sigma_probs[sigma].append(avg_prob)

    # 计算每个σ值的平均值和标准差
    means = []
    stds = []
    for sigma in sigma_values:
        if sigma_probs[sigma]:
            means.append(np.mean(sigma_probs[sigma]))
            stds.append(np.std(sigma_probs[sigma]))
        else:
            means.append(0)
            stds.append(0)

    return sigma_values, means, stds

def plot_sigma_probability():
    """绘制σ值与平均概率的关系图"""
    set_plot_style()
    plt.figure(figsize=(8, 6))

    # 获取数据
    sigma_values, means, stds = calculate_average_probability()

    # 绘制主线
    plt.plot(sigma_values, means, 
            marker='o',
            linestyle='-',
            color='#1f77b4',  # 蓝色
            linewidth=2,
            markersize=8)

    # 添加误差区域
    plt.fill_between(sigma_values,
                    np.array(means) - np.array(stds),
                    np.array(means) + np.array(stds),
                    color='#1f77b4',
                    alpha=0.2)

    # 设置图表属性
    plt.xlabel('Value of deception weight σ', fontsize=20)
    plt.ylabel('Average probability of real goal state', fontsize=20)
    plt.grid(True, alpha=0.3)
    plt.tick_params(axis='both', which='major', labelsize=20)

    # 设置y轴范围
    plt.ylim(-0.05, 1.05)

    # 保存图表
    os.makedirs("Deceptiveness", exist_ok=True)
    plt.savefig(os.path.join("Deceptiveness", "sigma_probability.pdf"),
                bbox_inches='tight', format='pdf')
    plt.savefig(os.path.join("Deceptiveness", "sigma_probability.png"),
                bbox_inches='tight', dpi=300)
    plt.close()

def main():
    """主函数"""
    print("Creating sigma-probability plot...")
    plot_sigma_probability()
    print("Plot complete!")

if __name__ == "__main__":
    main()
