
import matplotlib.pyplot as plt
import pandas as pd
import os

def plot_combined(directory, output_folder):
    if not os.path.exists(output_folder):
        os.makedirs(output_folder)

    mean_response_times = {}
    best_action_probabilities = {}
    num_actions = None

    # List all CSV files in the directory
    for filename in os.listdir(directory):
        if filename.endswith("-summary.csv"):  
            method_name = filename.replace("-summary.csv", "")
            filepath = os.path.join(directory, filename)

            # Read the summary data
            summary_data = pd.read_csv(filepath)

            if 'num_actions' in summary_data.columns:
                if num_actions is None:
                    num_actions = summary_data['num_actions'].values

                # Mean Response Time data
                if 'mean_response_time' in summary_data.columns:
                    mean_response_time = summary_data['mean_response_time'].values
                    lower_bound = summary_data.get('lower_bound_response_time', mean_response_time).values
                    upper_bound = summary_data.get('upper_bound_response_time', mean_response_time).values
                    mean_response_times[method_name] = (mean_response_time, lower_bound, upper_bound)

                # Best Action Chosen Probability data
                if 'mean_best_action' in summary_data.columns:
                    mean_best_action = summary_data['mean_best_action'].values
                    lower_bound = summary_data.get('lower_bound_best_action', mean_best_action).values
                    upper_bound = summary_data.get('upper_bound_best_action', mean_best_action).values
                    best_action_probabilities[method_name] = (mean_best_action, lower_bound, upper_bound)

    # Check if we found any data
    if not mean_response_times and not best_action_probabilities:
        print("No data found. Checking available files:")
        for filename in os.listdir(directory):
            if filename.endswith(".csv"):
                print(f"  - {filename}")
        return

    # Plot Mean Response Time for all methods
    if mean_response_times:
        plt.figure(figsize=(12, 6))
        for method, (mean, lower, upper) in mean_response_times.items():
            plt.plot(num_actions, mean, label=f'{method}', marker='o')
            plt.fill_between(num_actions, lower, upper, alpha=0.1)
        plt.xlabel('Number of Actions')
        plt.ylabel('Mean Response Time')
        plt.title('Mean Response Time for All Methods')
        plt.legend(bbox_to_anchor=(1.05, 1), loc='upper left')
        plt.grid(True, alpha=0.3)
        plt.tight_layout()
        plt.savefig(os.path.join(output_folder, 'combined_mean_response_time_all_methods.pdf'), bbox_inches='tight')
        plt.close()
        print("Mean response time plot saved.")

    # Plot Best Action Chosen Probability for all methods
    if best_action_probabilities:
        plt.figure(figsize=(12, 6))
        for method, (mean, lower, upper) in best_action_probabilities.items():
            plt.plot(num_actions, mean, label=f'{method}', marker='o')
            plt.fill_between(num_actions, lower, upper, alpha=0.1)
        plt.xlabel('Number of Actions')
        plt.ylabel('Best Action Chosen Probability')
        plt.title('Best Action Chosen Probability for All Methods')
        plt.legend(bbox_to_anchor=(1.05, 1), loc='upper left')
        plt.grid(True, alpha=0.3)
        plt.tight_layout()
        plt.savefig(os.path.join(output_folder, 'combined_best_action_probability_all_methods.pdf'), bbox_inches='tight')
        plt.close()
        print("Best action probability plot saved.")

if __name__ == "__main__":
    directory = 'all_method_data'  
    output_folder = 'plot_outputs'

    plot_combined(directory, output_folder)