"""
Plot Figure 3 from saved data using Type 1 fonts only.
"""

import numpy as np
import matplotlib.pyplot as plt
from pathlib import Path
import json

plt.rcParams.update({
    'text.usetex': True,
    'font.family': 'serif',
    'font.serif': ['Computer Modern'],
    'font.size': 10,
    'axes.labelsize': 11,
    'axes.titlesize': 11,
    'legend.fontsize': 9,
    'figure.dpi': 150,
    'pdf.fonttype': 42,
    'ps.fonttype': 42,
})


def exponential_saturation(K, c, beta):
    """Simplified exponential saturation: G_K = c * (1 - exp(-beta*K))"""
    return c * (1 - np.exp(-beta * K))


data_path = Path(__file__).parent / 'fig3_publication_data.json'
with open(data_path, 'r') as f:
    data = json.load(f)

panel_a = data['panel_a']
panel_b = data['panel_b']

fig, axes = plt.subplots(1, 2, figsize=(9, 3.5))

ax = axes[0]
K = np.array(panel_a['K_values'])
mean_gaps = np.array(panel_a['mean_gaps'])
c = panel_a['c']
beta = panel_a['beta']
R_sq_a = panel_a['R_squared']

ax.plot(K, mean_gaps, 'o', color='#2E86AB', markersize=5,
        label='Data', zorder=3)

if c is not None:
    K_fine = np.linspace(0, K[-1], 200)
    fitted_fine = exponential_saturation(K_fine, c, beta)
    ax.plot(K_fine, fitted_fine, '-', color='#E94F37', linewidth=2,
            label=r'$G_K = c(1-e^{-\beta K})$')
    ax.axhline(y=c, color='gray', linestyle='--', alpha=0.6, linewidth=1)

ax.set_xlabel(r'Adaptation Steps $K$')
ax.set_ylabel(r'Adaptation Gap $G_K$')
ax.set_title('(a) Exponential Saturation')
ax.set_xlim(-1, K[-1] + 1)
ax.set_ylim(bottom=0)
ax.grid(True, alpha=0.3)
ax.legend(loc='lower right', framealpha=0.9)

ax = axes[1]
sigma_sq = np.array(panel_b['actual_variance'])
G_inf = np.array(panel_b['G_inf_means'])
slope = panel_b['slope']
intercept = panel_b['intercept']
R_sq_b = panel_b['R_squared']

ax.plot(sigma_sq, G_inf, 's', color='#2E86AB', markersize=6,
        label='Data', zorder=3)

sigma_sq_fine = np.linspace(0, sigma_sq.max() * 1.05, 100)
fitted_line = slope * sigma_sq_fine + intercept
ax.plot(sigma_sq_fine, fitted_line, '-', color='#E94F37', linewidth=2,
        label=r'$G_\infty \propto \sigma^2_\tau$')

ax.set_xlabel(r'Task Variance $\sigma^2_\tau$')
ax.set_ylabel(r'Asymptotic Gap $G_\infty$')
ax.set_title('(b) Linear Scaling')
ax.set_xlim(left=0)
ax.set_ylim(bottom=0)
ax.grid(True, alpha=0.3)
ax.legend(loc='lower right', framealpha=0.9)

plt.tight_layout()

output_dir = Path(__file__).parent
plt.savefig(output_dir / 'fig3_publication.png', dpi=300, bbox_inches='tight')
plt.savefig(output_dir / 'fig3_publication.pdf', bbox_inches='tight')
print("Saved: fig3_publication.png/pdf (with Type 1 fonts)")
