import matplotlib.pyplot as plt
import numpy as np
import os

path = "bp_results_new.txt"

results = [[], [], []]

with open(path, "r") as fr:
    lines = fr.readlines()
    for line in lines:
        words = line.strip().split(":")
        if words[0] == "prior":
            ratio = float(words[1].strip())
            results[0].append(ratio)
        elif words[0] == "1-stage":
            acc = float(words[2].strip())
            results[1].append(acc)
        elif words[0] == "2-stage":
            acc = float(words[2].strip())
            results[2].append(acc)

    ratios = results[0]
    stage1_acc = results[1]
    stage2_acc = results[2]

    # Sort ratios and corresponding accuracies in ascending order of ratios
    sorted_data = sorted(zip(ratios, stage1_acc, stage2_acc), key=lambda x: x[0])
    ratios, stage1_acc, stage2_acc = zip(*sorted_data)

    x = np.arange(len(ratios))  # the label locations
    width = 0.35  # the width of the bars

    fig, ax = plt.subplots()
    rects1 = ax.bar(x - width/2, stage1_acc, width, label='1-stage')
    rects2 = ax.bar(x + width/2, stage2_acc, width, label='2-stage')

    # Add some text for labels, title and custom x-axis tick labels, etc.
    ax.set_xlabel('Prior')
    ax.set_ylabel('Accuracy')
    ax.set_title('Comparison of 1-stage and 2-stage for BP')
    ax.set_xticks(x)
    ax.set_xticklabels([f"{r:.2f}" for r in ratios])
    ax.legend()

    fig.tight_layout()
    plt.savefig("bp_new.png")
    plt.show()