import matplotlib.pyplot as plt
import seaborn as sns
import os
import pickle
import numpy as np

# To run this script:
# python -m plotting.experiment_3_plot

"""
Plotting for Experiment 3

This script visualizes the transition where the mechanism becomes feasible.
It overlays the theoretical vertical line derived from the model constraints.

Input: data/exp_3/exp_3_data.pkl
Output: plots/exp_3/exp_3_incentivizability.png and .pdf
"""

def load_data():
    file_path = os.path.join('data', 'exp_3', 'exp_3_data.pkl')
    if not os.path.exists(file_path):
        raise FileNotFoundError(f"Data file not found at {file_path}. Run experiment_3.py first.")
    with open(file_path, 'rb') as f:
        return pickle.load(f)

def plot_incentivizability_cliff(data, params, filename):
    plot_dir = os.path.join('plots', 'exp_3')
    if not os.path.exists(plot_dir): 
        os.makedirs(plot_dir)
    
    # Set professional style
    sns.set_theme(context="paper", style="darkgrid", palette="deep", font_scale=1.2)
    plt.figure(figsize=(8, 6))
    
    x_vals = data['x_vals']
    y_vals = data['y_vals']
    
    # 1. Plot the Simulation Data
    plt.plot(x_vals, y_vals, 
             color='crimson', 
             linewidth=3, 
             marker='o', 
             markersize=6, 
             label='Max Reachable Attribute')
    
    # 2. Calculate Theoretical Threshold
    # Condition: c_minus >= (1 - beta * gamma) * c_plus
    beta = params['beta']
    gamma = params['gamma']
    c_plus = params['c_plus']
    
    theoretical_cliff = (1.0 - beta * gamma) * c_plus
    
    # 3. Add Vertical Line
    label_text = r'Theoretical Bound: $(1 - \beta \gamma) c^+$'
    
    plt.axvline(x=theoretical_cliff, 
                color='black', 
                linestyle='--', 
                linewidth=2, 
                alpha=0.8, 
                label=label_text)
    
    # Annotations
    plt.xlabel(r"Gaming Cost ($c^-$)", fontsize=16)
    plt.ylabel(r"Max Incentivizable Attribute ($M_{max}$)", fontsize=16)
    
    plt.legend(
        loc='upper left', 
        frameon=True, 
        framealpha=0.9,
        fontsize=13
    )
    plt.grid(True, alpha=0.3)
    plt.tight_layout()

    base_name = os.path.splitext(filename)[0]
    save_path_base = os.path.join(plot_dir, base_name)
    
    plt.savefig(f"{save_path_base}.png", dpi=300)
    plt.savefig(f"{save_path_base}.pdf")
    
    print(f"Saved plots: {base_name}.png and {base_name}.pdf")
    plt.close()

if __name__ == "__main__":
    print("Loading Experiment 4 Data...")
    try:
        results = load_data()
        params = results['params']

        plot_incentivizability_cliff(
            results['c_minus_sweep'], 
            params,
            'exp_3_incentivizability.png'
        )
        
        print("\nDone! Check the 'plots/exp_3/' directory.")
        
    except Exception as e:
        print(f"Error: {e}")